lavva.exalushome 2.0.129 → 2.0.131

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.
Files changed (143) hide show
  1. package/build/exalushome-library-bundle.js +1 -1
  2. package/build/exalushome-library-bundle.js.map +1 -1
  3. package/build/js/Api.js +127 -127
  4. package/build/js/Api.js.map +1 -1
  5. package/build/js/AsyncLock.js +15 -15
  6. package/build/js/AsyncSemaphore.js +44 -44
  7. package/build/js/AsyncSemaphore.js.map +1 -1
  8. package/build/js/CancelationTokenSource.js +18 -18
  9. package/build/js/DataFrame.js +86 -86
  10. package/build/js/DependencyContainer.js +87 -87
  11. package/build/js/DependencyContainer.js.map +1 -1
  12. package/build/js/Event.js +24 -24
  13. package/build/js/Event.js.map +1 -1
  14. package/build/js/Guid.js +8 -8
  15. package/build/js/Helpers.js +132 -132
  16. package/build/js/Helpers.js.map +1 -1
  17. package/build/js/IDIService.js +1 -1
  18. package/build/js/INetworkService.js +41 -41
  19. package/build/js/Services/AppStateService.js +217 -217
  20. package/build/js/Services/AppStateService.js.map +1 -1
  21. package/build/js/Services/Chat/ChatImplementations/ControllerChat/ControllerChat.js +224 -224
  22. package/build/js/Services/Chat/ChatImplementations/ControllerChat/ControllerChat.js.map +1 -1
  23. package/build/js/Services/Chat/ChatImplementations/ControllerChat/IControllerChat.js +33 -33
  24. package/build/js/Services/Chat/ChatImplementations/FamillyChat/FamillyChat.js +147 -147
  25. package/build/js/Services/Chat/ChatImplementations/FamillyChat/FamillyChat.js.map +1 -1
  26. package/build/js/Services/Chat/ChatImplementations/FamillyChat/IFamillyChat.js +1 -1
  27. package/build/js/Services/Chat/ChatImplementations/GptChat/GptChat.js +184 -184
  28. package/build/js/Services/Chat/ChatImplementations/GptChat/GptChat.js.map +1 -1
  29. package/build/js/Services/Chat/ChatImplementations/GptChat/IGptChat.js +26 -26
  30. package/build/js/Services/Chat/ChatService.js +43 -43
  31. package/build/js/Services/Chat/ChatService.js.map +1 -1
  32. package/build/js/Services/Chat/IChatService.js +6 -6
  33. package/build/js/Services/Controller/ConnectedAppsService.js +117 -117
  34. package/build/js/Services/Controller/ConnectedAppsService.js.map +1 -1
  35. package/build/js/Services/Controller/ControllerConfigurationService.js +425 -425
  36. package/build/js/Services/Controller/ControllerConfigurationService.js.map +1 -1
  37. package/build/js/Services/Controller/ControllerExtensionsService.js +148 -148
  38. package/build/js/Services/Controller/ControllerExtensionsService.js.map +1 -1
  39. package/build/js/Services/Controller/FindControllerService.js +155 -155
  40. package/build/js/Services/Controller/FindControllerService.js.map +1 -1
  41. package/build/js/Services/Controller/GeolocationService.js +111 -111
  42. package/build/js/Services/Controller/GeolocationService.js.map +1 -1
  43. package/build/js/Services/Controller/IConnectedAppsService.js +24 -24
  44. package/build/js/Services/Controller/IControllerConfigurationService.js +1 -1
  45. package/build/js/Services/Controller/IControllerExtensionsService.js +1 -1
  46. package/build/js/Services/Controller/IGeolocationService.js +20 -20
  47. package/build/js/Services/DataMigrationService.js +224 -224
  48. package/build/js/Services/DataMigrationService.js.map +1 -1
  49. package/build/js/Services/Devices/ChannelsGroupsService.js +696 -696
  50. package/build/js/Services/Devices/ChannelsGroupsService.js.map +1 -1
  51. package/build/js/Services/Devices/Device.js +248 -248
  52. package/build/js/Services/Devices/Device.js.map +1 -1
  53. package/build/js/Services/Devices/DeviceChannel.js +304 -304
  54. package/build/js/Services/Devices/DeviceChannel.js.map +1 -1
  55. package/build/js/Services/Devices/DevicesService.js +1223 -1215
  56. package/build/js/Services/Devices/DevicesService.js.map +1 -1
  57. package/build/js/Services/Devices/IChannelsGroupsService.js +109 -109
  58. package/build/js/Services/Devices/IChannelsGroupsService.js.map +1 -1
  59. package/build/js/Services/Devices/IDevice.js +198 -198
  60. package/build/js/Services/Devices/IDeviceChannel.js +48 -48
  61. package/build/js/Services/Devices/IDeviceConfigService.js +1 -1
  62. package/build/js/Services/Devices/IDeviceState.js +995 -995
  63. package/build/js/Services/Devices/IDeviceState.js.map +1 -1
  64. package/build/js/Services/Devices/IDeviceTask.js +36 -36
  65. package/build/js/Services/Devices/IDevicesService.js +9 -9
  66. package/build/js/Services/Devices/IManuallyPairedDevicesProtocolService.js +1 -1
  67. package/build/js/Services/Devices/IManuallyPairedDevicesService.js +1 -1
  68. package/build/js/Services/Devices/ManuallyPairedDevicesService.js +68 -68
  69. package/build/js/Services/Devices/ManuallyPairedDevicesService.js.map +1 -1
  70. package/build/js/Services/Devices/TaskExecutionResult.js +9 -9
  71. package/build/js/Services/Devices/Tasks/DeviceTask.js +42 -42
  72. package/build/js/Services/Devices/Tasks/Tasks.js +216 -216
  73. package/build/js/Services/Devices/dist/DevicesService.d.ts +17 -17
  74. package/build/js/Services/ExalusConnectionService.js +510 -510
  75. package/build/js/Services/ExalusConnectionService.js.map +1 -1
  76. package/build/js/Services/FieldChangeResult.js +51 -51
  77. package/build/js/Services/IAppStateService.js +66 -66
  78. package/build/js/Services/IExalusConnectionService.js +31 -31
  79. package/build/js/Services/ILocalStorageService.js +1 -1
  80. package/build/js/Services/IRemoteStorageService.js +8 -8
  81. package/build/js/Services/LocalNetworkExalusConnectionService.js +289 -289
  82. package/build/js/Services/LocalNetworkExalusConnectionService.js.map +1 -1
  83. package/build/js/Services/LocalStorageService.js +38 -38
  84. package/build/js/Services/LocalStorageService.js.map +1 -1
  85. package/build/js/Services/Logging/ILoggerService.js +8 -8
  86. package/build/js/Services/Logging/LoggerService.js +132 -132
  87. package/build/js/Services/Logging/LoggerService.js.map +1 -1
  88. package/build/js/Services/Notifications/ControllerNotificationsService.js +325 -325
  89. package/build/js/Services/Notifications/ControllerNotificationsService.js.map +1 -1
  90. package/build/js/Services/Notifications/IControllerNotificationsService.js +51 -51
  91. package/build/js/Services/PictureInPicture.js +28 -28
  92. package/build/js/Services/PictureInPicture.js.map +1 -1
  93. package/build/js/Services/Pictures/IPicture.js +6 -6
  94. package/build/js/Services/Pictures/IPicturesService.js +1 -1
  95. package/build/js/Services/Pictures/Picture.js +50 -50
  96. package/build/js/Services/Pictures/PicturesService.js +441 -441
  97. package/build/js/Services/Pictures/PicturesService.js.map +1 -1
  98. package/build/js/Services/RemoteStorageService.js +122 -122
  99. package/build/js/Services/RemoteStorageService.js.map +1 -1
  100. package/build/js/Services/Scenes/IScenesService.js +7 -7
  101. package/build/js/Services/Scenes/LeftArgumentTypes.js +166 -166
  102. package/build/js/Services/Scenes/LeftArgumentTypes.js.map +1 -1
  103. package/build/js/Services/Scenes/SceneTaskTypes.js +32 -32
  104. package/build/js/Services/Scenes/Scenes.js +134 -134
  105. package/build/js/Services/Scenes/ScenesBuilder.js +1097 -1097
  106. package/build/js/Services/Scenes/ScenesBuilder.js.map +1 -1
  107. package/build/js/Services/Scenes/ScenesService.js +1131 -1131
  108. package/build/js/Services/Scenes/ScenesService.js.map +1 -1
  109. package/build/js/Services/Scenes/dist/ScenesService.d.ts +5 -5
  110. package/build/js/Services/Session/ISessionService.js +8 -8
  111. package/build/js/Services/Session/SessionService.js +225 -225
  112. package/build/js/Services/Session/SessionService.js.map +1 -1
  113. package/build/js/Services/StatesHistory/IStatesHistoryService.js +12 -12
  114. package/build/js/Services/StatesHistory/StatesHistory.js +75 -75
  115. package/build/js/Services/StatesHistory/StatesHistoryService.js +235 -235
  116. package/build/js/Services/StatesHistory/StatesHistoryService.js.map +1 -1
  117. package/build/js/Services/SupportedDevices/ISupportedDevicesService.js +115 -115
  118. package/build/js/Services/SupportedDevices/SupportedDevicesService.js +26 -26
  119. package/build/js/Services/Updates/CustomUpdateActions/ICustomUpdateActions.js +1 -1
  120. package/build/js/Services/Updates/IUpdateInfo.js +69 -69
  121. package/build/js/Services/Updates/IUpdatesProvider.js +48 -48
  122. package/build/js/Services/Updates/IUpdatesService.js +139 -139
  123. package/build/js/Services/Updates/UpdateProviderServices/IControllerModulesUpdatesProviderService.js +1 -1
  124. package/build/js/Services/Updates/UpdateProviderServices/IDeviceUpdateProviderService.js +1 -1
  125. package/build/js/Services/Updates/UpdateProviderServices/IUpdateProviderService.js +1 -1
  126. package/build/js/Services/Updates/UpdatesProvider.js +212 -212
  127. package/build/js/Services/Updates/UpdatesProvider.js.map +1 -1
  128. package/build/js/Services/Updates/UpdatesService.js +1556 -1556
  129. package/build/js/Services/Updates/UpdatesService.js.map +1 -1
  130. package/build/js/Services/Updates/dist/UpdatesService.d.ts +9 -9
  131. package/build/js/Services/Users/IUser.js +21 -21
  132. package/build/js/Services/Users/IUsersService.js +1 -1
  133. package/build/js/Services/Users/User.js +111 -111
  134. package/build/js/Services/Users/UsersService.js +302 -302
  135. package/build/js/Services/Users/UsersService.js.map +1 -1
  136. package/build/js/Services/WebApi/IWebApiCacheService.js +1 -1
  137. package/build/js/Services/WebApi/WebApiCacheService.js +42 -42
  138. package/build/js/Services/WebApi/WebApiCacheService.js.map +1 -1
  139. package/build/js/TypedEvent.js +23 -23
  140. package/build/js/TypedEvent.js.map +1 -1
  141. package/build/js/dist/Api.d.ts +12 -12
  142. package/build/tsconfig.tsbuildinfo +1 -1
  143. package/package.json +7 -7
@@ -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:()=>mv});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_${mv.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 y extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class m 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 D{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 T(e,t){let n="";return k(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 k(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function G(e,t,n,r,s,o){const i={},[a,c]=E();i[a]=c,e.log(S.Trace,`(${t} transport) sending data. ${T(s,o.logMessageContent)}.`);const u=k(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 D.isNode&&(e="User-Agent"),[e,I(A,R(),D.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(!D.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(D.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||{},k(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 D.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&&(k(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||D.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. ${T(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?G(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(D.isBrowser||D.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. ${T(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?G(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 K{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(D.isNode||D.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. ${T(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. ${T(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 j{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(D.isNode){const e=require;r=e("ws"),s=e("eventsource")}D.isNode||"undefined"==typeof WebSocket||t.WebSocket?D.isNode&&!t.WebSocket&&r&&(t.WebSocket=r):t.WebSocket=WebSocket,D.isNode||"undefined"==typeof EventSource||t.EventSource?D.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 m(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 y(`${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 K(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(!D.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(k(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(),D.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,D.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 j(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,y=-1732584194,m=271733878;for(u=0;u<g.length;u+=16)l=f,d=v,h=y,p=m,f=o(f,v,y,m,g[u+0],7,-680876936),m=o(m,f,v,y,g[u+1],12,-389564586),y=o(y,m,f,v,g[u+2],17,606105819),v=o(v,y,m,f,g[u+3],22,-1044525330),f=o(f,v,y,m,g[u+4],7,-176418897),m=o(m,f,v,y,g[u+5],12,1200080426),y=o(y,m,f,v,g[u+6],17,-1473231341),v=o(v,y,m,f,g[u+7],22,-45705983),f=o(f,v,y,m,g[u+8],7,1770035416),m=o(m,f,v,y,g[u+9],12,-1958414417),y=o(y,m,f,v,g[u+10],17,-42063),v=o(v,y,m,f,g[u+11],22,-1990404162),f=o(f,v,y,m,g[u+12],7,1804603682),m=o(m,f,v,y,g[u+13],12,-40341101),y=o(y,m,f,v,g[u+14],17,-1502002290),v=o(v,y,m,f,g[u+15],22,1236535329),f=i(f,v,y,m,g[u+1],5,-165796510),m=i(m,f,v,y,g[u+6],9,-1069501632),y=i(y,m,f,v,g[u+11],14,643717713),v=i(v,y,m,f,g[u+0],20,-373897302),f=i(f,v,y,m,g[u+5],5,-701558691),m=i(m,f,v,y,g[u+10],9,38016083),y=i(y,m,f,v,g[u+15],14,-660478335),v=i(v,y,m,f,g[u+4],20,-405537848),f=i(f,v,y,m,g[u+9],5,568446438),m=i(m,f,v,y,g[u+14],9,-1019803690),y=i(y,m,f,v,g[u+3],14,-187363961),v=i(v,y,m,f,g[u+8],20,1163531501),f=i(f,v,y,m,g[u+13],5,-1444681467),m=i(m,f,v,y,g[u+2],9,-51403784),y=i(y,m,f,v,g[u+7],14,1735328473),v=i(v,y,m,f,g[u+12],20,-1926607734),f=a(f,v,y,m,g[u+5],4,-378558),m=a(m,f,v,y,g[u+8],11,-2022574463),y=a(y,m,f,v,g[u+11],16,1839030562),v=a(v,y,m,f,g[u+14],23,-35309556),f=a(f,v,y,m,g[u+1],4,-1530992060),m=a(m,f,v,y,g[u+4],11,1272893353),y=a(y,m,f,v,g[u+7],16,-155497632),v=a(v,y,m,f,g[u+10],23,-1094730640),f=a(f,v,y,m,g[u+13],4,681279174),m=a(m,f,v,y,g[u+0],11,-358537222),y=a(y,m,f,v,g[u+3],16,-722521979),v=a(v,y,m,f,g[u+6],23,76029189),f=a(f,v,y,m,g[u+9],4,-640364487),m=a(m,f,v,y,g[u+12],11,-421815835),y=a(y,m,f,v,g[u+15],16,530742520),v=a(v,y,m,f,g[u+2],23,-995338651),f=c(f,v,y,m,g[u+0],6,-198630844),m=c(m,f,v,y,g[u+7],10,1126891415),y=c(y,m,f,v,g[u+14],15,-1416354905),v=c(v,y,m,f,g[u+5],21,-57434055),f=c(f,v,y,m,g[u+12],6,1700485571),m=c(m,f,v,y,g[u+3],10,-1894986606),y=c(y,m,f,v,g[u+10],15,-1051523),v=c(v,y,m,f,g[u+1],21,-2054922799),f=c(f,v,y,m,g[u+8],6,1873313359),m=c(m,f,v,y,g[u+15],10,-30611744),y=c(y,m,f,v,g[u+6],15,-1560198380),v=c(v,y,m,f,g[u+13],21,1309151649),f=c(f,v,y,m,g[u+4],6,-145523070),m=c(m,f,v,y,g[u+11],10,-1120210379),y=c(y,m,f,v,g[u+2],15,718787259),v=c(v,y,m,f,g[u+9],21,-343485551),f=r(f,l),v=r(v,d),y=r(y,h),m=r(m,p);return n(f)+n(v)+n(y)+n(m)}}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,ye,me,we,Se;(me=ae||(ae={}))[me.OK=0]="OK",me[me.UnknownError=1]="UnknownError",me[me.FatalError=2]="FatalError",me[me.WrongData=3]="WrongData",me[me.ResourceDoesNotExists=4]="ResourceDoesNotExists",me[me.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",me[me.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",me[me.OperationNotPermitted=7]="OperationNotPermitted",me[me.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",me[me.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",me[me.Error=10]="Error",me[me.NoData=11]="NoData",me[me.NotSupportedMethod=12]="NotSupportedMethod",me[me.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",me[me.MultiDataResponseStart=14]="MultiDataResponseStart",me[me.MultiDataResponse=15]="MultiDataResponse",me[me.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=mv.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 De{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"}(ye||(ye={}));class Te{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=ye.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 ke{constructor(){this._log=mv.Get(r.ServiceName),ke._localStorageService=mv.Get(o.ServiceName)}GetServiceName(){return ke.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===ae.OK&&(this._log.Debug(ke.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=ke._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=ke._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(ke.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),n}ClearCache(){var e;null===(e=ke._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(ke.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=ke._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(ke.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}ke._localStorageService=null,ke.ServiceName="WebApiCacheService";var Ge=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=mv.Get(Ot.ServiceName),this._logger=mv.Get(r.ServiceName)}GetServiceName(){return be.ServiceName}AddPictureAsync(e){var t,n;return Ge(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 Ge(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(mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.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 mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.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 Ge(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 mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.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 Ge(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 De(ae.UnknownError,"NoDataInResult")):t.Status!=ae.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new De(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 De(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 De(ae.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){var t;return Ge(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 De(ae.UnknownError,"NoDataInResult");switch(n.Status){case ae.ResourceDoesNotExists:return new De(ae.ResourceDoesNotExists,"PictureNotFound");case ae.OK:if(null==n.Data)return new De(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 De(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(be.ServiceName,`Cannot get picture! ${e}`),new De(ae.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){var e;return Ge(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 De(ae.UnknownError,"NoDataInResult")):t.Status!=ae.OK?(this._logger.Error(be.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new De(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(be.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new De(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 De(ae.FatalError,"ExceptionOccurred")}}))}}be.ServiceName="PictureService";class Ne extends Te{set DateTime(e){this._dateTime=e}}class Ee{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=ye.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=mv.Get(Ot.ServiceName),this._pictureService=mv.Get(be.ServiceName),this._sessionService=mv.Get(Ke.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 De(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 mv.Get(ke.ServiceName).ClearCache(),null==s||null==s.Status?new De(ae.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new De(s.Status,s.Data))}))}UpdateUserAsync(e){var t;return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new De(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 mv.Get(ke.ServiceName).ClearCache(),null==r||null==r.Status?new De(ae.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new De(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 De(ae.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new De(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 De(ae.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new De(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 mv.Get(ke.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 De(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 mv.Get(ke.ServiceName).ClearCache(),null!=e.Type?t:e}return new De(ae.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return xe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new De(ae.WrongData,"GuidCannotBeEmpty");let n=new Te;n.ImageType=ye.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(mv.Get(ke.ServiceName).ClearCache(),r.Type==ae.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ae.OK?new De(ae.OK,"PictureSet"):new De(e,"PictureServiceError")}if(null!=r.Type)return new De(ae.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ae.OK?new De(ae.OK,"PictureSet"):new De(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,this._softwareVersion=""}get Guid(){return this._guid}set Guid(e){this._guid=e}get CloudGuid(){return this._cloudGuid}set CloudGuid(e){this._cloudGuid=e}get Name(){return this._name}set Name(e){this._name=e}get Surname(){return this._surname}set Surname(e){this._surname=e}get Phone(){return this._phone}set Phone(e){this._phone=e}get AccessLevel(){return this._accessLevel}set AccessLevel(e){this._accessLevel=e}get Email(){return this._email}set Email(e){this._email=e}get IsAccountOnline(){return this._isAccountOnline}set IsAccountOnline(e){this._isAccountOnline=e}get IsActive(){return this._isAccountActive}set IsActive(e){this._isAccountActive=e}get IsBanned(){return this._isAccountBanned}set IsBanned(e){this._isAccountBanned=e}get NotificationChannels(){return this._notificationChannels}set NotificationChannels(e){this._notificationChannels=e}get Gender(){return this._gender}set Gender(e){this._gender=e}get Localization(){return this._localization}set Localization(e){this._localization=e}get SoftwareVersion(){return this._softwareVersion}set SoftwareVersion(e){this._softwareVersion=e}GetUserProfilePictureAsync(){return mv.Get(Fe.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return mv.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 Ke{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(Ke.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{let t=n=>{var r;null===(r=s.Log)||void 0===r||r.Debug(Ke.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(Ke.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 mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ae.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=s.Log)||void 0===e||e.Debug(Ke.ServiceName,"User has been logged out.")):null===(t=s.Log)||void 0===t||t.Debug(Ke.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:mv.Get(Ke.ServiceName).RestoreSessionAsync()}}))}AuthorizeAppAsync(e){var t,n,r,o;return Ve(this,void 0,void 0,(function*(){var i=mv.Get(Ot.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,c.SoftwareVersion=a.Data.SoftwareVersion,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,i.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(t=s.Log)||void 0===t||t.Debug(Ke.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(Ke.ServiceName,`App login response: ${a.Data}`),fe.AuthDisabled):a.Status===ae.ResourceDoesNotExists?(null===(r=s.Log)||void 0===r||r.Debug(Ke.ServiceName,`App login response: ${a.Data}`),fe.MethodNotSupported):(null===(o=s.Log)||void 0===o||o.Debug(Ke.ServiceName,`App login response: ${a.Data}`),fe.WrongAuthData)}))}UserLogInAsync(e,t){var n,r;return Ve(this,void 0,void 0,(function*(){var o=mv.Get(Ot.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,a.SoftwareVersion=i.Data.SoftwareVersion,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,o.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(n=s.Log)||void 0===n||n.Debug(Ke.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(Ke.ServiceName,`User login response: ${i.Data}`),fe.WrongAuthData}))}GetServiceName(){return Ke.ServiceName}}Ke.ServiceName="SessionService";class je{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 je(e,t),this.Resource="/users/user/login",this.Method=ce.Put}}class Ye{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 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 Qe{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new Ye(1)}GetServiceName(){return Qe.ServiceName}GetExtensionsInfoAsync(e,t=!1){return Xe(this,void 0,void 0,(function*(){mv.Get(r.ServiceName).Debug(Qe.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 tt("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e,t=!1,n=!1){return Xe(this,void 0,void 0,(function*(){if(mv.Get(r.ServiceName).Debug(Qe.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 tt("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 tt("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return Xe(this,void 0,void 0,(function*(){const e=new Ze,t=yield mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new tt("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ae.OK)throw new tt(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new tt("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 Xe(this,void 0,void 0,(function*(){const e=new et,t=yield mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new tt("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(t.Status){case ae.OK:if(null==t.Data)throw new tt("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:mv.Get(r.ServiceName).Debug(Qe.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new tt(`Cannot get ProtocolInfo from controller! Response status: ${t.Status}`)}}))}}Qe.ServiceName="StatisticsInfoService";class Ze extends ie{constructor(){super(),this.Resource="/controller/extensions/",this.Method=ce.Get}}class et extends ie{constructor(){super(),this.Resource="/controller/protocols/",this.Method=ce.Get}}class tt extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}var nt=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 rt{GetServiceName(){return rt.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=>{mv.Get(Ke.ServiceName).OnUserLoggedInEvent().Subscribe((t=>nt(this,void 0,void 0,(function*(){this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),this._didConfigurationChange&&mv.Get(ke.ServiceName).ClearCache(),e()}))))})),this._connection=mv.Get(Ot.ServiceName),this._session=mv.Get(Ke.ServiceName),this._localStorage=mv.Get(o.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{mv.Get(ke.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{mv.Get(ke.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke()}))}ImportControllerConfigurationAsync(e){var t,n,r;return nt(this,void 0,void 0,(function*(){let s=yield e.text(),o=this.SplitStringBySize(s),i=new st("");i.Status=ae.MultiDataResponseStart;let a=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(i,6e3,!1);if(void 0===a||(null==a?void 0:a.Status)!=ae.OK)return ae.Error;for(const e of o){let t=new st(e);t.Status=ae.MultiDataResponse;let r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(t,6e3,!1);if(void 0===r||(null==r?void 0:r.Status)!=ae.OK)return ae.Error}i.Status=ae.MultiDataResponseStop;let c=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(i,12e4,!1);return void 0===c||(null==c?void 0:c.Status)!=ae.OK?ae.Error:ae.OK}))}SplitStringBySize(e,t=1e5){const n=Math.floor(t/2),r=[];let s=0;for(;s<e.length;){let o=e.slice(s,s+n);for(;new Blob([o]).size>t;)o=o.slice(0,-1);r.push(o),s+=o.length}return r}GetControllerSystemTimeAsync(){var e;return nt(this,void 0,void 0,(function*(){try{var t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ht,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 mv.Get(r.ServiceName).Error(rt.ServiceName,`Cannot get current controller time! ${e}`),ae.FatalError}}))}SetControllerSystemTimeAsync(e){var t;return nt(this,void 0,void 0,(function*(){try{var n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new pt(e.toISOString()),8e3,!1);return null==n||null==n.Status?ae.Error:n.Status}catch(e){return mv.Get(r.ServiceName).Error(rt.ServiceName,`Cannot set current controller time! ${e}`),ae.FatalError}}))}StartNtpTimeSynchronizationAsync(){var e;return nt(this,void 0,void 0,(function*(){try{var t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new gt,8e3,!1);return null==t||null==t.Status?ae.Error:t.Status}catch(e){return mv.Get(r.ServiceName).Error(rt.ServiceName,`Cannot set current controller time! ${e}`),ae.FatalError}}))}FactoryResetAsync(e){var t,n;return nt(this,void 0,void 0,(function*(){try{mv.Get(ke.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new at,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),mv.Get(ke.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}RollbackLastUpdateAsync(e){var t,n;return nt(this,void 0,void 0,(function*(){try{mv.Get(ke.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ct,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),mv.Get(ke.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}RestartControllerAsync(e){var t,n;return nt(this,void 0,void 0,(function*(){try{mv.Get(ke.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new it,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),mv.Get(ke.ServiceName).ClearCache(),clearInterval(s),ae.OK}return r}catch(e){return ae.FatalError}}))}DidCofigurationChangeAsync(){return nt(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 nt(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,mv.Get(ke.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ut,2e4,!1)}))}ExitConfigurationModeAsync(){var e;return nt(this,void 0,void 0,(function*(){this._appEnteredConfigurationMode=!0,mv.Get(ke.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new lt,2e4,!1),mv.Get(ke.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){var e;return nt(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new dt,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 nt(this,void 0,void 0,(function*(){const e=yield this.GetLastConfigurationChangeTimeAsync();return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),mv.Get(ke.ServiceName).ClearCache(),!0)}))}CanExportOrImportControllerConfigurationAsync(){return nt(this,void 0,void 0,(function*(){try{let e=yield mv.Get(Qe.ServiceName).GetExtensionsInfoAsync(),t=mv.Get(Ke.ServiceName).User;return null!=t&&null!=t.AccessLevel&&t.AccessLevel>=he.Admin&&e.any((e=>"f4f0f066-7c43-46c6-a0bd-aedf93903dc0"==e.ExtensionGuid))}catch(e){return!1}}))}ExportControllerConfigurationAsync(){var e;return nt(this,void 0,void 0,(function*(){let t=[];yield null===(e=this._connection)||void 0===e?void 0:e.SendAndHandleResponseAsync(new ot,3e4,(e=>{switch(e.Status){case ae.MultiDataResponseStart:break;case ae.MultiDataResponse:null!=e.Data&&void 0!==e.Data&&t.push(e.Data);case ae.MultiDataResponseStop:}}),!0);let n=JSON.stringify(JSON.parse(t.join("")),null,2);return console.log(n),mv.ExportStringAsFileToDownload(this.GetCurrentTimestampedFilename(),n)}))}GetCurrentTimestampedFilename(){var e,t;const n=new Date,r=n.getHours().toString().padStart(2,"0"),s=n.getMinutes().toString().padStart(2,"0"),o=n.getDate().toString().padStart(2,"0"),i=(n.getMonth()+1).toString().padStart(2,"0"),a=n.getFullYear().toString();return`${null===(t=null===(e=this._connection)||void 0===e?void 0:e.GetAuthorizationInfo())||void 0===t?void 0:t.SerialNumber}_${r}-${s}-${o}-${i}-${a}-config.cexp`}}rt.ServiceName="ControllerConfigurationService";class st extends ie{constructor(e){super(),this.Resource="/configuration/backup/import",this.Method=ce.Put,this.Data=e}}class ot extends ie{constructor(){super(),this.Resource="/configuration/backup/export",this.Method=ce.Get}}class it extends ie{constructor(){super(),this.Resource="/controller/restart",this.Method=ce.Post}}class at extends ie{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=ce.Post}}class ct extends ie{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=ce.Post}}class ut extends ie{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=ce.Put}}class lt extends ie{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=ce.Put}}class dt extends ie{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=ce.Get}}class ht extends ie{constructor(){super(),this.Resource="/system/time",this.Method=ce.Get}}class pt extends ie{constructor(e){super(),this.Resource="/system/time",this.Method=ce.Put,this.Data=e}}class gt extends ie{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=ce.Put}}var ft,vt,yt,mt,wt,St,_t,At,Ct,Dt,Tt,kt,Gt,bt,Nt,Et,It,Rt,Pt=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 Ot{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=mv.Get(r.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._packetsBrokerServers=["br1.tr7.pl","br1.exala.pl"],this._lastReceivedPacketTime=Date.now(),this._connectedAtLeastOnce=!1}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 Ot.ServiceName}EnablePacketsLogging(){this._logPackets=!0}DisablePacketsLogging(){this._logPackets=!1}InitializeConnection(){if(this._controllerConfiguration=mv.Get(rt.ServiceName),this._cache=mv.Get(ke.ServiceName),this._session=mv.Get(Ke.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((()=>Pt(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 Pt(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(Ot.ServiceName,`Got server address: ${t}`),t):(this._log.Error(Ot.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(Ot.ServiceName,`Failed to get server address, status: ${e.status}`),null)}catch(e){return this._log.Error(Ot.ServiceName,e),null}}))}ConnectAsync(e){return Pt(this,void 0,void 0,(function*(){return this._connectedAtLeastOnce=!1,this._address=e,yield this.connectAsync()}))}AuthorizeAsync(e){return new Promise(((t,n)=>Pt(this,void 0,void 0,(function*(){var n;let r=0,s=e=>{window.clearTimeout(r),this._log.Debug(Ot.ServiceName,`Got authorization result: ${e}`),this._connectedAtLeastOnce=!0,t(e)};r=window.setTimeout((()=>{window.clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(s),t(!1)}),2e3),this._log.Debug(Ot.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 Pt(this,void 0,void 0,(function*(){this._connectedAtLeastOnce=!1,mv.WorksInContextOf=e.SerialNumber,this._serialId=e.SerialNumber,this._PIN=e.PIN;var t=yield this.GetServerAddressAsync();if(t&&null!=t){this._log.Debug(Ot.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(this._connectedAtLeastOnce=!1,yield this.swapBrokersAsync(),!this._allBrokersChecked)return this.ConnectAndAuthorizeAsync(e);this._allBrokersChecked=!1}return n&&(this._connectedAtLeastOnce=!0),n?le.Connected:le.AuthorizationFailed}{let t=le.ControllerIsNotConnected;this._log.Warning(Ot.ServiceName,"Server did not return packets broker address, trying to connect to known brokers.");for(let n of this._packetsBrokerServers){this._log.Warning(Ot.ServiceName,`Testing connection to ${n}`),this.SetDefaultPacketsBrokerAddress(n);try{yield this.DisconnectAsync()}catch(e){}this._log.Warning(Ot.ServiceName,`Connecting to server: ${n}`);let r=yield this.connectAsync();if(this._log.Warning(Ot.ServiceName,`Connection result: ${r}`),r==le.Connected){if(yield this.AuthorizeAsync(e))return t=le.Connected,this._connectedAtLeastOnce=!0,t;this._log.Warning(Ot.ServiceName,`Failed to authorize in ${n}`)}}return t}}))}swapBrokersAsync(e=!0){return Pt(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 Pt(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((()=>Pt(this,void 0,void 0,(function*(){var e,t;if(this._disconnectedOnPurpose?this._log.Info(Ot.ServiceName,"Connection closed on demand."):this._log.Error(Ot.ServiceName,"Connection closed"),mv.Get(Ke.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(Ot.ServiceName,"Reconnected from onClose"),this.FireConnectionStateChanged()):le.FailedToConnect})))),null===(t=this._connection)||void 0===t||t.onreconnected((()=>Pt(this,void 0,void 0,(function*(){if(yield this.AuthorizeAsync(new _e(this._serialId,this._PIN)))return this._log.Info(Ot.ServiceName,"Reconnected from onreconnected"),this.FireConnectionStateChanged()})))),null===(n=this._connection)||void 0===n||n.onreconnecting((()=>(this._log.Warning(Ot.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(Ot.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)=>Pt(this,void 0,void 0,(function*(){e.startsWith("NotAuthorized:")?(this._log.Error(Ot.ServiceName,"Failed to authorize!"),yield this.AuthorizeAsync(new _e(this._serialId,this._PIN))):(this._log.Error(Ot.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(Ot.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:if(this._connectedAtLeastOnce)return t.Invoke(de.Disconnected),le.FailedToConnect;break;case W.Disconnecting:if(this._connectedAtLeastOnce)return t.Invoke(de.Disconnecting),le.FailedToConnect;break;case W.Reconnecting:return t.Invoke(de.Reconnecting),le.FailedToConnect}return le.FailedToConnect}DisconnectAsync(){var e;return Pt(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 Pt(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)=>Pt(this,void 0,void 0,(function*(){let a=i=>Pt(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(Ot.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(Ot.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 Pt(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)=>Pt(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(Ot.ServiceName,t),a(new p(t))}),t);let u=l=>Pt(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(Ot.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 Pt(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(Ot.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId} data:\n${JSON.stringify(e,null,2)}`):t&&this._log.Debug(Ot.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(Ot.ServiceName,`${e}`),n(!1)}))}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}}Ot.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(ft||(ft={})),(kt=vt||(vt={}))[kt.Default=0]="Default",kt[kt.Monostable=1]="Monostable",kt[kt.Bistable=2]="Bistable",kt[kt.Gate=3]="Gate",kt[kt.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"}(yt||(yt={}));class Ut{constructor(){this._type=wt.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(bt=mt||(mt={}))[bt.Unknown=0]="Unknown",bt[bt.BlindMotor=1]="BlindMotor",bt[bt.DinModule=2]="DinModule",bt[bt.DinModuleWithAntenna=3]="DinModuleWithAntenna",bt[bt.Remote=4]="Remote",bt[bt.RemoteForBlinds=5]="RemoteForBlinds",bt[bt.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",bt[bt.MovementSensor=7]="MovementSensor",bt[bt.TemperatureSensor=8]="TemperatureSensor",bt[bt.HumiditySensor=9]="HumiditySensor",bt[bt.DinPowerMeter=10]="DinPowerMeter",bt[bt.Intercom=11]="Intercom",bt[bt.SecurityCamera=12]="SecurityCamera",bt[bt.Multisensor=13]="Multisensor",bt[bt.FloodSensor=14]="FloodSensor",bt[bt.FlushMountedReceiver=15]="FlushMountedReceiver",bt[bt.FlushMountedBlindController=16]="FlushMountedBlindController",bt[bt.FlushMountedDimmer=17]="FlushMountedDimmer",bt[bt.FlushMountedRelay=18]="FlushMountedRelay",bt[bt.FlushMountedGateController=19]="FlushMountedGateController",bt[bt.WindSensor=20]="WindSensor",bt[bt.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",bt[bt.AirPressureSensor=22]="AirPressureSensor",bt[bt.LightBrightnessSensor=23]="LightBrightnessSensor",bt[bt.ReedSensor=24]="ReedSensor",bt[bt.FlushMountedTransceiver=25]="FlushMountedTransceiver",bt[bt.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",bt[bt.WallMountedThermoregulator=27]="WallMountedThermoregulator",bt[bt.ImpulseCounter=28]="ImpulseCounter",bt[bt.FlushMountedFacadeController=29]="FlushMountedFacadeController",bt[bt.WallMountedGateController=30]="WallMountedGateController",bt[bt.WallMountedRGBLightController=31]="WallMountedRGBLightController",bt[bt.WallMountedDimmer=32]="WallMountedDimmer",bt[bt.WallMountedRemote=33]="WallMountedRemote",bt[bt.DinRelay=34]="DinRelay",bt[bt.DinReceiver=35]="DinReceiver",bt[bt.DinBlindController=36]="DinBlindController",bt[bt.DinTransceiver=37]="DinTransceiver",bt[bt.SocketPlugIn=38]="SocketPlugIn",bt[bt.WallMountedRelay=39]="WallMountedRelay",bt[bt.Retransmitter=40]="Retransmitter",(Gt=wt||(wt={})).Unknown="Unknown",Gt.SetBlindPosition="IBlindPosition",Gt.SetBlindPositionSimple="IBlindPositionSimple",Gt.SetBlindMicroventilation="IMicroventilation",Gt.TurnOff="IChannelOff",Gt.TurnOn="IChannelOn",Gt.TurnOnWithTime="IChannelOnWithTime",Gt.TogleState="IChannelSwitchState",Gt.SetLightBrightnessDynamicly="IDynamicLightBrightness",Gt.SetLightBrightness="ILightBrightness",Gt.SetLightColor="ILightColor",Gt.SetLightTemperature="ILightTemperature",Gt.PairDevice="IPair",Gt.UnpairDevice="IUnpair",Gt.IdentifyDevice="IIdentifyDevice",Gt.GetChannelsState="IGetDeviceState",Gt.GetPowerMeasurements="IGetPowerMeasurements",Gt.GetAvailableData="IGetAvailableData",Gt.MultipleDataRequest="IMultipleDataRequest",Gt.SetBlindOpenCloseTime="ISetBlindOpenCloseTime",Gt.SetTemperature="IChangeTemperature",Gt.SetGatePosition="IGatePosition",Gt.SetGatewayPosition="IGatewayPosition",Gt.ChangeGatePositionPulse="IGatePulse",Gt.ChangeGatewayPositionPulse="IGatewayPulse",Gt.SetFacadePosition="IFacadePosition",Gt.GetFacadeType="IGetFacadeType",Gt.LightRGBW="ILightRGBW",Gt.PreciseGateControl="IPreciseGateControl";class Mt{constructor(){this._type=St.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Rt=St||(St={})).Unknown="Unknown",Rt.BatteryState="IBatteryState",Rt.BinarySensorState="IBinarySensor",Rt.BlindOpenCloseTime="IBlindOpenCloseTime",Rt.BlindPosition="IBlindPosition",Rt.BlindRemoteButtonState="IBlindsControlButton",Rt.BlindErrorState="IBlindError",Rt.MeasuredBrightness="IBrightness",Rt.RemoteButtonState="IButtonState",Rt.ChannelOnOffState="IChannelOnOff",Rt.IntercomState="IIntercom",Rt.DoorBellState="IDoorBell",Rt.FacadeRemoteButtonState="IFacadeControlButton",Rt.FacadePosition="IFacadeState",Rt.FacadeType="IFacadeType",Rt.FloodSensorState="IFloodSensor",Rt.GatePosition="IGatePosition",Rt.GatewayPosition="IGatewayPosition",Rt.GateControllerHealth="IGateControllerHealth",Rt.HumiditySensorState="IHumiditySensor",Rt.LightBrightness="ILightBrightness",Rt.LightColor="ILightColor",Rt.LightWarmth="ILightTemperature",Rt.LightTreshold="ILightTreshold",Rt.MovementSensorState="IMovementSensor",Rt.OnlineCamera="IOnlineCamera",Rt.OvercurrentProtectionState="IOvercurrentProtection",Rt.OvercurrentProtectionThreshold="IOvercurrentProtectionThreshold",Rt.ReedState="IReedState",Rt.SignalStrength="ISignalStrength",Rt.SmokeSensorState="ISmokeSensor",Rt.MeasuredTemperature="ITemperature",Rt.VibrationSensorState="IVibrationSensor",Rt.MeasuredWindSpeed="IWindSpeed",Rt.WindThreshold="IWindThreshold",Rt.MeasuredEnergy="IEnergy",Rt.MeasuredDistance="DistanceSensor",Rt.BlindCalibration="BlindCalibration",Rt.ConfigurationState="ConfigurationState",Rt.CurrentWindThreshold="CurrentWindThreshold",Rt.CurrentLightThreshold="CurrentLightThreshold",Rt.WindSpeedState="WindSpeed",Rt.TamperProtectionState="ITamperProtection",Rt.PressureSensorState="IPressureSensor",Rt.LightRGBWState="ILightRGBW",(It=_t||(_t={}))[It.NotResponding=0]="NotResponding",It[It.Working=1]="Working",It[It.Broken=2]="Broken",It[It.FirmareUpgradeMode=3]="FirmareUpgradeMode",(Et=At||(At={}))[Et.TwoWay=1]="TwoWay",Et[Et.OneWay=2]="OneWay",Et[Et.ConditionalTwoWay=3]="ConditionalTwoWay",(Nt=Ct||(Ct={}))[Nt.Unknown=-1]="Unknown",Nt[Nt.Multipurpose=0]="Multipurpose",Nt[Nt.Controller=1]="Controller",Nt[Nt.Driver=2]="Driver",Nt[Nt.Receiver=3]="Receiver",Nt[Nt.Remote=4]="Remote",Nt[Nt.Sensor=5]="Sensor",Nt[Nt.Scene=6]="Scene";class xt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=ft.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"}(Dt||(Dt={})),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"}(Tt||(Tt={}));class Ft{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=Tt.Unknown}}var Lt,Bt,$t,Wt,qt,Ht,Vt,Kt,jt,zt,Jt,Yt,Xt,Qt,Zt,en,tn,nn,rn,sn,on,an,cn,un,ln,dn,hn,pn,gn,fn,vn;class yn{constructor(){this._type="",this._data=null,this._typeAsEnum=St.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}}(vn=Lt||(Lt={}))[vn.Confident=0]="Confident",vn[vn.Unconfident=1]="Unconfident";class mn extends yn{constructor(e){super(),this.TypeAsEnum=St.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class wn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=Bt.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Bt||(Bt={})),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"}($t||($t={}));class Sn extends yn{constructor(e){super(),this.TypeAsEnum=St.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class _n extends yn{constructor(e){super(),this.TypeAsEnum=St.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class An{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=Wt.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(Wt||(Wt={}));class Cn extends yn{constructor(e){super(),this.TypeAsEnum=St.ReedState,this.Type="ReedState",this.Data=e.state}}class Dn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=!1,this.Time=""}}class Tn extends yn{constructor(e){super(),this.TypeAsEnum=St.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return qt.UnableToMove;case 201:return qt.MotorOverheatedPleaseWait;default:return qt.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(qt||(qt={}));class kn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class Gn extends yn{constructor(e){super(),this.TypeAsEnum=St.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class bn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=Ht.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(Ht||(Ht={}));class Nn extends yn{constructor(e){super(),this.TypeAsEnum=St.LightColor,this.Type="LightColorState",this.Data=e.state}}class En{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class In extends yn{constructor(e){super(),this.TypeAsEnum=St.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class Rn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Temperature=0,this.Time=""}}class Pn extends yn{constructor(e){super(),this.TypeAsEnum=St.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class On{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Brightness=0,this.Time=""}}class Un extends yn{constructor(e){super(),this.TypeAsEnum=St.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class Mn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Temperature=0,this.Type=Vt.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"}(Vt||(Vt={}));class xn extends yn{constructor(e){super(),this.TypeAsEnum=St.BatteryState,this.Type="BatteryState",this.Data=e.state}}class Fn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=Kt.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"}(Kt||(Kt={}));class Ln extends yn{constructor(e){super(),this.TypeAsEnum=St.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class Bn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Brightness=0,this.Time=""}}class $n extends yn{constructor(e){super(),this.TypeAsEnum=St.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class Wn{constructor(){this.Channel=0,this.StateReliability=Lt.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"}(jt||(jt={}));class qn extends yn{constructor(e){super(),this.TypeAsEnum=St.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(zt||(zt={}));class Hn extends yn{constructor(e){super(),this.TypeAsEnum=St.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class Vn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Intensity=0,this.Movement=Jt.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Jt||(Jt={}));class Kn extends yn{constructor(e){super(),this.TypeAsEnum=St.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class jn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=Yt.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"}(Yt||(Yt={}));class zn extends yn{constructor(e){super(),this.TypeAsEnum=St.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class Jn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=Xt.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"}(Xt||(Xt={}));class Yn extends yn{constructor(e){super(),this.TypeAsEnum=St.SignalStrength,this.Type="SignalStrenghtState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Excellent=1]="Excellent",e[e.Good=2]="Good",e[e.Acceptable=3]="Acceptable",e[e.Low=4]="Low",e[e.Terrible=5]="Terrible",e[e.NoLink=6]="NoLink"}(Qt||(Qt={}));class Xn extends yn{constructor(e){super(),this.TypeAsEnum=St.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class Qn{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.PositionType=Zt.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"}(Zt||(Zt={}));class Zn extends yn{constructor(e){super(),this.TypeAsEnum=St.GatewayPosition,this.Type="GatewayPositionState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Open=1]="Open",e[e.PartiallyOpen=2]="PartiallyOpen",e[e.Close=3]="Close",e[e.On=4]="On",e[e.Off=5]="Off"}(en||(en={}));class er extends yn{constructor(e){super(),this.TypeAsEnum=St.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"}(tn||(tn={}));class tr extends yn{constructor(e){super(),this.TypeAsEnum=St.BlindCalibration,this.Type="BlindCalibrationState",this.Data=e.state}}!function(e){e[e.AutoLernIdle=0]="AutoLernIdle",e[e.AutoLernInProgress=1]="AutoLernInProgress",e[e.AutoLernSuccessfull=2]="AutoLernSuccessfull",e[e.AutoLernCancelled=4]="AutoLernCancelled"}(nn||(nn={}));class nr extends yn{constructor(e){super(),this.TypeAsEnum=St.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class rr{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Type=rn.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"}(rn||(rn={}));class sr extends yn{constructor(e){super(),this.TypeAsEnum=St.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(sn||(sn={}));class or extends yn{constructor(e){super(),this.TypeAsEnum=St.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class ir{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=on.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(on||(on={}));class ar extends yn{constructor(e){super(),this.TypeAsEnum=St.ConfigurationState,this.Type="ConfigurationState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.OngoingConfiguration=1]="OngoingConfiguration",e[e.NotConfigured=2]="NotConfigured",e[e.Configured=3]="Configured",e[e.PartiallyConfigured=4]="PartiallyConfigured"}(an||(an={}));class cr extends yn{constructor(e){super(),this.TypeAsEnum=St.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class ur extends yn{constructor(e){super(),this.TypeAsEnum=St.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class lr extends yn{constructor(e){super(),this.TypeAsEnum=St.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class dr extends yn{constructor(e){super(),this.TypeAsEnum=St.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class hr extends yn{constructor(e){super(),this.TypeAsEnum=St.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class pr extends yn{constructor(e){super(),this.TypeAsEnum=St.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class gr{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.WindThreshold=cn.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"}(cn||(cn={}));class fr extends yn{constructor(e){super(),this.TypeAsEnum=St.CurrentLightThreshold,this.Type="CurrentLightThresholdState",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.Below=1]="Below",e[e.Exceeded=2]="Exceeded"}(un||(un={}));class vr extends yn{constructor(e){super(),this.TypeAsEnum=St.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class yr{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Value=0,this.Time=""}}class mr extends yn{constructor(e){super(),this.TypeAsEnum=St.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class wr{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.State=ln.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(ln||(ln={})),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"}(dn||(dn={}));class Sr extends yn{constructor(e){super(),this.TypeAsEnum=St.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class _r{constructor(){this.Channel=0,this.StateReliability=Lt.Unconfident,this.Pressure=0,this.Time="",this.PressureType=hn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(hn||(hn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(pn||(pn={}));class Ar extends yn{constructor(e){super(),this.TypeAsEnum=St.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(gn||(gn={}));class Cr extends yn{constructor(e){super(),this.TypeAsEnum=St.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Dr extends yn{constructor(e){super(),this.TypeAsEnum=St.BlindErrorState,this.Type="BlindError",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.ObstacleDetected=1]="ObstacleDetected",e[e.MotorFailure=2]="MotorFailure"}(fn||(fn={}));class Tr{constructor(){this._onDeviceStateChangedEvent=new n,this._onDeviceStateRefreshedOrChangedEvent=new n,this._onDeviceTasksExecutionChangedOnChannelsEvent=new n,this._onDeviceFirmwareVersionChangedEvent=new n,this._iconType=mt.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=_t.Working,this._deviceType=Ct.Unknown,this._communicationWay=At.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==Tr._devicesService&&(Tr._devicesService=mv.Get(Ao.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Tr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Tr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),Tr._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===Ct.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!==wt.SetBlindPositionSimple))}return!1}get States(){return r.DoesThrowStackTrace?mv.Get(Ao.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Tr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Tr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Tr._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 mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(new kr(this,e),2e4,!1);switch(t.Status){case ae.OK:return this._name=e,mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.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 Tr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class kr extends ie{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=ce.Put;const n=new Gr;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class Gr{constructor(){this.DeviceGuid="",this.Name=""}}var br,Nr,Er,Ir,Rr,Pr,Or=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 Ur{constructor(){this._device=new Tr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=vt.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==Ur._devicesService&&(Ur._devicesService=mv.Get(Ao.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 Or(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t,this._customData[e]=t;const r=new Mr;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 Mr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new xr;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 Mr;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 Mr;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Mr;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 Mr;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 Mr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){var t;return Or(this,void 0,void 0,(function*(){try{const n=yield mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(new Fr(e),2e4,!1);switch(mv.Get(ke.ServiceName).ClearCache(),yield mv.Get(rt.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?mv.Get(Ao.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Ur._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,Ur._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(Tt.Failed)}}Ur._devicesService=null;class Mr{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new xr}}class xr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=vt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class Fr extends ie{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=ce.Put,this.Data=e}}(Pr=br||(br={}))[Pr.TurnOn=0]="TurnOn",Pr[Pr.TurnOff=1]="TurnOff",Pr[Pr.ToggleState=2]="ToggleState",Pr[Pr.SetBlindPosition=3]="SetBlindPosition",Pr[Pr.SetLightColor=4]="SetLightColor",Pr[Pr.SetLightTemperature=5]="SetLightTemperature",Pr[Pr.SetLightBrightness=6]="SetLightBrightness",Pr[Pr.SetTemperature=7]="SetTemperature",Pr[Pr.GetState=8]="GetState",Pr[Pr.TurnOnWithTimeout=9]="TurnOnWithTimeout",Pr[Pr.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",Pr[Pr.IdentifyDevice=11]="IdentifyDevice",Pr[Pr.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",Pr[Pr.SetBlindMicroventilation=13]="SetBlindMicroventilation",Pr[Pr.GatewayPulse=25]="GatewayPulse",Pr[Pr.GatePulse=26]="GatePulse",Pr[Pr.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",Pr[Pr.GetFacadeType=30]="GetFacadeType",Pr[Pr.LightRGBW=31]="LightRGBW",Pr[Pr.SetGatePositionPrecise=32]="SetGatePositionPrecise";class Lr{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 Br{constructor(){this._taskType=wt.GetChannelsState,this._featureType=br.GetState,this._channel=0,this._guid=Lr.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 $r extends Br{constructor(){super(),this.Temperature=0,this.FeatureType=br.SetTemperature,this.TaskType=wt.SetTemperature}}class Wr extends Br{constructor(){super(),this.FeatureType=br.TurnOff,this.TaskType=wt.TurnOff}}class qr extends Br{constructor(){super(),this.FeatureType=br.TurnOn,this.TaskType=wt.TurnOn}}class Hr extends Br{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=br.TurnOnWithTimeout,this.TaskType=wt.TurnOnWithTime}}class Vr extends Br{constructor(){super(),this.Brightness=0,this.FeatureType=br.SetLightBrightness,this.TaskType=wt.SetLightBrightness}}class Kr extends Br{constructor(){super(),this.FeatureType=br.ToggleState,this.TaskType=wt.TogleState}}class jr extends Br{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=br.SetLightColor,this.TaskType=wt.SetLightColor}}class zr extends Br{constructor(){super(),this.Temperature=0,this.FeatureType=br.SetLightTemperature,this.TaskType=wt.SetLightTemperature}}class Jr extends Br{constructor(){super(),this.Action=Nr.Stop,this.Position=0,this.FeatureType=br.SetBlindPosition,this.TaskType=wt.SetBlindPosition}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Nr||(Nr={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Er||(Er={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Ir||(Ir={}));class Yr extends Br{constructor(){super(),this.Brightness=0,this.FeatureType=br.SetLightBrightnessDynamicly,this.TaskType=wt.SetLightBrightnessDynamicly}}class Xr extends Br{constructor(){super(),this.FeatureType=br.IdentifyDevice,this.TaskType=wt.IdentifyDevice}}class Qr extends Br{constructor(){super(),this.Data=new Zr,this.FeatureType=br.SetBlindOpenCloseTime,this.TaskType=wt.SetBlindOpenCloseTime}}class Zr{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class es extends Br{constructor(){super(),this.FeatureType=br.GetState,this.TaskType=wt.GetChannelsState}}class ts extends Br{constructor(){super(),this.Position=0,this.FeatureType=br.SetBlindMicroventilation,this.TaskType=wt.SetBlindMicroventilation}}class ns extends Br{constructor(){super(),this.FeatureType=br.GatePulse,this.TaskType=wt.ChangeGatewayPositionPulse}}class rs extends Br{constructor(){super(),this.FeatureType=br.GatewayPulse,this.TaskType=wt.ChangeGatewayPositionPulse}}class ss extends Br{constructor(){super(),this.FacadeAction=Rr.Stop,this.Tilt=0,this.Position=0,this.FeatureType=br.SetFacadePositionAndTilt,this.TaskType=wt.SetFacadePosition}}class os extends Br{constructor(){super(),this.FeatureType=br.GetFacadeType,this.TaskType=wt.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"}(Rr||(Rr={}));class is{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class as extends Br{constructor(){super(),this.Data=new is,this.FeatureType=br.LightRGBW,this.TaskType=wt.LightRGBW}}var cs=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 us{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return us.ServiceName}RegisterManuallyPairedDevicesProtocol(e){mv.Get(r.ServiceName).Debug(us.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return cs(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 cs(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=t?t.AddManuallyPairedDeviceAsync(e):(mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),Tt.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}us.ServiceName="ManualDeviceService";class ls{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var ds,hs=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 ps{constructor(){this._connection=null,this._localDb=null,this._connection=mv.Get(Ot.ServiceName),this._localDb=mv.Get(o.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return hs(this,void 0,void 0,(function*(){let r=new gs(e,t,n),s=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(s.Status===ae.OK){const r=new ys;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(ps.ServiceName,this.GetLocalDbName(e,t),r)}return s.Status}))}ReadAsync(e,t,n){return hs(this,void 0,void 0,(function*(){let r=new fs(e,t);if(!n){const n=this._localDb.Read(ps.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new ls;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 ls;return e.ResourceGuid=s.ResourceGuid,e.Data=JSON.parse(s.Data),e.IsGlobal=s.IsGlobal,e}return s.Status}))}RemoveAsync(e,t){return hs(this,void 0,void 0,(function*(){let n=new vs(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return ps.ServiceName}}ps.ServiceName="RemoteStorageService";class gs 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 fs 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 vs 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 ys extends ie{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class ms{constructor(){this.Longitude=0,this.Latitude=0}}class ws{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"}(ds||(ds={}));var Ss,_s,As,Cs,Ds,Ts,ks,Gs,bs,Ns,Es,Is,Rs,Ps,Os,Us,Ms,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 Fs{IsControllerGeolocationSetAsync(){return xs(this,void 0,void 0,(function*(){let e=new Ls,t=yield mv.Get(Ot.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 xs(this,void 0,void 0,(function*(){return new Promise(((e,t)=>xs(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){var t,n;return xs(this,void 0,void 0,(function*(){let r=new $s;r.Data.Latitude=e.Latitude,r.Data.Longitude=e.Longitude,null===(t=s.Log)||void 0===t||t.Warning(Fs.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(r)}`);let o=yield mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(r,15e3,!1);switch(null===(n=s.Log)||void 0===n||n.Warning(Fs.ServiceName,`${JSON.stringify(o)}`),mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),null==o?void 0:o.Status){case ae.OK:return new De(ds.OK,"");case ae.NoPermissionToPerformThisOperation:case ae.NoPermissionsToCallGivenResource:return new De(ds.NoPermissions,"");case ae.UserIsNotLoggedIn:return new De(ds.UserIsNotLoggedIn,"");default:return new De(ds.UnknownError,"")}}))}GetControlllerGeolocationAsync(){var e,t;return xs(this,void 0,void 0,(function*(){let n=new Bs;null===(e=s.Log)||void 0===e||e.Warning(Fs.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=s.Log)||void 0===t||t.Warning(Fs.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ae.OK){let e=new ws;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 Fs.ServiceName}}Fs.ServiceName="GeolocationService";class Ls extends ie{constructor(){super(),this.Resource="/geolocation/isset",this.Method=ce.Get}}class Bs extends ie{constructor(){super(),this.Resource="/geolocation/get",this.Method=ce.Get}}class $s extends ie{constructor(){super(),this.Data=new ms,this.Resource="/geolocation/save",this.Method=ce.Put}}!function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(Ss||(Ss={}));class Ws{constructor(){this._comparisonParams=new Map,this.Type=St.Unknown,this.DeviceGuid="",this.ComparisonMethod=_s.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof Fn&&(this.Type=St.BatteryState),e instanceof ir&&(this.Type=St.BinarySensorState),e instanceof kn&&(this.Type=St.BlindPosition),e instanceof On&&(this.Type=St.LightBrightness),e instanceof Bn&&(this.Type=St.MeasuredBrightness),e instanceof bn&&(this.Type=St.RemoteButtonState),e instanceof wn&&(this.Type=St.ChannelOnOffState),e instanceof An&&(this.Type=St.DoorBellState),e instanceof Wn&&(this.Type=St.MeasuredEnergy),e instanceof wr&&(this.Type=St.FloodSensorState),e instanceof Qn&&(this.Type=St.GatePosition),e instanceof En&&(this.Type=St.LightColor),e instanceof Rn&&(this.Type=St.LightWarmth),e instanceof Dn&&(this.Type=St.ReedState),e instanceof Mn&&(this.Type=St.MeasuredTemperature),e instanceof rr&&(this.Type=St.HumiditySensorState),e instanceof jn&&(this.Type=St.BlindRemoteButtonState),e instanceof Jn&&(this.Type=St.FacadeRemoteButtonState),e instanceof Vn&&(this.Type=St.MovementSensorState),e instanceof Wn&&(this.Type=St.MeasuredEnergy),e instanceof _r&&(this.Type=St.PressureSensorState),e instanceof yr&&(this.Type=St.WindSpeedState),e instanceof gr&&(this.Type=St.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class qs{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class Hs{constructor(...e){this._value="00:00:00",e.length>1?this.SetTimeSpan(e[0],e[1],e[2],e[3]):this._value=e[0]}SetTimeSpan(e,t,n,r){this._value=r<=0?`${n.toString().padStart(2,"0")}:${t.toString().padStart(2,"0")}:${e.toString().padStart(2,"0")}`:`${r}.${n.toString().padStart(2,"0")}:${t.toString().padStart(2,"0")}:${e.toString().padStart(2,"0")}`}get Value(){return this._value}}!function(e){e[e.Default=0]="Default",e[e.Delta=1]="Delta",e[e.StateRepeat=2]="StateRepeat"}(_s||(_s={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}(As||(As={})),function(e){e[e.SunRise=1]="SunRise",e[e.SunSet=2]="SunSet"}(Cs||(Cs={}));class Vs{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"}(Ds||(Ds={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(Ts||(Ts={})),(Ms=ks||(ks={}))[Ms.Unknown=0]="Unknown",Ms[Ms.Second=1]="Second",Ms[Ms.Minute=2]="Minute",Ms[Ms.Hour=3]="Hour",Ms[Ms.Day=4]="Day",Ms[Ms.DayOfWeek=5]="DayOfWeek",Ms[Ms.Month=6]="Month",Ms[Ms.Year=7]="Year",Ms[Ms.Date=8]="Date",Ms[Ms.Time=9]="Time",Ms[Ms.WeatherType=11]="WeatherType",Ms[Ms.CompareNumbers=12]="CompareNumbers",Ms[Ms.CompareBooleans=13]="CompareBooleans",Ms[Ms.DeviceState=14]="DeviceState",Ms[Ms.Timer=15]="Timer",Ms[Ms.Temperature=17]="Temperature",Ms[Ms.DaysOfWeek=18]="DaysOfWeek",Ms[Ms.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",Ms[Ms.SceneExecuted=20]="SceneExecuted",(Us=Gs||(Gs={}))[Us.Unknown=0]="Unknown",Us[Us.Equal=1]="Equal",Us[Us.NotEqueal=2]="NotEqueal",Us[Us.BiggerThan=3]="BiggerThan",Us[Us.SmallerThan=4]="SmallerThan",Us[Us.BiggerThanOrEqual=5]="BiggerThanOrEqual",Us[Us.SmallerThanOrEqual=6]="SmallerThanOrEqual",Us[Us.OneOfBothIsTrue=7]="OneOfBothIsTrue",Us[Us.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"}(bs||(bs={})),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"}(Ns||(Ns={})),(Os=Es||(Es={})).Null="Null",Os.Condition="Condition",Os.ConditionGroup="ConditionGroup",Os.ArgumentAsInt="ArgumentAsInt",Os.ArgumentAsTimeSpan="ArgumentAsTimeSpan",Os.ArgumentAsBoolean="ArgumentAsBoolean",Os.ArgumentAsTimeout="ArgumentAsTimeout",Os.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",Os.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",Os.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",Os.ArgumentAsTime="ArgumentAsTime",Os.ArgumentAsDeviceState="ArgumentAsDeviceState",Os.ArgumentAsNumber="ArgumentAsNumber",Os.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",Os.ArgumentAsConditionInfo="ArgumentAsConditionInfo";class Ks 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"}(Is||(Is={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(Rs||(Rs={}));class js{constructor(e,t="Cube"){this._result=null,this._tmp=new zs,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=mv.Get(uo.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=Lr.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==Ps.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 js;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=Lr.NewGuid(),e.RightArgumentType==Ps.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=Lr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==Ps.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!=Ps.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=Gs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Gs.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=Lr.NewGuid(),this._tmp.HandledType=ks.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=Ps.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,t&&null!=n&&n!=Gs.Equal)throw new ro("AtmeetCondition supports only comparation type 'Equal'.");if(e.Offset<-3600||e.Offset>3600)throw new ro("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=Gs.Equal;else{if(null==n)throw new ro("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Ps.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=Lr.NewGuid(),this._tmp.HandledType=ks.Unknown,this._tmp.LeftArgumentType=Ps.Null,this._tmp.ConditionType=Gs.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=Ps.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=Gs.Equal){return this._tmp.Guid=Lr.NewGuid(),this._tmp.HandledType=ks.DaysOfWeek,this._tmp.LeftArgumentType=Ps.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Ps.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=Gs.Equal){return this._tmp.Guid=Lr.NewGuid(),this._tmp.HandledType=ks.Timer,this._tmp.LeftArgumentType=Ps.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Ps.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=Gs.Equal){return this._tmp.Guid=Lr.NewGuid(),this._tmp.HandledType=ks.Time,this._tmp.LeftArgumentType=Ps.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Ps.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=Gs.Equal){return this._tmp.Guid=Lr.NewGuid(),this._tmp.HandledType=ks.DeviceState,this._tmp.LeftArgumentType=Ps.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=Ps.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=Lr.NewGuid(),this._tmp.HandledType=ks.SceneExecuted,this._tmp.LeftArgumentType=Ps.ArgumentAsConditionInfo,this._tmp.ConditionType=Gs.Equal,this._tmp.AtMeetCondition=!0;const t=new Vs;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=Ps.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new Xs;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),{[As[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case St.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case St.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case St.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case St.LightBrightness:case St.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case St.RemoteButtonState:case St.ChannelOnOffState:case St.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case St.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[jt[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case St.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case St.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case St.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case St.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case St.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case St.SmokeSensorState:throw new Ks("Unsupported device state!");case St.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case St.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case St.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case St.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 St.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case St.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case St.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case St.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case St.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case St.Unknown:t.CheckedDeviceState={};break;default:throw new Ks("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case St.BatteryState:return bs.BatteryState;case St.BinarySensorState:return bs.BinarySensor;case St.BlindPosition:return bs.BlindPosition;case St.LightBrightness:return bs.LightBrightness;case St.RemoteButtonState:return bs.ButtonState;case St.ChannelOnOffState:return bs.ChannelOnOff;case St.DoorBellState:return bs.DoorBell;case St.MeasuredEnergy:return bs.Energy;case St.FloodSensorState:return bs.FloodSensor;case St.GatePosition:return bs.GatePosition;case St.MeasuredBrightness:return bs.Brightness;case St.LightColor:return bs.LightColor;case St.LightWarmth:return bs.LightTemperature;case St.ReedState:return bs.ReedState;case St.SmokeSensorState:return bs.SmokeSensor;case St.MeasuredTemperature:return bs.Temperature;case St.HumiditySensorState:return bs.Humidity;case St.BlindRemoteButtonState:return bs.BlindsControlButton;case St.FacadeRemoteButtonState:return bs.FacadeControlButton;case St.MovementSensorState:return bs.Movement;case St.PressureSensorState:return bs.AirPressure;case St.WindSpeedState:return bs.WindSpeed;case St.CurrentWindThreshold:return bs.WindThreshold;default:return bs.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=Ps.Null)return e(t.RightArgument,n);t.RightArgumentType=Ps.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new Qs)};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 zs,{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=Gs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Gs.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!=Ps.Condition){if(n.RightArgumentType==Ps.Condition)return t(n.RightArgument,r);throw new so(`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 so(`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 zs,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=Gs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Gs.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==Ps.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==Ps.Null)throw new so(`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 so("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=Ps.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=Gs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Gs.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!=Ps.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new so("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 eo;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==wt.SetBlindPosition||e instanceof Jr?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==wt.SetLightColor||e instanceof jr?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==wt.SetLightTemperature||e instanceof zr?t.Data.Temperature=e.Temperature:e.TaskType==wt.SetLightBrightness||e instanceof Vr?t.Data.Brightness=e.Brightness:e.TaskType==wt.SetTemperature||e instanceof $r?t.Data.Temperature=e.Temperature:e.TaskType==wt.TurnOnWithTime||e instanceof Hr?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==wt.SetLightBrightnessDynamicly||e instanceof Yr?t.Data.Brightness=e.Brightness:e.TaskType==wt.SetBlindOpenCloseTime||e instanceof Qr?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==wt.SetBlindMicroventilation||e instanceof ts?t.Data.Position=e.Position:e.TaskType==wt.SetFacadePosition||e instanceof ss?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):(e.TaskType==wt.LightRGBW||e instanceof as)&&(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 to;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 io("Funcionality will be available in the future.")}LockExecutionTask(e){const t=new no;if(t.LockType=e.LockType,t.LockType==Rs.Timeout&&"00:00:00"!=t.LockEndHour)throw new io("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!=Ps.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 eo&&t.Tasks.DevicesTasks.push(structuredClone(this._tmpTask)),t.Tasks.ControllerTasks.push(structuredClone(this._tmpTask)),this._tmpTask=null,mv.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!=Ps.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 oo("Task not found, cannot edit!");this._tmpTask instanceof eo&&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,mv.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!=Ps.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 wt.Unknown:throw new ro("Unsupported task type!");case wt.SetBlindPosition:case wt.SetBlindPositionSimple:return br.SetBlindPosition;case wt.SetBlindMicroventilation:return br.SetBlindMicroventilation;case wt.TurnOff:return br.TurnOff;case wt.TurnOn:return br.TurnOn;case wt.TurnOnWithTime:return br.TurnOnWithTimeout;case wt.TogleState:return br.ToggleState;case wt.SetLightBrightnessDynamicly:return br.SetLightBrightnessDynamicly;case wt.SetLightBrightness:return br.SetLightBrightness;case wt.SetLightColor:return br.SetLightColor;case wt.SetLightTemperature:return br.SetLightTemperature;case wt.PairDevice:case wt.UnpairDevice:throw new ro("Unsupported task type!");case wt.IdentifyDevice:return br.IdentifyDevice;case wt.GetChannelsState:return br.GetState;case wt.GetPowerMeasurements:case wt.GetAvailableData:case wt.MultipleDataRequest:throw new ro("Unsupported task type!");case wt.SetBlindOpenCloseTime:return br.SetBlindOpenCloseTime;case wt.SetTemperature:return br.SetTemperature;case wt.ChangeGatePositionPulse:return br.GatePulse;case wt.ChangeGatewayPositionPulse:return br.GatewayPulse;case wt.SetFacadePosition:case wt.GetFacadeType:return br.SetFacadePositionAndTilt;case wt.LightRGBW:return br.LightRGBW;default:throw new ro("Unsupported task type!")}}Build(){const e=t=>{if(t.RightArgumentType!=Ps.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==Ps.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}}class zs{constructor(){this.Tasks=new Qs,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=ks.Unknown,this.ConditionType=Gs.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=Ps.Null,this.RightArgumentType=Ps.Null,this.LeftArgument=new Ys({},Ps.Null),this.RightArgument=new Js}}class Js{constructor(){this.HandledType=0,this.Argument=null}}class Ys{constructor(e,t){this.Argument=e,this.HandledType=t}}class Xs{constructor(){this.DeviceStateType=bs.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=_s.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class Qs{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class Zs{constructor(){this.RunParallel=!1,this.TaskType=Ds.Unknown}}class eo extends Zs{constructor(){super(...arguments),this.TaskType=Ds.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=br.TurnOn}}class to extends Zs{constructor(){super(...arguments),this.TaskType=Ds.DelayTask,this.Delay="00:00:00"}}class no extends Zs{constructor(){super(...arguments),this.TaskType=Ds.LockExecution,this.LockType=Rs.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"}(Ps||(Ps={}));class ro extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class so extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class oo extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class io extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var ao,co=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 uo{constructor(){this._connection=mv.Get(Ot.ServiceName),this._configurationService=mv.Get(rt.ServiceName)}GetServiceName(){return uo.ServiceName}GetSequencesListAsync(){var e;return co(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new lo,12e3,!1);return mv.Get(r.ServiceName).Debug(`GetSequencesListAsync result:\n ${JSON.stringify(t)}}`),null==t?new De(Ss.OtherError,"Cannot get sequences list - response is null."):t.Status!=ae.OK?new De(Ss.OtherError,`Cannot get sequences list - controller responded with response code ${t.Status}.`):null==t.Data?new De(Ss.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):t.Data}))}GetSequenceAsync(e){var t;return co(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 ho(n),12e3,!1);if(null==r)return new De(Ss.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ae.OK)return new De(Ss.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new De(Ss.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 js(e,t)}CreateSequenceAsync(e){var t;return co(this,void 0,void 0,(function*(){try{yield this._configurationService.EnterConfigurationModeAsync(),mv.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 vo(e),2e4,!1);return null==n||null==n.Status?ae.Error:n.Status}catch(t){return mv.Get(r.ServiceName).Error(`Creating sequence ${e.Name} error: ${t}`),ae.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){var t;return co(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 po(n),12e3,!1);if(null==r)return new De(Ss.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ae.WrongData:return new De(Ss.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ae.OK:return null==r.Data?new De(Ss.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new De(Ss.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new De(Ss.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){var t;return co(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 mo(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 co(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 yo(n),2e4,!1);return null==r||null==r.Status?ae.Error:r.Status}catch(t){return mv.Get(r.ServiceName).Error(`Editing sequence ${e.Name} error: ${t}`),ae.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}EnableSequenceAsync(e){var t;return co(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 wo(n),12e3,!1);return null==r||null==r.Status?ae.Error:r.Status}))}DisableSequenceAsync(e){var t;return co(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 So(n),12e3,!1);return null==r||null==r.Status?ae.Error:r.Status}))}RunSequenceAsync(e){return co(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 qr;switch(n.Channel=1,n.DeviceGuid=t,yield mv.Get(Ao.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case Tt.Executed:return ae.OK;case Tt.DeviceNotFound:return ae.WrongData;default:return ae.Error}}))}GetUtilsAsync(){return co(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 co(this,void 0,void 0,(function*(){const e=mv.Get(Fs.ServiceName),t=new ms;let n=!1;t.Latitude=49.9958888026741,t.Longitude=18.9172596008914;try{if(yield e.IsControllerGeolocationSetAsync()){const n=yield e.GetControlllerGeolocationAsync();n instanceof ws&&(t.Latitude=n.Latitude,t.Longitude=n.Longitude)}}catch(e){mv.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!=ao.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=Ds.DeviceTask,e.RunParallel=!1})))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=Es.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==Es.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===Es.Condition&&(e.RightArgumentType=this.MapArgumentType(e.RightArgumentType),e.RightArgument=this.MapRightArgument(e.RightArgument,e.RightArgumentType))),e}MapLeftArgument(e,t){let n=new go;switch(n.HandledType=e.HandledType,t){case Es.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case Es.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case Es.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case Es.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case Es.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case Es.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case Es.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case Es.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case Es.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case Es.ArgumentAsDeviceState:{const t=new Ws;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?_s.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam(As[e[0]],new qs(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam(As[e[0]],new Hs(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case Es.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return Es[ao[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case bs.BatteryState:return St.BatteryState;case bs.BinarySensor:return St.BinarySensorState;case bs.BlindPosition:return St.BlindPosition;case bs.Brightness:return St.MeasuredBrightness;case bs.ButtonState:return St.RemoteButtonState;case bs.ChannelOnOff:return St.ChannelOnOffState;case bs.DoorBell:return St.DoorBellState;case bs.Energy:return St.MeasuredEnergy;case bs.FloodSensor:return St.FloodSensorState;case bs.GatePosition:return St.GatePosition;case bs.LightBrightness:return St.LightBrightness;case bs.LightColor:return St.LightColor;case bs.LightTemperature:return St.LightWarmth;case bs.ReedState:return St.ReedState;case bs.SmokeSensor:return St.SmokeSensorState;case bs.Temperature:return St.MeasuredTemperature;case bs.Humidity:return St.HumiditySensorState;case bs.BlindsControlButton:return St.BlindRemoteButtonState;case bs.FacadeControlButton:return St.FacadeRemoteButtonState;case bs.Movement:return St.MovementSensorState;case bs.AirPressure:return St.PressureSensorState;case bs.WindSpeed:return St.WindSpeedState;case bs.WindThreshold:return St.CurrentWindThreshold;default:return St.Unknown}}CreateDeviceState(e,t,n){switch(n){case St.BatteryState:return{Channel:t,StateReliability:Lt.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case St.BinarySensorState:return{Channel:t,StateReliability:Lt.Unconfident,State:e.State,Time:""};case St.BlindPosition:return{Channel:t,StateReliability:Lt.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case St.LightBrightness:case St.MeasuredBrightness:return{Channel:t,StateReliability:Lt.Unconfident,Brightness:e.Brightness,Time:""};case St.RemoteButtonState:case St.ChannelOnOffState:case St.DoorBellState:return{Channel:t,StateReliability:Lt.Unconfident,State:e.State,Time:""};case St.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(jt[t],r);return{Channel:t,StateReliability:Lt.Unconfident,MeasurementParameters:n,Time:""}}case St.FloodSensorState:return{Channel:t,StateReliability:Lt.Unconfident,State:e.State,Time:""};case St.GatePosition:return{Channel:t,StateReliability:Lt.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case St.LightColor:return{Channel:t,StateReliability:Lt.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case St.LightWarmth:return{Channel:t,StateReliability:Lt.Unconfident,Temperature:e.Temperature,Time:""};case St.ReedState:return{Channel:t,StateReliability:Lt.Unconfident,State:e.State,Time:""};case St.SmokeSensorState:throw new Ks("Unsupported device state!");case St.MeasuredTemperature:return{Channel:t,StateReliability:Lt.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case St.HumiditySensorState:return{Channel:t,StateReliability:Lt.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case St.BlindRemoteButtonState:return{Channel:t,StateReliability:Lt.Unconfident,State:e.State,Time:""};case St.LightRGBWState:return{StateReliability:Lt.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case St.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:Lt.Unconfident,State:e.State};case St.MovementSensorState:return{Channel:t,Time:"",StateReliability:Lt.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case St.PressureSensorState:return{Channel:t,Time:"",StateReliability:Lt.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case St.WindSpeedState:return{Channel:t,Time:"",StateReliability:Lt.Unconfident,Value:e.Value};case St.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:Lt.Unconfident,WindThreshold:e.WindThreshold};case St.Unknown:return new yn;default:throw new Ks("Unsupported device state!")}}MapDeviceTask(e){let t=new Br,n=e;switch(mv.Get(r.ServiceName).Debug(`[TASK] object: ${JSON.stringify(n)}`),n.ControlFeature){case br.TurnOn:t=new qr,t.TaskType=wt.TurnOn;break;case br.TurnOff:t=new Wr,t.TaskType=wt.TurnOff;break;case br.ToggleState:t=new Kr,t.TaskType=wt.TogleState;break;case br.SetBlindPosition:t=new Jr,t.TaskType=wt.SetBlindPosition,t.Action=n.Data.Action,t.Position=n.Data.Position;break;case br.SetLightColor:t=new jr,t.TaskType=wt.SetLightColor,t.R=n.Data.R,t.G=n.Data.G,t.B=n.Data.B;break;case br.SetLightTemperature:t=new zr,t.TaskType=wt.SetLightTemperature,t.Temperature=n.Data.Temperature;break;case br.SetLightBrightness:t=new Vr,t.TaskType=wt.SetLightBrightness,t.Brightness=n.Data.Brightness;break;case br.SetTemperature:t=new $r,t.TaskType=wt.SetTemperature,t.Temperature=n.Data.Temperature;break;case br.GetState:t=new es,t.TaskType=wt.GetChannelsState;break;case br.TurnOnWithTimeout:t=new Hr,t.TaskType=wt.TurnOnWithTime,t.SwitchOffDelaySeconds=n.Data.SwitchOffDelaySeconds;break;case br.SetLightBrightnessDynamicly:t=new Yr,t.TaskType=wt.SetLightBrightnessDynamicly,t.Brightness=n.Data.Brightness;break;case br.IdentifyDevice:t=new Xr,t.TaskType=wt.IdentifyDevice;break;case br.SetBlindOpenCloseTime:t=new Qr,t.TaskType=wt.SetBlindOpenCloseTime,t.Data.CloseTime=n.Data;break;case br.SetBlindMicroventilation:t=new ts,t.TaskType=wt.SetBlindMicroventilation,t.Position=n.Data.Position;break;case br.GatewayPulse:t=new rs,t.TaskType=wt.ChangeGatewayPositionPulse;break;case br.GatePulse:t=new ns,t.TaskType=wt.ChangeGatePositionPulse;break;case br.SetFacadePositionAndTilt:t=new ss,t.TaskType=wt.SetFacadePosition,t.Position=n.Data.Position,t.Tilt=n.Data.Tilt,t.FacadeAction=Rr.TiltAndPercentage;break;case br.GetFacadeType:t=new os,t.TaskType=wt.GetFacadeType;break;case br.LightRGBW:t=new as,t.TaskType=wt.LightRGBW,t.Data=n.Data}return t.Channel=n.Channel,t.DeviceGuid=n.DeviceGuid,t.FeatureType=n.ControlFeature,t.Guid=Lr.NewGuid(),t}MapControllerTasks(e){const t=[];mv.Get(r.ServiceName).Debug(`[TASKS] received tasks object: ${JSON.stringify(e)}`);for(let n of e){const e=new fo;switch(e.TaskId=re.GenerateMd5(JSON.stringify(n)),n.TaskType){case Ds.DeviceTask:e.TaskType=Ts.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(n);break;case Ds.DelayTask:e.TaskType=Ts.DelayTask,e.Task.DelayTask={Delay:new Hs(n.Delay)};break;case Ds.NotifyTask:e.TaskType=Ts.NotifyTask,e.Task.NotifyTask={Title:n.Title,Message:n.Message,NotifyType:n.NotifyType};break;case Ds.LockExecution:case Ds.LockExecution:e.TaskType=Ts.LockExecution,mv.Get(r.ServiceName).Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(n)}`),e.Task.LockExecution={LockStartHour:new Hs(n.LockStartHour),LockEndHour:new Hs(n.LockEndHour),LockType:n.LockType,ResetLockScenesGuids:n.ResetLockScenesGuids};case Ds.Unknown:}t.push(e)}return t}}uo.ServiceName="ScenesService";class lo extends ie{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=ce.Get}}class ho extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Get,this.Data=e}}class po extends ie{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=ce.Get,this.Data=e}}class go{constructor(){this.HandledType=ao.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"}(ao||(ao={}));class fo{constructor(){this.TaskId="",this.TaskType=Ts.Unknown,this.Task={}}}class vo extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Put,this.Data=e}}class yo extends ie{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=ce.Put,this.Data=e}}class mo extends ie{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ce.Delete,this.Data=e}}class wo extends ie{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=ce.Post,this.Data=e}}class So extends ie{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=ce.Post,this.Data=e}}var _o=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 Ao{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=mv.Get(Ot.ServiceName),this._session=mv.Get(Ke.ServiceName),this._controllerConfiguration=mv.Get(rt.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>_o(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=>_o(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(Ao.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=>_o(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(Ao.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!=Ct.Scene&&(null===(t=s.Log)||void 0===t||t.Debug(Ao.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==St.SignalStrength?e.Channels.forEach((n=>{let r=new Yn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==St.BatteryState&&e.Channels.forEach((n=>{let r=new xn(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==St.SignalStrength?e.Channels.forEach((n=>{let r=new Yn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==St.BatteryState&&e.Channels.forEach((n=>{let r=new xn(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==St.SignalStrength?e.Channels.forEach((n=>{let r=new Yn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):r.TypeAsEnum==St.BatteryState&&e.Channels.forEach((n=>{let r=new xn(Object.assign({},t));r.Data.Channel=n.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{mv.Get(ke.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=s.Log)||void 0===t||t.Debug(Ao.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{mv.Get(ke.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=s.Log)||void 0===t||t.Debug(Ao.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}ProtocolGuidToProtocolName(e){switch(e){case"1fca7e8a-a2dc-4883-bd94-4e9b2012f685":return"ExtaLife";case"cd25bdff-628c-4dbc-a16a-648c96a819d4":return"Portos 433MHz";case"634c2bb2-1a4f-4db6-8dd4-d5fbaf92678e":return"Supla";case"194aeb81-990c-4a02-9236-59e902958fda":return"RTSP";case"b3e4644e-ab5b-494e-b3c5-66fabe7fff64":return"Wekta";case"247198e1-e360-4355-9886-232ac1456eea":return"Lavva Wi-Fi";default:return null}}CheckIfDeviceUsedInScenesAsync(e){var t,n,r,o,i,a;return _o(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 Mo(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 mv.Get(uo.ServiceName).GetSequencesListAsync();if(c instanceof De)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 Bo;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 _o(this,void 0,void 0,(function*(){const e=mv.Get(ps.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return yield mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),e}))}DisableFastStatesSyncAsync(){return _o(this,void 0,void 0,(function*(){const e=mv.Get(ps.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return yield mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),e}))}IsFastStatesSyncEnabledAsync(){return _o(this,void 0,void 0,(function*(){const e=yield mv.Get(ps.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof ls?e.Data:e!=ae.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return _o(this,void 0,void 0,(function*(){let t=mv.Get(us.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 _o(this,void 0,void 0,(function*(){var t=yield mv.Get(us.ServiceName).AddManuallyPairedDeviceAsync(e);return yield mv.Get(rt.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){var n;let r=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid));if(null==r){let n=new Co;n.Channel=t.Data.Channel,n.States=[t],r={DeviceGuid:e.Guid,ChannelsStates:[n]},this._devicesChannelsStates.push(r)}else{let e=r.ChannelsStates.firstOrDefault((e=>e.Channel==t.Data.Channel));if(null==e)e=new Co,e.Channel=t.Data.Channel,e.States=[t],r.ChannelsStates.push(e);else{let r=e.States.firstOrDefault((e=>e.TypeAsEnum==t.TypeAsEnum));if(null!=r)if(r.TypeAsEnum==St.BlindErrorState){const t=null===(n=r.Data)||void 0===n?void 0:n.ErrorCode;e.States=e.States.where((e=>e.Data.ErrorCode!=t)).toArray()}else 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 _o(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Eo,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 xt;o.DeviceGuid=r[0],o.Channel=Number(r[1]),o.Status=ft.ExecutingTasks,t.push(o),null===(n=s.Log)||void 0===n||n.Debug(Ao.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 mn(t);case"DoorBell":return new _n(t);case"ReedPosition":return new Cn(t);case"BlindPosition":return new Tn(t);case"ButtonState":return new Gn(t);case"LightColor":return new Nn(t);case"LightTemperature":return new In(t);case"LightBrightness":return new Pn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new Un(t);case"BatteryState":return new xn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new Ln(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":return new $n(t);case"DistanceSensor":return new qn(t);case"MovementSensor":return new Hn(t);case"BlindsControlButton":return new Kn(t);case"FacadeControlButton":return new zn(t);case"SignalStrength":return new Yn(t);case"GatePosition":return new Xn(t);case"GatewayPosition":return new Zn(t);case"GateControllerHealth":return new er(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new tr(t);case"HumiditySensor":case"HumidityState":return new nr(t);case"VibrationSensor":return new sr(t);case"DigitalInputSensor":return new or(t);case"ConfigurationState":return new ar(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new cr(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new ur(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new lr(t);case"FacadePosition":case"FacadeState":return new dr(t);case"FacadeTypeState":return new hr(t);case"CurrentWindThreshold":return new pr(t);case"CurrentLightThreshold":return new fr(t);case"WindSpeed":return new vr(t);case"FloodSensor":return new mr(t);case"PressureState":return new Sr(t);case"ITamperProtection":case"TamperProtection":return new Ar(t);case"ILightRGBW":case"LightRGBW":return new Cr(t);case"OnlineCamera":case"IOnlineCamera":return new Sn(t);case"BlindError":case"IBlindError":return t.state.ErrorData=oe(t.state.ErrorData),new Dr(t);default:null===(n=s.Log)||void 0===n||n.Debug(Ao.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return Ao.ServiceName}SyncDevicesStatesAsync(e=!1){var t,n,r;return _o(this,void 0,void 0,(function*(){const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new To,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync()){if(e){let e=new ko;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 ko;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 Tr;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=mt.Unknown;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Ut;if(a.CommunicationWay==At.OneWay)"IBlindPosition"===e&&(t.InterfaceType="IBlindPositionSimple");else switch(e){case"IGatePosition":t.InterfaceType="IGatePulse";break;case"IGatewayPosition":t.InterfaceType="IGatewayPulse";break;default:t.InterfaceType=e}a.AvailableTaskTypes.push(t)})),null===(r=e.AvailableResponses)||void 0===r||r.forEach((e=>{var t=new Mt;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 Ur;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 Mt;t.InterfaceType=e,o.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Ut;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 _o(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 Do,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!=Ct.Scene))):(null===(r=s.Log)||void 0===r||r.Error(Ao.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(e=!1){return _o(this,void 0,void 0,(function*(){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){var e,t;return _o(this,void 0,void 0,(function*(){const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new No,15e3,!1);return null==n?[]:n.Status==ae.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==Ct.Scene)).toArray():(null===(t=s.Log)||void 0===t||t.Error(Ao.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){var e;return _o(this,void 0,void 0,(function*(){mv.Get(ke.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Go,35e3,!1)}))}StopSearchingForDevices(){var e;return _o(this,void 0,void 0,(function*(){yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new bo,2e4,!1)}))}RegisterDeviceAsync(e){var t,n;return _o(this,void 0,void 0,(function*(){try{const n=new Io;n.Data=e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,2e4,!1);return mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.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),Tt.Executed):Tt.Failed}catch(e){return null===(n=s.Log)||void 0===n||n.Error(Ao.ServiceName,`Failed to paired devices: ${e}`),Tt.ControllerResponseTimeout}}))}RemoveDeviceAsync(e,t=!1){var n;return _o(this,void 0,void 0,(function*(){var r=new Ro;t&&(r=new Po),r.Data=e.Guid;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(r,35e3,!1);return mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.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),Tt.Executed):Tt.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new xo;const r=t;switch(r.FeatureType){case br.SetTemperature:n.Data=r.Temperature;break;case br.SetLightBrightness:n.Data=r.Brightness;break;case br.SetLightColor:n=new Fo;const e=r;n.R=e.R,n.G=e.G,n.B=e.B;break;case br.SetLightTemperature:n.Data=r.Temperature;break;case br.SetGatePositionPrecise:switch(r.GateControlAction){case Er.Open:n.Data=101;break;case Er.Close:n.Data=102;break;case Er.Stop:n.Data=103;break;case Er.Percentage:n.Data=r.Position}break;case br.SetBlindPosition:switch(r.Action){case Nr.Open:n.Data=101;break;case Nr.Close:n.Data=102;break;case Nr.Stop:n.Data=103;break;case Nr.Percentage:n.Data=r.Position}break;case br.SetLightBrightnessDynamicly:n.Data=r.Brightness;break;case br.SetBlindOpenCloseTime:n.Data=r.Data;break;case br.SetBlindMicroventilation:n.Data=r.Position;break;case br.SetFacadePositionAndTilt:n=new Lo;const t=r;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case br.LightRGBW:n.Data=r.Data;break;case br.GatePulse:case br.GatewayPulse:n.Data=0;break;case br.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 _o(this,void 0,void 0,(function*(){try{null===(n=s.Log)||void 0===n||n.Debug(Ao.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new Oo(l);null===(r=s.Log)||void 0===r||r.Debug(Ao.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 Tt.Executed;case ae.FatalError:return null===(i=s.Log)||void 0===i||i.Error(Ao.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),Tt.Failed;case ae.WrongData:if("DeviceNotFound"===t.Data)return Tt.DeviceNotFound;break;case ae.Error:return"DeviceResponseTimeout"===t.Data?Tt.DeviceResponseTimeout:(null===(a=s.Log)||void 0===a||a.Error(Ao.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),Tt.Failed)}}catch(e){return e.message.includes("timeout")?(null===(c=s.Log)||void 0===c||c.Error(Ao.ServiceName,`Failed to get controller response in time.\n${e}`),Tt.ControllerResponseTimeout):(null===(u=s.Log)||void 0===u||u.Error(Ao.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Tt.Failed)}return Tt.Unknown}catch(e){return null===(l=s.Log)||void 0===l||l.Error(Ao.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Tt.Failed}}))}ExecuteDevicesTasksAsync(e){var t,n,r,o;return _o(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 Uo(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=Tt.Unknown;switch(t.Status){case ae.OK:return Tt.Executed;case ae.FatalError:null===(n=s.Log)||void 0===n||n.Error(Ao.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),c=Tt.Failed;break;case ae.WrongData:"DeviceNotFound"===t.Data&&(c=Tt.DeviceNotFound);break;case ae.Error:"DeviceResponseTimeout"===t.Data?c=Tt.DeviceResponseTimeout:(null===(a=s.Log)||void 0===a||a.Error(Ao.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),c=Tt.Failed)}let u=0,l=new Ft;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(Ao.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new Ft;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Tt.ControllerResponseTimeout}}else{null===(o=s.Log)||void 0===o||o.Error(Ao.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new Ft;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Tt.Failed}}}return i}))}}Ao.ServiceName="DevicesService";class Co{constructor(){this.Channel=0,this.States=[]}}class Do extends ie{constructor(){super(),this.Resource="/devices/list",this.Method=ce.Get}}class To extends ie{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=ce.Get}}class ko extends ie{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=ce.Get}}class Go extends ie{constructor(){super(),this.Resource="/devices/search",this.Method=ce.Post}}class bo extends ie{constructor(){super(),this.Resource="/devices/search/stop",this.Method=ce.Post}}class No extends ie{constructor(){super(),this.Resource="/devices/found/list",this.Method=ce.Get}}class Eo extends ie{constructor(){super(),this.Resource="/devices/tasks",this.Method=ce.Get}}class Io extends ie{constructor(){super(),this.Resource="/devices/device/pair",this.Method=ce.Put}}class Ro extends ie{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=ce.Put}}class Po extends ie{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=ce.Put}}class Oo extends ie{constructor(e){super(),this.Resource="/devices/device/control",this.Method=ce.Post,this.Data=e}}class Uo extends ie{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=ce.Post,this.Data=e}}class Mo extends ie{constructor(e){super(),this.Resource="/logic/device/used",this.Method=ce.Get,this.Data=e}}class xo{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=br.GetState,this.SequnceExecutionOrder=0}}class Fo extends xo{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class Lo extends xo{constructor(){super(...arguments),this.FacadeAction=Rr.Stop,this.Tilt=0,this.Position=0}}class Bo{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class $o 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 Wo=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 qo extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const Ho=(e,t)=>e===t;class Vo{constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Ko{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 jo{constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class zo extends Array{}const Jo=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Qo(e,t,n,r)}return n?Xo(e,t,n):Yo(e,t)},Yo=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new qo(Wo.NoElements);return n},Xo=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},Qo=(e,t,n,r)=>{let s=t;for(const t of e)s=n(s,t);return r(s)},Zo=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},ei=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},ti=(e,t)=>t?ri(e,t):ni(e),ni=e=>{for(const t of e)return!0;return!1},ri=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},si=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},oi=e=>{if(Array.isArray(e)){if(0===e.length)throw new qo(Wo.NoElements);return new Vo((async function*(){for await(const t of e)yield t}))}return new Vo(e)},ii=e=>oi((async function*(){for(const t of e)yield t})),ai=(e,t)=>new Ko({generator:t,type:e}),ci=e=>ai(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),ui=(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 qo(Wo.NoElements);return n/r},li=async(e,t)=>{let n=0,r=0;for(const s of e)n+=await t(s),r+=1;if(0===r)throw new qo(Wo.NoElements);return n/r},di=(e,t)=>{if(t<1)throw new $o("index");return new jo((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},hi=(e,t)=>new jo((function*(){yield*e,yield*t})),pi=(e,t,n=Ho)=>{for(const r of e)if(n(t,r))return!0;return!1},gi=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},fi=(e,t)=>t?yi(e,t):vi(e),vi=e=>{let t=0;for(const n of e)t++;return t},yi=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},mi=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},wi=(e,t)=>new jo((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),Si=(e,t=Ho)=>new jo((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),_i=(e,t)=>oi((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}})),Ai=(e,t)=>new jo((function*(){for(const n of e)t(n),yield n})),Ci=(e,t)=>oi((async function*(){for(const n of e)await t(n),yield n})),Di=(e,t)=>{if(t<0)throw new $o("index");let n=0;for(const r of e)if(t===n++)return r;throw new $o("index")},Ti=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},ki=(e,t,n=Ho)=>new jo((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)}})),Gi=(e,t,n)=>oi((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)}})),bi=(e,t)=>t?Ei(e,t):Ni(e),Ni=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new qo(Wo.NoElements);return t.value},Ei=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new qo(Wo.NoMatch)},Ii=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new qo(Wo.NoMatch)},Ri=(e,t)=>t?Oi(e,t):Pi(e),Pi=e=>e[Symbol.iterator]().next().value||null,Oi=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},Ui=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class Mi extends zo{constructor(e,t){super(1),this.key=e,this[0]=t}}const xi=(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 Mi(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 Mi(e,r)}for(const e in n)yield n[e]})(e,t),new jo(r)},Fi=(e,t,n)=>n?Bi(e,t,n):Li(e,t),Li=(e,t)=>oi((async function*(){const n={};for(const r of e){const e=await t(r),s=n[e];s?s.push(r):n[e]=new Mi(e,r)}for(const e in n)yield n[e]})),Bi=(e,t,n)=>oi((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 Mi(e,s))}for(const e of r)yield e})),$i=(e,t,n,r)=>r?((e,t,n,r)=>new jo((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 Mi(e,t))}}for(const e of s)yield e})))(e,t,n,r):((e,t,n)=>new jo((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 Mi(e,i)}for(const e in r)yield r[e]})))(e,t,n),Wi=(e,t,n,r,s,o)=>{const i=o?qi(e,t,n,r,s,o):Hi(e,t,n,r,s);return new jo(i)},qi=(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)}},Hi=(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)}},Vi=(e,t,n,r,s,o)=>{const i=o?Ki(e,t,n,r,s,o):ji(e,t,n,r,s);return oi(i)},Ki=(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)}},ji=(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)}},zi=(e,t,n=Ho)=>new jo((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}}})),Ji=(e,t,n)=>oi((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}}}})),Yi=(e,t,n,r,s,o=Ho)=>new jo((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))}}})),Xi=(e,t)=>t?Zi(e,t):Qi(e),Qi=e=>{let t;for(const n of e)t=n;if(!t)throw new qo(Wo.NoElements);return t},Zi=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new qo(Wo.NoMatch);return n},ea=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new qo(Wo.NoMatch);return n},ta=(e,t)=>t?ra(e,t):na(e),na=e=>{let t=null;for(const n of e)t=n;return t},ra=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},sa=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},oa=(e,t)=>t?aa(e,t):ia(e),ia=e=>{let t=null;for(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new qo(Wo.NoElements);return t},aa=(e,t)=>{let n=null;for(const r of e)n=Math.max(n||Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new qo(Wo.NoElements);return n},ca=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 qo(Wo.NoElements);return n},ua=(e,t)=>t?da(e,t):la(e),la=e=>{let t=null;for(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new qo(Wo.NoElements);return t},da=(e,t)=>{let n=null;for(const r of e)n=Math.min(n||Number.POSITIVE_INFINITY,t(r));if(null===n)throw new qo(Wo.NoElements);return n},ha=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 qo(Wo.NoElements);return n},pa=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new jo((function*(){for(const t of e)n(t)&&(yield t)}))};async function*ga(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*fa(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 va extends Vo{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 va?async function*(){for await(const s of e.orderedPairs())yield*ga(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 va(s)}static generate(e,t,n,r){let s;return s=e instanceof va?async function*(){for await(const s of e.orderedPairs())yield*fa(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 va(s)}thenBy(e,t){return va.generate(this,e,!0,t)}thenByAsync(e,t){return va.generateAsync(this,e,!0,t)}thenByDescending(e,t){return va.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return va.generateAsync(this,e,!1,t)}}function*ya(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*ma(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 wa extends jo{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 wa?function*(){for(const s of e.orderedPairs())yield*ya(s,t,n,r)}:()=>ya(e,t,n,r),new wa(s)}static generateAsync(e,t,n,r){let s;return s=e instanceof wa?async function*(){for(const s of e.orderedPairs())yield*ma(s,t,n,r)}:()=>ma(e,t,n,r),new va(s)}thenBy(e,t){return wa.generate(this,e,!0,t)}thenByAsync(e,t){return wa.generateAsync(this,e,!0,t)}thenByDescending(e,t){return wa.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return wa.generateAsync(this,e,!1,t)}}const Sa=(e,t,n)=>wa.generate(e,t,!0,n),_a=(e,t,n)=>wa.generateAsync(e,t,!0,n),Aa=(e,t,n)=>wa.generate(e,t,!1,n),Ca=(e,t,n)=>wa.generateAsync(e,t,!1,n),Da=(e,t)=>{const n=[],r=[];for(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},Ta=async(e,t)=>{const n=[],r=[];for(const s of e)!0===await t(s)?r.push(s):n.push(s);return[r,n]},ka=e=>new jo((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),Ga=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?ba(e,t):Na(e,t)}return Ea(e,t)},ba=(e,t)=>new jo((function*(){for(const n of e)yield t(n)})),Na=(e,t)=>new jo((function*(){let n=0;for(const r of e)yield t(r,n),n++})),Ea=(e,t)=>new jo((function*(){for(const n of e)yield n[t]})),Ia=(e,t)=>"function"==typeof t?1===t.length?Ra(e,t):Pa(e,t):Oa(e,t),Ra=(e,t)=>oi((async function*(){for(const n of e)yield t(n)})),Pa=(e,t)=>oi((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),Oa=(e,t)=>oi((async function*(){for(const n of e)yield n[t]})),Ua=(e,t)=>"function"==typeof t?1===t.length?Ma(e,t):xa(e,t):Fa(e,t),Ma=(e,t)=>new jo((function*(){for(const n of e)for(const e of t(n))yield e})),xa=(e,t)=>new jo((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),Fa=(e,t)=>new jo((function*(){for(const n of e)for(const e of n[t])yield e})),La=(e,t)=>1===t.length?Ba(e,t):$a(e,t),Ba=(e,t)=>oi((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),$a=(e,t)=>oi((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),Wa=(e,t,n=Ho)=>{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},qa=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},Ha=(e,t)=>t?Ka(e,t):Va(e),Va=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new qo(Wo.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new qo(Wo.NoElements);return n},Ka=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new qo(Wo.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new qo(Wo.NoMatch);return r},ja=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new qo(Wo.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new qo(Wo.NoMatch);return r},za=(e,t)=>t?Ya(e,t):Ja(e),Ja=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new qo(Wo.MoreThanOneElement);t=!0,n=r}return n},Ya=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new qo(Wo.MoreThanOneMatchingElement);n=!0,r=s}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 qo(Wo.MoreThanOneElement);n=!0,r=s}return r},Qa=(e,t)=>new jo((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),Za=(e,t)=>1===t.length?ec(e,t):tc(e,t),ec=(e,t)=>new jo((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),tc=(e,t)=>new jo((function*(){let n=0,r=!0;for(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),nc=(e,t)=>1===t.length?rc(e,t):sc(e,t),rc=(e,t)=>oi((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),sc=(e,t)=>oi((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++})),oc=(e,t)=>t?ac(e,t):ic(e),ic=e=>{let t=0;for(const n of e)t+=n;return t},ac=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},cc=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},uc=(e,t)=>new jo((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),lc=(e,t)=>1===t.length?dc(e,t):hc(e,t),dc=(e,t)=>new jo((function*(){for(const n of e){if(!t(n))break;yield n}})),hc=(e,t)=>new jo((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),pc=(e,t)=>1===t.length?gc(e,t):fc(e,t),gc=(e,t)=>oi((async function*(){for(const n of e){if(!await t(n))break;yield n}})),fc=(e,t)=>oi((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),vc=e=>[...e],yc=(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},mc=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},wc=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},Sc=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},_c=e=>new Set(e),Ac=(e,t,n)=>n?Dc(e,t,n):Cc(e,t),Cc=(e,t)=>new jo((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))})),Dc=(e,t,n)=>new jo((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))}})),Tc=(e,t,n)=>oi((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))}})),kc=(e,t)=>1===t.length?Gc(e,t):bc(e,t),Gc=(e,t)=>new jo((function*(){for(const n of e)!0===t(n)&&(yield n)})),bc=(e,t)=>new jo((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),Nc=(e,t)=>1===t.length?Ec(e,t):Ic(e,t),Ec=(e,t)=>oi((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),Ic=(e,t)=>oi((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),Rc=(e,t,n)=>n?Oc(e,t,n):Pc(e,t),Pc=(e,t)=>new jo((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]}})),Oc=(e,t,n)=>new jo((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)}})),Uc=(e,t,n)=>oi((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)}})),Mc=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(Jo,"aggregate"),n(Zo,"all"),n(ei,"allAsync"),n(ti,"any"),n(si,"anyAsync"),n(ii,"asAsync"),n(ci,"asParallel"),n(ui,"average"),n(li,"averageAsync"),n(di,"chunk"),n(hi,"concatenate"),n(pi,"contains"),n(gi,"containsAsync"),n(fi,"count"),n(mi,"countAsync"),n(wi,"defaultIfEmpty"),n(Si,"distinct"),n(_i,"distinctAsync"),n(Ai,"each"),n(Ci,"eachAsync"),n(Di,"elementAt"),n(Ti,"elementAtOrDefault"),n(ki,"except"),n(Gi,"exceptAsync"),n(bi,"first"),n(Ii,"firstAsync"),n(Ri,"firstOrDefault"),n(Ui,"firstOrDefaultAsync"),n(xi,"groupBy"),n(Fi,"groupByAsync"),n($i,"groupByWithSel"),n(Wi,"groupJoin"),n(Vi,"groupJoinAsync"),n(zi,"intersect"),n(Ji,"intersectAsync"),n(Yi,"joinByKey"),n(Xi,"last"),n(ea,"lastAsync"),n(ta,"lastOrDefault"),n(sa,"lastOrDefaultAsync"),n(oa,"max"),n(ca,"maxAsync"),n(ua,"min"),n(ha,"minAsync"),n(pa,"ofType"),n(Sa,"orderBy"),n(_a,"orderByAsync"),n(Aa,"orderByDescending"),n(Ca,"orderByDescendingAsync"),n(ka,"reverse"),n(Ga,"select"),n(Ia,"selectAsync"),n(Ua,"selectMany"),n(La,"selectManyAsync"),n(Wa,"sequenceEquals"),n(qa,"sequenceEqualsAsync"),n(Ha,"single"),n(ja,"singleAsync"),n(za,"singleOrDefault"),n(Xa,"singleOrDefaultAsync"),n(Qa,"skip"),n(Za,"skipWhile"),n(nc,"skipWhileAsync"),n(oc,"sum"),n(cc,"sumAsync"),n(uc,"take"),n(lc,"takeWhile"),n(pc,"takeWhileAsync"),n(vc,"toArray"),n(yc,"toMap"),n(mc,"toMapAsync"),n(wc,"toObject"),n(Sc,"toObjectAsync"),n(Da,"partition"),n(Ta,"partitionAsync"),n(_c,"toSet"),n(Ac,"union"),n(Tc,"unionAsync"),n(kc,"where"),n(Nc,"whereAsync"),n(Rc,"zip"),n(Uc,"zipAsync")},xc=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Bc(e,t,n,r)}return n?Lc(e,t,n):Fc(e,t)},Fc=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new qo(Wo.NoElements);return n},Lc=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},Bc=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},$c=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Wc=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},qc=(e,t)=>t?Vc(e,t):Hc(e),Hc=async e=>{for await(const t of e)return!0;return!1},Vc=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Kc=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},jc=e=>ai(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),zc=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 qo(Wo.NoElements);return n/r},Jc=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 qo(Wo.NoElements);return n/r},Yc=(e,t)=>{if(t<1)throw new $o("index");return new Vo((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Xc=(e,t)=>new Vo((async function*(){yield*e,yield*t})),Qc=async(e,t,n=Ho)=>{for await(const r of e)if(n(t,r))return!0;return!1},Zc=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},eu=(e,t)=>t?nu(e,t):tu(e),tu=async e=>{let t=0;for await(const n of e)t++;return t},nu=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},ru=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},su=(e,t)=>new Vo((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),ou=(e,t=Ho)=>new Vo((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),iu=(e,t)=>new Vo((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}})),au=(e,t)=>new Vo((async function*(){for await(const n of e)t(n),yield n})),cu=(e,t)=>new Vo((async function*(){for await(const n of e)await t(n),yield n})),uu=async(e,t)=>{if(t<0)throw new $o("index");let n=0;for await(const r of e)if(t===n++)return r;throw new $o("index")},lu=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},du=(e,t,n=Ho)=>new Vo((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)}})),hu=(e,t,n)=>new Vo((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)}})),pu=(e,t)=>t?fu(e,t):gu(e),gu=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new qo(Wo.NoElements);return t.value},fu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new qo(Wo.NoMatch)},vu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new qo(Wo.NoMatch)},yu=(e,t)=>t?wu(e,t):mu(e),mu=async e=>(await e[Symbol.asyncIterator]().next()).value||null,wu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},Su=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},_u=(e,t,n)=>n?Au(e,t,n):Cu(e,t),Au=(e,t,n)=>new Vo((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 Mi(e,s))}for(const e of r)yield e})),Cu=(e,t)=>new Vo((async function*(){const n={};for await(const r of e){const e=t(r),s=n[e];s?s.push(r):n[e]=new Mi(e,r)}for(const e in n)yield n[e]})),Du=(e,t,n)=>n?ku(e,t,n):Tu(e,t),Tu=(e,t)=>new Vo((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 Mi(e,r)}for(const e in n)yield n[e]})),ku=(e,t,n)=>new Vo((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 Mi(e,s))}for(const e of r)yield e})),Gu=(e,t,n,r)=>r?Nu(e,t,n,r):bu(e,t,n),bu=(e,t,n)=>new Vo((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 Mi(e,i)}for(const e in r)yield r[e]})),Nu=(e,t,n,r)=>new Vo((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 Mi(e,t))}}for(const e of s)yield e})),Eu=(e,t,n,r,s,o)=>{const i=o?Iu(e,t,n,r,s,o):Ru(e,t,n,r,s);return new Vo(i)},Iu=(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)}},Ru=(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)}},Pu=(e,t,n,r,s,o)=>{const i=o?Ou(e,t,n,r,s,o):Uu(e,t,n,r,s);return new Vo(i)},Ou=(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)}},Uu=(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)}},Mu=(e,t,n=Ho)=>new Vo((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}}}})),xu=(e,t,n)=>new Vo((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}}}})),Fu=(e,t,n,r,s,o=Ho)=>new Vo((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))}}})),Lu=(e,t)=>t?$u(e,t):Bu(e),Bu=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new qo(Wo.NoElements);return t},$u=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new qo(Wo.NoMatch);return n},Wu=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new qo(Wo.NoMatch);return n},qu=(e,t)=>t?Vu(e,t):Hu(e),Hu=async e=>{let t=null;for await(const n of e)t=n;return t},Vu=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},Ku=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},ju=(e,t)=>t?Ju(e,t):zu(e),zu=async e=>{let t=null;for await(const n of e)t=Math.max(t||Number.NEGATIVE_INFINITY,n);if(null===t)throw new qo(Wo.NoElements);return t},Ju=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 qo(Wo.NoElements);return n},Yu=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 qo(Wo.NoElements);return n},Xu=(e,t)=>t?Zu(e,t):Qu(e),Qu=async e=>{let t=null;for await(const n of e)t=Math.min(t||Number.POSITIVE_INFINITY,n);if(null===t)throw new qo(Wo.NoElements);return t},Zu=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 qo(Wo.NoElements);return n},el=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 qo(Wo.NoElements);return n},tl=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Vo((async function*(){for await(const t of e)n(t)&&(yield t)}))},nl=(e,t,n)=>va.generate(e,t,!0,n),rl=(e,t,n)=>va.generateAsync(e,t,!0,n),sl=(e,t,n)=>va.generate(e,t,!1,n),ol=(e,t,n)=>va.generateAsync(e,t,!1,n),il=async(e,t)=>{const n=[],r=[];for await(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},al=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]},cl=e=>new Vo((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]})),ul=(e,t)=>"function"==typeof t?1===t.length?ll(e,t):dl(e,t):hl(e,t),ll=(e,t)=>new Vo((async function*(){for await(const n of e)yield t(n)})),dl=(e,t)=>new Vo((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),hl=(e,t)=>new Vo((async function*(){for await(const n of e)yield n[t]})),pl=(e,t)=>"string"==typeof t?fl(e,t):gl(e,t),gl=(e,t)=>new Vo((async function*(){for await(const n of e)yield t(n)})),fl=(e,t)=>new Vo((async function*(){for await(const n of e)yield n[t]})),vl=(e,t)=>"function"==typeof t?1===t.length?yl(e,t):ml(e,t):wl(e,t),yl=(e,t)=>new Vo((async function*(){for await(const n of e)for(const e of t(n))yield e})),ml=(e,t)=>new Vo((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),wl=(e,t)=>new Vo((async function*(){for await(const n of e)for(const e of n[t])yield e})),Sl=(e,t)=>1===t.length?new Vo((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Vo((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++}})),_l=async(e,t,n=Ho)=>{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},Al=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},Cl=(e,t)=>t?Tl(e,t):Dl(e),Dl=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new qo(Wo.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new qo(Wo.NoElements);return n},Tl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new qo(Wo.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new qo(Wo.NoMatch);return r},kl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new qo(Wo.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new qo(Wo.NoMatch);return r},Gl=(e,t)=>t?Nl(e,t):bl(e),bl=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new qo(Wo.MoreThanOneElement);t=!0,n=r}return n},Nl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new qo(Wo.MoreThanOneMatchingElement);n=!0,r=s}return r},El=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new qo(Wo.MoreThanOneMatchingElement);n=!0,r=s}return r},Il=(e,t)=>new Vo((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),Rl=(e,t)=>1===t.length?Pl(e,t):Ol(e,t),Pl=(e,t)=>new Vo((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Ol=(e,t)=>new Vo((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++})),Ul=(e,t)=>1===t.length?Ml(e,t):xl(e,t),Ml=(e,t)=>new Vo((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),xl=(e,t)=>new Vo((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++})),Fl=(e,t)=>t?Bl(e,t):Ll(e),Ll=async e=>{let t=0;for await(const n of e)t+=n;return t},Bl=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},$l=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},Wl=(e,t)=>new Vo((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),ql=(e,t)=>1===t.length?Hl(e,t):Vl(e,t),Hl=(e,t)=>new Vo((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Vl=(e,t)=>new Vo((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),Kl=(e,t)=>1===t.length?jl(e,t):zl(e,t),jl=(e,t)=>new Vo((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),zl=(e,t)=>new Vo((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),Jl=async e=>{const t=[];for await(const n of e)t.push(n);return t},Yl=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},Xl=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},Ql=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},Zl=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},ed=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},td=(e,t,n)=>n?rd(e,t,n):nd(e,t),nd=(e,t)=>new Vo((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))})),rd=(e,t,n)=>new Vo((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))}})),sd=(e,t,n)=>new Vo((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))}})),od=(e,t)=>1===t.length?id(e,t):ad(e,t),id=(e,t)=>new Vo((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),ad=(e,t)=>new Vo((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),cd=(e,t)=>1===t.length?ud(e,t):ld(e,t),ud=(e,t)=>new Vo((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),ld=(e,t)=>new Vo((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),dd=(e,t,n)=>n?pd(e,t,n):hd(e,t),hd=(e,t)=>new Vo((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]}})),pd=(e,t,n)=>new Vo((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)}})),gd=(e,t,n)=>new Vo((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)}})),fd=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return md(e,t,n,r)}return n?yd(e,t,n):vd(e,t)},vd=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new qo(Wo.NoElements);return n},yd=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},md=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},wd=(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}}},Sd=(e,t)=>{const n=wd(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))}},_d=(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}}},Ad=(e,t)=>{const n=_d(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))}},Cd=(e,t)=>t?Td(e,t):Dd(e),Dd=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}},Td=async(e,t)=>{const n=wd(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)}},kd=async(e,t)=>{const n=_d(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)}},Gd=e=>oi((async function*(){for await(const t of e)yield t})),bd=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)}},Nd=async(e,t)=>{let n;n=t?wd(e,t):e.dataFunc;const r=await bd(n);if(0===r.length)throw new qo(Wo.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},Ed=async(e,t)=>{const n=_d(e,t),r=await bd(n);if(0===r.length)throw new qo(Wo.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},Id=(e,t)=>{if(t<1)throw new $o("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 Ko(n)},Rd=(e,t)=>new Ko({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),Pd=async(e,t,n=Ho)=>{let r;switch(r=wd(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))}},Od=async(e,t,n)=>{const r=_d(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))}},Ud=(e,t)=>t?xd(e,t):Md(e),Md=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},xd=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},Fd=async(e,t)=>{const n=_d(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},Ld=(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 Ko(s)},Bd=(e,t=Ho)=>new Ko({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),$d=(e,t)=>new Ko({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}),Wd=(e,t)=>new Ko(wd(e,(e=>(t(e),e)))),qd=(e,t)=>{const n=_d(e,(async e=>(await t(e),e)));return new Ko(n)},Hd=async(e,t)=>{if(t<0)throw new $o("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new $o("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new $o("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new $o("index");return await e[t]}}},Vd=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]}}},Kd=(e,t,n=Ho)=>new Ko({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}),jd=(e,t,n)=>new Ko({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}),zd=e=>bd(e.dataFunc),Jd=(e,t)=>t?Xd(e,t):Yd(e),Yd=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new qo(Wo.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new qo(Wo.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new qo(Wo.NoElements);return await e[0]}}},Xd=async(e,t)=>{const n=await zd(e);for(const e of n)if(!0===t(e))return e;throw new qo(Wo.NoMatch)},Qd=async(e,t)=>{const n=await zd(e);for(const e of n)if(!0===await t(e))return e;throw new qo(Wo.NoMatch)},Zd=(e,t)=>t?th(e,t):eh(e),eh=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]}}},th=async(e,t)=>{const n=await zd(e);for(const e of n)if(!0===t(e))return e;return null},nh=async(e,t)=>{const n=await zd(e);for(const e of n)if(!0===await t(e))return e;return null},rh=(e,t,n)=>n?oh(e,t,n):sh(e,t),sh=(e,t)=>new Ko({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 Mi(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),oh=(e,t,n)=>new Ko({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 Mi(e,s))}const s=new Array;for(const e of r)s.push(e);return s},type:0}),ih=(e,t,n)=>n?ah(e,t,n):ch(e,t),ah=(e,t,n)=>new Ko({generator:async()=>{const r=_d(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 Mi(e,t))}const i=new Array;for(const e of o)i.push(e);return i},type:0}),ch=(e,t)=>new Ko({generator:async()=>{const n=_d(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 Mi(e,t)}const o=new Array;for(const e in s)o.push(s[e]);return o},type:0}),uh=(e,t,n,r)=>r?lh(e,t,n,r):dh(e,t,n),lh=(e,t,n,r)=>new Ko({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 Mi(e,t))}}const o=new Array;for(const e of s)o.push(e);return o},type:0}),dh=(e,t,n)=>new Ko({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 Mi(e,i)}const s=new Array;for(const e in r)s.push(r[e]);return s},type:0}),hh=(e,t,n,r,s,o)=>{const i=o?ph(e,t,n,r,s,o):gh(e,t,n,r,s);return new Ko({generator:i,type:0})},ph=(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)}))},gh=(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)}))},fh=(e,t,n,r,s,o)=>{const i=o?vh(e,t,n,r,s,o):yh(e,t,n,r,s);return new Ko({generator:i,type:0})},vh=(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)},yh=(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)},mh=(e,t,n=Ho)=>new Ko({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}),wh=(e,t,n)=>new Ko({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}),Sh=(e,t,n,r,s,o=Ho)=>new Ko({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}),_h=(e,t)=>t?Ch(e,t):Ah(e),Ah=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new qo(Wo.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new qo(Wo.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new qo(Wo.NoElements);return await e[e.length-1]}}},Ch=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 qo(Wo.NoMatch)},Dh=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 qo(Wo.NoMatch)},Th=(e,t)=>t?Gh(e,t):kh(e),kh=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]}}},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(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},bh=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},Nh=async(e,t)=>{let n;n=t?wd(e,t):e.dataFunc;const r=await bd(n);if(0===r.length)throw new qo(Wo.NoElements);return Math.max.apply(null,r)},Eh=async(e,t)=>{const n=_d(e,t),r=await bd(n);if(0===r.length)throw new qo(Wo.NoElements);return Math.max.apply(null,r)},Ih=async(e,t)=>{let n;n=t?wd(e,t):e.dataFunc;const r=await bd(n);if(0===r.length)throw new qo(Wo.NoElements);return Math.min.apply(null,r)},Rh=async(e,t)=>{const n=_d(e,t),r=await bd(n);if(0===r.length)throw new qo(Wo.NoElements);return Math.min.apply(null,r)},Ph=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Ko({generator:async()=>{const t=wd(e,n),r=await bd(t),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0})};async function*Oh(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*Uh(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 Mh extends Ko{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 Mh?async function*(){for await(const s of e.orderedPairs())yield*Oh(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 Mh(s)}static generate(e,t,n,r){let s;return s=e instanceof Mh?async function*(){for await(const s of e.orderedPairs())yield*Uh(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 Mh(s)}thenBy(e,t){return Mh.generate(this,e,!0,t)}thenByAsync(e,t){return Mh.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Mh.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Mh.generateAsync(this,e,!1,t)}}const xh=(e,t,n)=>Mh.generate(e,t,!0,n),Fh=(e,t,n)=>Mh.generateAsync(e,t,!0,n),Lh=(e,t,n)=>Mh.generate(e,t,!1,n),Bh=(e,t,n)=>Mh.generateAsync(e,t,!1,n),$h=async(e,t)=>{const n=wd(e,(e=>[t(e),e])),r=await bd(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Wh=async(e,t)=>{const n=_d(e,(async e=>[await t(e),e])),r=await bd(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},qh=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Ko({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Ko({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Hh=(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}}},Vh=(e,t)=>"function"==typeof t?1===t.length?new Ko(wd(e,t)):new Ko(Hh(e,t)):new Ko(wd(e,(e=>e[t]))),Kh=(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}}},jh=(e,t)=>{let n;return n="function"==typeof t?1===t.length?_d(e,t):Kh(e,t):_d(e,(e=>e[t])),new Ko(n)},zh=(e,t)=>new Ko({generator:async()=>{let n;n="function"==typeof t?1===t.length?wd(e,t):Hh(e,t):wd(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}),Jh=(e,t)=>new Ko({generator:async()=>{let n;n=1===t.length?_d(e,t):Kh(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}),Yh=async(e,t,n=Ho)=>{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},Xh=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},Qh=(e,t)=>t?ep(e,t):Zh(e),Zh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new qo(Wo.MoreThanOneElement);if(0===e.length)throw new qo(Wo.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new qo(Wo.MoreThanOneElement);if(0===e.length)throw new qo(Wo.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new qo(Wo.MoreThanOneElement);if(0===e.length)throw new qo(Wo.NoElements);return await e[0]}}},ep=async(e,t)=>{const n=await zd(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new qo(Wo.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new qo(Wo.NoMatch);return s},tp=async(e,t)=>{const n=await zd(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new qo(Wo.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new qo(Wo.NoMatch);return s},np=(e,t)=>t?sp(e,t):rp(e),rp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new qo(Wo.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new qo(Wo.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new qo(Wo.MoreThanOneElement);return 0===e.length?null:await e[0]}}},sp=async(e,t)=>{const n=await zd(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new qo(Wo.MoreThanOneElement);r=!0,s=e}return s},op=async(e,t)=>{const n=await zd(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new qo(Wo.MoreThanOneElement);r=!0,s=e}return s},ip=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Ko({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Ko({generator:()=>n.generator().slice(t),type:1});case 2:return new Ko({generator:async()=>(await n.generator()).slice(t),type:2})}},ap=(e,t)=>new Ko({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}),cp=(e,t)=>new Ko({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}),up=(e,t)=>t?dp(e,t):lp(e),lp=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},dp=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},hp=async(e,t)=>{const n=_d(e,t),r=await bd(n);let s=0;for(const e of r)s+=e;return s},pp=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new Ko({generator:()=>r.generator().splice(0,n),type:1});case 2:return new Ko({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new Ko({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},gp=(e,t)=>new Ko({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}),fp=(e,t)=>new Ko({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}),vp=async(e,t)=>{const n=new Map,r=wd(e,(e=>[t(e),e])),s=await bd(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},yp=async(e,t)=>{const n=new Map,r=_d(e,(async e=>[await t(e),e])),s=await bd(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},mp=async(e,t)=>{const n=e.dataFunc,r=await bd(n),s={};for(const e of r)s[t(e)]=e;return s},wp=async(e,t)=>{const n=_d(e,(async e=>[await t(e),e])),r=await bd(n),s={};for(const[e,t]of r)s[e]=t;return s},Sp=async e=>{const t=e.dataFunc,n=await bd(t);return new Set(n)},_p=(e,t,n)=>n?Cp(e,t,n):Ap(e,t),Ap=(e,t)=>new Ko({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}),Cp=(e,t,n)=>new Ko({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}),Dp=(e,t,n)=>new Ko({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}),Tp=(e,t)=>new Ko({generator:async()=>(await e.toArray()).filter(t),type:0}),kp=(e,t)=>new Ko({generator:async()=>{const n=Kh(e,(async(e,n)=>[await t(e,n),e])),r=await bd(n),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0}),Gp=(e,t,n)=>n?Np(e,t,n):bp(e,t),bp=(e,t)=>new Ko({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}),Np=(e,t,n)=>new Ko({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}),Ep=(e,t,n)=>new Ko({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}),Ip=e=>{var t;const n=zo.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]};Mc(jo),(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(xc,"aggregate"),n($c,"all"),n(Wc,"allAsync"),n(qc,"any"),n(Kc,"anyAsync"),n(jc,"asParallel"),n(zc,"average"),n(Jc,"averageAsync"),n(Yc,"chunk"),n(Xc,"concatenate"),n(Qc,"contains"),n(Zc,"containsAsync"),n(eu,"count"),n(ru,"countAsync"),n(su,"defaultIfEmpty"),n(ou,"distinct"),n(iu,"distinctAsync"),n(au,"each"),n(cu,"eachAsync"),n(uu,"elementAt"),n(lu,"elementAtOrDefault"),n(du,"except"),n(hu,"exceptAsync"),n(pu,"first"),n(vu,"firstAsync"),n(yu,"firstOrDefault"),n(Su,"firstOrDefaultAsync"),n(_u,"groupBy"),n(Du,"groupByAsync"),n(Gu,"groupByWithSel"),n(Eu,"groupJoin"),n(Pu,"groupJoinAsync"),n(Mu,"intersect"),n(xu,"intersectAsync"),n(Fu,"joinByKey"),n(Lu,"last"),n(Wu,"lastAsync"),n(qu,"lastOrDefault"),n(Ku,"lastOrDefaultAsync"),n(ju,"max"),n(Yu,"maxAsync"),n(Xu,"min"),n(el,"minAsync"),n(tl,"ofType"),n(nl,"orderBy"),n(rl,"orderByAsync"),n(sl,"orderByDescending"),n(ol,"orderByDescendingAsync"),n(il,"partition"),n(al,"partitionAsync"),n(cl,"reverse"),n(ul,"select"),n(pl,"selectAsync"),n(vl,"selectMany"),n(Sl,"selectManyAsync"),n(_l,"sequenceEquals"),n(Al,"sequenceEqualsAsync"),n(Cl,"single"),n(kl,"singleAsync"),n(Gl,"singleOrDefault"),n(El,"singleOrDefaultAsync"),n(Il,"skip"),n(Rl,"skipWhile"),n(Ul,"skipWhileAsync"),n(Fl,"sum"),n($l,"sumAsync"),n(Wl,"take"),n(ql,"takeWhile"),n(Kl,"takeWhileAsync"),n(Jl,"toArray"),n(Yl,"toMap"),n(Xl,"toMapAsync"),n(Ql,"toObject"),n(Zl,"toObjectAsync"),n(ed,"toSet"),n(td,"union"),n(sd,"unionAsync"),n(od,"where"),n(cd,"whereAsync"),n(dd,"zip"),n(gd,"zipAsync")})(Vo),(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(fd,"aggregate"),n(Sd,"all"),n(Ad,"allAsync"),n(Cd,"any"),n(kd,"anyAsync"),n(Gd,"asAsync"),n(Nd,"average"),n(Ed,"averageAsync"),n(Id,"chunk"),n(Rd,"concatenate"),n(Pd,"contains"),n(Od,"containsAsync"),n(Ud,"count"),n(Fd,"countAsync"),n(Ld,"defaultIfEmpty"),n(Bd,"distinct"),n($d,"distinctAsync"),n(Wd,"each"),n(qd,"eachAsync"),n(Hd,"elementAt"),n(Vd,"elementAtOrDefault"),n(Kd,"except"),n(jd,"exceptAsync"),n(Jd,"first"),n(Qd,"firstAsync"),n(Zd,"firstOrDefault"),n(nh,"firstOrDefaultAsync"),n(rh,"groupBy"),n(ih,"groupByAsync"),n(uh,"groupByWithSel"),n(hh,"groupJoin"),n(fh,"groupJoinAsync"),n(hh,"groupJoin"),n(fh,"groupJoinAsync"),n(mh,"intersect"),n(wh,"intersectAsync"),n(Sh,"joinByKey"),n(_h,"last"),n(Dh,"lastAsync"),n(Th,"lastOrDefault"),n(bh,"lastOrDefaultAsync"),n(Nh,"max"),n(Eh,"maxAsync"),n(Ih,"min"),n(Rh,"minAsync"),n(Ph,"ofType"),n(xh,"orderBy"),n(Fh,"orderByAsync"),n(Lh,"orderByDescending"),n(Bh,"orderByDescendingAsync"),n($h,"partition"),n(Wh,"partitionAsync"),n(qh,"reverse"),n(Vh,"select"),n(jh,"selectAsync"),n(zh,"selectMany"),n(Jh,"selectManyAsync"),n(Yh,"sequenceEquals"),n(Xh,"sequenceEqualsAsync"),n(Qh,"single"),n(tp,"singleAsync"),n(np,"singleOrDefault"),n(op,"singleOrDefaultAsync"),n(ip,"skip"),n(ap,"skipWhile"),n(cp,"skipWhileAsync"),n(up,"sum"),n(hp,"sumAsync"),n(pp,"take"),n(gp,"takeWhile"),n(fp,"takeWhileAsync"),n(zd,"toArray"),n(vp,"toMap"),n(yp,"toMapAsync"),n(mp,"toObject"),n(wp,"toObjectAsync"),n(Sp,"toSet"),n(_p,"union"),n(Dp,"unionAsync"),n(Tp,"where"),n(kp,"whereAsync"),n(Gp,"zip"),n(Ep,"zipAsync")})(Ko),(()=>{var e;const{prototype:t}=zo,n=Object.getOwnPropertyNames(jo.prototype);for(const r of n)t[r]=null!==(e=t[r])&&void 0!==e?e:jo.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 $o("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 qo(Wo.NoMatch);return t}if(0===this.length)throw new qo(Wo.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 qo(Wo.NoMatch)}if(0===this.length)throw new qo(Wo.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 qo(Wo.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 qo(Wo.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 Rp,Pp;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(Rp||(Rp={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(Pp||(Pp={}));class Op{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==Op._devicesService&&(Op._devicesService=mv.Get(Ao.ServiceName))}GetDevicesChannelsInGroupAsync(e=!1){return t=this,n=void 0,o=function*(){let t=[],n=[];const s=yield Op._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){mv.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 mv.Get(xp.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return mv.Get(xp.ServiceName).ChangeGroupIconNameAsync(this,e)}}var Up,Mp=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._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._objectsGroupingSupported=!1,this._connection=mv.Get(Ot.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{mv.Get(Ke.ServiceName).OnUserLoggedInEvent().Subscribe((t=>Mp(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))}))}SetObjectsInGroupAndOrderAsync(e,t){var n;return Mp(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 Bp(e,s),15e3,!1);switch(mv.Get(ke.ServiceName).ClearCache(),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null==o?void 0:o.Status){case ae.OK:return new De(Rp.Success,"");case ae.NotSupportedMethod:case ae.ResourceDoesNotExists:case ae.ResourceIsNotAvailable:return new De(Rp.FunctionNotSupported,"");case ae.WrongData:return"GroupDoesNotExists"===o.Data?new De(Rp.GroupDoesNotExists,o.Data):new De(Rp.FatalError,o.Data);case ae.Error:case ae.FatalError:default:return new De(Rp.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=mv.Get(r.ServiceName);e.forEach(((e,n)=>{t.Debug(xp.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=mv.Get(r.ServiceName);n.Debug(xp.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(xp.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 Mp(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 Lp(n),15e3,!1);return mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ae.OK?(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),ae.OK):(mv.Get(r.ServiceName).Error(xp.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 Mp(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 Hp(e.Guid,s),15e3,!1);return mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ae.OK?(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync(),ae.OK):(mv.Get(r.ServiceName).Error(xp.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 Mp(this,void 0,void 0,(function*(){const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Fp(e.Guid,t),15e3,!1);return mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ae.OK?(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),ae.OK):(mv.Get(r.ServiceName).Error(xp.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 Mp(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 qp(e.Guid,o,n),15e3,!1);return mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ae.OK?(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync(),ae.OK):(mv.Get(r.ServiceName).Error(xp.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 Mp(this,void 0,void 0,(function*(){const o=new Yp;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 mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status?(i.Status==ae.OK?e.ChannelGroups.push(t):mv.Get(r.ServiceName).Error(xp.ServiceName,`Failed to add device channel ${e.Name} to group ${t}, controller responded with error ${i.Status} data: ${i.Data}`),mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync(),i.Status):(yield this.GetGroupsAsync(),ae.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){var n,s;return Mp(this,void 0,void 0,(function*(){const o=new Xp;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 mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status?(i.Status==ae.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():mv.Get(r.ServiceName).Error(xp.ServiceName,`Failed to remove device channel ${e.Name} from group ${t}, controller responded with error ${i.Status} data: ${i.Data}`),mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync(),i.Status):(yield this.GetGroupsAsync(),ae.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Mp(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 Op))return t instanceof De?t:new De(Pp.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(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync(),t!==ae.OK)return mv.Get(r.ServiceName).Error(xp.ServiceName,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`),new De(Pp.UnknownError,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`)}let n=yield mv.Get(Ao.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(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(),t!==ae.OK)return mv.Get(r.ServiceName).Error(xp.ServiceName,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),new De(Pp.UnknownError,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`)}return mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Mp(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(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(),t!==ae.OK)return mv.Get(r.ServiceName).Error(xp.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),ae.FatalError}let n=yield mv.Get(Ao.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(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync(),t!==ae.OK)return mv.Get(r.ServiceName).Error(xp.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),ae.FatalError}return mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),ae.OK}))}ChangeGroupNameByGuidAsync(e,t){var n,r;return Mp(this,void 0,void 0,(function*(){let s=new Jp,o=new Qp,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(mv.Get(ke.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ae.OK:return new De(Pp.Success,"");case ae.WrongData:switch(a.Data){case"NameToShort":return new De(Pp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new De(Pp.NameAlreadyExists,"Group with this name already exists");default:return new De(Pp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new De(Pp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new De(Pp.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){var r,s;return Mp(this,void 0,void 0,(function*(){let o=new Jp,i=new Qp,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(mv.Get(ke.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),null!=c&&null!=c.Status)switch(c.Status){case ae.OK:return new De(Pp.Success,"");case ae.WrongData:switch(c.Data){case"NameToShort":return new De(Pp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new De(Pp.NameAlreadyExists,"Group with this name already exists");default:return new De(Pp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new De(Pp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new De(Pp.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){var n,r;return Mp(this,void 0,void 0,(function*(){let s=new Jp,o=new Qp,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(mv.Get(ke.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ae.OK:return new De(Pp.Success,"");case ae.WrongData:switch(a.Data){case"NameToShort":return new De(Pp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new De(Pp.NameAlreadyExists,"Group with this name already exists");default:return new De(Pp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new De(Pp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new De(Pp.UnknownError,"")}))}GetServiceName(){return xp.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 Mp(this,void 0,void 0,(function*(){let n=new jp;n.Data=e;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync();for(let t of yield mv.Get(Ao.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 mv.Get(rt.ServiceName).ExitConfigurationModeAsync(),null!=r&&null!=r.Status?null==r?void 0:r.Status:ae.Error}))}GetGroupsAsync(e=!1){var t,n;return Mp(this,void 0,void 0,(function*(){const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new zp,15e3,e);let o=[];if((null==s?void 0:s.Status)===ae.OK){let e=mv.Get(r.ServiceName),t=0,i=yield mv.Get(Ao.ServiceName).GetDevicesAsync();return null===(n=s.Data)||void 0===n||n.forEach((n=>{t++;let r=new Op;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(xp.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 Mp(this,void 0,void 0,(function*(){let s=new Jp,o=new Qp;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(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync(),mv.Get(rt.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(mv.Get(r.ServiceName).Error(xp.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new De(Pp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new De(Pp.NameAlreadyExists,"Group with this name already exists");default:return new De(Pp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new De(Pp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new De(Pp.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){var n,s;return Mp(this,void 0,void 0,(function*(){let o=new Jp,i=new Qp;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(mv.Get(ke.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield mv.Get(Ao.ServiceName).GetDevicesAsync(),mv.Get(rt.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(mv.Get(r.ServiceName).Error(xp.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new De(Pp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new De(Pp.NameAlreadyExists,"Group with this name already exists");default:return new De(Pp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new De(Pp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new De(Pp.UnknownError,"")}))}}xp.ServiceName="ChannelsGroupsService";class Fp extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=ce.Post,this.Data=new Wp,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class Lp extends ie{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=ce.Post,this.Data=e}}class Bp extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=ce.Post,this.Data=new $p,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class $p{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Wp{constructor(){this.GroupGuid="",this.NewPosition=0}}class qp extends ie{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=ce.Post,this.Data=new Vp,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Hp extends ie{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=ce.Post,this.Data=new Kp,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class Vp{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class Kp{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class jp extends ie{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ce.Delete}}class zp extends ie{constructor(){super(),this.Resource="/devices/groups/",this.Method=ce.Get}}class Jp extends ie{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ce.Put,this.Data=[]}}class Yp extends ie{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ce.Put,this.Data=new Zp}}class Xp extends ie{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ce.Delete,this.Data=new Zp}}class Qp{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class Zp{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class eg{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"}(Up||(Up={}));var tg,ng,rg=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 sg{constructor(){this._syncLock=new eg,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=Up.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",(()=>rg(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(sg.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=s.Log)||void 0===r||r.Warning(sg.ServiceName,"Back button pressed"),null===(o=this._onBackButtonPressedEvent)||void 0===o||o.Invoke()))}))}MonitorAppState(){return rg(this,void 0,void 0,(function*(){this._session=yield mv.GetAsync("SessionService"),this._connection=yield mv.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=s.Log)||void 0===t||t.Warning(sg.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(Up.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=s.Log)||void 0===t||t.Warning(sg.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(Up.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(sg.ServiceName,"App state changed to: connected"),this._onAppStateChanged.Invoke(Up.Connected);break;case de.Disconnected:null===(n=s.Log)||void 0===n||n.Warning(sg.ServiceName,"App state changed to: disconnected"),this._onAppStateChanged.Invoke(Up.Disconnected);break;case de.Connecting:null===(r=s.Log)||void 0===r||r.Warning(sg.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(Up.Connecting);break;case de.Disconnecting:null===(o=s.Log)||void 0===o||o.Warning(sg.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(Up.Disconnecting);break;case de.Reconnecting:null===(i=s.Log)||void 0===i||i.Warning(sg.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(Up.Reconnecting);break;case de.Failed:null===(a=s.Log)||void 0===a||a.Warning(sg.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(Up.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(Up.Suspended),null===(e=s.Log)||void 0===e||e.Warning(sg.ServiceName,"App state changed to: suspended"),null===(t=s.Log)||void 0===t||t.Warning(sg.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(Up.ReturnedFromSuspension),null===(e=s.Log)||void 0===e||e.Warning(sg.ServiceName,"App state changed to: returned from suspension"),null===(t=s.Log)||void 0===t||t.Warning(sg.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Up.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Up.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 sg.ServiceName}}sg.ServiceName="AppStateService",function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(tg||(tg={}));class og{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=ng.Unknown,this.ResourceGuid=""}}class ig{constructor(){this.UpdateDescription=new Map,this.Update=new og,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"}(ng||(ng={}));class ag extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var cg,ug,lg,dg,hg,pg,gg,fg,vg,yg,mg=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 wg{constructor(){this._services=new Map,this._runtimeInfo=new Sg,this._hardwareInfo=new Ag,this._semaphore=new Ye(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return wg.ServiceName}RegisterUpdatesProvider(e){mv.Get(r.ServiceName).Debug(wg.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return mg(this,void 0,void 0,(function*(){mv.Get(r.ServiceName).Debug(wg.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const t=this._services.get(e);if(null==t)throw new ag("Cannot get update provider! Requested update provider has not been registered.");return t}))}GetUpdatesProvidersAsync(e){return mg(this,void 0,void 0,(function*(){mv.Get(r.ServiceName).Debug(wg.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 ag("Cannot get update providers! Requested update providers has not been registered.");return t}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return mg(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)){mv.Get(r.ServiceName).Debug(wg.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 ag("Cannot get update providers! Requested update providers has not been registered.");return s}throw new ag("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return mg(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)){mv.Get(r.ServiceName).Debug(wg.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 ag("Cannot get update providers! Requested update providers has not been registered.");return s}throw new ag("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(e=!1){return mg(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 mg(this,void 0,void 0,(function*(){mv.Get(r.ServiceName).Debug(wg.ServiceName,"Getting runtime version info from controller.");try{const e=yield mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(new _g,16e3,!1);if(null==e||null==e.Status)throw new Dg('Cannot get runtime info, controller response result is empty."',cg.EmptyResponse);if(e.Status!=ae.OK)throw new Dg(`Cannot get runtime info, controller responded with status ${e.Status}.`,cg.WrongResponseStatus);if(null==e.Data)throw new Dg("Cannot get runtime info, controller responded with status OK but response does not contains data.",cg.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof p?new Dg("Cannot get runtime info, controller response timeout.",cg.Timeout):e}}))}GetHardwareInfoAsync(e=!1){return mg(this,void 0,void 0,(function*(){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return mg(this,void 0,void 0,(function*(){mv.Get(r.ServiceName).Debug(wg.ServiceName,"Getting hardware info from controller.");const e=yield mv.Get(Ot.ServiceName).SendAndWaitForResponseAsync(new Cg,8e3,!1);if(null==e||null==e.Status)throw new Dg('Cannot get hardware info, controller response result is empty."',cg.EmptyResponse);if(e.Status!=ae.OK)throw new Dg(`Cannot get hardware info, controller responded with status ${e.Status}.`,cg.WrongResponseStatus);if(null==e.Data)throw new Dg("Cannot get hardware info, controller responded with status OK but response does not contains data.",cg.NoDataInResponse);this._hardwareInfo=e.Data,this._isRuntimeInfoInitialized=!0}))}}wg.ServiceName="UpdateProvider";class Sg{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class _g extends ie{constructor(){super(),this.Resource="/controller/software/info",this.Method=ce.Get}}class Ag{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class Cg extends ie{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=ce.Get}}class Dg 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"}(cg||(cg={}));class Tg{constructor(){this.DeviceGuid="",this.CurrentVersion="",this.NewVersion=""}}class kg{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class Gg{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class bg{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(ug||(ug={})),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"}(lg||(lg={})),(yg=dg||(dg={}))[yg.WaitingForUser=1]="WaitingForUser",yg[yg.Downloading=2]="Downloading",yg[yg.Unpackaging=3]="Unpackaging",yg[yg.CheckingApplicability=4]="CheckingApplicability",yg[yg.MigratingData=5]="MigratingData",yg[yg.CreatingBackup=6]="CreatingBackup",yg[yg.Deploying=7]="Deploying",yg[yg.Installing=8]="Installing",yg[yg.Removing=9]="Removing",yg[yg.Error=10]="Error",yg[yg.ReadyToDownload=11]="ReadyToDownload",yg[yg.PreparingSystem=12]="PreparingSystem",yg[yg.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",yg[yg.CheckingIntegrity=14]="CheckingIntegrity",yg[yg.UndoingInstallation=15]="UndoingInstallation",yg[yg.Installed=16]="Installed",(vg=hg||(hg={}))[vg.Ignore=0]="Ignore",vg[vg.Cancel=1]="Cancel",vg[vg.Install=2]="Install";class Ng{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=lg.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class Eg{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=pg.Unknown}}!function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate"}(pg||(pg={})),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"}(gg||(gg={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(fg||(fg={}));var Ig,Rg,Pg,Og,Ug,Mg,xg,Fg,Lg=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 Bg{constructor(){this._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5,this._oldUpdateBuild=56,this._updateOfflineStageTime=8.5,this._updateProviders=mv.Get(wg.ServiceName),this._logger=mv.Get(r.ServiceName),this._connection=mv.Get(Ot.ServiceName),this._appStateService=mv.Get(sg.ServiceName),this._extensionService=mv.Get(Qe.ServiceName)}GetAutomaticControllerUpdateDownloadStatusAsync(){return Lg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof De)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new De(gg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let r=yield this._connection.SendAndWaitForResponseAsync(new ef,1e4,!1);return!(r.Status!=ae.OK||!r.Data)}))}GetServiceName(){return Bg.ServiceName}CheckDeviceVersionAsync(e){var t;return Lg(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield mv.Get(Ao.ServiceName).GetDevice(e);if(null==t)return new De(gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new De(gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,tg.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){var t;return Lg(this,void 0,void 0,(function*(){let n;if("string"==typeof e){const t=yield mv.Get(Ao.ServiceName).GetDevice(e);if(null==t)return new De(gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new De(gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,tg.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const s=new qg;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 mv.Get(Ao.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(s.IsUpdateSafe=!1),s}))}InstallDeviceUpdateAsync(e,t,n,r=!1){var s;return Lg(this,void 0,void 0,(function*(){let o;if("string"==typeof e){const t=yield mv.Get(Ao.ServiceName).GetDevice(e);if(null==t)return new De(gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);o=t}else o=e;if(null==o.ProtocolGuid)return new De(gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(s=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(o.ProtocolGuid,tg.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,tg.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ae.OK)}))}CheckControllerSoftwareUpdateAvailabilityAsync(){return Lg(this,void 0,void 0,(function*(){const e=mv.Get(Ke.ServiceName).User;if(null==e)return!1;if(""==e.SoftwareVersion||null==e.SoftwareVersion)return!0;const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<=this._oldUpdateVersion&&parseFloat(n)<=this._oldUpdateBuild)return!0;const r=yield this._connection.SendAndWaitForResponseAsync(new Yg,1e4,!1);if(null==r||r.Status!=ae.OK||null==r.Data)return!1;const[s,o]=r.Data.Update.Version.ContainerSoftwareVersion.toString().split(".");return parseInt(s)>parseInt(t)||parseInt(s)==parseInt(t)&&parseInt(o)>parseInt(n)}))}CheckDevicesUpdatesAvailabilityAsync(){return Lg(this,void 0,void 0,(function*(){const e=yield this._connection.SendAndWaitForResponseAsync(new sf,1e4,!1),t=[];return null==e||(null==e?void 0:e.Status)!=ae.OK||null==(null==e?void 0:e.Data)?[]:(null==e||e.Data.forEach((e=>{if(!e.IsAvailable)return;const n=new Tg;n.DeviceGuid=e.DeviceGuid,n.CurrentVersion=e.CurrentVersion,n.NewVersion=e.NewVersion,t.push(n)})),t)}))}CheckControllerUpdatesAsync(){return Lg(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new kg,n=yield this.getRuntimeInfoAsync();if(n instanceof De){const e=new $g;return e.UpdateType=ug.SoftwareUpdate,e.ResponseResult=n,t.UpdatesNotAvailable.push(e),t}const r=parseInt(n.SoftwareVersion.toString().split(".")[0]),s=parseInt(n.SoftwareVersion.toString().split(".")[1]);try{e=yield this._updateProviders.GetUpdatesProvidersAsync(tg.Controller)}catch(e){if(!(e instanceof ag))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 $g;s.ResponseResult=r,s.UpdateType=ug.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 Wg;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=ug.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:ug.RadioUpdate}))}}let o=!0;if(r<=this._oldUpdateVersion&&s<=this._oldUpdateBuild&&(o=!1),o){const e=yield this._connection.SendAndWaitForResponseAsync(new Yg,15e3,!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 ig;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 Wg;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=ug.SoftwareUpdate,s.UpdateIdentifier=e.Data.Update.Guid,s.UpdateIsDownloading=e.Data.UpdateStep==Og.DownloadingInstaller||e.Data.UpdateStep==Og.DownloadingUpdate||e.Data.UpdateStep==Og.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:Bg.ServiceName,UpdateType:ug.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Xg,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ae.NoData:const r=new $g;r.UpdateType=ug.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new De(gg.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 ig;s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateDescription=oe(e.Data.UpdateDescription),s.UpdatedResourceName=oe(e.Data.UpdateName).get("en-US");const o=new Wg;o.UpdatedResourceName=oe(e.Data.UpdateName),o.UpdateDescription=oe(e.Data.UpdateDescription),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateType=ug.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:Bg.ServiceName,UpdateType:ug.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 ig;const i=new $g;switch(i.UpdateType=ug.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 De(gg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new De(gg.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 Wg;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=ug.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:Bg.ServiceName,UpdateType:ug.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 De){const e=new $g;e.UpdateType=ug.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new $g;r.UpdateType=ug.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new De(gg.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return Lg(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(tg.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof De)return t;const n=[];let r;r=new bg,r.Resource="Controller software",r.Type=ug.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new bg,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=ug.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 Lg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof De)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new De(gg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new zg,1e4,!1);if(null==r||(null==r?void 0:r.Status)!=ae.OK)return new De(gg.CannotGetUpdatesBranch,`Cannot get update branch, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data){case 0:return fg.Public;case 1:return fg.Beta;case 2:return fg.Development;default:return new De(gg.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${r.Data}`)}}))}SetControllerUpdateBranchAsync(e){return Lg(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof De)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);if(n<=this._oldUpdateVersion&&r<=this._oldUpdateBuild)return new De(gg.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const s=yield this._connection.SendAndWaitForResponseAsync(new Jg(e),1e4,!1);return null==s||(null==s?void 0:s.Status)!=ae.OK?new De(gg.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==s?void 0:s.Status}`):ae.OK}))}EnableAutomaticControllerUpdateDonwloadAsync(){return Lg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof De)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new De(gg.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new tf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ae.OK?new De(gg.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ae.OK}))}DisableAutomaticControllerUpdateDonwloadAsync(){return Lg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof De)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new De(gg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new nf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ae.OK?new De(gg.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ae.OK}))}GetControllerUpdatesHistoryAsync(){return Lg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof De)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new De(gg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new rf,1e4,!1);if(null==r)return new De(gg.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(r.Status){case ae.OK:return null!=r.Data?r.Data.map((e=>{const t=new Gg;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 De(gg.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ae.NoData:return[];default:return new De(gg.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${r.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,s){return Lg(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 De)return a;const c=parseInt(a.SoftwareVersion.toString().split(".")[0]),u=parseInt(a.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new De(gg.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=>Lg(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let l=this._controllerUpdates.where((e=>e.UpdateType==ug.RadioUpdate)).toArray(),d=[];this._appStateService.DisallowHibernation();for(let e=0;e<l.length;e++){const t=yield(yield this._updateProviders.GetUpdatesProviderAsync(l[e].ProviderName)).InstallRadioUpdateAsync(l[e],o,n);yield a(5e3),t==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=l[e].UpdateIdentifier))),d.push(t),s[0]++}const h=this._controllerUpdates.find((e=>e.UpdateType==ug.SoftwareUpdate));if(null!=h)if(c<=this._oldUpdateVersion&&u<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(h.Update,o);e==ae.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=h.UpdateIdentifier))),d.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))),d.push(e),s[0]++}const p=d.where((e=>e instanceof De)).toArray();if(null!=p&&0!=p.length){let e="";return p.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),new De(gg.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 De(gg.CannotGetUpdates,`Update with requested guid (${n}) not found.`);switch(this._logger.Debug(`Installing single update type: ${i.Update.UpdateType}, resource: ${i.UpdatedResourceName}, version: ${i.Update.Version}`),this._appStateService.DisallowHibernation(),i.UpdateType){case ug.RadioUpdate:return r?new De(gg.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 ug.SoftwareUpdate:if(c<=this._oldUpdateVersion&&u<=this._oldUpdateBuild){if(r)return new De(gg.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 De(gg.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){var n,r,s,o,i,a;return Lg(this,void 0,void 0,(function*(){switch(e.UpdateType){case ng.Container:case ng.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new Hg(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new Ng;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ae.MultiDataResponseStart:r.Status=lg.PreparingForUpgrade;break;case ae.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(Bg.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case dg.CheckingApplicability:case dg.CheckingIntegrity:case dg.CheckingPackageIntegrity:r.Status=lg.CheckingPackage;break;case dg.CreatingBackup:case dg.MigratingData:case dg.Removing:r.Status=lg.MovingData;break;case dg.Deploying:case dg.Installing:r.Status=lg.Upgrading;break;case dg.Downloading:r.Status=lg.DownloadingPackage;break;case dg.Error:r.Status=lg.Error;break;case dg.Installed:r.Status=lg.Upgraded;break;case dg.PreparingSystem:case dg.ReadyToDownload:r.Status=lg.PreparingForUpgrade;break;case dg.UndoingInstallation:r.Status=lg.InstallationStopped;break;case dg.Unpackaging:r.Status=lg.MovingData;break;case dg.WaitingForUser:r.Status=lg.Upgrading}break;case ae.MultiDataResponseStop:r.Status=lg.OK}t(r)}),!1),ae.OK}catch(e){return new De(gg.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case ng.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 De)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield mv.Get(Ao.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(Bg.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new Ng;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=lg.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)=>Lg(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=lg.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=lg.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=lg.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=lg.Upgrading,t(r))}s++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Vg(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ae.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=lg.InstallationError,t(r),this._logger.Debug(Bg.ServiceName,`Update failed with error. Update response status: ${d.Status}`),o(new De(gg.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(Bg.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=lg.Error,t(r),clearInterval(n),o(new De(gg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new Ng;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=lg.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new De(gg.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Kg({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=lg.PreparingForUpgrade,t(n);let r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new jg("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=lg.PreparingForUpgrade,t(n),r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new jg(`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=lg.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new jg("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=lg.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)=>Lg(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=lg.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=lg.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=lg.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=lg.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new jg("/runtime/tmp/update.sh"),12e3,!1)}catch(e){o(new De(gg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=lg.InstallationError,t(n),new De(gg.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new jg("/runtime/scripts/restart_all.sh"),12e3,!1),new De(gg.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new De(gg.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new De(gg.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new De(gg.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}UpdateControllerUsingApiAsync(e,t,n){return Lg(this,void 0,void 0,(function*(){const r=e=>Lg(this,void 0,void 0,(function*(){return new Promise(((r,s)=>Lg(this,void 0,void 0,(function*(){yield this._connection.SendAndHandleResponseAsync(new Qg,this._updateRequestTimeout,(s=>{var o,i,a,c;const u=new Eg;switch(u.UpdatedResourceName=oe(e.Update.UpdateName),s.Status){case ae.MultiDataResponseStart:u.Percentage=0,u.SpeedMbps=0,u.PercentageTotal=0,u.CurrentTask=pg.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 Og.DownloadingInstaller:u.CurrentTask=pg.DownloadingInstaller;break;case Og.DownloadingUpdate:u.CurrentTask=pg.DownloadingUpdate;break;default:u.CurrentTask=pg.CheckingUpdate}t(u)}break;case ae.MultiDataResponseStop:if(null!=s.Data)switch(s.Data.UpdateStep){case Og.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=pg.CheckingUpdate,t(u),r(ae.OK);break;case Og.UpdateDownloadFailed:u.Percentage=0,u.PercentageTotal=0,u.SpeedMbps=0,u.CurrentTask=pg.Unknown,t(u),r(new De(gg.UpdateDownloadFailed,"Update download failed!"))}}}),!1)}))))})),s=t=>Lg(this,void 0,void 0,(function*(){return new Promise(((n,r)=>Lg(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 Ng;switch(c.UpdatedResourceName=oe(t.Update.UpdateName),o.Status){case ae.MultiDataResponseStart:c.Status=lg.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=lg.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 Og.UpdateInstallationFailed:c.Status=lg.InstallationError,c.Percentage=0,c.PercentageTotal=0,e(c),n(new De(gg.CannotProcessUpdate,"Update installation failed!"));break;case Og.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=lg.Upgraded,c.Percentage=100,c.PercentageTotal=100,e(c),clearInterval(a),n(ae.OK)):(c.Status=lg.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 Yg,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 Og.DownloadingInstaller:case Og.DownloadingUpdate:case Og.UpdateDownloaded:return new De(gg.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case Og.InstallingUpdate:case Og.PreparingUpdate:return new De(gg.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield r(e.Data)}}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Yg,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 Og.DownloadingInstaller:case Og.DownloadingUpdate:return new De(gg.UpdateAlreadyDownloaded,"Update already downloaded, or donwload in progress.");case Og.InstallingUpdate:case Og.PreparingUpdate:return new De(gg.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case Og.UpdateDownloaded:return yield s(e.Data);default:var o=yield r(e.Data);return o!=ae.OK?o:yield s(e.Data)}}}))}getRuntimeInfoAsync(){return Lg(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof Dg&&e.code==cg.Timeout?new De(gg.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new De(gg.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}Bg.ServiceName="UpdatesService";class $g{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class Wg{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 qg{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 Hg 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"}(Ig||(Ig={})),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"}(Rg||(Rg={})),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"}(Pg||(Pg={})),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"}(Og||(Og={}));class Vg extends ie{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=ce.Put,this.Data=e}}class Kg extends ie{constructor(e){super(),this.Resource="/users/user/login",this.Method=ce.Put,this.Data=e}}class jg extends ie{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=ce.Post,this.Data=e}}class zg extends ie{constructor(){super(),this.Resource="/updates/branch",this.Method=ce.Get}}class Jg extends ie{constructor(e){super(),this.Resource="/updates/branch",this.Method=ce.Put,this.Data=e}}class Yg extends ie{constructor(){super(),this.Resource="/updates/pending",this.Method=ce.Get}}class Xg extends ie{constructor(){super(),this.Resource="/updates/check",this.Method=ce.Get}}class Qg 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 ef extends ie{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=ce.Get}}class tf extends ie{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=ce.Put}}class nf extends ie{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=ce.Put}}class rf extends ie{constructor(){super(),this.Resource="/updates/history",this.Method=ce.Get}}class sf extends ie{constructor(){super(),this.Resource="/updates/devices/availability",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"}(Ug||(Ug={})),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"}(Mg||(Mg={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(xg||(xg={}));class of{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"}(Fg||(Fg={}));var af,cf,uf,lf,df,hf,pf,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._connection=null,this._connection=mv.Get(Ot.ServiceName)}GetServiceName(){return ff.ServiceName}GetStatesByIntervalAsync(e,t,n,r,s,o,i=!1){var a;return gf(this,void 0,void 0,(function*(){try{if(!(yield this.IsFunctionalitySupportedAsync()))return new De(Ug.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 mv.Get(Ao.ServiceName).GetDevice(e);if(null==t)return new De(Ug.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new De(Ug.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 De(Ug.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new yf;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 vf(u),2e4,!1);if(null==l)return new De(Ug.OtherError,"Cannot get state history data - response is null.");switch(l.Status){case ae.WrongData:switch(l.Data){case"IncorrectLimitValue":return new De(Ug.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new De(Ug.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new De(Ug.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new De(Ug.OtherError,"Cannot get state history data - unknown error!")}case ae.FatalError:return new De(Ug.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ae.ResourceDoesNotExists:return new De(Ug.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ae.OK:if(null==l.Data)return new De(Ug.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===St.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 De(Ug.OtherError,`Cannot get state history data - controller responded with response code ${l.Status}`)}}catch(e){return new De(Ug.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){var e;return gf(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new mf,12e3,!1);return null==t?new De(Ug.OtherError,"Cannot get available states - response is null."):t.Status!=ae.OK?new De(Ug.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new De(Ug.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new of;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new De(Ug.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return gf(this,void 0,void 0,(function*(){return!(parseFloat((yield mv.Get(wg.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion)<=3.42)}))}GetAvailableStatesPerChannelAsync(e,t){var n;return gf(this,void 0,void 0,(function*(){let r;if("string"==typeof e){const t=yield mv.Get(Ao.ServiceName).GetDevice(e);if(null==t)return new De(Ug.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 wf(new Sf(r.Guid,t)),8e3,!1);if(null==s)return new De(Ug.OtherError,"Cannot get available states - response is null.");switch(s.Status){case ae.ResourceDoesNotExists:switch(s.Data){case"DeviceNotFound":return new De(Ug.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new De(Ug.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new De(Ug.OtherError,"Cannot get available states - unknown error!")}case ae.OK:{if(null==s.Data)return new De(Ug.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 of;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return s.Data.AvailableStates=e,s.Data}default:return new De(Ug.OtherError,`Cannot get available states - controller responded with response code ${s.Status}`)}}))}}ff.ServiceName="StatesHistoryService";class vf extends ie{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=ce.Get,this.Data=e}}class yf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=Mg.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class mf extends ie{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=ce.Get}}class wf extends ie{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=ce.Get,this.Data=e}}class Sf{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}(pf=af||(af={}))[pf.User=0]="User",pf[pf.Controller=1]="Controller",pf[pf.Marketing=2]="Marketing",(hf=cf||(cf={}))[hf.Notification=0]="Notification",hf[hf.Message=1]="Message",hf[hf.Alarm=2]="Alarm",hf[hf.Warning=3]="Warning",hf[hf.Info=4]="Info",(df=uf||(uf={}))[df.Other=0]="Other",df[df.UserLoggedIn=1]="UserLoggedIn",df[df.UserLoggedOut=2]="UserLoggedOut",df[df.FoundNewDevice=3]="FoundNewDevice",df[df.DoorBellPress=4]="DoorBellPress",df[df.AddedNewDevice=5]="AddedNewDevice",df[df.RemovedDevice=6]="RemovedDevice",df[df.RegisteredNewUser=7]="RegisteredNewUser",df[df.GotAccessToTheInternet=8]="GotAccessToTheInternet",df[df.LostAccessToTheInternet=9]="LostAccessToTheInternet",df[df.RemovedUser=10]="RemovedUser",df[df.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}(lf||(lf={}));var _f=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 Af{constructor(){this._chatSubscriptions=[],this._connection=mv.Get(Ot.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==cf.Message)return;const n=new Cf;n.DateTime=t.DateTime,n.Guid=t.Guid,n.MessageSource=t.MessageSource,n.MessageText=t.MessageText,n.MessageType=t.MessageType,n.RecipientUserGuid=t.RecipientUserGuid?t.RecipientUserGuid:"n/a",n.Sender=t.Sender,n.SenderName=t.SenderName?t.SenderName:"n/a",n.SenderUserGuid=t.SenderUserGuid?t.SenderUserGuid:"n/a",n.TextToSpeechMessage=t.TextToSpeechMessage?t.TextToSpeechMessage:"";for(let[e,r]of Object.entries(t.MessageActions))n.MessageActions.set(lf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return _f(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Df,12e3,!1);if(null==e)return new De(Uf.OtherError,"Cannot get messages - response is null.");if(e.Status!=ae.OK)return new De(Uf.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new De(Uf.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==cf.Message)return;const n=new Cf;n.DateTime=e.DateTime,n.Guid=e.Guid,n.MessageSource=e.MessageSource,n.MessageText=e.MessageText,n.MessageType=e.MessageType,n.RecipientUserGuid=e.RecipientUserGuid?e.RecipientUserGuid:"n/a",n.Sender=e.Sender,n.SenderName=e.SenderName?e.SenderName:"n/a",n.SenderUserGuid=e.SenderUserGuid?e.SenderUserGuid:"n/a",n.TextToSpeechMessage=e.TextToSpeechMessage?e.TextToSpeechMessage:"";for(let[t,r]of Object.entries(e.MessageActions))n.MessageActions.set(lf[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new De(Uf.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return _f(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Tf(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return mv.Get(r.ServiceName).Error(qf.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 Cf{constructor(){this._sender=af.Controller,this._messageType=cf.Info,this._messageSource=uf.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 Df extends ie{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ce.Get}}class Tf extends ie{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ce.Put,this.Data=e}}var kf,Gf,bf,Nf=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 Ef{constructor(){this._chatSubscriptions=[],this._connection=mv.Get(Ot.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==cf.Message){const e=new If;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 Nf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Pf,12e3,!1);if(null==e)return new De(Uf.OtherError,"Cannot get messages - response is null.");if(e.Status!=ae.OK)return new De(Uf.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new De(Uf.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==cf.Message){const n=new If;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 De(Uf.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return Nf(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 mv.Get(r.ServiceName).Error(qf.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 If{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 Rf extends ie{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ce.Put,this.Data=e}}class Pf extends ie{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ce.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(kf||(kf={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(Gf||(Gf={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(bf||(bf={}));var Of,Uf,Mf,xf=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=mv.Get(Ot.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new Wf;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=kf[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(bf[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return xf(this,void 0,void 0,(function*(){return(yield mv.Get(Qe.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return xf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Bf,8e3,!1);return null==e||null==e.Status?new De(Uf.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ae.OK?new De(Uf.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new De(Uf.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new De(Uf.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return xf(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new $f(e),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return mv.Get(r.ServiceName).Error(qf.ServiceName,`Cannot set chat configuration! ${e}`),ae.FatalError}}))}SendMessageAsync(e){return xf(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Lf(e),8e3,!1);return null==t||null==t.Status?ae.FatalError:t.Status}catch(e){return mv.Get(r.ServiceName).Error(qf.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 Lf extends ie{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=ce.Put,this.Data=e}}class Bf extends ie{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ce.Get}}class $f extends ie{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ce.Put,this.Data=e}}class Wf{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"}(Of||(Of={}));class qf{constructor(){this._services={ControllerChat:new Af,GptChat:new Ff,FamillyChat:new Ef}}GetServiceName(){return qf.ServiceName}GetChatImplementation(e){switch(e){case Of.ControllerChat:return this._services.ControllerChat;case Of.FamilyChat:return this._services.FamillyChat;case Of.GptChat:return this._services.GptChat;default:throw new Hf(`Chat with type ${e} not implemented!`)}}}qf.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(Uf||(Uf={}));class Hf 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"}(Mf||(Mf={}));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 Kf{constructor(){this._connection=mv.Get(Ot.ServiceName),this._log=mv.Get(r.ServiceName)}GetServiceName(){return Kf.ServiceName}IsSupportedAsync(){return Vf(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new jf,2e3,!0);return this._log.Debug(Kf.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ae.WrongData}))}GetConnectedAppsAsync(){return Vf(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new zf,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 Vf(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Yf(e),2e3,!1);switch(null==t?void 0:t.Status){case ae.OK:return new De(Mf.Changed,"");case ae.WrongData:switch(t.Data){case"AccessTokenToShort":return new De(Mf.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new De(Mf.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new De(Mf.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new De(Mf.AppNameToShort,t.Data);case"AppUrlToShort":return new De(Mf.AppUrlToShort,t.Data);case"AppUserIdToShort":return new De(Mf.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new De(Mf.AppUserNameToShort,t.Data);default:return new De(Mf.UnkownError,t.Data)}case ae.ResourceDoesNotExists:case ae.ResourceIsNotAvailable:return new De(Mf.ResourceIsNotAvailable,t.Data);default:return new De(Mf.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Vf(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Jf(e.Guid),2e3,!0);return null==t?void 0:t.Status}))}}Kf.ServiceName="ConnectedAppsService";class jf extends ie{constructor(){super(),this.Resource="/applications/app/auth",this.Method=ce.Put,this.Data=""}}class zf extends ie{constructor(){super(),this.Resource="/applications/get",this.Method=ce.Get}}class Jf extends ie{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=ce.Delete,this.Data=e}}class Yf extends ie{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=ce.Put,this.Data=e}}var Xf=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 Qf{constructor(){try{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(Qf.AppUserControllersKeyName,e)}null!==s&&localStorage.setItem(Qf.AppUserControllersKeyName,decodeURIComponent(s)),null!==o&&localStorage.setItem(Qf.AppSelectedLanguageKeyName,o)}catch(e){console.error(e)}}waitForNavigatorObject(e){return new Promise(((t,n)=>{setTimeout((()=>{n(new Error(`Timed out waiting for navigator.${e}`))}),1e4),function n(){navigator[e]?t(navigator[e]):requestAnimationFrame(n)}()}))}b64DecodeUnicode(e){return decodeURIComponent(Array.prototype.map.call(atob(e),(function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)})).join(""))}decodeUriJsonData(e){return JSON.parse(decodeURIComponent(e))}encodeUriJsonData(e){return encodeURIComponent(JSON.stringify(e))}IsExalusNativeMigrationAvailable(){return void 0!==navigator.exalusMigration}GetServiceName(){return Qf.ServiceName}IsMigrationDataAvailableAsync(){return Xf(this,void 0,void 0,(function*(){try{if(null!=window.webkit&&null!=window.webkit.messageHandlers){var e=yield Qf.GetIosMigrationStatus();return null!==e&&e}if(!navigator.userAgent.endsWith("LavvaAndroidNative")||void 0!==navigator.exalusMigration&&null!==navigator.exalusMigration||(yield this.waitForNavigatorObject("exalusMigration")),this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.IsMigrationDataAvailableAsync();return null!=e&&e.DataMigrated}return null!==localStorage.getItem(Qf.AppSelectedLanguageKeyName)||null!==localStorage.getItem(Qf.AppUserControllersKeyName)}catch(e){return console.error(e),!1}}))}GetControllersDataAsync(){return Xf(this,void 0,void 0,(function*(){try{if(null!=window.webkit&&null!=window.webkit.messageHandlers){let e=yield Qf.GetIosControllerList();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetControllersDataAsync();return void 0===e?null:e}let e=localStorage.getItem(Qf.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}catch(e){return console.error(e),null}}))}GetLanguageCodeAsync(){return Xf(this,void 0,void 0,(function*(){try{if(null!=window.webkit&&null!=window.webkit.messageHandlers){let e=yield Qf.GetIosDefaultLanguage();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetLanguageCodeAsync();return void 0===e?null:e}let e=localStorage.getItem(Qf.AppSelectedLanguageKeyName);return null!=e?e:null}}catch(e){return console.error(e),null}}))}static GetIosMigrationStatus(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.isMigrationAvaliable=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("IsMigrationAvaliable")}catch(e){r(e)}}))}static GetIosControllerList(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleControllers=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetControllers")}catch(e){r(e)}}))}static GetIosDefaultLanguage(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleLanguage=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetDefaultLanguage")}catch(e){r(e)}}))}}Qf.AppSelectedLanguageKeyName="App___SelectedLanguage",Qf.AppUserControllersKeyName="App___UserControllersListDatabase",Qf.ServiceName="DataMigrationService";var Zf=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 ev{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=mv.Get(Ot.ServiceName),this._logger=mv.Get(r.ServiceName),this._storage=mv.Get(o.ServiceName),mv.Get(Ke.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Zf(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(ev.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(ev.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(ev.ServiceName,"Controller not found in local network."))}else this._logger.Error(ev.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(ev.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return Zf(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(ev.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){var e;return Zf(this,void 0,void 0,(function*(){const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new tv,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(ev.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return ev.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("")}}))}}ev.ServiceName="FindControllerService";class tv extends ie{constructor(){super(),this.Resource="/network/lan/",this.Method=ce.Get}}var nv=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 rv{constructor(){this._errorOccuredEvent=new n,this._connectionStateChangedEvent=new n,this._dataReceivedEvent=new n,this._onMessageReceived=new n,this._log=mv.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=mv.Get(rt.ServiceName),this._cache=mv.Get(ke.ServiceName),this._session=mv.Get(Ke.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return nv(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 mv.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(rv.ServiceName,`Connecting to the WebSockets server ${e}`),this.sockets.onerror=t=>{this._log.Debug(rv.ServiceName,`Error occured in the WebSockets server ${e}: ${t}`),this._errorOccuredEvent.Invoke(["WebSockets",t.toString()])},this.sockets.onopen=t=>{this._log.Debug(rv.ServiceName,`Connected to the WebSockets server ${e}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(de.Connected)},this.sockets.onclose=t=>{this._log.Debug(rv.ServiceName,`Disconnected from the WebSockets server ${e}`),this._isOpen=!1,this._connectionStateChangedEvent.Invoke(de.Disconnected)},this.sockets.onmessage=t=>{this._log.Debug(rv.ServiceName,`Message received from the WebSockets server ${e}: ${t.data}`),this._onMessageReceived.Invoke(t.data);let n=JSON.parse(t.data);this._log.Debug(rv.ServiceName,`Received data frame: ${n.Status}`),this._dataReceivedEvent.Invoke(n)},this._connectionStateChangedEvent.Invoke(de.Connecting),Promise.resolve(le.Connected)}AuthorizeAsync(e){return nv(this,void 0,void 0,(function*(){return!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(rv.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,!0)}))}ConnectAndAuthorizeAsync(e){return nv(this,void 0,void 0,(function*(){if(this._log.Debug(rv.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(rv.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(rv.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(rv.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(rv.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.sockets)||void 0===n||n.send(r):this._log.Error(rv.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 nv(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)=>nv(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(rv.ServiceName,t),a(new Error(t))}),t);let u=l=>nv(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(rv.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 nv(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)=>nv(this,void 0,void 0,(function*(){let a=i=>nv(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(rv.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(rv.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 rv.ServiceName}}rv.ServiceName="ExalusConnectionService";class sv{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 sv.ServiceName}}sv.ServiceName="PictureInPictureService";var ov,iv,av;class cv{GetServiceName(){return cv.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}}cv.ServiceName="SupportedDevicesService",(av=ov||(ov={}))[av.Unknown=-1]="Unknown",av[av.Web=0]="Web",av[av.Android=1]="Android",av[av.iOS=2]="iOS";class uv{constructor(){this.ClientName="",this.LavvaUserName="",this.ClientType=ov.Unknown,this.TokenGuid="",this.RegistrationDate=new Date}}!function(e){e.FeatureUnsupported="FeatureUnsupported",e.UnknownError="UnknownError",e.NoData="NoData",e.IncorrectGuid="IncorrectGuid",e.IdentityIsEmpty="IdentityIsEmpty",e.DeviceTokenIsEmpty="DeviceTokenIsEmpty",e.ClientNameIsEmpty="ClientNameIsEmpty",e.LavvaUserNameIsEmpty="LavvaUserNameIsEmpty",e.TokenNotFound="TokenNotFound"}(iv||(iv={}));var lv=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 dv{constructor(){this._connection=mv.Get(Ot.ServiceName),this._logger=mv.Get(r.ServiceName)}GetServiceName(){return dv.ServiceName}RegisterNotificationsClientAsync(e){var t;return lv(this,void 0,void 0,(function*(){try{const n=new hv({ClientName:e.ClientName,DeviceToken:e.DeviceToken,LavvaUserName:e.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:e.EnableNotifications}),r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,8e3,!1);if(null==r||null==r.Status)return new De(iv.UnknownError,"Cannot register notifications client - unknown error!");switch(r.Status){case ae.WrongData:{const e=this.isValidErrorCode(r.Data)?r.Data:iv.UnknownError;return new De(e,"Cannot register notifications client - wrong data!")}case ae.ResourceDoesNotExists:return new De(iv.FeatureUnsupported,"Notifications feature not supported in controller!");case ae.OK:return"string"==typeof r.Data?r.Data:new De(iv.NoData,"Cannot register notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new De(iv.UnknownError,"Cannot register notifications client - unknown error!")}}catch(e){return new De(iv.UnknownError,`Cannot register notifications client - error: ${e}`)}}))}UpdateNotificationsClientAsync(e,t){var n;return lv(this,void 0,void 0,(function*(){try{const r=new pv({ClientName:t.ClientName,DeviceToken:t.DeviceToken,LavvaUserName:t.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:t.EnableNotifications,Guid:e}),s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(r,8e3,!1);if(null==s||null==s.Status)return new De(iv.UnknownError,"Cannot update notifications client - unknown error!");switch(s.Status){case ae.WrongData:{const e=this.isValidErrorCode(s.Data)?s.Data:iv.UnknownError;return new De(e,"Cannot update notifications client - wrong data!")}case ae.ResourceDoesNotExists:return new De(iv.FeatureUnsupported,"Notifications feature not supported in controller!");case ae.OK:return"string"==typeof s.Data?s.Data==e?ae.OK:new De(iv.UnknownError,`Cannot update notifications client - result status is OK, but token guid is different! request guid ${e}, response guid: ${s.Data}`):new De(iv.NoData,"Cannot update notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new De(iv.UnknownError,"Cannot update notifications client - unknown error!")}}catch(e){return this._logger.Error(`Cannot update notifications client - error: ${e}`),new De(iv.UnknownError,`Cannot update notifications client - error: ${e}`)}}))}GetRegisteredNotificationsClientsMetadataAsync(){var e;return lv(this,void 0,void 0,(function*(){try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new gv,8e3,!1);return null==t||null==t.Status?new De(iv.UnknownError,"Cannot get notifications clients metadata - unknown error!"):t.Status==ae.ResourceDoesNotExists?new De(iv.FeatureUnsupported,"Notifications feature not supported in controller!"):t.Status!=ae.OK?new De(iv.UnknownError,`Cannot get notifications clients metadata - response status: ${t.Status}}`):null==t.Data?new De(iv.NoData,"Cannot get notifications clients metadata - response status is OK, but no data!"):t.Data.map((e=>{const t=new uv;return t.ClientName=e.ClientName,t.LavvaUserName=e.LavvaUserName,t.ClientType=e.ClientType,t.TokenGuid=e.TokenGuid,t.RegistrationDate=new Date(e.RegistrationDate),t}))}catch(e){return this._logger.Error(`Cannot get notifications clients metadata - error: ${e}`),new De(iv.UnknownError,`Cannot get notifications clients metadata - error: ${e}`)}}))}IsNotifiacationsEnabledAsync(e){var t;return lv(this,void 0,void 0,(function*(){try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new fv(e),8e3,!1);if(null==n||null==n.Status)return new De(iv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ae.ResourceDoesNotExists:if(null==n.Data)return new De(iv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:iv.UnknownError;return new De(e,"Cannot get notifications status - resource not exists!")}case ae.OK:return"boolean"==typeof n.Data?n.Data:new De(iv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new De(iv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new De(iv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}EnableNotificationsAsync(e){var t;return lv(this,void 0,void 0,(function*(){try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new vv(n),8e3,!1);if(null==r||null==r.Status)return new De(iv.UnknownError,"Cannot enable notifications - unknown error!");switch(r.Status){case ae.ResourceDoesNotExists:if(null==r.Data)return new De(iv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:iv.UnknownError;return new De(e,"Cannot enable notifications - resource not exists!")}case ae.OK:return ae.OK;default:return new De(iv.UnknownError,`Cannot enable notifications - response code ${r.Status}}!`)}}catch(e){return this._logger.Error(`Cannot enable notifications - error: ${e}`),new De(iv.UnknownError,`Cannot enable notifications - error: ${e}`)}}))}DisableNotificationsAsync(e){var t;return lv(this,void 0,void 0,(function*(){try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new yv(n),8e3,!1);if(null==r||null==r.Status)return new De(iv.UnknownError,"Cannot disable notifications - unknown error!");switch(r.Status){case ae.ResourceDoesNotExists:if(null==r.Data)return new De(iv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:iv.UnknownError;return new De(e,"Cannot disable notifications - resource not exists!")}case ae.OK:return ae.OK;default:return new De(iv.UnknownError,`Cannot disable notifications - response code ${r.Status}!`)}}catch(e){return this._logger.Error(`Cannot disable notifications - error: ${e}`),new De(iv.UnknownError,`Cannot disable notifications - error: ${e}`)}}))}getClientType(){return null!=window.webkit&&null!=window.webkit.messageHandlers?ov.iOS:navigator.userAgent.endsWith("LavvaAndroidNative")?ov.Android:ov.Web}isValidErrorCode(e){return Object.values(iv).includes(e)}}dv.ServiceName="NotificationsService";class hv extends ie{constructor(e){super(),this.Resource="/notifications/token",this.Method=ce.Post,this.Data=e}}class pv extends ie{constructor(e){super(),this.Resource="/notifications/token",this.Method=ce.Put,this.Data=e}}class gv extends ie{constructor(){super(),this.Resource="/notifications/tokens/metadata",this.Method=ce.Get}}class fv extends ie{constructor(e){super(),this.Resource="/notifications/status",this.Method=ce.Get,this.Data={TokenIdentity:e}}}class vv extends ie{constructor(e){super(),this.Resource="/notifications/enabl",this.Method=ce.Post,this.Data=e}}class yv extends ie{constructor(e){super(),this.Resource="/notifications/disable",this.Method=ce.Post,this.Data=e}}Mc(Map),Mc(Set),(()=>{var e;const t=String.prototype,n=Object.getOwnPropertyNames(jo.prototype);for(const r of n)t[r]=null!==(e=t[r])&&void 0!==e?e:jo.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 qo(Wo.NoMatch)}if(0===this.length)throw new qo(Wo.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 $o("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 qo(Wo.NoMatch)}if(0===this.length)throw new qo(Wo.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 jo((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),Ip(Array),Ip(Int8Array),Ip(Int16Array),Ip(Int32Array),Ip(Uint8Array),Ip(Uint8ClampedArray),Ip(Uint16Array),Ip(Uint32Array),Ip(Float32Array),Ip(Float64Array);class mv{static Init(){if(s.IsInitialized)return;let e=s.Instance;try{e.RegisterService(new Qf),e.RegisterService(new o),e.RegisterService(new sg),e.RegisterService(new ke),e.RegisterService(new Ke),e.RegisterService(new sv),mv.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new rv)):e.RegisterService(new Ot),e.RegisterService(new ps),e.RegisterService(new cv),e.RegisterService(new ps),e.RegisterService(new Fs),e.RegisterService(new rt),e.RegisterService(new ev),e.RegisterService(new us),e.RegisterService(new Qe),e.RegisterService(new be),e.RegisterService(new Fe),e.RegisterService(new Ao),e.RegisterService(new xp),e.RegisterService(new wg),e.RegisterService(new Bg),e.RegisterService(new Kf),e.RegisterService(new ff),e.RegisterService(new uo),e.RegisterService(new qf),e.RegisterService(new dv)}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)))}static ExportStringAsFileToDownload(e,t){const n=new Blob([t],{type:"text/plain"}),r=document.createElement("a"),s=window.URL.createObjectURL(n);return r.href=s,r.download=e,r}}mv.WorksInContextOf="",mv.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({},{j:()=>bv});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_${bv.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,_,A,C,D;!function(e){e[e.Trace=0]="Trace",e[e.Debug=1]="Debug",e[e.Information=2]="Information",e[e.Warning=3]="Warning",e[e.Error=4]="Error",e[e.Critical=5]="Critical",e[e.None=6]="None"}(S||(S={}));class T{constructor(){}log(e,t){}}T.instance=new T;class k{static isRequired(e,t){if(null==e)throw new Error(`The '${t}' argument is required.`)}static isNotEmpty(e,t){if(!e||e.match(/^\s*$/))throw new Error(`The '${t}' argument should not be empty.`)}static isIn(e,t,n){if(!(e in t))throw new Error(`Unknown ${n} value: ${e}.`)}}class G{static get isBrowser(){return!G.isNode&&"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return!G.isNode&&"object"==typeof self&&"importScripts"in self}static get isReactNative(){return!G.isNode&&"object"==typeof window&&void 0===window.document}static get isNode(){return"undefined"!=typeof process&&process.release&&"node"===process.release.name}}function b(e,t){let n="";return N(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 N(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function E(e,t,n,r,s,o){const i={},[a,c]=P();i[a]=c,e.log(S.Trace,`(${t} transport) sending data. ${b(s,o.logMessageContent)}.`);const u=N(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 I{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 R{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 P(){let e="X-SignalR-User-Agent";return G.isNode&&(e="User-Agent"),[e,O("8.0.7",U(),G.isNode?"NodeJS":"Browser",M())]}function O(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 U(){if(!G.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function M(){if(G.isNode)return process.versions.node}function x(e){return e.stack?e.stack:e.message?e.message:`${e}`}class F extends l{constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch||G.isNode){const e=require;this._jar=new(e("tough-cookie").CookieJar),"undefined"==typeof fetch?this._fetchType=e("node-fetch"):this._fetchType=fetch,this._fetchType=e("fetch-cookie")(this._fetchType,this._jar)}else this._fetchType=fetch.bind(function(){if("undefined"!=typeof globalThis)return globalThis;if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==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||{},N(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 B(r,"text");throw new h(e||r.statusText,r.status)}const o=B(r,e.responseType),i=await o;return new u(r.status,r.statusText,i)}getCookieString(e){let t="";return G.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function B(e,t){let n;switch(t){case"arraybuffer":n=e.arrayBuffer();break;case"text":default:n=e.text();break;case"blob":case"document":case"json":throw new Error(`${t} is not supported.`)}return n}class L extends 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&&(N(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 $ extends l{constructor(e){if(super(),"undefined"!=typeof fetch||G.isNode)this._httpClient=new F(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new L(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new 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)}}!function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(_||(_={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(A||(A={}));class W{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 q{get pollAborted(){return this._pollAbort.aborted}constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new W,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}async connect(e,t){if(k.isRequired(e,"url"),k.isRequired(t,"transferFormat"),k.isIn(t,A,"transferFormat"),this._url=e,this._logger.log(S.Trace,"(LongPolling transport) Connecting."),t===A.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]=P(),s={[n]:r,...this._options.headers},o={abortSignal:this._pollAbort.signal,headers:s,timeout:1e5,withCredentials:this._options.withCredentials};t===A.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. ${b(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?E(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]=P();e[t]=n;const r={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};let s;try{await this._httpClient.delete(this._url,r)}catch(e){s=e}s?s instanceof h&&(404===s.statusCode?this._logger.log(S.Trace,"(LongPolling transport) A 404 response was returned from sending a DELETE request."):this._logger.log(S.Trace,`(LongPolling transport) Error sending a DELETE request: ${s}`)):this._logger.log(S.Trace,"(LongPolling transport) DELETE request accepted.")}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 H{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 k.isRequired(e,"url"),k.isRequired(t,"transferFormat"),k.isIn(t,A,"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===A.Text){if(G.isBrowser||G.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]=P();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. ${b(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?E(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 V{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 k.isRequired(e,"url"),k.isRequired(t,"transferFormat"),k.isIn(t,A,"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(G.isNode||G.isReactNative){const t={},[r,s]=P();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===A.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. ${b(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. ${b(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 j{constructor(e,t={}){var n;if(this._stopPromiseResolver=()=>{},this.features={},this._negotiateVersion=1,k.isRequired(e,"url"),this._logger=void 0===(n=t.logger)?new R(S.Information):null===n?T.instance:void 0!==n.log?n:new R(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(G.isNode){const e=require;r=e("ws"),s=e("eventsource")}G.isNode||"undefined"==typeof WebSocket||t.WebSocket?G.isNode&&!t.WebSocket&&r&&(t.WebSocket=r):t.WebSocket=WebSocket,G.isNode||"undefined"==typeof EventSource||t.EventSource?G.isNode&&!t.EventSource&&void 0!==s&&(t.EventSource=s):t.EventSource=EventSource,this._httpClient=new d(t.httpClient||new $(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||A.Binary,k.isIn(e,A,"transferFormat"),this._logger.log(S.Debug,`Starting connection with transfer format '${A[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 K(this.transport)),this._sendQueue.send(e))}async stop(e){return"Disconnected"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState="Disconnecting",this._stopPromise=new Promise((e=>{this._stopPromiseResolver=e})),await this._stopInternal(e),void await this._stopPromise)}async _stopInternal(e){this._stopError=e;try{await this._startInternalPromise}catch(e){}if(this.transport){try{await this.transport.stop()}catch(e){this._logger.log(S.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(S.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let t=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==_.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(_.WebSockets),await this._startTransport(t,e)}else{let n=null,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 q&&(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]=P();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.useStatefulReconnect&&!0!==this._options._useStatefulReconnect?Promise.reject(new y("Client didn't negotiate Stateful Reconnect but the server did.")):n}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof 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,!0===(null==a?void 0:a.useStatefulReconnect));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}`,_[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 _.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new V(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case _.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new H(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case _.LongPolling:return new q(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.features.reconnect?this.transport.onclose=async n=>{let r=!1;if(this.features.reconnect){try{this.features.disconnected(),await this.transport.connect(e,t),await this.features.resend()}catch{r=!0}r&&this._stopConnection(n)}else this._stopConnection(n)}:this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,t,n,r){const s=_[e.transport];if(null==s)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||!!(t&e)}(t,s))return this._logger.log(S.Debug,`Skipping transport '${_[s]}' because it was disabled by the client.`),new v(`'${_[s]}' is disabled by the client.`,s);if(!(e.transferFormats.map((e=>A[e])).indexOf(n)>=0))return this._logger.log(S.Debug,`Skipping transport '${_[s]}' because it does not support the requested transfer format '${A[n]}'.`),new Error(`'${_[s]}' does not support ${A[n]}.`);if(s===_.WebSockets&&!this._options.WebSocket||s===_.ServerSentEvents&&!this._options.EventSource)return this._logger.log(S.Debug,`Skipping transport '${_[s]}' because it is not supported in your environment.'`),new f(`'${_[s]}' is not supported in your environment.`,s);this._logger.log(S.Debug,`Selecting transport '${_[s]}'.`);try{return this.features.reconnect=s===_.WebSockets?r:void 0,this._constructTransport(s)}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(!G.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=new URL(e);t.pathname.endsWith("/")?t.pathname+="negotiate":t.pathname+="/negotiate";const n=new URLSearchParams(t.searchParams);return n.has("negotiateVersion")||n.append("negotiateVersion",this._negotiateVersion.toString()),n.has("useStatefulReconnect")?"true"===n.get("useStatefulReconnect")&&(this._options._useStatefulReconnect=!0):!0===this._options._useStatefulReconnect&&n.append("useStatefulReconnect","true"),t.search=n.toString(),t.toString()}}class K{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new z,this._transportResult=new z,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new z),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 z;const e=this._transportResult;this._transportResult=void 0;const t="string"==typeof this._buffer[0]?this._buffer.join(""):K._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 z{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class J{static write(e){return`${e}${J.RecordSeparator}`}static parse(e){if(e[e.length-1]!==J.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(J.RecordSeparator);return t.pop(),t}}J.RecordSeparatorCode=30,J.RecordSeparator=String.fromCharCode(J.RecordSeparatorCode);class Y{writeHandshakeRequest(e){return J.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(N(e)){const r=new Uint8Array(e),s=r.indexOf(J.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(J.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=J.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",e[e.Ack=8]="Ack",e[e.Sequence=9]="Sequence"}(C||(C={}));class X{constructor(){this.observers=[]}next(e){for(const t of this.observers)t.next(e)}error(e){for(const t of this.observers)t.error&&t.error(e)}complete(){for(const e of this.observers)e.complete&&e.complete()}subscribe(e){return this.observers.push(e),new I(this,e)}}class Q{constructor(e,t,n){this._bufferSize=1e5,this._messages=[],this._totalMessageCount=0,this._waitForSequenceMessage=!1,this._nextReceivingSequenceId=1,this._latestReceivedSequenceId=0,this._bufferedByteCount=0,this._reconnectInProgress=!1,this._protocol=e,this._connection=t,this._bufferSize=n}async _send(e){const t=this._protocol.writeMessage(e);let n=Promise.resolve();if(this._isInvocationMessage(e)){this._totalMessageCount++;let e=()=>{},r=()=>{};N(t)?this._bufferedByteCount+=t.byteLength:this._bufferedByteCount+=t.length,this._bufferedByteCount>=this._bufferSize&&(n=new Promise(((t,n)=>{e=t,r=n}))),this._messages.push(new Z(t,this._totalMessageCount,e,r))}try{this._reconnectInProgress||await this._connection.send(t)}catch{this._disconnected()}await n}_ack(e){let t=-1;for(let n=0;n<this._messages.length;n++){const r=this._messages[n];if(r._id<=e.sequenceId)t=n,N(r._message)?this._bufferedByteCount-=r._message.byteLength:this._bufferedByteCount-=r._message.length,r._resolver();else{if(!(this._bufferedByteCount<this._bufferSize))break;r._resolver()}}-1!==t&&(this._messages=this._messages.slice(t+1))}_shouldProcessMessage(e){if(this._waitForSequenceMessage)return e.type===C.Sequence&&(this._waitForSequenceMessage=!1,!0);if(!this._isInvocationMessage(e))return!0;const t=this._nextReceivingSequenceId;return this._nextReceivingSequenceId++,t<=this._latestReceivedSequenceId?(t===this._latestReceivedSequenceId&&this._ackTimer(),!1):(this._latestReceivedSequenceId=t,this._ackTimer(),!0)}_resetSequence(e){e.sequenceId>this._nextReceivingSequenceId?this._connection.stop(new Error("Sequence ID greater than amount of messages we've received.")):this._nextReceivingSequenceId=e.sequenceId}_disconnected(){this._reconnectInProgress=!0,this._waitForSequenceMessage=!0}async _resend(){const e=0!==this._messages.length?this._messages[0]._id:this._totalMessageCount+1;await this._connection.send(this._protocol.writeMessage({type:C.Sequence,sequenceId:e}));const t=this._messages;for(const e of t)await this._connection.send(e._message);this._reconnectInProgress=!1}_dispose(e){null!=e||(e=new Error("Unable to reconnect to server."));for(const t of this._messages)t._rejector(e)}_isInvocationMessage(e){switch(e.type){case C.Invocation:case C.StreamItem:case C.Completion:case C.StreamInvocation:case C.CancelInvocation:return!0;case C.Close:case C.Sequence:case C.Ping:case C.Ack:return!1}}_ackTimer(){void 0===this._ackTimerHandle&&(this._ackTimerHandle=setTimeout((async()=>{try{this._reconnectInProgress||await this._connection.send(this._protocol.writeMessage({type:C.Ack,sequenceId:this._latestReceivedSequenceId}))}catch{}clearTimeout(this._ackTimerHandle),this._ackTimerHandle=void 0}),1e3))}}class Z{constructor(e,t,n,r){this._message=e,this._id=t,this._resolver=n,this._rejector=r}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(D||(D={}));class ee{static create(e,t,n,r,s,o,i){return new ee(e,t,n,r,s,o,i)}constructor(e,t,n,r,s,o,i){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://learn.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},k.isRequired(e,"connection"),k.isRequired(t,"logger"),k.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=null!=s?s:3e4,this.keepAliveIntervalInMilliseconds=null!=o?o:15e3,this._statefulReconnectBufferSize=null!=i?i:1e5,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=r,this._handshakeProtocol=new Y,this.connection.onreceive=e=>this._processIncomingData(e),this.connection.onclose=e=>this._connectionClosed(e),this._callbacks={},this._methods={},this._closedCallbacks=[],this._reconnectingCallbacks=[],this._reconnectedCallbacks=[],this._invocationId=0,this._receivedHandshakeResponse=!1,this._connectionState=D.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:C.Ping})}get state(){return this._connectionState}get connectionId(){return this.connection&&this.connection.connectionId||null}get baseUrl(){return this.connection.baseUrl||""}set baseUrl(e){if(this._connectionState!==D.Disconnected&&this._connectionState!==D.Reconnecting)throw new Error("The HubConnection must be in the Disconnected or Reconnecting state to change the url.");if(!e)throw new Error("The HubConnection url must be a valid url.");this.connection.baseUrl=e}start(){return this._startPromise=this._startWithStateTransitions(),this._startPromise}async _startWithStateTransitions(){if(this._connectionState!==D.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=D.Connecting,this._logger.log(S.Debug,"Starting HubConnection.");try{await this._startInternal(),G.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=D.Connected,this._connectionStarted=!0,this._logger.log(S.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=D.Disconnected,this._logger.log(S.Debug,`HubConnection failed to start successfully because of error '${e}'.`),Promise.reject(e)}}async _startInternal(){this._stopDuringStartError=void 0,this._receivedHandshakeResponse=!1;const e=new Promise(((e,t)=>{this._handshakeResolver=e,this._handshakeRejecter=t}));await this.connection.start(this._protocol.transferFormat);try{let t=this._protocol.version;this.connection.features.reconnect||(t=1);const n={protocol:this._protocol.name,version:t};if(this._logger.log(S.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(n)),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.reconnect&&(this._messageBuffer=new Q(this._protocol,this.connection,this._statefulReconnectBufferSize),this.connection.features.disconnected=this._messageBuffer._disconnected.bind(this._messageBuffer),this.connection.features.resend=()=>{if(this._messageBuffer)return this._messageBuffer._resend()}),this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(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.connection.features.reconnect=!1,this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){if(this._connectionState===D.Disconnected)return this._logger.log(S.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve();if(this._connectionState===D.Disconnecting)return this._logger.log(S.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise;const t=this._connectionState;return this._connectionState=D.Disconnecting,this._logger.log(S.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(S.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(t===D.Connected&&this._sendCloseMessage(),this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new g("The connection was stopped before the hub handshake could complete."),this.connection.stop(e))}async _sendCloseMessage(){try{await this._sendWithProtocol(this._createCloseMessage())}catch{}}stream(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._createStreamInvocation(e,t,r);let o;const i=new X;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===C.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._messageBuffer?this._messageBuffer._send(e):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===C.Completion?n.error?t(new Error(n.error)):e(n.result):t(new Error(`Unexpected message type: ${n.type}`)))};const r=this._sendWithProtocol(s).catch((e=>{t(e),delete this._callbacks[s.invocationId]}));this._launchStreams(n,r)}))}on(e,t){e&&t&&(e=e.toLowerCase(),this._methods[e]||(this._methods[e]=[]),-1===this._methods[e].indexOf(t)&&this._methods[e].push(t))}off(e,t){if(!e)return;e=e.toLowerCase();const n=this._methods[e];if(n)if(t){const r=n.indexOf(t);-1!==r&&(n.splice(r,1),0===n.length&&delete this._methods[e])}else delete this._methods[e]}onclose(e){e&&this._closedCallbacks.push(e)}onreconnecting(e){e&&this._reconnectingCallbacks.push(e)}onreconnected(e){e&&this._reconnectedCallbacks.push(e)}_processIncomingData(e){if(this._cleanupTimeout(),this._receivedHandshakeResponse||(e=this._processHandshakeResponse(e),this._receivedHandshakeResponse=!0),e){const t=this._protocol.parseMessages(e,this._logger);for(const e of t)if(!this._messageBuffer||this._messageBuffer._shouldProcessMessage(e))switch(e.type){case C.Invocation:this._invokeClientMethod(e).catch((e=>{this._logger.log(S.Error,`Invoke client method threw error: ${x(e)}`)}));break;case C.StreamItem:case C.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===C.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(S.Error,`Stream callback threw error: ${x(e)}`)}}break}case C.Ping:break;case C.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}case C.Ack:this._messageBuffer&&this._messageBuffer._ack(e);break;case C.Sequence:this._messageBuffer&&this._messageBuffer._resetSequence(e);break;default:this._logger.log(S.Warning,`Invalid message type: ${e.type}.`)}}this._resetTimeoutPeriod()}_processHandshakeResponse(e){let t,n;try{[n,t]=this._handshakeProtocol.parseHandshakeResponse(e)}catch(e){const t="Error parsing handshake response: "+e;this._logger.log(S.Error,t);const n=new Error(t);throw this._handshakeRejecter(n),n}if(t.error){const e="Server returned handshake error: "+t.error;this._logger.log(S.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(S.Debug,"Server handshake complete."),this._handshakeResolver(),n}_resetKeepAliveInterval(){this.connection.features.inherentKeepAlive||(this._nextKeepAlive=(new Date).getTime()+this.keepAliveIntervalInMilliseconds,this._cleanupPingTimer())}_resetTimeoutPeriod(){if(!(this.connection.features&&this.connection.features.inherentKeepAlive||(this._timeoutHandle=setTimeout((()=>this.serverTimeout()),this.serverTimeoutInMilliseconds),void 0!==this._pingServerHandle))){let e=this._nextKeepAlive-(new Date).getTime();e<0&&(e=0),this._pingServerHandle=setTimeout((async()=>{if(this._connectionState===D.Connected)try{await this._sendMessage(this._cachedPingMessage)}catch{this._cleanupPingTimer()}}),e)}}serverTimeout(){this.connection.stop(new Error("Server timeout elapsed without receiving a message from the server."))}async _invokeClientMethod(e){const t=e.target.toLowerCase(),n=this._methods[t];if(!n)return this._logger.log(S.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(S.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),await this._sendWithProtocol(this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null))));const 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===D.Disconnecting?this._completeClose(e):this._connectionState===D.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===D.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=D.Disconnected,this._connectionStarted=!1,this._messageBuffer&&(this._messageBuffer._dispose(null!=e?e:new Error("Connection closed.")),this._messageBuffer=void 0),G.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(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=D.Reconnecting,e?this._logger.log(S.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(S.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(S.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==D.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==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!==D.Reconnecting)return void this._logger.log(S.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=D.Connected,this._logger.log(S.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(S.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(S.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==D.Reconnecting)return this._logger.log(S.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===D.Disconnecting&&this._completeClose());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: ${x(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:C.Invocation}:{arguments:t,target:e,type:C.Invocation};{const n=this._invocationId;return this._invocationId++,0!==r.length?{arguments:t,invocationId:n.toString(),streamIds:r,target:e,type:C.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:C.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:C.StreamInvocation}:{arguments:t,invocationId:r.toString(),target:e,type:C.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:C.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:C.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:C.Completion}:{invocationId:e,result:n,type:C.Completion}}_createCloseMessage(){return{type:C.Close}}}class te{constructor(){this.name="json",this.version=2,this.transferFormat=A.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=T.instance);const n=J.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 C.Invocation:this._isInvocationMessage(n);break;case C.StreamItem:this._isStreamItemMessage(n);break;case C.Completion:this._isCompletionMessage(n);break;case C.Ping:case C.Close:break;case C.Ack:this._isAckMessage(n);break;case C.Sequence:this._isSequenceMessage(n);break;default:t.log(S.Information,"Unknown message type '"+n.type+"' ignored.");continue}r.push(n)}return r}writeMessage(e){return J.write(JSON.stringify(e))}_isInvocationMessage(e){this._assertNotEmptyString(e.target,"Invalid payload for Invocation message."),void 0!==e.invocationId&&this._assertNotEmptyString(e.invocationId,"Invalid payload for Invocation message.")}_isStreamItemMessage(e){if(this._assertNotEmptyString(e.invocationId,"Invalid payload for StreamItem message."),void 0===e.item)throw new Error("Invalid payload for StreamItem message.")}_isCompletionMessage(e){if(e.result&&e.error)throw new Error("Invalid payload for Completion message.");!e.result&&e.error&&this._assertNotEmptyString(e.error,"Invalid payload for Completion message."),this._assertNotEmptyString(e.invocationId,"Invalid payload for Completion message.")}_isAckMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Ack message.")}_isSequenceMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Sequence message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const ne={trace: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 re{configureLogging(e){if(k.isRequired(e,"logging"),void 0!==e.log)this.logger=e;else if("string"==typeof e){const t=function(e){const t=ne[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new R(t)}else this.logger=new R(e);return this}withUrl(e,t){return k.isRequired(e,"url"),k.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return k.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}withServerTimeout(e){return k.isRequired(e,"milliseconds"),this._serverTimeoutInMilliseconds=e,this}withKeepAliveInterval(e){return k.isRequired(e,"milliseconds"),this._keepAliveIntervalInMilliseconds=e,this}withStatefulReconnect(e){return void 0===this.httpConnectionOptions&&(this.httpConnectionOptions={}),this.httpConnectionOptions._useStatefulReconnect=!0,this._statefulReconnectBufferSize=null==e?void 0:e.bufferSize,this}build(){const e=this.httpConnectionOptions||{};if(void 0===e.logger&&(e.logger=this.logger),!this.url)throw new Error("The 'HubConnectionBuilder.withUrl' method must be called before building the connection.");const t=new j(this.url,e);return ee.create(t,this.logger||T.instance,this.protocol||new te,this.reconnectPolicy,this._serverTimeoutInMilliseconds,this._keepAliveIntervalInMilliseconds,this._statefulReconnectBufferSize)}}class se{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 oe{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function ie(e){return new Map(Object.entries(e))}class ae{constructor(){this.TransactionId=se.GenerateUUID()}}var ce,ue,le,de,he,pe,ge,fe,ve,me,ye,we,Se,_e;(we=ce||(ce={}))[we.OK=0]="OK",we[we.UnknownError=1]="UnknownError",we[we.FatalError=2]="FatalError",we[we.WrongData=3]="WrongData",we[we.ResourceDoesNotExists=4]="ResourceDoesNotExists",we[we.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",we[we.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",we[we.OperationNotPermitted=7]="OperationNotPermitted",we[we.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",we[we.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",we[we.Error=10]="Error",we[we.NoData=11]="NoData",we[we.NotSupportedMethod=12]="NotSupportedMethod",we[we.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",we[we.MultiDataResponseStart=14]="MultiDataResponseStart",we[we.MultiDataResponse=15]="MultiDataResponse",we[we.MultiDataResponseStop=16]="MultiDataResponseStop",function(e){e[e.Get=0]="Get",e[e.Post=1]="Post",e[e.Delete=2]="Delete",e[e.Put=3]="Put",e[e.Options=4]="Options",e[e.Head=5]="Head"}(ue||(ue={}));class Ae{constructor(e,t){this.serialNumber=e,this.pin=t,this.SerialNumber=e,this.PIN=t}}!function(e){e[e.ByCloud=0]="ByCloud",e[e.LocalNetwork=1]="LocalNetwork",e[e.P2P=2]="P2P"}(le||(le={})),function(e){e[e.FailedToConnect=0]="FailedToConnect",e[e.AuthorizationFailed=1]="AuthorizationFailed",e[e.FailedToConnectToServer=2]="FailedToConnectToServer",e[e.Connected=3]="Connected",e[e.ControllerIsNotConnected=4]="ControllerIsNotConnected"}(de||(de={})),function(e){e[e.Disconnected=0]="Disconnected",e[e.Connecting=1]="Connecting",e[e.Connected=3]="Connected",e[e.Disconnecting=4]="Disconnecting",e[e.Failed=5]="Failed",e[e.Reconnecting=6]="Reconnecting"}(he||(he={}));class Ce{constructor(){this._log=bv.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)}}))}}(_e=pe||(pe={}))[_e.Any=0]="Any",_e[_e.Guest=10]="Guest",_e[_e.Standard=20]="Standard",_e[_e.Admin=30]="Admin",_e[_e.Installator=40]="Installator",_e[_e.Support=50]="Support",(Se=ge||(ge={}))[Se.Unknown=0]="Unknown",Se[Se.Men=1]="Men",Se[Se.Woman=2]="Woman",Se[Se.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(fe||(fe={})),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"}(ve||(ve={}));class De{constructor(e,t){this._type=me.Unknown,this._data="",this._type=e,this._data=t}get Type(){return this._type}set Type(e){this._type=e}get Data(){return this._data}set Data(e){this._data=e}}class 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"}(me||(me={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(ye||(ye={}));class ke{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=ye.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=bv.Get(r.ServiceName),Ge._localStorageService=bv.Get(o.ServiceName)}GetServiceName(){return Ge.ServiceName}GetResourceName(e){return`${e.Resource}_${e.Method}`}Cache(e){var t;e.Status===ce.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 be=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 Ne{constructor(){this._imageExistsCaseNumber=0,this._connection=bv.Get(Pt.ServiceName),this._logger=bv.Get(r.ServiceName)}GetServiceName(){return Ne.ServiceName}AddPictureAsync(e){return be(this,void 0,void 0,(function*(){var t,n;try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ne.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ce.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(Ne.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ce.WrongData;if(0===r.height||0===r.width)return this._logger.Error(Ne.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ce.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot add picture - Guid must be empty."),ce.WrongData;const o=new Ie;o.Guid=se.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 Pe(o.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(Ne.ServiceName,"Cannot add picture - unknown error!"),ce.UnknownError;if(i.Status==ce.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Me(o),8e3,!1);return null==e||null==e.Status?(this._logger.Error(Ne.ServiceName,"Cannot add picture - unknown error!"),ce.UnknownError):e.Status}return i.Status==ce.OK?(this._logger.Warning(Ne.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ce.UnknownError):(this._logger.Error(Ne.ServiceName,"Cannot add picture - cannot get current picture status."),ce.Error)}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot add picture! ${e}`),ce.FatalError}}))}EditPictureAsync(e){return be(this,void 0,void 0,(function*(){var t,n;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - guid is empty."),ce.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ce.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(Ne.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ce.WrongData;if(0===r.height||0===r.width)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ce.WrongData;const o=new Ie;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 Pe(o.Guid),8e3,!1);if(bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null==i||null==i.Status)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - unknown error!"),ce.UnknownError;if(i.Status==ce.ResourceDoesNotExists)return this._logger.Error(Ne.ServiceName,"Cannot edit picture - picture not exists."),ce.OperationNotPermitted;if(i.Status==ce.OK){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Me(o),8e3,!1);return bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(Ne.ServiceName,"Cannot edit picture - unknown error!"),ce.UnknownError):e.Status}return this._logger.Error(Ne.ServiceName,"Cannot edit picture - cannot get current picture status."),ce.Error}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot edit picture! ${e}`),ce.FatalError}}))}DeletePictureAsync(e){return be(this,void 0,void 0,(function*(){var t;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ne.ServiceName,"Cannot delete picture - guid is empty."),ce.WrongData;const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new xe(e.Guid),8e3,!1);return bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null==n||null==n.Status?(this._logger.Error(Ne.ServiceName,"Cannot edit picture - unknown error!"),ce.UnknownError):n.Status}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot delete picture! ${e}`),ce.FatalError}}))}GetPicturesInfoAsync(){return be(this,void 0,void 0,(function*(){var e;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(Ne.ServiceName,"Cannot get pictures info - unknown error!"),new Te(ce.UnknownError,"NoDataInResult")):t.Status!=ce.OK?(this._logger.Error(Ne.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Te(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ne.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Te(ce.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Re;return t.DateTime=e.DateTime,t.Guid=e.Guid,t.OwnerGuid=e.OwnerGuid,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot get picture info! ${e}`),new Te(ce.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){return be(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Pe(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(Ne.ServiceName,"Cannot get picture - unknown error!"),new Te(ce.UnknownError,"NoDataInResult");switch(n.Status){case ce.ResourceDoesNotExists:return new Te(ce.ResourceDoesNotExists,"PictureNotFound");case ce.OK:if(null==n.Data)return new Te(ce.Error,"RespondedWithOKButNoData");const e=new Ee;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(Ne.ServiceName,`Cannot get picture! ${e}`),new Te(ce.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){return be(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ue,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ne.ServiceName,"Cannot get pictures - unknown error!"),new Te(ce.UnknownError,"NoDataInResult")):t.Status!=ce.OK?(this._logger.Error(Ne.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Te(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ne.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Te(ce.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ee;return t.Base64Image=e.Base64Image,t.DateTime=e.DateTime,t.Guid=e.Guid,t.ImageType=e.ImageType,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(Ne.ServiceName,`Cannot get pictures! ${e}`),new Te(ce.FatalError,"ExceptionOccurred")}}))}}Ne.ServiceName="PictureService";class Ee extends ke{set DateTime(e){this._dateTime=e}}class Ie{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=ye.Device,this.DateTime=""}}class Re{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 Pe extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Get,this.Data=e}}class Oe extends ae{constructor(){super(),this.Resource="/pictures/info",this.Method=ue.Get}}class Ue extends ae{constructor(){super(),this.Resource="/pictures/list",this.Method=ue.Get}}class Me extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Put,this.Data=e}}class xe extends ae{constructor(e){super(),this.Resource="/pictures/picture",this.Method=ue.Delete,this.Data=e}}var Fe=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._connection=null,this._connection=bv.Get(Pt.ServiceName),this._pictureService=bv.Get(Ne.ServiceName),this._sessionService=bv.Get(Ke.ServiceName)}CanEditUser(e){const t=this._sessionService.User;return e.Guid===(null==t?void 0:t.Guid)||this.CanEditUsersOfAccessLevel(e.AccessLevel)}CanEditUsersOfAccessLevel(e){var t;const n=null===(t=this._sessionService.User)||void 0===t?void 0:t.AccessLevel;if(void 0===n)return!1;switch(e){case pe.Support:return n===pe.Support;case pe.Installator:return n>=pe.Installator;case pe.Admin:default:return n>=pe.Admin}}GetServiceName(){return Be.ServiceName}GetUsersAsync(){return Fe(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new qe,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ce.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new Ve;n.AccessLevel=t.AccessLevel,n.Email=t.Email,n.Gender=t.Gender,n.Guid=t.Guid,n.IsAccountOnline=t.IsAccountOnline,n.Name=t.Name,n.IsActive=t.IsActive,n.IsBanned=t.IsBanned,n.Phone=t.Phone,n.Surname=t.Surname,e.push(n)})),e}return Promise.resolve([])}if((null==n?void 0:n.Status)==ce.NoData)return Promise.resolve([]);throw null===(t=s.Log)||void 0===t||t.Debug(Be.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){return Fe(this,void 0,void 0,(function*(){var t,n;if(""===e)return Promise.resolve(null);null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Le(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ce.OK)return null===(n=s.Log)||void 0===n||n.Debug(Be.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const o=new Ve;return o.AccessLevel=r.Data.AccessLevel,o.Email=r.Data.Email,o.Gender=r.Data.Gender,o.Guid=r.Data.Guid,o.IsAccountOnline=r.Data.IsAccountOnline,o.Name=r.Data.Name,o.IsActive=r.Data.IsActive,o.IsBanned=r.Data.IsBanned,o.Phone=r.Data.Phone,o.Surname=r.Data.Surname,o}))}CreateUserAsync(e,t){return Fe(this,void 0,void 0,(function*(){var n;if(null!=e.Guid&&""!=e.Guid)return new Te(ce.WrongData,"GuidMustBeEmpty");const r=new $e;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 We(r),2e4,!1);return bv.Get(Ge.ServiceName).ClearCache(),null==s||null==s.Status?new Te(ce.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Te(s.Status,s.Data))}))}UpdateUserAsync(e){return Fe(this,void 0,void 0,(function*(){var t;if(null==e.Guid||""==e.Guid)return new Te(ce.WrongData,"GuidCannotBeEmpty");const n=new $e;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 We(n),2e4,!1);return bv.Get(Ge.ServiceName).ClearCache(),null==r||null==r.Status?new Te(ce.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Te(r.Status,r.Data))}))}ChangePasswordAsync(e,t){return Fe(this,void 0,void 0,(function*(){var n;if(null==e.Guid||""==e.Guid)return new Te(ce.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new Te(ce.ResourceIsNotAvailable,"CannotGetUser");const s=new $e;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 We(s),2e4,!1);return null==o||null==o.Status?new Te(ce.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Te(o.Status,o.Data))}))}DeleteUserAsync(e){return Fe(this,void 0,void 0,(function*(){var t,n;if(""===e)return ce.WrongData;null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new He(e),2e4,!1);return bv.Get(Ge.ServiceName).ClearCache(),null==r||null==r.Status?ce.FatalError:(r.Status!=ce.OK&&(null===(n=s.Log)||void 0===n||n.Debug(Be.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}))}GetUserProfilePictureAsync(e){return Fe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ce.WrongData,"GuidCannotBeEmpty");const t=yield this._pictureService.GetPicturesInfoAsync();if(null!=t.Type)return t;const n=t.find((t=>"profilePicture"==t.OwnerIdentity&&t.OwnerGuid==e.Guid));if(null!=n){const e=yield this._pictureService.GetPictureAsync(n.Guid);return bv.Get(Ge.ServiceName).ClearCache(),null!=e.Type?t:e}return new Te(ce.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return Fe(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Te(ce.WrongData,"GuidCannotBeEmpty");let n=new ke;n.ImageType=ye.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(bv.Get(Ge.ServiceName).ClearCache(),r.Type==ce.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ce.OK?new Te(ce.OK,"PictureSet"):new Te(e,"PictureServiceError")}if(null!=r.Type)return new Te(ce.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ce.OK?new Te(ce.OK,"PictureSet"):new Te(e,"PictureServiceError")}}))}}Be.ServiceName="UsersService";class Le extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Get,this.Data=e}}class $e{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=ge.Unknown,this.AccessLevel=pe.Any}}class We extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Put,this.Data=e}}class qe extends ae{constructor(){super(),this.Resource="/users/list",this.Method=ue.Get}}class He extends ae{constructor(e){super(),this.Resource="/users/user",this.Method=ue.Delete,this.Data=e}}class Ve{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=ge.Unknown,this._accessLevel=pe.Any,this._localization=fe.En_Us,this._softwareVersion=""}get Guid(){return this._guid}set Guid(e){this._guid=e}get CloudGuid(){return this._cloudGuid}set CloudGuid(e){this._cloudGuid=e}get Name(){return this._name}set Name(e){this._name=e}get Surname(){return this._surname}set Surname(e){this._surname=e}get Phone(){return this._phone}set Phone(e){this._phone=e}get AccessLevel(){return this._accessLevel}set AccessLevel(e){this._accessLevel=e}get Email(){return this._email}set Email(e){this._email=e}get IsAccountOnline(){return this._isAccountOnline}set IsAccountOnline(e){this._isAccountOnline=e}get IsActive(){return this._isAccountActive}set IsActive(e){this._isAccountActive=e}get IsBanned(){return this._isAccountBanned}set IsBanned(e){this._isAccountBanned=e}get NotificationChannels(){return this._notificationChannels}set NotificationChannels(e){this._notificationChannels=e}get Gender(){return this._gender}set Gender(e){this._gender=e}get Localization(){return this._localization}set Localization(e){this._localization=e}get SoftwareVersion(){return this._softwareVersion}set SoftwareVersion(e){this._softwareVersion=e}GetUserProfilePictureAsync(){return bv.Get(Be.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return bv.Get(Be.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var je=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 Ke{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(){return je(this,void 0,void 0,(function*(){var e;null===(e=s.Log)||void 0===e||e.Debug(Ke.ServiceName,"Creating _loginTaskCompletionSource"),this._loginTaskCompletionSource=new Promise((e=>{let t=n=>{var r;null===(r=s.Log)||void 0===r||r.Debug(Ke.ServiceName,`Logged in as ${n.Name}, completing CreateSessionCompletionSourceAsync()`),e(),this.OnUserLoggedInEvent().Unsubscribe(t)};this.OnUserLoggedInEvent().Subscribe(t)}))}))}RestoreSessionAsync(){return je(this,void 0,void 0,(function*(){var e;null===(e=s.Log)||void 0===e||e.Debug(Ke.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0!==this._user&&null!==this._user&&(yield this.UserLogInAsync(this._email,this._password))}))}WaitForSessionCreationAsync(){return je(this,void 0,void 0,(function*(){return this._loginTaskCompletionSource}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){return je(this,void 0,void 0,(function*(){var e,t,n=new ae;n.Resource="/users/user/logout",n.Method=ue.Put,this._email="",this._password="",(yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ce.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=s.Log)||void 0===e||e.Debug(Ke.ServiceName,"User has been logged out.")):null===(t=s.Log)||void 0===t||t.Debug(Ke.ServiceName,"Failed to logout user!")}))}OnConnectionStateChanged(e){return je(this,void 0,void 0,(function*(){switch(e){case he.Disconnected:case he.Failed:break;case he.Connected:bv.Get(Ke.ServiceName).RestoreSessionAsync()}}))}AuthorizeAppAsync(e){return je(this,void 0,void 0,(function*(){var t,n,r,o,i=bv.Get(Pt.ServiceName);const a=yield i.SendAndWaitForResponseAsync(new Je(e),2e4,!1);if(a.Status==ce.OK&&null!=a.Data){this._authToken=e;var c=new Ve;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,c.SoftwareVersion=a.Data.SoftwareVersion,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,i.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(t=s.Log)||void 0===t||t.Debug(Ke.ServiceName,`Did logging in succeded?: ${a.Status==ce.OK}`),this._onUserLoggedInEvent.Invoke(this._user),c}return a.Status===ce.OperationNotPermitted?(null===(n=s.Log)||void 0===n||n.Debug(Ke.ServiceName,`App login response: ${a.Data}`),ve.AuthDisabled):a.Status===ce.ResourceDoesNotExists?(null===(r=s.Log)||void 0===r||r.Debug(Ke.ServiceName,`App login response: ${a.Data}`),ve.MethodNotSupported):(null===(o=s.Log)||void 0===o||o.Debug(Ke.ServiceName,`App login response: ${a.Data}`),ve.WrongAuthData)}))}UserLogInAsync(e,t){return je(this,void 0,void 0,(function*(){var n,r,o=bv.Get(Pt.ServiceName);const i=yield o.SendAndWaitForResponseAsync(new Ye(e,t),2e4,!1);if(i.Status==ce.OK&&null!=i.Data){this._email=e,this._password=t;var a=new Ve;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,a.SoftwareVersion=i.Data.SoftwareVersion,this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,o.OnConnectionStateChangedEvent().Subscribe(this.OnConnectionStateChanged)),null===(n=s.Log)||void 0===n||n.Debug(Ke.ServiceName,`Did logging in succeded?: ${i.Status==ce.OK}`),this._onUserLoggedInEvent.Invoke(this._user),a}return null===(r=s.Log)||void 0===r||r.Debug(Ke.ServiceName,`User login response: ${i.Data}`),ve.WrongAuthData}))}GetServiceName(){return Ke.ServiceName}}Ke.ServiceName="SessionService";class ze{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class Je extends ae{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=ue.Put}}class Ye extends ae{constructor(e,t){super(),this.Data=new ze(e,t),this.Resource="/users/user/login",this.Method=ue.Put}}class Xe{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 Qe=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 Ze{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new Xe(1)}GetServiceName(){return Ze.ServiceName}GetExtensionsInfoAsync(e){return Qe(this,arguments,void 0,(function*(e,t=!1){bv.Get(r.ServiceName).Debug(Ze.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 nt("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e){return Qe(this,arguments,void 0,(function*(e,t=!1,n=!1){if(bv.Get(r.ServiceName).Debug(Ze.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 nt("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 nt("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return Qe(this,void 0,void 0,(function*(){const e=new et,t=yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new nt("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ce.OK)throw new nt(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new nt("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 Qe(this,void 0,void 0,(function*(){const e=new tt,t=yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new nt("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(t.Status){case ce.OK:if(null==t.Data)throw new nt("Cannot get ProtocolInfo from controller, controller response does not contain data!");t.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ce.ResourceDoesNotExists:bv.Get(r.ServiceName).Debug(Ze.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new nt(`Cannot get ProtocolInfo from controller! Response status: ${t.Status}`)}}))}}Ze.ServiceName="StatisticsInfoService";class et extends ae{constructor(){super(),this.Resource="/controller/extensions/",this.Method=ue.Get}}class tt extends ae{constructor(){super(),this.Resource="/controller/protocols/",this.Method=ue.Get}}class nt extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}var rt=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 st{GetServiceName(){return st.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new Ce,this._onExitedConfigurationEvent=new Ce,this._onConfigurationTimeCheckedEvent=new n,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!1,this._synchronizationTaskCompletionSource=new Promise((e=>{bv.Get(Ke.ServiceName).OnUserLoggedInEvent().Subscribe((t=>rt(this,void 0,void 0,(function*(){this._didConfigurationChange=yield this.CheckIfConfigurationHasChangedAsync(),this._didConfigurationChange&&bv.Get(Ge.ServiceName).ClearCache(),e()}))))})),this._connection=bv.Get(Pt.ServiceName),this._session=bv.Get(Ke.ServiceName),this._localStorage=bv.Get(o.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{bv.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{bv.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke()}))}ImportControllerConfigurationAsync(e){return rt(this,void 0,void 0,(function*(){var t,n,r;let s=yield e.text(),o=this.SplitStringBySize(s),i=new ot("");i.Status=ce.MultiDataResponseStart;let a=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(i,6e3,!1);if(void 0===a||(null==a?void 0:a.Status)!=ce.OK)return ce.Error;for(const e of o){let t=new ot(e);t.Status=ce.MultiDataResponse;let r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(t,6e3,!1);if(void 0===r||(null==r?void 0:r.Status)!=ce.OK)return ce.Error}i.Status=ce.MultiDataResponseStop;let c=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(i,12e4,!1);return void 0===c||(null==c?void 0:c.Status)!=ce.OK?ce.Error:ce.OK}))}SplitStringBySize(e,t=1e5){const n=Math.floor(t/2),r=[];let s=0;for(;s<e.length;){let o=e.slice(s,s+n);for(;new Blob([o]).size>t;)o=o.slice(0,-1);r.push(o),s+=o.length}return r}GetControllerSystemTimeAsync(){return rt(this,void 0,void 0,(function*(){var e;try{var t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new pt,8e3,!1);return null==t||null==t.Status?ce.Error:t.Status!=ce.OK?t.Status:null==t.Data?ce.ResourceIsNotAvailable:new Date(t.Data)}catch(e){return bv.Get(r.ServiceName).Error(st.ServiceName,`Cannot get current controller time! ${e}`),ce.FatalError}}))}SetControllerSystemTimeAsync(e){return rt(this,void 0,void 0,(function*(){var t;try{var n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new gt(e.toISOString()),8e3,!1);return null==n||null==n.Status?ce.Error:n.Status}catch(e){return bv.Get(r.ServiceName).Error(st.ServiceName,`Cannot set current controller time! ${e}`),ce.FatalError}}))}StartNtpTimeSynchronizationAsync(){return rt(this,void 0,void 0,(function*(){var e;try{var t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ft,8e3,!1);return null==t||null==t.Status?ce.Error:t.Status}catch(e){return bv.Get(r.ServiceName).Error(st.ServiceName,`Cannot set current controller time! ${e}`),ce.FatalError}}))}FactoryResetAsync(e){return rt(this,void 0,void 0,(function*(){var t,n;try{bv.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ct,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=300,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield oe.Delay(1e3*t),bv.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ce.OK}return r}catch(e){return ce.FatalError}}))}RollbackLastUpdateAsync(e){return rt(this,void 0,void 0,(function*(){var t,n;try{bv.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ut,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=420,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield oe.Delay(1e3*t),bv.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ce.OK}return r}catch(e){return ce.FatalError}}))}RestartControllerAsync(e){return rt(this,void 0,void 0,(function*(){var t,n;try{bv.Get(Ge.ServiceName).ClearCache();var r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new at,2e3,!1))||void 0===n?void 0:n.Status;if(r==ce.OK){let t=240,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield oe.Delay(1e3*t),bv.Get(Ge.ServiceName).ClearCache(),clearInterval(s),ce.OK}return r}catch(e){return ce.FatalError}}))}DidCofigurationChangeAsync(){return rt(this,void 0,void 0,(function*(){return yield this._synchronizationTaskCompletionSource,Promise.resolve(this._didConfigurationChange)}))}GetLastKnownConfigurationChangeTime(){var e;const t=null===(e=this._localStorage)||void 0===e?void 0:e.Read(this.GetServiceName(),"last_configuration_time");return null!=t?new Date(t):new Date}SaveLastConfigurationChangeTime(e){var t;null===(t=this._localStorage)||void 0===t||t.Save(this.GetServiceName(),"last_configuration_time",e.toString())}EnterConfigurationModeAsync(){return rt(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,bv.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new lt,2e4,!1)}))}ExitConfigurationModeAsync(){return rt(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,bv.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new dt,2e4,!1),bv.Get(Ge.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){return rt(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ht,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ce.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return rt(this,void 0,void 0,(function*(){const e=yield this.GetLastConfigurationChangeTimeAsync();return this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()&&(this.SaveLastConfigurationChangeTime(e),this._onConfigurationTimeCheckedEvent.Invoke(e),bv.Get(Ge.ServiceName).ClearCache(),!0)}))}CanExportOrImportControllerConfigurationAsync(){return rt(this,void 0,void 0,(function*(){try{let e=yield bv.Get(Ze.ServiceName).GetExtensionsInfoAsync(),t=bv.Get(Ke.ServiceName).User;return null!=t&&null!=t.AccessLevel&&t.AccessLevel>=pe.Admin&&e.any((e=>"f4f0f066-7c43-46c6-a0bd-aedf93903dc0"==e.ExtensionGuid))}catch(e){return!1}}))}ExportControllerConfigurationAsync(){return rt(this,void 0,void 0,(function*(){var e;let t=[];yield null===(e=this._connection)||void 0===e?void 0:e.SendAndHandleResponseAsync(new it,3e4,(e=>{switch(e.Status){case ce.MultiDataResponseStart:break;case ce.MultiDataResponse:null!=e.Data&&void 0!==e.Data&&t.push(e.Data);case ce.MultiDataResponseStop:}}),!0);let n=JSON.stringify(JSON.parse(t.join("")),null,2);return console.log(n),bv.ExportStringAsFileToDownload(this.GetCurrentTimestampedFilename(),n)}))}GetCurrentTimestampedFilename(){var e,t;const n=new Date,r=n.getHours().toString().padStart(2,"0"),s=n.getMinutes().toString().padStart(2,"0"),o=n.getDate().toString().padStart(2,"0"),i=(n.getMonth()+1).toString().padStart(2,"0"),a=n.getFullYear().toString();return`${null===(t=null===(e=this._connection)||void 0===e?void 0:e.GetAuthorizationInfo())||void 0===t?void 0:t.SerialNumber}_${r}-${s}-${o}-${i}-${a}-config.cexp`}}st.ServiceName="ControllerConfigurationService";class ot extends ae{constructor(e){super(),this.Resource="/configuration/backup/import",this.Method=ue.Put,this.Data=e}}class it extends ae{constructor(){super(),this.Resource="/configuration/backup/export",this.Method=ue.Get}}class at extends ae{constructor(){super(),this.Resource="/controller/restart",this.Method=ue.Post}}class ct extends ae{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=ue.Post}}class ut extends ae{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=ue.Post}}class lt extends ae{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=ue.Put}}class dt extends ae{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=ue.Put}}class ht extends ae{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=ue.Get}}class pt extends ae{constructor(){super(),this.Resource="/system/time",this.Method=ue.Get}}class gt extends ae{constructor(e){super(),this.Resource="/system/time",this.Method=ue.Put,this.Data=e}}class ft extends ae{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=ue.Put}}var vt,mt,yt,wt,St,_t,At,Ct,Dt,Tt,kt,Gt,bt,Nt,Et,It,Rt=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 Pt{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 Ce,this._authorizationReceivedEvent=new n,this._registrationReceivedEvent=new n,this._connectionStateChangedEvent=new n,this._errorOccuredEvent=new n,this._log=bv.Get(r.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._packetsBrokerServers=["br1.tr7.pl","br1.exala.pl"],this._lastReceivedPacketTime=Date.now(),this._connectedAtLeastOnce=!1}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 Pt.ServiceName}EnablePacketsLogging(){this._logPackets=!0}DisablePacketsLogging(){this._logPackets=!1}InitializeConnection(){if(this._controllerConfiguration=bv.Get(st.ServiceName),this._cache=bv.Get(Ge.ServiceName),this._session=bv.Get(Ke.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 re).withUrl(`https://${this._address}/broker`).build(),this._dataReceivedEvent.Subscribe((e=>{this._lastReceivedPacketTime=Date.now()})),setInterval((()=>Rt(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval)}GetAuthorizationInfo(){return null!=this._serialId&&null!=this._PIN?new Ae(this._serialId,this._PIN):null}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._defaultPacketsBrokerAddress=e,this._address=e}GetServerAddressAsync(){return Rt(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(Pt.ServiceName,`Got server address: ${t}`),t):(this._log.Error(Pt.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(Pt.ServiceName,`Failed to get server address, status: ${e.status}`),null)}catch(e){return this._log.Error(Pt.ServiceName,e),null}}))}ConnectAsync(e){return Rt(this,void 0,void 0,(function*(){return this._connectedAtLeastOnce=!1,this._address=e,yield this.connectAsync()}))}AuthorizeAsync(e){return new Promise(((t,n)=>Rt(this,void 0,void 0,(function*(){var n;let r=0,s=e=>{window.clearTimeout(r),this._log.Debug(Pt.ServiceName,`Got authorization result: ${e}`),this._connectedAtLeastOnce=!0,t(e)};r=window.setTimeout((()=>{window.clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(s),t(!1)}),2e3),this._log.Debug(Pt.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 Rt(this,void 0,void 0,(function*(){this._connectedAtLeastOnce=!1,bv.WorksInContextOf=e.SerialNumber,this._serialId=e.SerialNumber,this._PIN=e.PIN;var t=yield this.GetServerAddressAsync();if(t&&null!=t){this._log.Debug(Pt.ServiceName,`Got packets broker address: ${t}`),this.SetDefaultPacketsBrokerAddress(t);let r=yield this.connectAsync();if(r!=de.Connected)return r;var n=yield this.AuthorizeAsync(e);if(!n){if(this._connectedAtLeastOnce=!1,yield this.swapBrokersAsync(),!this._allBrokersChecked)return this.ConnectAndAuthorizeAsync(e);this._allBrokersChecked=!1}return n&&(this._connectedAtLeastOnce=!0),n?de.Connected:de.AuthorizationFailed}{let t=de.ControllerIsNotConnected;this._log.Warning(Pt.ServiceName,"Server did not return packets broker address, trying to connect to known brokers.");for(let n of this._packetsBrokerServers){this._log.Warning(Pt.ServiceName,`Testing connection to ${n}`),this.SetDefaultPacketsBrokerAddress(n);try{yield this.DisconnectAsync()}catch(e){}this._log.Warning(Pt.ServiceName,`Connecting to server: ${n}`);let r=yield this.connectAsync();if(this._log.Warning(Pt.ServiceName,`Connection result: ${r}`),r==de.Connected){if(yield this.AuthorizeAsync(e))return t=de.Connected,this._connectedAtLeastOnce=!0,t;this._log.Warning(Pt.ServiceName,`Failed to authorize in ${n}`)}}return t}}))}swapBrokersAsync(){return Rt(this,arguments,void 0,(function*(e=!0){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(){return Rt(this,void 0,void 0,(function*(){var e,t,n,r,s,o,i,a,c;if(de.FailedToConnect,!this._address)return Promise.resolve(de.ControllerIsNotConnected);this._disconnectedOnPurpose&&(this._disconnectedOnPurpose=!1),this._connectionStateChangedEvent,this.InitializeConnection(),null===(e=this._connection)||void 0===e||e.onclose((()=>Rt(this,void 0,void 0,(function*(){var e,t;if(this._disconnectedOnPurpose?this._log.Info(Pt.ServiceName,"Connection closed on demand."):this._log.Error(Pt.ServiceName,"Connection closed"),bv.Get(Ke.ServiceName).CreateSessionCompletionSourceAsync(),this.FireConnectionStateChanged(),(null===(e=this._connection)||void 0===e?void 0:e.state)===D.Disconnected&&!this._disconnectedOnPurpose)return yield null===(t=this._connection)||void 0===t?void 0:t.start(),null!=this._connection&&(yield this.AuthorizeAsync(new Ae(this._serialId,this._PIN)))?(this._log.Info(Pt.ServiceName,"Reconnected from onClose"),this.FireConnectionStateChanged()):de.FailedToConnect})))),null===(t=this._connection)||void 0===t||t.onreconnected((()=>Rt(this,void 0,void 0,(function*(){if(yield this.AuthorizeAsync(new Ae(this._serialId,this._PIN)))return this._log.Info(Pt.ServiceName,"Reconnected from onreconnected"),this.FireConnectionStateChanged()})))),null===(n=this._connection)||void 0===n||n.onreconnecting((()=>(this._log.Warning(Pt.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(Pt.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)=>Rt(this,void 0,void 0,(function*(){e.startsWith("NotAuthorized:")?(this._log.Error(Pt.ServiceName,"Failed to authorize!"),yield this.AuthorizeAsync(new Ae(this._serialId,this._PIN))):(this._log.Error(Pt.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(Pt.ServiceName,`Received data:\n${JSON.stringify(n,null,2)}`),u.Invoke(n)})),null!=this._connection?this.FireConnectionStateChanged():de.FailedToConnect}))}FireConnectionStateChanged(){var e;const t=this._connectionStateChangedEvent;switch(null===(e=this._connection)||void 0===e?void 0:e.state){case D.Connected:return t.Invoke(he.Connected),de.Connected;case D.Connecting:return t.Invoke(he.Connecting),de.Connected;case D.Disconnected:if(this._connectedAtLeastOnce)return t.Invoke(he.Disconnected),de.FailedToConnect;break;case D.Disconnecting:if(this._connectedAtLeastOnce)return t.Invoke(he.Disconnecting),de.FailedToConnect;break;case D.Reconnecting:return t.Invoke(he.Reconnecting),de.FailedToConnect}return de.FailedToConnect}DisconnectAsync(){return Rt(this,void 0,void 0,(function*(){var e;this._disconnectedOnPurpose=!0,yield null===(e=this._connection)||void 0===e?void 0:e.stop()}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===D.Connected}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,r)}SendAndWaitForResponseWithRepeatAsync(e,t,n){return Rt(this,arguments,void 0,(function*(e,t,n,r=!0,s=!0){var o,i,a;if(e.Method===ue.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)=>Rt(this,void 0,void 0,(function*(){let a=i=>Rt(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(Pt.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===ue.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ce.UserIsNotLoggedIn&&r&&((null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User),yield null===(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(Pt.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){return Rt(this,arguments,void 0,(function*(e,t,n,r=!0){var s;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)=>Rt(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(Pt.ServiceName,t),a(new p(t))}),t);let u=l=>Rt(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(Pt.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)===ce.UserIsNotLoggedIn&&(this._dataReceivedEvent.Unsubscribe(u),(null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User),yield null===(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 ce.MultiDataResponseStart:case ce.MultiDataResponse:n(l),o=c();break;case ce.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(){return Rt(this,void 0,void 0,(function*(){var e;if((null===(e=this._connection)||void 0===e?void 0:e.state)!==D.Connected)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new ae;return t.Resource="/system/ping",t.Method=ue.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(Pt.ServiceName,`Sent DataFrame ${e.Resource} ${e.Method} transaction id: ${e.TransactionId} data:\n${JSON.stringify(e,null,2)}`):t&&this._log.Debug(Pt.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(Pt.ServiceName,`${e}`),n(!1)}))}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}}Pt.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(vt||(vt={})),(Gt=mt||(mt={}))[Gt.Default=0]="Default",Gt[Gt.Monostable=1]="Monostable",Gt[Gt.Bistable=2]="Bistable",Gt[Gt.Gate=3]="Gate",Gt[Gt.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"}(yt||(yt={}));class Ot{constructor(){this._type=St.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(bt=wt||(wt={}))[bt.Unknown=0]="Unknown",bt[bt.BlindMotor=1]="BlindMotor",bt[bt.DinModule=2]="DinModule",bt[bt.DinModuleWithAntenna=3]="DinModuleWithAntenna",bt[bt.Remote=4]="Remote",bt[bt.RemoteForBlinds=5]="RemoteForBlinds",bt[bt.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",bt[bt.MovementSensor=7]="MovementSensor",bt[bt.TemperatureSensor=8]="TemperatureSensor",bt[bt.HumiditySensor=9]="HumiditySensor",bt[bt.DinPowerMeter=10]="DinPowerMeter",bt[bt.Intercom=11]="Intercom",bt[bt.SecurityCamera=12]="SecurityCamera",bt[bt.Multisensor=13]="Multisensor",bt[bt.FloodSensor=14]="FloodSensor",bt[bt.FlushMountedReceiver=15]="FlushMountedReceiver",bt[bt.FlushMountedBlindController=16]="FlushMountedBlindController",bt[bt.FlushMountedDimmer=17]="FlushMountedDimmer",bt[bt.FlushMountedRelay=18]="FlushMountedRelay",bt[bt.FlushMountedGateController=19]="FlushMountedGateController",bt[bt.WindSensor=20]="WindSensor",bt[bt.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",bt[bt.AirPressureSensor=22]="AirPressureSensor",bt[bt.LightBrightnessSensor=23]="LightBrightnessSensor",bt[bt.ReedSensor=24]="ReedSensor",bt[bt.FlushMountedTransceiver=25]="FlushMountedTransceiver",bt[bt.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",bt[bt.WallMountedThermoregulator=27]="WallMountedThermoregulator",bt[bt.ImpulseCounter=28]="ImpulseCounter",bt[bt.FlushMountedFacadeController=29]="FlushMountedFacadeController",bt[bt.WallMountedGateController=30]="WallMountedGateController",bt[bt.WallMountedRGBLightController=31]="WallMountedRGBLightController",bt[bt.WallMountedDimmer=32]="WallMountedDimmer",bt[bt.WallMountedRemote=33]="WallMountedRemote",bt[bt.DinRelay=34]="DinRelay",bt[bt.DinReceiver=35]="DinReceiver",bt[bt.DinBlindController=36]="DinBlindController",bt[bt.DinTransceiver=37]="DinTransceiver",bt[bt.SocketPlugIn=38]="SocketPlugIn",bt[bt.WallMountedRelay=39]="WallMountedRelay",bt[bt.Retransmitter=40]="Retransmitter",function(e){e.Unknown="Unknown",e.SetBlindPosition="IBlindPosition",e.SetBlindPositionSimple="IBlindPositionSimple",e.SetBlindMicroventilation="IMicroventilation",e.TurnOff="IChannelOff",e.TurnOn="IChannelOn",e.TurnOnWithTime="IChannelOnWithTime",e.TogleState="IChannelSwitchState",e.SetLightBrightnessDynamicly="IDynamicLightBrightness",e.SetLightBrightness="ILightBrightness",e.SetLightColor="ILightColor",e.SetLightTemperature="ILightTemperature",e.PairDevice="IPair",e.UnpairDevice="IUnpair",e.IdentifyDevice="IIdentifyDevice",e.GetChannelsState="IGetDeviceState",e.GetPowerMeasurements="IGetPowerMeasurements",e.GetAvailableData="IGetAvailableData",e.MultipleDataRequest="IMultipleDataRequest",e.SetBlindOpenCloseTime="ISetBlindOpenCloseTime",e.SetTemperature="IChangeTemperature",e.SetGatePosition="IGatePosition",e.SetGatewayPosition="IGatewayPosition",e.ChangeGatePositionPulse="IGatePulse",e.ChangeGatewayPositionPulse="IGatewayPulse",e.SetFacadePosition="IFacadePosition",e.GetFacadeType="IGetFacadeType",e.LightRGBW="ILightRGBW",e.PreciseGateControl="IPreciseGateControl"}(St||(St={}));class Ut{constructor(){this._type=_t.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}!function(e){e.Unknown="Unknown",e.BatteryState="IBatteryState",e.BinarySensorState="IBinarySensor",e.BlindOpenCloseTime="IBlindOpenCloseTime",e.BlindPosition="IBlindPosition",e.BlindRemoteButtonState="IBlindsControlButton",e.BlindErrorState="IBlindError",e.MeasuredBrightness="IBrightness",e.RemoteButtonState="IButtonState",e.ChannelOnOffState="IChannelOnOff",e.IntercomState="IIntercom",e.DoorBellState="IDoorBell",e.FacadeRemoteButtonState="IFacadeControlButton",e.FacadePosition="IFacadeState",e.FacadeType="IFacadeType",e.FloodSensorState="IFloodSensor",e.GatePosition="IGatePosition",e.GatewayPosition="IGatewayPosition",e.GateControllerHealth="IGateControllerHealth",e.HumiditySensorState="IHumiditySensor",e.LightBrightness="ILightBrightness",e.LightColor="ILightColor",e.LightWarmth="ILightTemperature",e.LightTreshold="ILightTreshold",e.MovementSensorState="IMovementSensor",e.OnlineCamera="IOnlineCamera",e.OvercurrentProtectionState="IOvercurrentProtection",e.OvercurrentProtectionThreshold="IOvercurrentProtectionThreshold",e.ReedState="IReedState",e.SignalStrength="ISignalStrength",e.SmokeSensorState="ISmokeSensor",e.MeasuredTemperature="ITemperature",e.VibrationSensorState="IVibrationSensor",e.MeasuredWindSpeed="IWindSpeed",e.WindThreshold="IWindThreshold",e.MeasuredEnergy="IEnergy",e.MeasuredDistance="DistanceSensor",e.BlindCalibration="BlindCalibration",e.ConfigurationState="ConfigurationState",e.CurrentWindThreshold="CurrentWindThreshold",e.CurrentLightThreshold="CurrentLightThreshold",e.WindSpeedState="WindSpeed",e.TamperProtectionState="ITamperProtection",e.PressureSensorState="IPressureSensor",e.LightRGBWState="ILightRGBW"}(_t||(_t={})),(It=At||(At={}))[It.NotResponding=0]="NotResponding",It[It.Working=1]="Working",It[It.Broken=2]="Broken",It[It.FirmareUpgradeMode=3]="FirmareUpgradeMode",(Et=Ct||(Ct={}))[Et.TwoWay=1]="TwoWay",Et[Et.OneWay=2]="OneWay",Et[Et.ConditionalTwoWay=3]="ConditionalTwoWay",(Nt=Dt||(Dt={}))[Nt.Unknown=-1]="Unknown",Nt[Nt.Multipurpose=0]="Multipurpose",Nt[Nt.Controller=1]="Controller",Nt[Nt.Driver=2]="Driver",Nt[Nt.Receiver=3]="Receiver",Nt[Nt.Remote=4]="Remote",Nt[Nt.Sensor=5]="Sensor",Nt[Nt.Scene=6]="Scene";class Mt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=vt.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"}(Tt||(Tt={})),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"}(kt||(kt={}));class xt{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=kt.Unknown}}var Ft,Bt,Lt,$t,Wt,qt,Ht,Vt,jt,Kt,zt,Jt,Yt,Xt,Qt,Zt,en,tn,nn,rn,sn,on,an,cn,un,ln,dn,hn,pn,gn,fn;class vn{constructor(){this._type="",this._data=null,this._typeAsEnum=_t.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}}(fn=Ft||(Ft={}))[fn.Confident=0]="Confident",fn[fn.Unconfident=1]="Unconfident";class mn extends vn{constructor(e){super(),this.TypeAsEnum=_t.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class yn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=Bt.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Bt||(Bt={})),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"}(Lt||(Lt={}));class wn extends vn{constructor(e){super(),this.TypeAsEnum=_t.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class Sn extends vn{constructor(e){super(),this.TypeAsEnum=_t.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class _n{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=$t.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}($t||($t={}));class An extends vn{constructor(e){super(),this.TypeAsEnum=_t.ReedState,this.Type="ReedState",this.Data=e.state}}class Cn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=!1,this.Time=""}}class Dn extends vn{constructor(e){super(),this.TypeAsEnum=_t.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return Wt.UnableToMove;case 201:return Wt.MotorOverheatedPleaseWait;default:return Wt.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(Wt||(Wt={}));class Tn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class kn extends vn{constructor(e){super(),this.TypeAsEnum=_t.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class Gn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=qt.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(qt||(qt={}));class bn extends vn{constructor(e){super(),this.TypeAsEnum=_t.LightColor,this.Type="LightColorState",this.Data=e.state}}class Nn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class En extends vn{constructor(e){super(),this.TypeAsEnum=_t.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class In{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Temperature=0,this.Time=""}}class Rn extends vn{constructor(e){super(),this.TypeAsEnum=_t.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class Pn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Brightness=0,this.Time=""}}class On extends vn{constructor(e){super(),this.TypeAsEnum=_t.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class Un{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Temperature=0,this.Type=Ht.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"}(Ht||(Ht={}));class Mn extends vn{constructor(e){super(),this.TypeAsEnum=_t.BatteryState,this.Type="BatteryState",this.Data=e.state}}class xn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=Vt.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"}(Vt||(Vt={}));class Fn extends vn{constructor(e){super(),this.TypeAsEnum=_t.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class Bn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Brightness=0,this.Time=""}}class Ln extends vn{constructor(e){super(),this.TypeAsEnum=_t.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class $n{constructor(){this.Channel=0,this.StateReliability=Ft.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"}(jt||(jt={}));class Wn extends vn{constructor(e){super(),this.TypeAsEnum=_t.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(Kt||(Kt={}));class qn extends vn{constructor(e){super(),this.TypeAsEnum=_t.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class Hn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Intensity=0,this.Movement=zt.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(zt||(zt={}));class Vn extends vn{constructor(e){super(),this.TypeAsEnum=_t.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class jn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=Jt.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"}(Jt||(Jt={}));class Kn extends vn{constructor(e){super(),this.TypeAsEnum=_t.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class zn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=Yt.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"}(Yt||(Yt={}));class Jn extends vn{constructor(e){super(),this.TypeAsEnum=_t.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"}(Xt||(Xt={}));class Yn extends vn{constructor(e){super(),this.TypeAsEnum=_t.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class Xn{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.PositionType=Qt.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"}(Qt||(Qt={}));class Qn extends vn{constructor(e){super(),this.TypeAsEnum=_t.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"}(Zt||(Zt={}));class Zn extends vn{constructor(e){super(),this.TypeAsEnum=_t.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"}(en||(en={}));class er extends vn{constructor(e){super(),this.TypeAsEnum=_t.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"}(tn||(tn={}));class tr extends vn{constructor(e){super(),this.TypeAsEnum=_t.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class nr{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Type=nn.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"}(nn||(nn={}));class rr extends vn{constructor(e){super(),this.TypeAsEnum=_t.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(rn||(rn={}));class sr extends vn{constructor(e){super(),this.TypeAsEnum=_t.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class or{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=sn.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(sn||(sn={}));class ir extends vn{constructor(e){super(),this.TypeAsEnum=_t.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"}(on||(on={}));class ar extends vn{constructor(e){super(),this.TypeAsEnum=_t.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class cr extends vn{constructor(e){super(),this.TypeAsEnum=_t.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class ur extends vn{constructor(e){super(),this.TypeAsEnum=_t.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class lr extends vn{constructor(e){super(),this.TypeAsEnum=_t.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class dr extends vn{constructor(e){super(),this.TypeAsEnum=_t.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class hr extends vn{constructor(e){super(),this.TypeAsEnum=_t.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class pr{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.WindThreshold=an.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"}(an||(an={}));class gr extends vn{constructor(e){super(),this.TypeAsEnum=_t.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"}(cn||(cn={}));class fr extends vn{constructor(e){super(),this.TypeAsEnum=_t.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class vr{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Value=0,this.Time=""}}class mr extends vn{constructor(e){super(),this.TypeAsEnum=_t.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class yr{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.State=un.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(un||(un={})),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"}(ln||(ln={}));class wr extends vn{constructor(e){super(),this.TypeAsEnum=_t.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class Sr{constructor(){this.Channel=0,this.StateReliability=Ft.Unconfident,this.Pressure=0,this.Time="",this.PressureType=dn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(dn||(dn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(hn||(hn={}));class _r extends vn{constructor(e){super(),this.TypeAsEnum=_t.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(pn||(pn={}));class Ar extends vn{constructor(e){super(),this.TypeAsEnum=_t.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Cr extends vn{constructor(e){super(),this.TypeAsEnum=_t.BlindErrorState,this.Type="BlindError",this.Data=e.state}}!function(e){e[e.Unknown=0]="Unknown",e[e.ObstacleDetected=1]="ObstacleDetected",e[e.MotorFailure=2]="MotorFailure"}(gn||(gn={}));class Dr{constructor(){this._onDeviceStateChangedEvent=new n,this._onDeviceStateRefreshedOrChangedEvent=new n,this._onDeviceTasksExecutionChangedOnChannelsEvent=new n,this._onDeviceFirmwareVersionChangedEvent=new n,this._iconType=wt.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=At.Working,this._deviceType=Dt.Unknown,this._communicationWay=Ct.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==Dr._devicesService&&(Dr._devicesService=bv.Get(So.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Dr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Dr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),Dr._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===Dt.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!==St.SetBlindPositionSimple))}return!1}get States(){return r.DoesThrowStackTrace?bv.Get(So.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Dr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Dr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Dr._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 bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(new Tr(this,e),2e4,!1);switch(t.Status){case ce.OK:return this._name=e,bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),new De(me.Changed,"");case ce.WrongData:if("DeviceNotFound"==t.Data)return new De(me.Failed,"DeviceNotFound");break;case ce.NoPermissionsToCallGivenResource:return new De(me.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new De(me.ControllerResponseTimeout,""):new De(me.UnknownError,"")}return new De(me.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 Dr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class Tr extends ae{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=ue.Put;const n=new kr;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class kr{constructor(){this.DeviceGuid="",this.Name=""}}var Gr,br,Nr,Er,Ir,Rr=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 Pr{constructor(){this._device=new Dr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=mt.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==Pr._devicesService&&(Pr._devicesService=bv.Get(So.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 Rr(this,void 0,void 0,(function*(){const n=this.GetChannelConfigurationData();n.CustomData[e]=t,this._customData[e]=t;const r=new Or;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 Or;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new Ur;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 Or;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 Or;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Or;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 Or;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 Or;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){return Rr(this,void 0,void 0,(function*(){var t;try{const n=yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(new Mr(e),2e4,!1);switch(bv.Get(Ge.ServiceName).ClearCache(),yield bv.Get(st.ServiceName).ExitConfigurationModeAsync(),n.Status){case ce.OK:return this._name=e.ChannelConfiguration.ChannelName,this._iconName=e.ChannelConfiguration.IconName,this._channelGroups=e.ChannelConfiguration.GroupsGuids,this._isHidden=e.ChannelConfiguration.Hidden,this._mode=e.ChannelConfiguration.Configuration,this._customData=e.ChannelConfiguration.CustomData,this._roles=e.ChannelConfiguration.Roles,this._configurations=e.ChannelConfiguration.Configurations,new De(me.Changed,"");case ce.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 De(me.WrongData,"DeviceNotFound");break;case ce.FatalError:return new De(me.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new De(me.ControllerResponseTimeout,"")}return new De(me.Unknown,"")}))}get Number(){return this._number}set Number(e){this._number=e}get Name(){return this._name}set Name(e){this._name=e}get IconName(){return this._iconName}set IconName(e){this._iconName=e}get States(){return r.DoesThrowStackTrace?bv.Get(So.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Pr._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,Pr._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(kt.Failed)}}Pr._devicesService=null;class Or{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new Ur}}class Ur{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=mt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class Mr extends ae{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=ue.Put,this.Data=e}}!function(e){e[e.TurnOn=0]="TurnOn",e[e.TurnOff=1]="TurnOff",e[e.ToggleState=2]="ToggleState",e[e.SetBlindPosition=3]="SetBlindPosition",e[e.SetLightColor=4]="SetLightColor",e[e.SetLightTemperature=5]="SetLightTemperature",e[e.SetLightBrightness=6]="SetLightBrightness",e[e.SetTemperature=7]="SetTemperature",e[e.GetState=8]="GetState",e[e.TurnOnWithTimeout=9]="TurnOnWithTimeout",e[e.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",e[e.IdentifyDevice=11]="IdentifyDevice",e[e.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",e[e.SetBlindMicroventilation=13]="SetBlindMicroventilation",e[e.GatewayPulse=25]="GatewayPulse",e[e.GatePulse=26]="GatePulse",e[e.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",e[e.GetFacadeType=30]="GetFacadeType",e[e.LightRGBW=31]="LightRGBW",e[e.SetGatePositionPrecise=32]="SetGatePositionPrecise"}(Gr||(Gr={}));class xr{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 Fr{constructor(){this._taskType=St.GetChannelsState,this._featureType=Gr.GetState,this._channel=0,this._guid=xr.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 Br extends Fr{constructor(){super(),this.Temperature=0,this.FeatureType=Gr.SetTemperature,this.TaskType=St.SetTemperature}}class Lr extends Fr{constructor(){super(),this.FeatureType=Gr.TurnOff,this.TaskType=St.TurnOff}}class $r extends Fr{constructor(){super(),this.FeatureType=Gr.TurnOn,this.TaskType=St.TurnOn}}class Wr extends Fr{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=Gr.TurnOnWithTimeout,this.TaskType=St.TurnOnWithTime}}class qr extends Fr{constructor(){super(),this.Brightness=0,this.FeatureType=Gr.SetLightBrightness,this.TaskType=St.SetLightBrightness}}class Hr extends Fr{constructor(){super(),this.FeatureType=Gr.ToggleState,this.TaskType=St.TogleState}}class Vr extends Fr{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=Gr.SetLightColor,this.TaskType=St.SetLightColor}}class jr extends Fr{constructor(){super(),this.Temperature=0,this.FeatureType=Gr.SetLightTemperature,this.TaskType=St.SetLightTemperature}}class Kr extends Fr{constructor(){super(),this.Action=br.Stop,this.Position=0,this.FeatureType=Gr.SetBlindPosition,this.TaskType=St.SetBlindPosition}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(br||(br={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Nr||(Nr={})),function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Er||(Er={}));class zr extends Fr{constructor(){super(),this.Brightness=0,this.FeatureType=Gr.SetLightBrightnessDynamicly,this.TaskType=St.SetLightBrightnessDynamicly}}class Jr extends Fr{constructor(){super(),this.FeatureType=Gr.IdentifyDevice,this.TaskType=St.IdentifyDevice}}class Yr extends Fr{constructor(){super(),this.Data=new Xr,this.FeatureType=Gr.SetBlindOpenCloseTime,this.TaskType=St.SetBlindOpenCloseTime}}class Xr{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class Qr extends Fr{constructor(){super(),this.FeatureType=Gr.GetState,this.TaskType=St.GetChannelsState}}class Zr extends Fr{constructor(){super(),this.Position=0,this.FeatureType=Gr.SetBlindMicroventilation,this.TaskType=St.SetBlindMicroventilation}}class es extends Fr{constructor(){super(),this.FeatureType=Gr.GatePulse,this.TaskType=St.ChangeGatewayPositionPulse}}class ts extends Fr{constructor(){super(),this.FeatureType=Gr.GatewayPulse,this.TaskType=St.ChangeGatewayPositionPulse}}class ns extends Fr{constructor(){super(),this.FacadeAction=Ir.Stop,this.Tilt=0,this.Position=0,this.FeatureType=Gr.SetFacadePositionAndTilt,this.TaskType=St.SetFacadePosition}}class rs extends Fr{constructor(){super(),this.FeatureType=Gr.GetFacadeType,this.TaskType=St.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"}(Ir||(Ir={}));class ss{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class os extends Fr{constructor(){super(),this.Data=new ss,this.FeatureType=Gr.LightRGBW,this.TaskType=St.LightRGBW}}var is=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 as{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return as.ServiceName}RegisterManuallyPairedDevicesProtocol(e){bv.Get(r.ServiceName).Debug(as.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return is(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 is(this,void 0,void 0,(function*(){const t=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=t?t.AddManuallyPairedDeviceAsync(e):(bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),kt.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}as.ServiceName="ManualDeviceService";class cs{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var us,ls=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 ds{constructor(){this._connection=null,this._localDb=null,this._connection=bv.Get(Pt.ServiceName),this._localDb=bv.Get(o.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return ls(this,void 0,void 0,(function*(){let r=new hs(e,t,n),s=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(s.Status===ce.OK){const r=new fs;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(ds.ServiceName,this.GetLocalDbName(e,t),r)}return s.Status}))}ReadAsync(e,t,n){return ls(this,void 0,void 0,(function*(){let r=new ps(e,t);if(!n){const n=this._localDb.Read(ds.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new cs;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===ce.OK){const e=new cs;return e.ResourceGuid=s.ResourceGuid,e.Data=JSON.parse(s.Data),e.IsGlobal=s.IsGlobal,e}return s.Status}))}RemoveAsync(e,t){return ls(this,void 0,void 0,(function*(){let n=new gs(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}))}GetServiceName(){return ds.ServiceName}}ds.ServiceName="RemoteStorageService";class hs extends ae{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class ps extends ae{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Get,this.ResourceGuid=e,this.Global=t}}class gs extends ae{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=ue.Delete,this.ResourceGuid=e,this.Global=t}}class fs extends ae{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class vs{constructor(){this.Longitude=0,this.Latitude=0}}class ms{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"}(us||(us={}));var ys,ws,Ss,_s,As,Cs,Ds,Ts,ks,Gs,bs,Ns,Es,Is,Rs,Ps,Os,Us=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 Ms{IsControllerGeolocationSetAsync(){return Us(this,void 0,void 0,(function*(){let e=new xs,t=yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ce.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return Us(this,void 0,void 0,(function*(){return new Promise(((e,t)=>Us(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){return Us(this,void 0,void 0,(function*(){var t,n;let r=new Bs;r.Data.Latitude=e.Latitude,r.Data.Longitude=e.Longitude,null===(t=s.Log)||void 0===t||t.Warning(Ms.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(r)}`);let o=yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(r,15e3,!1);switch(null===(n=s.Log)||void 0===n||n.Warning(Ms.ServiceName,`${JSON.stringify(o)}`),bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null==o?void 0:o.Status){case ce.OK:return new Te(us.OK,"");case ce.NoPermissionToPerformThisOperation:case ce.NoPermissionsToCallGivenResource:return new Te(us.NoPermissions,"");case ce.UserIsNotLoggedIn:return new Te(us.UserIsNotLoggedIn,"");default:return new Te(us.UnknownError,"")}}))}GetControlllerGeolocationAsync(){return Us(this,void 0,void 0,(function*(){var e,t;let n=new Fs;null===(e=s.Log)||void 0===e||e.Warning(Ms.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=s.Log)||void 0===t||t.Warning(Ms.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ce.OK){let e=new ms;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 Ms.ServiceName}}Ms.ServiceName="GeolocationService";class xs extends ae{constructor(){super(),this.Resource="/geolocation/isset",this.Method=ue.Get}}class Fs extends ae{constructor(){super(),this.Resource="/geolocation/get",this.Method=ue.Get}}class Bs extends ae{constructor(){super(),this.Data=new vs,this.Resource="/geolocation/save",this.Method=ue.Put}}!function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(ys||(ys={}));class Ls{constructor(){this._comparisonParams=new Map,this.Type=_t.Unknown,this.DeviceGuid="",this.ComparisonMethod=ws.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof xn&&(this.Type=_t.BatteryState),e instanceof or&&(this.Type=_t.BinarySensorState),e instanceof Tn&&(this.Type=_t.BlindPosition),e instanceof Pn&&(this.Type=_t.LightBrightness),e instanceof Bn&&(this.Type=_t.MeasuredBrightness),e instanceof Gn&&(this.Type=_t.RemoteButtonState),e instanceof yn&&(this.Type=_t.ChannelOnOffState),e instanceof _n&&(this.Type=_t.DoorBellState),e instanceof $n&&(this.Type=_t.MeasuredEnergy),e instanceof yr&&(this.Type=_t.FloodSensorState),e instanceof Xn&&(this.Type=_t.GatePosition),e instanceof Nn&&(this.Type=_t.LightColor),e instanceof In&&(this.Type=_t.LightWarmth),e instanceof Cn&&(this.Type=_t.ReedState),e instanceof Un&&(this.Type=_t.MeasuredTemperature),e instanceof nr&&(this.Type=_t.HumiditySensorState),e instanceof jn&&(this.Type=_t.BlindRemoteButtonState),e instanceof zn&&(this.Type=_t.FacadeRemoteButtonState),e instanceof Hn&&(this.Type=_t.MovementSensorState),e instanceof $n&&(this.Type=_t.MeasuredEnergy),e instanceof Sr&&(this.Type=_t.PressureSensorState),e instanceof vr&&(this.Type=_t.WindSpeedState),e instanceof pr&&(this.Type=_t.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class $s{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class Ws{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"}(ws||(ws={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}(Ss||(Ss={})),function(e){e[e.SunRise=1]="SunRise",e[e.SunSet=2]="SunSet"}(_s||(_s={}));class qs{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"}(As||(As={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(Cs||(Cs={})),(Os=Ds||(Ds={}))[Os.Unknown=0]="Unknown",Os[Os.Second=1]="Second",Os[Os.Minute=2]="Minute",Os[Os.Hour=3]="Hour",Os[Os.Day=4]="Day",Os[Os.DayOfWeek=5]="DayOfWeek",Os[Os.Month=6]="Month",Os[Os.Year=7]="Year",Os[Os.Date=8]="Date",Os[Os.Time=9]="Time",Os[Os.WeatherType=11]="WeatherType",Os[Os.CompareNumbers=12]="CompareNumbers",Os[Os.CompareBooleans=13]="CompareBooleans",Os[Os.DeviceState=14]="DeviceState",Os[Os.Timer=15]="Timer",Os[Os.Temperature=17]="Temperature",Os[Os.DaysOfWeek=18]="DaysOfWeek",Os[Os.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",Os[Os.SceneExecuted=20]="SceneExecuted",(Ps=Ts||(Ts={}))[Ps.Unknown=0]="Unknown",Ps[Ps.Equal=1]="Equal",Ps[Ps.NotEqueal=2]="NotEqueal",Ps[Ps.BiggerThan=3]="BiggerThan",Ps[Ps.SmallerThan=4]="SmallerThan",Ps[Ps.BiggerThanOrEqual=5]="BiggerThanOrEqual",Ps[Ps.SmallerThanOrEqual=6]="SmallerThanOrEqual",Ps[Ps.OneOfBothIsTrue=7]="OneOfBothIsTrue",Ps[Ps.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"}(ks||(ks={})),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"}(Gs||(Gs={})),(Rs=bs||(bs={})).Null="Null",Rs.Condition="Condition",Rs.ConditionGroup="ConditionGroup",Rs.ArgumentAsInt="ArgumentAsInt",Rs.ArgumentAsTimeSpan="ArgumentAsTimeSpan",Rs.ArgumentAsBoolean="ArgumentAsBoolean",Rs.ArgumentAsTimeout="ArgumentAsTimeout",Rs.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",Rs.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",Rs.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",Rs.ArgumentAsTime="ArgumentAsTime",Rs.ArgumentAsDeviceState="ArgumentAsDeviceState",Rs.ArgumentAsNumber="ArgumentAsNumber",Rs.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",Rs.ArgumentAsConditionInfo="ArgumentAsConditionInfo";class Hs 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"}(Ns||(Ns={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(Es||(Es={}));class Vs{constructor(e,t="Cube"){this._result=null,this._tmp=new js,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=bv.Get(ao.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=xr.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==Is.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 Vs;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=xr.NewGuid(),e.RightArgumentType==Is.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=xr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==Is.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!=Is.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=Ts.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Ts.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=xr.NewGuid(),this._tmp.HandledType=Ds.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=Is.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,t&&null!=n&&n!=Ts.Equal)throw new to("AtmeetCondition supports only comparation type 'Equal'.");if(e.Offset<-3600||e.Offset>3600)throw new to("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=Ts.Equal;else{if(null==n)throw new to("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Is.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=xr.NewGuid(),this._tmp.HandledType=Ds.Unknown,this._tmp.LeftArgumentType=Is.Null,this._tmp.ConditionType=Ts.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=Is.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=Ts.Equal){return this._tmp.Guid=xr.NewGuid(),this._tmp.HandledType=Ds.DaysOfWeek,this._tmp.LeftArgumentType=Is.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Is.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=Ts.Equal){return this._tmp.Guid=xr.NewGuid(),this._tmp.HandledType=Ds.Timer,this._tmp.LeftArgumentType=Is.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Is.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=Ts.Equal){return this._tmp.Guid=xr.NewGuid(),this._tmp.HandledType=Ds.Time,this._tmp.LeftArgumentType=Is.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Is.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=Ts.Equal){return this._tmp.Guid=xr.NewGuid(),this._tmp.HandledType=Ds.DeviceState,this._tmp.LeftArgumentType=Is.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=Is.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=xr.NewGuid(),this._tmp.HandledType=Ds.SceneExecuted,this._tmp.LeftArgumentType=Is.ArgumentAsConditionInfo,this._tmp.ConditionType=Ts.Equal,this._tmp.AtMeetCondition=!0;const t=new qs;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=Is.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new Js;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),{[Ss[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case _t.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case _t.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case _t.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case _t.LightBrightness:case _t.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case _t.RemoteButtonState:case _t.ChannelOnOffState:case _t.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case _t.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[jt[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case _t.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case _t.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case _t.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case _t.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case _t.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case _t.SmokeSensorState:throw new Hs("Unsupported device state!");case _t.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case _t.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case _t.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case _t.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 _t.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case _t.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case _t.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case _t.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case _t.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case _t.Unknown:t.CheckedDeviceState={};break;default:throw new Hs("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case _t.BatteryState:return ks.BatteryState;case _t.BinarySensorState:return ks.BinarySensor;case _t.BlindPosition:return ks.BlindPosition;case _t.LightBrightness:return ks.LightBrightness;case _t.RemoteButtonState:return ks.ButtonState;case _t.ChannelOnOffState:return ks.ChannelOnOff;case _t.DoorBellState:return ks.DoorBell;case _t.MeasuredEnergy:return ks.Energy;case _t.FloodSensorState:return ks.FloodSensor;case _t.GatePosition:return ks.GatePosition;case _t.MeasuredBrightness:return ks.Brightness;case _t.LightColor:return ks.LightColor;case _t.LightWarmth:return ks.LightTemperature;case _t.ReedState:return ks.ReedState;case _t.SmokeSensorState:return ks.SmokeSensor;case _t.MeasuredTemperature:return ks.Temperature;case _t.HumiditySensorState:return ks.Humidity;case _t.BlindRemoteButtonState:return ks.BlindsControlButton;case _t.FacadeRemoteButtonState:return ks.FacadeControlButton;case _t.MovementSensorState:return ks.Movement;case _t.PressureSensorState:return ks.AirPressure;case _t.WindSpeedState:return ks.WindSpeed;case _t.CurrentWindThreshold:return ks.WindThreshold;default:return ks.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=Is.Null)return e(t.RightArgument,n);t.RightArgumentType=Is.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new Ys)};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 js,{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=Ts.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Ts.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!=Is.Condition){if(n.RightArgumentType==Is.Condition)return t(n.RightArgument,r);throw new no(`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 no(`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 js,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=Ts.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Ts.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==Is.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==Is.Null)throw new no(`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 no("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=Is.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=Ts.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Ts.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!=Is.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new no("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:se.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==St.SetBlindPosition||e instanceof Kr?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==St.SetLightColor||e instanceof Vr?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==St.SetLightTemperature||e instanceof jr?t.Data.Temperature=e.Temperature:e.TaskType==St.SetLightBrightness||e instanceof qr?t.Data.Brightness=e.Brightness:e.TaskType==St.SetTemperature||e instanceof Br?t.Data.Temperature=e.Temperature:e.TaskType==St.TurnOnWithTime||e instanceof Wr?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==St.SetLightBrightnessDynamicly||e instanceof zr?t.Data.Brightness=e.Brightness:e.TaskType==St.SetBlindOpenCloseTime||e instanceof Yr?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==St.SetBlindMicroventilation||e instanceof Zr?t.Data.Position=e.Position:e.TaskType==St.SetFacadePosition||e instanceof ns?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):(e.TaskType==St.LightRGBW||e instanceof os)&&(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 Zs;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:se.GenerateMd5(JSON.stringify(t))}}NotifyTask(e){throw new so("Funcionality will be available in the future.")}LockExecutionTask(e){const t=new eo;if(t.LockType=e.LockType,t.LockType==Es.Timeout&&"00:00:00"!=t.LockEndHour)throw new so("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:se.GenerateMd5(JSON.stringify(t))}}AddTask(){const e=t=>{if(t.RightArgumentType!=Is.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,bv.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!=Is.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 ro("Task not found, cannot edit!");this._tmpTask instanceof Qs&&null!=n.Tasks.DevicesTasks&&(n.Tasks.DevicesTasks=n.Tasks.DevicesTasks.map((t=>se.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t))),n.Tasks.ControllerTasks=n.Tasks.ControllerTasks.map((t=>se.GenerateMd5(JSON.stringify(t))==e?structuredClone(this._tmpTask):t)),this._tmpTask=null,bv.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!=Is.Null)return t(e.RightArgument,n);{const t=e.Tasks.ControllerTasks.filter((e=>se.GenerateMd5(JSON.stringify(e))!=n));if(e.Tasks.ControllerTasks=null==t?[]:t,e.Tasks.DevicesTasks.any()){const t=e.Tasks.DevicesTasks.filter((e=>se.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 St.Unknown:throw new to("Unsupported task type!");case St.SetBlindPosition:case St.SetBlindPositionSimple:return Gr.SetBlindPosition;case St.SetBlindMicroventilation:return Gr.SetBlindMicroventilation;case St.TurnOff:return Gr.TurnOff;case St.TurnOn:return Gr.TurnOn;case St.TurnOnWithTime:return Gr.TurnOnWithTimeout;case St.TogleState:return Gr.ToggleState;case St.SetLightBrightnessDynamicly:return Gr.SetLightBrightnessDynamicly;case St.SetLightBrightness:return Gr.SetLightBrightness;case St.SetLightColor:return Gr.SetLightColor;case St.SetLightTemperature:return Gr.SetLightTemperature;case St.PairDevice:case St.UnpairDevice:throw new to("Unsupported task type!");case St.IdentifyDevice:return Gr.IdentifyDevice;case St.GetChannelsState:return Gr.GetState;case St.GetPowerMeasurements:case St.GetAvailableData:case St.MultipleDataRequest:throw new to("Unsupported task type!");case St.SetBlindOpenCloseTime:return Gr.SetBlindOpenCloseTime;case St.SetTemperature:return Gr.SetTemperature;case St.ChangeGatePositionPulse:return Gr.GatePulse;case St.ChangeGatewayPositionPulse:return Gr.GatewayPulse;case St.SetFacadePosition:case St.GetFacadeType:return Gr.SetFacadePositionAndTilt;case St.LightRGBW:return Gr.LightRGBW;default:throw new to("Unsupported task type!")}}Build(){const e=t=>{if(t.RightArgumentType!=Is.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==Is.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}}class js{constructor(){this.Tasks=new Ys,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=Ds.Unknown,this.ConditionType=Ts.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=Is.Null,this.RightArgumentType=Is.Null,this.LeftArgument=new zs({},Is.Null),this.RightArgument=new Ks}}class Ks{constructor(){this.HandledType=0,this.Argument=null}}class zs{constructor(e,t){this.Argument=e,this.HandledType=t}}class Js{constructor(){this.DeviceStateType=ks.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=ws.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class Ys{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class Xs{constructor(){this.RunParallel=!1,this.TaskType=As.Unknown}}class Qs extends Xs{constructor(){super(...arguments),this.TaskType=As.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=Gr.TurnOn}}class Zs extends Xs{constructor(){super(...arguments),this.TaskType=As.DelayTask,this.Delay="00:00:00"}}class eo extends Xs{constructor(){super(...arguments),this.TaskType=As.LockExecution,this.LockType=Es.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"}(Is||(Is={}));class to extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class no extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class ro extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class so extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var oo,io=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 ao{constructor(){this._connection=bv.Get(Pt.ServiceName),this._configurationService=bv.Get(st.ServiceName)}GetServiceName(){return ao.ServiceName}GetSequencesListAsync(){return io(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new co,12e3,!1);return bv.Get(r.ServiceName).Debug(`GetSequencesListAsync result:\n ${JSON.stringify(t)}}`),null==t?new Te(ys.OtherError,"Cannot get sequences list - response is null."):t.Status!=ce.OK?new Te(ys.OtherError,`Cannot get sequences list - controller responded with response code ${t.Status}.`):null==t.Data?new Te(ys.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):t.Data}))}GetSequenceAsync(e){return io(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new uo(n),12e3,!1);if(null==r)return new Te(ys.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ce.OK)return new Te(ys.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new Te(ys.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 Vs(e,t)}CreateSequenceAsync(e){return io(this,void 0,void 0,(function*(){var t;try{yield this._configurationService.EnterConfigurationModeAsync(),bv.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 go(e),2e4,!1);return null==n||null==n.Status?ce.Error:n.Status}catch(t){return bv.Get(r.ServiceName).Error(`Creating sequence ${e.Name} error: ${t}`),ce.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){return io(this,void 0,void 0,(function*(){var t;try{let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new lo(n),12e3,!1);if(null==r)return new Te(ys.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ce.WrongData:return new Te(ys.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ce.OK:return null==r.Data?new Te(ys.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new Te(ys.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new Te(ys.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){return io(this,void 0,void 0,(function*(){var t;try{let n="";n="string"==typeof e?e:e.Guid,yield this._configurationService.EnterConfigurationModeAsync();const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new vo(n),12e3,!1);return null==r||null==r.Status?ce.Error:r.Status}catch(e){return ce.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}EditSequenceAsync(e){return io(this,void 0,void 0,(function*(){var t;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 fo(n),2e4,!1);return null==r||null==r.Status?ce.Error:r.Status}catch(t){return bv.Get(r.ServiceName).Error(`Editing sequence ${e.Name} error: ${t}`),ce.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}EnableSequenceAsync(e){return io(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new mo(n),12e3,!1);return null==r||null==r.Status?ce.Error:r.Status}))}DisableSequenceAsync(e){return io(this,void 0,void 0,(function*(){var t;let n="";n="string"==typeof e?e:e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new yo(n),12e3,!1);return null==r||null==r.Status?ce.Error:r.Status}))}RunSequenceAsync(e){return io(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ce.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ce.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new $r;switch(n.Channel=1,n.DeviceGuid=t,yield bv.Get(So.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case kt.Executed:return ce.OK;case kt.DeviceNotFound:return ce.WrongData;default:return ce.Error}}))}GetUtilsAsync(){return io(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 io(this,void 0,void 0,(function*(){const e=bv.Get(Ms.ServiceName),t=new vs;let n=!1;t.Latitude=49.9958888026741,t.Longitude=18.9172596008914;try{if(yield e.IsControllerGeolocationSetAsync()){const n=yield e.GetControlllerGeolocationAsync();n instanceof ms&&(t.Latitude=n.Latitude,t.Longitude=n.Longitude)}}catch(e){bv.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!=oo.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=As.DeviceTask,e.RunParallel=!1})))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=bs.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==bs.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===bs.Condition&&(e.RightArgumentType=this.MapArgumentType(e.RightArgumentType),e.RightArgument=this.MapRightArgument(e.RightArgument,e.RightArgumentType))),e}MapLeftArgument(e,t){let n=new ho;switch(n.HandledType=e.HandledType,t){case bs.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case bs.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case bs.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case bs.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case bs.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case bs.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case bs.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case bs.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case bs.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case bs.ArgumentAsDeviceState:{const t=new Ls;t.Type=this.MapDeviceStateTypeToResponseType(e.Argument.DeviceStateType),t.SetCheckDeviceState(this.CreateDeviceState(e.Argument.CheckedDeviceState,e.Argument.Channel,t.Type)),t.DeviceGuid=e.Argument.DeviceGuid,t.ComparisonMethod=null==e.Argument.ComparisonMethod?ws.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam(Ss[e[0]],new $s(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam(Ss[e[0]],new Ws(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case bs.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return bs[oo[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case ks.BatteryState:return _t.BatteryState;case ks.BinarySensor:return _t.BinarySensorState;case ks.BlindPosition:return _t.BlindPosition;case ks.Brightness:return _t.MeasuredBrightness;case ks.ButtonState:return _t.RemoteButtonState;case ks.ChannelOnOff:return _t.ChannelOnOffState;case ks.DoorBell:return _t.DoorBellState;case ks.Energy:return _t.MeasuredEnergy;case ks.FloodSensor:return _t.FloodSensorState;case ks.GatePosition:return _t.GatePosition;case ks.LightBrightness:return _t.LightBrightness;case ks.LightColor:return _t.LightColor;case ks.LightTemperature:return _t.LightWarmth;case ks.ReedState:return _t.ReedState;case ks.SmokeSensor:return _t.SmokeSensorState;case ks.Temperature:return _t.MeasuredTemperature;case ks.Humidity:return _t.HumiditySensorState;case ks.BlindsControlButton:return _t.BlindRemoteButtonState;case ks.FacadeControlButton:return _t.FacadeRemoteButtonState;case ks.Movement:return _t.MovementSensorState;case ks.AirPressure:return _t.PressureSensorState;case ks.WindSpeed:return _t.WindSpeedState;case ks.WindThreshold:return _t.CurrentWindThreshold;default:return _t.Unknown}}CreateDeviceState(e,t,n){switch(n){case _t.BatteryState:return{Channel:t,StateReliability:Ft.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case _t.BinarySensorState:return{Channel:t,StateReliability:Ft.Unconfident,State:e.State,Time:""};case _t.BlindPosition:return{Channel:t,StateReliability:Ft.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case _t.LightBrightness:case _t.MeasuredBrightness:return{Channel:t,StateReliability:Ft.Unconfident,Brightness:e.Brightness,Time:""};case _t.RemoteButtonState:case _t.ChannelOnOffState:case _t.DoorBellState:return{Channel:t,StateReliability:Ft.Unconfident,State:e.State,Time:""};case _t.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(jt[t],r);return{Channel:t,StateReliability:Ft.Unconfident,MeasurementParameters:n,Time:""}}case _t.FloodSensorState:return{Channel:t,StateReliability:Ft.Unconfident,State:e.State,Time:""};case _t.GatePosition:return{Channel:t,StateReliability:Ft.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case _t.LightColor:return{Channel:t,StateReliability:Ft.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case _t.LightWarmth:return{Channel:t,StateReliability:Ft.Unconfident,Temperature:e.Temperature,Time:""};case _t.ReedState:return{Channel:t,StateReliability:Ft.Unconfident,State:e.State,Time:""};case _t.SmokeSensorState:throw new Hs("Unsupported device state!");case _t.MeasuredTemperature:return{Channel:t,StateReliability:Ft.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case _t.HumiditySensorState:return{Channel:t,StateReliability:Ft.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case _t.BlindRemoteButtonState:return{Channel:t,StateReliability:Ft.Unconfident,State:e.State,Time:""};case _t.LightRGBWState:return{StateReliability:Ft.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case _t.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:Ft.Unconfident,State:e.State};case _t.MovementSensorState:return{Channel:t,Time:"",StateReliability:Ft.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case _t.PressureSensorState:return{Channel:t,Time:"",StateReliability:Ft.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case _t.WindSpeedState:return{Channel:t,Time:"",StateReliability:Ft.Unconfident,Value:e.Value};case _t.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:Ft.Unconfident,WindThreshold:e.WindThreshold};case _t.Unknown:return new vn;default:throw new Hs("Unsupported device state!")}}MapDeviceTask(e){let t=new Fr,n=e;switch(bv.Get(r.ServiceName).Debug(`[TASK] object: ${JSON.stringify(n)}`),n.ControlFeature){case Gr.TurnOn:t=new $r,t.TaskType=St.TurnOn;break;case Gr.TurnOff:t=new Lr,t.TaskType=St.TurnOff;break;case Gr.ToggleState:t=new Hr,t.TaskType=St.TogleState;break;case Gr.SetBlindPosition:t=new Kr,t.TaskType=St.SetBlindPosition,t.Action=n.Data.Action,t.Position=n.Data.Position;break;case Gr.SetLightColor:t=new Vr,t.TaskType=St.SetLightColor,t.R=n.Data.R,t.G=n.Data.G,t.B=n.Data.B;break;case Gr.SetLightTemperature:t=new jr,t.TaskType=St.SetLightTemperature,t.Temperature=n.Data.Temperature;break;case Gr.SetLightBrightness:t=new qr,t.TaskType=St.SetLightBrightness,t.Brightness=n.Data.Brightness;break;case Gr.SetTemperature:t=new Br,t.TaskType=St.SetTemperature,t.Temperature=n.Data.Temperature;break;case Gr.GetState:t=new Qr,t.TaskType=St.GetChannelsState;break;case Gr.TurnOnWithTimeout:t=new Wr,t.TaskType=St.TurnOnWithTime,t.SwitchOffDelaySeconds=n.Data.SwitchOffDelaySeconds;break;case Gr.SetLightBrightnessDynamicly:t=new zr,t.TaskType=St.SetLightBrightnessDynamicly,t.Brightness=n.Data.Brightness;break;case Gr.IdentifyDevice:t=new Jr,t.TaskType=St.IdentifyDevice;break;case Gr.SetBlindOpenCloseTime:t=new Yr,t.TaskType=St.SetBlindOpenCloseTime,t.Data.CloseTime=n.Data;break;case Gr.SetBlindMicroventilation:t=new Zr,t.TaskType=St.SetBlindMicroventilation,t.Position=n.Data.Position;break;case Gr.GatewayPulse:t=new ts,t.TaskType=St.ChangeGatewayPositionPulse;break;case Gr.GatePulse:t=new es,t.TaskType=St.ChangeGatePositionPulse;break;case Gr.SetFacadePositionAndTilt:t=new ns,t.TaskType=St.SetFacadePosition,t.Position=n.Data.Position,t.Tilt=n.Data.Tilt,t.FacadeAction=Ir.TiltAndPercentage;break;case Gr.GetFacadeType:t=new rs,t.TaskType=St.GetFacadeType;break;case Gr.LightRGBW:t=new os,t.TaskType=St.LightRGBW,t.Data=n.Data}return t.Channel=n.Channel,t.DeviceGuid=n.DeviceGuid,t.FeatureType=n.ControlFeature,t.Guid=xr.NewGuid(),t}MapControllerTasks(e){const t=[];bv.Get(r.ServiceName).Debug(`[TASKS] received tasks object: ${JSON.stringify(e)}`);for(let n of e){const e=new po;switch(e.TaskId=se.GenerateMd5(JSON.stringify(n)),n.TaskType){case As.DeviceTask:e.TaskType=Cs.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(n);break;case As.DelayTask:e.TaskType=Cs.DelayTask,e.Task.DelayTask={Delay:new Ws(n.Delay)};break;case As.NotifyTask:e.TaskType=Cs.NotifyTask,e.Task.NotifyTask={Title:n.Title,Message:n.Message,NotifyType:n.NotifyType};break;case As.LockExecution:case As.LockExecution:e.TaskType=Cs.LockExecution,bv.Get(r.ServiceName).Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(n)}`),e.Task.LockExecution={LockStartHour:new Ws(n.LockStartHour),LockEndHour:new Ws(n.LockEndHour),LockType:n.LockType,ResetLockScenesGuids:n.ResetLockScenesGuids};case As.Unknown:}t.push(e)}return t}}ao.ServiceName="ScenesService";class co extends ae{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=ue.Get}}class uo extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Get,this.Data=e}}class lo extends ae{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=ue.Get,this.Data=e}}class ho{constructor(){this.HandledType=oo.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"}(oo||(oo={}));class po{constructor(){this.TaskId="",this.TaskType=Cs.Unknown,this.Task={}}}class go extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Put,this.Data=e}}class fo extends ae{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=ue.Put,this.Data=e}}class vo extends ae{constructor(e){super(),this.Resource="/logic/sequence",this.Method=ue.Delete,this.Data=e}}class mo extends ae{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=ue.Post,this.Data=e}}class yo extends ae{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=ue.Post,this.Data=e}}var wo=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 So{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=bv.Get(Pt.ServiceName),this._session=bv.Get(Ke.ServiceName),this._controllerConfiguration=bv.Get(st.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>wo(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=>wo(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(So.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=>wo(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(So.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!=Dt.Scene&&(null===(t=s.Log)||void 0===t||t.Debug(So.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=>{var t;const n=e.Data,r=this._devices.filter((e=>e.Guid==n.DeviceGuid));if(r.length>0){const e=r[0],s=this.MapApiDeviceStateToDeviceState(e,n);if(null!=s){this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:s}),s.TypeAsEnum==_t.SignalStrength?e.Channels.forEach((t=>{let r=new Jn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==_t.BatteryState&&e.Channels.forEach((t=>{let r=new Mn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})}));let r=e.States.find((e=>e.TypeAsEnum===s.TypeAsEnum&&e.Data.Channel===s.Data.Channel));if(r){let o=r.StatesComparisonData;if(s.TypeAsEnum==_t.BlindErrorState&&(null===(t=s.Data)||void 0===t?void 0:t.ErrorCode)!=r.Data.ErrorCode)return void this._onDeviceStateChangedEvent.Invoke({Device:e,State:s});r.Data=s.Data,o!==s.StatesComparisonData&&(this._onDeviceStateChangedEvent.Invoke({Device:e,State:s}),s.TypeAsEnum==_t.SignalStrength?e.Channels.forEach((t=>{let r=new Jn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==_t.BatteryState&&e.Channels.forEach((t=>{let r=new Mn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})))}else e.States.push(s),this._onDeviceStateChangedEvent.Invoke({Device:e,State:s}),s.TypeAsEnum==_t.SignalStrength?e.Channels.forEach((t=>{let r=new Jn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==_t.BatteryState&&e.Channels.forEach((t=>{let r=new Mn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{bv.Get(Ge.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=s.Log)||void 0===t||t.Debug(So.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{bv.Get(Ge.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=s.Log)||void 0===t||t.Debug(So.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}ProtocolGuidToProtocolName(e){switch(e){case"1fca7e8a-a2dc-4883-bd94-4e9b2012f685":return"ExtaLife";case"cd25bdff-628c-4dbc-a16a-648c96a819d4":return"Portos 433MHz";case"634c2bb2-1a4f-4db6-8dd4-d5fbaf92678e":return"Supla";case"194aeb81-990c-4a02-9236-59e902958fda":return"RTSP";case"b3e4644e-ab5b-494e-b3c5-66fabe7fff64":return"Wekta";case"247198e1-e360-4355-9886-232ac1456eea":return"Lavva Wi-Fi";default:return null}}CheckIfDeviceUsedInScenesAsync(e){return wo(this,void 0,void 0,(function*(){var t,n,r,o,i,a;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"),ce.ResourceDoesNotExists;a=n}else a=e;const u=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Oo(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!"),ce.FatalError;if(u.Status!=ce.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!"),ce.FatalError;var c=yield bv.Get(ao.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}`),ce.Error;const l=new Fo;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}`),ce.FatalError}}))}CanEditDevicesInfo(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=pe.Admin}CanAddAndRemoveAndConfigureDevices(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=pe.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return wo(this,void 0,void 0,(function*(){const e=bv.Get(ds.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return yield bv.Get(st.ServiceName).ExitConfigurationModeAsync(),e}))}DisableFastStatesSyncAsync(){return wo(this,void 0,void 0,(function*(){const e=bv.Get(ds.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return yield bv.Get(st.ServiceName).ExitConfigurationModeAsync(),e}))}IsFastStatesSyncEnabledAsync(){return wo(this,void 0,void 0,(function*(){const e=yield bv.Get(ds.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof cs?e.Data:e!=ce.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return wo(this,void 0,void 0,(function*(){let t=bv.Get(as.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 wo(this,void 0,void 0,(function*(){var t=yield bv.Get(as.ServiceName).AddManuallyPairedDeviceAsync(e);return yield bv.Get(st.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 _o;r.Channel=t.Data.Channel,r.States=[t],n={DeviceGuid:e.Guid,ChannelsStates:[r]},this._devicesChannelsStates.push(n)}else{let e=n.ChannelsStates.firstOrDefault((e=>e.Channel==t.Data.Channel));if(null==e)e=new _o,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e);else{let n=e.States.firstOrDefault((e=>e.TypeAsEnum==t.TypeAsEnum));null!=n&&(n.TypeAsEnum==_t.BlindErrorState?e.States=e.States.where((e=>e.Data.ErrorCode!=t.Data.ErrorCode)).toArray():e.States=e.States.where((e=>e.TypeAsEnum!=t.TypeAsEnum)).toArray()),e.States.push(t)}}}WaitForSynchronizationAsync(){return this._synchronizationTaskCompletionSource}WaitForDevicesStatesSynchronizationAsync(){return this._deviceStatesSynchronizationTaskCompletionSource}GetCurrentlyRunningTaksAsync(){return wo(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new bo,15e3,!1);(null==t?void 0:t.Status)==ce.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{var n;const r=e.split(";"),o=new Mt;o.DeviceGuid=r[0],o.Channel=Number(r[1]),o.Status=vt.ExecutingTasks,t.push(o),null===(n=s.Log)||void 0===n||n.Debug(So.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 mn(t);case"DoorBell":return new Sn(t);case"ReedPosition":return new An(t);case"BlindPosition":return new Dn(t);case"ButtonState":return new kn(t);case"LightColor":return new bn(t);case"LightTemperature":return new En(t);case"LightBrightness":return new Rn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new On(t);case"BatteryState":return new Mn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new Fn(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":return new Ln(t);case"DistanceSensor":return new Wn(t);case"MovementSensor":return new qn(t);case"BlindsControlButton":return new Vn(t);case"FacadeControlButton":return new Kn(t);case"SignalStrength":return new Jn(t);case"GatePosition":return new Yn(t);case"GatewayPosition":return new Qn(t);case"GateControllerHealth":return new Zn(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new er(t);case"HumiditySensor":case"HumidityState":return new tr(t);case"VibrationSensor":return new rr(t);case"DigitalInputSensor":return new sr(t);case"ConfigurationState":return new ir(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new ar(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new cr(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new ur(t);case"FacadePosition":case"FacadeState":return new lr(t);case"FacadeTypeState":return new dr(t);case"CurrentWindThreshold":return new hr(t);case"CurrentLightThreshold":return new gr(t);case"WindSpeed":return new fr(t);case"FloodSensor":return new mr(t);case"PressureState":return new wr(t);case"ITamperProtection":case"TamperProtection":return new _r(t);case"ILightRGBW":case"LightRGBW":return new Ar(t);case"OnlineCamera":case"IOnlineCamera":return new wn(t);case"BlindError":case"IBlindError":return t.state.ErrorData=ie(t.state.ErrorData),new Cr(t);default:null===(n=s.Log)||void 0===n||n.Debug(So.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return So.ServiceName}SyncDevicesStatesAsync(){return wo(this,arguments,void 0,(function*(e=!1){var t,n,r;const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Co,15e3,!1);if(yield this.IsFastStatesSyncEnabledAsync()){if(e){let e=new Do;e.Data=!0;const t=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(e,35e3,!1);return(null==t?void 0:t.Status)==ce.OK}return(null==s?void 0:s.Status)==ce.OK}{let e=new Do;e.Data=!0;const t=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(e,35e3,!1);return(null==t?void 0:t.Status)==ce.OK}}))}OnDevicesTasksExecutionChangeEvent(){return this._onDevicesTasksChangedEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}OnDeviceStateRefreshedOrChangedEvent(){return this._onDeviceStateRefreshedOrChangedEvent}OnDeviceRegisteredEvent(){return this._onDeviceRegisteredEvent}OnDeviceRemovedEvent(){return this._onDeviceRemovedEvent}OnDeviceFoundEvent(){return this._onDeviceFoundEvent}MapApiDevices(e){const t=[];return null==e?[]:(e.forEach((e=>{var n,r,o,i,a=new Dr;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=wt.Unknown;try{null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Ot;if(a.CommunicationWay==Ct.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 Ut;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 Pr;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 Ut;t.InterfaceType=e,o.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{var t=new Ot;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(){return wo(this,arguments,void 0,(function*(e=!1){var t,n,r;if(this._synchronized&&!(yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync()))return Promise.resolve(this._devices);const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ao,15e3,!0);return null==o||void 0===o?[]:o.Status==ce.OK&&null!=o.Data?e?this.MapApiDevices(o.Data):this.MapApiDevices(o.Data.filter((e=>e.DeviceType!=Dt.Scene))):(null===(r=s.Log)||void 0===r||r.Error(So.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(){return wo(this,arguments,void 0,(function*(e=!1){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){return wo(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Go,15e3,!1);return null==n?[]:n.Status==ce.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==Dt.Scene)).toArray():(null===(t=s.Log)||void 0===t||t.Error(So.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){return wo(this,void 0,void 0,(function*(){var e;bv.Get(Ge.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new To,35e3,!1)}))}StopSearchingForDevices(){return wo(this,void 0,void 0,(function*(){var e;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ko,2e4,!1)}))}RegisterDeviceAsync(e){return wo(this,void 0,void 0,(function*(){var t,n;try{const n=new No;n.Data=e.Guid;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,2e4,!1);return bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),(null==r?void 0:r.Status)==ce.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),kt.Executed):kt.Failed}catch(e){return null===(n=s.Log)||void 0===n||n.Error(So.ServiceName,`Failed to paired devices: ${e}`),kt.ControllerResponseTimeout}}))}RemoveDeviceAsync(e){return wo(this,arguments,void 0,(function*(e,t=!1){var n,r=new Eo;t&&(r=new Io),r.Data=e.Guid;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(r,35e3,!1);return bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ce.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),kt.Executed):kt.Failed}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new Uo;const r=t;switch(r.FeatureType){case Gr.SetTemperature:n.Data=r.Temperature;break;case Gr.SetLightBrightness:n.Data=r.Brightness;break;case Gr.SetLightColor:n=new Mo;const e=r;n.R=e.R,n.G=e.G,n.B=e.B;break;case Gr.SetLightTemperature:n.Data=r.Temperature;break;case Gr.SetGatePositionPrecise:switch(r.GateControlAction){case Nr.Open:n.Data=101;break;case Nr.Close:n.Data=102;break;case Nr.Stop:n.Data=103;break;case Nr.Percentage:n.Data=r.Position}break;case Gr.SetBlindPosition:switch(r.Action){case br.Open:n.Data=101;break;case br.Close:n.Data=102;break;case br.Stop:n.Data=103;break;case br.Percentage:n.Data=r.Position}break;case Gr.SetLightBrightnessDynamicly:n.Data=r.Brightness;break;case Gr.SetBlindOpenCloseTime:n.Data=r.Data;break;case Gr.SetBlindMicroventilation:n.Data=r.Position;break;case Gr.SetFacadePositionAndTilt:n=new xo;const t=r;n.FacadeAction=t.FacadeAction,n.Tilt=t.Tilt,n.Position=t.Position;break;case Gr.LightRGBW:n.Data=r.Data;break;case Gr.GatePulse:case Gr.GatewayPulse:n.Data=0;break;case Gr.TurnOnWithTimeout:n.Data=r.SwitchOffDelaySeconds}return n.Channel=r.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=r.FeatureType,n}ExecuteDeviceTaskAsync(e,t){return wo(this,void 0,void 0,(function*(){var n,r,o,i,a,c,u,l;try{null===(n=s.Log)||void 0===n||n.Debug(So.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new Ro(l);null===(r=s.Log)||void 0===r||r.Debug(So.ServiceName,`Sending device task for execution, device: ${l.DeviceGuid} task: ${l.ControlFeature} channel: ${l.Channel} request: ${JSON.stringify(e)}`);const t=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(e,15e3,!1);switch(null==t?void 0:t.Status){case ce.OK:return kt.Executed;case ce.FatalError:return null===(i=s.Log)||void 0===i||i.Error(So.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),kt.Failed;case ce.WrongData:if("DeviceNotFound"===t.Data)return kt.DeviceNotFound;break;case ce.Error:return"DeviceResponseTimeout"===t.Data?kt.DeviceResponseTimeout:(null===(a=s.Log)||void 0===a||a.Error(So.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),kt.Failed)}}catch(e){return e.message.includes("timeout")?(null===(c=s.Log)||void 0===c||c.Error(So.ServiceName,`Failed to get controller response in time.\n${e}`),kt.ControllerResponseTimeout):(null===(u=s.Log)||void 0===u||u.Error(So.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),kt.Failed)}return kt.Unknown}catch(e){return null===(l=s.Log)||void 0===l||l.Error(So.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),kt.Failed}}))}ExecuteDevicesTasksAsync(e){return wo(this,void 0,void 0,(function*(){var t,n,r,o;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 Po(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=kt.Unknown;switch(t.Status){case ce.OK:return kt.Executed;case ce.FatalError:null===(n=s.Log)||void 0===n||n.Error(So.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),c=kt.Failed;break;case ce.WrongData:"DeviceNotFound"===t.Data&&(c=kt.DeviceNotFound);break;case ce.Error:"DeviceResponseTimeout"===t.Data?c=kt.DeviceResponseTimeout:(null===(a=s.Log)||void 0===a||a.Error(So.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),c=kt.Failed)}let u=0,l=new xt;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(So.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new xt;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=kt.ControllerResponseTimeout}}else{null===(o=s.Log)||void 0===o||o.Error(So.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new xt;i.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=kt.Failed}}}return i}))}}So.ServiceName="DevicesService";class _o{constructor(){this.Channel=0,this.States=[]}}class Ao extends ae{constructor(){super(),this.Resource="/devices/list",this.Method=ue.Get}}class Co extends ae{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=ue.Get}}class Do extends ae{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=ue.Get}}class To extends ae{constructor(){super(),this.Resource="/devices/search",this.Method=ue.Post}}class ko extends ae{constructor(){super(),this.Resource="/devices/search/stop",this.Method=ue.Post}}class Go extends ae{constructor(){super(),this.Resource="/devices/found/list",this.Method=ue.Get}}class bo extends ae{constructor(){super(),this.Resource="/devices/tasks",this.Method=ue.Get}}class No extends ae{constructor(){super(),this.Resource="/devices/device/pair",this.Method=ue.Put}}class Eo extends ae{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=ue.Put}}class Io extends ae{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=ue.Put}}class Ro extends ae{constructor(e){super(),this.Resource="/devices/device/control",this.Method=ue.Post,this.Data=e}}class Po extends ae{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=ue.Post,this.Data=e}}class Oo extends ae{constructor(e){super(),this.Resource="/logic/device/used",this.Method=ue.Get,this.Data=e}}class Uo{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=Gr.GetState,this.SequnceExecutionOrder=0}}class Mo extends Uo{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class xo extends Uo{constructor(){super(...arguments),this.FacadeAction=Ir.Stop,this.Tilt=0,this.Position=0}}class Fo{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class Bo extends RangeError{paramName;constructor(e){super(`${e} was out of range. Must be non-negative and less than the size of the collection.`),this.paramName=e,this.name="ArgumentOutOfRangeException",this.stack=this.stack||(new Error).stack}}const Lo=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 $o extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const Wo=(e,t)=>e===t;class qo{iterator;constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Ho{dataFunc;constructor(e){this.dataFunc=e}[Symbol.asyncIterator](){const{dataFunc:e}=this;return async function*(){if(1===e.type)for(const t of e.generator())yield t;else for(const t of await e.generator())yield t}()}}class Vo{iterator;constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class jo extends Array{}const Ko=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Yo(e,t,n,r)}return n?Jo(e,t,n):zo(e,t)},zo=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new $o(Lo.NoElements);return n},Jo=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},Yo=(e,t,n,r)=>{let s=t;for(const t of e)s=n(s,t);return r(s)},Xo=(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},Zo=(e,t)=>t?ti(e,t):ei(e),ei=e=>{for(const t of e)return!0;return!1},ti=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},ni=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},ri=(e,t)=>new Vo((function*(){yield*e,yield t})),si=e=>{if(Array.isArray(e)){if(0===e.length)throw new $o(Lo.NoElements);return new qo((async function*(){for await(const t of e)yield t}))}return new qo(e)},oi=e=>si((async function*(){for(const t of e)yield t})),ii=(e,t)=>new Ho({generator:t,type:e}),ai=e=>ii(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),ci=(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 $o(Lo.NoElements);return n/r},ui=async(e,t)=>{let n=0,r=0;for(const s of e)n+=await t(s),r+=1;if(0===r)throw new $o(Lo.NoElements);return n/r},li=(e,t)=>{if(t<1)throw new Bo("size");return new Vo((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},di=(e,t)=>new Vo((function*(){yield*e,yield*t})),hi=(e,t,n=Wo)=>{for(const r of e)if(n(t,r))return!0;return!1},pi=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},gi=(e,t)=>t?vi(e,t):fi(e),fi=e=>{let t=0;for(const n of e)t++;return t},vi=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},mi=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},yi=(e,t)=>new Vo((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),wi=(e,t=Wo)=>new Vo((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Si=(e,t)=>si((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}})),_i=(e,t)=>new Vo((function*(){for(const n of e)t(n),yield n})),Ai=(e,t)=>si((async function*(){for(const n of e)await t(n),yield n})),Ci=(e,t)=>{if(t<0)throw new Bo("index");let n=0;for(const r of e)if(t===n++)return r;throw new Bo("index")},Di=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},Ti=(e,t,n=Wo)=>new Vo((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)}})),ki=(e,t,n)=>si((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)}})),Gi=(e,t)=>t?Ni(e,t):bi(e),bi=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new $o(Lo.NoElements);return t.value},Ni=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new $o(Lo.NoMatch)},Ei=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new $o(Lo.NoMatch)},Ii=(e,t)=>t?Pi(e,t):Ri(e),Ri=e=>e[Symbol.iterator]().next().value??null,Pi=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},Oi=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class Ui extends jo{key;constructor(e,t){super(1),this.key=e,this[0]=t}}const Mi=(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 Ui(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 Ui(e,r)}for(const e in n)yield n[e]})(e,t),new Vo(r)},xi=(e,t,n)=>n?Bi(e,t,n):Fi(e,t),Fi=(e,t)=>si((async function*(){const n={};for(const r of e){const e=await t(r),s=n[e];s?s.push(r):n[e]=new Ui(e,r)}for(const e in n)yield n[e]})),Bi=(e,t,n)=>si((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 Ui(e,s))}for(const e of r)yield e})),Li=(e,t,n,r)=>r?((e,t,n,r)=>new Vo((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 Ui(e,t))}}for(const e of s)yield e})))(e,t,n,r):((e,t,n)=>new Vo((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 Ui(e,i)}for(const e in r)yield r[e]})))(e,t,n),$i=(e,t,n,r,s,o)=>{const i=o?Wi(e,t,n,r,s,o):qi(e,t,n,r,s);return new Vo(i)},Wi=(e,t,n,r,s,o)=>function*(){const i=[];for(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]})}for(const t of e){const e=n(t),r=i.find((t=>o(t.key,e)))??{key:e,values:[]};yield s(t,r.values)}},qi=(e,t,n,r,s)=>function*(){const o=new Map;for(const e of t){const t=r(e),n=o.get(t);n?n.push(e):o.set(t,[e])}for(const t of e){const e=n(t),r=o.get(e)??[];yield s(t,r)}},Hi=(e,t,n,r,s,o)=>{const i=o?Vi(e,t,n,r,s,o):ji(e,t,n,r,s);return si(i)},Vi=(e,t,n,r,s,o)=>async function*(){const i=[];for(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]})}for(const t of e){const e=await n(t),r=i.find((t=>o(t.key,e)))??{key:e,values:[]};yield s(t,r.values)}},ji=(e,t,n,r,s)=>async function*(){const o=new Map;for(const e of t){const t=await r(e),n=o.get(t);n?n.push(e):o.set(t,[e])}for(const t of e){const e=await n(t),r=o.get(e)??[];yield s(t,r)}},Ki=(e,t,n=Wo)=>new Vo((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}}})),zi=(e,t,n)=>si((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}}}})),Ji=(e,t,n,r,s,o=Wo)=>new Vo((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))}}})),Yi=(e,t)=>t?Qi(e,t):Xi(e),Xi=e=>{let t;for(const n of e)t=n;if(!t)throw new $o(Lo.NoElements);return t},Qi=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new $o(Lo.NoMatch);return n},Zi=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new $o(Lo.NoMatch);return n},ea=(e,t)=>t?na(e,t):ta(e),ta=e=>{let t=null;for(const n of e)t=n;return t},na=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},ra=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},sa=(e,t)=>t?ia(e,t):oa(e),oa=e=>{let t=null;for(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new $o(Lo.NoElements);return t},ia=(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new $o(Lo.NoElements);return n},aa=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 $o(Lo.NoElements);return n},ca=(e,t)=>t?la(e,t):ua(e),ua=e=>{let t=null;for(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new $o(Lo.NoElements);return t},la=(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new $o(Lo.NoElements);return n},da=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 $o(Lo.NoElements);return n},ha=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Vo((function*(){for(const t of e)n(t)&&(yield t)}))};async function*pa(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*ga(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 fa extends qo{orderedPairs;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 fa?async function*(){for await(const s of e.orderedPairs())yield*pa(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 fa(s)}static generate(e,t,n,r){let s;return s=e instanceof fa?async function*(){for await(const s of e.orderedPairs())yield*ga(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 fa(s)}thenBy(e,t){return fa.generate(this,e,!0,t)}thenByAsync(e,t){return fa.generateAsync(this,e,!0,t)}thenByDescending(e,t){return fa.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return fa.generateAsync(this,e,!1,t)}}function*va(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*ma(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 ya extends Vo{orderedPairs;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 ya?function*(){for(const s of e.orderedPairs())yield*va(s,t,n,r)}:()=>va(e,t,n,r),new ya(s)}static generateAsync(e,t,n,r){let s;return s=e instanceof ya?async function*(){for(const s of e.orderedPairs())yield*ma(s,t,n,r)}:()=>ma(e,t,n,r),new fa(s)}thenBy(e,t){return ya.generate(this,e,!0,t)}thenByAsync(e,t){return ya.generateAsync(this,e,!0,t)}thenByDescending(e,t){return ya.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return ya.generateAsync(this,e,!1,t)}}const wa=(e,t)=>ya.generate(e,(e=>e),!0,t),Sa=(e,t,n)=>ya.generate(e,t,!0,n),_a=(e,t,n)=>ya.generateAsync(e,t,!0,n),Aa=(e,t,n)=>ya.generate(e,t,!1,n),Ca=(e,t,n)=>ya.generateAsync(e,t,!1,n),Da=(e,t)=>ya.generate(e,(e=>e),!1,t),Ta=(e,t)=>{const n=[],r=[];for(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},ka=async(e,t)=>{const n=[],r=[];for(const s of e)!0===await t(s)?r.push(s):n.push(s);return[r,n]},Ga=(e,t)=>new Vo((function*(){yield t,yield*e})),ba=e=>new Vo((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),Na=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?Ea(e,t):Ia(e,t)}return Ra(e,t)},Ea=(e,t)=>new Vo((function*(){for(const n of e)yield t(n)})),Ia=(e,t)=>new Vo((function*(){let n=0;for(const r of e)yield t(r,n),n++})),Ra=(e,t)=>new Vo((function*(){for(const n of e)yield n[t]})),Pa=(e,t)=>"function"==typeof t?1===t.length?Oa(e,t):Ua(e,t):Ma(e,t),Oa=(e,t)=>si((async function*(){for(const n of e)yield t(n)})),Ua=(e,t)=>si((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),Ma=(e,t)=>si((async function*(){for(const n of e)yield n[t]})),xa=(e,t)=>"function"==typeof t?1===t.length?Fa(e,t):Ba(e,t):La(e,t),Fa=(e,t)=>new Vo((function*(){for(const n of e)for(const e of t(n))yield e})),Ba=(e,t)=>new Vo((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),La=(e,t)=>new Vo((function*(){for(const n of e)for(const e of n[t])yield e})),$a=(e,t)=>1===t.length?Wa(e,t):qa(e,t),Wa=(e,t)=>si((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),qa=(e,t)=>si((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),Ha=(e,t,n=Wo)=>{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},Va=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},ja=(e,t)=>t?za(e,t):Ka(e),Ka=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new $o(Lo.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new $o(Lo.NoElements);return n},za=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new $o(Lo.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new $o(Lo.NoMatch);return r},Ja=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new $o(Lo.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new $o(Lo.NoMatch);return r},Ya=(e,t)=>t?Qa(e,t):Xa(e),Xa=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new $o(Lo.MoreThanOneElement);t=!0,n=r}return n},Qa=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new $o(Lo.MoreThanOneMatchingElement);n=!0,r=s}return r},Za=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new $o(Lo.MoreThanOneElement);n=!0,r=s}return r},ec=(e,t)=>new Vo((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),tc=(e,t)=>1===t.length?nc(e,t):rc(e,t),nc=(e,t)=>new Vo((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),rc=(e,t)=>new Vo((function*(){let n=0,r=!0;for(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),sc=(e,t)=>1===t.length?oc(e,t):ic(e,t),oc=(e,t)=>si((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),ic=(e,t)=>si((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++})),ac=(e,t)=>t?uc(e,t):cc(e),cc=e=>{let t=0;for(const n of e)t+=n;return t},uc=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},lc=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},dc=(e,t)=>new Vo((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),hc=(e,t)=>1===t.length?pc(e,t):gc(e,t),pc=(e,t)=>new Vo((function*(){for(const n of e){if(!t(n))break;yield n}})),gc=(e,t)=>new Vo((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),fc=(e,t)=>1===t.length?vc(e,t):mc(e,t),vc=(e,t)=>si((async function*(){for(const n of e){if(!await t(n))break;yield n}})),mc=(e,t)=>si((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),yc=e=>[...e],wc=(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},Sc=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},_c=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},Ac=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},Cc=e=>new Set(e),Dc=(e,t,n)=>n?kc(e,t,n):Tc(e,t),Tc=(e,t)=>new Vo((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))})),kc=(e,t,n)=>new Vo((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)=>si((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))}})),bc=(e,t)=>1===t.length?Nc(e,t):Ec(e,t),Nc=(e,t)=>new Vo((function*(){for(const n of e)!0===t(n)&&(yield n)})),Ec=(e,t)=>new Vo((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),Ic=(e,t)=>1===t.length?Rc(e,t):Pc(e,t),Rc=(e,t)=>si((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),Pc=(e,t)=>si((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),Oc=(e,t,n)=>n?Mc(e,t,n):Uc(e,t),Uc=(e,t)=>new Vo((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]}})),Mc=(e,t,n)=>new Vo((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)}})),xc=(e,t,n)=>si((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)}})),Fc=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(Ko,"aggregate"),n(Xo,"all"),n(Qo,"allAsync"),n(Zo,"any"),n(ni,"anyAsync"),n(ri,"append"),n(oi,"asAsync"),n(ai,"asParallel"),n(ci,"average"),n(ui,"averageAsync"),n(li,"chunk"),n(di,"concatenate"),n(hi,"contains"),n(pi,"containsAsync"),n(gi,"count"),n(mi,"countAsync"),n(yi,"defaultIfEmpty"),n(wi,"distinct"),n(Si,"distinctAsync"),n(_i,"each"),n(Ai,"eachAsync"),n(Ci,"elementAt"),n(Di,"elementAtOrDefault"),n(Ti,"except"),n(ki,"exceptAsync"),n(Gi,"first"),n(Ei,"firstAsync"),n(Ii,"firstOrDefault"),n(Oi,"firstOrDefaultAsync"),n(Mi,"groupBy"),n(xi,"groupByAsync"),n(Li,"groupByWithSel"),n($i,"groupJoin"),n(Hi,"groupJoinAsync"),n(Ki,"intersect"),n(zi,"intersectAsync"),n(Ji,"joinByKey"),n(Yi,"last"),n(Zi,"lastAsync"),n(ea,"lastOrDefault"),n(ra,"lastOrDefaultAsync"),n(sa,"max"),n(aa,"maxAsync"),n(ca,"min"),n(da,"minAsync"),n(ha,"ofType"),n(wa,"order"),n(Sa,"orderBy"),n(_a,"orderByAsync"),n(Aa,"orderByDescending"),n(Ca,"orderByDescendingAsync"),n(Da,"orderDescending"),n(Ga,"prepend"),n(ba,"reverse"),n(Na,"select"),n(Pa,"selectAsync"),n(xa,"selectMany"),n($a,"selectManyAsync"),n(Ha,"sequenceEquals"),n(Va,"sequenceEqualsAsync"),n(ja,"single"),n(Ja,"singleAsync"),n(Ya,"singleOrDefault"),n(Za,"singleOrDefaultAsync"),n(ec,"skip"),n(tc,"skipWhile"),n(sc,"skipWhileAsync"),n(ac,"sum"),n(lc,"sumAsync"),n(dc,"take"),n(hc,"takeWhile"),n(fc,"takeWhileAsync"),n(yc,"toArray"),n(wc,"toMap"),n(Sc,"toMapAsync"),n(_c,"toObject"),n(Ac,"toObjectAsync"),n(Ta,"partition"),n(ka,"partitionAsync"),n(Cc,"toSet"),n(Dc,"union"),n(Gc,"unionAsync"),n(bc,"where"),n(Ic,"whereAsync"),n(Oc,"zip"),n(xc,"zipAsync")},Bc=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Wc(e,t,n,r)}return n?$c(e,t,n):Lc(e,t)},Lc=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new $o(Lo.NoElements);return n},$c=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},Wc=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},qc=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Hc=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},Vc=(e,t)=>new qo((async function*(){yield*e,yield t})),jc=(e,t)=>t?zc(e,t):Kc(e),Kc=async e=>{for await(const t of e)return!0;return!1},zc=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Jc=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},Yc=e=>ii(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 $o(Lo.NoElements);return n/r},Qc=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 $o(Lo.NoElements);return n/r},Zc=(e,t)=>{if(t<1)throw new Bo("size");return new qo((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},eu=(e,t)=>new qo((async function*(){yield*e,yield*t})),tu=async(e,t,n=Wo)=>{for await(const r of e)if(n(t,r))return!0;return!1},nu=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},ru=(e,t)=>t?ou(e,t):su(e),su=async e=>{let t=0;for await(const n of e)t++;return t},ou=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},iu=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},au=(e,t)=>new qo((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),cu=(e,t=Wo)=>new qo((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),uu=(e,t)=>new qo((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}})),lu=(e,t)=>new qo((async function*(){for await(const n of e)t(n),yield n})),du=(e,t)=>new qo((async function*(){for await(const n of e)await t(n),yield n})),hu=async(e,t)=>{if(t<0)throw new Bo("index");let n=0;for await(const r of e)if(t===n++)return r;throw new Bo("index")},pu=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},gu=(e,t,n=Wo)=>new qo((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)}})),fu=(e,t,n)=>new qo((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)}})),vu=(e,t)=>t?yu(e,t):mu(e),mu=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new $o(Lo.NoElements);return t.value},yu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new $o(Lo.NoMatch)},wu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new $o(Lo.NoMatch)},Su=(e,t)=>t?Au(e,t):_u(e),_u=async e=>(await e[Symbol.asyncIterator]().next()).value??null,Au=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},Cu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},Du=(e,t,n)=>n?Tu(e,t,n):ku(e,t),Tu=(e,t,n)=>new qo((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 Ui(e,s))}for(const e of r)yield e})),ku=(e,t)=>new qo((async function*(){const n={};for await(const r of e){const e=t(r),s=n[e];s?s.push(r):n[e]=new Ui(e,r)}for(const e in n)yield n[e]})),Gu=(e,t,n)=>n?Nu(e,t,n):bu(e,t),bu=(e,t)=>new qo((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 Ui(e,r)}for(const e in n)yield n[e]})),Nu=(e,t,n)=>new qo((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 Ui(e,s))}for(const e of r)yield e})),Eu=(e,t,n,r)=>r?Ru(e,t,n,r):Iu(e,t,n),Iu=(e,t,n)=>new qo((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 Ui(e,i)}for(const e in r)yield r[e]})),Ru=(e,t,n,r)=>new qo((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 Ui(e,t))}}for(const e of s)yield e})),Pu=(e,t,n,r,s,o)=>{const i=o?Ou(e,t,n,r,s,o):Uu(e,t,n,r,s);return new qo(i)},Ou=(e,t,n,r,s,o)=>async function*(){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]})}for await(const t of e){const e=n(t),r=i.find((t=>o(t.key,e)))??{key:e,values:[]};yield s(t,r.values)}},Uu=(e,t,n,r,s)=>async function*(){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])}for await(const t of e){const e=n(t),r=o.get(e)??[];yield s(t,r)}},Mu=(e,t,n,r,s,o)=>{const i=o?xu(e,t,n,r,s,o):Fu(e,t,n,r,s);return new qo(i)},xu=(e,t,n,r,s,o)=>async function*(){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]})}for await(const t of e){const e=await n(t),r=i.find((t=>o(t.key,e)))??{key:e,values:[]};yield s(t,r.values)}},Fu=(e,t,n,r,s)=>async function*(){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])}for await(const t of e){const e=await n(t),r=o.get(e)??[];yield s(t,r)}},Bu=(e,t,n=Wo)=>new qo((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}}}})),Lu=(e,t,n)=>new qo((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}}}})),$u=(e,t,n,r,s,o=Wo)=>new qo((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))}}})),Wu=(e,t)=>t?Hu(e,t):qu(e),qu=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new $o(Lo.NoElements);return t},Hu=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new $o(Lo.NoMatch);return n},Vu=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new $o(Lo.NoMatch);return n},ju=(e,t)=>t?zu(e,t):Ku(e),Ku=async e=>{let t=null;for await(const n of e)t=n;return t},zu=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},Ju=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},Yu=(e,t)=>t?Qu(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 $o(Lo.NoElements);return t},Qu=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 $o(Lo.NoElements);return n},Zu=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 $o(Lo.NoElements);return n},el=(e,t)=>t?nl(e,t):tl(e),tl=async e=>{let t=null;for await(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new $o(Lo.NoElements);return t},nl=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 $o(Lo.NoElements);return n},rl=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 $o(Lo.NoElements);return n},sl=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new qo((async function*(){for await(const t of e)n(t)&&(yield t)}))},ol=(e,t)=>fa.generate(e,(e=>e),!0,t),il=(e,t,n)=>fa.generate(e,t,!0,n),al=(e,t,n)=>fa.generateAsync(e,t,!0,n),cl=(e,t,n)=>fa.generate(e,t,!1,n),ul=(e,t,n)=>fa.generateAsync(e,t,!1,n),ll=(e,t)=>fa.generate(e,(e=>e),!1,t),dl=async(e,t)=>{const n=[],r=[];for await(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},hl=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]},pl=(e,t)=>new qo((async function*(){yield t,yield*e})),gl=e=>new qo((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]})),fl=(e,t)=>"function"==typeof t?1===t.length?vl(e,t):ml(e,t):yl(e,t),vl=(e,t)=>new qo((async function*(){for await(const n of e)yield t(n)})),ml=(e,t)=>new qo((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),yl=(e,t)=>new qo((async function*(){for await(const n of e)yield n[t]})),wl=(e,t)=>"string"==typeof t?_l(e,t):Sl(e,t),Sl=(e,t)=>new qo((async function*(){for await(const n of e)yield t(n)})),_l=(e,t)=>new qo((async function*(){for await(const n of e)yield n[t]})),Al=(e,t)=>"function"==typeof t?1===t.length?Cl(e,t):Dl(e,t):Tl(e,t),Cl=(e,t)=>new qo((async function*(){for await(const n of e)for(const e of t(n))yield e})),Dl=(e,t)=>new qo((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),Tl=(e,t)=>new qo((async function*(){for await(const n of e)for(const e of n[t])yield e})),kl=(e,t)=>1===t.length?new qo((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new qo((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++}})),Gl=async(e,t,n=Wo)=>{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},bl=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},Nl=(e,t)=>t?Il(e,t):El(e),El=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new $o(Lo.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new $o(Lo.NoElements);return n},Il=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new $o(Lo.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new $o(Lo.NoMatch);return r},Rl=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new $o(Lo.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new $o(Lo.NoMatch);return r},Pl=(e,t)=>t?Ul(e,t):Ol(e),Ol=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new $o(Lo.MoreThanOneElement);t=!0,n=r}return n},Ul=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new $o(Lo.MoreThanOneMatchingElement);n=!0,r=s}return r},Ml=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new $o(Lo.MoreThanOneMatchingElement);n=!0,r=s}return r},xl=(e,t)=>new qo((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),Fl=(e,t)=>1===t.length?Bl(e,t):Ll(e,t),Bl=(e,t)=>new qo((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Ll=(e,t)=>new qo((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++})),$l=(e,t)=>1===t.length?Wl(e,t):ql(e,t),Wl=(e,t)=>new qo((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),ql=(e,t)=>new qo((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++})),Hl=(e,t)=>t?jl(e,t):Vl(e),Vl=async e=>{let t=0;for await(const n of e)t+=n;return t},jl=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},Kl=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},zl=(e,t)=>new qo((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),Jl=(e,t)=>1===t.length?Yl(e,t):Xl(e,t),Yl=(e,t)=>new qo((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Xl=(e,t)=>new qo((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),Ql=(e,t)=>1===t.length?Zl(e,t):ed(e,t),Zl=(e,t)=>new qo((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),ed=(e,t)=>new qo((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),td=async e=>{const t=[];for await(const n of e)t.push(n);return t},nd=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},rd=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},sd=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},od=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},id=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},ad=(e,t,n)=>n?ud(e,t,n):cd(e,t),cd=(e,t)=>new qo((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))})),ud=(e,t,n)=>new qo((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))}})),ld=(e,t,n)=>new qo((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))}})),dd=(e,t)=>1===t.length?hd(e,t):pd(e,t),hd=(e,t)=>new qo((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),pd=(e,t)=>new qo((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),gd=(e,t)=>1===t.length?fd(e,t):vd(e,t),fd=(e,t)=>new qo((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),vd=(e,t)=>new qo((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),md=(e,t,n)=>n?wd(e,t,n):yd(e,t),yd=(e,t)=>new qo((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]}})),wd=(e,t,n)=>new qo((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 qo((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)}})),_d=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Dd(e,t,n,r)}return n?Cd(e,t,n):Ad(e,t)},Ad=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new $o(Lo.NoElements);return n},Cd=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},Dd=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},Td=(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}}},kd=(e,t)=>{const n=Td(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))}},Gd=(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}}},bd=(e,t)=>{const n=Gd(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))}},Nd=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ho({generator:()=>{const e=n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 2:return new Ho({generator:async()=>{const e=await n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 0:return new Ho({generator:async()=>{const e=await n.generator();return e.push(t),e},type:n.type})}},Ed=(e,t)=>t?Rd(e,t):Id(e),Id=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}},Rd=async(e,t)=>{const n=Td(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)}},Pd=async(e,t)=>{const n=Gd(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)}},Od=e=>si((async function*(){for await(const t of e)yield t})),Ud=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)}},Md=async(e,t)=>{let n;n=t?Td(e,t):e.dataFunc;const r=await Ud(n);if(0===r.length)throw new $o(Lo.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},xd=async(e,t)=>{const n=Gd(e,t),r=await Ud(n);if(0===r.length)throw new $o(Lo.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},Fd=(e,t)=>{if(t<1)throw new Bo("size");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 Ho(n)},Bd=(e,t)=>new Ho({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),Ld=async(e,t,n=Wo)=>{let r;switch(r=Td(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))}},$d=async(e,t,n)=>{const r=Gd(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))}},Wd=(e,t)=>t?Hd(e,t):qd(e),qd=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},Hd=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},Vd=async(e,t)=>{const n=Gd(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},jd=(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 Ho(s)},Kd=(e,t=Wo)=>new Ho({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),zd=(e,t)=>new Ho({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}),Jd=(e,t)=>new Ho(Td(e,(e=>(t(e),e)))),Yd=(e,t)=>{const n=Gd(e,(async e=>(await t(e),e)));return new Ho(n)},Xd=async(e,t)=>{if(t<0)throw new Bo("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new Bo("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new Bo("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new Bo("index");return await e[t]}}},Qd=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]}}},Zd=(e,t,n=Wo)=>new Ho({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}),eh=(e,t,n)=>new Ho({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}),th=e=>Ud(e.dataFunc),nh=(e,t)=>t?sh(e,t):rh(e),rh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new $o(Lo.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new $o(Lo.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new $o(Lo.NoElements);return await e[0]}}},sh=async(e,t)=>{const n=await th(e);for(const e of n)if(!0===t(e))return e;throw new $o(Lo.NoMatch)},oh=async(e,t)=>{const n=await th(e);for(const e of n)if(!0===await t(e))return e;throw new $o(Lo.NoMatch)},ih=(e,t)=>t?ch(e,t):ah(e),ah=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]}}},ch=async(e,t)=>{const n=await th(e);for(const e of n)if(!0===t(e))return e;return null},uh=async(e,t)=>{const n=await th(e);for(const e of n)if(!0===await t(e))return e;return null},lh=(e,t,n)=>n?hh(e,t,n):dh(e,t),dh=(e,t)=>new Ho({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 Ui(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),hh=(e,t,n)=>new Ho({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 Ui(e,s))}const s=new Array;for(const e of r)s.push(e);return s},type:0}),ph=(e,t,n)=>n?gh(e,t,n):fh(e,t),gh=(e,t,n)=>new Ho({generator:async()=>{const r=Gd(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 Ui(e,t))}const i=new Array;for(const e of o)i.push(e);return i},type:0}),fh=(e,t)=>new Ho({generator:async()=>{const n=Gd(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 Ui(e,t)}const o=new Array;for(const e in s)o.push(s[e]);return o},type:0}),vh=(e,t,n,r)=>r?mh(e,t,n,r):yh(e,t,n),mh=(e,t,n,r)=>new Ho({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 Ui(e,t))}}const o=new Array;for(const e of s)o.push(e);return o},type:0}),yh=(e,t,n)=>new Ho({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 Ui(e,i)}const s=new Array;for(const e in r)s.push(r[e]);return s},type:0}),wh=(e,t,n,r,s,o)=>{const i=o?Sh(e,t,n,r,s,o):_h(e,t,n,r,s);return new Ho({generator:i,type:0})},Sh=(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=>{const t=n(e),r=i.find((e=>o(e.key,t)))??{key:t,values:[]};return s(e,r.values)}))},_h=(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=>{const t=n(e),r=o.get(t)??[];return s(e,r)}))},Ah=(e,t,n,r,s,o)=>{const i=o?Ch(e,t,n,r,s,o):Dh(e,t,n,r,s);return new Ho({generator:i,type:0})},Ch=(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=>{const t=await n(e),r=i.find((e=>o(e.key,t)))??{key:t,values:[]};return s(e,r.values)}));return await Promise.all(a)},Dh=(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=>{const t=await n(e),r=o.get(t)??[];return s(e,r)}));return await Promise.all(i)},Th=(e,t,n=Wo)=>new Ho({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}),kh=(e,t,n)=>new Ho({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}),Gh=(e,t,n,r,s,o=Wo)=>new Ho({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}),bh=(e,t)=>t?Eh(e,t):Nh(e),Nh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new $o(Lo.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new $o(Lo.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new $o(Lo.NoElements);return await e[e.length-1]}}},Eh=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 $o(Lo.NoMatch)},Ih=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 $o(Lo.NoMatch)},Rh=(e,t)=>t?Oh(e,t):Ph(e),Ph=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]}}},Oh=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},Uh=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},Mh=async(e,t)=>{let n;n=t?Td(e,t):e.dataFunc;const r=await Ud(n);if(0===r.length)throw new $o(Lo.NoElements);return Math.max.apply(null,r)},xh=async(e,t)=>{const n=Gd(e,t),r=await Ud(n);if(0===r.length)throw new $o(Lo.NoElements);return Math.max.apply(null,r)},Fh=async(e,t)=>{let n;n=t?Td(e,t):e.dataFunc;const r=await Ud(n);if(0===r.length)throw new $o(Lo.NoElements);return Math.min.apply(null,r)},Bh=async(e,t)=>{const n=Gd(e,t),r=await Ud(n);if(0===r.length)throw new $o(Lo.NoElements);return Math.min.apply(null,r)},Lh=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Ho({generator:async()=>{const t=Td(e,n),r=await Ud(t),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0})};async function*$h(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*Wh(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 qh extends Ho{orderedPairs;constructor(e){super({generator:async()=>{const t=e(),n=[];for await(const e of t)n.push(...e);return n},type:0}),this.orderedPairs=e}static generateAsync(e,t,n,r){let s;return s=e instanceof qh?async function*(){for await(const s of e.orderedPairs())yield*$h(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 qh(s)}static generate(e,t,n,r){let s;return s=e instanceof qh?async function*(){for await(const s of e.orderedPairs())yield*Wh(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 qh(s)}thenBy(e,t){return qh.generate(this,e,!0,t)}thenByAsync(e,t){return qh.generateAsync(this,e,!0,t)}thenByDescending(e,t){return qh.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return qh.generateAsync(this,e,!1,t)}}const Hh=(e,t)=>qh.generate(e,(e=>e),!0,t),Vh=(e,t,n)=>qh.generate(e,t,!0,n),jh=(e,t,n)=>qh.generateAsync(e,t,!0,n),Kh=(e,t,n)=>qh.generate(e,t,!1,n),zh=(e,t,n)=>qh.generateAsync(e,t,!1,n),Jh=(e,t)=>qh.generate(e,(e=>e),!1,t),Yh=async(e,t)=>{const n=Td(e,(e=>[t(e),e])),r=await Ud(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Xh=async(e,t)=>{const n=Gd(e,(async e=>[await t(e),e])),r=await Ud(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Qh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ho({generator:()=>{const e=n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 2:return new Ho({generator:async()=>{const e=await n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 0:return new Ho({generator:async()=>{const e=await n.generator();return e.unshift(t),e},type:n.type})}},Zh=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Ho({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Ho({generator:async()=>(await t.generator()).reverse(),type:t.type})}},ep=(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}}},tp=(e,t)=>"function"==typeof t?1===t.length?new Ho(Td(e,t)):new Ho(ep(e,t)):new Ho(Td(e,(e=>e[t]))),np=(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}}},rp=(e,t)=>{let n;return n="function"==typeof t?1===t.length?Gd(e,t):np(e,t):Gd(e,(e=>e[t])),new Ho(n)},sp=(e,t)=>new Ho({generator:async()=>{let n;n="function"==typeof t?1===t.length?Td(e,t):ep(e,t):Td(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}),op=(e,t)=>new Ho({generator:async()=>{let n;n=1===t.length?Gd(e,t):np(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}),ip=async(e,t,n=Wo)=>{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},ap=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},cp=(e,t)=>t?lp(e,t):up(e),up=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new $o(Lo.MoreThanOneElement);if(0===e.length)throw new $o(Lo.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new $o(Lo.MoreThanOneElement);if(0===e.length)throw new $o(Lo.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new $o(Lo.MoreThanOneElement);if(0===e.length)throw new $o(Lo.NoElements);return await e[0]}}},lp=async(e,t)=>{const n=await th(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new $o(Lo.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new $o(Lo.NoMatch);return s},dp=async(e,t)=>{const n=await th(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new $o(Lo.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new $o(Lo.NoMatch);return s},hp=(e,t)=>t?gp(e,t):pp(e),pp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new $o(Lo.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new $o(Lo.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new $o(Lo.MoreThanOneElement);return 0===e.length?null:await e[0]}}},gp=async(e,t)=>{const n=await th(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new $o(Lo.MoreThanOneElement);r=!0,s=e}return s},fp=async(e,t)=>{const n=await th(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new $o(Lo.MoreThanOneElement);r=!0,s=e}return s},vp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Ho({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Ho({generator:()=>n.generator().slice(t),type:1});case 2:return new Ho({generator:async()=>(await n.generator()).slice(t),type:2})}},mp=(e,t)=>new Ho({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}),yp=(e,t)=>new Ho({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}),wp=(e,t)=>t?_p(e,t):Sp(e),Sp=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},_p=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},Ap=async(e,t)=>{const n=Gd(e,t),r=await Ud(n);let s=0;for(const e of r)s+=e;return s},Cp=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new Ho({generator:()=>r.generator().splice(0,n),type:1});case 2:return new Ho({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new Ho({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},Dp=(e,t)=>new Ho({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}),Tp=(e,t)=>new Ho({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}),kp=async(e,t)=>{const n=new Map,r=Td(e,(e=>[t(e),e])),s=await Ud(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},Gp=async(e,t)=>{const n=new Map,r=Gd(e,(async e=>[await t(e),e])),s=await Ud(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},bp=async(e,t)=>{const n=e.dataFunc,r=await Ud(n),s={};for(const e of r)s[t(e)]=e;return s},Np=async(e,t)=>{const n=Gd(e,(async e=>[await t(e),e])),r=await Ud(n),s={};for(const[e,t]of r)s[e]=t;return s},Ep=async e=>{const t=e.dataFunc,n=await Ud(t);return new Set(n)},Ip=(e,t,n)=>n?Pp(e,t,n):Rp(e,t),Rp=(e,t)=>new Ho({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 Ho({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}),Op=(e,t,n)=>new Ho({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}),Up=(e,t)=>new Ho({generator:async()=>(await e.toArray()).filter(t),type:0}),Mp=(e,t)=>new Ho({generator:async()=>{const n=np(e,(async(e,n)=>[await t(e,n),e])),r=await Ud(n),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0}),xp=(e,t,n)=>n?Bp(e,t,n):Fp(e,t),Fp=(e,t)=>new Ho({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}),Bp=(e,t,n)=>new Ho({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}),Lp=(e,t,n)=>new Ho({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=>{const t=jo.prototype,n=e.prototype,r=Object.getOwnPropertyNames(t);for(const e of r)n[e]=n[e]??t[e]};Fc(Vo),(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(Bc,"aggregate"),n(qc,"all"),n(Hc,"allAsync"),n(Vc,"append"),n(jc,"any"),n(Jc,"anyAsync"),n(Yc,"asParallel"),n(Xc,"average"),n(Qc,"averageAsync"),n(Zc,"chunk"),n(eu,"concatenate"),n(tu,"contains"),n(nu,"containsAsync"),n(ru,"count"),n(iu,"countAsync"),n(au,"defaultIfEmpty"),n(cu,"distinct"),n(uu,"distinctAsync"),n(lu,"each"),n(du,"eachAsync"),n(hu,"elementAt"),n(pu,"elementAtOrDefault"),n(gu,"except"),n(fu,"exceptAsync"),n(vu,"first"),n(wu,"firstAsync"),n(Su,"firstOrDefault"),n(Cu,"firstOrDefaultAsync"),n(Du,"groupBy"),n(Gu,"groupByAsync"),n(Eu,"groupByWithSel"),n(Pu,"groupJoin"),n(Mu,"groupJoinAsync"),n(Bu,"intersect"),n(Lu,"intersectAsync"),n($u,"joinByKey"),n(Wu,"last"),n(Vu,"lastAsync"),n(ju,"lastOrDefault"),n(Ju,"lastOrDefaultAsync"),n(Yu,"max"),n(Zu,"maxAsync"),n(el,"min"),n(rl,"minAsync"),n(sl,"ofType"),n(ol,"order"),n(il,"orderBy"),n(al,"orderByAsync"),n(cl,"orderByDescending"),n(ul,"orderByDescendingAsync"),n(ll,"orderDescending"),n(dl,"partition"),n(hl,"partitionAsync"),n(pl,"prepend"),n(gl,"reverse"),n(fl,"select"),n(wl,"selectAsync"),n(Al,"selectMany"),n(kl,"selectManyAsync"),n(Gl,"sequenceEquals"),n(bl,"sequenceEqualsAsync"),n(Nl,"single"),n(Rl,"singleAsync"),n(Pl,"singleOrDefault"),n(Ml,"singleOrDefaultAsync"),n(xl,"skip"),n(Fl,"skipWhile"),n($l,"skipWhileAsync"),n(Hl,"sum"),n(Kl,"sumAsync"),n(zl,"take"),n(Jl,"takeWhile"),n(Ql,"takeWhileAsync"),n(td,"toArray"),n(nd,"toMap"),n(rd,"toMapAsync"),n(sd,"toObject"),n(od,"toObjectAsync"),n(id,"toSet"),n(ad,"union"),n(ld,"unionAsync"),n(dd,"where"),n(gd,"whereAsync"),n(md,"zip"),n(Sd,"zipAsync")})(qo),(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(_d,"aggregate"),n(kd,"all"),n(bd,"allAsync"),n(Nd,"append"),n(Ed,"any"),n(Pd,"anyAsync"),n(Od,"asAsync"),n(Md,"average"),n(xd,"averageAsync"),n(Fd,"chunk"),n(Bd,"concatenate"),n(Ld,"contains"),n($d,"containsAsync"),n(Wd,"count"),n(Vd,"countAsync"),n(jd,"defaultIfEmpty"),n(Kd,"distinct"),n(zd,"distinctAsync"),n(Jd,"each"),n(Yd,"eachAsync"),n(Xd,"elementAt"),n(Qd,"elementAtOrDefault"),n(Zd,"except"),n(eh,"exceptAsync"),n(nh,"first"),n(oh,"firstAsync"),n(ih,"firstOrDefault"),n(uh,"firstOrDefaultAsync"),n(lh,"groupBy"),n(ph,"groupByAsync"),n(vh,"groupByWithSel"),n(wh,"groupJoin"),n(Ah,"groupJoinAsync"),n(wh,"groupJoin"),n(Ah,"groupJoinAsync"),n(Th,"intersect"),n(kh,"intersectAsync"),n(Gh,"joinByKey"),n(bh,"last"),n(Ih,"lastAsync"),n(Rh,"lastOrDefault"),n(Uh,"lastOrDefaultAsync"),n(Mh,"max"),n(xh,"maxAsync"),n(Fh,"min"),n(Bh,"minAsync"),n(Lh,"ofType"),n(Hh,"order"),n(Vh,"orderBy"),n(jh,"orderByAsync"),n(Kh,"orderByDescending"),n(zh,"orderByDescendingAsync"),n(Jh,"orderDescending"),n(Yh,"partition"),n(Xh,"partitionAsync"),n(Qh,"prepend"),n(Zh,"reverse"),n(tp,"select"),n(rp,"selectAsync"),n(sp,"selectMany"),n(op,"selectManyAsync"),n(ip,"sequenceEquals"),n(ap,"sequenceEqualsAsync"),n(cp,"single"),n(dp,"singleAsync"),n(hp,"singleOrDefault"),n(fp,"singleOrDefaultAsync"),n(vp,"skip"),n(mp,"skipWhile"),n(yp,"skipWhileAsync"),n(wp,"sum"),n(Ap,"sumAsync"),n(Cp,"take"),n(Dp,"takeWhile"),n(Tp,"takeWhileAsync"),n(th,"toArray"),n(kp,"toMap"),n(Gp,"toMapAsync"),n(bp,"toObject"),n(Np,"toObjectAsync"),n(Ep,"toSet"),n(Ip,"union"),n(Op,"unionAsync"),n(Up,"where"),n(Mp,"whereAsync"),n(xp,"zip"),n(Lp,"zipAsync")})(Ho),(()=>{const{prototype:e}=jo,t=Object.getOwnPropertyNames(Vo.prototype);for(const n of t)e[n]=e[n]??Vo.prototype[n];e.all=function(e){return this.every(e)},e.any=function(e){return e?this.some(e):0!==this.length},e.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},e.elementAt=function(e){if(e<0||e>=this.length)throw new Bo("index");return this[e]},e.elementAtOrDefault=function(e){return this[e]??null},e.first=function(e){if(e){const t=this.find(e);if(void 0===t)throw new $o(Lo.NoMatch);return t}if(0===this.length)throw new $o(Lo.NoElements);return this[0]},e.firstOrDefault=function(e){if(e){const t=this.find(e);return void 0===t?null:t}return 0===this.length?null:this[0]},e.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new $o(Lo.NoMatch)}if(0===this.length)throw new $o(Lo.NoElements);return this[this.length-1]},e.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},e.max=function(e){if(0===this.length)throw new $o(Lo.NoElements);if(e){let t=Number.NEGATIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.max(e(this[n]),t);return t}return Math.max.apply(null,this)},e.min=function(e){if(0===this.length)throw new $o(Lo.NoElements);if(e){let t=Number.POSITIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.min(e(this[n]),t);return t}return Math.min.apply(null,this)},e.reverse=function(){return Array.prototype.reverse.apply(this),this}})();var Wp,qp;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(Wp||(Wp={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(qp||(qp={}));class Hp{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==Hp._devicesService&&(Hp._devicesService=bv.Get(So.ServiceName))}GetDevicesChannelsInGroupAsync(){return e=this,t=arguments,s=function*(e=!1){let t=[],n=[];const s=yield Hp._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){bv.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((n=void 0)||(n=Promise))((function(r,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(e){var t;e.done?r(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((s=s.apply(e,t||[])).next())}));var e,t,n,s}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 bv.Get(Kp.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return bv.Get(Kp.ServiceName).ChangeGroupIconNameAsync(this,e)}}var Vp,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 Kp{constructor(){this._connection=null,this._synchronized=!1,this._synchronizationTaskCompletionSource=null,this._groups=[],this._objectsGroupingSupported=!1,this._connection=bv.Get(Pt.ServiceName),this._synchronizationTaskCompletionSource=new Promise((e=>{bv.Get(Ke.ServiceName).OnUserLoggedInEvent().Subscribe((t=>jp(this,void 0,void 0,(function*(){yield this.GetGroupsAsync(!0),e(),this._synchronized=!0}))))}))}SetObjectsInGroupAndOrderAsync(e,t){return jp(this,void 0,void 0,(function*(){var n;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 Yp(e,s),15e3,!1);switch(bv.Get(Ge.ServiceName).ClearCache(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null==o?void 0:o.Status){case ce.OK:return new Te(Wp.Success,"");case ce.NotSupportedMethod:case ce.ResourceDoesNotExists:case ce.ResourceIsNotAvailable:return new Te(Wp.FunctionNotSupported,"");case ce.WrongData:return"GroupDoesNotExists"===o.Data?new Te(Wp.GroupDoesNotExists,o.Data):new Te(Wp.FatalError,o.Data);case ce.Error:case ce.FatalError:default:return new Te(Wp.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=bv.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=bv.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){return jp(this,void 0,void 0,(function*(){var t;const n=e.select((e=>e.Guid)).toArray(),s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Jp(n),15e3,!1);return bv.Get(st.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ce.OK?(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),ce.OK):(bv.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){return jp(this,void 0,void 0,(function*(){var n;const s=t.select((e=>e.ChannelId)).toArray(),o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new eg(e.Guid,s),15e3,!1);return bv.Get(st.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ce.OK?(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync(),ce.OK):(bv.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){return jp(this,void 0,void 0,(function*(){var n;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new zp(e.Guid,t),15e3,!1);return bv.Get(st.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ce.OK?(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),ce.OK):(bv.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){return jp(this,void 0,void 0,(function*(){var s;const o=`${t.GetDevice().Guid}_${t.Number}`,i=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Zp(e.Guid,o,n),15e3,!1);return bv.Get(st.ServiceName).ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ce.OK?(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync(),ce.OK):(bv.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){return jp(this,void 0,void 0,(function*(){var n,s;const o=new ig;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 bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status?(i.Status==ce.OK?e.ChannelGroups.push(t):bv.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}`),bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync(),i.Status):(yield this.GetGroupsAsync(),ce.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){return jp(this,void 0,void 0,(function*(){var n,s;const o=new ag;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 bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status?(i.Status==ce.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():bv.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}`),bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync(),i.Status):(yield this.GetGroupsAsync(),ce.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return jp(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 Hp))return t instanceof Te?t:new Te(qp.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(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync(),t!==ce.OK)return bv.Get(r.ServiceName).Error(Kp.ServiceName,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`),new Te(qp.UnknownError,`Failed to add device channel ${n.Name} to group ${e.Name}, controller responded with error ${t}`)}let n=yield bv.Get(So.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(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(),t!==ce.OK)return bv.Get(r.ServiceName).Error(Kp.ServiceName,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),new Te(qp.UnknownError,`Failed to remove device channel ${n.Name} from group ${e.Name}, controller responded with error ${t}`)}return bv.Get(st.ServiceName).ExitConfigurationModeAsync(),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return jp(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(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(),t!==ce.OK)return bv.Get(r.ServiceName).Error(Kp.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),ce.FatalError}let n=yield bv.Get(So.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(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync(),t!==ce.OK)return bv.Get(r.ServiceName).Error(Kp.ServiceName,`Failed to add device channel ${n.Name} to group ${e}, controller responded with error ${t}`),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),ce.FatalError}return bv.Get(st.ServiceName).ExitConfigurationModeAsync(),ce.OK}))}ChangeGroupNameByGuidAsync(e,t){return jp(this,void 0,void 0,(function*(){var n,r;let s=new og,o=new cg,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(bv.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return new Te(qp.Success,"");case ce.WrongData:switch(a.Data){case"NameToShort":return new Te(qp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(qp.NameAlreadyExists,"Group with this name already exists");default:return new Te(qp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(qp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(qp.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){return jp(this,void 0,void 0,(function*(){var r,s;let o=new og,i=new cg,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(bv.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null!=c&&null!=c.Status)switch(c.Status){case ce.OK:return new Te(qp.Success,"");case ce.WrongData:switch(c.Data){case"NameToShort":return new Te(qp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(qp.NameAlreadyExists,"Group with this name already exists");default:return new Te(qp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new Te(qp.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new Te(qp.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){return jp(this,void 0,void 0,(function*(){var n,r;let s=new og,o=new cg,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(bv.Get(Ge.ServiceName).ClearCache(),this._groups=yield this.GetGroupsAsync(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return new Te(qp.Success,"");case ce.WrongData:switch(a.Data){case"NameToShort":return new Te(qp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(qp.NameAlreadyExists,"Group with this name already exists");default:return new Te(qp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(qp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(qp.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){return jp(this,void 0,void 0,(function*(){var t;let n=new rg;n.Data=e;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync();for(let t of yield bv.Get(So.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 bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null!=r&&null!=r.Status?null==r?void 0:r.Status:ce.Error}))}GetGroupsAsync(){return jp(this,arguments,void 0,(function*(e=!1){var t,n;const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new sg,15e3,e);let o=[];if((null==s?void 0:s.Status)===ce.OK){let e=bv.Get(r.ServiceName),t=0,i=yield bv.Get(So.ServiceName).GetDevicesAsync();return null===(n=s.Data)||void 0===n||n.forEach((n=>{t++;let r=new Hp;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){return jp(this,void 0,void 0,(function*(){var t,n;let s=new og,o=new cg;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(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null!=i&&null!=i.Status)switch(i.Status){case ce.OK:return this._groups.first((t=>t.Name===e));case ce.WrongData:switch(bv.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(qp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(qp.NameAlreadyExists,"Group with this name already exists");default:return new Te(qp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Te(qp.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Te(qp.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){return jp(this,void 0,void 0,(function*(){var n,s;let o=new og,i=new cg;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(bv.Get(Ge.ServiceName).ClearCache(),yield this.GetGroupsAsync(!1),yield bv.Get(So.ServiceName).GetDevicesAsync(),bv.Get(st.ServiceName).ExitConfigurationModeAsync(),null!=a&&null!=a.Status)switch(a.Status){case ce.OK:return this._groups.first((t=>t.Name===e));case ce.WrongData:switch(bv.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(qp.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Te(qp.NameAlreadyExists,"Group with this name already exists");default:return new Te(qp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Te(qp.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Te(qp.UnknownError,"")}))}}Kp.ServiceName="ChannelsGroupsService";class zp extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=ue.Post,this.Data=new Qp,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class Jp extends ae{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=ue.Post,this.Data=e}}class Yp extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=ue.Post,this.Data=new Xp,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Xp{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Qp{constructor(){this.GroupGuid="",this.NewPosition=0}}class Zp extends ae{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=ue.Post,this.Data=new tg,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class eg extends ae{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=ue.Post,this.Data=new ng,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class tg{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class ng{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class rg extends ae{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ue.Delete}}class sg extends ae{constructor(){super(),this.Resource="/devices/groups/",this.Method=ue.Get}}class og extends ae{constructor(){super(),this.Resource="/devices/groups/group",this.Method=ue.Put,this.Data=[]}}class ig extends ae{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ue.Put,this.Data=new ug}}class ag extends ae{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=ue.Delete,this.Data=new ug}}class cg{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class ug{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class lg{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"}(Vp||(Vp={}));var 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._syncLock=new lg,this._isInFouces=!0,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=Vp.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new Ce,this._onSuspendedEvent=new Ce,this._onEnterLowPowerModeEvent=new Ce,this._onExitLowPowerModeEvent=new Ce,this._onBackButtonPressedEvent=new Ce,this._onForwardButtonPressedEvent=new Ce,this._onAppStateChanged=new n,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices?window.addEventListener("visibilitychange",(()=>pg(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(gg.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=s.Log)||void 0===r||r.Warning(gg.ServiceName,"Back button pressed"),null===(o=this._onBackButtonPressedEvent)||void 0===o||o.Invoke()))}))}MonitorAppState(){return pg(this,void 0,void 0,(function*(){this._session=yield bv.GetAsync("SessionService"),this._connection=yield bv.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=s.Log)||void 0===t||t.Warning(gg.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(Vp.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=s.Log)||void 0===t||t.Warning(gg.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(Vp.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,r,o,i,a;switch(e){case he.Connected:null===(t=s.Log)||void 0===t||t.Warning(gg.ServiceName,"App state changed to: connected"),this._onAppStateChanged.Invoke(Vp.Connected);break;case he.Disconnected:null===(n=s.Log)||void 0===n||n.Warning(gg.ServiceName,"App state changed to: disconnected"),this._onAppStateChanged.Invoke(Vp.Disconnected);break;case he.Connecting:null===(r=s.Log)||void 0===r||r.Warning(gg.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(Vp.Connecting);break;case he.Disconnecting:null===(o=s.Log)||void 0===o||o.Warning(gg.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(Vp.Disconnecting);break;case he.Reconnecting:null===(i=s.Log)||void 0===i||i.Warning(gg.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(Vp.Reconnecting);break;case he.Failed:null===(a=s.Log)||void 0===a||a.Warning(gg.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(Vp.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(Vp.Suspended),null===(e=s.Log)||void 0===e||e.Warning(gg.ServiceName,"App state changed to: suspended"),null===(t=s.Log)||void 0===t||t.Warning(gg.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(Vp.ReturnedFromSuspension),null===(e=s.Log)||void 0===e||e.Warning(gg.ServiceName,"App state changed to: returned from suspension"),null===(t=s.Log)||void 0===t||t.Warning(gg.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Vp.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(Vp.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 gg.ServiceName}}gg.ServiceName="AppStateService",function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(dg||(dg={}));class fg{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=hg.Unknown,this.ResourceGuid=""}}class vg{constructor(){this.UpdateDescription=new Map,this.Update=new fg,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"}(hg||(hg={}));class mg extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var yg,wg,Sg,_g,Ag,Cg,Dg,Tg,kg,Gg,bg=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 Ng{constructor(){this._services=new Map,this._runtimeInfo=new Eg,this._hardwareInfo=new Rg,this._semaphore=new Xe(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return Ng.ServiceName}RegisterUpdatesProvider(e){bv.Get(r.ServiceName).Debug(Ng.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return bg(this,void 0,void 0,(function*(){bv.Get(r.ServiceName).Debug(Ng.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const t=this._services.get(e);if(null==t)throw new mg("Cannot get update provider! Requested update provider has not been registered.");return t}))}GetUpdatesProvidersAsync(e){return bg(this,void 0,void 0,(function*(){bv.Get(r.ServiceName).Debug(Ng.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 mg("Cannot get update providers! Requested update providers has not been registered.");return t}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return bg(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)){bv.Get(r.ServiceName).Debug(Ng.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 mg("Cannot get update providers! Requested update providers has not been registered.");return s}throw new mg("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return bg(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)){bv.Get(r.ServiceName).Debug(Ng.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 mg("Cannot get update providers! Requested update providers has not been registered.");return s}throw new mg("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(){return bg(this,arguments,void 0,(function*(e=!1){var t=yield this._semaphore.AcquireAsync();return!this._isRuntimeInfoInitialized||e?(yield this.GetRuntimeControllerInfoAsync(),t.Release(),this._runtimeInfo):(t.Release(),this._runtimeInfo)}))}GetRuntimeControllerInfoAsync(){return bg(this,void 0,void 0,(function*(){bv.Get(r.ServiceName).Debug(Ng.ServiceName,"Getting runtime version info from controller.");try{const e=yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(new Ig,16e3,!1);if(null==e||null==e.Status)throw new Og('Cannot get runtime info, controller response result is empty."',yg.EmptyResponse);if(e.Status!=ce.OK)throw new Og(`Cannot get runtime info, controller responded with status ${e.Status}.`,yg.WrongResponseStatus);if(null==e.Data)throw new Og("Cannot get runtime info, controller responded with status OK but response does not contains data.",yg.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof p?new Og("Cannot get runtime info, controller response timeout.",yg.Timeout):e}}))}GetHardwareInfoAsync(){return bg(this,arguments,void 0,(function*(e=!1){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return bg(this,void 0,void 0,(function*(){bv.Get(r.ServiceName).Debug(Ng.ServiceName,"Getting hardware info from controller.");const e=yield bv.Get(Pt.ServiceName).SendAndWaitForResponseAsync(new Pg,8e3,!1);if(null==e||null==e.Status)throw new Og('Cannot get hardware info, controller response result is empty."',yg.EmptyResponse);if(e.Status!=ce.OK)throw new Og(`Cannot get hardware info, controller responded with status ${e.Status}.`,yg.WrongResponseStatus);if(null==e.Data)throw new Og("Cannot get hardware info, controller responded with status OK but response does not contains data.",yg.NoDataInResponse);this._hardwareInfo=e.Data,this._isRuntimeInfoInitialized=!0}))}}Ng.ServiceName="UpdateProvider";class Eg{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class Ig extends ae{constructor(){super(),this.Resource="/controller/software/info",this.Method=ue.Get}}class Rg{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class Pg extends ae{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=ue.Get}}class Og 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"}(yg||(yg={}));class Ug{constructor(){this.DeviceGuid="",this.CurrentVersion="",this.NewVersion=""}}class Mg{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class xg{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class Fg{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(wg||(wg={})),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"}(Sg||(Sg={})),(Gg=_g||(_g={}))[Gg.WaitingForUser=1]="WaitingForUser",Gg[Gg.Downloading=2]="Downloading",Gg[Gg.Unpackaging=3]="Unpackaging",Gg[Gg.CheckingApplicability=4]="CheckingApplicability",Gg[Gg.MigratingData=5]="MigratingData",Gg[Gg.CreatingBackup=6]="CreatingBackup",Gg[Gg.Deploying=7]="Deploying",Gg[Gg.Installing=8]="Installing",Gg[Gg.Removing=9]="Removing",Gg[Gg.Error=10]="Error",Gg[Gg.ReadyToDownload=11]="ReadyToDownload",Gg[Gg.PreparingSystem=12]="PreparingSystem",Gg[Gg.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",Gg[Gg.CheckingIntegrity=14]="CheckingIntegrity",Gg[Gg.UndoingInstallation=15]="UndoingInstallation",Gg[Gg.Installed=16]="Installed",(kg=Ag||(Ag={}))[kg.Ignore=0]="Ignore",kg[kg.Cancel=1]="Cancel",kg[kg.Install=2]="Install";class Bg{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=Sg.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class Lg{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"}(Dg||(Dg={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(Tg||(Tg={}));var $g,Wg,qg,Hg,Vg,jg,Kg,zg,Jg=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 Yg{constructor(){this._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5,this._oldUpdateBuild=56,this._updateOfflineStageTime=8.5,this._updateProviders=bv.Get(Ng.ServiceName),this._logger=bv.Get(r.ServiceName),this._connection=bv.Get(Pt.ServiceName),this._appStateService=bv.Get(gg.ServiceName),this._extensionService=bv.Get(Ze.ServiceName)}GetAutomaticControllerUpdateDownloadStatusAsync(){return Jg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Te(Dg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let r=yield this._connection.SendAndWaitForResponseAsync(new df,1e4,!1);return!(r.Status!=ce.OK||!r.Data)}))}GetServiceName(){return Yg.ServiceName}CheckDeviceVersionAsync(e){return Jg(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield bv.Get(So.ServiceName).GetDevice(e);if(null==t)return new Te(Dg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Te(Dg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,dg.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){return Jg(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield bv.Get(So.ServiceName).GetDevice(e);if(null==t)return new Te(Dg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Te(Dg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,dg.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const s=new Zg;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 bv.Get(So.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(s.IsUpdateSafe=!1),s}))}InstallDeviceUpdateAsync(e,t,n){return Jg(this,arguments,void 0,(function*(e,t,n,r=!1){var s;let o;if("string"==typeof e){const t=yield bv.Get(So.ServiceName).GetDevice(e);if(null==t)return new Te(Dg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);o=t}else o=e;if(null==o.ProtocolGuid)return new Te(Dg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(s=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(o.ProtocolGuid,dg.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,dg.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ce.OK)}))}CheckControllerSoftwareUpdateAvailabilityAsync(){return Jg(this,void 0,void 0,(function*(){const e=bv.Get(Ke.ServiceName).User;if(null==e)return!1;if(""==e.SoftwareVersion||null==e.SoftwareVersion)return!0;const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<=this._oldUpdateVersion&&parseFloat(n)<=this._oldUpdateBuild)return!0;const r=yield this._connection.SendAndWaitForResponseAsync(new af,1e4,!1);if(null==r||r.Status!=ce.OK||null==r.Data)return!1;const[s,o]=r.Data.Update.Version.ContainerSoftwareVersion.toString().split(".");return parseInt(s)>parseInt(t)||parseInt(s)==parseInt(t)&&parseInt(o)>parseInt(n)}))}CheckDevicesUpdatesAvailabilityAsync(){return Jg(this,void 0,void 0,(function*(){const e=yield this._connection.SendAndWaitForResponseAsync(new ff,1e4,!1),t=[];return null==e||(null==e?void 0:e.Status)!=ce.OK||null==(null==e?void 0:e.Data)?[]:(null==e||e.Data.forEach((e=>{if(!e.IsAvailable)return;const n=new Ug;n.DeviceGuid=e.DeviceGuid,n.CurrentVersion=e.CurrentVersion,n.NewVersion=e.NewVersion,t.push(n)})),t)}))}CheckControllerUpdatesAsync(){return Jg(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new Mg,n=yield this.getRuntimeInfoAsync();if(n instanceof Te){const e=new Xg;return e.UpdateType=wg.SoftwareUpdate,e.ResponseResult=n,t.UpdatesNotAvailable.push(e),t}const r=parseInt(n.SoftwareVersion.toString().split(".")[0]),s=parseInt(n.SoftwareVersion.toString().split(".")[1]);try{e=yield this._updateProviders.GetUpdatesProvidersAsync(dg.Controller)}catch(e){if(!(e instanceof mg))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 Xg;s.ResponseResult=r,s.UpdateType=wg.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 Qg;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=wg.RadioUpdate,o.UpdateIdentifier=se.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:wg.RadioUpdate}))}}let o=!0;if(r<=this._oldUpdateVersion&&s<=this._oldUpdateBuild&&(o=!1),o){const e=yield this._connection.SendAndWaitForResponseAsync(new af,15e3,!1);if(null==e||e.Status!=ce.OK&&e.Status!=ce.NoData)throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);if(null!=e.Data){const r=new vg;r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,r.UpdateDescription=ie(e.Data.Update.UpdateDescription),r.UpdatedResourceName=ie(e.Data.Update.UpdateName).get("en-US");const s=new Qg;s.UpdatedResourceName=ie(e.Data.Update.UpdateName),s.UpdateDescription=ie(e.Data.Update.UpdateDescription),s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.NewResourceVersion=`${e.Data.Update.Version.BaseRuntime}.${e.Data.Update.Version.ContainerSoftwareVersion}`,s.UpdateType=wg.SoftwareUpdate,s.UpdateIdentifier=e.Data.Update.Guid,s.UpdateIsDownloading=e.Data.UpdateStep==Hg.DownloadingInstaller||e.Data.UpdateStep==Hg.DownloadingUpdate||e.Data.UpdateStep==Hg.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:Yg.ServiceName,UpdateType:wg.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new cf,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ce.NoData:const r=new Xg;r.UpdateType=wg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Te(Dg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ce.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const s=new vg;s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateDescription=ie(e.Data.UpdateDescription),s.UpdatedResourceName=ie(e.Data.UpdateName).get("en-US");const o=new Qg;o.UpdatedResourceName=ie(e.Data.UpdateName),o.UpdateDescription=ie(e.Data.UpdateDescription),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateType=wg.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:Yg.ServiceName,UpdateType:wg.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 vg;const i=new Xg;switch(i.UpdateType=wg.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(Dg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Te(Dg.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 Qg;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=wg.SoftwareUpdate,e.UpdateIdentifier=se.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:Yg.ServiceName,UpdateType:wg.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 Xg;e.UpdateType=wg.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new Xg;r.UpdateType=wg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Te(Dg.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return Jg(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(dg.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof Te)return t;const n=[];let r;r=new Fg,r.Resource="Controller software",r.Type=wg.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new Fg,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=wg.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 Jg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Te(Dg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new sf,1e4,!1);if(null==r||(null==r?void 0:r.Status)!=ce.OK)return new Te(Dg.CannotGetUpdatesBranch,`Cannot get update branch, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data){case 0:return Tg.Public;case 1:return Tg.Beta;case 2:return Tg.Development;default:return new Te(Dg.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${r.Data}`)}}))}SetControllerUpdateBranchAsync(e){return Jg(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof Te)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);if(n<=this._oldUpdateVersion&&r<=this._oldUpdateBuild)return new Te(Dg.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const s=yield this._connection.SendAndWaitForResponseAsync(new of(e),1e4,!1);return null==s||(null==s?void 0:s.Status)!=ce.OK?new Te(Dg.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==s?void 0:s.Status}`):ce.OK}))}EnableAutomaticControllerUpdateDonwloadAsync(){return Jg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Te(Dg.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new hf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ce.OK?new Te(Dg.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ce.OK}))}DisableAutomaticControllerUpdateDonwloadAsync(){return Jg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Te(Dg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new pf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ce.OK?new Te(Dg.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ce.OK}))}GetControllerUpdatesHistoryAsync(){return Jg(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Te)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<=this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Te(Dg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new gf,1e4,!1);if(null==r)return new Te(Dg.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(r.Status){case ce.OK:return null!=r.Data?r.Data.map((e=>{const t=new xg;return t.UpdatedResourceName=ie(e.UpdateName),t.UpdateDescription=ie(e.UpdateDescription),t.UpdateCreationTime=e.Creationtime,t.UpdateChannel=e.UpdateChannel,t.Version=`${e.Version.BaseRuntime}.${e.Version.ContainerSoftwareVersion}`,t})):new Te(Dg.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ce.NoData:return[];default:return new Te(Dg.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${r.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,s){return Jg(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=parseInt(a.SoftwareVersion.toString().split(".")[0]),u=parseInt(a.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Te(Dg.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=>Jg(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let l=this._controllerUpdates.where((e=>e.UpdateType==wg.RadioUpdate)).toArray(),d=[];this._appStateService.DisallowHibernation();for(let e=0;e<l.length;e++){const t=yield(yield this._updateProviders.GetUpdatesProviderAsync(l[e].ProviderName)).InstallRadioUpdateAsync(l[e],o,n);yield a(5e3),t==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=l[e].UpdateIdentifier))),d.push(t),s[0]++}const h=this._controllerUpdates.find((e=>e.UpdateType==wg.SoftwareUpdate));if(null!=h)if(c<=this._oldUpdateVersion&&u<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(h.Update,o);e==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=h.UpdateIdentifier))),d.push(e),s[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(o,t,r);this._appStateService.AllowHibernation(),e==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),d.push(e),s[0]++}const p=d.where((e=>e instanceof Te)).toArray();if(null!=p&&0!=p.length){let e="";return p.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),new Te(Dg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ce.OK}{let o;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new Te(Dg.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 wg.RadioUpdate:return r?new Te(Dg.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==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),o);case wg.SoftwareUpdate:if(c<=this._oldUpdateVersion&&u<=this._oldUpdateBuild){if(r)return new Te(Dg.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");o=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),o==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else o=yield this.UpdateControllerUsingApiAsync(e,t,r),this._appStateService.AllowHibernation(),o==ce.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)));return o;default:return new Te(Dg.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){return Jg(this,void 0,void 0,(function*(){var n,r,s,o,i,a;switch(e.UpdateType){case hg.Container:case hg.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new ef(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new Bg;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ce.MultiDataResponseStart:r.Status=Sg.PreparingForUpgrade;break;case ce.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(Yg.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case _g.CheckingApplicability:case _g.CheckingIntegrity:case _g.CheckingPackageIntegrity:r.Status=Sg.CheckingPackage;break;case _g.CreatingBackup:case _g.MigratingData:case _g.Removing:r.Status=Sg.MovingData;break;case _g.Deploying:case _g.Installing:r.Status=Sg.Upgrading;break;case _g.Downloading:r.Status=Sg.DownloadingPackage;break;case _g.Error:r.Status=Sg.Error;break;case _g.Installed:r.Status=Sg.Upgraded;break;case _g.PreparingSystem:case _g.ReadyToDownload:r.Status=Sg.PreparingForUpgrade;break;case _g.UndoingInstallation:r.Status=Sg.InstallationStopped;break;case _g.Unpackaging:r.Status=Sg.MovingData;break;case _g.WaitingForUser:r.Status=Sg.Upgrading}break;case ce.MultiDataResponseStop:r.Status=Sg.OK}t(r)}),!1),ce.OK}catch(e){return new Te(Dg.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case hg.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 bv.Get(So.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(Yg.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new Bg;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=Sg.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)=>Jg(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=Sg.Upgraded,t(r),o(ce.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=Sg.Upgraded,t(r),o(ce.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=Sg.Upgraded,t(r),o(ce.OK);else{var e=s;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=Sg.Upgrading,t(r))}s++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new tf(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ce.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Sg.InstallationError,t(r),this._logger.Debug(Yg.ServiceName,`Update failed with error. Update response status: ${d.Status}`),o(new Te(Dg.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(Yg.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Sg.Error,t(r),clearInterval(n),o(new Te(Dg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new Bg;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Sg.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new Te(Dg.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new nf({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ce.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Sg.PreparingForUpgrade,t(n);let r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new rf("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ce.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=Sg.PreparingForUpgrade,t(n),r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new rf(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ce.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Sg.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new rf("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ce.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Sg.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)=>Jg(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=Sg.Upgraded,t(n),o(ce.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=Sg.Upgraded,t(n),o(ce.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=Sg.Upgraded,t(n),o(ce.OK);else{var i=5+r*s;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=Sg.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new rf("/runtime/tmp/update.sh"),12e3,!1)}catch(e){o(new Te(Dg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=Sg.InstallationError,t(n),new Te(Dg.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new rf("/runtime/scripts/restart_all.sh"),12e3,!1),new Te(Dg.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Te(Dg.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Te(Dg.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Te(Dg.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}UpdateControllerUsingApiAsync(e,t,n){return Jg(this,void 0,void 0,(function*(){const r=e=>Jg(this,void 0,void 0,(function*(){return new Promise(((r,s)=>Jg(this,void 0,void 0,(function*(){yield this._connection.SendAndHandleResponseAsync(new uf,this._updateRequestTimeout,(s=>{var o,i,a,c;const u=new Lg;switch(u.UpdatedResourceName=ie(e.Update.UpdateName),s.Status){case ce.MultiDataResponseStart:u.Percentage=0,u.SpeedMbps=0,u.PercentageTotal=0,u.CurrentTask=Cg.DownloadingInstaller,t(u);break;case ce.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 Hg.DownloadingInstaller:u.CurrentTask=Cg.DownloadingInstaller;break;case Hg.DownloadingUpdate:u.CurrentTask=Cg.DownloadingUpdate;break;default:u.CurrentTask=Cg.CheckingUpdate}t(u)}break;case ce.MultiDataResponseStop:if(null!=s.Data)switch(s.Data.UpdateStep){case Hg.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(ce.OK);break;case Hg.UpdateDownloadFailed:u.Percentage=0,u.PercentageTotal=0,u.SpeedMbps=0,u.CurrentTask=Cg.Unknown,t(u),r(new Te(Dg.UpdateDownloadFailed,"Update download failed!"))}}}),!1)}))))})),s=t=>Jg(this,void 0,void 0,(function*(){return new Promise(((n,r)=>Jg(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let s=0;yield this._connection.SendAndHandleResponseAsync(new lf,this._updateRequestTimeout,(o=>{var i,a;const c=new Bg;switch(c.UpdatedResourceName=ie(t.Update.UpdateName),o.Status){case ce.MultiDataResponseStart:c.Status=Sg.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 ce.MultiDataResponse:null!=o.Data&&(c.Status=Sg.Upgrading,c.Percentage=Math.round(o.Data.StepProgressInPercentage),c.PercentageTotal=Math.round(o.Data.UpdateProgressInPercentage),s=o.Data.StepProgressInPercentage,e(c));break;case ce.MultiDataResponseStop:if(null!=o.Data)switch(o.Data.UpdateStep){case Hg.UpdateInstallationFailed:c.Status=Sg.InstallationError,c.Percentage=0,c.PercentageTotal=0,e(c),n(new Te(Dg.CannotProcessUpdate,"Update installation failed!"));break;case Hg.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=Sg.Upgraded,c.Percentage=100,c.PercentageTotal=100,e(c),clearInterval(a),n(ce.OK)):(c.Status=Sg.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 af,1e4,!1);if(null==e||(null==e?void 0:e.Status)!=ce.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 Hg.DownloadingInstaller:case Hg.DownloadingUpdate:case Hg.UpdateDownloaded:return new Te(Dg.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case Hg.InstallingUpdate:case Hg.PreparingUpdate:return new Te(Dg.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield r(e.Data)}}else{const e=yield this._connection.SendAndWaitForResponseAsync(new af,1e4,!1);if(null==e||(null==e?void 0:e.Status)!=ce.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 Hg.DownloadingInstaller:case Hg.DownloadingUpdate:return new Te(Dg.UpdateAlreadyDownloaded,"Update already downloaded, or donwload in progress.");case Hg.InstallingUpdate:case Hg.PreparingUpdate:return new Te(Dg.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case Hg.UpdateDownloaded:return yield s(e.Data);default:var o=yield r(e.Data);return o!=ce.OK?o:yield s(e.Data)}}}))}getRuntimeInfoAsync(){return Jg(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof Og&&e.code==yg.Timeout?new Te(Dg.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new Te(Dg.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}Yg.ServiceName="UpdatesService";class Xg{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class Qg{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 Zg{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 ef extends ae{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=ue.Post,this.Data=e}}!function(e){e[e.Windows=0]="Windows",e[e.Linux=1]="Linux",e[e.Unix=2]="Unix",e[e.OSX=3]="OSX",e[e.Android=4]="Android",e[e.iOS=5]="iOS",e[e.WindowsMobile=6]="WindowsMobile"}($g||($g={})),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"}(Wg||(Wg={})),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"}(qg||(qg={})),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"}(Hg||(Hg={}));class tf extends ae{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=ue.Put,this.Data=e}}class nf extends ae{constructor(e){super(),this.Resource="/users/user/login",this.Method=ue.Put,this.Data=e}}class rf extends ae{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=ue.Post,this.Data=e}}class sf extends ae{constructor(){super(),this.Resource="/updates/branch",this.Method=ue.Get}}class of extends ae{constructor(e){super(),this.Resource="/updates/branch",this.Method=ue.Put,this.Data=e}}class af extends ae{constructor(){super(),this.Resource="/updates/pending",this.Method=ue.Get}}class cf extends ae{constructor(){super(),this.Resource="/updates/check",this.Method=ue.Get}}class uf extends ae{constructor(){super(),this.Resource="/updates/download",this.Method=ue.Post}}class lf extends ae{constructor(){super(),this.Resource="/updates/install",this.Method=ue.Post}}class df extends ae{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=ue.Get}}class hf extends ae{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=ue.Put}}class pf extends ae{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=ue.Put}}class gf extends ae{constructor(){super(),this.Resource="/updates/history",this.Method=ue.Get}}class ff extends ae{constructor(){super(),this.Resource="/updates/devices/availability",this.Method=ue.Get}}!function(e){e.CannotFindDevice="CannotFindDevice",e.ResponseTypeNotSupported="ResponseTypeNotSupported",e.InvalidChannelNumber="InvalidChannelNumber",e.IncorrectLimitValue="IncorrectLimitValue",e.IncorrectOffsetValue="IncorrectOffsetValue",e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.FunctionalityNotSupported="FunctionalityNotSupported"}(Vg||(Vg={})),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"}(jg||(jg={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(Kg||(Kg={}));class vf{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"}(zg||(zg={}));var mf,yf,wf,Sf,_f,Af,Cf,Df=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._connection=null,this._connection=bv.Get(Pt.ServiceName)}GetServiceName(){return Tf.ServiceName}GetStatesByIntervalAsync(e,t,n,r,s,o){return Df(this,arguments,void 0,(function*(e,t,n,r,s,o,i=!1){var a;try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Te(Vg.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 bv.Get(So.ServiceName).GetDevice(e);if(null==t)return new Te(Vg.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(Vg.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(Vg.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new Gf;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 kf(u),2e4,!1);if(null==l)return new Te(Vg.OtherError,"Cannot get state history data - response is null.");switch(l.Status){case ce.WrongData:switch(l.Data){case"IncorrectLimitValue":return new Te(Vg.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Te(Vg.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Te(Vg.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Te(Vg.OtherError,"Cannot get state history data - unknown error!")}case ce.FatalError:return new Te(Vg.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ce.ResourceDoesNotExists:return new Te(Vg.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ce.OK:if(null==l.Data)return new Te(Vg.NoData,"Controller responede with status OK, but response does not contain data!");if(l.Data.AggregateDataList=l.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===_t.MeasuredEnergy){const e=l.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return l.Data.Data=e,l.Data}return l.Data;default:return new Te(Vg.OtherError,`Cannot get state history data - controller responded with response code ${l.Status}`)}}catch(e){return new Te(Vg.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){return Df(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new bf,12e3,!1);return null==t?new Te(Vg.OtherError,"Cannot get available states - response is null."):t.Status!=ce.OK?new Te(Vg.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Te(Vg.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new vf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Te(Vg.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return Df(this,void 0,void 0,(function*(){return!(parseFloat((yield bv.Get(Ng.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion)<=3.42)}))}GetAvailableStatesPerChannelAsync(e,t){return Df(this,void 0,void 0,(function*(){var n;let r;if("string"==typeof e){const t=yield bv.Get(So.ServiceName).GetDevice(e);if(null==t)return new Te(Vg.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 Nf(new Ef(r.Guid,t)),8e3,!1);if(null==s)return new Te(Vg.OtherError,"Cannot get available states - response is null.");switch(s.Status){case ce.ResourceDoesNotExists:switch(s.Data){case"DeviceNotFound":return new Te(Vg.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new Te(Vg.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new Te(Vg.OtherError,"Cannot get available states - unknown error!")}case ce.OK:{if(null==s.Data)return new Te(Vg.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 vf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return s.Data.AvailableStates=e,s.Data}default:return new Te(Vg.OtherError,`Cannot get available states - controller responded with response code ${s.Status}`)}}))}}Tf.ServiceName="StatesHistoryService";class kf extends ae{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=ue.Get,this.Data=e}}class Gf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=jg.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class bf extends ae{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=ue.Get}}class Nf extends ae{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=ue.Get,this.Data=e}}class Ef{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}(Cf=mf||(mf={}))[Cf.User=0]="User",Cf[Cf.Controller=1]="Controller",Cf[Cf.Marketing=2]="Marketing",(Af=yf||(yf={}))[Af.Notification=0]="Notification",Af[Af.Message=1]="Message",Af[Af.Alarm=2]="Alarm",Af[Af.Warning=3]="Warning",Af[Af.Info=4]="Info",(_f=wf||(wf={}))[_f.Other=0]="Other",_f[_f.UserLoggedIn=1]="UserLoggedIn",_f[_f.UserLoggedOut=2]="UserLoggedOut",_f[_f.FoundNewDevice=3]="FoundNewDevice",_f[_f.DoorBellPress=4]="DoorBellPress",_f[_f.AddedNewDevice=5]="AddedNewDevice",_f[_f.RemovedDevice=6]="RemovedDevice",_f[_f.RegisteredNewUser=7]="RegisteredNewUser",_f[_f.GotAccessToTheInternet=8]="GotAccessToTheInternet",_f[_f.LostAccessToTheInternet=9]="LostAccessToTheInternet",_f[_f.RemovedUser=10]="RemovedUser",_f[_f.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}(Sf||(Sf={}));var 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=bv.Get(Pt.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==yf.Message)return;const n=new Pf;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(Sf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return If(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Of,12e3,!1);if(null==e)return new Te(Vf.OtherError,"Cannot get messages - response is null.");if(e.Status!=ce.OK)return new Te(Vf.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Te(Vf.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==yf.Message)return;const n=new Pf;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(Sf[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(Vf.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return If(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Uf(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return bv.Get(r.ServiceName).Error(Zf.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class Pf{constructor(){this._sender=mf.Controller,this._messageType=yf.Info,this._messageSource=wf.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 Of extends ae{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ue.Get}}class Uf extends ae{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ue.Put,this.Data=e}}var Mf,xf,Ff,Bf=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._chatSubscriptions=[],this._connection=bv.Get(Pt.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==yf.Message){const e=new $f;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 Bf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new qf,12e3,!1);if(null==e)return new Te(Vf.OtherError,"Cannot get messages - response is null.");if(e.Status!=ce.OK)return new Te(Vf.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Te(Vf.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==yf.Message){const n=new $f;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(Vf.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return Bf(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Wf(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return bv.Get(r.ServiceName).Error(Zf.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class $f{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 Wf extends ae{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=ue.Put,this.Data=e}}class qf extends ae{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=ue.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(Mf||(Mf={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(xf||(xf={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(Ff||(Ff={}));var Hf,Vf,jf,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._chatSubscriptions=[],this._connection=bv.Get(Pt.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new Qf;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=Mf[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(Ff[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return Kf(this,void 0,void 0,(function*(){return(yield bv.Get(Ze.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return Kf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Yf,8e3,!1);return null==e||null==e.Status?new Te(Vf.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ce.OK?new Te(Vf.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new Te(Vf.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new Te(Vf.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return Kf(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Xf(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return bv.Get(r.ServiceName).Error(Zf.ServiceName,`Cannot set chat configuration! ${e}`),ce.FatalError}}))}SendMessageAsync(e){return Kf(this,void 0,void 0,(function*(){try{const t=yield this._connection.SendAndWaitForResponseAsync(new Jf(e),8e3,!1);return null==t||null==t.Status?ce.FatalError:t.Status}catch(e){return bv.Get(r.ServiceName).Error(Zf.ServiceName,`Cannot send message! ${e}`),ce.FatalError}}))}SubscribeToMessages(e){var t;null===(t=this._chatSubscriptions)||void 0===t||t.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class Jf extends ae{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=ue.Put,this.Data=e}}class Yf extends ae{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ue.Get}}class Xf extends ae{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=ue.Put,this.Data=e}}class Qf{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"}(Hf||(Hf={}));class Zf{constructor(){this._services={ControllerChat:new Rf,GptChat:new zf,FamillyChat:new Lf}}GetServiceName(){return Zf.ServiceName}GetChatImplementation(e){switch(e){case Hf.ControllerChat:return this._services.ControllerChat;case Hf.FamilyChat:return this._services.FamillyChat;case Hf.GptChat:return this._services.GptChat;default:throw new ev(`Chat with type ${e} not implemented!`)}}}Zf.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(Vf||(Vf={}));class ev 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"}(jf||(jf={}));var tv=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 nv{constructor(){this._connection=bv.Get(Pt.ServiceName),this._log=bv.Get(r.ServiceName)}GetServiceName(){return nv.ServiceName}IsSupportedAsync(){return tv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new rv,2e3,!0);return this._log.Debug(nv.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ce.WrongData}))}GetConnectedAppsAsync(){return tv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new sv,2e3,!0);return(null==e?void 0:e.Status)===ce.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return tv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new iv(e),2e3,!1);switch(null==t?void 0:t.Status){case ce.OK:return new Te(jf.Changed,"");case ce.WrongData:switch(t.Data){case"AccessTokenToShort":return new Te(jf.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new Te(jf.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new Te(jf.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new Te(jf.AppNameToShort,t.Data);case"AppUrlToShort":return new Te(jf.AppUrlToShort,t.Data);case"AppUserIdToShort":return new Te(jf.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new Te(jf.AppUserNameToShort,t.Data);default:return new Te(jf.UnkownError,t.Data)}case ce.ResourceDoesNotExists:case ce.ResourceIsNotAvailable:return new Te(jf.ResourceIsNotAvailable,t.Data);default:return new Te(jf.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return tv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new ov(e.Guid),2e3,!0);return null==t?void 0:t.Status}))}}nv.ServiceName="ConnectedAppsService";class rv extends ae{constructor(){super(),this.Resource="/applications/app/auth",this.Method=ue.Put,this.Data=""}}class sv extends ae{constructor(){super(),this.Resource="/applications/get",this.Method=ue.Get}}class ov extends ae{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=ue.Delete,this.Data=e}}class iv extends ae{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=ue.Put,this.Data=e}}var av=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 cv{constructor(){try{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(cv.AppUserControllersKeyName,e)}null!==s&&localStorage.setItem(cv.AppUserControllersKeyName,decodeURIComponent(s)),null!==o&&localStorage.setItem(cv.AppSelectedLanguageKeyName,o)}catch(e){console.error(e)}}waitForNavigatorObject(e){return new Promise(((t,n)=>{setTimeout((()=>{n(new Error(`Timed out waiting for navigator.${e}`))}),1e4),function n(){navigator[e]?t(navigator[e]):requestAnimationFrame(n)}()}))}b64DecodeUnicode(e){return decodeURIComponent(Array.prototype.map.call(atob(e),(function(e){return"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)})).join(""))}decodeUriJsonData(e){return JSON.parse(decodeURIComponent(e))}encodeUriJsonData(e){return encodeURIComponent(JSON.stringify(e))}IsExalusNativeMigrationAvailable(){return void 0!==navigator.exalusMigration}GetServiceName(){return cv.ServiceName}IsMigrationDataAvailableAsync(){return av(this,void 0,void 0,(function*(){try{if(null!=window.webkit&&null!=window.webkit.messageHandlers){var e=yield cv.GetIosMigrationStatus();return null!==e&&e}if(!navigator.userAgent.endsWith("LavvaAndroidNative")||void 0!==navigator.exalusMigration&&null!==navigator.exalusMigration||(yield this.waitForNavigatorObject("exalusMigration")),this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.IsMigrationDataAvailableAsync();return null!=e&&e.DataMigrated}return null!==localStorage.getItem(cv.AppSelectedLanguageKeyName)||null!==localStorage.getItem(cv.AppUserControllersKeyName)}catch(e){return console.error(e),!1}}))}GetControllersDataAsync(){return av(this,void 0,void 0,(function*(){try{if(null!=window.webkit&&null!=window.webkit.messageHandlers){let e=yield cv.GetIosControllerList();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetControllersDataAsync();return void 0===e?null:e}let e=localStorage.getItem(cv.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}catch(e){return console.error(e),null}}))}GetLanguageCodeAsync(){return av(this,void 0,void 0,(function*(){try{if(null!=window.webkit&&null!=window.webkit.messageHandlers){let e=yield cv.GetIosDefaultLanguage();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetLanguageCodeAsync();return void 0===e?null:e}let e=localStorage.getItem(cv.AppSelectedLanguageKeyName);return null!=e?e:null}}catch(e){return console.error(e),null}}))}static GetIosMigrationStatus(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.isMigrationAvaliable=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("IsMigrationAvaliable")}catch(e){r(e)}}))}static GetIosControllerList(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleControllers=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetControllers")}catch(e){r(e)}}))}static GetIosDefaultLanguage(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleLanguage=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetDefaultLanguage")}catch(e){r(e)}}))}}cv.AppSelectedLanguageKeyName="App___SelectedLanguage",cv.AppUserControllersKeyName="App___UserControllersListDatabase",cv.ServiceName="DataMigrationService";var uv=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 lv{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=bv.Get(Pt.ServiceName),this._logger=bv.Get(r.ServiceName),this._storage=bv.Get(o.ServiceName),bv.Get(Ke.ServiceName).OnUserLoggedInEvent().Subscribe((e=>uv(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(lv.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(lv.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(lv.ServiceName,"Controller not found in local network."))}else this._logger.Error(lv.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(lv.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return uv(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(lv.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){return uv(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new dv,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(lv.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return lv.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("")}}))}}lv.ServiceName="FindControllerService";class dv extends ae{constructor(){super(),this.Resource="/network/lan/",this.Method=ue.Get}}var hv=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 pv{constructor(){this._errorOccuredEvent=new n,this._connectionStateChangedEvent=new n,this._dataReceivedEvent=new n,this._onMessageReceived=new n,this._log=bv.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=bv.Get(st.ServiceName),this._cache=bv.Get(Ge.ServiceName),this._session=bv.Get(Ke.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return hv(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 bv.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(pv.ServiceName,`Connecting to the WebSockets server ${e}`),this.sockets.onerror=t=>{this._log.Debug(pv.ServiceName,`Error occured in the WebSockets server ${e}: ${t}`),this._errorOccuredEvent.Invoke(["WebSockets",t.toString()])},this.sockets.onopen=t=>{this._log.Debug(pv.ServiceName,`Connected to the WebSockets server ${e}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(he.Connected)},this.sockets.onclose=t=>{this._log.Debug(pv.ServiceName,`Disconnected from the WebSockets server ${e}`),this._isOpen=!1,this._connectionStateChangedEvent.Invoke(he.Disconnected)},this.sockets.onmessage=t=>{this._log.Debug(pv.ServiceName,`Message received from the WebSockets server ${e}: ${t.data}`),this._onMessageReceived.Invoke(t.data);let n=JSON.parse(t.data);this._log.Debug(pv.ServiceName,`Received data frame: ${n.Status}`),this._dataReceivedEvent.Invoke(n)},this._connectionStateChangedEvent.Invoke(he.Connecting),Promise.resolve(de.Connected)}AuthorizeAsync(e){return hv(this,void 0,void 0,(function*(){return!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(pv.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,!0)}))}ConnectAndAuthorizeAsync(e){return hv(this,void 0,void 0,(function*(){if(this._log.Debug(pv.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`),!(yield this.AuthorizeAsync(e)))return de.AuthorizationFailed;let t=yield this.GetServerAddressAsync();return null==t?de.FailedToConnectToServer:yield this.ConnectAsync(t)}))}DisconnectAsync(){var e;return this._log.Debug(pv.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._connectionStateChangedEvent.Invoke(he.Disconnecting),null===(e=this.sockets)||void 0===e||e.close(),Promise.resolve()}IsConnected(){return this._isOpen}EnablePacketsLogging(){this._log.Debug(pv.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(pv.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(pv.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.sockets)||void 0===n||n.send(r):this._log.Error(pv.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){return hv(this,void 0,void 0,(function*(){var s;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)=>hv(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(pv.ServiceName,t),a(new Error(t))}),t);let u=l=>hv(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(pv.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)===ce.UserIsNotLoggedIn&&(this._dataReceivedEvent.Unsubscribe(u),(null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User),yield null===(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 ce.MultiDataResponseStart:case ce.MultiDataResponse:n(l),o=c();break;case ce.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){return hv(this,arguments,void 0,(function*(e,t,n,r=!0,s=!0){var o,i,a;if(e.Method===ue.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)=>hv(this,void 0,void 0,(function*(){let a=i=>hv(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(pv.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===ue.Get&&n&&(null===(l=this._cache)||void 0===l||l.Cache(i)),!n&&(null==i?void 0:i.Status)===ce.UserIsNotLoggedIn&&r&&((null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User),yield null===(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(pv.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 pv.ServiceName}}pv.ServiceName="ExalusConnectionService";class gv{constructor(){var e,t;this.OnEnteredPictureInPicture=new Ce,this.OnExitedPictureInPicture=new Ce,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 gv.ServiceName}}gv.ServiceName="PictureInPictureService";var fv,vv,mv;class yv{GetServiceName(){return yv.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}}yv.ServiceName="SupportedDevicesService",(mv=fv||(fv={}))[mv.Unknown=-1]="Unknown",mv[mv.Web=0]="Web",mv[mv.Android=1]="Android",mv[mv.iOS=2]="iOS";class wv{constructor(){this.ClientName="",this.LavvaUserName="",this.ClientType=fv.Unknown,this.TokenGuid="",this.RegistrationDate=new Date}}!function(e){e.FeatureUnsupported="FeatureUnsupported",e.UnknownError="UnknownError",e.NoData="NoData",e.IncorrectGuid="IncorrectGuid",e.IdentityIsEmpty="IdentityIsEmpty",e.DeviceTokenIsEmpty="DeviceTokenIsEmpty",e.ClientNameIsEmpty="ClientNameIsEmpty",e.LavvaUserNameIsEmpty="LavvaUserNameIsEmpty",e.TokenNotFound="TokenNotFound"}(vv||(vv={}));var Sv=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 _v{constructor(){this._connection=bv.Get(Pt.ServiceName),this._logger=bv.Get(r.ServiceName)}GetServiceName(){return _v.ServiceName}RegisterNotificationsClientAsync(e){return Sv(this,void 0,void 0,(function*(){var t;try{const n=new Av({ClientName:e.ClientName,DeviceToken:e.DeviceToken,LavvaUserName:e.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:e.EnableNotifications}),r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,8e3,!1);if(null==r||null==r.Status)return new Te(vv.UnknownError,"Cannot register notifications client - unknown error!");switch(r.Status){case ce.WrongData:{const e=this.isValidErrorCode(r.Data)?r.Data:vv.UnknownError;return new Te(e,"Cannot register notifications client - wrong data!")}case ce.ResourceDoesNotExists:return new Te(vv.FeatureUnsupported,"Notifications feature not supported in controller!");case ce.OK:return"string"==typeof r.Data?r.Data:new Te(vv.NoData,"Cannot register notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Te(vv.UnknownError,"Cannot register notifications client - unknown error!")}}catch(e){return new Te(vv.UnknownError,`Cannot register notifications client - error: ${e}`)}}))}UpdateNotificationsClientAsync(e,t){return Sv(this,void 0,void 0,(function*(){var n;try{const r=new Cv({ClientName:t.ClientName,DeviceToken:t.DeviceToken,LavvaUserName:t.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:t.EnableNotifications,Guid:e}),s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(r,8e3,!1);if(null==s||null==s.Status)return new Te(vv.UnknownError,"Cannot update notifications client - unknown error!");switch(s.Status){case ce.WrongData:{const e=this.isValidErrorCode(s.Data)?s.Data:vv.UnknownError;return new Te(e,"Cannot update notifications client - wrong data!")}case ce.ResourceDoesNotExists:return new Te(vv.FeatureUnsupported,"Notifications feature not supported in controller!");case ce.OK:return"string"==typeof s.Data?s.Data==e?ce.OK:new Te(vv.UnknownError,`Cannot update notifications client - result status is OK, but token guid is different! request guid ${e}, response guid: ${s.Data}`):new Te(vv.NoData,"Cannot update notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Te(vv.UnknownError,"Cannot update notifications client - unknown error!")}}catch(e){return this._logger.Error(`Cannot update notifications client - error: ${e}`),new Te(vv.UnknownError,`Cannot update notifications client - error: ${e}`)}}))}GetRegisteredNotificationsClientsMetadataAsync(){return Sv(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Dv,8e3,!1);return null==t||null==t.Status?new Te(vv.UnknownError,"Cannot get notifications clients metadata - unknown error!"):t.Status==ce.ResourceDoesNotExists?new Te(vv.FeatureUnsupported,"Notifications feature not supported in controller!"):t.Status!=ce.OK?new Te(vv.UnknownError,`Cannot get notifications clients metadata - response status: ${t.Status}}`):null==t.Data?new Te(vv.NoData,"Cannot get notifications clients metadata - response status is OK, but no data!"):t.Data.map((e=>{const t=new wv;return t.ClientName=e.ClientName,t.LavvaUserName=e.LavvaUserName,t.ClientType=e.ClientType,t.TokenGuid=e.TokenGuid,t.RegistrationDate=new Date(e.RegistrationDate),t}))}catch(e){return this._logger.Error(`Cannot get notifications clients metadata - error: ${e}`),new Te(vv.UnknownError,`Cannot get notifications clients metadata - error: ${e}`)}}))}IsNotifiacationsEnabledAsync(e){return Sv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Tv(e),8e3,!1);if(null==n||null==n.Status)return new Te(vv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ce.ResourceDoesNotExists:if(null==n.Data)return new Te(vv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:vv.UnknownError;return new Te(e,"Cannot get notifications status - resource not exists!")}case ce.OK:return"boolean"==typeof n.Data?n.Data:new Te(vv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Te(vv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Te(vv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}EnableNotificationsAsync(e){return Sv(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new kv(n),8e3,!1);if(null==r||null==r.Status)return new Te(vv.UnknownError,"Cannot enable notifications - unknown error!");switch(r.Status){case ce.ResourceDoesNotExists:if(null==r.Data)return new Te(vv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:vv.UnknownError;return new Te(e,"Cannot enable notifications - resource not exists!")}case ce.OK:return ce.OK;default:return new Te(vv.UnknownError,`Cannot enable notifications - response code ${r.Status}}!`)}}catch(e){return this._logger.Error(`Cannot enable notifications - error: ${e}`),new Te(vv.UnknownError,`Cannot enable notifications - error: ${e}`)}}))}DisableNotificationsAsync(e){return Sv(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Gv(n),8e3,!1);if(null==r||null==r.Status)return new Te(vv.UnknownError,"Cannot disable notifications - unknown error!");switch(r.Status){case ce.ResourceDoesNotExists:if(null==r.Data)return new Te(vv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:vv.UnknownError;return new Te(e,"Cannot disable notifications - resource not exists!")}case ce.OK:return ce.OK;default:return new Te(vv.UnknownError,`Cannot disable notifications - response code ${r.Status}!`)}}catch(e){return this._logger.Error(`Cannot disable notifications - error: ${e}`),new Te(vv.UnknownError,`Cannot disable notifications - error: ${e}`)}}))}getClientType(){return null!=window.webkit&&null!=window.webkit.messageHandlers?fv.iOS:navigator.userAgent.endsWith("LavvaAndroidNative")?fv.Android:fv.Web}isValidErrorCode(e){return Object.values(vv).includes(e)}}_v.ServiceName="NotificationsService";class Av extends ae{constructor(e){super(),this.Resource="/notifications/token",this.Method=ue.Post,this.Data=e}}class Cv extends ae{constructor(e){super(),this.Resource="/notifications/token",this.Method=ue.Put,this.Data=e}}class Dv extends ae{constructor(){super(),this.Resource="/notifications/tokens/metadata",this.Method=ue.Get}}class Tv extends ae{constructor(e){super(),this.Resource="/notifications/status",this.Method=ue.Get,this.Data={TokenIdentity:e}}}class kv extends ae{constructor(e){super(),this.Resource="/notifications/enabl",this.Method=ue.Post,this.Data=e}}class Gv extends ae{constructor(e){super(),this.Resource="/notifications/disable",this.Method=ue.Post,this.Data=e}}Fc(Map),Fc(Set),(()=>{const e=String.prototype,t=Object.getOwnPropertyNames(Vo.prototype);for(const n of t)e[n]=e[n]??Vo.prototype[n];e.first=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}throw new $o(Lo.NoMatch)}if(0===this.length)throw new $o(Lo.NoElements);return this[0]},e.firstOrDefault=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[0]},e.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},e.elementAt=function(e){if(e<0||e>=this.length)throw new Bo("index");return this[e]},e.elementAtOrDefault=function(e){return this[e]||null},e.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new $o(Lo.NoMatch)}if(0===this.length)throw new $o(Lo.NoElements);return this[this.length-1]},e.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},e.reverse=function(){const e=this;return new Vo((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 bv{static Init(){if(s.IsInitialized)return;let e=s.Instance;try{e.RegisterService(new cv),e.RegisterService(new o),e.RegisterService(new gg),e.RegisterService(new Ge),e.RegisterService(new Ke),e.RegisterService(new gv),bv.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new pv)):e.RegisterService(new Pt),e.RegisterService(new ds),e.RegisterService(new yv),e.RegisterService(new ds),e.RegisterService(new Ms),e.RegisterService(new st),e.RegisterService(new lv),e.RegisterService(new as),e.RegisterService(new Ze),e.RegisterService(new Ne),e.RegisterService(new Be),e.RegisterService(new So),e.RegisterService(new Kp),e.RegisterService(new Ng),e.RegisterService(new Yg),e.RegisterService(new nv),e.RegisterService(new Tf),e.RegisterService(new ao),e.RegisterService(new Zf),e.RegisterService(new _v)}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)))}static ExportStringAsFileToDownload(e,t){const n=new Blob([t],{type:"text/plain"}),r=document.createElement("a"),s=window.URL.createObjectURL(n);return r.href=s,r.download=e,r}}bv.WorksInContextOf="",bv.Version=1})();
2
2
  //# sourceMappingURL=exalushome-library-bundle.js.map