lavva.exalushome 2.1.5 → 2.1.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/exalushome-library-bundle.js +1 -1
- package/build/exalushome-library-bundle.js.map +1 -1
- package/build/js/Api.js +138 -138
- package/build/js/AsyncLock.js +15 -15
- package/build/js/AsyncSemaphore.js +50 -50
- package/build/js/CancelationTokenSource.js +18 -18
- package/build/js/DataFrame.js +86 -86
- package/build/js/DependencyContainer.js +122 -122
- package/build/js/Event.js +25 -25
- package/build/js/Guid.js +8 -8
- package/build/js/Helpers.js +150 -150
- package/build/js/IDIService.js +1 -1
- package/build/js/INetworkService.js +41 -41
- package/build/js/Services/AndroidAutoCarPlayService.js +112 -107
- package/build/js/Services/AndroidAutoCarPlayService.js.map +1 -1
- package/build/js/Services/AndroidLocationService.js +21 -21
- package/build/js/Services/AndroidNotificationService.js +33 -33
- package/build/js/Services/AppLocalesService.js +20 -20
- package/build/js/Services/AppRateService.js +28 -28
- package/build/js/Services/AppStateService.js +239 -239
- package/build/js/Services/Chat/ChatImplementations/ControllerChat/ControllerChat.js +225 -225
- package/build/js/Services/Chat/ChatImplementations/ControllerChat/IControllerChat.js +33 -33
- package/build/js/Services/Chat/ChatImplementations/FamillyChat/FamillyChat.js +148 -148
- package/build/js/Services/Chat/ChatImplementations/FamillyChat/IFamillyChat.js +1 -1
- package/build/js/Services/Chat/ChatImplementations/GptChat/GptChat.js +186 -186
- package/build/js/Services/Chat/ChatImplementations/GptChat/IGptChat.js +26 -26
- package/build/js/Services/Chat/ChatService.js +43 -43
- package/build/js/Services/Chat/IChatService.js +6 -6
- package/build/js/Services/Controller/ConnectedAppsService.js +122 -122
- package/build/js/Services/Controller/ControllerConfigurationService.js +489 -489
- package/build/js/Services/Controller/ControllerExtensionsService.js +157 -157
- package/build/js/Services/Controller/FindControllerService.js +154 -154
- package/build/js/Services/Controller/GeolocationService.js +114 -114
- package/build/js/Services/Controller/IConnectedAppsService.js +24 -24
- package/build/js/Services/Controller/IControllerConfigurationService.js +4 -4
- package/build/js/Services/Controller/IControllerExtensionsService.js +1 -1
- package/build/js/Services/Controller/IGeolocationService.js +20 -20
- package/build/js/Services/DataMigrationService.js +225 -225
- package/build/js/Services/Devices/ChannelsGroupsService.js +718 -718
- package/build/js/Services/Devices/Device.js +249 -249
- package/build/js/Services/Devices/DeviceChannel.js +309 -309
- package/build/js/Services/Devices/DevicesService.js +1346 -1346
- package/build/js/Services/Devices/IChannelsGroupsService.js +109 -109
- package/build/js/Services/Devices/IDevice.js +202 -202
- package/build/js/Services/Devices/IDeviceChannel.js +48 -48
- package/build/js/Services/Devices/IDeviceConfigService.js +1 -1
- package/build/js/Services/Devices/IDeviceState.js +1027 -1027
- package/build/js/Services/Devices/IDeviceTask.js +37 -37
- package/build/js/Services/Devices/IDevicesService.js +9 -9
- package/build/js/Services/Devices/IManuallyPairedDevicesProtocolService.js +1 -1
- package/build/js/Services/Devices/IManuallyPairedDevicesService.js +1 -1
- package/build/js/Services/Devices/ManuallyPairedDevicesService.js +67 -67
- package/build/js/Services/Devices/TaskExecutionResult.js +9 -9
- package/build/js/Services/Devices/Tasks/DeviceTask.js +42 -42
- package/build/js/Services/Devices/Tasks/Tasks.js +226 -226
- package/build/js/Services/ExalusConnectionService.d.ts +6 -1
- package/build/js/Services/ExalusConnectionService.js +908 -868
- package/build/js/Services/ExalusConnectionService.js.map +1 -1
- package/build/js/Services/FieldChangeResult.js +51 -51
- package/build/js/Services/HomeKitService.js +76 -76
- package/build/js/Services/IAppStateService.js +66 -66
- package/build/js/Services/IExalusConnectionService.d.ts +12 -0
- package/build/js/Services/IExalusConnectionService.js +51 -38
- package/build/js/Services/IExalusConnectionService.js.map +1 -1
- package/build/js/Services/ILocalStorageService.js +1 -1
- package/build/js/Services/IRemoteStorageService.js +8 -8
- package/build/js/Services/LocalNetworkExalusConnectionService.d.ts +2 -1
- package/build/js/Services/LocalNetworkExalusConnectionService.js +426 -419
- package/build/js/Services/LocalNetworkExalusConnectionService.js.map +1 -1
- package/build/js/Services/LocalStorageService.js +40 -40
- package/build/js/Services/Logging/ILoggerService.js +8 -8
- package/build/js/Services/Logging/LoggerService.js +133 -133
- package/build/js/Services/Notifications/ControllerNotificationsService.js +475 -475
- package/build/js/Services/Notifications/IControllerNotificationsService.js +44 -44
- package/build/js/Services/PictureInPicture.js +28 -28
- package/build/js/Services/Pictures/IPicture.js +6 -6
- package/build/js/Services/Pictures/IPicturesService.js +1 -1
- package/build/js/Services/Pictures/Picture.js +50 -50
- package/build/js/Services/Pictures/PicturesService.js +441 -441
- package/build/js/Services/RemoteStorageService.js +137 -137
- package/build/js/Services/Scenes/IScenesService.js +7 -7
- package/build/js/Services/Scenes/LeftArgumentTypes.js +166 -166
- package/build/js/Services/Scenes/SceneTaskTypes.js +36 -36
- package/build/js/Services/Scenes/Scenes.js +142 -142
- package/build/js/Services/Scenes/ScenesBuilder.js +1348 -1348
- package/build/js/Services/Scenes/ScenesService.js +1222 -1222
- package/build/js/Services/Session/ISessionService.js +8 -8
- package/build/js/Services/Session/SessionService.js +256 -256
- package/build/js/Services/StatesHistory/IStatesHistoryService.js +12 -12
- package/build/js/Services/StatesHistory/StatesHistory.js +89 -89
- package/build/js/Services/StatesHistory/StatesHistoryHelper.js +37 -37
- package/build/js/Services/StatesHistory/StatesHistoryService.js +470 -470
- package/build/js/Services/Updates/CustomUpdateActions/ICustomUpdateActions.js +1 -1
- package/build/js/Services/Updates/IUpdateInfo.js +69 -69
- package/build/js/Services/Updates/IUpdatesProvider.js +48 -48
- package/build/js/Services/Updates/IUpdatesService.js +174 -174
- package/build/js/Services/Updates/UpdateProviderServices/IControllerModulesUpdatesProviderService.js +1 -1
- package/build/js/Services/Updates/UpdateProviderServices/IDeviceUpdateProviderService.js +1 -1
- package/build/js/Services/Updates/UpdateProviderServices/IUpdateProviderService.js +1 -1
- package/build/js/Services/Updates/UpdatesProvider.js +221 -221
- package/build/js/Services/Updates/UpdatesService.js +2130 -2130
- package/build/js/Services/Users/IUser.js +21 -21
- package/build/js/Services/Users/IUsersService.js +1 -1
- package/build/js/Services/Users/User.js +111 -111
- package/build/js/Services/Users/UsersService.js +308 -308
- package/build/js/Services/WebApi/IWebApiCacheService.js +1 -1
- package/build/js/Services/WebApi/WebApiCacheService.js +44 -44
- package/build/js/TypedEvent.js +24 -24
- package/build/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
(()=>{"use strict";var e,t,n,r,s,o,i={d:(e,t)=>{for(var n in t)i.o(t,n)&&!i.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})}};i.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),i.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),i.d({},{j:()=>hy}),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 a{constructor(){this._blockedServices=[],this._logLevel=e.Debug;const t=globalThis;void 0!==t.loglevel&&null!==t.loglevel&&(this._logLevel=t.loglevel),t.logger=this}EnableStackTrace(){a.DoesThrowStackTrace=!0}DisableStackTrace(){a.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(a.ServiceName,`Disabling logs from ${e}`)}EnableLogsFrom(e){this._blockedServices.any((t=>t==e))&&(this._blockedServices=this._blockedServices.where((t=>t!=e)).toArray()),this.Debug(a.ServiceName,`Enaabling logs from ${e}`)}get LogLevel(){return this._logLevel}set LogLevel(e){this._logLevel=e}GetServiceName(){return a.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}`):a.DoesThrowStackTrace||!0===globalThis.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}`)))}}a.ServiceName="LoggerService",a.DoesThrowStackTrace=!1;class c{constructor(){this.handlers=[]}Subscribe(e){this.handlers.includes(e)||this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(e){this.handlers.slice(0).forEach((t=>{var n;try{t(e)}catch(e){null===(n=u.Log)||void 0===n||n.Error(e)}}))}}class u{constructor(){this._services=new Map,this._serviceRegistrationEvent=new c,this._pendingResolutions=new Map,this._nextResolutionId=1}static get Timers(){return globalThis}static get Instance(){const e=globalThis;if(e.__dc_instance)return e.__dc_instance;const t=new u;return e.__dc_instance=t,"undefined"==typeof window||window.LavvaDI||(window.appservices=t),this.Log=new a,this.Log.Warning(u.ServiceName,"Initializing DependencyContainer"),t.RegisterService(this.Log),this.IsInitialized=!0,t}RegisterService(e){var t;const n=e.GetServiceName();this._services.has(n)&&(null===(t=u.Log)||void 0===t||t.Warning(u.ServiceName,`Service "${n}" is being re-registered and the previous instance will be overwritten.`)),this._services.set(n,e),this._serviceRegistrationEvent.Invoke(e)}GetService(e){return this._services.get(e)}GetServiceAsync(e,t){var n,r;if(this._services.has(e))return null===(n=u.Log)||void 0===n||n.Debug(u.ServiceName,`Resolved service "${e}" immediately.`),Promise.resolve(this._services.get(e));const s=this.CreatePendingResolution(e);return this._pendingResolutions.set(s.Id,s),null===(r=u.Log)||void 0===r||r.Debug(u.ServiceName,`Waiting for service "${e}" (request #${s.Id}). Registered services: ${this.GetRegisteredServiceNamesForLogs()}.`),new Promise(((n,r)=>{const o=r=>{var a;if(r.GetServiceName()===e&&this.TryCompleteResolution(s.Id)){this._serviceRegistrationEvent.Unsubscribe(o),null==t||t.CancellationEvent.Unsubscribe(i);const c=Date.now()-s.StartedAt;null===(a=u.Log)||void 0===a||a.Info(u.ServiceName,`Resolved service "${e}" after ${c}ms (request #${s.Id}).`),n(r)}},i=()=>{var t;if(this._serviceRegistrationEvent.Unsubscribe(o),!this.TryCompleteResolution(s.Id))return;const n=Date.now()-s.StartedAt;null===(t=u.Log)||void 0===t||t.Warning(u.ServiceName,`Cancelled waiting for service "${e}" after ${n}ms (request #${s.Id}).`),r(new Error("cancelled"))};null==t||t.CancellationEvent.Subscribe(i),this._serviceRegistrationEvent.Subscribe(o)}))}GetServiceWithTimeoutAsync(e,t){var n,r;if(this._services.has(e))return null===(n=u.Log)||void 0===n||n.Debug(u.ServiceName,`Resolved service "${e}" immediately.`),Promise.resolve(this._services.get(e));const s=this.CreatePendingResolution(e);return this._pendingResolutions.set(s.Id,s),null===(r=u.Log)||void 0===r||r.Debug(u.ServiceName,`Waiting for service "${e}" with timeout ${t}ms (request #${s.Id}). Registered services: ${this.GetRegisteredServiceNamesForLogs()}.`),new Promise(((n,r)=>{const o=t=>{var r;if(t.GetServiceName()===e&&this.TryCompleteResolution(s.Id)){u.Timers.clearTimeout(i),this._serviceRegistrationEvent.Unsubscribe(o);const a=Date.now()-s.StartedAt;null===(r=u.Log)||void 0===r||r.Info(u.ServiceName,`Resolved service "${e}" after ${a}ms (request #${s.Id}).`),n(t)}},i=u.Timers.setTimeout((()=>{var t;if(this._serviceRegistrationEvent.Unsubscribe(o),!this.TryCompleteResolution(s.Id))return;const n=Date.now()-s.StartedAt;null===(t=u.Log)||void 0===t||t.Warning(u.ServiceName,`Timeout waiting for service "${e}" after ${n}ms (request #${s.Id}). Registered services: ${this.GetRegisteredServiceNamesForLogs()}.`),r(new Error(`timeout waiting for "${e}"`))}),t);this._serviceRegistrationEvent.Subscribe(o)}))}CreatePendingResolution(e){return{Id:this._nextResolutionId++,ServiceName:e,StartedAt:Date.now()}}TryCompleteResolution(e){return this._pendingResolutions.delete(e)}GetRegisteredServiceNamesForLogs(){const e=[...this._services.keys()].sort();return 0===e.length?"<none>":e.join(", ")}}u.ServiceName="DependencyContainer",u.IsInitialized=!1;class l{GetServiceName(){return l.ServiceName}GetResourceName(e,t){return`_exalus_${hy.WorksInContextOf}_${e}_${t}`}Remove(e,t){localStorage.removeItem(this.GetResourceName(e,t))}DropStorage(e){const t=`_exalus_${hy.WorksInContextOf}_${e}`;Object.keys(localStorage).filter((e=>e.startsWith(t))).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(l.ServiceName,`Clearing API cache for key: ${e}`),localStorage.removeItem(e)}))}Save(e,t,n){localStorage.setItem(this.GetResourceName(e,t),JSON.stringify(n))}Read(e,t){var n;try{let n=this.GetResourceName(e,t),r=localStorage.getItem(n);return null==r?null:JSON.parse(r)}catch(r){return null===(n=u.Log)||void 0===n||n.Error(l.ServiceName,`Exception has occurred while reading ${this.GetResourceName(e,t)}`),null}}}l.ServiceName="LocalStorageService",function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(t||(t={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(n||(n={})),function(e){e[e.Trace=0]="Trace",e[e.Debug=1]="Debug",e[e.Information=2]="Information",e[e.Warning=3]="Warning",e[e.Error=4]="Error",e[e.Critical=5]="Critical",e[e.None=6]="None"}(r||(r={}));class d{static write(e){return`${e}${d.RecordSeparator}`}static parse(e){if(e[e.length-1]!==d.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(d.RecordSeparator);return t.pop(),t}}d.RecordSeparatorCode=30,d.RecordSeparator=String.fromCharCode(d.RecordSeparatorCode);class h{constructor(){}log(e,t){}}h.instance=new h;class p{static isRequired(e,t){if(null==e)throw new Error(`The '${t}' argument is required.`)}static isNotEmpty(e,t){if(!e||e.match(/^\s*$/))throw new Error(`The '${t}' argument should not be empty.`)}static isIn(e,t,n){if(!(e in t))throw new Error(`Unknown ${n} value: ${e}.`)}}class g{static get isBrowser(){return!g.isNode&&"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return!g.isNode&&"object"==typeof self&&"importScripts"in self}static get isReactNative(){return!g.isNode&&"object"==typeof window&&void 0===window.document}static get isNode(){return"undefined"!=typeof process&&process.release&&"node"===process.release.name}}function f(e,t){let n="";return v(e)?(n=`Binary data of length ${e.byteLength}`,t&&(n+=`. Content: '${function(e){const t=new Uint8Array(e);let n="";return t.forEach((e=>{n+=`0x${e<16?"0":""}${e.toString(16)} `})),n.substr(0,n.length-1)}(e)}'`)):"string"==typeof e&&(n=`String data of length ${e.length}`,t&&(n+=`. Content: '${e}'`)),n}function v(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function y(e,t,n,s,o,i){const a={},[c,u]=S();a[c]=u,e.log(r.Trace,`(${t} transport) sending data. ${f(o,i.logMessageContent)}.`);const l=v(o)?"arraybuffer":"text",d=await n.post(s,{content:o,headers:{...a,...i.headers},responseType:l,timeout:i.timeout,withCredentials:i.withCredentials});e.log(r.Trace,`(${t} transport) request complete. Response status: ${d.statusCode}.`)}class m{constructor(e,t){this._subject=e,this._observer=t}dispose(){const e=this._subject.observers.indexOf(this._observer);e>-1&&this._subject.observers.splice(e,1),0===this._subject.observers.length&&this._subject.cancelCallback&&this._subject.cancelCallback().catch((e=>{}))}}class w{constructor(e){this._minLevel=e,this.out=console}log(e,t){if(e>=this._minLevel){const n=`[${(new Date).toISOString()}] ${r[e]}: ${t}`;switch(e){case r.Critical:case r.Error:this.out.error(n);break;case r.Warning:this.out.warn(n);break;case r.Information:this.out.info(n);break;default:this.out.log(n)}}}}function S(){let e="X-SignalR-User-Agent";return g.isNode&&(e="User-Agent"),[e,A("8.0.7",_(),g.isNode?"NodeJS":"Browser",C())]}function A(e,t,n,r){let 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 _(){if(!g.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function C(){if(g.isNode)return process.versions.node}function T(e){return e.stack?e.stack:e.message?e.message:`${e}`}class D{writeHandshakeRequest(e){return d.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(v(e)){const r=new Uint8Array(e),s=r.indexOf(d.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(d.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=d.parse(t),s=JSON.parse(r[0]);if(s.type)throw new Error("Expected a handshake response from the server.");return[n,s]}}class k extends Error{constructor(e,t){const n=new.target.prototype;super(`${e}: Status code '${t}'`),this.statusCode=t,this.__proto__=n}}class I extends Error{constructor(e="A timeout occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class E extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class b extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="UnsupportedTransportError",this.__proto__=n}}class N extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="DisabledTransportError",this.__proto__=n}}class G extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class R extends Error{constructor(e){const t=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=t}}class P extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.innerErrors=t,this.__proto__=n}}!function(e){e[e.Invocation=1]="Invocation",e[e.StreamItem=2]="StreamItem",e[e.Completion=3]="Completion",e[e.StreamInvocation=4]="StreamInvocation",e[e.CancelInvocation=5]="CancelInvocation",e[e.Ping=6]="Ping",e[e.Close=7]="Close",e[e.Ack=8]="Ack",e[e.Sequence=9]="Sequence"}(s||(s={}));class U{constructor(){this.observers=[]}next(e){for(const t of this.observers)t.next(e)}error(e){for(const t of this.observers)t.error&&t.error(e)}complete(){for(const e of this.observers)e.complete&&e.complete()}subscribe(e){return this.observers.push(e),new m(this,e)}}class O{constructor(e,t,n){this._bufferSize=1e5,this._messages=[],this._totalMessageCount=0,this._waitForSequenceMessage=!1,this._nextReceivingSequenceId=1,this._latestReceivedSequenceId=0,this._bufferedByteCount=0,this._reconnectInProgress=!1,this._protocol=e,this._connection=t,this._bufferSize=n}async _send(e){const t=this._protocol.writeMessage(e);let n=Promise.resolve();if(this._isInvocationMessage(e)){this._totalMessageCount++;let e=()=>{},r=()=>{};v(t)?this._bufferedByteCount+=t.byteLength:this._bufferedByteCount+=t.length,this._bufferedByteCount>=this._bufferSize&&(n=new Promise(((t,n)=>{e=t,r=n}))),this._messages.push(new M(t,this._totalMessageCount,e,r))}try{this._reconnectInProgress||await this._connection.send(t)}catch{this._disconnected()}await n}_ack(e){let t=-1;for(let n=0;n<this._messages.length;n++){const r=this._messages[n];if(r._id<=e.sequenceId)t=n,v(r._message)?this._bufferedByteCount-=r._message.byteLength:this._bufferedByteCount-=r._message.length,r._resolver();else{if(!(this._bufferedByteCount<this._bufferSize))break;r._resolver()}}-1!==t&&(this._messages=this._messages.slice(t+1))}_shouldProcessMessage(e){if(this._waitForSequenceMessage)return e.type===s.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:s.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 s.Invocation:case s.StreamItem:case s.Completion:case s.StreamInvocation:case s.CancelInvocation:return!0;case s.Close:case s.Sequence:case s.Ping:case s.Ack:return!1}}_ackTimer(){void 0===this._ackTimerHandle&&(this._ackTimerHandle=setTimeout((async()=>{try{this._reconnectInProgress||await this._connection.send(this._protocol.writeMessage({type:s.Ack,sequenceId:this._latestReceivedSequenceId}))}catch{}clearTimeout(this._ackTimerHandle),this._ackTimerHandle=void 0}),1e3))}}class M{constructor(e,t,n,r){this._message=e,this._id=t,this._resolver=n,this._rejector=r}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(o||(o={}));class x{static create(e,t,n,r,s,o,i){return new x(e,t,n,r,s,o,i)}constructor(e,t,n,i,a,c,u){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(r.Warning,"The page is being frozen, this will likely lead to the connection being closed and messages being lost. For more information see the docs at https://learn.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},p.isRequired(e,"connection"),p.isRequired(t,"logger"),p.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=null!=a?a:3e4,this.keepAliveIntervalInMilliseconds=null!=c?c:15e3,this._statefulReconnectBufferSize=null!=u?u:1e5,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=i,this._handshakeProtocol=new D,this.connection.onreceive=e=>this._processIncomingData(e),this.connection.onclose=e=>this._connectionClosed(e),this._callbacks={},this._methods={},this._closedCallbacks=[],this._reconnectingCallbacks=[],this._reconnectedCallbacks=[],this._invocationId=0,this._receivedHandshakeResponse=!1,this._connectionState=o.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:s.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!==o.Disconnected&&this._connectionState!==o.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!==o.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=o.Connecting,this._logger.log(r.Debug,"Starting HubConnection.");try{await this._startInternal(),g.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=o.Connected,this._connectionStarted=!0,this._logger.log(r.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=o.Disconnected,this._logger.log(r.Debug,`HubConnection failed to start successfully because of error '${e}'.`),Promise.reject(e)}}async _startInternal(){this._stopDuringStartError=void 0,this._receivedHandshakeResponse=!1;const e=new Promise(((e,t)=>{this._handshakeResolver=e,this._handshakeRejecter=t}));await this.connection.start(this._protocol.transferFormat);try{let t=this._protocol.version;this.connection.features.reconnect||(t=1);const n={protocol:this._protocol.name,version:t};if(this._logger.log(r.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(n)),this._logger.log(r.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;!!this.connection.features.reconnect&&(this._messageBuffer=new O(this._protocol,this.connection,this._statefulReconnectBufferSize),this.connection.features.disconnected=this._messageBuffer._disconnected.bind(this._messageBuffer),this.connection.features.resend=()=>{if(this._messageBuffer)return this._messageBuffer._resend()}),this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(r.Debug,`Hub handshake failed with error '${e}' during start(). Stopping HubConnection.`),this._cleanupTimeout(),this._cleanupPingTimer(),await this.connection.stop(e),e}}async stop(){const e=this._startPromise;this.connection.features.reconnect=!1,this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){if(this._connectionState===o.Disconnected)return this._logger.log(r.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve();if(this._connectionState===o.Disconnecting)return this._logger.log(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise;const t=this._connectionState;return this._connectionState=o.Disconnecting,this._logger.log(r.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(r.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(t===o.Connected&&this._sendCloseMessage(),this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new E("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),o=this._createStreamInvocation(e,t,r);let i;const a=new U;return a.cancelCallback=()=>{const e=this._createCancelInvocation(o.invocationId);return delete this._callbacks[o.invocationId],i.then((()=>this._sendWithProtocol(e)))},this._callbacks[o.invocationId]=(e,t)=>{t?a.error(t):e&&(e.type===s.Completion?e.error?a.error(new Error(e.error)):a.complete():a.next(e.item))},i=this._sendWithProtocol(o).catch((e=>{a.error(e),delete this._callbacks[o.invocationId]})),this._launchStreams(n,i),a}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._messageBuffer?this._messageBuffer._send(e):this._sendMessage(this._protocol.writeMessage(e))}send(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._sendWithProtocol(this._createInvocation(e,t,!0,r));return this._launchStreams(n,s),s}invoke(e,...t){const[n,r]=this._replaceStreamingParams(t),o=this._createInvocation(e,t,!1,r);return new Promise(((e,t)=>{this._callbacks[o.invocationId]=(n,r)=>{r?t(r):n&&(n.type===s.Completion?n.error?t(new Error(n.error)):e(n.result):t(new Error(`Unexpected message type: ${n.type}`)))};const r=this._sendWithProtocol(o).catch((e=>{t(e),delete this._callbacks[o.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 s.Invocation:this._invokeClientMethod(e).catch((e=>{this._logger.log(r.Error,`Invoke client method threw error: ${T(e)}`)}));break;case s.StreamItem:case s.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===s.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(r.Error,`Stream callback threw error: ${T(e)}`)}}break}case s.Ping:break;case s.Close:{this._logger.log(r.Information,"Close message received from server.");const t=e.error?new Error("Server returned an error on close: "+e.error):void 0;!0===e.allowReconnect?this.connection.stop(t):this._stopPromise=this._stopInternal(t);break}case s.Ack:this._messageBuffer&&this._messageBuffer._ack(e);break;case s.Sequence:this._messageBuffer&&this._messageBuffer._resetSequence(e);break;default:this._logger.log(r.Warning,`Invalid message type: ${e.type}.`)}}this._resetTimeoutPeriod()}_processHandshakeResponse(e){let t,n;try{[n,t]=this._handshakeProtocol.parseHandshakeResponse(e)}catch(e){const t="Error parsing handshake response: "+e;this._logger.log(r.Error,t);const n=new Error(t);throw this._handshakeRejecter(n),n}if(t.error){const e="Server returned handshake error: "+t.error;this._logger.log(r.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(r.Debug,"Server handshake complete."),this._handshakeResolver(),n}_resetKeepAliveInterval(){this.connection.features.inherentKeepAlive||(this._nextKeepAlive=(new Date).getTime()+this.keepAliveIntervalInMilliseconds,this._cleanupPingTimer())}_resetTimeoutPeriod(){if(!(this.connection.features&&this.connection.features.inherentKeepAlive||(this._timeoutHandle=setTimeout((()=>this.serverTimeout()),this.serverTimeoutInMilliseconds),void 0!==this._pingServerHandle))){let e=this._nextKeepAlive-(new Date).getTime();e<0&&(e=0),this._pingServerHandle=setTimeout((async()=>{if(this._connectionState===o.Connected)try{await this._sendMessage(this._cachedPingMessage)}catch{this._cleanupPingTimer()}}),e)}}serverTimeout(){this.connection.stop(new Error("Server timeout elapsed without receiving a message from the server."))}async _invokeClientMethod(e){const t=e.target.toLowerCase(),n=this._methods[t];if(!n)return this._logger.log(r.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(r.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),await this._sendWithProtocol(this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null))));const s=n.slice(),o=!!e.invocationId;let i,a,c;for(const n of s)try{const s=i;i=await n.apply(this,e.arguments),o&&i&&s&&(this._logger.log(r.Error,`Multiple results provided for '${t}'. Sending error to server.`),c=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),a=void 0}catch(e){a=e,this._logger.log(r.Error,`A callback for the method '${t}' threw error '${e}'.`)}c?await this._sendWithProtocol(c):o?(a?c=this._createCompletionMessage(e.invocationId,`${a}`,null):void 0!==i?c=this._createCompletionMessage(e.invocationId,null,i):(this._logger.log(r.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),c=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(c)):i&&this._logger.log(r.Error,`Result given for '${t}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(r.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new E("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===o.Disconnecting?this._completeClose(e):this._connectionState===o.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===o.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=o.Disconnected,this._connectionStarted=!1,this._messageBuffer&&(this._messageBuffer._dispose(null!=e?e:new Error("Connection closed.")),this._messageBuffer=void 0),g.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(r.Error,`An onclose callback called with error '${e}' threw error '${t}'.`)}}}async _reconnect(e){const t=Date.now();let n=0,s=void 0!==e?e:new Error("Attempting to reconnect due to a unknown error."),i=this._getNextRetryDelay(n++,0,s);if(null===i)return this._logger.log(r.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),void this._completeClose(e);if(this._connectionState=o.Reconnecting,e?this._logger.log(r.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(r.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(r.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==o.Reconnecting)return void this._logger.log(r.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==i;){if(this._logger.log(r.Information,`Reconnect attempt number ${n} will start in ${i} ms.`),await new Promise((e=>{this._reconnectDelayHandle=setTimeout(e,i)})),this._reconnectDelayHandle=void 0,this._connectionState!==o.Reconnecting)return void this._logger.log(r.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=o.Connected,this._logger.log(r.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(r.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(r.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==o.Reconnecting)return this._logger.log(r.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===o.Disconnecting&&this._completeClose());s=e instanceof Error?e:new Error(e.toString()),i=this._getNextRetryDelay(n++,Date.now()-t,s)}}this._logger.log(r.Information,`Reconnect retries have been exhausted after ${Date.now()-t} ms and ${n} failed attempts. Connection disconnecting.`),this._completeClose()}_getNextRetryDelay(e,t,n){try{return this._reconnectPolicy.nextRetryDelayInMilliseconds({elapsedMilliseconds:t,previousRetryCount:e,retryReason:n})}catch(n){return this._logger.log(r.Error,`IRetryPolicy.nextRetryDelayInMilliseconds(${e}, ${t}) threw error '${n}'.`),null}}_cancelCallbacksWithError(e){const t=this._callbacks;this._callbacks={},Object.keys(t).forEach((n=>{const s=t[n];try{s(null,e)}catch(t){this._logger.log(r.Error,`Stream 'error' callback called with '${e}' threw error: ${T(t)}`)}}))}_cleanupPingTimer(){this._pingServerHandle&&(clearTimeout(this._pingServerHandle),this._pingServerHandle=void 0)}_cleanupTimeout(){this._timeoutHandle&&clearTimeout(this._timeoutHandle)}_createInvocation(e,t,n,r){if(n)return 0!==r.length?{arguments:t,streamIds:r,target:e,type:s.Invocation}:{arguments:t,target:e,type:s.Invocation};{const n=this._invocationId;return this._invocationId++,0!==r.length?{arguments:t,invocationId:n.toString(),streamIds:r,target:e,type:s.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:s.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:s.StreamInvocation}:{arguments:t,invocationId:r.toString(),target:e,type:s.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:s.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:s.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:s.Completion}:{invocationId:e,result:n,type:s.Completion}}_createCloseMessage(){return{type:s.Close}}}const F=[0,2e3,1e4,3e4,null];class L{constructor(e){this._retryDelays=void 0!==e?[...e,null]:F}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class B{}B.Authorization="Authorization",B.Cookie="Cookie";class ${constructor(e,t,n){this.statusCode=e,this.statusText=t,this.content=n}}class W{get(e,t){return this.send({...t,method:"GET",url:e})}post(e,t){return this.send({...t,method:"POST",url:e})}delete(e,t){return this.send({...t,method:"DELETE",url:e})}getCookieString(e){return""}}class V extends W{constructor(e,t){super(),this._innerClient=e,this._accessTokenFactory=t}async send(e){let t=!0;this._accessTokenFactory&&(!this._accessToken||e.url&&e.url.indexOf("/negotiate?")>0)&&(t=!1,this._accessToken=await this._accessTokenFactory()),this._setAuthorizationHeader(e);const n=await this._innerClient.send(e);return t&&401===n.statusCode&&this._accessTokenFactory?(this._accessToken=await this._accessTokenFactory(),this._setAuthorizationHeader(e),await this._innerClient.send(e)):n}_setAuthorizationHeader(e){e.headers||(e.headers={}),this._accessToken?e.headers[B.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[B.Authorization]&&delete e.headers[B.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}class q extends W{constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch||g.isNode){const e=require;this._jar=new(e("tough-cookie").CookieJar),"undefined"==typeof fetch?this._fetchType=e("node-fetch"):this._fetchType=fetch,this._fetchType=e("fetch-cookie")(this._fetchType,this._jar)}else this._fetchType=fetch.bind(function(){if("undefined"!=typeof globalThis)return globalThis;if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==i.g)return i.g;throw new Error("could not find global")}());if("undefined"==typeof AbortController){const e=require;this._abortControllerType=e("abort-controller")}else this._abortControllerType=AbortController}async send(e){if(e.abortSignal&&e.abortSignal.aborted)throw new E;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 E});let s,o=null;if(e.timeout){const s=e.timeout;o=setTimeout((()=>{t.abort(),this._logger.log(r.Warning,"Timeout from HTTP request."),n=new I}),s)}""===e.content&&(e.content=void 0),e.content&&(e.headers=e.headers||{},v(e.content)?e.headers["Content-Type"]="application/octet-stream":e.headers["Content-Type"]="text/plain;charset=UTF-8");try{s=await this._fetchType(e.url,{body:e.content,cache:"no-cache",credentials:!0===e.withCredentials?"include":"same-origin",headers:{"X-Requested-With":"XMLHttpRequest",...e.headers},method:e.method,mode:"cors",redirect:"follow",signal:t.signal})}catch(e){if(n)throw n;throw this._logger.log(r.Warning,`Error from HTTP request. ${e}.`),e}finally{o&&clearTimeout(o),e.abortSignal&&(e.abortSignal.onabort=null)}if(!s.ok){const e=await H(s,"text");throw new k(e||s.statusText,s.status)}const i=H(s,e.responseType),a=await i;return new $(s.status,s.statusText,a)}getCookieString(e){let t="";return g.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function H(e,t){let n;switch(t){case"arraybuffer":n=e.arrayBuffer();break;case"text":default:n=e.text();break;case"blob":case"document":case"json":throw new Error(`${t} is not supported.`)}return n}class K extends W{constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new E):e.method?e.url?new Promise(((t,n)=>{const s=new XMLHttpRequest;s.open(e.method,e.url,!0),s.withCredentials=void 0===e.withCredentials||e.withCredentials,s.setRequestHeader("X-Requested-With","XMLHttpRequest"),""===e.content&&(e.content=void 0),e.content&&(v(e.content)?s.setRequestHeader("Content-Type","application/octet-stream"):s.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const o=e.headers;o&&Object.keys(o).forEach((e=>{s.setRequestHeader(e,o[e])})),e.responseType&&(s.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{s.abort(),n(new E)}),e.timeout&&(s.timeout=e.timeout),s.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),s.status>=200&&s.status<300?t(new $(s.status,s.statusText,s.response||s.responseText)):n(new k(s.response||s.responseText||s.statusText,s.status))},s.onerror=()=>{this._logger.log(r.Warning,`Error from HTTP request. ${s.status}: ${s.statusText}.`),n(new k(s.statusText,s.status))},s.ontimeout=()=>{this._logger.log(r.Warning,"Timeout from HTTP request."),n(new I)},s.send(e.content)})):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class j extends W{constructor(e){if(super(),"undefined"!=typeof fetch||g.isNode)this._httpClient=new q(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new K(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new E):e.method?e.url?this._httpClient.send(e):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}getCookieString(e){return this._httpClient.getCookieString(e)}}class z{constructor(){this._isAborted=!1,this.onabort=null}abort(){this._isAborted||(this._isAborted=!0,this.onabort&&this.onabort())}get signal(){return this}get aborted(){return this._isAborted}}class J{get pollAborted(){return this._pollAbort.aborted}constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new z,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}async connect(e,t){if(p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.isIn(t,n,"transferFormat"),this._url=e,this._logger.log(r.Trace,"(LongPolling transport) Connecting."),t===n.Binary&&"undefined"!=typeof XMLHttpRequest&&"string"!=typeof(new XMLHttpRequest).responseType)throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[s,o]=S(),i={[s]:o,...this._options.headers},a={abortSignal:this._pollAbort.signal,headers:i,timeout:1e5,withCredentials:this._options.withCredentials};t===n.Binary&&(a.responseType="arraybuffer");const c=`${e}&_=${Date.now()}`;this._logger.log(r.Trace,`(LongPolling transport) polling: ${c}.`);const u=await this._httpClient.get(c,a);200!==u.statusCode?(this._logger.log(r.Error,`(LongPolling transport) Unexpected response code: ${u.statusCode}.`),this._closeError=new k(u.statusText||"",u.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,a)}async _poll(e,t){try{for(;this._running;)try{const n=`${e}&_=${Date.now()}`;this._logger.log(r.Trace,`(LongPolling transport) polling: ${n}.`);const s=await this._httpClient.get(n,t);204===s.statusCode?(this._logger.log(r.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):200!==s.statusCode?(this._logger.log(r.Error,`(LongPolling transport) Unexpected response code: ${s.statusCode}.`),this._closeError=new k(s.statusText||"",s.statusCode),this._running=!1):s.content?(this._logger.log(r.Trace,`(LongPolling transport) data received. ${f(s.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(s.content)):this._logger.log(r.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(e){this._running?e instanceof I?this._logger.log(r.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=e,this._running=!1):this._logger.log(r.Trace,`(LongPolling transport) Poll errored after shutdown: ${e.message}`)}}finally{this._logger.log(r.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?y(this._logger,"LongPolling",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}async stop(){this._logger.log(r.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(r.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[t,n]=S();e[t]=n;const s={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};let o;try{await this._httpClient.delete(this._url,s)}catch(e){o=e}o?o instanceof k&&(404===o.statusCode?this._logger.log(r.Trace,"(LongPolling transport) A 404 response was returned from sending a DELETE request."):this._logger.log(r.Trace,`(LongPolling transport) Error sending a DELETE request: ${o}`)):this._logger.log(r.Trace,"(LongPolling transport) DELETE request accepted.")}finally{this._logger.log(r.Trace,"(LongPolling transport) Stop finished."),this._raiseOnClose()}}_raiseOnClose(){if(this.onclose){let e="(LongPolling transport) Firing onclose event.";this._closeError&&(e+=" Error: "+this._closeError),this._logger.log(r.Trace,e),this.onclose(this._closeError)}}}class X{constructor(e,t,n,r){this._httpClient=e,this._accessToken=t,this._logger=n,this._options=r,this.onreceive=null,this.onclose=null}async connect(e,t){return p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.isIn(t,n,"transferFormat"),this._logger.log(r.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise(((s,o)=>{let i,a=!1;if(t===n.Text){if(g.isBrowser||g.isWebWorker)i=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const t=this._httpClient.getCookieString(e),n={};n.Cookie=t;const[r,s]=S();n[r]=s,i=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...n,...this._options.headers}})}try{i.onmessage=e=>{if(this.onreceive)try{this._logger.log(r.Trace,`(SSE transport) data received. ${f(e.data,this._options.logMessageContent)}.`),this.onreceive(e.data)}catch(e){return void this._close(e)}},i.onerror=e=>{a?this._close():o(new Error("EventSource failed to connect. The connection could not be found on the server, either the connection ID is not present on the server, or a proxy is refusing/buffering the connection. If you have multiple servers check that sticky sessions are enabled."))},i.onopen=()=>{this._logger.log(r.Information,`SSE connected to ${this._url}`),this._eventSource=i,a=!0,s()}}catch(e){return void o(e)}}else o(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"))}))}async send(e){return this._eventSource?y(this._logger,"SSE",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}stop(){return this._close(),Promise.resolve()}_close(e){this._eventSource&&(this._eventSource.close(),this._eventSource=void 0,this.onclose&&this.onclose(e))}}class Y{constructor(e,t,n,r,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 s;return p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.isIn(t,n,"transferFormat"),this._logger.log(r.Trace,"(WebSockets transport) Connecting."),this._accessTokenFactory&&(s=await this._accessTokenFactory()),new Promise(((o,i)=>{let a;e=e.replace(/^http/,"ws");const c=this._httpClient.getCookieString(e);let u=!1;if(g.isNode||g.isReactNative){const t={},[n,r]=S();t[n]=r,s&&(t[B.Authorization]=`Bearer ${s}`),c&&(t[B.Cookie]=c),a=new this._webSocketConstructor(e,void 0,{headers:{...t,...this._headers}})}else s&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(s)}`);a||(a=new this._webSocketConstructor(e)),t===n.Binary&&(a.binaryType="arraybuffer"),a.onopen=t=>{this._logger.log(r.Information,`WebSocket connected to ${e}.`),this._webSocket=a,u=!0,o()},a.onerror=e=>{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"There was an error with the transport",this._logger.log(r.Information,`(WebSockets transport) ${t}.`)},a.onmessage=e=>{if(this._logger.log(r.Trace,`(WebSockets transport) data received. ${f(e.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(e.data)}catch(e){return void this._close(e)}},a.onclose=e=>{if(u)this._close(e);else{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"WebSocket failed to connect. The connection could not be found on the server, either the endpoint may not be a SignalR endpoint, the connection ID is not present on the server, or there is a proxy blocking WebSockets. If you have multiple servers check that sticky sessions are enabled.",i(new Error(t))}}}))}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(r.Trace,`(WebSockets transport) sending data. ${f(e,this._logMessageContent)}.`),this._webSocket.send(e),Promise.resolve()):Promise.reject("WebSocket is not in the OPEN state")}stop(){return this._webSocket&&this._close(void 0),Promise.resolve()}_close(e){this._webSocket&&(this._webSocket.onclose=()=>{},this._webSocket.onmessage=()=>{},this._webSocket.onerror=()=>{},this._webSocket.close(),this._webSocket=void 0),this._logger.log(r.Trace,"(WebSockets transport) socket closed."),this.onclose&&(!this._isCloseEvent(e)||!1!==e.wasClean&&1e3===e.code?e instanceof Error?this.onclose(e):this.onclose():this.onclose(new Error(`WebSocket closed with status code: ${e.code} (${e.reason||"no reason given"}).`)))}_isCloseEvent(e){return e&&"boolean"==typeof e.wasClean&&"number"==typeof e.code}}class Q{constructor(e,t={}){var n;if(this._stopPromiseResolver=()=>{},this.features={},this._negotiateVersion=1,p.isRequired(e,"url"),this._logger=void 0===(n=t.logger)?new w(r.Information):null===n?h.instance:void 0!==n.log?n:new w(n),this.baseUrl=this._resolveUrl(e),(t=t||{}).logMessageContent=void 0!==t.logMessageContent&&t.logMessageContent,"boolean"!=typeof t.withCredentials&&void 0!==t.withCredentials)throw new Error("withCredentials option was not a 'boolean' or 'undefined' value");t.withCredentials=void 0===t.withCredentials||t.withCredentials,t.timeout=void 0===t.timeout?1e5:t.timeout;let s=null,o=null;if(g.isNode){const e=require;s=e("ws"),o=e("eventsource")}g.isNode||"undefined"==typeof WebSocket||t.WebSocket?g.isNode&&!t.WebSocket&&s&&(t.WebSocket=s):t.WebSocket=WebSocket,g.isNode||"undefined"==typeof EventSource||t.EventSource?g.isNode&&!t.EventSource&&void 0!==o&&(t.EventSource=o):t.EventSource=EventSource,this._httpClient=new V(t.httpClient||new j(this._logger),t.accessTokenFactory),this._connectionState="Disconnected",this._connectionStarted=!1,this._options=t,this.onreceive=null,this.onclose=null}async start(e){if(e=e||n.Binary,p.isIn(e,n,"transferFormat"),this._logger.log(r.Debug,`Starting connection with transfer format '${n[e]}'.`),"Disconnected"!==this._connectionState)return Promise.reject(new Error("Cannot start an HttpConnection that is not in the 'Disconnected' state."));if(this._connectionState="Connecting",this._startInternalPromise=this._startInternal(e),await this._startInternalPromise,"Disconnecting"===this._connectionState){const e="Failed to start the HttpConnection before stop() was called.";return this._logger.log(r.Error,e),await this._stopPromise,Promise.reject(new E(e))}if("Connected"!==this._connectionState){const e="HttpConnection.startInternal completed gracefully but didn't enter the connection into the connected state!";return this._logger.log(r.Error,e),Promise.reject(new E(e))}this._connectionStarted=!0}send(e){return"Connected"!==this._connectionState?Promise.reject(new Error("Cannot send data if the connection is not in the 'Connected' State.")):(this._sendQueue||(this._sendQueue=new Z(this.transport)),this._sendQueue.send(e))}async stop(e){return"Disconnected"===this._connectionState?(this._logger.log(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState="Disconnecting",this._stopPromise=new Promise((e=>{this._stopPromiseResolver=e})),await this._stopInternal(e),void await this._stopPromise)}async _stopInternal(e){this._stopError=e;try{await this._startInternalPromise}catch(e){}if(this.transport){try{await this.transport.stop()}catch(e){this._logger.log(r.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(r.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let n=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==t.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(t.WebSockets),await this._startTransport(n,e)}else{let t=null,r=0;do{if(t=await this._getNegotiationResponse(n),"Disconnecting"===this._connectionState||"Disconnected"===this._connectionState)throw new E("The connection was stopped during negotiation.");if(t.error)throw new Error(t.error);if(t.ProtocolVersion)throw new Error("Detected a connection attempt to an ASP.NET SignalR Server. This client only supports connecting to an ASP.NET Core SignalR Server. See https://aka.ms/signalr-core-differences for details.");if(t.url&&(n=t.url),t.accessToken){const e=t.accessToken;this._accessTokenFactory=()=>e,this._httpClient._accessToken=e,this._httpClient._accessTokenFactory=void 0}r++}while(t.url&&r<100);if(100===r&&t.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(n,this._options.transport,t,e)}this.transport instanceof J&&(this.features.inherentKeepAlive=!0),"Connecting"===this._connectionState&&(this._logger.log(r.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(e){return this._logger.log(r.Error,"Failed to start the connection: "+e),this._connectionState="Disconnected",this.transport=void 0,this._stopPromiseResolver(),Promise.reject(e)}}async _getNegotiationResponse(e){const t={},[n,s]=S();t[n]=s;const o=this._resolveNegotiateUrl(e);this._logger.log(r.Debug,`Sending negotiation request: ${o}.`);try{const e=await this._httpClient.post(o,{content:"",headers:{...t,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials});if(200!==e.statusCode)return Promise.reject(new Error(`Unexpected status code returned from negotiate '${e.statusCode}'`));const n=JSON.parse(e.content);return(!n.negotiateVersion||n.negotiateVersion<1)&&(n.connectionToken=n.connectionId),n.useStatefulReconnect&&!0!==this._options._useStatefulReconnect?Promise.reject(new R("Client didn't negotiate Stateful Reconnect but the server did.")):n}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof k&&404===e.statusCode&&(t+=" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(r.Error,t),Promise.reject(new R(t))}}_createConnectUrl(e,t){return t?e+(-1===e.indexOf("?")?"?":"&")+`id=${t}`:e}async _createTransport(e,n,s,o){let i=this._createConnectUrl(e,s.connectionToken);if(this._isITransport(n))return this._logger.log(r.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=n,await this._startTransport(i,o),void(this.connectionId=s.connectionId);const a=[],c=s.availableTransports||[];let u=s;for(const s of c){const c=this._resolveTransportOrError(s,n,o,!0===(null==u?void 0:u.useStatefulReconnect));if(c instanceof Error)a.push(`${s.transport} failed:`),a.push(c);else if(this._isITransport(c)){if(this.transport=c,!u){try{u=await this._getNegotiationResponse(e)}catch(e){return Promise.reject(e)}i=this._createConnectUrl(e,u.connectionToken)}try{return await this._startTransport(i,o),void(this.connectionId=u.connectionId)}catch(e){if(this._logger.log(r.Error,`Failed to start the transport '${s.transport}': ${e}`),u=void 0,a.push(new G(`${s.transport} failed: ${e}`,t[s.transport])),"Connecting"!==this._connectionState){const e="Failed to select transport before stop() was called.";return this._logger.log(r.Debug,e),Promise.reject(new E(e))}}}}return a.length>0?Promise.reject(new P(`Unable to connect to the server with any of the available transports. ${a.join(" ")}`,a)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case t.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new Y(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case t.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new X(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case t.LongPolling:return new J(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.features.reconnect?this.transport.onclose=async n=>{let r=!1;if(this.features.reconnect){try{this.features.disconnected(),await this.transport.connect(e,t),await this.features.resend()}catch{r=!0}r&&this._stopConnection(n)}else this._stopConnection(n)}:this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,s,o,i){const a=t[e.transport];if(null==a)return this._logger.log(r.Debug,`Skipping transport '${e.transport}' because it is not supported by this client.`),new Error(`Skipping transport '${e.transport}' because it is not supported by this client.`);if(!function(e,t){return!e||!!(t&e)}(s,a))return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it was disabled by the client.`),new N(`'${t[a]}' is disabled by the client.`,a);if(!(e.transferFormats.map((e=>n[e])).indexOf(o)>=0))return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it does not support the requested transfer format '${n[o]}'.`),new Error(`'${t[a]}' does not support ${n[o]}.`);if(a===t.WebSockets&&!this._options.WebSocket||a===t.ServerSentEvents&&!this._options.EventSource)return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it is not supported in your environment.'`),new b(`'${t[a]}' is not supported in your environment.`,a);this._logger.log(r.Debug,`Selecting transport '${t[a]}'.`);try{return this.features.reconnect=a===t.WebSockets?i:void 0,this._constructTransport(a)}catch(e){return e}}_isITransport(e){return e&&"object"==typeof e&&"connect"in e}_stopConnection(e){if(this._logger.log(r.Debug,`HttpConnection.stopConnection(${e}) called while in state ${this._connectionState}.`),this.transport=void 0,e=this._stopError||e,this._stopError=void 0,"Disconnected"!==this._connectionState){if("Connecting"===this._connectionState)throw this._logger.log(r.Warning,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is still in the connecting state.`),new Error(`HttpConnection.stopConnection(${e}) was called while the connection is still in the connecting state.`);if("Disconnecting"===this._connectionState&&this._stopPromiseResolver(),e?this._logger.log(r.Error,`Connection disconnected with error '${e}'.`):this._logger.log(r.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch((e=>{this._logger.log(r.Error,`TransportSendQueue.stop() threw error '${e}'.`)})),this._sendQueue=void 0),this.connectionId=void 0,this._connectionState="Disconnected",this._connectionStarted){this._connectionStarted=!1;try{this.onclose&&this.onclose(e)}catch(t){this._logger.log(r.Error,`HttpConnection.onclose(${e}) threw error '${t}'.`)}}}else this._logger.log(r.Debug,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is already in the disconnected state.`)}_resolveUrl(e){if(0===e.lastIndexOf("https://",0)||0===e.lastIndexOf("http://",0))return e;if(!g.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const t=window.document.createElement("a");return t.href=e,this._logger.log(r.Information,`Normalizing '${e}' to '${t.href}'.`),t.href}_resolveNegotiateUrl(e){const t=new URL(e);t.pathname.endsWith("/")?t.pathname+="negotiate":t.pathname+="/negotiate";const n=new URLSearchParams(t.searchParams);return n.has("negotiateVersion")||n.append("negotiateVersion",this._negotiateVersion.toString()),n.has("useStatefulReconnect")?"true"===n.get("useStatefulReconnect")&&(this._options._useStatefulReconnect=!0):!0===this._options._useStatefulReconnect&&n.append("useStatefulReconnect","true"),t.search=n.toString(),t.toString()}}class Z{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new ee,this._transportResult=new ee,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new ee),this._transportResult.promise}stop(){return this._executing=!1,this._sendBufferedData.resolve(),this._sendLoopPromise}_bufferData(e){if(this._buffer.length&&typeof this._buffer[0]!=typeof e)throw new Error(`Expected data to be of type ${typeof this._buffer} but was of type ${typeof e}`);this._buffer.push(e),this._sendBufferedData.resolve()}async _sendLoop(){for(;;){if(await this._sendBufferedData.promise,!this._executing){this._transportResult&&this._transportResult.reject("Connection stopped.");break}this._sendBufferedData=new ee;const e=this._transportResult;this._transportResult=void 0;const t="string"==typeof this._buffer[0]?this._buffer.join(""):Z._concatBuffers(this._buffer);this._buffer.length=0;try{await this._transport.send(t),e.resolve()}catch(t){e.reject(t)}}}static _concatBuffers(e){const t=e.map((e=>e.byteLength)).reduce(((e,t)=>e+t)),n=new Uint8Array(t);let r=0;for(const t of e)n.set(new Uint8Array(t),r),r+=t.byteLength;return n.buffer}}class ee{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class te{constructor(){this.name="json",this.version=2,this.transferFormat=n.Text}parseMessages(e,t){if("string"!=typeof e)throw new Error("Invalid input for JSON hub protocol. Expected a string.");if(!e)return[];null===t&&(t=h.instance);const n=d.parse(e),o=[];for(const e of n){const n=JSON.parse(e);if("number"!=typeof n.type)throw new Error("Invalid payload.");switch(n.type){case s.Invocation:this._isInvocationMessage(n);break;case s.StreamItem:this._isStreamItemMessage(n);break;case s.Completion:this._isCompletionMessage(n);break;case s.Ping:case s.Close:break;case s.Ack:this._isAckMessage(n);break;case s.Sequence:this._isSequenceMessage(n);break;default:t.log(r.Information,"Unknown message type '"+n.type+"' ignored.");continue}o.push(n)}return o}writeMessage(e){return d.write(JSON.stringify(e))}_isInvocationMessage(e){this._assertNotEmptyString(e.target,"Invalid payload for Invocation message."),void 0!==e.invocationId&&this._assertNotEmptyString(e.invocationId,"Invalid payload for Invocation message.")}_isStreamItemMessage(e){if(this._assertNotEmptyString(e.invocationId,"Invalid payload for StreamItem message."),void 0===e.item)throw new Error("Invalid payload for StreamItem message.")}_isCompletionMessage(e){if(e.result&&e.error)throw new Error("Invalid payload for Completion message.");!e.result&&e.error&&this._assertNotEmptyString(e.error,"Invalid payload for Completion message."),this._assertNotEmptyString(e.invocationId,"Invalid payload for Completion message.")}_isAckMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Ack message.")}_isSequenceMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Sequence message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const ne={trace:r.Trace,debug:r.Debug,info:r.Information,information:r.Information,warn:r.Warning,warning:r.Warning,error:r.Error,critical:r.Critical,none:r.None};class re{configureLogging(e){if(p.isRequired(e,"logging"),void 0!==e.log)this.logger=e;else if("string"==typeof e){const t=function(e){const t=ne[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new w(t)}else this.logger=new w(e);return this}withUrl(e,t){return p.isRequired(e,"url"),p.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return p.isRequired(e,"protocol"),this.protocol=e,this}withAutomaticReconnect(e){if(this.reconnectPolicy)throw new Error("A reconnectPolicy has already been set.");return e?Array.isArray(e)?this.reconnectPolicy=new L(e):this.reconnectPolicy=e:this.reconnectPolicy=new L,this}withServerTimeout(e){return p.isRequired(e,"milliseconds"),this._serverTimeoutInMilliseconds=e,this}withKeepAliveInterval(e){return p.isRequired(e,"milliseconds"),this._keepAliveIntervalInMilliseconds=e,this}withStatefulReconnect(e){return void 0===this.httpConnectionOptions&&(this.httpConnectionOptions={}),this.httpConnectionOptions._useStatefulReconnect=!0,this._statefulReconnectBufferSize=null==e?void 0:e.bufferSize,this}build(){const e=this.httpConnectionOptions||{};if(void 0===e.logger&&(e.logger=this.logger),!this.url)throw new Error("The 'HubConnectionBuilder.withUrl' method must be called before building the connection.");const t=new Q(this.url,e);return x.create(t,this.logger||h.instance,this.protocol||new te,this.reconnectPolicy,this._serverTimeoutInMilliseconds,this._keepAliveIntervalInMilliseconds,this._statefulReconnectBufferSize)}}class 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,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)}static IsIosNative(){var e;const t=null!=window.webkit&&null!=window.webkit.messageHandlers,n=void 0!==(null===(e=window.nativeEvent)||void 0===e?void 0:e.exalusFindController);return t&&n}}class oe{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function ie(e){return new Map(Object.entries(e))}function ae(e,t="export.csv"){const n=new Blob(["\ufeff",e],{type:"text/csv;charset=utf-8;"}),r=URL.createObjectURL(n),s=document.createElement("a");s.href=r,s.download=t,s.style.display="none",document.body.appendChild(s),s.click(),document.body.removeChild(s),URL.revokeObjectURL(r)}class ce{constructor(){this.TransactionId=se.GenerateUUID()}}var ue,le,de,he,pe,ge,fe,ve,ye,me,we,Se,Ae,_e,Ce;(Ae=ue||(ue={}))[Ae.OK=0]="OK",Ae[Ae.UnknownError=1]="UnknownError",Ae[Ae.FatalError=2]="FatalError",Ae[Ae.WrongData=3]="WrongData",Ae[Ae.ResourceDoesNotExists=4]="ResourceDoesNotExists",Ae[Ae.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",Ae[Ae.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",Ae[Ae.OperationNotPermitted=7]="OperationNotPermitted",Ae[Ae.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",Ae[Ae.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",Ae[Ae.Error=10]="Error",Ae[Ae.NoData=11]="NoData",Ae[Ae.NotSupportedMethod=12]="NotSupportedMethod",Ae[Ae.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",Ae[Ae.MultiDataResponseStart=14]="MultiDataResponseStart",Ae[Ae.MultiDataResponse=15]="MultiDataResponse",Ae[Ae.MultiDataResponseStop=16]="MultiDataResponseStop",function(e){e[e.Get=0]="Get",e[e.Post=1]="Post",e[e.Delete=2]="Delete",e[e.Put=3]="Put",e[e.Options=4]="Options",e[e.Head=5]="Head"}(le||(le={}));class Te{constructor(e,t){this.serialNumber=e,this.pin=t,this.SerialNumber=e,this.PIN=t}}!function(e){e[e.ByCloud=0]="ByCloud",e[e.LocalNetwork=1]="LocalNetwork",e[e.P2P=2]="P2P"}(de||(de={})),function(e){e[e.FailedToConnect=0]="FailedToConnect",e[e.AuthorizationFailed=1]="AuthorizationFailed",e[e.FailedToConnectToServer=2]="FailedToConnectToServer",e[e.Connected=3]="Connected",e[e.ControllerIsNotConnected=4]="ControllerIsNotConnected"}(he||(he={})),function(e){e[e.Disconnected=0]="Disconnected",e[e.Connecting=1]="Connecting",e[e.Connected=3]="Connected",e[e.Disconnecting=4]="Disconnecting",e[e.Failed=5]="Failed",e[e.Reconnecting=6]="Reconnecting",e[e.ConnectedAndAuthorized=7]="ConnectedAndAuthorized"}(pe||(pe={}));class De extends Error{constructor(e){super(e),this.name="StreamError"}}class ke{constructor(){this._log=hy.Get(a.ServiceName),this.handlers=[]}Subscribe(e){this.handlers.includes(e)||this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(){this.handlers.slice(0).forEach((e=>{try{e()}catch(e){this._log.Error(e)}}))}}!function(e){e.CannotExportConfiguration="CannotExportConfiguration"}(ge||(ge={})),(Ce=fe||(fe={}))[Ce.Any=0]="Any",Ce[Ce.Guest=10]="Guest",Ce[Ce.Standard=20]="Standard",Ce[Ce.Admin=30]="Admin",Ce[Ce.Installator=40]="Installator",Ce[Ce.Support=50]="Support",(_e=ve||(ve={}))[_e.Unknown=0]="Unknown",_e[_e.Men=1]="Men",_e[_e.Woman=2]="Woman",_e[_e.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(ye||(ye={})),function(e){e[e.Unknown=0]="Unknown",e[e.WrongAuthData=1]="WrongAuthData",e[e.NoResponseFromController=2]="NoResponseFromController",e[e.AuthDisabled=3]="AuthDisabled",e[e.MethodNotSupported=4]="MethodNotSupported"}(me||(me={}));class Ie{constructor(e,t){this._type=we.Unknown,this._data="",this._type=e,this._data=t}get Type(){return this._type}set Type(e){this._type=e}get Data(){return this._data}set Data(e){this._data=e}}class Ee{constructor(e,t){this._type=null,this._data="",this._type=e,this._data=t}get Type(){return this._type}set Type(e){this._type=e}get Data(){return this._data}set Data(e){this._data=e}}!function(e){e[e.ResourceDoesNotExists=-6]="ResourceDoesNotExists",e[e.UnknownError=-5]="UnknownError",e[e.NoPermissions=-4]="NoPermissions",e[e.WrongData=-3]="WrongData",e[e.ControllerResponseTimeout=-2]="ControllerResponseTimeout",e[e.Failed=-1]="Failed",e[e.Unknown=0]="Unknown",e[e.Changed=1]="Changed"}(we||(we={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(Se||(Se={}));class be{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=Se.Device,this._dateTime=""}get Guid(){return this._guid}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}get Base64Image(){return this._base64Image}get ImageType(){return this._imageType}get DateTime(){return this._dateTime}set Base64Image(e){this._base64Image=e}set Guid(e){this._guid=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}set ImageType(e){this._imageType=e}}var Ne=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 Ge{constructor(){this._imageExistsCaseNumber=0,this._connection=hy.Get(It.ServiceName),this._logger=hy.Get(a.ServiceName)}GetServiceName(){return Ge.ServiceName}AddPictureAsync(e){return Ne(this,void 0,void 0,(function*(){var t,n;try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ge.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ue.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(Ge.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ue.WrongData;if(0===r.height||0===r.width)return this._logger.Error(Ge.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ue.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot add picture - Guid must be empty."),ue.WrongData;const o=new Pe;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 Oe(o.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(Ge.ServiceName,"Cannot add picture - unknown error!"),ue.UnknownError;if(i.Status==ue.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Fe(o),8e3,!1);return null==e||null==e.Status?(this._logger.Error(Ge.ServiceName,"Cannot add picture - unknown error!"),ue.UnknownError):e.Status}return i.Status==ue.OK?(this._logger.Warning(Ge.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ue.UnknownError):(this._logger.Error(Ge.ServiceName,"Cannot add picture - cannot get current picture status."),ue.Error)}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot add picture! ${e}`),ue.FatalError}}))}EditPictureAsync(e){return Ne(this,void 0,void 0,(function*(){var t,n,r,s;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - guid is empty."),ue.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ue.WrongData;let o=new Image;const i=new Promise(((t,n)=>{o.src=e.Base64Image,o.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield i))return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ue.WrongData;if(0===o.height||0===o.width)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ue.WrongData;const a=new Pe;a.DateTime=(new Date).toISOString(),a.ImageType=e.ImageType,a.Base64Image=e.Base64Image,a.Guid=e.Guid,e.Guid.includes("profilePicture")||e.Guid.includes("devices_group")?a.OwnerGuid=e.OwnerGuid:a.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`;const c=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Oe(a.Guid),8e3,!1);if(null===(n=u.Log)||void 0===n||n.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),null==c||null==c.Status)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - unknown error!"),ue.UnknownError;if(c.Status==ue.ResourceDoesNotExists)return this._logger.Error(Ge.ServiceName,"Cannot edit picture - picture not exists."),ue.OperationNotPermitted;if(c.Status==ue.OK){const e=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Fe(a),8e3,!1);return null===(s=u.Log)||void 0===s||s.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(Ge.ServiceName,"Cannot edit picture - unknown error!"),ue.UnknownError):e.Status}return this._logger.Error(Ge.ServiceName,"Cannot edit picture - cannot get current picture status."),ue.Error}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot edit picture! ${e}`),ue.FatalError}}))}DeletePictureAsync(e){return Ne(this,void 0,void 0,(function*(){var t,n;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Ge.ServiceName,"Cannot delete picture - guid is empty."),ue.WrongData;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Le(e.Guid),8e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Ge.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DeletePictureAsync()"),hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),null==r||null==r.Status?(this._logger.Error(Ge.ServiceName,"Cannot delete picture - unknown error!"),ue.UnknownError):r.Status}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot delete picture! ${e}`),ue.FatalError}}))}GetPicturesInfoAsync(){return Ne(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Me,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ge.ServiceName,"Cannot get pictures info - unknown error!"),new Ee(ue.UnknownError,"NoDataInResult")):t.Status!=ue.OK?(this._logger.Error(Ge.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Ee(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ge.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Ee(ue.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ue;return t.DateTime=e.DateTime,t.Guid=e.Guid,t.OwnerGuid=e.OwnerGuid,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot get picture info! ${e}`),new Ee(ue.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){return Ne(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Oe(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(Ge.ServiceName,"Cannot get picture - unknown error!"),new Ee(ue.UnknownError,"NoDataInResult");switch(n.Status){case ue.ResourceDoesNotExists:return new Ee(ue.ResourceDoesNotExists,"PictureNotFound");case ue.OK:if(null==n.Data)return new Ee(ue.Error,"RespondedWithOKButNoData");const e=new Re;return e.Base64Image=n.Data.Base64Image,e.DateTime=n.Data.DateTime,e.ImageType=n.Data.ImageType,e.Guid=n.Data.Guid,-1!=n.Data.OwnerGuid.indexOf("_")?(e.OwnerGuid=n.Data.OwnerGuid.substring(0,n.Data.OwnerGuid.indexOf("_")),e.OwnerIdentity=n.Data.OwnerGuid.substring(n.Data.OwnerGuid.indexOf("_")+1)):n.Data.Guid.includes("profilePicture")?(e.OwnerIdentity=n.Data.Guid.substring(n.Data.Guid.indexOf("_")+1),e.OwnerGuid=n.Data.OwnerGuid):n.Data.Guid.includes("devices_group")?(e.OwnerIdentity=n.Data.Guid.substring(0,n.Data.Guid.lastIndexOf("_")),e.OwnerGuid=n.Data.OwnerGuid):(e.OwnerGuid=n.Data.OwnerGuid,e.OwnerIdentity=""),e;default:return new Ee(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot get picture! ${e}`),new Ee(ue.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){return Ne(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new xe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Ge.ServiceName,"Cannot get pictures - unknown error!"),new Ee(ue.UnknownError,"NoDataInResult")):t.Status!=ue.OK?(this._logger.Error(Ge.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Ee(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Ge.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Ee(ue.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Re;return t.Base64Image=e.Base64Image,t.DateTime=e.DateTime,t.Guid=e.Guid,t.ImageType=e.ImageType,-1!=e.OwnerGuid.indexOf("_")?(t.OwnerGuid=e.OwnerGuid.substring(0,e.OwnerGuid.indexOf("_")),t.OwnerIdentity=e.OwnerGuid.substring(e.OwnerGuid.indexOf("_")+1)):e.Guid.includes("profilePicture")?(t.OwnerIdentity=e.Guid.substring(e.Guid.indexOf("_")+1),t.OwnerGuid=e.OwnerGuid):e.Guid.includes("devices_group")?(t.OwnerIdentity=e.Guid.substring(0,e.Guid.lastIndexOf("_")),t.OwnerGuid=e.OwnerGuid):(t.OwnerGuid=e.OwnerGuid,t.OwnerIdentity=""),t}))}catch(e){return this._logger.Error(Ge.ServiceName,`Cannot get pictures! ${e}`),new Ee(ue.FatalError,"ExceptionOccurred")}}))}}Ge.ServiceName="PictureService";class Re extends be{set DateTime(e){this._dateTime=e}}class Pe{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=Se.Device,this.DateTime=""}}class Ue{constructor(){this._guid="",this._dateTime="",this._ownerGuid="",this._ownerIdentity=""}get Guid(){return this._guid}get DateTime(){return this._dateTime}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}set Guid(e){this._guid=e}set DateTime(e){this._dateTime=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}}class Oe extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Get,this.Data=e}}class Me extends ce{constructor(){super(),this.Resource="/pictures/info",this.Method=le.Get}}class xe extends ce{constructor(){super(),this.Resource="/pictures/list",this.Method=le.Get}}class Fe extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Put,this.Data=e}}class Le extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Delete,this.Data=e}}class Be{constructor(){this._log=hy.Get(a.ServiceName),Be._localStorageService=hy.Get(l.ServiceName)}GetServiceName(){return Be.ServiceName}GetResourceName(e){return`${e.Resource}${e.Method}`}Cache(e){var t;e.Status===ue.OK&&(this._log.Debug(Be.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=Be._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=Be._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug(Be.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),null==n?null:Object.assign(Object.assign({},n),{TransactionId:e.TransactionId})}ClearCache(){var e;null===(e=Be._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug(Be.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=Be._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug(Be.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}Be._localStorageService=null,Be.ServiceName="WebApiCacheService";var $e=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 We{constructor(){this._connection=null,this._connection=hy.Get(It.ServiceName),this._pictureService=hy.Get(Ge.ServiceName),this._sessionService=hy.Get(Xe.ServiceName)}CanEditUser(e){const t=this._sessionService.User;return e.Guid===(null==t?void 0:t.Guid)||this.CanEditUsersOfAccessLevel(e.AccessLevel)}CanEditUsersOfAccessLevel(e){var t;const n=null===(t=this._sessionService.User)||void 0===t?void 0:t.AccessLevel;if(void 0===n)return!1;switch(e){case fe.Support:return n===fe.Support;case fe.Installator:return n>=fe.Installator;case fe.Admin:default:return n>=fe.Admin}}GetServiceName(){return We.ServiceName}GetUsersAsync(){return $e(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ke,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ue.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new ze;n.AccessLevel=t.AccessLevel,n.Email=t.Email,n.Gender=t.Gender,n.Guid=t.Guid,n.IsAccountOnline=t.IsAccountOnline,n.Name=t.Name,n.IsActive=t.IsActive,n.IsBanned=t.IsBanned,n.Phone=t.Phone,n.Surname=t.Surname,e.push(n)})),e}return Promise.resolve([])}if((null==n?void 0:n.Status)==ue.NoData)return Promise.resolve([]);throw null===(t=u.Log)||void 0===t||t.Debug(We.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){return $e(this,void 0,void 0,(function*(){var t,n;if(""===e)return Promise.resolve(null);null==e&&(e="");const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ve(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ue.OK)return null===(n=u.Log)||void 0===n||n.Debug(We.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const s=new ze;return s.AccessLevel=r.Data.AccessLevel,s.Email=r.Data.Email,s.Gender=r.Data.Gender,s.Guid=r.Data.Guid,s.IsAccountOnline=r.Data.IsAccountOnline,s.Name=r.Data.Name,s.IsActive=r.Data.IsActive,s.IsBanned=r.Data.IsBanned,s.Phone=r.Data.Phone,s.Surname=r.Data.Surname,s}))}CreateUserAsync(e,t){return $e(this,void 0,void 0,(function*(){var n;if(null!=e.Guid&&""!=e.Guid)return new Ee(ue.WrongData,"GuidMustBeEmpty");const r=new qe;r.Name=e.Name.trim(),r.Surname=e.Surname.trim(),r.Email=e.Email.trim(),r.Password=t.trim(),r.Phone=e.Phone.trim(),r.Gender=e.Gender,r.AccessLevel=e.AccessLevel;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new He(r),2e4,!1);return hy.Get(Be.ServiceName).ClearCache(),null==s||null==s.Status?new Ee(ue.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Ee(s.Status,s.Data))}))}UpdateUserAsync(e){return $e(this,void 0,void 0,(function*(){var t;if(null==e.Guid||""==e.Guid)return new Ee(ue.WrongData,"GuidCannotBeEmpty");const n=new qe;n.Guid=e.Guid,n.Name=e.Name.trim(),n.Surname=e.Surname.trim(),n.Email=e.Email.trim(),n.Phone=e.Phone.trim(),n.Gender=e.Gender,n.AccessLevel=e.AccessLevel;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new He(n),2e4,!1);return hy.Get(Be.ServiceName).ClearCache(),null==r||null==r.Status?new Ee(ue.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Ee(r.Status,r.Data))}))}ChangePasswordAsync(e,t){return $e(this,void 0,void 0,(function*(){var n;if(null==e.Guid||""==e.Guid)return new Ee(ue.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new Ee(ue.ResourceIsNotAvailable,"CannotGetUser");const s=new qe;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 He(s),2e4,!1);return null==o||null==o.Status?new Ee(ue.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Ee(o.Status,o.Data))}))}DeleteUserAsync(e){return $e(this,void 0,void 0,(function*(){var t,n,r;if(""===e)return ue.WrongData;null==e&&(e="");try{const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new je(e),2e4,!1);return hy.Get(Be.ServiceName).ClearCache(),null==r||null==r.Status?ue.FatalError:(r.Status!=ue.OK&&(null===(n=u.Log)||void 0===n||n.Debug(We.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}catch(e){return null===(r=u.Log)||void 0===r||r.Error(We.ServiceName,`Failed to delete user: ${e}`),ue.FatalError}}))}GetUserProfilePictureAsync(e){return $e(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ee(ue.WrongData,"GuidCannotBeEmpty");const t=yield this._pictureService.GetPicturesInfoAsync();if(null!=t.Type)return t;const n=t.find((t=>"profilePicture"==t.OwnerIdentity&&t.OwnerGuid==e.Guid));if(null!=n){const e=yield this._pictureService.GetPictureAsync(n.Guid);return hy.Get(Be.ServiceName).ClearCache(),e.Type,e}return new Ee(ue.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return $e(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ee(ue.WrongData,"GuidCannotBeEmpty");let n=new be;n.ImageType=Se.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(hy.Get(Be.ServiceName).ClearCache(),r.Type==ue.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ue.OK?new Ee(ue.OK,"PictureSet"):new Ee(e,"PictureServiceError")}if(null!=r.Type)return new Ee(ue.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ue.OK?new Ee(ue.OK,"PictureSet"):new Ee(e,"PictureServiceError")}}))}}We.ServiceName="UsersService";class Ve extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Get,this.Data=e}}class qe{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=ve.Unknown,this.AccessLevel=fe.Any}}class He extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Put,this.Data=e}}class Ke extends ce{constructor(){super(),this.Resource="/users/list",this.Method=le.Get}}class je extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Delete,this.Data=e}}class ze{constructor(){this._guid="",this._cloudGuid="",this._name="",this._surname="",this._phone="",this._email="",this._isAccountOnline=!0,this._isAccountActive=!0,this._isAccountBanned=!0,this._notificationChannels=[],this._gender=ve.Unknown,this._accessLevel=fe.Any,this._localization=ye.En_Us,this._softwareVersion=""}get Guid(){return this._guid}set Guid(e){this._guid=e}get CloudGuid(){return this._cloudGuid}set CloudGuid(e){this._cloudGuid=e}get Name(){return this._name}set Name(e){this._name=e}get Surname(){return this._surname}set Surname(e){this._surname=e}get Phone(){return this._phone}set Phone(e){this._phone=e}get AccessLevel(){return this._accessLevel}set AccessLevel(e){this._accessLevel=e}get Email(){return this._email}set Email(e){this._email=e}get IsAccountOnline(){return this._isAccountOnline}set IsAccountOnline(e){this._isAccountOnline=e}get IsActive(){return this._isAccountActive}set IsActive(e){this._isAccountActive=e}get IsBanned(){return this._isAccountBanned}set IsBanned(e){this._isAccountBanned=e}get NotificationChannels(){return this._notificationChannels}set NotificationChannels(e){this._notificationChannels=e}get Gender(){return this._gender}set Gender(e){this._gender=e}get Localization(){return this._localization}set Localization(e){this._localization=e}get SoftwareVersion(){return this._softwareVersion}set SoftwareVersion(e){this._softwareVersion=e}GetUserProfilePictureAsync(){return hy.Get(We.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return hy.Get(We.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 Xe{constructor(){this._onUserLoggedInEvent=new c,this._onUserLoggedOutEvent=new c,this._email="",this._password="",this._authToken="",this._alreadySubsribedToNetworkEvents=!1,this._isLoggedIn=!1,this._user=null}isLoginError(e){return"number"==typeof e&&void 0!==me[e]}RestoreSessionAsync(){return Je(this,void 0,void 0,(function*(){var e,t,n;if(null===(e=u.Log)||void 0===e||e.Debug(Xe.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0===this._user||null===this._user||!this._isLoggedIn)return!1;let r=yield this.UserLogInAsync(this._email,this._password);if(this.isLoginError(r)){if(null===(t=u.Log)||void 0===t||t.Error(Xe.ServiceName,"RestoreSessionAsync failed, user login failed"),r==me.WrongAuthData)throw new Error("Wrong authentication data!");return!1}return null===(n=u.Log)||void 0===n||n.Debug(Xe.ServiceName,"RestoreSessionAsync completed successfully"),!0}))}WaitForSessionCreationAsync(){return Je(this,void 0,void 0,(function*(){return new Promise((e=>{if(this._isLoggedIn&&null!=this._user)return e();const t=n=>{this._onUserLoggedInEvent.Unsubscribe(t),e()};this._onUserLoggedInEvent.Subscribe(t)}))}))}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;let n=new ce;n.Resource="/users/user/logout",n.Method=le.Put,this._email="",this._password="",(yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ue.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=u.Log)||void 0===e||e.Debug(Xe.ServiceName,"User has been logged out."),this._user=null,hy.Get(Be.ServiceName).ClearCache()):null===(t=u.Log)||void 0===t||t.Debug(Xe.ServiceName,"Failed to logout user!")}))}AuthorizeAppAsync(e){return Je(this,void 0,void 0,(function*(){var t,n,r,s,o;let i=hy.Get(It.ServiceName);const a=yield i.SendAndWaitForResponseAsync(new Qe(e),2e4,!1);if(a.Status==ue.OK&&null!=a.Data){const r=!this._isLoggedIn||(null===(t=this._user)||void 0===t?void 0:t.Guid)!==a.Data.Guid;this._authToken=e;let s=new ze;this._user=s,s.AccessLevel=a.Data.AccessLevel,s.Email=a.Data.Email,this._email=a.Data.Email,s.Gender=a.Data.Gender,s.Guid=a.Data.Guid,s.IsAccountOnline=a.Data.IsAccountOnline,s.Name=a.Data.Name,s.IsActive=a.Data.IsActive,s.IsBanned=a.Data.IsBanned,s.Phone=a.Data.Phone,s.Surname=a.Data.Surname,s.SoftwareVersion=a.Data.SoftwareVersion;let o=hy.Get(ct.ServiceName);return void 0!==a.Data.ConfigurationTime&&null!=a.Data.ConfigurationTime?(ct.ConfigurationTimeRetrieved=new Date(a.Data.ConfigurationTime),yield o.CheckIfConfigurationTimeHasChangedAsync(new Date(a.Data.ConfigurationTime))):yield o.CheckIfConfigurationHasChangedAsync(),r&&hy.Get(Be.ServiceName).ClearCache(),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,hy.Get(It.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>Je(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Xe.ServiceName,`User logged out: ${JSON.stringify(e.Data)}`),this._isLoggedIn=!1,null===(n=this._onUserLoggedOutEvent)||void 0===n||n.Invoke(this._user),this._user=null,hy.Get(Be.ServiceName).ClearCache()}))))),null===(n=u.Log)||void 0===n||n.Debug(Xe.ServiceName,`Did logging in succeded?: ${a.Status==ue.OK}`),this._isLoggedIn=!0,this._onUserLoggedInEvent.Invoke(this._user),s}return a.Status===ue.OperationNotPermitted?(null===(r=u.Log)||void 0===r||r.Debug(Xe.ServiceName,`App login response: ${a.Data}`),me.AuthDisabled):a.Status===ue.ResourceDoesNotExists?(null===(s=u.Log)||void 0===s||s.Debug(Xe.ServiceName,`App login response: ${a.Data}`),me.MethodNotSupported):(null===(o=u.Log)||void 0===o||o.Debug(Xe.ServiceName,`App login response: ${a.Data}`),me.WrongAuthData)}))}UserLogInAsync(e,t){return Je(this,void 0,void 0,(function*(){var n,r,s;let o=hy.Get(It.ServiceName);const i=yield o.SendAndWaitForResponseAsync(new Ze(e,t),2e4,!1);if(i.Status==ue.OK&&null!=i.Data){const s=!this._isLoggedIn||(null===(n=this._user)||void 0===n?void 0:n.Guid)!==i.Data.Guid;this._email=e,this._password=t;let o=new ze;this._user=o,o.AccessLevel=i.Data.AccessLevel,o.Email=i.Data.Email,o.Gender=i.Data.Gender,o.Guid=i.Data.Guid,o.IsAccountOnline=i.Data.IsAccountOnline,o.Name=i.Data.Name,o.IsActive=i.Data.IsActive,o.IsBanned=i.Data.IsBanned,o.Phone=i.Data.Phone,o.Surname=i.Data.Surname,o.SoftwareVersion=i.Data.SoftwareVersion;let a=hy.Get(ct.ServiceName);return void 0!==i.Data.ConfigurationTime&&null!=i.Data.ConfigurationTime?(ct.ConfigurationTimeRetrieved=new Date(i.Data.ConfigurationTime),yield a.CheckIfConfigurationTimeHasChangedAsync(new Date(i.Data.ConfigurationTime))):yield a.CheckIfConfigurationHasChangedAsync(),s&&hy.Get(Be.ServiceName).ClearCache(),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,hy.Get(It.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>Je(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Xe.ServiceName,`User logged out: ${JSON.stringify(e.Data)}`),this._isLoggedIn=!1,null===(n=this._onUserLoggedOutEvent)||void 0===n||n.Invoke(this._user),this._user=null,hy.Get(Be.ServiceName).ClearCache()}))))),null===(r=u.Log)||void 0===r||r.Debug(Xe.ServiceName,`Did logging in succeded?: ${i.Status==ue.OK}`),this._isLoggedIn=!0,this._onUserLoggedInEvent.Invoke(this._user),o}return null===(s=u.Log)||void 0===s||s.Debug(Xe.ServiceName,`User login response: ${i.Data}`),me.WrongAuthData}))}GetServiceName(){return Xe.ServiceName}}Xe.ServiceName="SessionService";class Ye{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class Qe extends ce{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=le.Put}}class Ze extends ce{constructor(e,t){super(),this.Data=new Ye(e,t),this.Resource="/users/user/login",this.Method=le.Put}}class et{constructor(e){if(this.initialCount=e,this._running=0,this._waiting=[],this.Take=()=>{if(this._waiting.length>0&&this._running<this.initialCount){this._running++;const e=this._waiting.shift();null==e||e.Resolve({Release:this.Release})}},this.IsLocked=()=>this._running>0,this.AcquireAsync=()=>this._running<this.initialCount?(this._running++,Promise.resolve({Release:this.Release})):new Promise(((e,t)=>{this._waiting.push({Resolve:e,Reject:t})})),this.Release=()=>{if(0===this._running)throw new Error("Release called more times than AcquireAsync");this._running--,this.Take()},this.Purge=()=>{this._waiting.forEach((e=>{e.Reject(new Error("The semaphore was purged and as a result this task has been cancelled"))})),this._running=0,this._waiting=[]},e<1)throw new Error(`The semaphore was created with a max value of ${e} but the max value cannot be less than 1`)}}var tt=function(e,t,n,r){return new(n||(n=Promise))((function(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 nt{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new et(1)}GetServiceName(){return nt.ServiceName}GetExtensionsInfoAsync(e){return tt(this,arguments,void 0,(function*(e,t=!1){var n;null===(n=u.Log)||void 0===n||n.Debug(nt.ServiceName,`Getting ExtensionsInfo, data loaded from cache: ${!t}`);let r=yield this._semaphore.AcquireAsync();try{this._isExtensionInfoInitialized&&!t||(yield this.GetExtensionInfoFromControllerAsync())}finally{r.Release()}if(0==[...this._extensionInfoCache.values()].length)return[];if(null!=e){const t=this._extensionInfoCache.get(e);if(null==t)throw new ot("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e){return tt(this,arguments,void 0,(function*(e,t=!1,n=!1){var r;if(null===(r=u.Log)||void 0===r||r.Debug(nt.ServiceName,`Getting ProtocolInfo, data loaded from cache: ${!t}`),t&&(yield this.GetProtocolExtensionInfoFromControllerAsync()),0!=[...this._protocolInfoCache.values()].length||n){if(0==[...this._protocolInfoCache.values()].length)throw new ot("Cannot get ProtocolInfo, controler may return empty list of Extensions or other unknown error occurs!")}else yield this.GetProtocolInfoAsync(e,!0,!0);if(null!=e){const t=this._protocolInfoCache.get(e);if(null==t)throw new ot("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return tt(this,void 0,void 0,(function*(){const e=new rt,t=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new ot("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ue.OK)throw new ot(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new ot("Cannot get ExtensionsInfo from controller, controller response does not contain data!");this._extensionInfoCache.clear(),t.Data.forEach((e=>{this._extensionInfoCache.set(e.ExtensionGuid,e)})),0!=[...this._extensionInfoCache.values()].length&&(this._isExtensionInfoInitialized=!0)}))}GetProtocolExtensionInfoFromControllerAsync(){return tt(this,void 0,void 0,(function*(){var e;const t=new st,n=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(t,16e3,!1);if(null==n||null==n.Status)throw new ot("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(n.Status){case ue.OK:if(null==n.Data)throw new ot("Cannot get ProtocolInfo from controller, controller response does not contain data!");this._protocolInfoCache.clear(),n.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ue.ResourceDoesNotExists:null===(e=u.Log)||void 0===e||e.Debug(nt.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new ot(`Cannot get ProtocolInfo from controller! Response status: ${n.Status}`)}}))}}nt.ServiceName="StatisticsInfoService";class rt extends ce{constructor(){super(),this.Resource="/controller/extensions/",this.Method=le.Get}}class st extends ce{constructor(){super(),this.Resource="/controller/protocols/",this.Method=le.Get}}class ot extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}var it,at=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 ct{OnConfigurationChangedEvent(){return this._onConfigurationChangedEvent}GetServiceName(){return ct.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new ke,this._onExitedConfigurationEvent=new ke,this._onConfigurationTimeCheckedEvent=new c,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!0,this._didSynchronization=!1,this._onSynchronized=new ke,this._onConfigurationChangedEvent=new ke,this._connection=hy.Get(It.ServiceName),this._session=hy.Get(Xe.ServiceName),this._localStorage=hy.Get(l.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{hy.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{var t;hy.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke(),null===(t=this.OnConfigurationChangedEvent())||void 0===t||t.Invoke()}))}CheckIfControllerSoftwareVersionIsEnough(e,t){var n,r,s;const o=null!==(s=null===(r=null===(n=this._session)||void 0===n?void 0:n.User)||void 0===r?void 0:r.SoftwareVersion)&&void 0!==s?s:null;if(!o||!o.includes("."))return!1;const i=o.split(".");if(2!==i.length)return!1;const a=i.map((e=>parseInt(e,10)));if(a.some((e=>Number.isNaN(e)||e<0)))return!1;const[c,u]=a;return c>e||c===e&&u>=t}ImportControllerConfigurationAsync(e){return at(this,void 0,void 0,(function*(){var t,n,r;let s=yield e.text(),o=this.SplitStringBySize(s),i=new ut("");i.Status=ue.MultiDataResponseStart;let a=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(i,6e3,!1);if(void 0===a||(null==a?void 0:a.Status)!=ue.OK)return ue.Error;for(const e of o){let t=new ut(e);t.Status=ue.MultiDataResponse;let r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(t,6e3,!1);if(void 0===r||(null==r?void 0:r.Status)!=ue.OK)return ue.Error}i.Status=ue.MultiDataResponseStop;let c=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(i,12e4,!1);return void 0===c||(null==c?void 0:c.Status)!=ue.OK?ue.Error:ue.OK}))}SplitStringBySize(e,t=1e5){const n=Math.floor(t/2),r=[];let 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 at(this,void 0,void 0,(function*(){var e,t;try{let t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new yt,8e3,!1);return null==t||null==t.Status?ue.Error:t.Status!=ue.OK?t.Status:null==t.Data?ue.ResourceIsNotAvailable:new Date(t.Data)}catch(e){return null===(t=u.Log)||void 0===t||t.Error(ct.ServiceName,`Cannot get current controller time! ${e}`),ue.FatalError}}))}SetControllerSystemTimeAsync(e){return at(this,void 0,void 0,(function*(){var t,n;try{let n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new mt(e.toISOString()),8e3,!1);return null==n||null==n.Status?ue.Error:n.Status}catch(e){return null===(n=u.Log)||void 0===n||n.Error(ct.ServiceName,`Cannot set current controller time! ${e}`),ue.FatalError}}))}StartNtpTimeSynchronizationAsync(){return at(this,void 0,void 0,(function*(){var e,t;try{let t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new wt,8e3,!1);return null==t||null==t.Status?ue.Error:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(ct.ServiceName,`Cannot set current controller time! ${e}`),ue.FatalError}}))}FactoryResetAsync(e){return at(this,void 0,void 0,(function*(){var t,n;try{hy.Get(Be.ServiceName).ClearCache();let r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ht,2e3,!1))||void 0===n?void 0:n.Status;if(r==ue.OK){let t=300,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield oe.Delay(1e3*t),hy.Get(Be.ServiceName).ClearCache(),clearInterval(s),ue.OK}return r}catch(e){return ue.FatalError}}))}RollbackLastUpdateAsync(e){return at(this,void 0,void 0,(function*(){var t,n;try{hy.Get(Be.ServiceName).ClearCache();let r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new pt,2e3,!1))||void 0===n?void 0:n.Status;if(r==ue.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),hy.Get(Be.ServiceName).ClearCache(),clearInterval(s),ue.OK}return r}catch(e){return ue.FatalError}}))}RestartControllerAsync(e){return at(this,void 0,void 0,(function*(){var t,n;try{hy.Get(Be.ServiceName).ClearCache();let r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new dt,2e3,!1))||void 0===n?void 0:n.Status;if(r==ue.OK){let t=240,n=0,r=100/t,s=setInterval((()=>{n+=r,e(parseFloat(n.toPrecision(1)))}),1e3);return yield oe.Delay(1e3*t),hy.Get(Be.ServiceName).ClearCache(),clearInterval(s),ue.OK}return r}catch(e){return ue.FatalError}}))}DidCofigurationChangeAsync(){return at(this,void 0,void 0,(function*(){return new Promise((e=>{var t;this._didSynchronization?e(this._didConfigurationChange):null===(t=this._onSynchronized)||void 0===t||t.Subscribe((()=>{e(this._didConfigurationChange)}))}))}))}GetLastKnownConfigurationChangeTime(){var e;const t=null===(e=this._localStorage)||void 0===e?void 0:e.Read(this.GetServiceName(),"last_configuration_time");return null!=t?new Date(t):new Date}SaveLastConfigurationChangeTime(e){var t;null===(t=this._localStorage)||void 0===t||t.Save(this.GetServiceName(),"last_configuration_time",e.toString())}EnterConfigurationModeAsync(){return at(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,hy.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new gt,2e4,!1)}))}ExitConfigurationModeAsync(){return at(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,hy.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ft,2e4,!1),this._didConfigurationChange=!0,hy.Get(Be.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._didConfigurationChange=!0,this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){return at(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new vt,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ue.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return at(this,void 0,void 0,(function*(){var e,t,n,r;const s=yield this.GetLastConfigurationChangeTimeAsync();return null===(e=u.Log)||void 0===e||e.Info(ct.ServiceName,`Checking if configuration time has changed. Current: ${s.toString()}, Last known: ${this.GetLastKnownConfigurationChangeTime().toString()}`),this.GetLastKnownConfigurationChangeTime().toString()!=s.toString()?(this.SaveLastConfigurationChangeTime(s),hy.Get(Be.ServiceName).ClearCache(),this._didSynchronization=!0,this._didConfigurationChange=!0,null===(t=this.OnConfigurationChangedEvent())||void 0===t||t.Invoke(),this._onConfigurationTimeCheckedEvent.Invoke(s),null===(n=this._onSynchronized)||void 0===n||n.Invoke(),!0):(this._didSynchronization=!0,this._didConfigurationChange=!1,null===(r=this._onSynchronized)||void 0===r||r.Invoke(),!1)}))}CheckIfConfigurationTimeHasChangedAsync(e){return at(this,void 0,void 0,(function*(){var t,n,r,s;return null===(t=u.Log)||void 0===t||t.Info(ct.ServiceName,`Checking if configuration time has changed. Current: ${e.toString()}, Last known: ${this.GetLastKnownConfigurationChangeTime().toString()}`),this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()?(this.SaveLastConfigurationChangeTime(e),hy.Get(Be.ServiceName).ClearCache(),this._didSynchronization=!0,this._didConfigurationChange=!0,null===(n=this.OnConfigurationChangedEvent())||void 0===n||n.Invoke(),this._onConfigurationTimeCheckedEvent.Invoke(e),null===(r=this._onSynchronized)||void 0===r||r.Invoke(),!0):(this._didSynchronization=!0,this._didConfigurationChange=!1,null===(s=this._onSynchronized)||void 0===s||s.Invoke(),!1)}))}CanExportOrImportControllerConfigurationAsync(){return at(this,void 0,void 0,(function*(){try{let e=yield hy.Get(nt.ServiceName).GetExtensionsInfoAsync(),t=hy.Get(Xe.ServiceName).User;return null!=t&&null!=t.AccessLevel&&t.AccessLevel>=fe.Admin&&e.any((e=>"f4f0f066-7c43-46c6-a0bd-aedf93903dc0"==e.ExtensionGuid))}catch(e){return!1}}))}ExportControllerConfigurationAsync(){return at(this,void 0,void 0,(function*(){var e;let t=[],n=null;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndHandleResponseAsync(new lt,3e4,(e=>{switch(e.Status){case ue.MultiDataResponseStart:break;case ue.MultiDataResponse:null!=e.Data&&void 0!==e.Data&&t.push(e.Data);break;case ue.MultiDataResponseStop:break;case ue.Error:case ue.FatalError:n=new Ee(ge.CannotExportConfiguration,"Cannot export configuration! Controller returned error!")}}),!0);let r=JSON.stringify(JSON.parse(t.join("")),null,2);return console.log(r),null!=n?n:hy.ExportStringAsFileToDownload(this.GetCurrentTimestampedFilename(),r)}))}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`}}ct.ServiceName="ControllerConfigurationService",ct.ConfigurationTimeRetrieved=null;class ut extends ce{constructor(e){super(),this.Resource="/configuration/backup/import",this.Method=le.Put,this.Data=e}}class lt extends ce{constructor(){super(),this.Resource="/configuration/backup/export",this.Method=le.Get}}class dt extends ce{constructor(){super(),this.Resource="/controller/restart",this.Method=le.Post}}class ht extends ce{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=le.Post}}class pt extends ce{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=le.Post}}class gt extends ce{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=le.Put}}class ft extends ce{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=le.Put}}class vt extends ce{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=le.Get}}class yt extends ce{constructor(){super(),this.Resource="/system/time",this.Method=le.Get}}class mt extends ce{constructor(e){super(),this.Resource="/system/time",this.Method=le.Put,this.Data=e}}class wt extends ce{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=le.Put}}!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"}(it||(it={}));class St{constructor(){this._promise=Promise.resolve(),this._disable=()=>{}}Lock(){this._promise=new Promise((e=>this._disable=e))}Unlock(){this._disable()}WaitForLockAsync(){return this._promise}}var At=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 _t{constructor(){if(this._isConnectedAndAuthorized=!1,this._syncLock=new St,this._isInFouces=!0,this._lastVisibilityState=null,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=it.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new ke,this._onSuspendedEvent=new ke,this._onEnterLowPowerModeEvent=new ke,this._onExitLowPowerModeEvent=new ke,this._onBackButtonPressedEvent=new ke,this._onForwardButtonPressedEvent=new ke,this._onAppStateChanged=new c,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),this._lastVisibilityState=this.IsHidden(),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices){const e=()=>At(this,void 0,void 0,(function*(){yield this._syncLock.WaitForLockAsync(),this._syncLock.Lock();try{const e=this.IsHidden();if(this._lastVisibilityState===e)return;this._lastVisibilityState=e,e?this.Suspend():this.ReturnFromSuspension()}finally{this._syncLock.Unlock()}}));document.addEventListener("visibilitychange",e),window.addEventListener("visibilitychange",e)}else{const e=()=>{this._isInFouces&&(this._isInFouces=!1,this.Suspend())},t=()=>{this._isInFouces||(this._isInFouces=!0,this.ReturnFromSuspension())};window.addEventListener("blur",e),window.addEventListener("onblur",e),window.addEventListener("focus",t),window.addEventListener("onfocus",t)}window.addEventListener("popstate",(e=>{var t,n,r,s;document.location,e.state&&("forward"==e.state.direction?(null===(t=u.Log)||void 0===t||t.Warning(_t.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=u.Log)||void 0===r||r.Warning(_t.ServiceName,"Back button pressed"),null===(s=this._onBackButtonPressedEvent)||void 0===s||s.Invoke()))}))}MonitorAppState(){return At(this,void 0,void 0,(function*(){this._session=yield hy.GetAsync("SessionService"),this._connection=yield hy.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(_t.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(it.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(_t.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(it.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,r,s,o,i;switch(e){case pe.ConnectedAndAuthorized:null===(t=u.Log)||void 0===t||t.Warning(_t.ServiceName,"App state changed to: connected"),this._isConnectedAndAuthorized=!0,this._onAppStateChanged.Invoke(it.Connected);break;case pe.Disconnected:null===(n=u.Log)||void 0===n||n.Warning(_t.ServiceName,"App state changed to: disconnected"),this._isConnectedAndAuthorized&&this._onAppStateChanged.Invoke(it.Disconnected),this._isConnectedAndAuthorized=!1;break;case pe.Connecting:null===(r=u.Log)||void 0===r||r.Warning(_t.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(it.Connecting);break;case pe.Disconnecting:null===(s=u.Log)||void 0===s||s.Warning(_t.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(it.Disconnecting);break;case pe.Reconnecting:null===(o=u.Log)||void 0===o||o.Warning(_t.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(it.Reconnecting);break;case pe.Failed:null===(i=u.Log)||void 0===i||i.Warning(_t.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(it.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(it.Suspended),null===(e=u.Log)||void 0===e||e.Warning(_t.ServiceName,"App state changed to: suspended"),null===(t=u.Log)||void 0===t||t.Warning(_t.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(it.ReturnedFromSuspension),null===(e=u.Log)||void 0===e||e.Warning(_t.ServiceName,"App state changed to: returned from suspension"),null===(t=u.Log)||void 0===t||t.Warning(_t.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(it.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(it.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 _t.ServiceName}}_t.ServiceName="AppStateService";var Ct=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 Tt{nextRetryDelayInMilliseconds(){return 1e3}}const Dt=[t.WebSockets,t.ServerSentEvents,t.LongPolling];class kt{constructor(){this._log=hy.Get(a.ServiceName)}log(e,t){if(!(e<It.SignalRLogLevel))switch(t=`[SignalR] ${t}`,e){case r.Critical:case r.Error:this._log.Error(t);break;case r.Warning:this._log.Warning(t);break;case r.Information:this._log.Info(t);break;default:this._log.Debug(t)}}}class It{constructor(){this._connectTask=null,this._authorizeTask=null,this._pingTimerId=null,this._consecutivePingFailures=0,this._disconnectedOnPurpose=!1,this._address="packets-broker1.tr7.pl",this._serversBrokerAddress="https://servers-broker.tr7.pl",this._serversBrokerAddressList=["https://servers-broker.tr7.pl","https://broker.tr7.pl","https://dev-broker.tr7.pl"],this._allBrokersChecked=!1,this._packetsBrokerServers=["packets-broker1.tr7.pl","packets-broker2.tr7.pl"],this._isAuthorized=!1,this._lastReceivedPacket=Date.now(),this._everConnected=!1,this._pendingRequests=new Map,this._log=hy.Get(a.ServiceName),this._appState=hy.Get(_t.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._dataReceivedEvent=new c,this._pongReceivedEvent=new ke,this._authorizationReceivedEvent=new c,this._registrationReceivedEvent=new c,this._streamStartedEvent=new c,this._connectionStateChangedEvent=new c,this._errorOccuredEvent=new c,this._tryReconnect=()=>{this._connectTask||navigator.onLine&&this.validateConnectionToController().then((e=>{e||(this._log.Debug(It.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))},this._onVisibility=()=>{this._connectTask||"visible"===document.visibilityState&&(this._log.Debug(It.ServiceName,"Page visible → connection check"),this.validateConnectionToController().then((e=>{e||(this._log.Debug(It.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())})))},this._onHidden=()=>{},this._onVisible=()=>{this._connectTask||this.validateConnectionToController().then((e=>{e||(this._log.Debug(It.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))},this._appState.OnAppStateChanged().Subscribe((e=>Ct(this,void 0,void 0,(function*(){var t;switch(this._log.Debug(It.ServiceName,`App state changed: ${e}`),e){case it.ExitedLowPowerMode:case it.ReturnedFromSuspension:this._log.Debug(It.ServiceName,`Handling app state change: ${e}`),(yield this.RestoreConnectionAsync())&&(null===(t=this._session)||void 0===t||t.RestoreSessionAsync())}}))))}GetServiceName(){return It.ServiceName}GetAuthorizationInfo(){return this._serialId&&this._PIN?new Te(this._serialId,this._PIN):null}GetControllerSerialNumber(){return this._serialId}GetControllerPin(){return this._PIN}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._address=e}EnablePacketsLogging(){window.packets=!0}DisablePacketsLogging(){window.packets=!1}SubscribeTo(e,t){const n=n=>{n.Resource===e&&t(n)};return this._dataReceivedEvent.Subscribe(n),()=>this._dataReceivedEvent.Unsubscribe(n)}reauthorizeIfPossible(){return Ct(this,void 0,void 0,(function*(){if(!this._serialId||!this._PIN)return this._isAuthorized=!1,!1;const e=yield this.AuthorizeAsync(new Te(this._serialId,this._PIN));return this._isAuthorized=e,e}))}GetServerAddressAsync(){return Ct(this,void 0,void 0,(function*(){if(!this._serialId)return this._log.Warning(It.ServiceName,"GetServerAddressAsync() – serialId not set"),null;const e=`${this._serversBrokerAddress}/api/connections/broker/whichserver/${this._serialId}`;try{const t=yield fetch(e);switch(t.status){case 200:{const e=(yield t.text()).trim();return e?(this._log.Debug(It.ServiceName,`Broker address resolved: ${e}`),e):(this._log.Warning(It.ServiceName,"Broker returned empty address"),null)}case 204:return this._allBrokersChecked?(this._log.Error(It.ServiceName,"All servers-brokers checked, controller not found – likely offline"),null):(this._log.Warning(It.ServiceName,`Servers-broker ${this._serversBrokerAddress} returned 204 (no content) – controller not found on this server`),yield this.rotateServersBroker(),this.GetServerAddressAsync());default:return this._log.Warning(It.ServiceName,`GetServerAddressAsync() – HTTP ${t.status}`),null}}catch(e){return this._log.Error(It.ServiceName,String(e)),null}}))}rotateServersBroker(){return Ct(this,void 0,void 0,(function*(){const e=this._serversBrokerAddressList.indexOf(this._serversBrokerAddress),t=e+1<this._serversBrokerAddressList.length?e+1:0;this._serversBrokerAddress=this._serversBrokerAddressList[t],this._allBrokersChecked=0===t,this._log.Info(It.ServiceName,`Switching servers-broker to: ${this._serversBrokerAddress}`)}))}ConnectAsync(e){return Ct(this,void 0,void 0,(function*(){return this._address=e,this.serialisedConnect()}))}ConnectAndAuthorizeAsync(e){return Ct(this,void 0,void 0,(function*(){this._serialId=e.serialNumber,this._PIN=e.pin,hy.WorksInContextOf=this._serialId,this._allBrokersChecked=!1,this._serversBrokerAddress=this._serversBrokerAddressList[0];const t=yield this.GetServerAddressAsync();if(t&&(this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===he.Connected&&(yield this.AuthorizeAsync(e))))return he.Connected;for(const t of this._packetsBrokerServers)if(this._log.Info(It.ServiceName,`Fallback broker: ${t}`),this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===he.Connected&&(yield this.AuthorizeAsync(e)))return this._disconnectedOnPurpose=!1,he.Connected;return he.FailedToConnect}))}AuthorizeAsync(e){return Ct(this,void 0,void 0,(function*(){return this._authorizeTask||(this._authorizeTask=new Promise((t=>Ct(this,void 0,void 0,(function*(){var n;const r=window.setTimeout((()=>{this._authorizationReceivedEvent.Unsubscribe(s),this._isAuthorized=!1,this._log.Debug(It.ServiceName,`AuthorizeAsync timed out for id ${r}`),t(!1)}),2e3);this._log.Debug(It.ServiceName,`AuthorizeAsync - created timeoutId ${r}`);const s=e=>{window.clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(s),this._log.Debug(It.ServiceName,`Authorization → ${e}`),this._isAuthorized=e,e&&this._connectionStateChangedEvent.Invoke(pe.ConnectedAndAuthorized),this._log.Debug(It.ServiceName,`AuthorizeAsync isAuthorized: ${e} cleared timeoutId ${r}`),t(e)};this._authorizationReceivedEvent.Subscribe(s),this._log.Debug(It.ServiceName,`Authorizing to ${e.SerialNumber}... for timoeoutId ${r}`),yield null===(n=this._connection)||void 0===n?void 0:n.send("AuthorizeTo",e.SerialNumber,e.PIN)})))).finally((()=>{this._authorizeTask=null}))),this._authorizeTask}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===o.Connected}DisconnectAsync(){return Ct(this,void 0,void 0,(function*(){var e;this._disconnectedOnPurpose=!0,this._log.Debug(It.ServiceName,"Disconnecting..."),yield null===(e=this._connection)||void 0===e?void 0:e.stop(),this.cleanup()}))}SendAsync(e){return Ct(this,arguments,void 0,(function*(e,t=!1){var n,r;if(!this.IsConnected())throw new Error("Not connected");const s=()=>Ct(this,void 0,void 0,(function*(){yield this._connection.invoke("SendTo",this._serialId,e)})),o=!0===window.packets;(o||t)&&this._log.Debug(It.ServiceName,`⇢ ${e.Resource} ${e.Method} ${e.TransactionId}`+(o?`\n${JSON.stringify(e,null,2)}`:""));try{return yield s(),!0}catch(e){if(String(null!==(n=null==e?void 0:e.message)&&void 0!==n?n:e).toLowerCase().includes("unauthorized")){if(!(yield this.reauthorizeIfPossible())){this._allBrokersChecked=!1,this._serversBrokerAddress=this._serversBrokerAddressList[0];const e=yield this.GetServerAddressAsync();if(e&&e!==this._address){this._log.Info(It.ServiceName,`Switching to resolved broker: ${e}`);try{yield null===(r=this._connection)||void 0===r?void 0:r.stop()}catch(e){}this.cleanup(),yield this.ConnectAsync(e),yield this.reauthorizeIfPossible()}}if(this.IsConnected()&&this._isAuthorized)try{return yield s(),!0}catch(t){e=t}}return this._log.Error(It.ServiceName,String(e)),!1}}))}RestoreConnectionAsync(){return Ct(this,void 0,void 0,(function*(){var e,t;if(this._disconnectedOnPurpose)return!1;const n=this.GetAuthorizationInfo();if(null===n)return null===(e=u.Log)||void 0===e||e.Error(It.ServiceName,"RestoreSessionAsync failed, no authorization info"),!1;const r=Date.now();let s=0;do{if(this.IsConnected()&&(yield this.AuthorizeAsync(n)))return!0;if((yield this.ConnectAndAuthorizeAsync(n))===he.Connected)return!0;const e=Math.min(3e4,5e3*Math.pow(2,s++));yield new Promise((t=>setTimeout(t,e))),this._allBrokersChecked=!1,this._serversBrokerAddress=this._serversBrokerAddressList[0]}while(Date.now()-r<18e5);return null===(t=u.Log)||void 0===t||t.Error(It.ServiceName,"RestoreSessionAsync failed, authorization failed"),!1}))}SendAndWaitForResponseAsync(e,t,n){return Ct(this,arguments,void 0,(function*(e,t,n,r=!0,s=!0){var o,i,a;if(e.Method===le.Get&&n&&!(yield null===(o=this._controllerConfiguration)||void 0===o?void 0:o.DidCofigurationChangeAsync())){const t=null===(i=this._cache)||void 0===i?void 0:i.GetCache(e);if(t)return t}if(!this.IsConnected()&&!(yield this.RestoreConnectionAsync()))throw new Error("Failed to restore connection!");return"/users/user/login"!==e.Resource&&(yield null===(a=this._session)||void 0===a?void 0:a.WaitForSessionCreationAsync()),new Promise(((o,i)=>Ct(this,void 0,void 0,(function*(){const a=window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(c),this._pendingRequests.delete(e.TransactionId),i(new I("Response timeout"))}),t),c=u=>{var l;u.TransactionId===e.TransactionId&&(window.clearTimeout(a),this._dataReceivedEvent.Unsubscribe(c),this._pendingRequests.delete(e.TransactionId),e.Method===le.Get&&n&&u.Status!==ue.UserIsNotLoggedIn&&(null===(l=this._cache)||void 0===l||l.Cache(u)),s&&u.Status===ue.UserIsNotLoggedIn?(()=>{Ct(this,void 0,void 0,(function*(){var s;try{yield null===(s=this._session)||void 0===s?void 0:s.RestoreSessionAsync(),o(yield this.SendAndWaitForResponseAsync(e,t,n,r,!1))}catch(e){i(e)}}))})():o(u))};this._dataReceivedEvent.Subscribe(c),this._pendingRequests.set(e.TransactionId,{resolve:e=>o(e),reject:i,timeoutId:a}),(yield this.SendAsync(e,r))||(window.clearTimeout(a),this._dataReceivedEvent.Unsubscribe(c),this._pendingRequests.delete(e.TransactionId),i(new Error("Failed to send request")))}))))}))}SendAndHandleResponseAsync(e,t,n){return Ct(this,arguments,void 0,(function*(e,t,n,r=!0){var s;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,o)=>Ct(this,void 0,void 0,(function*(){const i=()=>window.setTimeout((()=>{c(),o(new I("MultiDataResponse timeout"))}),t);let a=i();const c=()=>{window.clearTimeout(a),this._dataReceivedEvent.Unsubscribe(u),this._pendingRequests.delete(e.TransactionId)},u=t=>{if(t.TransactionId===e.TransactionId)switch(window.clearTimeout(a),t.Status){case ue.MultiDataResponseStart:case ue.MultiDataResponse:n(t),a=i();break;case ue.MultiDataResponseStop:case ue.OK:n(t),c(),s();break;default:c(),o(new Error(`Unexpected status ${t.Status}`))}};this._dataReceivedEvent.Subscribe(u),this._pendingRequests.set(e.TransactionId,{resolve:()=>s(),reject:o,timeoutId:a}),(yield this.SendAsync(e,r))||(c(),o(new Error("Failed to send request")))}))))}))}SendAndHandleStreamAsync(e,t){return Ct(this,arguments,void 0,(function*(e,t,n=!0){var r;if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(r=this._session)||void 0===r?void 0:r.WaitForSessionCreationAsync()),new Promise(((r,s)=>Ct(this,void 0,void 0,(function*(){const o=window.setTimeout((()=>{this._streamStartedEvent.Unsubscribe(i),s(new I("Stream registration timeout"))}),8e3),i=n=>{n===e.TransactionId&&(window.clearTimeout(o),this._streamStartedEvent.Unsubscribe(i),this._connection.stream("WatchStream",n).subscribe({next:e=>t.Next(e),complete:()=>{t.Complete(),r()},error:e=>{t.Error(e),s(new De(String(e)))}}))};this._streamStartedEvent.Subscribe(i),(yield this.SendAsync(e,n))||(window.clearTimeout(o),this._streamStartedEvent.Unsubscribe(i),s(new Error("Failed to send request")))}))))}))}PingControllerAsync(){return Ct(this,void 0,void 0,(function*(){if(!this.IsConnected()||!this._isAuthorized)return!1;if(Date.now()-this._lastReceivedPacket<It.PING_INTERVAL_MS)return!1;const e=new ce;e.Resource="/system/ping",e.Method=le.Get;try{return yield this.SendAndWaitForResponseAsync(e,2e3,!1,!1),!0}catch(e){return!1}}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}serialisedConnect(){return this._connectTask||(this._connectTask=this.connectCore().finally((()=>this._connectTask=null))),this._connectTask}waitForState(e){return Ct(this,arguments,void 0,(function*(e,t=1e4){var n;const r=Date.now();for(;;){const s=null===(n=this._connection)||void 0===n?void 0:n.state;if(null!=s&&e.includes(s))return;if(Date.now()-r>t)throw new Error(`waitForState timeout; state=${s}`);yield new Promise((e=>setTimeout(e,50)))}}))}connectCore(){return Ct(this,void 0,void 0,(function*(){var n,s;if(!this._address)return he.ControllerIsNotConnected;if(this._connection&&this._currentAddress!==this._address){this._log.Info(It.ServiceName,"Broker changed → rebuilding connection");try{yield this._connection.stop()}catch(e){}this.cleanup()}if(this._connection){const e=this._connection.state;if(e===o.Connected)return this._isAuthorized||(yield this.reauthorizeIfPossible()),he.Connected;if(e===o.Connecting||e===o.Reconnecting){this._log.Info(It.ServiceName,"Existing connection is starting/reconnecting – waiting.");try{yield this.waitForState([o.Connected,o.Disconnected])}catch(e){}if((null===(n=this._connection)||void 0===n?void 0:n.state)===o.Connected)return this._isAuthorized||(yield this.reauthorizeIfPossible()),he.Connected}e===o.Disconnecting&&(yield this.waitForState([o.Disconnected]).catch((()=>{})))}this.initializeServices(),this.cleanup();for(const n of Dt){const o=(new re).withAutomaticReconnect(new Tt).configureLogging(new kt).withStatefulReconnect({bufferSize:256e3}).withServerTimeout(It.SERVER_TIMOUT_MS).withKeepAliveInterval(It.PING_INTERVAL_MS-1e3).withUrl(`https://${this._address}/broker`,{skipNegotiation:n===t.WebSockets,transport:n});this._log.LogLevel===e.Debug&&o.configureLogging(r.Debug);const i=o.build();this._connection=i,this._currentAddress=this._address,this.wireConnectionEvents();try{return yield i.start(),yield this.reauthorizeIfPossible(),this.startPingLoop(),this._connectionStateChangedEvent.Invoke(pe.Connected),he.Connected}catch(e){this._log.Warning(It.ServiceName,`Transport ${t[n]} failed (${null==e?void 0:e.message}).`);try{yield i.stop()}catch(e){}try{null===(s=null==i?void 0:i.off)||void 0===s||s.call(i)}catch(e){}}}return this._connectionStateChangedEvent.Invoke(pe.Failed),he.FailedToConnect}))}waitForReconnection(e=0){return new Promise(((t,n)=>{if(!this._connection||this._connection.state!==o.Reconnecting)return void n(new Error("Connection is not in reconnecting state"));let r;e>0&&(r=window.setTimeout((()=>{this._connectionStateChangedEvent.Unsubscribe(s),n(new Error("Reconnection timeout"))}),e));const s=e=>{e===pe.Connected?(r&&window.clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(s),t()):e!==pe.Disconnected&&e!==pe.Failed||(r&&window.clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(s),n(new Error("Connection closed during reconnection")))};this._connectionStateChangedEvent.Subscribe(s),this._connection.state!==o.Reconnecting&&(r&&window.clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(s),this._connection.state===o.Connected?t():n(new Error(`Connection is in unexpected state: ${this._connection.state}`)))}))}initializeServices(){this._controllerConfiguration=hy.Get(ct.ServiceName),this._cache=hy.Get(Be.ServiceName),this._session=hy.Get(Xe.ServiceName)}wireConnectionEvents(){this._connection&&(this._connection.on("Pong",(()=>{this._lastReceivedPacket=Date.now(),this._pongReceivedEvent.Invoke()})),this._connection.on("controllerdisconnected",(()=>{this._isAuthorized=!1,this._connectionStateChangedEvent.Invoke(pe.Disconnected)})),this._connection.on("Authorization",(e=>this._authorizationReceivedEvent.Invoke(e))),this._connection.on("Registration",(e=>this._registrationReceivedEvent.Invoke(e))),this._connection.on("SendError",((e,t)=>{e.startsWith("NotAuthorized:")?this.AuthorizeAsync(new Te(this._serialId,this._PIN)):this._errorOccuredEvent.Invoke([e,t])})),this._connection.on("Data",((e,t)=>{this._lastReceivedPacket=Date.now(),!0===window.packets&&this._log.Debug(It.ServiceName,`Received: ${JSON.stringify(JSON.parse(t),null,2)}`),this._dataReceivedEvent.Invoke(JSON.parse(t))})),this._connection.onclose((()=>{this._isAuthorized=!1,this.cleanup(),this._connectionStateChangedEvent.Invoke(pe.Disconnected)})),this._connection.onreconnecting((()=>this._connectionStateChangedEvent.Invoke(pe.Reconnecting))),this._connection.onreconnected((()=>Ct(this,void 0,void 0,(function*(){var e;this._connectionStateChangedEvent.Invoke(pe.Connected),(yield this.RestoreConnectionAsync())&&(null===(e=this._session)||void 0===e||e.RestoreSessionAsync())})))))}startPingLoop(){null!==this._pingTimerId&&clearInterval(this._pingTimerId),this._pingTimerId=window.setInterval((()=>{this.pingOnce()}),It.PING_INTERVAL_MS),window.addEventListener("online",this._tryReconnect),window.addEventListener("offline",this._tryReconnect),document.addEventListener("visibilitychange",this._onVisibility,!0),window.addEventListener("pagehide",this._onHidden,!0),window.addEventListener("pageshow",this._onVisible,!0)}isBusy(){var e;const t=null===(e=this._connection)||void 0===e?void 0:e.state;return t===o.Connecting||t===o.Disconnecting||t===o.Reconnecting}pingOnce(){return Ct(this,void 0,void 0,(function*(){this.IsConnected()&&!this.isBusy()&&(Date.now()-this._lastReceivedPacket<It.PING_INTERVAL_MS||((yield this.PingControllerAsync())?this._consecutivePingFailures=0:++this._consecutivePingFailures>=It.MAX_CONSECUTIVE_PING_FAILURES&&(this._consecutivePingFailures=0,this._log.Warning(It.ServiceName,"Ping failed too many times → reconnecting..."),this.serialisedConnect())))}))}validateConnectionToController(){return Ct(this,void 0,void 0,(function*(){var e;if(!this.IsConnected())return this._log.Warning(It.ServiceName,"Connection was lost"),!1;{const t=new ce;t.Resource="/system/ping",t.Method=le.Get;try{const n=yield this.SendAndWaitForResponseAsync(t,It.SERVER_TIMOUT_MS+1e3,!1,!1);return(null==n?void 0:n.Status)!==ue.OK?(this._log.Warning(It.ServiceName,"Connection check failed, "+(null==n?"result is null":`status: ${n.Status}`)),!1):(null===(e=this._connection)||void 0===e?void 0:e.state)===o.Reconnecting?(this._log.Warning(It.ServiceName,"Connection check failed, connection is in reconnecting state"),!1):(this._log.Info(It.ServiceName,"Connection still active"),!0)}catch(e){return!1}}}))}cleanup(){var e,t;null!==this._pingTimerId&&(clearInterval(this._pingTimerId),this._pingTimerId=null);for(const[,e]of this._pendingRequests)window.clearTimeout(e.timeoutId),e.reject(new Error("Connection lost"));this._pendingRequests.clear(),window.removeEventListener("online",this._tryReconnect),window.removeEventListener("offline",this._tryReconnect),document.removeEventListener("visibilitychange",this._onVisibility,!0),window.removeEventListener("pagehide",this._onHidden,!0),window.removeEventListener("pageshow",this._onVisible,!0);try{null===(t=null===(e=this._connection)||void 0===e?void 0:e.off)||void 0===t||t.call(e)}catch(e){}this._connection=void 0,this._currentAddress=void 0}}var Et,bt,Nt,Gt,Rt,Pt,Ut,Ot,Mt,xt,Ft,Lt,Bt,$t,Wt,Vt;It.PING_INTERVAL_MS=5e3,It.MAX_CONSECUTIVE_PING_FAILURES=6,It.SERVER_TIMOUT_MS=1e4,It.SignalRLogLevel=r.Warning,It.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(Et||(Et={})),(Lt=bt||(bt={}))[Lt.Default=0]="Default",Lt[Lt.Monostable=1]="Monostable",Lt[Lt.Bistable=2]="Bistable",Lt[Lt.Gate=3]="Gate",Lt[Lt.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"}(Nt||(Nt={}));class qt{constructor(){this._type=Rt.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}(Bt=Gt||(Gt={}))[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",e.PreciseGateControlSecure="IPreciseGateControlSecure"}(Rt||(Rt={}));class Ht{constructor(){this._type=Pt.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}!function(e){e.Unknown="Unknown",e.BatteryState="IBatteryState",e.BinarySensorState="IBinarySensor",e.BlindOpenCloseTime="IBlindOpenCloseTime",e.BlindPosition="IBlindPosition",e.BlindRemoteButtonState="IBlindsControlButton",e.BlindErrorState="IBlindError",e.MeasuredBrightness="IBrightness",e.RemoteButtonState="IButtonState",e.ChannelOnOffState="IChannelOnOff",e.IntercomState="IIntercom",e.DoorBellState="IDoorBell",e.FacadeRemoteButtonState="IFacadeControlButton",e.FacadePosition="IFacadeState",e.FacadeType="IFacadeType",e.FloodSensorState="IFloodSensor",e.GatePosition="IGatePosition",e.GatewayPosition="IGatewayPosition",e.GateControllerHealth="IGateControllerHealth",e.HumiditySensorState="IHumiditySensor",e.LightBrightness="ILightBrightness",e.LightColor="ILightColor",e.LightWarmth="ILightTemperature",e.LightTreshold="ILightTreshold",e.MovementSensorState="IMovementSensor",e.OnlineCamera="IOnlineCamera",e.OvercurrentProtectionState="IOvercurrentProtection",e.OvercurrentProtectionThreshold="IOvercurrentProtectionThreshold",e.ReedState="IReedState",e.SignalStrength="ISignalStrength",e.SmokeSensorState="ISmokeSensor",e.MeasuredTemperature="ITemperature",e.VibrationSensorState="IVibrationSensor",e.MeasuredWindSpeed="IWindSpeed",e.WindThreshold="IWindThreshold",e.MeasuredEnergy="IEnergy",e.MeasuredDistance="DistanceSensor",e.BlindCalibration="BlindCalibration",e.ConfigurationState="ConfigurationState",e.CurrentWindThreshold="CurrentWindThreshold",e.CurrentLightThreshold="CurrentLightThreshold",e.WindSpeedState="WindSpeed",e.TamperProtectionState="ITamperProtection",e.PressureSensorState="IPressureSensor",e.LightRGBWState="ILightRGBW",e.SceneExecuted="ISceneExecuted",e.HallState="IHallState",e.Intercom="IIntercom"}(Pt||(Pt={})),(Vt=Ut||(Ut={}))[Vt.NotResponding=0]="NotResponding",Vt[Vt.Working=1]="Working",Vt[Vt.Broken=2]="Broken",Vt[Vt.FirmareUpgradeMode=3]="FirmareUpgradeMode",(Wt=Ot||(Ot={}))[Wt.TwoWay=1]="TwoWay",Wt[Wt.OneWay=2]="OneWay",Wt[Wt.ConditionalTwoWay=3]="ConditionalTwoWay",($t=Mt||(Mt={}))[$t.Unknown=-1]="Unknown",$t[$t.Multipurpose=0]="Multipurpose",$t[$t.Controller=1]="Controller",$t[$t.Driver=2]="Driver",$t[$t.Receiver=3]="Receiver",$t[$t.Remote=4]="Remote",$t[$t.Sensor=5]="Sensor",$t[$t.Scene=6]="Scene";class Kt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=Et.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"}(xt||(xt={})),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"}(Ft||(Ft={}));class jt{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=Ft.Unknown}}var zt,Jt,Xt,Yt,Qt,Zt,en,tn,nn,rn,sn,on,an,cn,un,ln,dn,hn,pn,gn,fn,vn,yn,mn,wn,Sn,An,_n,Cn,Tn,Dn;class kn{constructor(){this._type="",this._data=null,this._typeAsEnum=Pt.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}}(Dn=zt||(zt={}))[Dn.Confident=0]="Confident",Dn[Dn.Unconfident=1]="Unconfident";class In extends kn{constructor(e){super(),this.TypeAsEnum=Pt.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class En{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=Jt.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Jt||(Jt={}));class bn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.HallState,this.Type="IHallState",this.Data=e.state}}class Nn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.SceneExecuted,this.Type="ISceneExecuted",this.Data=e.state}}class Gn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.IntercomState,this.Type="IntercomState",this.Data=e.state}}!function(e){e[e.Idle=0]="Idle",e[e.IncomingCall=1]="IncomingCall",e[e.AnsweringCall=2]="AnsweringCall",e[e.Busy=3]="Busy",e[e.NoAnswerToCall=4]="NoAnswerToCall",e[e.Unknown=5]="Unknown"}(Xt||(Xt={}));class Rn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class Pn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class Un{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=Yt.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(Yt||(Yt={}));class On extends kn{constructor(e){super(),this.TypeAsEnum=Pt.ReedState,this.Type="ReedState",this.Data=e.state}}class Mn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=!1,this.Time=""}}class xn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.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 Fn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class Ln extends kn{constructor(e){super(),this.TypeAsEnum=Pt.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class Bn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=Zt.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(Zt||(Zt={}));class $n extends kn{constructor(e){super(),this.TypeAsEnum=Pt.LightColor,this.Type="LightColorState",this.Data=e.state}}class Wn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class Vn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class qn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Temperature=0,this.Time=""}}class Hn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class Kn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Brightness=0,this.Time=""}}class jn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class zn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Temperature=0,this.Type=en.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"}(en||(en={}));class Jn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.BatteryState,this.Type="BatteryState",this.Data=e.state}}class Xn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=tn.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"}(tn||(tn={}));class Yn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class Qn{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Brightness=0,this.Time=""}}class Zn extends kn{constructor(e){super(),this.TypeAsEnum=Pt.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class er{constructor(){this.Channel=0,this.StateReliability=zt.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"}(nn||(nn={}));class tr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(rn||(rn={}));class nr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class rr{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Intensity=0,this.Movement=sn.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(sn||(sn={}));class sr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class or{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=on.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"}(on||(on={}));class ir extends kn{constructor(e){super(),this.TypeAsEnum=Pt.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class ar{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=an.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"}(an||(an={}));class cr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.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"}(cn||(cn={}));class ur extends kn{constructor(e){super(),this.TypeAsEnum=Pt.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class lr{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.PositionType=un.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"}(un||(un={}));class dr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.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"}(ln||(ln={}));class hr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.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"}(dn||(dn={}));class pr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.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"}(hn||(hn={}));class gr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class fr{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Type=pn.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"}(pn||(pn={}));class vr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(gn||(gn={}));class yr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class mr{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=fn.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(fn||(fn={}));class wr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.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"}(vn||(vn={}));class Sr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class Ar extends kn{constructor(e){super(),this.TypeAsEnum=Pt.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class _r extends kn{constructor(e){super(),this.TypeAsEnum=Pt.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class Cr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class Tr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class Dr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class kr{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.WindThreshold=yn.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"}(yn||(yn={}));class Ir extends kn{constructor(e){super(),this.TypeAsEnum=Pt.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"}(mn||(mn={}));class Er extends kn{constructor(e){super(),this.TypeAsEnum=Pt.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class br{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Value=0,this.Time=""}}class Nr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class Gr{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.State=wn.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(wn||(wn={})),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"}(Sn||(Sn={}));class Rr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class Pr{constructor(){this.Channel=0,this.StateReliability=zt.Unconfident,this.Pressure=0,this.Time="",this.PressureType=An.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(An||(An={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(_n||(_n={}));class Ur extends kn{constructor(e){super(),this.TypeAsEnum=Pt.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(Cn||(Cn={}));class Or extends kn{constructor(e){super(),this.TypeAsEnum=Pt.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Mr extends kn{constructor(e){super(),this.TypeAsEnum=Pt.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"}(Tn||(Tn={}));class xr{constructor(){this._onDeviceStateChangedEvent=new c,this._onDeviceStateRefreshedOrChangedEvent=new c,this._onDeviceTasksExecutionChangedOnChannelsEvent=new c,this._onDeviceFirmwareVersionChangedEvent=new c,this._iconType=Gt.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=Ut.Working,this._deviceType=Mt.Unknown,this._communicationWay=Ot.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==xr._devicesService&&(xr._devicesService=hy.Get(Yo.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;xr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),xr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),xr._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===Mt.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!==Rt.SetBlindPositionSimple))}return!1}get States(){return a.DoesThrowStackTrace?hy.Get(Yo.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():xr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return xr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return xr._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*(){var t;try{const n=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(new Fr(this,e),2e4,!1);switch(n.Status){case ue.OK:return this._name=e,null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeDeviceNameAsync()"),hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),new Ie(we.Changed,"");case ue.WrongData:if("DeviceNotFound"==n.Data)return new Ie(we.Failed,"DeviceNotFound");break;case ue.NoPermissionsToCallGivenResource:return new Ie(we.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new Ie(we.ControllerResponseTimeout,""):new Ie(we.UnknownError,"")}return new Ie(we.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 xr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class Fr extends ce{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=le.Put;const n=new Lr;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class Lr{constructor(){this.DeviceGuid="",this.Name=""}}var Br,$r,Wr,Vr,qr;class Hr{constructor(){this._device=new xr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=bt.Default,this._channelGroups=[],this._isHidden=!1,this._availableTasksTypes=[],this._availableResponseTypes=[],this._customData={},this._roles=[],this._configurations={},this.CustomDataAndRolesSupported=!1,this._onTasksExecutionChangedEvent=new c,this._onChannelStateChangedEvent=new c,this._onChannelStateRefreshedOrChangedEvent=new c,null==Hr._devicesService&&(Hr._devicesService=hy.Get(Yo.ServiceName))}SetCustomDataAsync(e,t){const n=this.GetChannelConfigurationData();if(Array.isArray(e))for(const t of e)n.CustomData[t.dataId]=t.data,this._customData[t.dataId]=t.data;else n.CustomData[e]=t,this._customData[e]=t;const r=new Kr;return r.DeviceGuid=this._device.Guid,r.ChannelConfiguration=n,this.ChangeConfigurationAsync(r)}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}RemoveCustomDataAsync(e){const t=this.GetChannelConfigurationData();delete t.CustomData[e],delete this._customData[e];const n=new Kr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new jr;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 Kr;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 Kr;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new Kr;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 Kr;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 Kr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){return t=this,n=void 0,s=function*(){var t,n;try{const r=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(new zr(e),2e4,!1);switch(null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeConfigurationAsync()"),yield hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),r.Status){case ue.OK:return this._name=e.ChannelConfiguration.ChannelName,this._iconName=e.ChannelConfiguration.IconName,this._channelGroups=e.ChannelConfiguration.GroupsGuids,this._isHidden=e.ChannelConfiguration.Hidden,this._mode=e.ChannelConfiguration.Configuration,this._customData=e.ChannelConfiguration.CustomData,this._roles=e.ChannelConfiguration.Roles,this._configurations=e.ChannelConfiguration.Configurations,new Ie(we.Changed,"");case ue.WrongData:if("DeviceNotFound"===r.Data)return null===(n=u.Log)||void 0===n||n.Error("Failed to change channel configuration, referenced device does not exist!"),new Ie(we.WrongData,"DeviceNotFound");break;case ue.FatalError:return new Ie(we.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new Ie(we.ControllerResponseTimeout,"")}return new Ie(we.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}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 a.DoesThrowStackTrace?hy.Get(Yo.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():Hr._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,Hr._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(Ft.Failed)}}Hr._devicesService=null;class Kr{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new jr}}class jr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=bt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class zr extends ce{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=le.Put,this.Data=e}}!function(e){e[e.TurnOn=0]="TurnOn",e[e.TurnOff=1]="TurnOff",e[e.ToggleState=2]="ToggleState",e[e.SetBlindPosition=3]="SetBlindPosition",e[e.SetLightColor=4]="SetLightColor",e[e.SetLightTemperature=5]="SetLightTemperature",e[e.SetLightBrightness=6]="SetLightBrightness",e[e.SetTemperature=7]="SetTemperature",e[e.GetState=8]="GetState",e[e.TurnOnWithTimeout=9]="TurnOnWithTimeout",e[e.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",e[e.IdentifyDevice=11]="IdentifyDevice",e[e.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",e[e.SetBlindMicroventilation=13]="SetBlindMicroventilation",e[e.GatewayPulse=25]="GatewayPulse",e[e.GatePulse=26]="GatePulse",e[e.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",e[e.GetFacadeType=30]="GetFacadeType",e[e.LightRGBW=31]="LightRGBW",e[e.SetGatePositionPrecise=32]="SetGatePositionPrecise",e[e.SetGatePositionPreciseSecure=33]="SetGatePositionPreciseSecure"}(Br||(Br={}));class Jr{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 Xr{constructor(){this._taskType=Rt.GetChannelsState,this._featureType=Br.GetState,this._channel=0,this._guid=Jr.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 Yr extends Xr{constructor(){super(),this.Temperature=0,this.FeatureType=Br.SetTemperature,this.TaskType=Rt.SetTemperature}}class Qr extends Xr{constructor(){super(),this.FeatureType=Br.TurnOff,this.TaskType=Rt.TurnOff}}class Zr extends Xr{constructor(){super(),this.FeatureType=Br.TurnOn,this.TaskType=Rt.TurnOn}}class es extends Xr{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=Br.TurnOnWithTimeout,this.TaskType=Rt.TurnOnWithTime}}class ts extends Xr{constructor(){super(),this.Brightness=0,this.FeatureType=Br.SetLightBrightness,this.TaskType=Rt.SetLightBrightness}}class ns extends Xr{constructor(){super(),this.FeatureType=Br.ToggleState,this.TaskType=Rt.TogleState}}class rs extends Xr{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=Br.SetLightColor,this.TaskType=Rt.SetLightColor}}class ss extends Xr{constructor(){super(),this.Temperature=0,this.FeatureType=Br.SetLightTemperature,this.TaskType=Rt.SetLightTemperature}}class os extends Xr{constructor(){super(),this.Action=$r.Stop,this.Position=0,this.FeatureType=Br.SetBlindPosition,this.TaskType=Rt.SetBlindPosition}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}($r||($r={}));class is extends Xr{constructor(){super(),this.GateControlAction=Wr.Stop,this.Position=0,this.FeatureType=Br.SetGatePositionPrecise,this.TaskType=Rt.PreciseGateControl}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Wr||(Wr={}));class as extends Xr{constructor(){super(),this.Action=Vr.Stop,this.Position=0,this.FeatureType=Br.SetBlindPosition,this.TaskType=Rt.SetBlindPositionSimple}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Vr||(Vr={}));class cs extends Xr{constructor(){super(),this.Brightness=0,this.FeatureType=Br.SetLightBrightnessDynamicly,this.TaskType=Rt.SetLightBrightnessDynamicly}}class us extends Xr{constructor(){super(),this.FeatureType=Br.IdentifyDevice,this.TaskType=Rt.IdentifyDevice}}class ls extends Xr{constructor(){super(),this.Data=new ds,this.FeatureType=Br.SetBlindOpenCloseTime,this.TaskType=Rt.SetBlindOpenCloseTime}}class ds{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class hs extends Xr{constructor(){super(),this.FeatureType=Br.GetState,this.TaskType=Rt.GetChannelsState}}class ps extends Xr{constructor(){super(),this.Position=0,this.FeatureType=Br.SetBlindMicroventilation,this.TaskType=Rt.SetBlindMicroventilation}}class gs extends Xr{constructor(){super(),this.FeatureType=Br.GatePulse,this.TaskType=Rt.ChangeGatewayPositionPulse}}class fs extends Xr{constructor(){super(),this.FeatureType=Br.GatewayPulse,this.TaskType=Rt.ChangeGatewayPositionPulse}}class vs extends Xr{constructor(){super(),this.FacadeAction=qr.Stop,this.Tilt=0,this.Position=0,this.FeatureType=Br.SetFacadePositionAndTilt,this.TaskType=Rt.SetFacadePosition}}class ys extends Xr{constructor(){super(),this.FeatureType=Br.GetFacadeType,this.TaskType=Rt.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"}(qr||(qr={}));class ms{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class ws extends Xr{constructor(){super(),this.Data=new ms,this.FeatureType=Br.LightRGBW,this.TaskType=Rt.LightRGBW}}var Ss=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){var t;null===(t=u.Log)||void 0===t||t.Debug(As.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return Ss(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 Ss(this,void 0,void 0,(function*(){var t;const n=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=n?n.AddManuallyPairedDeviceAsync(e):(null===(t=u.Log)||void 0===t||t.Error(As.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDeviceAsync()"),hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),Ft.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}As.ServiceName="ManualDeviceService";class _s{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var Cs,Ts=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ds{constructor(){this._connection=null,this._localDb=null,this._connection=hy.Get(It.ServiceName),this._localDb=hy.Get(l.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return Ts(this,void 0,void 0,(function*(){try{let r=new ks(e,t,n),s=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(s.Status===ue.OK){const r=new bs;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(Ds.ServiceName,this.GetLocalDbName(e,t),r)}return s.Status}catch(e){return ue.FatalError}}))}ReadAsync(e,t,n){return Ts(this,void 0,void 0,(function*(){try{let r=new Is(e,t);if(!n){const n=this._localDb.Read(Ds.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new _s;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===ue.OK){const e=new _s;return e.ResourceGuid=s.ResourceGuid,e.Data=JSON.parse(s.Data),e.IsGlobal=s.IsGlobal,e}return s.Status}catch(e){return ue.FatalError}}))}RemoveAsync(e,t){return Ts(this,void 0,void 0,(function*(){try{let n=new Es(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}catch(e){return ue.FatalError}}))}GetServiceName(){return Ds.ServiceName}}Ds.ServiceName="RemoteStorageService";class ks extends ce{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class Is extends ce{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Get,this.ResourceGuid=e,this.Global=t}}class Es extends ce{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Delete,this.ResourceGuid=e,this.Global=t}}class bs extends ce{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class Ns{constructor(){this.Longitude=0,this.Latitude=0}}class Gs{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"}(Cs||(Cs={}));var Rs,Ps,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 Os{IsControllerGeolocationSetAsync(){return Us(this,void 0,void 0,(function*(){let e=new Ms,t=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ue.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return 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,r;let s=new Fs;s.Data.Latitude=e.Latitude,s.Data.Longitude=e.Longitude,null===(t=u.Log)||void 0===t||t.Warning(Os.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(s)}`);let o=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(s,15e3,!1);switch(null===(n=u.Log)||void 0===n||n.Warning(Os.ServiceName,`${JSON.stringify(o)}`),null===(r=u.Log)||void 0===r||r.Error(Os.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetControllerGeolocationAsync()"),hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),null==o?void 0:o.Status){case ue.OK:const e=hy.Get(Be.ServiceName);return e.Remove(new Ms),e.Remove(new xs),new Ee(Cs.OK,"");case ue.NoPermissionToPerformThisOperation:case ue.NoPermissionsToCallGivenResource:return new Ee(Cs.NoPermissions,"");case ue.UserIsNotLoggedIn:return new Ee(Cs.UserIsNotLoggedIn,"");default:return new Ee(Cs.UnknownError,"")}}))}GetControlllerGeolocationAsync(){return Us(this,void 0,void 0,(function*(){var e,t;let n=new xs;null===(e=u.Log)||void 0===e||e.Warning(Os.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=u.Log)||void 0===t||t.Warning(Os.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ue.OK){let e=new Gs;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 Os.ServiceName}}Os.ServiceName="GeolocationService";class Ms extends ce{constructor(){super(),this.Resource="/geolocation/isset",this.Method=le.Get}}class xs extends ce{constructor(){super(),this.Resource="/geolocation/get",this.Method=le.Get}}class Fs extends ce{constructor(){super(),this.Data=new Ns,this.Resource="/geolocation/save",this.Method=le.Put}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Rs||(Rs={}));class Ls{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=Ps.Unknown,this.ResourceGuid=""}}class Bs{constructor(){this.UpdateDescription=new Map,this.Update=new Ls,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"}(Ps||(Ps={}));class $s extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var Ws,Vs,qs,Hs,Ks,js,zs,Js,Xs,Ys,Qs,Zs,eo,to,no,ro,so,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._services=new Map,this._runtimeInfo=new co,this._hardwareInfo=new lo,this._semaphore=new et(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return ao.ServiceName}RegisterUpdatesProvider(e){var t;null===(t=u.Log)||void 0===t||t.Debug(ao.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return io(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(ao.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const n=this._services.get(e);if(null==n)throw new $s("Cannot get update provider! Requested update provider has not been registered.");return n}))}GetUpdatesProvidersAsync(e){return io(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(ao.ServiceName,`Getting update providers with type ${e} by GetUpdateProvidersAsync<T>()`);let n=[];if(n=[...this._services.values()].filter((t=>t.ProviderType==e)),0==n.length)throw new $s("Cannot get update providers! Requested update providers has not been registered.");return n}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return io(this,void 0,void 0,(function*(){var r;if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){null===(r=u.Log)||void 0===r||r.Debug(ao.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 $s("Cannot get update providers! Requested update providers has not been registered.");return s}throw new $s("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return io(this,void 0,void 0,(function*(){var r;if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){null===(r=u.Log)||void 0===r||r.Debug(ao.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 $s("Cannot get update providers! Requested update providers has not been registered.");return s}throw new $s("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(){return io(this,arguments,void 0,(function*(e=!1){var t=yield this._semaphore.AcquireAsync();try{return this._isRuntimeInfoInitialized&&!e||(yield this.GetRuntimeControllerInfoAsync()),this._runtimeInfo}finally{t.Release()}}))}GetRuntimeControllerInfoAsync(){return io(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(ao.ServiceName,"Getting runtime version info from controller.");try{const e=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(new uo,16e3,!1);if(null==e||null==e.Status)throw new po('Cannot get runtime info, controller response result is empty."',Ws.EmptyResponse);if(e.Status!=ue.OK)throw new po(`Cannot get runtime info, controller responded with status ${e.Status}.`,Ws.WrongResponseStatus);if(null==e.Data)throw new po("Cannot get runtime info, controller responded with status OK but response does not contains data.",Ws.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof I?new po("Cannot get runtime info, controller response timeout.",Ws.Timeout):e}}))}GetHardwareInfoAsync(){return io(this,arguments,void 0,(function*(e=!1){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return io(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(ao.ServiceName,"Getting hardware info from controller.");const t=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(new ho,8e3,!1);if(null==t||null==t.Status)throw new po('Cannot get hardware info, controller response result is empty."',Ws.EmptyResponse);if(t.Status!=ue.OK)throw new po(`Cannot get hardware info, controller responded with status ${t.Status}.`,Ws.WrongResponseStatus);if(null==t.Data)throw new po("Cannot get hardware info, controller responded with status OK but response does not contains data.",Ws.NoDataInResponse);this._hardwareInfo=t.Data,this._isHardwareInfoInitialized=!0}))}}ao.ServiceName="UpdateProvider";class co{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class uo extends ce{constructor(){super(),this.Resource="/controller/software/info",this.Method=le.Get}}class lo{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class ho extends ce{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=le.Get}}class po 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"}(Ws||(Ws={})),function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(Vs||(Vs={}));class go{constructor(){this._comparisonParams=new Map,this.Type=Pt.Unknown,this.DeviceGuid="",this.ComparisonMethod=qs.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof Xn&&(this.Type=Pt.BatteryState),e instanceof mr&&(this.Type=Pt.BinarySensorState),e instanceof Fn&&(this.Type=Pt.BlindPosition),e instanceof Kn&&(this.Type=Pt.LightBrightness),e instanceof Qn&&(this.Type=Pt.MeasuredBrightness),e instanceof Bn&&(this.Type=Pt.RemoteButtonState),e instanceof En&&(this.Type=Pt.ChannelOnOffState),e instanceof Un&&(this.Type=Pt.DoorBellState),e instanceof er&&(this.Type=Pt.MeasuredEnergy),e instanceof Gr&&(this.Type=Pt.FloodSensorState),e instanceof lr&&(this.Type=Pt.GatePosition),e instanceof Wn&&(this.Type=Pt.LightColor),e instanceof qn&&(this.Type=Pt.LightWarmth),e instanceof Mn&&(this.Type=Pt.ReedState),e instanceof zn&&(this.Type=Pt.MeasuredTemperature),e instanceof fr&&(this.Type=Pt.HumiditySensorState),e instanceof or&&(this.Type=Pt.BlindRemoteButtonState),e instanceof ar&&(this.Type=Pt.FacadeRemoteButtonState),e instanceof rr&&(this.Type=Pt.MovementSensorState),e instanceof er&&(this.Type=Pt.MeasuredEnergy),e instanceof Pr&&(this.Type=Pt.PressureSensorState),e instanceof br&&(this.Type=Pt.WindSpeedState),e instanceof kr&&(this.Type=Pt.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class fo{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class vo{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"}(qs||(qs={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}(Hs||(Hs={})),function(e){e[e.SunRise=1]="SunRise",e[e.SunSet=2]="SunSet"}(Ks||(Ks={}));class yo{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"}(js||(js={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(zs||(zs={})),(oo=Js||(Js={}))[oo.Unknown=0]="Unknown",oo[oo.Second=1]="Second",oo[oo.Minute=2]="Minute",oo[oo.Hour=3]="Hour",oo[oo.Day=4]="Day",oo[oo.DayOfWeek=5]="DayOfWeek",oo[oo.Month=6]="Month",oo[oo.Year=7]="Year",oo[oo.Date=8]="Date",oo[oo.Time=9]="Time",oo[oo.WeatherType=11]="WeatherType",oo[oo.CompareNumbers=12]="CompareNumbers",oo[oo.CompareBooleans=13]="CompareBooleans",oo[oo.DeviceState=14]="DeviceState",oo[oo.Timer=15]="Timer",oo[oo.Temperature=17]="Temperature",oo[oo.DaysOfWeek=18]="DaysOfWeek",oo[oo.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",oo[oo.SceneExecuted=20]="SceneExecuted",(so=Xs||(Xs={}))[so.Unknown=0]="Unknown",so[so.Equal=1]="Equal",so[so.NotEqueal=2]="NotEqueal",so[so.BiggerThan=3]="BiggerThan",so[so.SmallerThan=4]="SmallerThan",so[so.BiggerThanOrEqual=5]="BiggerThanOrEqual",so[so.SmallerThanOrEqual=6]="SmallerThanOrEqual",so[so.OneOfBothIsTrue=7]="OneOfBothIsTrue",so[so.BothAreTrue=8]="BothAreTrue",function(e){e[e.Unknown=0]="Unknown",e[e.BatteryState=1]="BatteryState",e[e.BinarySensor=2]="BinarySensor",e[e.BlindPosition=3]="BlindPosition",e[e.Brightness=4]="Brightness",e[e.ButtonState=5]="ButtonState",e[e.ChannelOnOff=6]="ChannelOnOff",e[e.DoorBell=7]="DoorBell",e[e.Energy=8]="Energy",e[e.FloodSensor=9]="FloodSensor",e[e.GatePosition=10]="GatePosition",e[e.HeatSensor=11]="HeatSensor",e[e.LightBrightness=12]="LightBrightness",e[e.LightColor=13]="LightColor",e[e.LightTemperature=14]="LightTemperature",e[e.MeasuredCurrent=15]="MeasuredCurrent",e[e.MeasuredPower=16]="MeasuredPower",e[e.MeasuredVoltage=17]="MeasuredVoltage",e[e.ReedState=18]="ReedState",e[e.SmokeSensor=19]="SmokeSensor",e[e.Temperature=20]="Temperature",e[e.BlindsControlButton=21]="BlindsControlButton",e[e.Movement=22]="Movement",e[e.WindSpeed=24]="WindSpeed",e[e.Humidity=25]="Humidity",e[e.AirPressure=26]="AirPressure",e[e.WindThreshold=31]="WindThreshold",e[e.FacadeControlButton=36]="FacadeControlButton"}(Ys||(Ys={})),function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(Qs||(Qs={})),(ro=Zs||(Zs={})).Null="Null",ro.Condition="Condition",ro.ConditionGroup="ConditionGroup",ro.ArgumentAsInt="ArgumentAsInt",ro.ArgumentAsTimeSpan="ArgumentAsTimeSpan",ro.ArgumentAsBoolean="ArgumentAsBoolean",ro.ArgumentAsTimeout="ArgumentAsTimeout",ro.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",ro.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",ro.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",ro.ArgumentAsTime="ArgumentAsTime",ro.ArgumentAsDeviceState="ArgumentAsDeviceState",ro.ArgumentAsNumber="ArgumentAsNumber",ro.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",ro.ArgumentAsConditionInfo="ArgumentAsConditionInfo",function(e){e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.LockExecutionTask="LockExecutionTask",e.NotifyTaskAppNotify="NotifyTaskAppNotify",e.NotifyTaskEmailNotify="NotifyTaskEmailNotify"}(eo||(eo={}));class mo 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"}(to||(to={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(no||(no={}));var wo,So,Ao;class _o{constructor(e,t="Cube"){this._result=null,this._tmp=new Co,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=hy.Get(Lo.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=Jr.NewGuid())}SetSequenceName(e){const t=n=>{if(n.RightArgumentType!=Ao.Null)return t(n.RightArgument);n.Tasks.ControllerTasks.where((e=>e.TaskType==js.NotifyTask)).toArray().forEach((t=>{t.Title=e}))};this._sequenceName=e,this._editingExistingSequence&&null!=this._result&&(this._result.Name=e,t(this._result))}SetSequenceIcon(e){this._sequenceIcon=e,this._editingExistingSequence&&null!=this._result&&(this._result.Icon=e)}GetNext(){if(null==this._result)return null;if(""==this._currentSeqGuid)return this._currentSeqGuid=this._result.Guid,this._service.MapSequence(JSON.parse(JSON.stringify(this._result)),!0);{const e=this.FindArgumentWithGuid(this._result,this._currentSeqGuid);return null==e?null:e.RightArgumentType==Ao.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 _o;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=Jr.NewGuid(),e.RightArgumentType==Ao.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=Jr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==Ao.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!=Ao.Null)return t(e.RightArgument);this._rawExistingSequenceTasks=JSON.parse(JSON.stringify(e.Tasks))};return this._editingExistingSequence=!0,t(e._rawRequestData),Object.hasOwn(e._rawRequestData,"Condition")?this._result=e._rawRequestData.Condition:this._result=e._rawRequestData,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequence:e=>this.RemoveSequenceByGuid(e),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=Xs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Xs.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=Jr.NewGuid(),this._tmp.HandledType=Js.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=Ao.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,e.Offset<-3600||e.Offset>3600)throw new Po("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=Xs.Equal;else{if(t||null==n)throw new Po("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Ao.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=Jr.NewGuid(),this._tmp.HandledType=Js.Unknown,this._tmp.LeftArgumentType=Ao.Null,this._tmp.ConditionType=Xs.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=Ao.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=Xs.Equal){return this._tmp.Guid=Jr.NewGuid(),this._tmp.HandledType=Js.DaysOfWeek,this._tmp.LeftArgumentType=Ao.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Ao.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=Xs.Equal){return this._tmp.Guid=Jr.NewGuid(),this._tmp.HandledType=Js.Timer,this._tmp.LeftArgumentType=Ao.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Ao.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=Xs.Equal){return this._tmp.Guid=Jr.NewGuid(),this._tmp.HandledType=Js.Time,this._tmp.LeftArgumentType=Ao.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Ao.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=Xs.Equal){return this._tmp.Guid=Jr.NewGuid(),this._tmp.HandledType=Js.DeviceState,this._tmp.LeftArgumentType=Ao.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=Ao.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=Jr.NewGuid(),this._tmp.HandledType=Js.SceneExecuted,this._tmp.LeftArgumentType=Ao.ArgumentAsConditionInfo,this._tmp.ConditionType=Xs.Equal,this._tmp.AtMeetCondition=!0;const t=new yo;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=Ao.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new ko;t.Channel=e.GetCheckDeviceState().Channel,t.ComparisonMethod=e.ComparisonMethod;let n={},r=e.GetComparisonParams().entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[Hs[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case Pt.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case Pt.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Pt.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case Pt.LightBrightness:case Pt.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case Pt.RemoteButtonState:case Pt.ChannelOnOffState:case Pt.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Pt.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[nn[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case Pt.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Pt.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case Pt.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case Pt.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case Pt.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Pt.SmokeSensorState:throw new mo("Unsupported device state!");case Pt.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case Pt.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case Pt.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Pt.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 Pt.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Pt.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case Pt.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case Pt.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case Pt.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case Pt.Unknown:t.CheckedDeviceState={};break;default:throw new mo("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case Pt.BatteryState:return Ys.BatteryState;case Pt.BinarySensorState:return Ys.BinarySensor;case Pt.BlindPosition:return Ys.BlindPosition;case Pt.LightBrightness:return Ys.LightBrightness;case Pt.RemoteButtonState:return Ys.ButtonState;case Pt.ChannelOnOffState:return Ys.ChannelOnOff;case Pt.DoorBellState:return Ys.DoorBell;case Pt.MeasuredEnergy:return Ys.Energy;case Pt.FloodSensorState:return Ys.FloodSensor;case Pt.GatePosition:return Ys.GatePosition;case Pt.MeasuredBrightness:return Ys.Brightness;case Pt.LightColor:return Ys.LightColor;case Pt.LightWarmth:return Ys.LightTemperature;case Pt.ReedState:return Ys.ReedState;case Pt.SmokeSensorState:return Ys.SmokeSensor;case Pt.MeasuredTemperature:return Ys.Temperature;case Pt.HumiditySensorState:return Ys.Humidity;case Pt.BlindRemoteButtonState:return Ys.BlindsControlButton;case Pt.FacadeRemoteButtonState:return Ys.FacadeControlButton;case Pt.MovementSensorState:return Ys.Movement;case Pt.PressureSensorState:return Ys.AirPressure;case Pt.WindSpeedState:return Ys.WindSpeed;case Pt.CurrentWindThreshold:return Ys.WindThreshold;default:return Ys.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=Ao.Null)return e(t.RightArgument,n);t.RightArgumentType=Ao.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new Io)};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 Co,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=Xs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Xs.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!=Ao.Condition){if(n.RightArgumentType==Ao.Condition)return t(n.RightArgument,r);throw new Uo(`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 Uo(`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 Co,console.log(`new tmp guid: ${this._tmp.Guid}`),this._result.AtMeetCondition||(this._result.AtMeetCondition=!0),{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=Xs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Xs.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==Ao.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==Ao.Null)throw new Uo(`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 Uo("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=Ao.Null?(this._result.RightArgument.Name=this._result.Name,this._result.RightArgument.Icon=this._result.Icon,this._result.RightArgument.Guid=this._result.Guid,this._result=this._result.RightArgument,this._result.AtMeetCondition=!0,n(this._result,e)):r(this._result,e),{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=Xs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Xs.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!=Ao.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new Uo("Sequence are not initialized! Not found root sequence.");return this._editingExistingSequence&&e(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}DeviceTask(e){if(this._tmpTask=this.ParseDeviceTask(e),null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:se.GenerateMd5(JSON.stringify(this._tmpTask))}}ParseDeviceTask(e){const t=new bo;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==Rt.SetBlindPosition||e instanceof os?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==Rt.SetBlindPositionSimple||e instanceof as?(t.Data.Action=e.Action,t.Data.Position=0):e.TaskType==Rt.SetLightColor||e instanceof rs?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==Rt.SetLightTemperature||e instanceof ss?t.Data.Temperature=e.Temperature:e.TaskType==Rt.SetLightBrightness||e instanceof ts?t.Data.Brightness=e.Brightness:e.TaskType==Rt.SetTemperature||e instanceof Yr?t.Data.Temperature=e.Temperature:e.TaskType==Rt.TurnOnWithTime||e instanceof es?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==Rt.SetLightBrightnessDynamicly||e instanceof cs?t.Data.Brightness=e.Brightness:e.TaskType==Rt.SetBlindOpenCloseTime||e instanceof ls?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==Rt.SetBlindMicroventilation||e instanceof ps?t.Data.Position=e.Position:e.TaskType==Rt.SetFacadePosition||e instanceof vs?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):e.TaskType==Rt.LightRGBW||e instanceof ws?(t.Data.R=e.Data.R,t.Data.G=e.Data.G,t.Data.B=e.Data.B,t.Data.W=e.Data.W,t.Data.Brightness=e.Data.Brightness):(e.TaskType==Rt.PreciseGateControl||e instanceof is)&&(t.Data.Position=e.Position,t.Data.GateControlAction=e.GateControlAction),t}DelayTask(e){const t=new No;if("00:00:00"==e.Delay.Value)throw new Po("Delay must be other than 00:00:00!");if(t.Delay=e.Delay.Value,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:se.GenerateMd5(JSON.stringify(t))}}NotifyTask(e){if(e.NotifyType==to.Email)throw new Mo("NotifyType 'Email' is not supported!");if(e.NotifyType==to.None)throw new Error("NotifyType mus be set!");if(""==e.Message)throw new Po("Message must be set!");if(e.Message.length>1e3)throw new Po("Message is too long! Max length is 1000 characters.");const t=new Ro;if(t.NotifyType=e.NotifyType,t.Message=e.Message,t.NotificationClients=e.NotificationClients,t.Title=this._sequenceName,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:se.GenerateMd5(JSON.stringify(t))}}LockExecutionTask(e){const t=new Go;if(t.LockType=e.LockType,t.LockType==no.Timeout&&"00:00:00"!=t.LockEndHour)throw new Mo("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=>{var n;if(t.RightArgumentType!=Ao.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 bo&&t.Tasks.DevicesTasks.push(structuredClone(this._tmpTask)),t.Tasks.ControllerTasks.push(structuredClone(this._tmpTask)),this._tmpTask=null,null===(n=u.Log)||void 0===n||n.Debug(`Task added to sequence: \n${JSON.stringify(this._tmpTask)} \ntasks on a list: \n${JSON.stringify(t.Tasks)}`)};if(null==this._result)throw new Error("No context!");return e(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}EditTask(e){const t=n=>{var r;if(n.RightArgumentType!=Ao.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 bo&&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,null===(r=u.Log)||void 0===r||r.Debug(`Task edited in sequence: \n${JSON.stringify(this._tmpTask)} \ntasks on a list: \n${JSON.stringify(n.Tasks)}`)};if(null==this._result)throw new Error("No context!");return t(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}RemoveTask(e){const t=(e,n)=>{var r,s;if(e.RightArgumentType!=Ao.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,null===(s=null===(r=e.Tasks)||void 0===r?void 0:r.DevicesTasks)||void 0===s?void 0:s.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 Rt.Unknown:throw new Po("Unsupported task type!");case Rt.SetBlindPosition:case Rt.SetBlindPositionSimple:return Br.SetBlindPosition;case Rt.SetBlindMicroventilation:return Br.SetBlindMicroventilation;case Rt.TurnOff:return Br.TurnOff;case Rt.TurnOn:return Br.TurnOn;case Rt.TurnOnWithTime:return Br.TurnOnWithTimeout;case Rt.TogleState:return Br.ToggleState;case Rt.SetLightBrightnessDynamicly:return Br.SetLightBrightnessDynamicly;case Rt.SetLightBrightness:return Br.SetLightBrightness;case Rt.SetLightColor:return Br.SetLightColor;case Rt.SetLightTemperature:return Br.SetLightTemperature;case Rt.PairDevice:case Rt.UnpairDevice:throw new Po("Unsupported task type!");case Rt.IdentifyDevice:return Br.IdentifyDevice;case Rt.GetChannelsState:return Br.GetState;case Rt.GetPowerMeasurements:case Rt.GetAvailableData:case Rt.MultipleDataRequest:throw new Po("Unsupported task type!");case Rt.SetBlindOpenCloseTime:return Br.SetBlindOpenCloseTime;case Rt.SetTemperature:return Br.SetTemperature;case Rt.ChangeGatePositionPulse:return Br.GatePulse;case Rt.ChangeGatewayPositionPulse:return Br.GatewayPulse;case Rt.SetFacadePosition:case Rt.GetFacadeType:return Br.SetFacadePositionAndTilt;case Rt.LightRGBW:return Br.LightRGBW;case Rt.PreciseGateControl:return Br.SetGatePositionPrecise;default:throw new Po("Unsupported task type!")}}GetSupportedTaskTypesAsync(){return e=this,t=void 0,r=function*(){const e=yield hy.Get(ao.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[eo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(eo.DelayTask),(t>5||5==t&&n>=37)&&r.push(eo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(eo.NotifyTaskAppNotify),r},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}Build(){const e=t=>{if(t.RightArgumentType!=Ao.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==Ao.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}GetAllowedArguments(){const e=[];return null==this._result?(e.push({ArgumentType:So.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:So.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:So.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:So.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:So.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:So.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1})):null!=this._result&&(null==this._result.RightArgument||this._result.RightArgument instanceof To)&&(this._result.LeftArgumentType==Ao.ArgumentAsDaysOfWeek&&(e.push({ArgumentType:So.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),e.push({ArgumentType:So.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0})),this._result.LeftArgumentType==Ao.ArgumentAsTime&&e.push({ArgumentType:So.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1}),this._result.LeftArgumentType==Ao.ArgumentAsAstronomicalClockWithOffset&&e.push({ArgumentType:So.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1})),0==e.any((e=>e.ArgumentType==So.ArgumentAsAstronomicalClockWithOffset))&&e.push({ArgumentType:So.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==So.ArgumentAsDaysOfWeek))&&e.push({ArgumentType:So.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==So.ArgumentAsDeviceState))&&e.push({ArgumentType:So.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==So.ArgumentAsSceneExecuted))&&e.push({ArgumentType:So.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),0==e.any((e=>e.ArgumentType==So.ArgumentAsTime))&&e.push({ArgumentType:So.ArgumentAsTime,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==So.ArgumentAsTimeSpan))&&e.push({ArgumentType:So.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e}ValidateScene(){var e,t,n,r;if(null==this._result)throw new Error("No context!");const s=[],o=(e,t,n)=>e.RightArgumentType==Ao.Null?e.LeftArgumentType==t&&e.AtMeetCondition==n?e:null:e.LeftArgumentType==t&&e.AtMeetCondition==n?e:o(e.RightArgument,t,n),i=o(this._result,Ao.ArgumentAsDaysOfWeek,!0);null!=i&&((null===(e=i.RightArgument)||void 0===e?void 0:e.LeftArgumentType)==Ao.ArgumentAsTime||(null===(t=i.RightArgument)||void 0===t?void 0:t.LeftArgumentType)==Ao.ArgumentAsAstronomicalClockWithOffset)&&s.push(wo.OptimizeDayOfWeekArgument);const a=o(this._result,Ao.ArgumentAsTime,!0);return null!=a&&(null===(n=a.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==Ao.ArgumentAsDaysOfWeek&&(null===(r=a.RightArgument)||void 0===r?void 0:r.AtMeetCondition)&&s.push(wo.OptimizeAtInDayOfWeekArgument),{IsValid:0==s.length,Errors:s,TryFix:()=>this.TryFix(s),Ignore:()=>this.Commit()}}TryFix(e){if(null==this._result)throw new Error("No context!");if(e.includes(wo.OptimizeDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==Ao.ArgumentAsDaysOfWeek?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==Ao.ArgumentAsTime||(null===(r=t.RightArgument)||void 0===r?void 0:r.LeftArgumentType)==Ao.ArgumentAsAstronomicalClockWithOffset?t:e(t.RightArgument):t.RightArgumentType==Ao.Null?null:e(t.RightArgument)},t=e(this._result);if(null==t)throw new Error("Something wrong! Cannot find 'days of week' argument! Cannot fix!");const n=structuredClone(t),r=t.RightArgument;t.LeftArgument=r.LeftArgument,t.LeftArgumentType=r.LeftArgumentType,t.HandledType=r.HandledType,r.LeftArgument=n.LeftArgument,r.LeftArgumentType=n.LeftArgumentType,r.HandledType=n.HandledType,r.AtMeetCondition=!1}if(this.ValidateScene().Errors.includes(wo.OptimizeAtInDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==Ao.ArgumentAsTime?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==Ao.ArgumentAsDaysOfWeek&&(null===(r=t.RightArgument)||void 0===r?void 0:r.AtMeetCondition)?t:e(t.RightArgument):t.RightArgumentType==Ao.Null?null:e(t.RightArgument)},t=e(this._result);if(null==t)return this.Commit();t.RightArgument.AtMeetCondition=!1}return this.Commit()}}!function(e){e.OptimizeDayOfWeekArgument="OptimizeDayOfWeekArgument",e.OptimizeAtInDayOfWeekArgument="OptimizeAtInDayOfWeekArgument"}(wo||(wo={})),function(e){e.Unknown="Unknown",e.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",e.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",e.ArgumentAsTimeSpan="ArgumentAsTimeSpan",e.ArgumentAsTime="ArgumentAsTime",e.ArgumentAsDeviceState="ArgumentAsDeviceState",e.ArgumentAsSceneExecuted="ArgumentAsSceneExecuted"}(So||(So={}));class Co{constructor(){this.Tasks=new Io,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=Js.Unknown,this.ConditionType=Xs.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=Ao.Null,this.RightArgumentType=Ao.Null,this.LeftArgument=new Do({},Ao.Null),this.RightArgument=new To}}class To{constructor(){this.HandledType=0,this.Argument=null}}class Do{constructor(e,t){this.Argument=e,this.HandledType=t}}class ko{constructor(){this.DeviceStateType=Ys.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=qs.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class Io{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class Eo{constructor(){this.Guid=Jr.NewGuid(),this.RunParallel=!1,this.TaskType=js.Unknown}}class bo extends Eo{constructor(){super(...arguments),this.TaskType=js.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=Br.TurnOn}}class No extends Eo{constructor(){super(...arguments),this.TaskType=js.DelayTask,this.Delay="00:00:00"}}class Go extends Eo{constructor(){super(...arguments),this.TaskType=js.LockExecution,this.LockType=no.Timeout,this.LockStartHour="00:00:00",this.LockEndHour="00:00:00",this.ResetLockScenesGuids=[]}}class Ro extends Eo{constructor(){super(...arguments),this.TaskType=js.NotifyTask,this.Title="",this.Message="",this.NotifyType=to.None,this.NotificationClients=[]}}!function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(Ao||(Ao={}));class Po extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class Uo 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 Mo extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var xo,Fo=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Lo{constructor(){this._connection=hy.Get(It.ServiceName),this._configurationService=hy.Get(ct.ServiceName)}GetServiceName(){return Lo.ServiceName}GetSequencesListAsync(){return Fo(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Bo,12e3,!1);return null===(t=u.Log)||void 0===t||t.Debug(`GetSequencesListAsync result:\n ${JSON.stringify(n)}}`),null==n?new Ee(Vs.OtherError,"Cannot get sequences list - response is null."):n.Status!=ue.OK?new Ee(Vs.OtherError,`Cannot get sequences list - controller responded with response code ${n.Status}.`):null==n.Data?new Ee(Vs.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):n.Data}))}GetSequenceAsync(e){return Fo(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 $o(n),12e3,!1);if(null==r)return new Ee(Vs.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ue.OK)return new Ee(Vs.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new Ee(Vs.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");const s=r.Data;let o=this.MapSequence(s);if("string"==typeof e){let e=yield this.GetSequencesListAsync();if(e instanceof Ee){let t=e;console.warn(`Cannot get sequence - response is null. Error: ${t.Data} ${t.Type}`)}else{const t=e.find((e=>e.Guid==n));if(!t)return new Ee(Vs.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");o.IsDisabled=t.IsDisabled}}else{const e=s;o.IsDisabled=e.IsDisabled}return o}))}GetSequenceBuilder(e,t){return new _o(e,t)}CreateSequenceAsync(e){return Fo(this,void 0,void 0,(function*(){var t,n,r,s;try{yield this._configurationService.EnterConfigurationModeAsync(),null===(t=u.Log)||void 0===t||t.Debug(`Creating sequence ${e.Name} json: \n${JSON.stringify(e)}`);const r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Ho(e),2e4,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(t){return null===(r=u.Log)||void 0===r||r.Error(`Creating sequence ${e.Name} error: ${t}`),ue.FatalError}finally{null===(s=u.Log)||void 0===s||s.Error(Lo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! CreateSequenceAsync()"),yield this._configurationService.ExitConfigurationModeAsync(),yield hy.Get(Yo.ServiceName).GetDevicesAsync(!0)}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){return Fo(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 Wo(n),12e3,!1);if(null==r)return new Ee(Vs.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ue.WrongData:return new Ee(Vs.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ue.OK:return null==r.Data?new Ee(Vs.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new Ee(Vs.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new Ee(Vs.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){return Fo(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 jo(n),12e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield hy.Get(Yo.ServiceName).GetDevicesAsync(!0)}}))}EditSequenceAsync(e){return Fo(this,void 0,void 0,(function*(){var t,n;try{const n={Guid:e.Guid,Icon:e.Icon,Name:e.Name,Condition:e};var r=n.Condition.IsDisabled;n.Condition.IsDisabled=!1,yield this._configurationService.EnterConfigurationModeAsync();const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Ko(n),2e4,!1);return n.Condition.IsDisabled=r,null==s||null==s.Status?ue.Error:s.Status}catch(t){return null===(n=u.Log)||void 0===n||n.Error(`Editing sequence ${e.Name} error: ${t}`),ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield hy.Get(Yo.ServiceName).GetDevicesAsync(!0)}}))}EnableSequenceAsync(e){return Fo(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 zo(n),12e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}DisableSequenceAsync(e){return Fo(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 Jo(n),12e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}RunSequenceAsync(e){return Fo(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ue.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ue.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new Zr;switch(n.Channel=1,n.DeviceGuid=t,yield hy.Get(Yo.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case Ft.Executed:return ue.OK;case Ft.DeviceNotFound:return ue.WrongData;default:return ue.Error}}))}GetUtilsAsync(){return Fo(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 Fo(this,void 0,void 0,(function*(){var e;const t=hy.Get(Os.ServiceName),n=new Ns;let r=!1;n.Latitude=49.9958888026741,n.Longitude=18.9172596008914;try{if(!0===(yield t.IsControllerGeolocationSetAsync())){const e=yield t.GetControlllerGeolocationAsync();e instanceof Gs&&(n.Latitude=e.Latitude,n.Longitude=e.Longitude)}}catch(t){null===(e=u.Log)||void 0===e||e.Warning(`Cannot get localization data, using default values: 49.9958888026741, 18.9172596008914. Error: ${t}`)}const s=e=>{let t=7.95204*Math.sin(.01768*e+3.03217)+9.98906*Math.sin(.03383*e+3.4687)+4*(n.Longitude-15*Math.round(n.Longitude/15));return((e=new Date)=>{const t=new Date(e.getFullYear(),0,1).getTimezoneOffset(),n=new Date(e.getFullYear(),6,1).getTimezoneOffset();return Math.max(t,n)!==e.getTimezoneOffset()})()&&(t-=60),t},o=e=>Math.asin(-.39795*Math.cos(2*Math.PI*(e+10)/365)),i=e=>{const t=n.Latitude*Math.PI/180;let r=Math.sin(t)*Math.sin(e)/(Math.cos(t)*Math.cos(e));return r=(e=>(e<-1&&(e=-1),e>1&&(e=1),e))(r),r},a=e=>{const t=Math.ceil(e/60),n=e-60*t,r=new Date;return new Date(r.getFullYear(),r.getMonth(),r.getDate(),t,n)},c=e=>{const t=new Date;t.setDate(t.getDate()+e);const n=(u=t,Math.floor((u.valueOf()-new Date(u.getFullYear(),0,0).valueOf())/1e3/60/60/24));var u;const l=s(n),d=o(n),h=((e,t)=>{let n=720-720/Math.PI*Math.acos(-e)-t;return n<0&&(n+=1440),n})(i(d),l),p=a(h);return new Date>p&&!r?(r=!0,c(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),p.getHours(),p.getMinutes()))},l=e=>{const t=new Date;t.setDate(t.getDate()+e);const n=(c=t,Math.floor((c.valueOf()-new Date(c.getFullYear(),0,0).valueOf())/1e3/60/60/24));var c;const u=s(n),d=o(n),h=i(d),p=Math.floor(((e,t)=>{let n=720+720/Math.PI*Math.acos(-e)-t;return n>1439&&(n-=1439),n})(h,u)),g=a(p);return new Date>g&&!r?(r=!0,l(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),g.getHours(),g.getMinutes()))};return{GetSunRiseTime:()=>c(0),GetSunSetTime:()=>l(0)}}))}MapSequence(e,t=!1){const n=Object.assign({},e),r=e=>{if(e.RightArgumentType!=xo.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=js.DeviceTask,e.RunParallel=!1}))),null!=e.Tasks.ControllerTasks&&e.Tasks.ControllerTasks.map((e=>{null==(null==e?void 0:e.Guid)&&(e.Guid=Jr.NewGuid())}))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=Zs.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==Zs.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===Zs.Condition&&(e.RightArgumentType=this.MapArgumentType(e.RightArgumentType),e.RightArgument=this.MapRightArgument(e.RightArgument,e.RightArgumentType))),e}MapLeftArgument(e,t){let n=new Vo;switch(n.HandledType=e.HandledType,t){case Zs.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case Zs.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case Zs.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case Zs.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case Zs.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case Zs.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case Zs.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case Zs.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case Zs.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case Zs.ArgumentAsDeviceState:{const t=new go;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?qs.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam(Hs[e[0]],new fo(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam(Hs[e[0]],new vo(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case Zs.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return Zs[xo[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case Ys.BatteryState:return Pt.BatteryState;case Ys.BinarySensor:return Pt.BinarySensorState;case Ys.BlindPosition:return Pt.BlindPosition;case Ys.Brightness:return Pt.MeasuredBrightness;case Ys.ButtonState:return Pt.RemoteButtonState;case Ys.ChannelOnOff:return Pt.ChannelOnOffState;case Ys.DoorBell:return Pt.DoorBellState;case Ys.Energy:return Pt.MeasuredEnergy;case Ys.FloodSensor:return Pt.FloodSensorState;case Ys.GatePosition:return Pt.GatePosition;case Ys.LightBrightness:return Pt.LightBrightness;case Ys.LightColor:return Pt.LightColor;case Ys.LightTemperature:return Pt.LightWarmth;case Ys.ReedState:return Pt.ReedState;case Ys.SmokeSensor:return Pt.SmokeSensorState;case Ys.Temperature:return Pt.MeasuredTemperature;case Ys.Humidity:return Pt.HumiditySensorState;case Ys.BlindsControlButton:return Pt.BlindRemoteButtonState;case Ys.FacadeControlButton:return Pt.FacadeRemoteButtonState;case Ys.Movement:return Pt.MovementSensorState;case Ys.AirPressure:return Pt.PressureSensorState;case Ys.WindSpeed:return Pt.WindSpeedState;case Ys.WindThreshold:return Pt.CurrentWindThreshold;default:return Pt.Unknown}}CreateDeviceState(e,t,n){switch(n){case Pt.BatteryState:return{Channel:t,StateReliability:zt.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case Pt.BinarySensorState:return{Channel:t,StateReliability:zt.Unconfident,State:e.State,Time:""};case Pt.BlindPosition:return{Channel:t,StateReliability:zt.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case Pt.LightBrightness:case Pt.MeasuredBrightness:return{Channel:t,StateReliability:zt.Unconfident,Brightness:e.Brightness,Time:""};case Pt.RemoteButtonState:case Pt.ChannelOnOffState:case Pt.DoorBellState:return{Channel:t,StateReliability:zt.Unconfident,State:e.State,Time:""};case Pt.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(nn[t],r);return{Channel:t,StateReliability:zt.Unconfident,MeasurementParameters:n,Time:""}}case Pt.FloodSensorState:return{Channel:t,StateReliability:zt.Unconfident,State:e.State,Time:""};case Pt.GatePosition:return{Channel:t,StateReliability:zt.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case Pt.LightColor:return{Channel:t,StateReliability:zt.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case Pt.LightWarmth:return{Channel:t,StateReliability:zt.Unconfident,Temperature:e.Temperature,Time:""};case Pt.ReedState:return{Channel:t,StateReliability:zt.Unconfident,State:e.State,Time:""};case Pt.SmokeSensorState:throw new mo("Unsupported device state!");case Pt.MeasuredTemperature:return{Channel:t,StateReliability:zt.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case Pt.HumiditySensorState:return{Channel:t,StateReliability:zt.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case Pt.BlindRemoteButtonState:return{Channel:t,StateReliability:zt.Unconfident,State:e.State,Time:""};case Pt.LightRGBWState:return{StateReliability:zt.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case Pt.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:zt.Unconfident,State:e.State};case Pt.MovementSensorState:return{Channel:t,Time:"",StateReliability:zt.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case Pt.PressureSensorState:return{Channel:t,Time:"",StateReliability:zt.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case Pt.WindSpeedState:return{Channel:t,Time:"",StateReliability:zt.Unconfident,Value:e.Value};case Pt.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:zt.Unconfident,WindThreshold:e.WindThreshold};case Pt.Unknown:return new kn;default:throw new mo("Unsupported device state!")}}MapDeviceTask(e){var t;let n=new Xr,r=e;switch(null===(t=u.Log)||void 0===t||t.Debug(`[TASK] object: ${JSON.stringify(r)}`),r.ControlFeature){case Br.TurnOn:n=new Zr,n.TaskType=Rt.TurnOn;break;case Br.TurnOff:n=new Qr,n.TaskType=Rt.TurnOff;break;case Br.ToggleState:n=new ns,n.TaskType=Rt.TogleState;break;case Br.SetBlindPosition:{const e=hy.Get(Yo.ServiceName).GetDevice(r.DeviceGuid);(null==e?void 0:e.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType)))?(n=new as,n.TaskType=Rt.SetBlindPositionSimple,n.Action=r.Data.Action):(n=new os,n.TaskType=Rt.SetBlindPosition,n.Action=r.Data.Action,n.Position=r.Data.Position);break}case Br.SetLightColor:n=new rs,n.TaskType=Rt.SetLightColor,n.R=r.Data.R,n.G=r.Data.G,n.B=r.Data.B;break;case Br.SetLightTemperature:n=new ss,n.TaskType=Rt.SetLightTemperature,n.Temperature=r.Data.Temperature;break;case Br.SetLightBrightness:n=new ts,n.TaskType=Rt.SetLightBrightness,n.Brightness=r.Data.Brightness;break;case Br.SetTemperature:n=new Yr,n.TaskType=Rt.SetTemperature,n.Temperature=r.Data.Temperature;break;case Br.GetState:n=new hs,n.TaskType=Rt.GetChannelsState;break;case Br.TurnOnWithTimeout:n=new es,n.TaskType=Rt.TurnOnWithTime,n.SwitchOffDelaySeconds=r.Data.SwitchOffDelaySeconds;break;case Br.SetLightBrightnessDynamicly:n=new cs,n.TaskType=Rt.SetLightBrightnessDynamicly,n.Brightness=r.Data.Brightness;break;case Br.IdentifyDevice:n=new us,n.TaskType=Rt.IdentifyDevice;break;case Br.SetBlindOpenCloseTime:n=new ls,n.TaskType=Rt.SetBlindOpenCloseTime,n.Data.CloseTime=r.Data;break;case Br.SetBlindMicroventilation:n=new ps,n.TaskType=Rt.SetBlindMicroventilation,n.Position=r.Data.Position;break;case Br.GatewayPulse:n=new fs,n.TaskType=Rt.ChangeGatewayPositionPulse;break;case Br.GatePulse:n=new gs,n.TaskType=Rt.ChangeGatePositionPulse;break;case Br.SetFacadePositionAndTilt:n=new vs,n.TaskType=Rt.SetFacadePosition,n.Position=r.Data.Position,n.Tilt=r.Data.Tilt,n.FacadeAction=qr.TiltAndPercentage;break;case Br.GetFacadeType:n=new ys,n.TaskType=Rt.GetFacadeType;break;case Br.LightRGBW:n=new ws,n.TaskType=Rt.LightRGBW,n.Data=r.Data;break;case Br.SetGatePositionPrecise:n=new is,n.TaskType=Rt.PreciseGateControl,n.Position=r.Data.Position,n.GateControlAction=r.Data.GateControlAction}return n.Channel=r.Channel,n.DeviceGuid=r.DeviceGuid,n.FeatureType=r.ControlFeature,n.Guid=Jr.NewGuid(),n}MapControllerTasks(e){var t,n;const r=[];null===(t=u.Log)||void 0===t||t.Debug(`[TASKS] received tasks object: ${JSON.stringify(e)}`);for(let t of e){const e=new qo;switch(e.Guid=t.Guid,e.TaskId=se.GenerateMd5(JSON.stringify(t)),t.TaskType){case js.DeviceTask:e.TaskType=zs.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(t);break;case js.DelayTask:e.TaskType=zs.DelayTask,e.Task.DelayTask={Delay:new vo(t.Delay)};break;case js.NotifyTask:e.TaskType=zs.NotifyTask,e.Task.NotifyTask={Message:t.Message,NotifyType:t.NotifyType,NotificationClients:t.NotificationClients};break;case js.LockExecution:case js.LockExecution:e.TaskType=zs.LockExecution,null===(n=u.Log)||void 0===n||n.Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(t)}`),e.Task.LockExecution={LockStartHour:new vo(t.LockStartHour),LockEndHour:new vo(t.LockEndHour),LockType:t.LockType,ResetLockScenesGuids:t.ResetLockScenesGuids};case js.Unknown:}r.push(e)}return r}GetSupportedTaskTypesAsync(){return Fo(this,void 0,void 0,(function*(){const e=yield hy.Get(ao.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[eo.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(eo.DelayTask),(t>5||5==t&&n>=37)&&r.push(eo.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(eo.NotifyTaskAppNotify),r}))}}Lo.ServiceName="ScenesService";class Bo extends ce{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=le.Get}}class $o extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Get,this.Data=e}}class Wo extends ce{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=le.Get,this.Data=e}}class Vo{constructor(){this.HandledType=xo.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"}(xo||(xo={}));class qo{constructor(){this.TaskId="",this.Guid="",this.TaskType=zs.Unknown,this.Task={}}}class Ho extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Put,this.Data=e}}class Ko extends ce{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=le.Put,this.Data=e}}class jo extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Delete,this.Data=e}}class zo extends ce{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=le.Post,this.Data=e}}class Jo extends ce{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=le.Post,this.Data=e}}var Xo=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 Yo{constructor(){var e;this._devices=[],this._onDevicesTasksChangedEvent=new c,this._onDeviceFoundEvent=new c,this._onDeviceRegisteredEvent=new c,this._onDeviceRemovedEvent=new c,this._onDeviceFirmwareVersionChangedEvent=new c,this._onDeviceStateChangedEvent=new c,this._onDeviceStateRefreshedOrChangedEvent=new c,this._connection=null,this._session=null,this._controllerConfiguration=null,this._synchronized=!1,this._synchronizedDevicesStates=!1,this._devicesChannelsStates=[],this._onDevicesSynchronized=new ke,this._onDevicesStatesSynchronized=new ke,this._syncSemaphore=new et(1),this._connection=hy.Get(It.ServiceName),this._session=hy.Get(Xe.ServiceName),this._controllerConfiguration=hy.Get(ct.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>Xo(this,void 0,void 0,(function*(){return this.PutDeviceStateOnList(e.Device,e.State)})))),null===(e=this._session)||void 0===e||e.OnUserLoggedInEvent().Subscribe((e=>Xo(this,void 0,void 0,(function*(){var t,n;try{null===(t=u.Log)||void 0===t||t.Debug(Yo.ServiceName,`User logged in: ${e.Guid} syncing devices...`),yield this.ResyncDevicesAsync()}catch(e){null===(n=u.Log)||void 0===n||n.Error(Yo.ServiceName,`Failed to sync devices and states: ${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!=Mt.Scene&&(null===(t=u.Log)||void 0===t||t.Debug(Yo.ServiceName,`Found device: ${e.Name} guid: ${e.Guid}`),this._onDeviceFoundEvent.Invoke(e))}))})),this._connection.SubscribeTo("/info/devices/device/firmware/updated",(e=>{const t=e.Data.DeviceGuid,n=e.Data.Version,r=this._devices.find((e=>e.Guid==t));void 0!==r&&(this._onDeviceFirmwareVersionChangedEvent.Invoke({Device:r,FirmwareVersion:n}),r.SoftwareVersion=n,r.OnDeviceFirmwareVersionChangedEvent().Invoke({FirmwareVersion:n}))})),this._connection.SubscribeTo("/info/devices/device/state/changed",(e=>{var t;const n=e.Data,r=this._devices.filter((e=>e.Guid==n.DeviceGuid));if(r.length>0){const e=r[0],s=this.MapApiDeviceStateToDeviceState(e,n);if(null!=s){this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:s}),s.TypeAsEnum==Pt.SignalStrength?e.Channels.forEach((t=>{let r=new cr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==Pt.BatteryState&&e.Channels.forEach((t=>{let r=new Jn(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==Pt.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==Pt.SignalStrength?e.Channels.forEach((t=>{let r=new cr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==Pt.BatteryState&&e.Channels.forEach((t=>{let r=new Jn(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==Pt.SignalStrength?e.Channels.forEach((t=>{let r=new cr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==Pt.BatteryState&&e.Channels.forEach((t=>{let r=new Jn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{hy.Get(Be.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Yo.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{hy.Get(Be.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Yo.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}ResyncDevicesAsync(){return Xo(this,void 0,void 0,(function*(){var e;const t=yield this._syncSemaphore.AcquireAsync();try{this._synchronized=!1,this._synchronizedDevicesStates=!1,this._devices=yield this.GetPairedDevicesAsync(!0),this._synchronized=!0,this._onDevicesSynchronized.Invoke(),yield this.SyncDevicesStatesAsync(),this._synchronizedDevicesStates=!0,this._onDevicesStatesSynchronized.Invoke()}catch(t){null===(e=u.Log)||void 0===e||e.Error(Yo.ServiceName,`Failed to sync devices and states: ${t}`)}finally{t.Release()}}))}WaitForSynchronizationAsync(){var e;return this._synchronized?(null===(e=u.Log)||void 0===e||e.Debug(Yo.ServiceName,"Already synchronized"),Promise.resolve()):new Promise((e=>{const t=window.setTimeout((()=>{this._onDevicesSynchronized.Unsubscribe(n),e()}),3e4),n=()=>{var r;null===(r=u.Log)||void 0===r||r.Debug(Yo.ServiceName,"Fired onDevicesSynchronized event – clearing timeout & resolving promise"),window.clearTimeout(t),this._onDevicesSynchronized.Unsubscribe(n),e()};this._onDevicesSynchronized.Subscribe(n)}))}WaitForDevicesStatesSynchronizationAsync(){var e;return this._synchronizedDevicesStates?(null===(e=u.Log)||void 0===e||e.Debug(Yo.ServiceName,"Already synchronized states"),Promise.resolve()):new Promise((e=>{const t=window.setTimeout((()=>{this._onDevicesStatesSynchronized.Unsubscribe(n),e()}),12e4),n=()=>{var r;null===(r=u.Log)||void 0===r||r.Debug(Yo.ServiceName,"Fired onDevicesStatesSynchronized event, CLEARING timeout AND resolving WaitForDevicesStatesSynchronizationAsync promise"),window.clearTimeout(t),this._onDevicesStatesSynchronized.Unsubscribe(n),e()};this._onDevicesStatesSynchronized.Subscribe(n)}))}ProtocolGuidToProtocolName(e){switch(e){case"1fca7e8a-a2dc-4883-bd94-4e9b2012f685":return"ExtaLife";case"cd25bdff-628c-4dbc-a16a-648c96a819d4":return"Portos 433MHz";case"634c2bb2-1a4f-4db6-8dd4-d5fbaf92678e":return"Supla";case"194aeb81-990c-4a02-9236-59e902958fda":return"RTSP";case"b3e4644e-ab5b-494e-b3c5-66fabe7fff64":return"Wekta";case"247198e1-e360-4355-9886-232ac1456eea":return"Lavva Wi-Fi";default:return null}}CanDisplaySceneDevices(){return this.CheckIfControllerSoftwareVersionIsEnough(6,56)}CheckIfControllerSoftwareVersionIsEnough(e,t){var n,r,s;const o=null!==(s=null===(r=null===(n=this._session)||void 0===n?void 0:n.User)||void 0===r?void 0:r.SoftwareVersion)&&void 0!==s?s:null;if(!o||!o.includes("."))return!1;const i=o.split(".");if(2!==i.length)return!1;const a=i.map((e=>parseInt(e,10)));if(a.some((e=>Number.isNaN(e)||e<0)))return!1;const[c,u]=a;return c>e||c===e&&u>=t}CheckIfDeviceUsedInScenesAsync(e){return Xo(this,void 0,void 0,(function*(){var t,n,r,s,o,i;try{let i;if("string"==typeof e){const n=this.GetDevice(e);if(null==n)return null===(t=u.Log)||void 0===t||t.Error("Cannot check if device is used in scenes! Device with given guid not exists"),ue.ResourceDoesNotExists;i=n}else i=e;const a=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new di(i.Guid),2e4,!1);if(null==a||null==a.Status)return null===(r=u.Log)||void 0===r||r.Error("Cannot check if device is used in scenes! Response or status is null!"),ue.FatalError;if(a.Status!=ue.OK)return a.Status;if(null==a.Data)return null===(s=u.Log)||void 0===s||s.Error("Cannot check if device is used in scenes! No data!"),ue.FatalError;let c=yield hy.Get(Lo.ServiceName).GetSequencesListAsync();if(c instanceof Ee)return null===(o=u.Log)||void 0===o||o.Error(`Cannot check if device is used in scenes! Cannot get sequence list, ScenesServiceErrorCode: ${c.Type}`),ue.Error;const l=new fi;return l.DeviceGuid=i.Guid,a.Data.ConditionsAsCondition.forEach((e=>{const t=c.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),a.Data.ConditionsAsTask.forEach((e=>{const t=c.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),l}catch(e){return null===(i=u.Log)||void 0===i||i.Error(`Cannot check if device is used in scenes! ${e}`),ue.FatalError}}))}CanEditDevicesInfo(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=fe.Admin}CanAddAndRemoveAndConfigureDevices(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=fe.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return Xo(this,void 0,void 0,(function*(){var e;const t=hy.Get(Ds.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return null===(e=u.Log)||void 0===e||e.Error(Yo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EnableFastStatesSyncAsync()"),yield hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),t}))}DisableFastStatesSyncAsync(){return Xo(this,void 0,void 0,(function*(){var e;const t=hy.Get(Ds.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return null===(e=u.Log)||void 0===e||e.Error(Yo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DisableFastStatesSyncAsync()"),yield hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),t}))}IsFastStatesSyncEnabledAsync(){return Xo(this,void 0,void 0,(function*(){const e=yield hy.Get(Ds.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof _s?e.Data:e!=ue.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return Xo(this,void 0,void 0,(function*(){let t=hy.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 Xo(this,void 0,void 0,(function*(){var t;let n=yield hy.Get(As.ServiceName).AddManuallyPairedDeviceAsync(e);return null===(t=u.Log)||void 0===t||t.Error(Yo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDevice()"),yield hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),n}))}GetDeviceChannelStates(e,t){var n,r;return null!==(r=null===(n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===n?void 0:n.ChannelsStates.filter((e=>e.Channel==t)))&&void 0!==r?r:[]}GetDeviceStates(e){var t,n;return null!==(n=null===(t=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===t?void 0:t.ChannelsStates)&&void 0!==n?n:[]}PutDeviceStateOnList(e,t){let n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid));if(null==n){let r=new Qo;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 Qo,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e);else{let n=e.States.firstOrDefault((e=>e.Type==t.Type));null!=n&&(n.TypeAsEnum==Pt.BlindErrorState?e.States=e.States.where((e=>e.Data.ErrorCode!=t.Data.ErrorCode)).toArray():e.States=e.States.where((e=>e.Type!=t.Type)).toArray()),e.States.push(t)}}}GetCurrentlyRunningTaksAsync(){return Xo(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new oi,15e3,!1);(null==t?void 0:t.Status)==ue.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{const n=e.split(";"),r=new Kt;if(r.DeviceGuid=n[0],r.Channel=Number(n[1]),r.Status=Et.ExecutingTasks,t.push(r),0===r.Channel){const e=this._devices.find((e=>e.Guid==r.DeviceGuid));void 0!==e&&e.Channels.forEach((n=>{const r=new Kt;r.DeviceGuid=e.Guid,r.Channel=n.Number,r.Status=Et.ExecutingTasks,t.push(r)}))}})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new In(t);case"DoorBell":return new Pn(t);case"ReedPosition":return new On(t);case"BlindPosition":return new xn(t);case"ButtonState":return new Ln(t);case"LightColor":return new $n(t);case"LightTemperature":return new Vn(t);case"LightBrightness":return new Hn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new jn(t);case"BatteryState":return new Jn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new Yn(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":case"IGetPowerMeasurements":return new Zn(t);case"DistanceSensor":return new tr(t);case"MovementSensor":return new nr(t);case"BlindsControlButton":return new sr(t);case"FacadeControlButton":return new ir(t);case"SignalStrength":return new cr(t);case"GatePosition":return new ur(t);case"GatewayPosition":return new dr(t);case"GateControllerHealth":return new hr(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new pr(t);case"HumiditySensor":case"HumidityState":return new gr(t);case"VibrationSensor":return new vr(t);case"DigitalInputSensor":return new yr(t);case"ConfigurationState":return new wr(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new Sr(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new Ar(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new _r(t);case"FacadePosition":case"FacadeState":return new Cr(t);case"FacadeTypeState":return new Tr(t);case"CurrentWindThreshold":return new Dr(t);case"CurrentLightThreshold":return new Ir(t);case"WindSpeed":return new Er(t);case"FloodSensor":return new Nr(t);case"PressureState":return new Rr(t);case"ITamperProtection":case"TamperProtection":return new Ur(t);case"ILightRGBW":case"LightRGBW":return new Or(t);case"OnlineCamera":case"IOnlineCamera":return new Rn(t);case"BlindError":case"IBlindError":return t.state.ErrorData=ie(t.state.ErrorData),new Mr(t);case"HallState":return new bn(t);case"SceneExecuted":return new Nn(t);case"Intercom":return new Gn(t);default:null===(n=u.Log)||void 0===n||n.Debug(Yo.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return Yo.ServiceName}SyncDevicesStatesAsync(){return Xo(this,arguments,void 0,(function*(e=!1){var t,n;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ei,15e3,!1);if(!0!==(yield this.IsFastStatesSyncEnabledAsync())||e){let e=new ti;e.Data=!0;const t=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(e,35e3,!1);return(null==t?void 0:t.Status)==ue.OK}return(null==r?void 0:r.Status)==ue.OK}))}OnDevicesTasksExecutionChangeEvent(){return this._onDevicesTasksChangedEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}OnDeviceStateRefreshedOrChangedEvent(){return this._onDeviceStateRefreshedOrChangedEvent}OnDeviceRegisteredEvent(){return this._onDeviceRegisteredEvent}OnDeviceRemovedEvent(){return this._onDeviceRemovedEvent}OnDeviceFoundEvent(){return this._onDeviceFoundEvent}MapApiDevices(e){const t=[];return null==e?[]:(e.forEach((e=>{var n,r,s,o;let i=new xr;i.Guid=e.Guid,i.Name=e.DeviceName,i.ChannelsAmount=e.ChannelsNumber,i.DeviceType=e.DeviceType,i.CommunicationWay=e.CommunicationWay,i.DeviceState=e.DeviceState,i.IsEnabled=e.IsEnabled,i.IsVirtual=e.IsVirtual,i.SerialNumber=e.DeviceSerialNumber,i.ManufacturerGuid=e.ManufacturerGuid,i.ModelGuid=e.DeviceModelGuid,i.Model=e.DeviceModel,i.Name=e.DeviceName,i.ProtocolGuid=e.ProtocolGuid,void 0!==e.IconType&&null!==e.IconType?i.IconType=e.IconType:i.IconType=Gt.Unknown;try{if(null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{let t=new qt;if(i.CommunicationWay==Ot.OneWay)"IBlindPosition"===e&&(t.InterfaceType="IBlindPositionSimple");else switch(e){case"IGatePosition":t.InterfaceType="IGatePulse";break;case"IGatewayPosition":t.InterfaceType="IGatewayPulse";break;default:t.InterfaceType=e}i.AvailableTaskTypes.push(t)})),null===(r=e.AvailableResponses)||void 0===r||r.forEach((e=>{let t=new Ht;t.InterfaceType=e,i.AvailableResponseTypes.push(t)})),null===(s=e.ChannelsConfiguration)||void 0===s||s.forEach((e=>{var t,n,r;try{let r=new Hr;r.Number=e.Channel,i.Channels.push(r),r.SetDevice(i),r.Name=e.ChannelName,r.ChannelGroups=e.GroupsGuids,r.IconName=e.IconName,r.IsHidden=e.Hidden,r.Configurations=e.Configurations,r.CustomDataAndRolesSupported=void 0!==e.CustomData&&null!==e.CustomData,void 0!==e.CustomData&&null!==e.CustomData&&(r.CustomData=e.CustomData),void 0!==e.Roles&&null!==e.Roles&&(r.Roles=e.Roles),null===(t=e.AvailableResponses)||void 0===t||t.forEach((e=>{let t=new Ht;t.InterfaceType=e,r.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{let t=new qt;i.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType))?"IBlindPosition"==e&&(t.InterfaceType="IBlindPositionSimple"):t.InterfaceType=e,r.AvailableTaskTypes.push(t)}))}catch(e){null===(r=u.Log)||void 0===r||r.Error(e)}})),"f4cc5043-2198-47df-9361-4cd130ed0323"===i.ModelGuid&&i.Channels.first().AvailableTaskTypes.all((e=>e.Type!=Rt.GetPowerMeasurements))){let e=new qt;e.InterfaceType="IGetPowerMeasurements",i.Channels.first().AvailableTaskTypes.push(e)}}catch(e){null===(o=u.Log)||void 0===o||o.Error(e)}t.push(i)})),t)}GetPairedDevicesAsync(){return Xo(this,arguments,void 0,(function*(e=!1){var t,n,r;let s=yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync();if(this._synchronized&&!s)return e?Promise.resolve(this._devices):Promise.resolve(this._devices.filter((e=>e.DeviceType!=Mt.Scene)));const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Zo,15e3,!0);return null==o||void 0===o?[]:o.Status==ue.OK&&null!=o.Data?(this._devices=this.MapApiDevices(o.Data),e?this._devices:this._devices.filter((e=>e.DeviceType!=Mt.Scene))):(null===(r=u.Log)||void 0===r||r.Error(Yo.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(){return Xo(this,arguments,void 0,(function*(e=!1){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){return Xo(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new si,15e3,!1);return null==n?[]:n.Status==ue.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==Mt.Scene)).toArray():(null===(t=u.Log)||void 0===t||t.Error(Yo.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){return Xo(this,void 0,void 0,(function*(){var e;hy.Get(Be.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ni,35e3,!1)}))}StopSearchingForDevices(){return Xo(this,void 0,void 0,(function*(){var e;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ri,2e4,!1)}))}RegisterDeviceAsync(e){return Xo(this,void 0,void 0,(function*(){var t,n,r;try{const r=new ii;r.Data=e.Guid;const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(r,2e4,!1);return null===(n=u.Log)||void 0===n||n.Error(Yo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RegisterDeviceAsync()"),hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ue.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),Ft.Executed):Ft.Failed}catch(e){return null===(r=u.Log)||void 0===r||r.Error(Yo.ServiceName,`Failed to paired devices: ${e}`),Ft.ControllerResponseTimeout}}))}RemoveDeviceAsync(e){return Xo(this,arguments,void 0,(function*(e,t=!1){var n,r,s;try{let s=new ai;t&&(s=new ci),s.Data=e.Guid;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(s,35e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Yo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RemoveDeviceAsync()"),hy.Get(ct.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)==ue.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),Ft.Executed):Ft.Failed}catch(e){return null===(s=u.Log)||void 0===s||s.Error(Yo.ServiceName,`Failed to unpair device: ${e}`),Ft.ControllerResponseTimeout}}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new hi;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 pi;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 Wr.Open:n.Data=101;break;case Wr.Close:n.Data=102;break;case Wr.Stop:n.Data=103;break;case Wr.Percentage:n.Data=r.Position}break;case Br.SetGatePositionPreciseSecure:let t=0,s=r.Pin;switch(r.GateControlAction){case Wr.Open:t=101;break;case Wr.Close:t=102;break;case Wr.Stop:t=103;break;case Wr.Percentage:t=r.Position}n.Data={Position:t,Pin:s};break;case Br.SetBlindPosition:switch(r.Action){case $r.Open:n.Data=101;break;case $r.Close:n.Data=102;break;case $r.Stop:n.Data=103;break;case $r.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 gi;const o=r;n.FacadeAction=o.FacadeAction,n.Tilt=o.Tilt,n.Position=o.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){return Xo(this,void 0,void 0,(function*(){var n,r,s,o,i,a,c,l;try{null===(n=u.Log)||void 0===n||n.Debug(Yo.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new ui(l);null===(r=u.Log)||void 0===r||r.Debug(Yo.ServiceName,`Sending device task for execution, device: ${l.DeviceGuid} task: ${l.ControlFeature} channel: ${l.Channel} request: ${JSON.stringify(e)}`);const t=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(e,15e3,!1);switch(null==t?void 0:t.Status){case ue.OK:return Ft.Executed;case ue.FatalError:return null===(o=u.Log)||void 0===o||o.Error(Yo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),Ft.Failed;case ue.WrongData:if("DeviceNotFound"===t.Data)return Ft.DeviceNotFound;break;case ue.Error:return"DeviceResponseTimeout"===t.Data?Ft.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Yo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),Ft.Failed)}}catch(e){return e.message.includes("timeout")?(null===(a=u.Log)||void 0===a||a.Error(Yo.ServiceName,`Failed to get controller response in time.\n${e}`),Ft.ControllerResponseTimeout):(null===(c=u.Log)||void 0===c||c.Error(Yo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Ft.Failed)}return Ft.Unknown}catch(e){return null===(l=u.Log)||void 0===l||l.Error(Yo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Ft.Failed}}))}ExecuteDevicesTasksAsync(e){return Xo(this,void 0,void 0,(function*(){var t,n,r,s;let o=[],i=[],a=0;for(const[t,n]of e){const e=this.MapDeviceTaskToDeviceTaskInfo(t,n);e.SequnceExecutionOrder=a,a++,i.push(e)}const c=new li(i);try{const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(c,12e4,!1);let s=-1;null===(n=null==r?void 0:r.Data)||void 0===n||n.forEach((t=>{var n,i;s++;let a=Ft.Unknown;switch(t.Status){case ue.OK:a=Ft.Executed;break;case ue.FatalError:null===(n=u.Log)||void 0===n||n.Error(Yo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),a=Ft.Failed;break;case ue.WrongData:"DeviceNotFound"===t.Data&&(a=Ft.DeviceNotFound);break;case ue.Error:"DeviceResponseTimeout"===t.Data?a=Ft.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Yo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),a=Ft.Failed)}let c=0,l=new jt;for(const[t,n]of e){if(c==s){l.Device=t,l.Task=n,l.Channel=n.Channel,l.Result=a,o.push(l);break}c++}}))}catch(t){if(t.message.includes("timeout")){null===(r=u.Log)||void 0===r||r.Error(Yo.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new jt;o.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Ft.ControllerResponseTimeout}}else{null===(s=u.Log)||void 0===s||s.Error(Yo.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new jt;o.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Ft.Failed}}}return o}))}}Yo.ServiceName="DevicesService";class Qo{constructor(){this.Channel=0,this.States=[]}}class Zo extends ce{constructor(){super(),this.Resource="/devices/list",this.Method=le.Get}}class ei extends ce{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=le.Get}}class ti extends ce{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=le.Get}}class ni extends ce{constructor(){super(),this.Resource="/devices/search",this.Method=le.Post}}class ri extends ce{constructor(){super(),this.Resource="/devices/search/stop",this.Method=le.Post}}class si extends ce{constructor(){super(),this.Resource="/devices/found/list",this.Method=le.Get}}class oi extends ce{constructor(){super(),this.Resource="/devices/tasks",this.Method=le.Get}}class ii extends ce{constructor(){super(),this.Resource="/devices/device/pair",this.Method=le.Put}}class ai extends ce{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=le.Put}}class ci extends ce{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=le.Put}}class ui extends ce{constructor(e){super(),this.Resource="/devices/device/control",this.Method=le.Post,this.Data=e}}class li extends ce{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=le.Post,this.Data=e}}class di extends ce{constructor(e){super(),this.Resource="/logic/device/used",this.Method=le.Get,this.Data=e}}class hi{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=Br.GetState,this.SequnceExecutionOrder=0}}class pi extends hi{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class gi extends hi{constructor(){super(...arguments),this.FacadeAction=qr.Stop,this.Tilt=0,this.Position=0}}class fi{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class vi extends RangeError{paramName;constructor(e){super(`${e} was out of range. Must be non-negative and less than the size of the collection.`),this.paramName=e,this.name="ArgumentOutOfRangeException",this.stack=this.stack||(new Error).stack}}const yi=Object.freeze({MoreThanOneElement:"Sequence contains more than one element",MoreThanOneMatchingElement:"Sequence contains more than one matching element",NoElements:"Sequence contains no elements",NoMatch:"Sequence contains no matching element"});class mi extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const wi=(e,t)=>e===t;class Si{iterator;constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Ai{dataFunc;constructor(e){this.dataFunc=e}[Symbol.asyncIterator](){const{dataFunc:e}=this;return async function*(){if(1===e.type)for(const t of e.generator())yield t;else for(const t of await e.generator())yield t}()}}class _i{iterator;constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class Ci extends Array{}const Ti=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Ii(e,t,n,r)}return n?ki(e,t,n):Di(e,t)},Di=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},ki=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},Ii=(e,t,n,r)=>{let s=t;for(const t of e)s=n(s,t);return r(s)},Ei=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},bi=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Ni=(e,t)=>t?Ri(e,t):Gi(e),Gi=e=>{for(const t of e)return!0;return!1},Ri=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Pi=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},Ui=(e,t)=>new _i((function*(){yield*e,yield t})),Oi=e=>{if(Array.isArray(e)){if(0===e.length)throw new mi(yi.NoElements);return new Si((async function*(){for await(const t of e)yield t}))}return new Si(e)},Mi=e=>Oi((async function*(){for(const t of e)yield t})),xi=(e,t)=>new Ai({generator:t,type:e}),Fi=e=>xi(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Li=(e,t)=>{let n=0,r=0;if(t)for(const s of e)n+=t(s),r+=1;else for(const t of e)n+=t,r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},Bi=async(e,t)=>{let n=0,r=0;for(const s of e)n+=await t(s),r+=1;if(0===r)throw new mi(yi.NoElements);return n/r},$i=(e,t)=>{if(t<1)throw new vi("size");return new _i((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Wi=(e,t)=>new _i((function*(){yield*e,yield*t})),Vi=(e,t,n=wi)=>{for(const r of e)if(n(t,r))return!0;return!1},qi=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},Hi=(e,t)=>t?ji(e,t):Ki(e),Ki=e=>{let t=0;for(const n of e)t++;return t},ji=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},zi=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},Ji=(e,t)=>new _i((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),Xi=(e,t=wi)=>new _i((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Yi=(e,t)=>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}})),Qi=(e,t)=>new _i((function*(){for(const n of e)t(n),yield n})),Zi=(e,t)=>Oi((async function*(){for(const n of e)await t(n),yield n})),ea=(e,t)=>{if(t<0)throw new vi("index");let n=0;for(const r of e)if(t===n++)return r;throw new vi("index")},ta=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},na=(e,t,n=wi)=>new _i((function*(){const r=[...t];for(const t of e){let e=!1;for(let s=0;s<r.length;s++)if(!0===n(t,r[s])){e=!0;break}!1===e&&(yield t)}})),ra=(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)}})),sa=(e,t)=>t?ia(e,t):oa(e),oa=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new mi(yi.NoElements);return t.value},ia=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new mi(yi.NoMatch)},aa=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new mi(yi.NoMatch)},ca=(e,t)=>t?la(e,t):ua(e),ua=e=>e[Symbol.iterator]().next().value??null,la=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},da=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class ha extends Ci{key;constructor(e,t){super(1),this.key=e,this[0]=t}}const pa=(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 ha(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 ha(e,r)}for(const e in n)yield n[e]})(e,t),new _i(r)},ga=(e,t,n)=>n?va(e,t,n):fa(e,t),fa=(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 ha(e,r)}for(const e in n)yield n[e]})),va=(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 ha(e,s))}for(const e of r)yield e})),ya=(e,t,n,r)=>r?((e,t,n,r)=>new _i((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 ha(e,t))}}for(const e of s)yield e})))(e,t,n,r):((e,t,n)=>new _i((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 ha(e,i)}for(const e in r)yield r[e]})))(e,t,n),ma=(e,t,n,r,s,o)=>{const i=o?wa(e,t,n,r,s,o):Sa(e,t,n,r,s);return new _i(i)},wa=(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)}},Sa=(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)}},Aa=(e,t,n,r,s,o)=>{const i=o?_a(e,t,n,r,s,o):Ca(e,t,n,r,s);return Oi(i)},_a=(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)}},Ca=(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)}},Ta=(e,t,n=wi)=>new _i((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}}})),Da=(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}}}})),ka=(e,t,n,r,s,o=wi)=>new _i((function*(){const i=[...t];for(const t of e){const e=n(t);for(const n of i){const i=r(n);!0===o(e,i)&&(yield s(t,n))}}})),Ia=(e,t)=>t?ba(e,t):Ea(e),Ea=e=>{let t;for(const n of e)t=n;if(!t)throw new mi(yi.NoElements);return t},ba=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Na=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Ga=(e,t)=>t?Pa(e,t):Ra(e),Ra=e=>{let t=null;for(const n of e)t=n;return t},Pa=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},Ua=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},Oa=(e,t)=>t?xa(e,t):Ma(e),Ma=e=>{let t=null;for(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},xa=(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Fa=async(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},La=(e,t)=>t?$a(e,t):Ba(e),Ba=e=>{let t=null;for(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},$a=(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Wa=async(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},Va=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new _i((function*(){for(const t of e)n(t)&&(yield t)}))};async function*qa(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*Ha(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 Ka extends Si{orderedPairs;constructor(e){super((async function*(){for await(const t of e())yield*t})),this.orderedPairs=e}static generateAsync(e,t,n,r){let s;return s=e instanceof Ka?async function*(){for await(const s of e.orderedPairs())yield*qa(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 Ka(s)}static generate(e,t,n,r){let s;return s=e instanceof Ka?async function*(){for await(const s of e.orderedPairs())yield*Ha(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 Ka(s)}thenBy(e,t){return Ka.generate(this,e,!0,t)}thenByAsync(e,t){return Ka.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Ka.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Ka.generateAsync(this,e,!1,t)}}function*ja(e,t,n,r){const 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*za(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 Ja extends _i{orderedPairs;constructor(e){super((function*(){for(const t of e())yield*t})),this.orderedPairs=e}static generate(e,t,n,r){let s;return s=e instanceof Ja?function*(){for(const s of e.orderedPairs())yield*ja(s,t,n,r)}:()=>ja(e,t,n,r),new Ja(s)}static generateAsync(e,t,n,r){let s;return s=e instanceof Ja?async function*(){for(const s of e.orderedPairs())yield*za(s,t,n,r)}:()=>za(e,t,n,r),new Ka(s)}thenBy(e,t){return Ja.generate(this,e,!0,t)}thenByAsync(e,t){return Ja.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Ja.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Ja.generateAsync(this,e,!1,t)}}const Xa=(e,t)=>Ja.generate(e,(e=>e),!0,t),Ya=(e,t,n)=>Ja.generate(e,t,!0,n),Qa=(e,t,n)=>Ja.generateAsync(e,t,!0,n),Za=(e,t,n)=>Ja.generate(e,t,!1,n),ec=(e,t,n)=>Ja.generateAsync(e,t,!1,n),tc=(e,t)=>Ja.generate(e,(e=>e),!1,t),nc=(e,t)=>{const n=[],r=[];for(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},rc=async(e,t)=>{const n=[],r=[];for(const s of e)!0===await t(s)?r.push(s):n.push(s);return[r,n]},sc=(e,t)=>new _i((function*(){yield t,yield*e})),oc=e=>new _i((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),ic=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?ac(e,t):cc(e,t)}return uc(e,t)},ac=(e,t)=>new _i((function*(){for(const n of e)yield t(n)})),cc=(e,t)=>new _i((function*(){let n=0;for(const r of e)yield t(r,n),n++})),uc=(e,t)=>new _i((function*(){for(const n of e)yield n[t]})),lc=(e,t)=>"function"==typeof t?1===t.length?dc(e,t):hc(e,t):pc(e,t),dc=(e,t)=>Oi((async function*(){for(const n of e)yield t(n)})),hc=(e,t)=>Oi((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),pc=(e,t)=>Oi((async function*(){for(const n of e)yield n[t]})),gc=(e,t)=>"function"==typeof t?1===t.length?fc(e,t):vc(e,t):yc(e,t),fc=(e,t)=>new _i((function*(){for(const n of e)for(const e of t(n))yield e})),vc=(e,t)=>new _i((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),yc=(e,t)=>new _i((function*(){for(const n of e)for(const e of n[t])yield e})),mc=(e,t)=>1===t.length?wc(e,t):Sc(e,t),wc=(e,t)=>Oi((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),Sc=(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++}})),Ac=(e,t,n=wi)=>{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},_c=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},Cc=(e,t)=>t?Dc(e,t):Tc(e),Tc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new mi(yi.NoElements);return n},Dc=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new mi(yi.NoMatch);return r},kc=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new mi(yi.NoMatch);return r},Ic=(e,t)=>t?bc(e,t):Ec(e),Ec=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}return n},bc=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=s}return r},Nc=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new mi(yi.MoreThanOneElement);n=!0,r=s}return r},Gc=(e,t)=>new _i((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),Rc=(e,t)=>1===t.length?Pc(e,t):Uc(e,t),Pc=(e,t)=>new _i((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Uc=(e,t)=>new _i((function*(){let n=0,r=!0;for(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),Oc=(e,t)=>1===t.length?Mc(e,t):xc(e,t),Mc=(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)})),xc=(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++})),Fc=(e,t)=>t?Bc(e,t):Lc(e),Lc=e=>{let t=0;for(const n of e)t+=n;return t},Bc=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},$c=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},Wc=(e,t)=>new _i((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),Vc=(e,t)=>1===t.length?qc(e,t):Hc(e,t),qc=(e,t)=>new _i((function*(){for(const n of e){if(!t(n))break;yield n}})),Hc=(e,t)=>new _i((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),Kc=(e,t)=>1===t.length?jc(e,t):zc(e,t),jc=(e,t)=>Oi((async function*(){for(const n of e){if(!await t(n))break;yield n}})),zc=(e,t)=>Oi((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),Jc=e=>[...e],Xc=(e,t)=>{const n=new Map;for(const r of e){const e=t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},Yc=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},Qc=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},Zc=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},eu=e=>new Set(e),tu=(e,t,n)=>n?ru(e,t,n):nu(e,t),nu=(e,t)=>new _i((function*(){const n=new Set;for(const t of e)!1===n.has(t)&&(yield t,n.add(t));for(const e of t)!1===n.has(e)&&(yield e,n.add(e))})),ru=(e,t,n)=>new _i((function*(){const r=[];for(const 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))}})),su=(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))}})),ou=(e,t)=>1===t.length?iu(e,t):au(e,t),iu=(e,t)=>new _i((function*(){for(const n of e)!0===t(n)&&(yield n)})),au=(e,t)=>new _i((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),cu=(e,t)=>1===t.length?uu(e,t):lu(e,t),uu=(e,t)=>Oi((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),lu=(e,t)=>Oi((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),du=(e,t,n)=>n?pu(e,t,n):hu(e,t),hu=(e,t)=>new _i((function*(){const n=e[Symbol.iterator](),r=t[Symbol.iterator]();for(;;){const e=n.next(),t=r.next();if(e.done||t.done)break;yield[e.value,t.value]}})),pu=(e,t,n)=>new _i((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)}})),gu=(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)}})),fu=e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(Ti,"aggregate"),n(Ei,"all"),n(bi,"allAsync"),n(Ni,"any"),n(Pi,"anyAsync"),n(Ui,"append"),n(Mi,"asAsync"),n(Fi,"asParallel"),n(Li,"average"),n(Bi,"averageAsync"),n($i,"chunk"),n(Wi,"concatenate"),n(Vi,"contains"),n(qi,"containsAsync"),n(Hi,"count"),n(zi,"countAsync"),n(Ji,"defaultIfEmpty"),n(Xi,"distinct"),n(Yi,"distinctAsync"),n(Qi,"each"),n(Zi,"eachAsync"),n(ea,"elementAt"),n(ta,"elementAtOrDefault"),n(na,"except"),n(ra,"exceptAsync"),n(sa,"first"),n(aa,"firstAsync"),n(ca,"firstOrDefault"),n(da,"firstOrDefaultAsync"),n(pa,"groupBy"),n(ga,"groupByAsync"),n(ya,"groupByWithSel"),n(ma,"groupJoin"),n(Aa,"groupJoinAsync"),n(Ta,"intersect"),n(Da,"intersectAsync"),n(ka,"joinByKey"),n(Ia,"last"),n(Na,"lastAsync"),n(Ga,"lastOrDefault"),n(Ua,"lastOrDefaultAsync"),n(Oa,"max"),n(Fa,"maxAsync"),n(La,"min"),n(Wa,"minAsync"),n(Va,"ofType"),n(Xa,"order"),n(Ya,"orderBy"),n(Qa,"orderByAsync"),n(Za,"orderByDescending"),n(ec,"orderByDescendingAsync"),n(tc,"orderDescending"),n(sc,"prepend"),n(oc,"reverse"),n(ic,"select"),n(lc,"selectAsync"),n(gc,"selectMany"),n(mc,"selectManyAsync"),n(Ac,"sequenceEquals"),n(_c,"sequenceEqualsAsync"),n(Cc,"single"),n(kc,"singleAsync"),n(Ic,"singleOrDefault"),n(Nc,"singleOrDefaultAsync"),n(Gc,"skip"),n(Rc,"skipWhile"),n(Oc,"skipWhileAsync"),n(Fc,"sum"),n($c,"sumAsync"),n(Wc,"take"),n(Vc,"takeWhile"),n(Kc,"takeWhileAsync"),n(Jc,"toArray"),n(Xc,"toMap"),n(Yc,"toMapAsync"),n(Qc,"toObject"),n(Zc,"toObjectAsync"),n(nc,"partition"),n(rc,"partitionAsync"),n(eu,"toSet"),n(tu,"union"),n(su,"unionAsync"),n(ou,"where"),n(cu,"whereAsync"),n(du,"zip"),n(gu,"zipAsync")},vu=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return wu(e,t,n,r)}return n?mu(e,t,n):yu(e,t)},yu=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},mu=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},wu=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},Su=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Au=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},_u=(e,t)=>new Si((async function*(){yield*e,yield t})),Cu=(e,t)=>t?Du(e,t):Tu(e),Tu=async e=>{for await(const t of e)return!0;return!1},Du=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},ku=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},Iu=e=>xi(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),Eu=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 mi(yi.NoElements);return n/r},bu=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 mi(yi.NoElements);return n/r},Nu=(e,t)=>{if(t<1)throw new vi("size");return new Si((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Gu=(e,t)=>new Si((async function*(){yield*e,yield*t})),Ru=async(e,t,n=wi)=>{for await(const r of e)if(n(t,r))return!0;return!1},Pu=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},Uu=(e,t)=>t?Mu(e,t):Ou(e),Ou=async e=>{let t=0;for await(const n of e)t++;return t},Mu=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},xu=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},Fu=(e,t)=>new Si((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),Lu=(e,t=wi)=>new Si((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Bu=(e,t)=>new Si((async function*(){const n=[];e:for await(const r of e){for(const e of n)if(await t(e,r))continue e;n.push(r),yield r}})),$u=(e,t)=>new Si((async function*(){for await(const n of e)t(n),yield n})),Wu=(e,t)=>new Si((async function*(){for await(const n of e)await t(n),yield n})),Vu=async(e,t)=>{if(t<0)throw new vi("index");let n=0;for await(const r of e)if(t===n++)return r;throw new vi("index")},qu=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},Hu=(e,t,n=wi)=>new Si((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let s=0;s<r.length;s++){const o=r[s];if(!0===n(t,o)){e=!0;break}}!1===e&&(yield t)}})),Ku=(e,t,n)=>new Si((async function*(){const r=[];for await(const e of t)r.push(e);for await(const t of e){let e=!1;for(let s=0;s<r.length;s++){const o=r[s];if(!0===await n(t,o)){e=!0;break}}!1===e&&(yield t)}})),ju=(e,t)=>t?Ju(e,t):zu(e),zu=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new mi(yi.NoElements);return t.value},Ju=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new mi(yi.NoMatch)},Xu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new mi(yi.NoMatch)},Yu=(e,t)=>t?Zu(e,t):Qu(e),Qu=async e=>(await e[Symbol.asyncIterator]().next()).value??null,Zu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},el=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},tl=(e,t,n)=>n?nl(e,t,n):rl(e,t),nl=(e,t,n)=>new Si((async function*(){const r=new Array;for await(const 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 ha(e,s))}for(const e of r)yield e})),rl=(e,t)=>new Si((async function*(){const n={};for await(const r of e){const e=t(r),s=n[e];s?s.push(r):n[e]=new ha(e,r)}for(const e in n)yield n[e]})),sl=(e,t,n)=>n?il(e,t,n):ol(e,t),ol=(e,t)=>new Si((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 ha(e,r)}for(const e in n)yield n[e]})),il=(e,t,n)=>new Si((async function*(){const r=new Array;for await(const 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 ha(e,s))}for(const e of r)yield e})),al=(e,t,n,r)=>r?ul(e,t,n,r):cl(e,t,n),cl=(e,t,n)=>new Si((async function*(){const r={};for await(const s of e){const e=t(s),o=r[e],i=n(s);o?o.push(i):r[e]=new ha(e,i)}for(const e in r)yield r[e]})),ul=(e,t,n,r)=>new Si((async function*(){const 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 ha(e,t))}}for(const e of s)yield e})),ll=(e,t,n,r,s,o)=>{const i=o?dl(e,t,n,r,s,o):hl(e,t,n,r,s);return new Si(i)},dl=(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)}},hl=(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)}},pl=(e,t,n,r,s,o)=>{const i=o?gl(e,t,n,r,s,o):fl(e,t,n,r,s);return new Si(i)},gl=(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)}},fl=(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)}},vl=(e,t,n=wi)=>new Si((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}}}})),yl=(e,t,n)=>new Si((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}}}})),ml=(e,t,n,r,s,o=wi)=>new Si((async function*(){const i=[];for await(const e of t)i.push(e);for await(const t of e){const e=n(t);for(const n of i){const i=r(n);!0===o(e,i)&&(yield s(t,n))}}})),wl=(e,t)=>t?Al(e,t):Sl(e),Sl=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new mi(yi.NoElements);return t},Al=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},_l=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new mi(yi.NoMatch);return n},Cl=(e,t)=>t?Dl(e,t):Tl(e),Tl=async e=>{let t=null;for await(const n of e)t=n;return t},Dl=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},kl=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},Il=(e,t)=>t?bl(e,t):El(e),El=async e=>{let t=null;for await(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},bl=async(e,t)=>{let n=null;for await(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Nl=async(e,t)=>{let n=null;for await(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},Gl=(e,t)=>t?Pl(e,t):Rl(e),Rl=async e=>{let t=null;for await(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new mi(yi.NoElements);return t},Pl=async(e,t)=>{let n=null;for await(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new mi(yi.NoElements);return n},Ul=async(e,t)=>{let n=null;for await(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,await t(r));if(null===n)throw new mi(yi.NoElements);return n},Ol=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Si((async function*(){for await(const t of e)n(t)&&(yield t)}))},Ml=(e,t)=>Ka.generate(e,(e=>e),!0,t),xl=(e,t,n)=>Ka.generate(e,t,!0,n),Fl=(e,t,n)=>Ka.generateAsync(e,t,!0,n),Ll=(e,t,n)=>Ka.generate(e,t,!1,n),Bl=(e,t,n)=>Ka.generateAsync(e,t,!1,n),$l=(e,t)=>Ka.generate(e,(e=>e),!1,t),Wl=async(e,t)=>{const n=[],r=[];for await(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},Vl=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]},ql=(e,t)=>new Si((async function*(){yield t,yield*e})),Hl=e=>new Si((async function*(){const t=[];for await(const n of e)t.push(n);for(let e=t.length-1;e>=0;e--)yield t[e]})),Kl=(e,t)=>"function"==typeof t?1===t.length?jl(e,t):zl(e,t):Jl(e,t),jl=(e,t)=>new Si((async function*(){for await(const n of e)yield t(n)})),zl=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),Jl=(e,t)=>new Si((async function*(){for await(const n of e)yield n[t]})),Xl=(e,t)=>"string"==typeof t?Ql(e,t):Yl(e,t),Yl=(e,t)=>new Si((async function*(){for await(const n of e)yield t(n)})),Ql=(e,t)=>new Si((async function*(){for await(const n of e)yield n[t]})),Zl=(e,t)=>"function"==typeof t?1===t.length?ed(e,t):td(e,t):nd(e,t),ed=(e,t)=>new Si((async function*(){for await(const n of e)for(const e of t(n))yield e})),td=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),nd=(e,t)=>new Si((async function*(){for await(const n of e)for(const e of n[t])yield e})),rd=(e,t)=>1===t.length?new Si((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new Si((async function*(){let n=0;for await(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),sd=async(e,t,n=wi)=>{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},od=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},id=(e,t)=>t?cd(e,t):ad(e),ad=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new mi(yi.NoElements);return n},cd=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new mi(yi.NoMatch);return r},ud=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new mi(yi.NoMatch);return r},ld=(e,t)=>t?hd(e,t):dd(e),dd=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new mi(yi.MoreThanOneElement);t=!0,n=r}return n},hd=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=s}return r},pd=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new mi(yi.MoreThanOneMatchingElement);n=!0,r=s}return r},gd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),fd=(e,t)=>1===t.length?vd(e,t):yd(e,t),vd=(e,t)=>new Si((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),yd=(e,t)=>new Si((async function*(){let n=0,r=!0;for await(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),md=(e,t)=>1===t.length?wd(e,t):Sd(e,t),wd=(e,t)=>new Si((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Sd=(e,t)=>new Si((async function*(){let n=0,r=!0;for await(const s of e)!1===r?yield s:!1===await t(s,n)&&(r=!1,yield s),n++})),Ad=(e,t)=>t?Cd(e,t):_d(e),_d=async e=>{let t=0;for await(const n of e)t+=n;return t},Cd=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},Td=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},Dd=(e,t)=>new Si((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),kd=(e,t)=>1===t.length?Id(e,t):Ed(e,t),Id=(e,t)=>new Si((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Ed=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),bd=(e,t)=>1===t.length?Nd(e,t):Gd(e,t),Nd=(e,t)=>new Si((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Gd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),Rd=async e=>{const t=[];for await(const n of e)t.push(n);return t},Pd=async(e,t)=>{const n=new Map;for await(const r of e){const e=t(r),s=n.get(e);void 0===s?n.set(e,[r]):s.push(r)}return n},Ud=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},Od=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},Md=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},xd=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Fd=(e,t,n)=>n?Bd(e,t,n):Ld(e,t),Ld=(e,t)=>new Si((async function*(){const n=new Set;for await(const t of e)!1===n.has(t)&&(yield t,n.add(t));for await(const e of t)!1===n.has(e)&&(yield e,n.add(e))})),Bd=(e,t,n)=>new Si((async function*(){const r=[];for(const 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))}})),$d=(e,t,n)=>new Si((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))}})),Wd=(e,t)=>1===t.length?Vd(e,t):qd(e,t),Vd=(e,t)=>new Si((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),qd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),Hd=(e,t)=>1===t.length?Kd(e,t):jd(e,t),Kd=(e,t)=>new Si((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),jd=(e,t)=>new Si((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),zd=(e,t,n)=>n?Xd(e,t,n):Jd(e,t),Jd=(e,t)=>new Si((async function*(){const n=e[Symbol.asyncIterator](),r=t[Symbol.asyncIterator]();for(;;){const[e,t]=await Promise.all([n.next(),r.next()]);if(e.done||t.done)break;yield[e.value,t.value]}})),Xd=(e,t,n)=>new Si((async function*(){const r=e[Symbol.asyncIterator](),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)}})),Yd=(e,t,n)=>new Si((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)}})),Qd=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return th(e,t,n,r)}return n?eh(e,t,n):Zd(e,t)},Zd=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new mi(yi.NoElements);return n},eh=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},th=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},nh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:()=>n.generator().then((e=>{const n=new Array(e.length);for(let r=0;r<e.length;r++)n[r]=t(e[r]);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then(t);return r},type:1};case 2:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then(t);return r},type:2}}},rh=(e,t)=>{const n=nh(e,(e=>{if(!t(e))throw new Error(String(!1));return!0}));switch(n.type){case 0:return n.generator().then((()=>!0),(()=>!1));case 1:return Promise.all(n.generator()).then((()=>!0),(()=>!1));case 2:return n.generator().then(Promise.all.bind(Promise)).then((()=>!0),(()=>!1))}},sh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=t(e[n]);return r},type:2};case 1:return{generator:()=>n.generator().map((async e=>{const n=await e;return await t(n)})),type:1};case 2:return{generator:async()=>(await n.generator()).map((e=>e.then(t))),type:2}}},oh=(e,t)=>{const n=sh(e,(async e=>{if(!1===await t(e))throw new Error(String(!1));return!0}));switch(n.type){case 1:return Promise.all(n.generator()).then((()=>!0),(()=>!1));case 2:return n.generator().then(Promise.all.bind(Promise)).then((()=>!0),(()=>!1))}},ih=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ai({generator:()=>{const e=n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 2:return new Ai({generator:async()=>{const e=await n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 0:return new Ai({generator:async()=>{const e=await n.generator();return e.push(t),e},type:n.type})}},ah=(e,t)=>t?uh(e,t):ch(e),ch=async e=>{const t=e.dataFunc;let n;switch(t.type){case 1:return n=t.generator(),0!==n.length;case 0:case 2:return n=await t.generator(),0!==n.length}},uh=async(e,t)=>{const n=nh(e,t);let r;switch(n.type){case 0:return r=await n.generator(),r.includes(!0);case 1:return r=await Promise.all(n.generator()),r.includes(!0);case 2:return r=await Promise.all(await n.generator()),r.includes(!0)}},lh=async(e,t)=>{const n=sh(e,t);let r;switch(n.type){case 1:return r=n.generator(),0!==r.length&&new Promise(((e,t)=>{let n=0;for(const 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)}},dh=e=>Oi((async function*(){for await(const t of e)yield t})),hh=async e=>{switch(e.type){case 0:return await e.generator();case 1:return await Promise.all(e.generator());case 2:const t=await e.generator();return await Promise.all(t)}},ph=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},gh=async(e,t)=>{const n=sh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},fh=(e,t)=>{if(t<1)throw new vi("size");let n;switch(e.dataFunc.type){case 1:const r=e.dataFunc.generator;n={type:1,generator:()=>{const e=[];let n=[];for(const 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 Ai(n)},vh=(e,t)=>new Ai({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),yh=async(e,t,n=wi)=>{let r;switch(r=nh(e,n?e=>n(t,e):e=>e===t),r.type){case 0:return(await r.generator()).some((e=>e));case 1:return(await Promise.all(r.generator())).some((e=>e));case 2:return(await Promise.all(await r.generator())).some((e=>e))}},mh=async(e,t,n)=>{const r=sh(e,(e=>n(t,e)));switch(r.type){case 1:return(await Promise.all(r.generator())).some((e=>e));case 2:return(await Promise.all(await r.generator())).some((e=>e))}},wh=(e,t)=>t?Ah(e,t):Sh(e),Sh=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},Ah=async(e,t)=>{const n=await e.toArray();let r=0;for(let e=0;e<n.length;e++)!0===t(n[e])&&r++;return r},_h=async(e,t)=>{const n=sh(e,t);let r;switch(n.type){case 1:r=Promise.all(n.generator());break;case 2:r=Promise.all(await n.generator())}let s=0;for(const e of await r)e&&s++;return s},Ch=(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 Ai(s)},Th=(e,t=wi)=>new Ai({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),Dh=(e,t)=>new Ai({generator:async()=>{const n=[];e:for(const r of await e.toArray()){for(const e of n)if(await t(e,r))continue e;n.push(r)}return n},type:0}),kh=(e,t)=>new Ai(nh(e,(e=>(t(e),e)))),Ih=(e,t)=>{const n=sh(e,(async e=>(await t(e),e)));return new Ai(n)},Eh=async(e,t)=>{if(t<0)throw new vi("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new vi("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new vi("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new vi("index");return await e[t]}}},bh=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();return t>=e.length?null:e[t]}case 1:{const e=n.generator();return t>=e.length?null:await e[t]}case 2:{const e=await n.generator();return t>=e.length?null:await e[t]}}},Nh=(e,t,n=wi)=>new Ai({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}),Gh=(e,t,n)=>new Ai({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}),Rh=e=>hh(e.dataFunc),Ph=(e,t)=>t?Oh(e,t):Uh(e),Uh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[0]}}},Oh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===t(e))return e;throw new mi(yi.NoMatch)},Mh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===await t(e))return e;throw new mi(yi.NoMatch)},xh=(e,t)=>t?Lh(e,t):Fh(e),Fh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();return 0===e.length?null:e[0]}case 1:{const e=t.generator();return 0===e.length?null:await e[0]}case 2:{const e=await t.generator();return 0===e.length?null:await e[0]}}},Lh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===t(e))return e;return null},Bh=async(e,t)=>{const n=await Rh(e);for(const e of n)if(!0===await t(e))return e;return null},$h=(e,t,n)=>n?Vh(e,t,n):Wh(e,t),Wh=(e,t)=>new Ai({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 ha(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),Vh=(e,t,n)=>new Ai({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 ha(e,s))}const s=new Array;for(const e of r)s.push(e);return s},type:0}),qh=(e,t,n)=>n?Hh(e,t,n):Kh(e,t),Hh=(e,t,n)=>new Ai({generator:async()=>{const r=sh(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 ha(e,t))}const i=new Array;for(const e of o)i.push(e);return i},type:0}),Kh=(e,t)=>new Ai({generator:async()=>{const n=sh(e,(async e=>[await t(e),e]));let r;switch(n.type){case 1:r=await Promise.all(n.generator());break;case 2:r=await Promise.all(await n.generator())}const s={};for(const[e,t]of r){const n=s[e];n?n.push(t):s[e]=new ha(e,t)}const o=new Array;for(const e in s)o.push(s[e]);return o},type:0}),jh=(e,t,n,r)=>r?zh(e,t,n,r):Jh(e,t,n),zh=(e,t,n,r)=>new Ai({generator:async()=>{const 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 ha(e,t))}}const o=new Array;for(const e of s)o.push(e);return o},type:0}),Jh=(e,t,n)=>new Ai({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 ha(e,i)}const s=new Array;for(const e in r)s.push(r[e]);return s},type:0}),Xh=(e,t,n,r,s,o)=>{const i=o?Yh(e,t,n,r,s,o):Qh(e,t,n,r,s);return new Ai({generator:i,type:0})},Yh=(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)}))},Qh=(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)}))},Zh=(e,t,n,r,s,o)=>{const i=o?ep(e,t,n,r,s,o):tp(e,t,n,r,s);return new Ai({generator:i,type:0})},ep=(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)},tp=(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)},np=(e,t,n=wi)=>new Ai({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}),rp=(e,t,n)=>new Ai({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}),sp=(e,t,n,r,s,o=wi)=>new Ai({generator:async()=>{const[i,a]=await Promise.all([t.toArray(),e.toArray()]),c=new Array;for(const e of a){const t=n(e);for(const n of i){const i=r(n);!0===o(t,i)&&c.push(s(e,n))}}return c},type:0}),op=(e,t)=>t?ap(e,t):ip(e),ip=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new mi(yi.NoElements);return await e[e.length-1]}}},ap=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=e[n];if(t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(t(r))return r}break}}throw new mi(yi.NoMatch)},cp=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=e[n];if(!0===await t(r))return r}break}case 1:{const e=n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}case 2:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=await e[n];if(!0===await t(r))return r}break}}throw new mi(yi.NoMatch)},up=(e,t)=>t?dp(e,t):lp(e),lp=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]}}},dp=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},hp=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=e[n];if(!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},pp=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.max.apply(null,r)},gp=async(e,t)=>{const n=sh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.max.apply(null,r)},fp=async(e,t)=>{let n;n=t?nh(e,t):e.dataFunc;const r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.min.apply(null,r)},vp=async(e,t)=>{const n=sh(e,t),r=await hh(n);if(0===r.length)throw new mi(yi.NoElements);return Math.min.apply(null,r)},yp=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Ai({generator:async()=>{const t=nh(e,n),r=await hh(t),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0})};async function*mp(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*wp(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 Sp extends Ai{orderedPairs;constructor(e){super({generator:async()=>{const t=e(),n=[];for await(const e of t)n.push(...e);return n},type:0}),this.orderedPairs=e}static generateAsync(e,t,n,r){let s;return s=e instanceof Sp?async function*(){for await(const s of e.orderedPairs())yield*mp(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 Sp(s)}static generate(e,t,n,r){let s;return s=e instanceof Sp?async function*(){for await(const s of e.orderedPairs())yield*wp(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 Sp(s)}thenBy(e,t){return Sp.generate(this,e,!0,t)}thenByAsync(e,t){return Sp.generateAsync(this,e,!0,t)}thenByDescending(e,t){return Sp.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return Sp.generateAsync(this,e,!1,t)}}const Ap=(e,t)=>Sp.generate(e,(e=>e),!0,t),_p=(e,t,n)=>Sp.generate(e,t,!0,n),Cp=(e,t,n)=>Sp.generateAsync(e,t,!0,n),Tp=(e,t,n)=>Sp.generate(e,t,!1,n),Dp=(e,t,n)=>Sp.generateAsync(e,t,!1,n),kp=(e,t)=>Sp.generate(e,(e=>e),!1,t),Ip=async(e,t)=>{const n=nh(e,(e=>[t(e),e])),r=await hh(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Ep=async(e,t)=>{const n=sh(e,(async e=>[await t(e),e])),r=await hh(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},bp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ai({generator:()=>{const e=n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 2:return new Ai({generator:async()=>{const e=await n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 0:return new Ai({generator:async()=>{const e=await n.generator();return e.unshift(t),e},type:n.type})}},Np=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Ai({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Ai({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Gp=(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}}},Rp=(e,t)=>"function"==typeof t?1===t.length?new Ai(nh(e,t)):new Ai(Gp(e,t)):new Ai(nh(e,(e=>e[t]))),Pp=(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}}},Up=(e,t)=>{let n;return n="function"==typeof t?1===t.length?sh(e,t):Pp(e,t):sh(e,(e=>e[t])),new Ai(n)},Op=(e,t)=>new Ai({generator:async()=>{let n;n="function"==typeof t?1===t.length?nh(e,t):Gp(e,t):nh(e,(e=>e[t]));const r=[];switch(n.type){case 0:for(const e of await n.generator())for(const t of e)r.push(t);break;case 1:for(const e of n.generator())for(const t of await e)r.push(t);break;case 2:for(const e of await n.generator())for(const t of await e)r.push(t)}return r},type:0}),Mp=(e,t)=>new Ai({generator:async()=>{let n;n=1===t.length?sh(e,t):Pp(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}),xp=async(e,t,n=wi)=>{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},Fp=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},Lp=(e,t)=>t?$p(e,t):Bp(e),Bp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);if(0===e.length)throw new mi(yi.NoElements);return await e[0]}}},$p=async(e,t)=>{const n=await Rh(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new mi(yi.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new mi(yi.NoMatch);return s},Wp=async(e,t)=>{const n=await Rh(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new mi(yi.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new mi(yi.NoMatch);return s},Vp=(e,t)=>t?Hp(e,t):qp(e),qp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new mi(yi.MoreThanOneElement);return 0===e.length?null:await e[0]}}},Hp=async(e,t)=>{const n=await Rh(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new mi(yi.MoreThanOneElement);r=!0,s=e}return s},Kp=async(e,t)=>{const n=await Rh(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new mi(yi.MoreThanOneElement);r=!0,s=e}return s},jp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Ai({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Ai({generator:()=>n.generator().slice(t),type:1});case 2:return new Ai({generator:async()=>(await n.generator()).slice(t),type:2})}},zp=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray();let r=0;for(;r<n.length;r++){const e=n[r];if(!1===t(e,r))break}const s=[];for(;r<n.length;r++)s.push(n[r]);return s},type:0}),Jp=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray();let r=0;for(;r<n.length;r++){const e=n[r];if(!1===await t(e,r))break}const s=[];for(;r<n.length;r++)s.push(n[r]);return s},type:0}),Xp=(e,t)=>t?Qp(e,t):Yp(e),Yp=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},Qp=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},Zp=async(e,t)=>{const n=sh(e,t),r=await hh(n);let s=0;for(const e of r)s+=e;return s},eg=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new Ai({generator:()=>r.generator().splice(0,n),type:1});case 2:return new Ai({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new Ai({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},tg=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray(),r=new Array;if(1===t.length)for(const e of n){if(!0!==t(e))break;r.push(e)}else for(let e=0;e<n.length;e++){const s=n[e];if(!0!==t(s,e))break;r.push(s)}return r},type:0}),ng=(e,t)=>new Ai({generator:async()=>{const n=await e.toArray(),r=new Array;if(1===t.length){const e=t;for(const t of n){if(!0!==await e(t))break;r.push(t)}}else for(let e=0;e<n.length;e++){const s=n[e];if(!0!==await t(s,e))break;r.push(s)}return r},type:0}),rg=async(e,t)=>{const n=new Map,r=nh(e,(e=>[t(e),e])),s=await hh(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},sg=async(e,t)=>{const n=new Map,r=sh(e,(async e=>[await t(e),e])),s=await hh(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},og=async(e,t)=>{const n=e.dataFunc,r=await hh(n),s={};for(const e of r)s[t(e)]=e;return s},ig=async(e,t)=>{const n=sh(e,(async e=>[await t(e),e])),r=await hh(n),s={};for(const[e,t]of r)s[e]=t;return s},ag=async e=>{const t=e.dataFunc,n=await hh(t);return new Set(n)},cg=(e,t,n)=>n?lg(e,t,n):ug(e,t),ug=(e,t)=>new Ai({generator:async()=>{const n=new Set,r=t.toArray();for await(const t of e)!1===n.has(t)&&n.add(t);const s=await r;for(const e of s)!1===n.has(e)&&n.add(e);return[...n.keys()]},type:0}),lg=(e,t,n)=>new Ai({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}),dg=(e,t,n)=>new Ai({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}),hg=(e,t)=>new Ai({generator:async()=>(await e.toArray()).filter(t),type:0}),pg=(e,t)=>new Ai({generator:async()=>{const n=Pp(e,(async(e,n)=>[await t(e,n),e])),r=await hh(n),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0}),gg=(e,t,n)=>n?vg(e,t,n):fg(e,t),fg=(e,t)=>new Ai({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}),vg=(e,t,n)=>new Ai({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}),yg=(e,t,n)=>new Ai({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}),mg=e=>{const t=Ci.prototype,n=e.prototype,r=Object.getOwnPropertyNames(t);for(const e of r)n[e]=n[e]??t[e]};fu(_i),(e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(vu,"aggregate"),n(Su,"all"),n(Au,"allAsync"),n(_u,"append"),n(Cu,"any"),n(ku,"anyAsync"),n(Iu,"asParallel"),n(Eu,"average"),n(bu,"averageAsync"),n(Nu,"chunk"),n(Gu,"concatenate"),n(Ru,"contains"),n(Pu,"containsAsync"),n(Uu,"count"),n(xu,"countAsync"),n(Fu,"defaultIfEmpty"),n(Lu,"distinct"),n(Bu,"distinctAsync"),n($u,"each"),n(Wu,"eachAsync"),n(Vu,"elementAt"),n(qu,"elementAtOrDefault"),n(Hu,"except"),n(Ku,"exceptAsync"),n(ju,"first"),n(Xu,"firstAsync"),n(Yu,"firstOrDefault"),n(el,"firstOrDefaultAsync"),n(tl,"groupBy"),n(sl,"groupByAsync"),n(al,"groupByWithSel"),n(ll,"groupJoin"),n(pl,"groupJoinAsync"),n(vl,"intersect"),n(yl,"intersectAsync"),n(ml,"joinByKey"),n(wl,"last"),n(_l,"lastAsync"),n(Cl,"lastOrDefault"),n(kl,"lastOrDefaultAsync"),n(Il,"max"),n(Nl,"maxAsync"),n(Gl,"min"),n(Ul,"minAsync"),n(Ol,"ofType"),n(Ml,"order"),n(xl,"orderBy"),n(Fl,"orderByAsync"),n(Ll,"orderByDescending"),n(Bl,"orderByDescendingAsync"),n($l,"orderDescending"),n(Wl,"partition"),n(Vl,"partitionAsync"),n(ql,"prepend"),n(Hl,"reverse"),n(Kl,"select"),n(Xl,"selectAsync"),n(Zl,"selectMany"),n(rd,"selectManyAsync"),n(sd,"sequenceEquals"),n(od,"sequenceEqualsAsync"),n(id,"single"),n(ud,"singleAsync"),n(ld,"singleOrDefault"),n(pd,"singleOrDefaultAsync"),n(gd,"skip"),n(fd,"skipWhile"),n(md,"skipWhileAsync"),n(Ad,"sum"),n(Td,"sumAsync"),n(Dd,"take"),n(kd,"takeWhile"),n(bd,"takeWhileAsync"),n(Rd,"toArray"),n(Pd,"toMap"),n(Ud,"toMapAsync"),n(Od,"toObject"),n(Md,"toObjectAsync"),n(xd,"toSet"),n(Fd,"union"),n($d,"unionAsync"),n(Wd,"where"),n(Hd,"whereAsync"),n(zd,"zip"),n(Yd,"zipAsync")})(Si),(e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(Qd,"aggregate"),n(rh,"all"),n(oh,"allAsync"),n(ih,"append"),n(ah,"any"),n(lh,"anyAsync"),n(dh,"asAsync"),n(ph,"average"),n(gh,"averageAsync"),n(fh,"chunk"),n(vh,"concatenate"),n(yh,"contains"),n(mh,"containsAsync"),n(wh,"count"),n(_h,"countAsync"),n(Ch,"defaultIfEmpty"),n(Th,"distinct"),n(Dh,"distinctAsync"),n(kh,"each"),n(Ih,"eachAsync"),n(Eh,"elementAt"),n(bh,"elementAtOrDefault"),n(Nh,"except"),n(Gh,"exceptAsync"),n(Ph,"first"),n(Mh,"firstAsync"),n(xh,"firstOrDefault"),n(Bh,"firstOrDefaultAsync"),n($h,"groupBy"),n(qh,"groupByAsync"),n(jh,"groupByWithSel"),n(Xh,"groupJoin"),n(Zh,"groupJoinAsync"),n(Xh,"groupJoin"),n(Zh,"groupJoinAsync"),n(np,"intersect"),n(rp,"intersectAsync"),n(sp,"joinByKey"),n(op,"last"),n(cp,"lastAsync"),n(up,"lastOrDefault"),n(hp,"lastOrDefaultAsync"),n(pp,"max"),n(gp,"maxAsync"),n(fp,"min"),n(vp,"minAsync"),n(yp,"ofType"),n(Ap,"order"),n(_p,"orderBy"),n(Cp,"orderByAsync"),n(Tp,"orderByDescending"),n(Dp,"orderByDescendingAsync"),n(kp,"orderDescending"),n(Ip,"partition"),n(Ep,"partitionAsync"),n(bp,"prepend"),n(Np,"reverse"),n(Rp,"select"),n(Up,"selectAsync"),n(Op,"selectMany"),n(Mp,"selectManyAsync"),n(xp,"sequenceEquals"),n(Fp,"sequenceEqualsAsync"),n(Lp,"single"),n(Wp,"singleAsync"),n(Vp,"singleOrDefault"),n(Kp,"singleOrDefaultAsync"),n(jp,"skip"),n(zp,"skipWhile"),n(Jp,"skipWhileAsync"),n(Xp,"sum"),n(Zp,"sumAsync"),n(eg,"take"),n(tg,"takeWhile"),n(ng,"takeWhileAsync"),n(Rh,"toArray"),n(rg,"toMap"),n(sg,"toMapAsync"),n(og,"toObject"),n(ig,"toObjectAsync"),n(ag,"toSet"),n(cg,"union"),n(dg,"unionAsync"),n(hg,"where"),n(pg,"whereAsync"),n(gg,"zip"),n(yg,"zipAsync")})(Ai),(()=>{const{prototype:e}=Ci,t=Object.getOwnPropertyNames(_i.prototype);for(const n of t)e[n]=e[n]??_i.prototype[n];e.all=function(e){return this.every(e)},e.any=function(e){return e?this.some(e):0!==this.length},e.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},e.elementAt=function(e){if(e<0||e>=this.length)throw new vi("index");return this[e]},e.elementAtOrDefault=function(e){return this[e]??null},e.first=function(e){if(e){const t=this.find(e);if(void 0===t)throw new mi(yi.NoMatch);return t}if(0===this.length)throw new mi(yi.NoElements);return this[0]},e.firstOrDefault=function(e){if(e){const t=this.find(e);return void 0===t?null:t}return 0===this.length?null:this[0]},e.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[this.length-1]},e.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},e.max=function(e){if(0===this.length)throw new mi(yi.NoElements);if(e){let t=Number.NEGATIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.max(e(this[n]),t);return t}return Math.max.apply(null,this)},e.min=function(e){if(0===this.length)throw new mi(yi.NoElements);if(e){let t=Number.POSITIVE_INFINITY;for(let n=0;n<this.length;n++)t=Math.min(e(this[n]),t);return t}return Math.min.apply(null,this)},e.reverse=function(){return Array.prototype.reverse.apply(this),this}})();var wg,Sg;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(wg||(wg={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(Sg||(Sg={}));class Ag{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==Ag._devicesService&&(Ag._devicesService=hy.Get(Yo.ServiceName))}GetDevicesChannelsInGroupAsync(){return e=this,t=arguments,r=function*(e=!1){let t=[],n=[];const r=yield Ag._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){hy.Get(a.ServiceName).Error("Old controller API fallback to old groups API.");for(let e of r)for(let t of e.Channels.where((e=>e.ChannelGroups.any((e=>e===this._guid)))))n.push(t);return n}const s=Object.keys(this._objectsOrder).map(Number).sort(((e,t)=>e-t));Object.values(this._objectsOrder).forEach((e=>{const n=r.select((t=>t.Channels.where((t=>t.ChannelId===e))));if(null!==n)for(let e of n)for(let n of e)t.push(n)}));for(let e of s){const r=t.firstOrDefault((t=>t.ChannelId===this._objectsOrder[e]));null!==r&&n.push(r)}return n},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}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 hy.Get(Ug.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return hy.Get(Ug.ServiceName).ChangeGroupIconNameAsync(this,e)}}var _g,Cg,Tg,Dg,kg,Ig,Eg,bg,Ng,Gg,Rg,Pg=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Ug{constructor(){this._connection=null,this._synchronized=!1,this._onSynchronized=new ke,this._groups=[],this._objectsGroupingSupported=!1,this._configurationService=hy.Get(ct.ServiceName),this._syncSemaphore=new et(1),this._connection=hy.Get(It.ServiceName),hy.Get(Xe.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Pg(this,void 0,void 0,(function*(){yield this.ResyncGroupsAsync()}))))}ResyncGroupsAsync(){return Pg(this,void 0,void 0,(function*(){var e;const t=yield this._syncSemaphore.AcquireAsync();try{this._synchronized=!1,yield this.GetGroupsAsync(!0),this._synchronized=!0,this._onSynchronized.Invoke()}catch(t){null===(e=u.Log)||void 0===e||e.Error(Ug.ServiceName,`Failed to sync groups: ${t}`)}finally{t.Release()}}))}WaitForSynchronizationAsync(){return this._synchronized?Promise.resolve():new Promise((e=>{const t=window.setTimeout((()=>{this._onSynchronized.Unsubscribe(n),e()}),3e4),n=()=>{window.clearTimeout(t),this._onSynchronized.Unsubscribe(n),e()};this._onSynchronized.Subscribe(n)}))}SetObjectsInGroupAndOrderAsync(e,t){return Pg(this,void 0,void 0,(function*(){var n,r;let s=[],o=[];for(let e of t)if(this.IsDevice(e)){for(let t of e.Channels)s.push(`${t.ChannelId}`);o.push(`${e.Guid}`)}else{if(!this.IsDeviceChannel(e))throw new Error("Passed object is not a device or device channel!");s.push(`${e.ChannelId}`),o.push(`${e.ChannelId}`)}const i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new xg(e,o),15e3,!1);switch(null===(r=u.Log)||void 0===r||r.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetObjectsInGroupAndOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),yield hy.Get(Yo.ServiceName).GetDevicesAsync(),null==i?void 0:i.Status){case ue.OK:return new Ee(wg.Success,"");case ue.NotSupportedMethod:case ue.ResourceDoesNotExists:case ue.ResourceIsNotAvailable:return new Ee(wg.FunctionNotSupported,"");case ue.WrongData:return"GroupDoesNotExists"===i.Data?new Ee(wg.GroupDoesNotExists,i.Data):new Ee(wg.FatalError,i.Data);case ue.Error:case ue.FatalError:default:return new Ee(wg.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=hy.Get(a.ServiceName);e.forEach(((e,n)=>{t.Debug(Ug.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=hy.Get(a.ServiceName);n.Debug(Ug.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(Ug.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 Pg(this,void 0,void 0,(function*(){var t,n;const r=e.select((e=>e.Guid)).toArray(),s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Mg(r),15e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeGroupsOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ue.OK?(yield this.GetGroupsAsync(!1),ue.OK):(hy.Get(a.ServiceName).Error(Ug.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 Pg(this,void 0,void 0,(function*(){var n,r,s;const o=t.select((e=>e.ChannelId)).toArray(),i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new $g(e.Guid,o),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeObjectsPositionsInGroupAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ue.OK?(yield this.GetGroupsAsync(!1),yield hy.Get(Yo.ServiceName).GetDevicesAsync(),ue.OK):(null===(s=u.Log)||void 0===s||s.Error(Ug.ServiceName,`Failed to change objects positions in group, controller responded with error ${null==i?void 0:i.Status} data: ${null==i?void 0:i.Data}`),this.LogObjectsInGroupOrder(e,t),null==i?void 0:i.Status)}))}IsGroupsAndObjectsOrderingAvailable(){return this._objectsGroupingSupported}MoveGroupPositionAsync(e,t){return Pg(this,void 0,void 0,(function*(){var n,r,s;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Og(e.Guid,t),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ue.OK?(yield this.GetGroupsAsync(!1),ue.OK):(null===(s=u.Log)||void 0===s||s.Error(Ug.ServiceName,`Failed to move group position, controller responded with error ${null==o?void 0:o.Status} data: ${null==o?void 0:o.Data}`),null==o?void 0:o.Status)}))}MoveObjectInGroupPositionAsync(e,t,n){return Pg(this,void 0,void 0,(function*(){var r,s,o;const i=`${t.GetDevice().Guid}_${t.Number}`,a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Bg(e.Guid,i,n),15e3,!1);return null===(s=u.Log)||void 0===s||s.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveObjectInGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==a?void 0:a.Status)===ue.OK?(yield this.GetGroupsAsync(!1),yield hy.Get(Yo.ServiceName).GetDevicesAsync(),ue.OK):(null===(o=u.Log)||void 0===o||o.Error(Ug.ServiceName,`Failed to move object in group position, controller responded with error ${null==a?void 0:a.Status} data: ${null==a?void 0:a.Data}`),null==a?void 0:a.Status)}))}AddDeviceChannelToGroupByGuidAsync(e,t){return Pg(this,arguments,void 0,(function*(e,t,n=!1){var r,s,o,i;const a=new jg;if(a.Data.Channel=e.Number,null==e.GetDevice())throw new Error("Device is not set on this channel!");a.Data.DeviceGuid=null===(r=e.GetDevice())||void 0===r?void 0:r.Guid,a.Data.GroupGuid=t;const c=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(a,15e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddDeviceChannelToGroupByGuidAsync()"),this._configurationService.ExitConfigurationModeAsync(),null!=c&&null!=c.Status?(c.Status==ue.OK?e.ChannelGroups.push(t):null===(i=u.Log)||void 0===i||i.Error(Ug.ServiceName,`Failed to add device channel ${e.Name} to group ${t}, controller responded with error ${c.Status} data: ${c.Data}`),n||(yield this.GetGroupsAsync(!1),yield hy.Get(Yo.ServiceName).GetDevicesAsync()),c.Status):(n||(yield this.GetGroupsAsync(!1),yield hy.Get(Yo.ServiceName).GetDevicesAsync()),ue.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){return Pg(this,arguments,void 0,(function*(e,t,n=!1){var r,s,o;const i=new zg;if(null==e.GetDevice())throw new Error("Device is not set on this channel!");i.Data.DeviceGuid=null===(r=e.GetDevice())||void 0===r?void 0:r.Guid,i.Data.Channel=e.Number,i.Data.GroupGuid=t;const a=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(i,15e3,!1);return n||this._configurationService.ExitConfigurationModeAsync(),null!=a&&null!=a.Status?(a.Status==ue.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():null===(o=u.Log)||void 0===o||o.Error(Ug.ServiceName,`Failed to remove device channel ${e.Name} from group ${t}, controller responded with error ${a.Status} data: ${a.Data}`),n||(yield this.GetGroupsAsync(!1)),yield hy.Get(Yo.ServiceName).GetDevicesAsync(),a.Status):(n||(yield this.GetGroupsAsync(!1)),yield hy.Get(Yo.ServiceName).GetDevicesAsync(),ue.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Pg(this,void 0,void 0,(function*(){var n,r,s;if(this._groups.all((t=>t.Guid!=e.Guid))){let t=yield this.AddNewGroupWithIconAsync(e.Name,e.IconName);if(!(t instanceof Ag))return t instanceof Ee?t:new Ee(Sg.UnknownError,"");e=t}for(let r of t.where((t=>t.ChannelGroups.all((t=>t!==e.Guid))))){let t=yield this.AddDeviceChannelToGroupAsync(r,e,!0);if(t!==ue.OK)return null===(n=u.Log)||void 0===n||n.Error(Ug.ServiceName,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`),new Ee(Sg.UnknownError,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`)}let o=yield hy.Get(Yo.ServiceName).GetDevicesAsync();for(let n of o)for(let o of n.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(let t of o.ChannelGroups.where((t=>e.Guid==t))){let t=yield this.RemoveDeviceChannelFromGroupAsync(o,e,!0);if(t!==ue.OK)return null===(r=u.Log)||void 0===r||r.Error(Ug.ServiceName,`Failed to remove device channel ${o.Name} from group ${e.Name}, controller responded with error ${t}`),null===(s=u.Log)||void 0===s||s.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpsertGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),new Ee(Sg.UnknownError,`Failed to remove device channel ${o.Name} from group ${e.Name}, controller responded with error ${t}`)}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Pg(this,void 0,void 0,(function*(){var n,r,s,o;for(let s of t.where((t=>t.ChannelGroups.all((t=>t!==e))))){let t=yield this.AddDeviceChannelToGroupByGuidAsync(s,e,!0);if(t!==ue.OK)return null===(n=u.Log)||void 0===n||n.Error(Ug.ServiceName,`Failed to add device channel ${s.Name} to group ${e}, controller responded with error ${t}`),null===(r=u.Log)||void 0===r||r.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.FatalError}let i=yield hy.Get(Yo.ServiceName).GetDevicesAsync();for(let n of i)for(let r of n.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(let t of r.ChannelGroups.where((t=>e==t))){let t=yield this.RemoveDeviceChannelFromGroupByGuidAsync(r,e,!0);if(t!==ue.OK)return null===(s=u.Log)||void 0===s||s.Error(Ug.ServiceName,`Failed to remove device channel ${r.Name} from group ${e}, controller responded with error ${t}`),null===(o=u.Log)||void 0===o||o.Error(Ug.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.FatalError}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.OK}))}ChangeGroupNameByGuidAsync(e,t){return Pg(this,void 0,void 0,(function*(){var n,r;let s=new Kg,o=new Jg,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(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ue.OK:return new Ee(Sg.Success,"");case ue.WrongData:switch(a.Data){case"NameToShort":return new Ee(Sg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sg.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sg.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){return Pg(this,void 0,void 0,(function*(){var r,s;let o=new Kg,i=new Jg,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(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=c&&null!=c.Status)switch(c.Status){case ue.OK:return new Ee(Sg.Success,"");case ue.WrongData:switch(c.Data){case"NameToShort":return new Ee(Sg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sg.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sg.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new Ee(Sg.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new Ee(Sg.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){return Pg(this,void 0,void 0,(function*(){var n,r;let s=new Kg,o=new Jg,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(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ue.OK:return new Ee(Sg.Success,"");case ue.WrongData:switch(a.Data){case"NameToShort":return new Ee(Sg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sg.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sg.UnknownError,"")}))}GetServiceName(){return Ug.ServiceName}GetGroupByGuid(e){return this._groups.first((t=>t.Guid===e))}ChangeGroupNameAsync(e,t){return this.ChangeGroupNameByGuidAsync(e.Guid,t)}ChangeGroupIconNameAsync(e,t){return this.ChangeGroupIconNameByGuidAsync(e.Guid,t)}RemoveGroupAsync(e){return this.RemoveGroupByGuidAsync(e.Guid)}RemoveGroupByGuidAsync(e){return Pg(this,void 0,void 0,(function*(){var t;let n=new qg;n.Data=e;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=r&&null!=r.Status?null==r?void 0:r.Status:ue.Error}))}GetGroupsAsync(){return Pg(this,arguments,void 0,(function*(e=!0){var t,n;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Hg,15e3,e);let s=[];if((null==r?void 0:r.Status)===ue.OK){let t=0,o=hy.Get(a.ServiceName),i=yield hy.Get(Yo.ServiceName).GetDevicesAsync();return null===(n=r.Data)||void 0===n||n.forEach((n=>{t++;let r=new Ag;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||o.Info(Ug.ServiceName,`Got group: ${r.Name} ${r.Guid} order: ${r.OrderPosition} objects order: ${JSON.stringify(r.ObjectsOrder)}`),s.push(r)})),this._groups=s,s}throw new Error(`Failed to get groups, API responded with status ${null==r?void 0:r.Status} data: ${null==r?void 0:r.Data}`)}))}AddDeviceChannelToGroupAsync(e,t,n=!1){return this.AddDeviceChannelToGroupByGuidAsync(e,t.Guid,n)}RemoveDeviceChannelFromGroupAsync(e,t,n=!1){return this.RemoveDeviceChannelFromGroupByGuidAsync(e,t.Guid,n)}AddNewGroupAsync(e){return Pg(this,void 0,void 0,(function*(){var t,n,r;let s=new Kg,o=new Jg;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(this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=i&&null!=i.Status)switch(i.Status){case ue.OK:return this._groups.first((t=>t.Name===e));case ue.WrongData:switch(null===(r=u.Log)||void 0===r||r.Error(Ug.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new Ee(Sg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sg.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sg.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Ee(Sg.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Ee(Sg.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){return Pg(this,void 0,void 0,(function*(){var n,r,s;let o=new Kg,i=new Jg;i.Name=e,i.IconName=t,null===(n=o.Data)||void 0===n||n.push(i);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(o,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ue.OK:return this._groups.first((t=>t.Name===e));case ue.WrongData:switch(null===(s=u.Log)||void 0===s||s.Error(Ug.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new Ee(Sg.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ee(Sg.NameAlreadyExists,"Group with this name already exists");default:return new Ee(Sg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ee(Sg.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ee(Sg.UnknownError,"")}))}}Ug.ServiceName="ChannelsGroupsService";class Og extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=le.Post,this.Data=new Lg,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class Mg extends ce{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=le.Post,this.Data=e}}class xg extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=le.Post,this.Data=new Fg,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Fg{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Lg{constructor(){this.GroupGuid="",this.NewPosition=0}}class Bg extends ce{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=le.Post,this.Data=new Wg,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class $g extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=le.Post,this.Data=new Vg,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class Wg{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class Vg{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class qg extends ce{constructor(){super(),this.Resource="/devices/groups/group",this.Method=le.Delete}}class Hg extends ce{constructor(){super(),this.Resource="/devices/groups/",this.Method=le.Get}}class Kg extends ce{constructor(){super(),this.Resource="/devices/groups/group",this.Method=le.Put,this.Data=[]}}class jg extends ce{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=le.Put,this.Data=new Xg}}class zg extends ce{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=le.Delete,this.Data=new Xg}}class Jg{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class Xg{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Yg{constructor(){this.DeviceGuid="",this.CurrentVersion="",this.NewVersion=""}}class Qg{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class Zg{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class ef{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(_g||(_g={})),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"}(Cg||(Cg={})),(Rg=Tg||(Tg={}))[Rg.WaitingForUser=1]="WaitingForUser",Rg[Rg.Downloading=2]="Downloading",Rg[Rg.Unpackaging=3]="Unpackaging",Rg[Rg.CheckingApplicability=4]="CheckingApplicability",Rg[Rg.MigratingData=5]="MigratingData",Rg[Rg.CreatingBackup=6]="CreatingBackup",Rg[Rg.Deploying=7]="Deploying",Rg[Rg.Installing=8]="Installing",Rg[Rg.Removing=9]="Removing",Rg[Rg.Error=10]="Error",Rg[Rg.ReadyToDownload=11]="ReadyToDownload",Rg[Rg.PreparingSystem=12]="PreparingSystem",Rg[Rg.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",Rg[Rg.CheckingIntegrity=14]="CheckingIntegrity",Rg[Rg.UndoingInstallation=15]="UndoingInstallation",Rg[Rg.Installed=16]="Installed",(Gg=Dg||(Dg={}))[Gg.Ignore=0]="Ignore",Gg[Gg.Cancel=1]="Cancel",Gg[Gg.Install=2]="Install";class tf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=Cg.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class nf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=Eg.Unknown,this.DownloadOnly=!1}}class rf{constructor(){this.BulkUpdateStatus=kg.Success,this.DevicesUpdateResults=new Map}}!function(e){e[e.Success=0]="Success",e[e.PartialSuccess=1]="PartialSuccess",e[e.UpdatesNotFound=2]="UpdatesNotFound",e[e.CannotUnpairRetransmitters=3]="CannotUnpairRetransmitters",e[e.CannotPairRetransmitters=4]="CannotPairRetransmitters"}(kg||(kg={})),function(e){e[e.Unknown=0]="Unknown",e[e.Updated=1]="Updated",e[e.InsufficientConnection=2]="InsufficientConnection",e[e.Error=3]="Error",e[e.UnknownError=4]="UnknownError",e[e.ControllerSoftwareTooOld=5]="ControllerSoftwareTooOld"}(Ig||(Ig={})),function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate",e[e.UpdateDownloadedAndChecked=4]="UpdateDownloadedAndChecked"}(Eg||(Eg={})),function(e){e[e.DeviceIsUpToDate=0]="DeviceIsUpToDate",e[e.CannotFindDevice=1]="CannotFindDevice",e[e.UnsupportedApiVersion=2]="UnsupportedApiVersion",e[e.UnsupportedDevice=3]="UnsupportedDevice",e[e.CannotGetFirmwareVersion=4]="CannotGetFirmwareVersion",e[e.CannotGetUpdates=5]="CannotGetUpdates",e[e.CannotProcessUpdate=6]="CannotProcessUpdate",e[e.UpdateActionsNotSupported=7]="UpdateActionsNotSupported",e[e.UnsupportedExtensionVersion=8]="UnsupportedExtensionVersion",e[e.UpdatesPartiallyInstalled=9]="UpdatesPartiallyInstalled",e[e.RetransmitterFound=10]="RetransmitterFound",e[e.ProtocolRadioUnsupported=11]="ProtocolRadioUnsupported",e[e.FeatureUnsupportedInCurrentVersion=12]="FeatureUnsupportedInCurrentVersion",e[e.CannotGetUpdatesBranch=13]="CannotGetUpdatesBranch",e[e.CannotSetUpdatesBranch=14]="CannotSetUpdatesBranch",e[e.UpdateAlreadyDownloaded=15]="UpdateAlreadyDownloaded",e[e.UpdateDownloadFailed=16]="UpdateDownloadFailed",e[e.UpdateAlreadyInstalled=17]="UpdateAlreadyInstalled",e[e.CannotGetCurrentControllerVersionTimeout=18]="CannotGetCurrentControllerVersionTimeout",e[e.CannotGetCurrentControllerVersion=19]="CannotGetCurrentControllerVersion",e[e.InstallerFileSignCheckFailed=20]="InstallerFileSignCheckFailed",e[e.UpdateFileSignCheckFailed=21]="UpdateFileSignCheckFailed",e[e.UpdateFileCheckFailed=22]="UpdateFileCheckFailed",e[e.UpdateInstallationFailed=23]="UpdateInstallationFailed"}(bg||(bg={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(Ng||(Ng={}));var sf,of,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._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5,this._oldUpdateBuild=56,this._updateOfflineStageTime=15,this._updateProviders=hy.Get(ao.ServiceName),this._logger=hy.Get(a.ServiceName),this._connection=hy.Get(It.ServiceName),this._appStateService=hy.Get(_t.ServiceName),this._extensionService=hy.Get(nt.ServiceName)}IsBranchAndAutomaticUpdatesSettingSupportedAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return!1;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);return!(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)}))}DownloadControllerUpdateAsync(e){return gf(this,void 0,void 0,(function*(){try{const t=yield this.getRuntimeInfoAsync();if(t instanceof Ee)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);return n<this._oldUpdateVersion||n===this._oldUpdateVersion&&r<=this._oldUpdateBuild?new Ee(bg.FeatureUnsupportedInCurrentVersion,`Cannot download update, feature unsupported in current version. Current version: ${t}`):yield this.DownloadControllerUpdateUsingApiAsync((()=>{}),e,!0)}catch(e){return new Ee(bg.CannotProcessUpdate,`Failed to download controller update: ${e}`)}}))}InstallControllerOrRadioUpdateAsync(e,t,n){return gf(this,void 0,void 0,(function*(){const r=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),s=this._controllerUpdates.length,o=yield this.getRuntimeInfoAsync();if(o instanceof Ee)return o;const i=parseInt(o.SoftwareVersion.toString().split(".")[0]),a=parseInt(o.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Ee(bg.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if(void 0===n||"string"!=typeof n||!r.test(n)){const r=[1],o=t=>{t.UpdateNumber=r[0],t.AvailableUpdates=s,e(t)},c=e=>gf(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let u=this._controllerUpdates.where((e=>e.UpdateType==_g.RadioUpdate)).toArray(),l=[];this._appStateService.DisallowHibernation();for(let e=0;e<u.length;e++){const t=yield(yield this._updateProviders.GetUpdatesProviderAsync(u[e].ProviderName)).InstallRadioUpdateAsync(u[e],o);yield c(5e3),t==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=u[e].UpdateIdentifier))),l.push(t),r[0]++}const d=this._controllerUpdates.find((e=>e.UpdateType==_g.SoftwareUpdate));if(null!=d)if(i<this._oldUpdateVersion||i===this._oldUpdateVersion&&a<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(d.Update,o);e==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=d.UpdateIdentifier))),l.push(e),r[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(o,t,!1);this._appStateService.AllowHibernation(),e==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),l.push(e),r[0]++}const h=l.where((e=>e instanceof Ee)).toArray();if(null!=h&&0!=h.length){let e="";return h.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),h.any((e=>e.Type==bg.UpdateDownloadFailed))?new Ee(bg.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new Ee(bg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ue.OK}{let r;const s=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==s)return new Ee(bg.CannotGetUpdates,`Update with requested guid (${n}) not found.`);switch(this._logger.Debug(`Installing single update type: ${s.Update.UpdateType}, resource: ${s.UpdatedResourceName}, version: ${s.Update.Version}`),this._appStateService.DisallowHibernation(),s.UpdateType){case _g.RadioUpdate:return r=yield(yield this._updateProviders.GetUpdatesProviderAsync(s.ProviderName)).InstallRadioUpdateAsync(s,e),this._appStateService.AllowHibernation(),this._logger.Debug(`Radio update result: ${r}`),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),r;case _g.SoftwareUpdate:return i<this._oldUpdateVersion||i===this._oldUpdateVersion&&a<=this._oldUpdateBuild?(r=yield this.UpdateControllerUsingScriptAsync(s.Update,e),this._appStateService.AllowHibernation(),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))):(yield this.CheckControllerUpdatesAsync(),r=yield this.UpdateControllerUsingApiAsync(e,t,!1),this._appStateService.AllowHibernation(),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))),r;default:return new Ee(bg.CannotProcessUpdate,`Update with type ${s.UpdateType} is not supported by UpdateService.`)}}}))}GetAutomaticControllerUpdateDownloadStatusAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(bg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let r=yield this._connection.SendAndWaitForResponseAsync(new Gf,1e4,!1);return!(r.Status!=ue.OK||!r.Data)}))}GetServiceName(){return ff.ServiceName}CheckDeviceVersionAsync(e){return gf(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield hy.Get(Yo.ServiceName).GetDevice(e);if(null==t)return new Ee(bg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ee(bg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Rs.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){return gf(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield hy.Get(Yo.ServiceName).GetDevice(e);if(null==t)return new Ee(bg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ee(bg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Rs.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const s=new mf;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 hy.Get(Yo.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(s.IsUpdateSafe=!1),s}))}CheckDeviceUpdatesBulkAsync(e){return gf(this,void 0,void 0,(function*(){const t=yield yield this._updateProviders.GetUpdatesProvidersAsync(Rs.Device),n=[];for(var r of t){const t=yield r.CheckUpdateBulkAsync(e);if(t instanceof Ee)return t;for(const e of t){const t=new mf;t.CurrentResourceVersion=e.CurrentResourceVersion,t.NewResourceVersion=e.Update.Version,t.UpdatedResourceName=e.UpdatedResourceName,t.UpdateDescription=e.UpdateDescription,t.IsUpdateSafe=!0;let s="n/a";try{s=(yield this._extensionService.GetProtocolInfoAsync(r.ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}t.Protocol=s,t.ProtocolGuid=r.ProtocolGuid,t.UpdateResourceGuid=e.Update.ResourceGuid,n.push(t)}}return n}))}InstallDeviceUpdateAsync(e,t,n){return gf(this,arguments,void 0,(function*(e,t,n,r=!1){var s;let o;if("string"==typeof e){const t=yield hy.Get(Yo.ServiceName).GetDevice(e);if(null==t)return new Ee(bg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);o=t}else o=e;if(null==o.ProtocolGuid)return new Ee(bg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(s=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(o.ProtocolGuid,Rs.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,Rs.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ue.OK)}))}InstallDevicesUpdateBulkAsync(e,t,n){return gf(this,void 0,void 0,(function*(){const r=(yield hy.Get(Yo.ServiceName).GetDevicesAsync()).where((t=>e.includes(t.Guid))).groupBy((e=>e.ProtocolGuid)),s=[];this._appStateService.DisallowHibernation();const o=r.count();for(let e=0;e<o;e++){const i=r.elementAt(e),a=e*(100/o),c=(e+1)*(100/o),u=e=>{e.PercentageTotal=Math.floor(e.PercentageTotal/100*(c-a)+a),t(e)},l=yield yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(i.key,Rs.Device),d=yield l.first().InstalUpdateBulkAsync(i.select((e=>e.Guid)).toArray(),u,n);if(d instanceof Ee)return d;s.push(d)}if(this._appStateService.AllowHibernation(),1==s.length)return s[0];{const e=new rf;s.some((e=>e.DevicesUpdateResults.count()>0))&&s.any((e=>e.BulkUpdateStatus!=kg.Success))?e.BulkUpdateStatus=kg.PartialSuccess:s.any((e=>e.BulkUpdateStatus!=kg.Success))?e.BulkUpdateStatus=s.first().BulkUpdateStatus:e.BulkUpdateStatus=kg.Success;for(const t of s)t.DevicesUpdateResults.forEach(((t,n)=>{e.DevicesUpdateResults.set(n,t)}));return e}}))}CheckControllerSoftwareUpdateAvailabilityAsync(){return gf(this,void 0,void 0,(function*(){const e=hy.Get(Xe.ServiceName).User;if(null==e)return!1;if(""==e.SoftwareVersion||null==e.SoftwareVersion)return!0;const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<this._oldUpdateVersion||parseFloat(t)==this._oldUpdateVersion&&parseFloat(n)<=this._oldUpdateBuild)return!0;const r=yield this._connection.SendAndWaitForResponseAsync(new If,1e4,!1);if(null==r||r.Status!=ue.OK||null==r.Data)return!1;const[s,o]=r.Data.Update.Version.ContainerSoftwareVersion.toString().split(".");return parseInt(s)>parseInt(t)||parseInt(s)==parseInt(t)&&parseInt(o)>parseInt(n)}))}CanCancelFailedControllerUpdateOrGetPendingUpdateProgress(){return hy.Get(ct.ServiceName).CheckIfControllerSoftwareVersionIsEnough(6,66)}CancelFailedControllerUpdateAsync(){return gf(this,void 0,void 0,(function*(){switch((yield this._connection.SendAndWaitForResponseAsync(new Df,1e4,!1)).Status){case ue.OK:return ue.OK;case ue.OperationNotPermitted:return ue.OperationNotPermitted;case ue.Error:default:return ue.Error}}))}CheckControllerPendingUpdateProgressAsync(e,t){return gf(this,void 0,void 0,(function*(){return new Promise(((n,r)=>gf(this,void 0,void 0,(function*(){var s;const o=hy.Get(Xe.ServiceName).User;if(null==o)return n(new Ee(bg.UpdateActionsNotSupported,"No user data found, cannot check pending update progress."));if(""==o.SoftwareVersion||null==o.SoftwareVersion)return n(new Ee(bg.CannotGetCurrentControllerVersion,"No software version data found, cannot check pending update progress."));const[i,a]=o.SoftwareVersion.split(".");if(parseFloat(i)<this._oldUpdateVersion||parseFloat(i)==this._oldUpdateVersion&&parseFloat(a)<=this._oldUpdateBuild)return n(new Ee(bg.UnsupportedApiVersion,"Not supported API version, cannot check pending update progress."));const c=yield this._connection.SendAndWaitForResponseAsync(new If,1e4,!1);if(c.Status!=ue.OK)return n(new Ee(bg.CannotGetUpdates,"No pending updates found."));let u=null===(s=c.Data)||void 0===s?void 0:s.DownloadOnly,l=100;const d=60*this._updateOfflineStageTime*1e3;let h=0;const p=new tf;let g=50,f=new nf,v=new tf,y=!1;u||(f.DownloadOnly=u,g=100);let m=100/g;const w=n=>{let r=n.Data;switch(this._logger.Debug(`Update progress: ${r.UpdateStep}, ${r.StepProgressInPercentage}%, ${r.UpdateProgressInPercentage}% data frame status: ${n.Status}`),p.Percentage=Math.round(r.StepProgressInPercentage),p.PercentageTotal=Math.round(r.UpdateProgressInPercentage),f.SpeedMbps=r.DownloadSpeedInMbs,f.Percentage=Math.round(r.StepProgressInPercentage),f.PercentageTotal=Math.round(r.UpdateProgressInPercentage),f.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),v.AvailableUpdates=1,v.Percentage=r.StepProgressInPercentage,v.PercentageTotal=r.UpdateProgressInPercentage,v.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),h=r.StepProgressInPercentage,r.UpdateStep){case cf.DownloadingInstaller:f.CurrentTask=Eg.DownloadingInstaller,v.Status=Cg.DownloadingPackage,t(f);break;case cf.DownloadingUpdate:f.CurrentTask=Eg.DownloadingUpdate,v.Status=Cg.DownloadingPackage,t(f);break;case cf.CheckingUpdate:f.CurrentTask=Eg.CheckingUpdate,v.Status=Cg.CheckingPackage,e(v);break;case cf.PreparingUpdate:v.Status=Cg.PreparingForUpgrade,f.CurrentTask=Eg.CheckingUpdate,e(v);break;case cf.OfflineUpdateStep:case cf.InstallingUpdate:v.Status=Cg.Upgrading,e(v);break;case cf.InstallerFileSignCheckFailed:case cf.UpdateFileSignCheckFailed:v.Status=Cg.InstallationError,e(v);break;case cf.UpdateDownloadFailed:v.Status=Cg.InstallationStopped,e(v);break;case cf.UpdateInstallationFailed:v.Status=Cg.InstallationError,e(v);break;case cf.UpdateFileCheckFailed:v.Status=Cg.IncompatiblePackage,e(v);break;case cf.UpdateDownloaded:f.Percentage=100,f.PercentageTotal=u?Math.round(r.UpdateProgressInPercentage*m):Math.round(r.UpdateProgressInPercentage),f.SpeedMbps=0,f.CurrentTask=Eg.CheckingUpdate,t(f),f.CurrentTask=Eg.UpdateDownloadedAndChecked,t(f)}};let S=null;const A=t=>gf(this,void 0,void 0,(function*(){t==it.Connected&&(clearInterval(S),p.Status=Cg.Upgraded,p.Percentage=100,p.PercentageTotal=100,e(p),clearInterval(S),yield oe.Delay(5e3),n(ue.OK),hy.Get(_t.ServiceName).OnAppStateChanged().Unsubscribe(A))}));yield this._connection.SendAndHandleResponseAsync(new kf,1e5,(s=>{var o,i,a,c,g;switch(s.Status){case ue.MultiDataResponseStart:y||(l=(null===(o=s.Data)||void 0===o?void 0:o.UpdateStep)==cf.UpdateDownloaded?100:50,y=!0),w(s);break;case ue.MultiDataResponse:w(s);break;case ue.MultiDataResponseStop:switch(null===(i=s.Data)||void 0===i?void 0:i.UpdateStep){case cf.UpdateInstallationFailed:v.Status=Cg.InstallationError,e(v),p.Percentage=0,p.PercentageTotal=0,e(p),n(new Ee(bg.CannotProcessUpdate,"Update installation failed!"));break;case cf.InstallerFileSignCheckFailed:case cf.UpdateFileSignCheckFailed:case cf.UpdateDownloadFailed:case cf.UpdateFileCheckFailed:v.Status=Cg.DownloadingFailure,e(v),p.Percentage=0,p.PercentageTotal=0,e(p),n(new Ee(bg.UpdateDownloadFailed,"Update download failed!"));break;case cf.OfflineUpdateStep:w(s),p.Percentage=Math.round(s.Data.StepProgressInPercentage),p.PercentageTotal=Math.round(s.Data.UpdateProgressInPercentage);let r=(100-p.PercentageTotal)/100,o=p.PercentageTotal;S=setInterval((()=>{h++,o+=r,o>100&&(o=100),h>=l?(p.Status=Cg.Upgraded,p.Percentage=100,p.PercentageTotal=100,e(p),clearInterval(S),n(ue.OK)):(p.Status=Cg.Upgrading,p.Percentage=Math.round(h),p.PercentageTotal=Math.round(o),e(p))}),d/(l-h)),hy.Get(_t.ServiceName).OnAppStateChanged().Subscribe(A);break;case cf.UpdateDownloaded:f.Percentage=100,f.PercentageTotal=u?Math.round((null===(a=s.Data)||void 0===a?void 0:a.UpdateProgressInPercentage)*m):Math.round(null===(c=s.Data)||void 0===c?void 0:c.UpdateProgressInPercentage),f.SpeedMbps=0,f.CurrentTask=Eg.CheckingUpdate,t(f),f.CurrentTask=Eg.UpdateDownloadedAndChecked,t(f),u&&n(ue.OK);break;default:w(s),n(new Ee(bg.CannotProcessUpdate,`Update installation failed, received UpdateStep code: ${null===(g=s.Data)||void 0===g?void 0:g.UpdateStep}!`))}break;default:r(new Ee(bg.CannotGetUpdates,`Cannot get pending update progress, response is empty or status is not OK. Status: ${null==s?void 0:s.Status}`))}}),!0)}))))}))}CheckDevicesUpdatesAvailabilityAsync(){return gf(this,void 0,void 0,(function*(){const e=hy.Get(Xe.ServiceName).User;if(null==e)return[];if(""==e.SoftwareVersion||null==e.SoftwareVersion)return[];const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<6||6==parseFloat(t)&&parseFloat(n)<=4)return[];const r=yield this._connection.SendAndWaitForResponseAsync(new Of,1e4,!1),s=[];return null==r||(null==r?void 0:r.Status)!=ue.OK||null==(null==r?void 0:r.Data)?[]:(null==r||r.Data.forEach((e=>{if(!e.IsAvailable)return;const t=new Yg;t.DeviceGuid=e.DeviceGuid,t.CurrentVersion=e.CurrentVersion,t.NewVersion=e.NewVersion,s.push(t)})),s)}))}CheckControllerUpdatesAsync(){return gf(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new Qg,n=yield this.getRuntimeInfoAsync();if(n instanceof Ee){const e=new vf;return e.UpdateType=_g.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(Rs.Controller)}catch(e){if(!(e instanceof $s))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 vf;s.ResponseResult=r,s.UpdateType=_g.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 yf;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=_g.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:_g.RadioUpdate}))}}let o=!0;if((r<this._oldUpdateVersion||r===this._oldUpdateVersion&&s<=this._oldUpdateBuild)&&(o=!1),o){const e=yield this._connection.SendAndWaitForResponseAsync(new If,15e3,!1);if(null==e||e.Status!=ue.OK&&e.Status!=ue.NoData)throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);if(null!=e.Data){const r=new Bs;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 yf;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=_g.SoftwareUpdate,s.UpdateIdentifier=e.Data.Update.Guid,s.UpdateIsDownloading=e.Data.UpdateStep==cf.DownloadingInstaller||e.Data.UpdateStep==cf.DownloadingUpdate||e.Data.UpdateStep==cf.CheckingUpdate,s.DownloadProgress=e.Data.DownloadProgress,s.UpdateCreationTime=e.Data.Update.Creationtime,s.IsDownloadOnly=e.Data.DownloadOnly,t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:ff.ServiceName,UpdateType:_g.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Ef,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ue.NoData:const r=new vf;r.UpdateType=_g.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ee(bg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ue.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const s=new Bs;s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateDescription=ie(e.Data.UpdateDescription),s.UpdatedResourceName=ie(e.Data.UpdateName).get("en-US");const o=new yf;o.UpdatedResourceName=ie(e.Data.UpdateName),o.UpdateDescription=ie(e.Data.UpdateDescription),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateType=_g.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:ff.ServiceName,UpdateType:_g.SoftwareUpdate}));break;default:throw new Error(`Cannot check updates! Response status is not OK. Status: ${e.Status}`)}}}else{const e=`https://exalus-updates.tr7.pl/software/${n.UpdateChannel}/${n.RuntimeVersion}/${n.SoftwareVersion}/update.json`;try{const r=yield fetch(e);let s,o=new Bs;const i=new vf;switch(i.UpdateType=_g.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 Ee(bg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Ee(bg.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 yf;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=_g.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:ff.ServiceName,UpdateType:_g.SoftwareUpdate}))}else if(200==r.status)throw new Error(`Cannot get Update Data from response. Status: ${r.status}`)}catch(e){const n=yield this.getRuntimeInfoAsync();if(n instanceof Ee){const e=new vf;e.UpdateType=_g.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new vf;r.UpdateType=_g.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ee(bg.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Rs.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof Ee)return t;const n=[];let r;r=new ef,r.Resource="Controller software",r.Type=_g.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new ef,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=_g.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 gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(bg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Cf,1e4,!1);if(null==r||(null==r?void 0:r.Status)!=ue.OK)return new Ee(bg.CannotGetUpdatesBranch,`Cannot get update branch, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data){case 0:return Ng.Public;case 1:return Ng.Beta;case 2:return Ng.Development;default:return new Ee(bg.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${r.Data}`)}}))}SetControllerUpdateBranchAsync(e){return gf(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof Ee)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);if(n<this._oldUpdateVersion||n===this._oldUpdateVersion&&r<=this._oldUpdateBuild)return new Ee(bg.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const s=yield this._connection.SendAndWaitForResponseAsync(new Tf(e),1e4,!1);return null==s||(null==s?void 0:s.Status)!=ue.OK?new Ee(bg.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==s?void 0:s.Status}`):ue.OK}))}EnableAutomaticControllerUpdateDownloadAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(bg.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Rf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ue.OK?new Ee(bg.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ue.OK}))}DisableAutomaticControllerUpdateDownloadAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(bg.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)!=ue.OK?new Ee(bg.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ue.OK}))}GetControllerUpdatesHistoryAsync(){return gf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ee)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ee(bg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Uf,1e4,!1);if(null==r)return new Ee(bg.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(r.Status){case ue.OK:return null!=r.Data?r.Data.map((e=>{const t=new Zg;return t.UpdatedResourceName=ie(e.UpdateName),t.UpdateDescription=ie(e.UpdateDescription),t.UpdateCreationTime=e.Creationtime,t.UpdateChannel=e.UpdateChannel,t.Version=`${e.Version.BaseRuntime}.${e.Version.ContainerSoftwareVersion}`,t})):new Ee(bg.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ue.NoData:return[];default:return new Ee(bg.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${r.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,s){return gf(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 Ee)return a;const c=parseInt(a.SoftwareVersion.toString().split(".")[0]),u=parseInt(a.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Ee(bg.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=>gf(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let l=this._controllerUpdates.where((e=>e.UpdateType==_g.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==ue.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==_g.SoftwareUpdate));if(null!=h)if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(h.Update,o);e==ue.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==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),d.push(e),s[0]++}const p=d.where((e=>e instanceof Ee)).toArray();if(null!=p&&0!=p.length){let e="";return p.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),p.any((e=>e.Type==bg.UpdateDownloadFailed))?new Ee(bg.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new Ee(bg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ue.OK}{let o;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new Ee(bg.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 _g.RadioUpdate:return r?new Ee(bg.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==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),o);case _g.SoftwareUpdate:if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){if(r)return new Ee(bg.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");o=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),o==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else{let s=(yield this.CheckControllerUpdatesAsync()).UpdatesAvailable.any((e=>e.IsDownloadOnly));o=yield this.UpdateControllerUsingApiAsync(e,t,!s&&r),this._appStateService.AllowHibernation(),o==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}return o;default:return new Ee(bg.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){return gf(this,void 0,void 0,(function*(){var n,r,s,o,i,a;switch(e.UpdateType){case Ps.Container:case Ps.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new wf(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new tf;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ue.MultiDataResponseStart:r.Status=Cg.PreparingForUpgrade;break;case ue.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(ff.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case Tg.CheckingApplicability:case Tg.CheckingIntegrity:case Tg.CheckingPackageIntegrity:r.Status=Cg.CheckingPackage;break;case Tg.CreatingBackup:case Tg.MigratingData:case Tg.Removing:r.Status=Cg.MovingData;break;case Tg.Deploying:case Tg.Installing:r.Status=Cg.Upgrading;break;case Tg.Downloading:r.Status=Cg.DownloadingPackage;break;case Tg.Error:r.Status=Cg.Error;break;case Tg.Installed:r.Status=Cg.Upgraded;break;case Tg.PreparingSystem:case Tg.ReadyToDownload:r.Status=Cg.PreparingForUpgrade;break;case Tg.UndoingInstallation:r.Status=Cg.InstallationStopped;break;case Tg.Unpackaging:r.Status=Cg.MovingData;break;case Tg.WaitingForUser:r.Status=Cg.Upgrading}break;case ue.MultiDataResponseStop:r.Status=Cg.OK;break;case ue.Error:case ue.FatalError:r.Status=Cg.Error}t(r)}),!1),ue.OK}catch(e){return new Ee(bg.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case Ps.RuntimeFixingScript:var c=10;let d="n/a";try{d=(yield this._extensionService.GetExtensionsInfoAsync()).first((e=>"f4f45dac-beda-441a-8d29-efc6dc977cd1"==e.ExtensionGuid)).ExtensionVersion}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}var u=d;const h=yield this.getRuntimeInfoAsync();if(h instanceof Ee)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield hy.Get(Yo.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(ff.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new tf;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=Cg.PreparingForUpgrade,t(r);let s=2;const o=Date.now(),i=900*c+16e5,a=i/100,u=o+i,l=new Promise(((o,c)=>gf(this,void 0,void 0,(function*(){var c;try{const l=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(l),Date.now()>u)clearInterval(n),this._logger.Debug("Update already finished!"),r.Percentage=100,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cg.Upgraded,t(r),o(ue.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=Cg.Upgraded,t(r),o(ue.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=Cg.Upgraded,t(r),o(ue.OK);else{var e=s;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=Cg.Upgrading,t(r))}s++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Sf(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ue.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cg.InstallationError,t(r),this._logger.Debug(ff.ServiceName,`Update failed with error. Update response status: ${d.Status}`),o(new Ee(bg.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(ff.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Cg.Error,t(r),clearInterval(n),o(new Ee(bg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new tf;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cg.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new Ee(bg.CannotProcessUpdate,"Cannot process update. Cannot get current controller login credentials!");if((yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Af({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ue.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cg.PreparingForUpgrade,t(n);let r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new _f("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ue.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cg.PreparingForUpgrade,t(n),r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new _f(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ue.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cg.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new _f("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ue.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cg.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)=>gf(this,void 0,void 0,(function*(){var c;try{const l=()=>{if(this._appStateService.OnReturnedFromSuspension().Unsubscribe(l),Date.now()>u)clearInterval(e),this._logger.Debug("Update already finished!"),n.Percentage=100,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cg.Upgraded,t(n),o(ue.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=Cg.Upgraded,t(n),o(ue.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=Cg.Upgraded,t(n),o(ue.OK);else{var i=5+r*s;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=Cg.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new _f("/runtime/tmp/update.sh"),12e3,!1)}catch(e){o(new Ee(bg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=Cg.InstallationError,t(n),new Ee(bg.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new _f("/runtime/scripts/restart_all.sh"),12e3,!1),new Ee(bg.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Ee(bg.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Ee(bg.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Ee(bg.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}DownloadControllerUpdateNewApiAsync(e,t,n,r){return gf(this,void 0,void 0,(function*(){return new Promise(((t,s)=>gf(this,void 0,void 0,(function*(){let s=50;r||(s=100);let o=100/s;yield this._connection.SendAndHandleResponseAsync(new bf,this._updateRequestTimeout,(s=>{var i,a,c,u,l,d;const h=new nf;switch(h.DownloadOnly=r,h.UpdatedResourceName=ie(e.Update.UpdateName),s.Status){case ue.MultiDataResponseStart:h.Percentage=0,h.SpeedMbps=0,h.PercentageTotal=0,h.CurrentTask=Eg.DownloadingInstaller,n(h);break;case ue.MultiDataResponse:if(null!=s.Data){switch(h.Percentage=s.Data.StepProgressInPercentage,h.SpeedMbps=s.Data.DownloadSpeedInMbs,h.PercentageTotal=r?Math.round((null===(i=s.Data)||void 0===i?void 0:i.UpdateProgressInPercentage)*o):Math.round(null===(a=s.Data)||void 0===a?void 0:a.UpdateProgressInPercentage),s.Data.UpdateStep){case cf.DownloadingInstaller:h.CurrentTask=Eg.DownloadingInstaller;break;case cf.DownloadingUpdate:h.CurrentTask=Eg.DownloadingUpdate;break;case cf.UpdateDownloaded:h.Percentage=100,h.PercentageTotal=r?Math.round((null===(c=s.Data)||void 0===c?void 0:c.UpdateProgressInPercentage)*o):Math.round(null===(u=s.Data)||void 0===u?void 0:u.UpdateProgressInPercentage),h.SpeedMbps=0,h.CurrentTask=Eg.CheckingUpdate,n(h),h.CurrentTask=Eg.UpdateDownloadedAndChecked,n(h),t(ue.OK);break;default:h.CurrentTask=Eg.CheckingUpdate}n(h)}break;case ue.MultiDataResponseStop:if(null!=s.Data)switch(s.Data.UpdateStep){case cf.UpdateDownloaded:h.Percentage=100,h.PercentageTotal=r?Math.round((null===(l=s.Data)||void 0===l?void 0:l.UpdateProgressInPercentage)*o):Math.round(null===(d=s.Data)||void 0===d?void 0:d.UpdateProgressInPercentage),h.SpeedMbps=0,h.CurrentTask=Eg.CheckingUpdate,n(h),h.CurrentTask=Eg.UpdateDownloadedAndChecked,n(h),t(ue.OK);break;case cf.UpdateDownloadFailed:h.Percentage=0,h.PercentageTotal=0,h.SpeedMbps=0,h.CurrentTask=Eg.Unknown,n(h),t(new Ee(bg.UpdateDownloadFailed,"Update download failed!"))}break;case ue.Error:case ue.FatalError:h.Percentage=0,h.PercentageTotal=0,h.SpeedMbps=0,h.CurrentTask=Eg.Unknown,n(h),t(new Ee(bg.CannotProcessUpdate,"Update download failed!"))}}),!1)}))))}))}InstallUpdateNewApiAsync(e,t,n,r){return gf(this,void 0,void 0,(function*(){return new Promise(((n,r)=>gf(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let s=0;const o=new tf;let i=null;e.DownloadOnly=!1;const a=e=>gf(this,void 0,void 0,(function*(){e==it.Connected&&(clearInterval(i),o.Status=Cg.Upgraded,o.Percentage=100,o.PercentageTotal=100,t(o),clearInterval(i),yield oe.Delay(5e3),n(ue.OK),hy.Get(_t.ServiceName).OnAppStateChanged().Unsubscribe(a))}));yield this._connection.SendAndHandleResponseAsync(new Nf,this._updateRequestTimeout,(c=>{var u,l;switch(o.UpdatedResourceName=ie(e.Update.UpdateName),c.Status){case ue.MultiDataResponseStart:o.Status=Cg.PreparingForUpgrade,o.Percentage=null===(u=c.Data)||void 0===u?void 0:u.StepProgressInPercentage,o.PercentageTotal=null===(l=c.Data)||void 0===l?void 0:l.UpdateProgressInPercentage,t(o);break;case ue.MultiDataResponse:null!=c.Data&&(o.Status=Cg.Upgrading,o.Percentage=Math.round(c.Data.StepProgressInPercentage),o.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage),s=c.Data.StepProgressInPercentage,t(o));break;case ue.MultiDataResponseStop:if(null!=c.Data)switch(c.Data.UpdateStep){case cf.UpdateInstallationFailed:o.Status=Cg.InstallationError,o.Percentage=0,o.PercentageTotal=0,t(o),n(new Ee(bg.CannotProcessUpdate,"Update installation failed!"));break;case cf.OfflineUpdateStep:{o.Percentage=Math.round(c.Data.StepProgressInPercentage),o.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage);let e=(100-o.PercentageTotal)/100,u=o.PercentageTotal;i=setInterval((()=>{s++,u+=e,u>100&&(u=100),s>=100?(o.Status=Cg.Upgraded,o.Percentage=100,o.PercentageTotal=100,t(o),clearInterval(i),n(ue.OK)):(o.Status=Cg.Upgrading,o.Percentage=Math.round(s),o.PercentageTotal=Math.round(u),t(o))}),r/(100-s)),hy.Get(_t.ServiceName).OnAppStateChanged().Subscribe(a)}}break;case ue.Error:case ue.FatalError:o.Status=Cg.Error,o.Percentage=0,o.PercentageTotal=0,t(o),n(new Ee(bg.CannotProcessUpdate,"Update installation failed!"))}}),!1)}))))}))}InstallControllerUpdateUsingApiAsync(e,t){return gf(this,void 0,void 0,(function*(){const n=yield this._connection.SendAndWaitForResponseAsync(new If,1e4,!1);if((null==n?void 0:n.Status)==ue.NoData)return new Ee(bg.DeviceIsUpToDate,"No updates available!");if(null==n||(null==n?void 0:n.Status)!=ue.OK||null==(null==n?void 0:n.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==n?void 0:n.Status}`);switch(n.Data.UpdateStep){case cf.DownloadingInstaller:case cf.DownloadingUpdate:return new Ee(bg.UpdateAlreadyDownloaded,"Update already downloaded, or download in progress.");case cf.InstallingUpdate:case cf.PreparingUpdate:return new Ee(bg.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case cf.UpdateDownloaded:return n.Data.DownloadOnly=!1,yield this.InstallUpdateNewApiAsync(n.Data,e,t,!1);default:this._logger.Debug(ff.ServiceName,`Installing update using new API. Update step: ${n.Data.UpdateStep} downloadOnly: false`),n.Data.DownloadOnly=!1;var r=yield this.DownloadControllerUpdateNewApiAsync(n.Data,e,t,!1);return r!=ue.OK?r:yield this.InstallUpdateNewApiAsync(n.Data,e,t,!1)}}))}DownloadControllerUpdateUsingApiAsync(e,t,n){return gf(this,void 0,void 0,(function*(){const r=yield this._connection.SendAndWaitForResponseAsync(new If,1e4,!1);if((null==r?void 0:r.Status)==ue.NoData)return new Ee(bg.DeviceIsUpToDate,"No updates available!");if(null==r||(null==r?void 0:r.Status)!=ue.OK||null==(null==r?void 0:r.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data.UpdateStep){case cf.DownloadingInstaller:case cf.DownloadingUpdate:case cf.UpdateDownloaded:return new Ee(bg.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case cf.InstallingUpdate:case cf.PreparingUpdate:return new Ee(bg.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield this.DownloadControllerUpdateNewApiAsync(r.Data,e,t,n)}}))}UpdateControllerUsingApiAsync(e,t,n){return gf(this,void 0,void 0,(function*(){return n?yield this.DownloadControllerUpdateUsingApiAsync(e,t,!0):yield this.InstallControllerUpdateUsingApiAsync(e,t)}))}getRuntimeInfoAsync(){return gf(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof po&&e.code==Ws.Timeout?new Ee(bg.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new Ee(bg.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}ff.ServiceName="UpdatesService";class vf{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class yf{constructor(){this._updateIdentifier="",this._updateResourceName=new Map,this._updateType=null,this._currentResourceVersion="",this._newResourceVersion="",this._updateDescription=new Map,this._updateIsDownloading=!1,this._updateCheckDownloadProgress=0,this._updateCreationTime=null,this._isDownloadOnly=!1}get IsDownloadOnly(){return this._isDownloadOnly}set IsDownloadOnly(e){this._isDownloadOnly=e}get UpdateCreationTime(){return this._updateCreationTime}get DownloadProgress(){return this._updateCheckDownloadProgress}get UpdateDescription(){return this._updateDescription}get UpdateIdentifier(){return this._updateIdentifier}get UpdatedResourceName(){return this._updateResourceName}get UpdateType(){return this._updateType}get CurrentResourceVersion(){return this._currentResourceVersion}get NewResourceVersion(){return this._newResourceVersion}get UpdateIsDownloading(){return this._updateIsDownloading}set UpdateCreationTime(e){this._updateCreationTime=e}set DownloadProgress(e){this._updateCheckDownloadProgress=e}set UpdateDescription(e){this._updateDescription=e}set UpdateIdentifier(e){this._updateIdentifier=e}set UpdatedResourceName(e){this._updateResourceName=e}set UpdateType(e){this._updateType=e}set CurrentResourceVersion(e){this._currentResourceVersion=e}set NewResourceVersion(e){this._newResourceVersion=e}set UpdateIsDownloading(e){this._updateIsDownloading=e}}class mf{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 wf extends ce{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=le.Post,this.Data=e}}!function(e){e[e.Windows=0]="Windows",e[e.Linux=1]="Linux",e[e.Unix=2]="Unix",e[e.OSX=3]="OSX",e[e.Android=4]="Android",e[e.iOS=5]="iOS",e[e.WindowsMobile=6]="WindowsMobile"}(sf||(sf={})),function(e){e[e.Any=0]="Any",e[e.MIPS=1]="MIPS",e[e.ARM32=2]="ARM32",e[e.ARM64=3]="ARM64",e[e.IntelX86=4]="IntelX86",e[e.IntelX64=5]="IntelX64"}(of||(of={})),function(e){e[e.Unknown=0]="Unknown",e[e.Environment=1]="Environment",e[e.OperatingSystem=2]="OperatingSystem",e[e.Application=3]="Application",e[e.Extension=4]="Extension",e[e.HardwareFirmware=5]="HardwareFirmware",e[e.Script=6]="Script",e[e.Command=7]="Command"}(af||(af={})),function(e){e[e.InstallerFileSignCheckFailed=-5]="InstallerFileSignCheckFailed",e[e.UpdateFileSignCheckFailed=-4]="UpdateFileSignCheckFailed",e[e.UpdateInstallationFailed=-3]="UpdateInstallationFailed",e[e.UpdateDownloadFailed=-2]="UpdateDownloadFailed",e[e.UpdateFileCheckFailed=-1]="UpdateFileCheckFailed",e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.CheckingUpdate=2]="CheckingUpdate",e[e.PreparingUpdate=3]="PreparingUpdate",e[e.InstallingUpdate=4]="InstallingUpdate",e[e.DownloadingInstaller=5]="DownloadingInstaller",e[e.UpdateDownloaded=6]="UpdateDownloaded",e[e.OfflineUpdateStep=7]="OfflineUpdateStep"}(cf||(cf={}));class Sf extends ce{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=le.Put,this.Data=e}}class Af extends ce{constructor(e){super(),this.Resource="/users/user/login",this.Method=le.Put,this.Data=e}}class _f extends ce{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=le.Post,this.Data=e}}class Cf extends ce{constructor(){super(),this.Resource="/updates/branch",this.Method=le.Get}}class Tf extends ce{constructor(e){super(),this.Resource="/updates/branch",this.Method=le.Put,this.Data=e}}class Df extends ce{constructor(){super(),this.Resource="/updates/failed/cancel",this.Method=le.Put}}class kf extends ce{constructor(){super(),this.Resource="/updates/pending/progress",this.Method=le.Get}}class If extends ce{constructor(){super(),this.Resource="/updates/pending",this.Method=le.Get}}class Ef extends ce{constructor(){super(),this.Resource="/updates/check",this.Method=le.Get}}class bf extends ce{constructor(){super(),this.Resource="/updates/download",this.Method=le.Post}}class Nf extends ce{constructor(){super(),this.Resource="/updates/install",this.Method=le.Post}}class Gf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=le.Get}}class Rf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=le.Put}}class Pf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=le.Put}}class Uf extends ce{constructor(){super(),this.Resource="/updates/history",this.Method=le.Get}}class Of extends ce{constructor(){super(),this.Resource="/updates/devices/availability",this.Method=le.Get}}!function(e){e.CannotFindDevice="CannotFindDevice",e.ResponseTypeNotSupported="ResponseTypeNotSupported",e.InvalidChannelNumber="InvalidChannelNumber",e.IncorrectLimitValue="IncorrectLimitValue",e.IncorrectOffsetValue="IncorrectOffsetValue",e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.FunctionalityNotSupported="FunctionalityNotSupported"}(uf||(uf={})),function(e){e[e.None=0]="None",e[e.DataRange=1]="DataRange",e[e.Hour=2]="Hour",e[e.Day=3]="Day",e[e.Week=4]="Week",e[e.Month=5]="Month",e[e.Year=6]="Year",e[e.ThisHour=7]="ThisHour",e[e.ThisDay=8]="ThisDay",e[e.ThisWeek=9]="ThisWeek",e[e.ThisMonth=10]="ThisMonth",e[e.ThisYear=11]="ThisYear"}(lf||(lf={})),function(e){e[e.Day=0]="Day",e[e.Week=1]="Week",e[e.Month=2]="Month",e[e.Year=3]="Year",e[e.Hour=4]="Hour"}(df||(df={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(hf||(hf={}));class Mf{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"}(pf||(pf={}));var xf,Ff,Lf,Bf,$f,Wf,Vf,qf=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 Hf{constructor(){this.DELIM=";",this._connection=null,this._connection=hy.Get(It.ServiceName)}numToCsv(e){const t="string"==typeof e?Number(e.replace(",",".")):e;return Number.isFinite(t)?t.toLocaleString("en-US",{useGrouping:!1}):""}quoteIfNeeded(e){return e.includes(this.DELIM)||e.includes('"')?`"${e.replace(/"/g,'""')}"`:e}ExportPressureToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`PressureHistory_${e.Name}_${t}.csv`)}ExportBrightnessToCsv(e,t,n){var r;if(!(null===(r=null==n?void 0:n.Data)||void 0===r?void 0:r.length))return;const s=[],o=(n.Data[0],["Time","AggregatedBy"]);o.push("LuxValue","LuxToLinearScale","LightCondition"),s.push(o.join(this.DELIM)),n.Data.forEach((e=>{var t,n,r;const o=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null!==e.Values&&(o.push(this.numToCsv(null===(t=e.Values)||void 0===t?void 0:t.LuxValue)),o.push(this.numToCsv(null===(n=e.Values)||void 0===n?void 0:n.LuxToLinearScale)),o.push(this.numToCsv(null===(r=e.Values)||void 0===r?void 0:r.LightCondition))),s.push(o.join(this.DELIM))})),ae(s.join("\n"),`BrightnessHistory_${e.Name}_${t}.csv`)}ExportHumidityToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`HumidityHistory_${e.Name}_${t}.csv`)}ExportWindSpeedToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`WindSpeedHistory_${e.Name}_${t}.csv`)}ExportTemperatureToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`TemperatureHistory_${e.Name}_${t}.csv`)}ExportAveragingStateValuesToCsv(e,t,n){var r;if(!(null===(r=null==n?void 0:n.Data)||void 0===r?void 0:r.length))return"";const s=[],o=(n.Data[0],["Time","AggregatedBy"]);return o.push("LastValue","Average","Mode","Min","Max"),s.push(o.join(this.DELIM)),n.Data.forEach((e=>{var t,n,r,o,i;const a=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null!==e.Values&&(a.push(this.numToCsv(null===(t=e.Values)||void 0===t?void 0:t.LastValue)),a.push(this.numToCsv(null===(n=e.Values)||void 0===n?void 0:n.Average)),a.push(this.numToCsv(null===(r=e.Values)||void 0===r?void 0:r.Mode)),a.push(this.numToCsv(null===(o=e.Values)||void 0===o?void 0:o.Min)),a.push(this.numToCsv(null===(i=e.Values)||void 0===i?void 0:i.Max))),s.push(a.join(this.DELIM))})),s.join("\n")}ExportEnergyToCsv(e,t,n){var r,s;let o=n.Data;if(!(null==o?void 0:o.length))return;const i=[],a=o[0],c=["Time","AggregatedBy"];null===(r=a.Values)||void 0===r||r.MeasurementAveragingParameters.forEach(((e,t)=>{c.push(`${t}:LastValue`,`${t}:Average`,`${t}:Mode`,`${t}:Min`,`${t}:Max`)})),null===(s=a.Values)||void 0===s||s.MeasurementNonAveragingParmeters.forEach(((e,t)=>c.push(`${t}`))),i.push(c.join(this.DELIM)),o.forEach((e=>{var t,n;const r=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null===(t=e.Values)||void 0===t||t.MeasurementAveragingParameters.forEach((e=>{r.push(this.numToCsv(e.LastValue),this.numToCsv(e.Average),this.numToCsv(e.Mode),this.numToCsv(e.Min),this.numToCsv(e.Max))})),null===(n=e.Values)||void 0===n||n.MeasurementNonAveragingParmeters.forEach((e=>r.push(this.numToCsv(e)))),i.push(r.join(this.DELIM))})),ae(i.join("\n"),`EnergyHistory_${e.Name}_${t}.csv`)}GetStatesByTimeRangeAsync(e,t,n,r,s,o,i){return qf(this,arguments,void 0,(function*(e,t,n,r,s,o,i,a=!1){var c;try{if(!(yield this.DoesSupportPreciseTimeFramesAsync()))return new Ee(uf.FunctionalityNotSupported,"State history data in time range is not supported with this version of controller software, update software to get this functionality.");let u;if("string"==typeof e){const t=yield hy.Get(Yo.ServiceName).GetDevice(e);if(null==t)return new Ee(uf.CannotFindDevice,`Device with specified GUID ${e} does not exist.`);u=t}else u=e;if(!u.Channels.any((e=>e.Number===t)))return new Ee(uf.InvalidChannelNumber,`Given channel not found in device with guid: ${u.Guid}.`);if(!u.Channels.any((e=>e.Number===t&&e.AvailableResponseTypes.any((e=>e.Type===n)))))return new Ee(uf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const l=new Jf;l.DeviceGuid=u.Guid,l.DeviceChannel=t,l.StateInterfaceType=n,l.ReverseOrder=a,l.DataRange=r,l.Time=s,l.Limit=o,l.Offset=i;const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new zf(l),3e4,!1);if(null==d)return new Ee(uf.OtherError,"Cannot get state history data - response is null.");switch(d.Status){case ue.WrongData:switch(d.Data){case"IncorrectLimitValue":return new Ee(uf.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ee(uf.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ee(uf.OtherError,"Cannot get state history data - some parameters are incorrect!");case"UnsupportedRange":return new Ee(uf.OtherError,"Cannot get state history data - time range is incorrect!");default:return new Ee(uf.OtherError,"Cannot get state history data - unknown error!")}case ue.FatalError:return new Ee(uf.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ue.ResourceDoesNotExists:return new Ee(uf.ResponseTypeNotSupported,`Device or channel not supporting requested DeviceResponseType or device/channel does not exist. ${d.Data}`);case ue.OK:if(null==d.Data)return new Ee(uf.NoData,"Controller responded with status OK, but response does not contain data!");if(d.Data.AggregateDataList=d.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===Pt.MeasuredEnergy){const e=d.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return d.Data.Data=e,d.Data}return d.Data;default:return new Ee(uf.OtherError,`Cannot get state history data - controller responded with response code ${d.Status}`)}}catch(e){return new Ee(uf.FatalError,`Cannot get state history data - exception occurs! ${e}`)}}))}GetServiceName(){return Hf.ServiceName}DoesSupportPreciseTimeFramesAsync(){return qf(this,void 0,void 0,(function*(){let e=(yield hy.Get(ao.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");return Number(e[0])>6||6===Number(e[0])&&Number(e[1])>=101}))}GetStatesByIntervalAsync(e,t,n,r,s,o){return qf(this,arguments,void 0,(function*(e,t,n,r,s,o,i=!1){var a;try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Ee(uf.FunctionalityNotSupported,"State history data is not supported with this version of controller software, update software to get this functionality.");let c;if("string"==typeof e){const t=yield hy.Get(Yo.ServiceName).GetDevice(e);if(null==t)return new Ee(uf.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new Ee(uf.InvalidChannelNumber,`Given channel not found in device with guid: ${c.Guid}.`);if(!c.Channels.any((e=>e.Number==t&&e.AvailableResponseTypes.any((e=>e.Type==n)))))return new Ee(uf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new jf;u.DeviceGuid=c.Guid,u.DeviceChannel=t,u.StateInterfaceType=n,u.ReverseOrder=i,u.Limit=s,u.Offset=o;let l=(yield hy.Get(ao.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");if(Number(l[0])>6||6===Number(l[0])&&Number(l[1])>=101)switch(r){case lf.ThisHour:u.Range=lf.Hour;break;case lf.ThisDay:u.Range=lf.Day;break;case lf.ThisWeek:u.Range=lf.Week;break;case lf.ThisMonth:u.Range=lf.Month;break;case lf.ThisYear:u.Range=lf.Year}else u.Range=r;const d=yield null===(a=this._connection)||void 0===a?void 0:a.SendAndWaitForResponseAsync(new Kf(u),3e4,!1);if(null==d)return new Ee(uf.OtherError,"Cannot get state history data - response is null.");switch(d.Status){case ue.WrongData:switch(d.Data){case"IncorrectLimitValue":return new Ee(uf.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ee(uf.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ee(uf.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Ee(uf.OtherError,"Cannot get state history data - unknown error!")}case ue.FatalError:return new Ee(uf.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ue.ResourceDoesNotExists:return new Ee(uf.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ue.OK:if(null==d.Data)return new Ee(uf.NoData,"Controller responede with status OK, but response does not contain data!");if(d.Data.AggregateDataList=d.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===Pt.MeasuredEnergy){const e=d.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return d.Data.Data=e,d.Data}return d.Data;default:return new Ee(uf.OtherError,`Cannot get state history data - controller responded with response code ${d.Status}`)}}catch(e){return new Ee(uf.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){return qf(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Xf,12e3,!1);return null==t?new Ee(uf.OtherError,"Cannot get available states - response is null."):t.Status!=ue.OK?new Ee(uf.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Ee(uf.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new Mf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Ee(uf.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return qf(this,void 0,void 0,(function*(){let e=(yield hy.Get(ao.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");return Number(e[0])>3||3===Number(e[0])&&Number(e[1])>=42}))}GetAvailableStatesPerChannelAsync(e,t){return qf(this,void 0,void 0,(function*(){var n;let r;if("string"==typeof e){const t=yield hy.Get(Yo.ServiceName).GetDevice(e);if(null==t)return new Ee(uf.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);r=t}else r=e;const s=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Yf(new Qf(r.Guid,t)),8e3,!1);if(null==s)return new Ee(uf.OtherError,"Cannot get available states - response is null.");switch(s.Status){case ue.ResourceDoesNotExists:switch(s.Data){case"DeviceNotFound":return new Ee(uf.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new Ee(uf.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new Ee(uf.OtherError,"Cannot get available states - unknown error!")}case ue.OK:{if(null==s.Data)return new Ee(uf.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 Mf;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return s.Data.AvailableStates=e,s.Data}default:return new Ee(uf.OtherError,`Cannot get available states - controller responded with response code ${s.Status}`)}}))}}Hf.ServiceName="StatesHistoryService";class Kf extends ce{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=le.Get,this.Data=e}}class jf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=lf.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class zf extends ce{constructor(e){super(),this.Resource="/statehistory/states/get/timerange",this.Method=le.Get,this.Data=e}}class Jf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.DataRange=df.Day,this.Time=new Date,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class Xf extends ce{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=le.Get}}class Yf extends ce{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=le.Get,this.Data=e}}class Qf{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}(Vf=xf||(xf={}))[Vf.User=0]="User",Vf[Vf.Controller=1]="Controller",Vf[Vf.Marketing=2]="Marketing",(Wf=Ff||(Ff={}))[Wf.Notification=0]="Notification",Wf[Wf.Message=1]="Message",Wf[Wf.Alarm=2]="Alarm",Wf[Wf.Warning=3]="Warning",Wf[Wf.Info=4]="Info",($f=Lf||(Lf={}))[$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"}(Bf||(Bf={}));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._chatSubscriptions=[],this._connection=hy.Get(It.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==Ff.Message)return;const n=new tv;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(Bf[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return Zf(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new nv,12e3,!1);if(null==e)return new Ee(pv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ue.OK)return new Ee(pv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ee(pv.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==Ff.Message)return;const n=new tv;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(Bf[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new Ee(pv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return Zf(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new rv(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(Av.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class tv{constructor(){this._sender=xf.Controller,this._messageType=Ff.Info,this._messageSource=Lf.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 nv extends ce{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=le.Get}}class rv extends ce{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=le.Put,this.Data=e}}var sv,ov,iv,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(){this._chatSubscriptions=[],this._connection=hy.Get(It.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==Ff.Message){const e=new uv;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 av(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new dv,12e3,!1);if(null==e)return new Ee(pv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ue.OK)return new Ee(pv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ee(pv.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==Ff.Message){const n=new uv;n.DateTime=e.DateTime,n.Guid=e.Guid,n.MessageText=e.MessageText,n.SenderName=e.SenderName?e.SenderName:"n/a",t.push(n)}})),t}catch(e){return new Ee(pv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return av(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new lv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(Av.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class uv{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 lv extends ce{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=le.Put,this.Data=e}}class dv extends ce{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=le.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(sv||(sv={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(ov||(ov={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(iv||(iv={}));var hv,pv,gv,fv=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 vv{constructor(){this._chatSubscriptions=[],this._connection=hy.Get(It.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new Sv;if(n.DateTime=t.DateTime,n.Guid=t.Guid,n.MessageText=t.MessageText?t.MessageText:"",n.SenderName=t.SenderName?t.SenderName:"n/a",null!=t.ControllerActivities)for(let[e,r]of Object.entries(t.ControllerActivities)){const t=sv[e],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(iv[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return fv(this,void 0,void 0,(function*(){return(yield hy.Get(nt.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return fv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new mv,8e3,!1);return null==e||null==e.Status?new Ee(pv.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ue.OK?new Ee(pv.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new Ee(pv.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new Ee(pv.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return fv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new wv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(Av.ServiceName,`Cannot set chat configuration! ${e}`),ue.FatalError}}))}SendMessageAsync(e){return fv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new yv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(Av.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){var t;null===(t=this._chatSubscriptions)||void 0===t||t.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class yv extends ce{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=le.Put,this.Data=e}}class mv extends ce{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=le.Get}}class wv extends ce{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=le.Put,this.Data=e}}class Sv{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"}(hv||(hv={}));class Av{constructor(){this._services={ControllerChat:new ev,GptChat:new vv,FamillyChat:new cv}}GetServiceName(){return Av.ServiceName}GetChatImplementation(e){switch(e){case hv.ControllerChat:return this._services.ControllerChat;case hv.FamilyChat:return this._services.FamillyChat;case hv.GptChat:return this._services.GptChat;default:throw new _v(`Chat with type ${e} not implemented!`)}}}Av.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(pv||(pv={}));class _v 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"}(gv||(gv={}));var Cv=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 Tv{constructor(){this._connection=hy.Get(It.ServiceName),this._log=hy.Get(a.ServiceName),this._cache=hy.Get(Be.ServiceName)}GetServiceName(){return Tv.ServiceName}IsSupportedAsync(){return Cv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Dv,2e3,!1);return this._log.Debug(Tv.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ue.WrongData}))}GetConnectedAppsAsync(){return Cv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new kv,2e3,!0);return(null==e?void 0:e.Status)===ue.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return Cv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Ev(e),2e3,!1);switch(null==t?void 0:t.Status){case ue.OK:return this._cache.Remove(new kv),new Ee(gv.Changed,"");case ue.WrongData:switch(t.Data){case"AccessTokenToShort":return new Ee(gv.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new Ee(gv.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new Ee(gv.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new Ee(gv.AppNameToShort,t.Data);case"AppUrlToShort":return new Ee(gv.AppUrlToShort,t.Data);case"AppUserIdToShort":return new Ee(gv.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new Ee(gv.AppUserNameToShort,t.Data);default:return new Ee(gv.UnkownError,t.Data)}case ue.ResourceDoesNotExists:case ue.ResourceIsNotAvailable:return new Ee(gv.ResourceIsNotAvailable,t.Data);default:return new Ee(gv.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Cv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Iv(e.Guid),2e3,!1);return(null==t?void 0:t.Status)===ue.OK&&this._cache.Remove(new kv),null==t?void 0:t.Status}))}}Tv.ServiceName="ConnectedAppsService";class Dv extends ce{constructor(){super(),this.Resource="/applications/app/auth",this.Method=le.Put,this.Data=""}}class kv extends ce{constructor(){super(),this.Resource="/applications/get",this.Method=le.Get}}class Iv extends ce{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=le.Delete,this.Data=e}}class Ev extends ce{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=le.Put,this.Data=e}}var bv=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(){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(Nv.AppUserControllersKeyName,e)}null!==s&&localStorage.setItem(Nv.AppUserControllersKeyName,decodeURIComponent(s)),null!==o&&localStorage.setItem(Nv.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 Nv.ServiceName}IsMigrationDataAvailableAsync(){return bv(this,void 0,void 0,(function*(){try{if(se.IsIosNative()){var e=yield Nv.GetIosMigrationStatus();return null!==e&&e}if(!navigator.userAgent.endsWith("LavvaAndroidNative")||void 0!==navigator.exalusMigration&&null!==navigator.exalusMigration||(yield this.waitForNavigatorObject("exalusMigration")),this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.IsMigrationDataAvailableAsync();return null!=e&&e.DataMigrated}return null!==localStorage.getItem(Nv.AppSelectedLanguageKeyName)||null!==localStorage.getItem(Nv.AppUserControllersKeyName)}catch(e){return console.error(e),!1}}))}GetControllersDataAsync(){return bv(this,void 0,void 0,(function*(){try{if(se.IsIosNative()){let e=yield Nv.GetIosControllerList();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetControllersDataAsync();return void 0===e?null:e}let e=localStorage.getItem(Nv.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}catch(e){return console.error(e),null}}))}GetLanguageCodeAsync(){return bv(this,void 0,void 0,(function*(){try{if(se.IsIosNative()){let e=yield Nv.GetIosDefaultLanguage();return void 0===e?null:e}{if(this.IsExalusNativeMigrationAvailable()){let e=yield navigator.exalusMigration.GetLanguageCodeAsync();return void 0===e?null:e}let e=localStorage.getItem(Nv.AppSelectedLanguageKeyName);return null!=e?e:null}}catch(e){return console.error(e),null}}))}static GetIosMigrationStatus(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.isMigrationAvaliable=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("IsMigrationAvaliable")}catch(e){r(e)}}))}static GetIosControllerList(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleControllers=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetControllers")}catch(e){r(e)}}))}static GetIosDefaultLanguage(e=8e3){let t;return new Promise(((n,r)=>{t=setTimeout((()=>{r(null)}),e);try{window.nativeEvent.exalusControllerData.handleLanguage=e=>{clearTimeout(t),n(e)},window.webkit.messageHandlers.exalusControllerData.postMessage("GetDefaultLanguage")}catch(e){r(e)}}))}}Nv.AppSelectedLanguageKeyName="App___SelectedLanguage",Nv.AppUserControllersKeyName="App___UserControllersListDatabase",Nv.ServiceName="DataMigrationService";var Gv=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._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=hy.Get(It.ServiceName),this._logger=hy.Get(a.ServiceName),this._storage=hy.Get(l.ServiceName),hy.Get(Xe.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Gv(this,void 0,void 0,(function*(){var e;try{yield oe.Delay(5e3);const t=yield this.GetControllerNetworkConfigurationAsync();if(null!=t){this._localIpAddress=t.LocalIPv4,this._publicIpAddress=t.PublicIPv4,this._gatewayIpAddress=t.GatewayIPv4,this._macAddress=t.MAC,this._storage.Save(Rv.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;se.IsIosNative()?r=yield this.getIosControllerIpAsync(n):null!==this.nativeFindControllerApi&&(r=yield null===(e=this.nativeFindControllerApi)||void 0===e?void 0:e.FindControllerAsync(n)),null!=r&&""!=r?(this._isInLocalNetwork=!0,this._logger.Debug(Rv.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(Rv.ServiceName,"Controller not found in local network."))}else this._logger.Error(Rv.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(Rv.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return Gv(this,void 0,void 0,(function*(){if(se.IsIosNative()){const t=yield this.getIosControllerIpAsync(e);return""==t?null:t}return null!==this.nativeFindControllerApi?this.nativeFindControllerApi.FindControllerAsync(e):Promise.resolve(null)}))}GetLastKnownControllerLocalIpAddress(){return null!==this._localIpAddress?this._localIpAddress:this._storage.Read(Rv.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){return Gv(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Pv,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(Rv.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return Rv.ServiceName}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("")}}))}}Rv.ServiceName="FindControllerService";class Pv extends ce{constructor(){super(),this.Resource="/network/lan/",this.Method=le.Get}}var Uv,Ov,Mv,xv=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 Fv{SendAndHandleStreamAsync(e,t,n){return Promise.reject(new Error("Streams are not supported over local network connection."))}constructor(){this._errorOccuredEvent=new c,this._connectionStateChangedEvent=new c,this._dataReceivedEvent=new c,this._onMessageReceived=new c,this._log=hy.Get(a.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._logPackets=!0,this.socket=null,this._address=null,this._port="81",this._isOpen=!1,this._pin=void 0,this._serial=void 0,this._auth=null,this._initialized=!1,this._pingInterval=5e3,this._pingIntervalId=null,this._lastReceivedPacketTime=Date.now(),this._disconnectedOnPurpose=!1,this._restoreTask=null,hy.Get(_t.ServiceName).OnAppStateChanged().Subscribe((e=>xv(this,void 0,void 0,(function*(){var t;switch(e){case it.ExitedLowPowerMode:case it.ReturnedFromSuspension:(yield this.RestoreConnectionAsync())&&(null===(t=this._session)||void 0===t||t.RestoreSessionAsync())}}))))}Initialize(){this._initialized||(this._initialized=!0,this._controllerConfiguration=hy.Get(ct.ServiceName),this._cache=hy.Get(Be.ServiceName),this._session=hy.Get(Xe.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return xv(this,void 0,void 0,(function*(){const t=`http://${window.location.hostname}/controller_info`;let n=yield fetch(t,{method:"GET"});return!!n.ok&&(yield n.text())===`${e.SerialNumber}:${e.PIN}`}))}PingControllerAsync(){return xv(this,void 0,void 0,(function*(){var e;if((null===(e=this.socket)||void 0===e?void 0:e.readyState)!==WebSocket.OPEN)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new ce;return t.Resource="/system/ping",t.Method=le.Get,yield this.SendAndWaitForResponseAsync(t,2e3,!1,!1).then((()=>!0)).catch((()=>!1))}))}SubscribeTo(e,t){let n=n=>{n.Resource===e&&t(n)};return this.OnDataReceivedEvent().Subscribe(n),()=>this.OnDataReceivedEvent().Unsubscribe(n)}GetControllerSerialNumber(){return this._serial}GetControllerPin(){return this._pin}SetServersBrokerAddress(e){}SetDefaultPacketsBrokerAddress(e){}GetServerAddressAsync(){return hy.IsRunningFromLocalNetwork()&&(this._address=`${window.location.hostname}:${this._port}`),Promise.resolve(this._address)}ConnectAsync(e){return new Promise(((t,n)=>{this.Initialize(),this._disconnectedOnPurpose=!1,this._address=e;const r=this.socket,s=new WebSocket(`ws://${e}/api`);this.socket=s,null!==this._pingIntervalId&&(clearInterval(this._pingIntervalId),this._pingIntervalId=null),null==r||r.close(),this._log.Debug(Fv.ServiceName,`Connecting to the WebSockets server ${e}`),s.onerror=t=>{if(this.socket===s)return this._log.Debug(Fv.ServiceName,`Error occured in the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._errorOccuredEvent.Invoke(["WebSockets",t.toString()]),n(he.FailedToConnect)},s.onopen=n=>{if(this.socket===s)return this._log.Debug(Fv.ServiceName,`Connected to the WebSockets server ${e} info: \n${JSON.stringify(n)}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(pe.Connected),this._pingIntervalId=setInterval((()=>xv(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval),t(he.Connected)},s.onclose=t=>{this.socket===s&&(this._log.Debug(Fv.ServiceName,`Disconnected from the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,null!==this._pingIntervalId&&(clearInterval(this._pingIntervalId),this._pingIntervalId=null),this._connectionStateChangedEvent.Invoke(pe.Disconnected))},s.onmessage=t=>{if(this.socket===s){this._log.Debug(Fv.ServiceName,`Message received from the WebSockets server ${e}: ${t.data}`),this._onMessageReceived.Invoke(t.data);try{let e=JSON.parse(t.data);this._log.Debug(Fv.ServiceName,`Received data frame: ${e.Status}`),this._dataReceivedEvent.Invoke(e)}catch(e){this._log.Error(Fv.ServiceName,`Failed to parse message: ${t.data}`)}}},this._connectionStateChangedEvent.Invoke(pe.Connecting)}))}AuthorizeAsync(e){return xv(this,void 0,void 0,(function*(){return hy.WorksInContextOf=e.SerialNumber,!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(Fv.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,this.IsConnected()&&this._connectionStateChangedEvent.Invoke(pe.ConnectedAndAuthorized),!0)}))}ConnectAndAuthorizeAsync(e){return xv(this,void 0,void 0,(function*(){var t;hy.WorksInContextOf=e.SerialNumber,this._log.Debug(Fv.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`);let n=yield this.GetServerAddressAsync();if(null==n)return he.FailedToConnectToServer;const r=yield this.ConnectAsync(n);return r!==he.Connected?r:(yield this.AuthorizeAsync(e))?he.Connected:(null===(t=this.socket)||void 0===t||t.close(),he.AuthorizationFailed)}))}DisconnectAsync(){var e;return this._log.Debug(Fv.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._disconnectedOnPurpose=!0,this._connectionStateChangedEvent.Invoke(pe.Disconnecting),null!==this._pingIntervalId&&clearInterval(this._pingIntervalId),null===(e=this.socket)||void 0===e||e.close(),Promise.resolve()}IsConnected(){return this._isOpen}EnablePacketsLogging(){this._log.Debug(Fv.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(Fv.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(Fv.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.socket)||void 0===n||n.send(r):this._log.Error(Fv.ServiceName,`Failed to send data frame: ${r}`),this._isOpen}SendAsync(e){return this._isOpen?Promise.resolve(this.SendData(e,this._logPackets)):Promise.resolve(!1)}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!0,r)}SendAndHandleResponseAsync(e,t,n,r){return xv(this,void 0,void 0,(function*(){var s;let o=0;const i=Date.now();if(!this.IsConnected()&&!(yield this.RestoreConnectionAsync()))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)=>xv(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(Fv.ServiceName,t),a(new Error(t))}),t);let u=l=>xv(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;if((r||!0===window.packets)&&this._log.Debug(Fv.ServiceName,`Received response for: ${null==l?void 0:l.Resource} ${null==l?void 0:l.Method} id: ${null==l?void 0:l.TransactionId} in ${g}ms`),(null==l?void 0:l.Status)===ue.UserIsNotLoggedIn){this._dataReceivedEvent.Unsubscribe(u),(null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User);try{yield null===(p=this._session)||void 0===p?void 0:p.RestoreSessionAsync(),s(yield this.SendAndHandleResponseAsync(e,t,n,r))}catch(e){a(e)}return}switch(null==l?void 0:l.Status){case ue.MultiDataResponseStart:case ue.MultiDataResponse:n(l),o=c();break;case ue.MultiDataResponseStop:case ue.FatalError:case ue.Error: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 xv(this,arguments,void 0,(function*(e,t,n,r=!0,s=!0){var o,i,a;if(e.Method===le.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()&&!(yield this.RestoreConnectionAsync()))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)=>xv(this,void 0,void 0,(function*(){let a=l=>xv(this,void 0,void 0,(function*(){var d,h,p,g;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(c),this._dataReceivedEvent.Unsubscribe(a);const f=Date.now()-u;if(s&&this._log.Debug(Fv.ServiceName,`Received response for: ${null==l?void 0:l.Resource} ${null==l?void 0:l.Method} id: ${null==l?void 0:l.TransactionId} in ${f}ms`),e.Method===le.Get&&n&&(null==l?void 0:l.Status)!==ue.UserIsNotLoggedIn&&(null===(d=this._cache)||void 0===d||d.Cache(l)),(null==l?void 0:l.Status)===ue.UserIsNotLoggedIn&&r){(null===(h=this._session)||void 0===h?void 0:h.OnUserLoggedOutEvent()).Invoke(null===(p=this._session)||void 0===p?void 0:p.User);try{yield null===(g=this._session)||void 0===g?void 0:g.RestoreSessionAsync(),o(yield this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!1,s))}catch(e){i(e)}return}o(l)}}));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(Fv.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 Fv.ServiceName}RestoreConnectionAsync(){return xv(this,void 0,void 0,(function*(){return!this._disconnectedOnPurpose&&(this._restoreTask||(this._restoreTask=(()=>xv(this,void 0,void 0,(function*(){const e=this._auth;if(null==e)return!1;if(this.IsConnected())return this.AuthorizeAsync(e);const t=yield this.GetServerAddressAsync();return null!=t&&((yield this.ConnectAsync(t))===he.Connected&&this.AuthorizeAsync(e))})))().finally((()=>{this._restoreTask=null}))),this._restoreTask)}))}}Fv.ServiceName="ExalusConnectionService";class Lv{constructor(){var e,t;this.OnEnteredPictureInPicture=new ke,this.OnExitedPictureInPicture=new ke,this._nativeApi=null,this.IsSupported()?(this._nativeApi=navigator.pip,null===(e=this._nativeApi)||void 0===e||e.OnEnteredPictureInPicture.Subscribe((()=>this.OnEnteredPictureInPicture.Invoke())),null===(t=this._nativeApi)||void 0===t||t.OnExitedPictureInPicture.Subscribe((()=>this.OnExitedPictureInPicture.Invoke()))):navigator.pip=null}IsSupported(){return void 0!==navigator.pip&&null!==navigator.pip}RequestPictureInPictureAsync(){return this.IsSupported()?this._nativeApi.RequestPictureInPictureAsync():Promise.resolve(!1)}GetServiceName(){return Lv.ServiceName}}Lv.ServiceName="PictureInPictureService",(Mv=Uv||(Uv={}))[Mv.Unknown=-1]="Unknown",Mv[Mv.Web=0]="Web",Mv[Mv.Android=1]="Android",Mv[Mv.iOS=2]="iOS";class Bv{constructor(){this.ClientName="",this.LavvaUserName="",this.ClientType=Uv.Unknown,this.TokenGuid="",this.Token="",this.RegistrationDate=new Date}}!function(e){e.FeatureUnsupported="FeatureUnsupported",e.UnknownError="UnknownError",e.NoData="NoData",e.IncorrectGuid="IncorrectGuid",e.IdentityIsEmpty="IdentityIsEmpty",e.DeviceTokenIsEmpty="DeviceTokenIsEmpty",e.ClientNameIsEmpty="ClientNameIsEmpty",e.LavvaUserNameIsEmpty="LavvaUserNameIsEmpty",e.TokenNotFound="TokenNotFound",e.TokensNotFoundForLavvaUser="TokensNotFoundForLavvaUser"}(Ov||(Ov={}));var $v=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 Wv{constructor(){this._connection=hy.Get(It.ServiceName),this._logger=hy.Get(a.ServiceName)}GetServiceName(){return Wv.ServiceName}RegisterNotificationsClientAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=new Vv({ClientName:e.ClientName,DeviceToken:e.DeviceToken,LavvaUserName:e.LavvaUserName,ClientType:this.getClientType(),NotificationsEnabledForToken:e.EnableNotifications}),r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,8e3,!1);if(null==r||null==r.Status)return new Ee(Ov.UnknownError,"Cannot register notifications client - unknown error!");switch(r.Status){case ue.WrongData:{const e=this.isValidErrorCode(r.Data)?r.Data:Ov.UnknownError;return new Ee(e,"Cannot register notifications client - wrong data!")}case ue.ResourceDoesNotExists:return new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!");case ue.OK:return"string"==typeof r.Data?r.Data:new Ee(Ov.NoData,"Cannot register notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ee(Ov.UnknownError,"Cannot register notifications client - unknown error!")}}catch(e){return new Ee(Ov.UnknownError,`Cannot register notifications client - error: ${e}`)}}))}UpdateNotificationsClientAsync(e,t){return $v(this,void 0,void 0,(function*(){var n;try{const r=new qv({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 Ee(Ov.UnknownError,"Cannot update notifications client - unknown error!");switch(s.Status){case ue.WrongData:{const e=this.isValidErrorCode(s.Data)?s.Data:Ov.UnknownError;return new Ee(e,"Cannot update notifications client - wrong data!")}case ue.ResourceDoesNotExists:return new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!");case ue.OK:return"string"==typeof s.Data?s.Data==e?ue.OK:new Ee(Ov.UnknownError,`Cannot update notifications client - result status is OK, but token guid is different! request guid ${e}, response guid: ${s.Data}`):new Ee(Ov.NoData,"Cannot update notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ee(Ov.UnknownError,"Cannot update notifications client - unknown error!")}}catch(e){return this._logger.Error(`Cannot update notifications client - error: ${e}`),new Ee(Ov.UnknownError,`Cannot update notifications client - error: ${e}`)}}))}GetRegisteredNotificationsClientsMetadataAsync(e){return $v(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Hv,8e3,!1);return null==t||null==t.Status?new Ee(Ov.UnknownError,"Cannot get notifications clients metadata - unknown error!"):t.Status==ue.ResourceDoesNotExists?new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!"):t.Status!=ue.OK?new Ee(Ov.UnknownError,`Cannot get notifications clients metadata - response status: ${t.Status}}`):null==t.Data?new Ee(Ov.NoData,"Cannot get notifications clients metadata - response status is OK, but no data!"):t.Data.map((e=>{const t=new Bv;return t.ClientName=e.ClientName,t.LavvaUserName=e.LavvaUserName,t.ClientType=e.ClientType,t.TokenGuid=e.TokenGuid,t.Token=e.Token,t.RegistrationDate=new Date(e.RegistrationDate),t}))}catch(e){return this._logger.Error(`Cannot get notifications clients metadata - error: ${e}`),new Ee(Ov.UnknownError,`Cannot get notifications clients metadata - error: ${e}`)}}))}IsNotificationsEnabledForAllUserTokensAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Yv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Ov.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Ov.UnknownError;return new Ee(e,"Cannot get notifications status!")}case ue.OK:return"boolean"==typeof n.Data?n.Data:new Ee(Ov.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ee(Ov.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ee(Ov.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}IsNotificationsEnabledAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Kv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Ov.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:if(null==n.Data)return new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Ov.UnknownError;return new Ee(e,"Cannot get notifications status - resource not exists!")}case ue.OK:return"boolean"==typeof n.Data?n.Data:new Ee(Ov.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ee(Ov.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ee(Ov.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}EnableNotificationsAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new jv(n),8e3,!1);if(null==r||null==r.Status)return new Ee(Ov.UnknownError,"Cannot enable notifications - unknown error!");switch(r.Status){case ue.ResourceDoesNotExists:if(null==r.Data)return new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Ov.UnknownError;return new Ee(e,"Cannot enable notifications - resource not exists!")}case ue.OK:return ue.OK;default:return new Ee(Ov.UnknownError,`Cannot enable notifications - response code ${r.Status}}!`)}}catch(e){return this._logger.Error(`Cannot enable notifications - error: ${e}`),new Ee(Ov.UnknownError,`Cannot enable notifications - error: ${e}`)}}))}EnableNotificationsForAllUserTokensAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Jv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Ov.UnknownError,"Cannot enable notifications - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Ov.UnknownError;return new Ee(e,"Cannot enable notifications!")}case ue.OK:return ue.OK;default:return new Ee(Ov.UnknownError,`Cannot enable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot enable notifications for lavva user ${e} - error: ${t}`),new Ee(Ov.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DisableNotificationsAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new zv(n),8e3,!1);if(null==r||null==r.Status)return new Ee(Ov.UnknownError,"Cannot disable notifications - unknown error!");switch(r.Status){case ue.ResourceDoesNotExists:if(null==r.Data)return new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:Ov.UnknownError;return new Ee(e,"Cannot disable notifications - resource not exists!")}case ue.OK:return ue.OK;default:return new Ee(Ov.UnknownError,`Cannot disable notifications - response code ${r.Status}!`)}}catch(e){return this._logger.Error(`Cannot disable notifications - error: ${e}`),new Ee(Ov.UnknownError,`Cannot disable notifications - error: ${e}`)}}))}DisableNotificationsForAllUserTokensAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Xv(e),8e3,!1);if(null==n||null==n.Status)return new Ee(Ov.UnknownError,"Cannot disable notifications - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ee(Ov.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:Ov.UnknownError;return new Ee(e,"Cannot disable notifications!")}case ue.OK:return ue.OK;default:return new Ee(Ov.UnknownError,`Cannot disable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot disable notifications for lavva user ${e} - error: ${t}`),new Ee(Ov.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DeleteNotificationsTokenAsync(e){return $v(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Qv(e),8e3,!1);return null==n||null==n.Status?new Ee(Ov.UnknownError,"Cannot delete notifications token - unknown error!"):n.Status==ue.OK?ue.OK:new Ee(Ov.UnknownError,`Cannot delete notifications token - response code ${n.Status}!`)}catch(e){return this._logger.Error(`Cannot delete notifications token - error: ${e}`),new Ee(Ov.UnknownError,`Cannot delete notifications token - error: ${e}`)}}))}getClientType(){return se.IsIosNative()?Uv.iOS:navigator.userAgent.endsWith("LavvaAndroidNative")?Uv.Android:Uv.Web}isValidErrorCode(e){return Object.values(Ov).includes(e)}}Wv.ServiceName="NotificationsService";class Vv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Post,this.Data=e}}class qv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Put,this.Data=e}}class Hv extends ce{constructor(){super(),this.Resource="/notifications/tokens/metadata",this.Method=le.Get}}class Kv extends ce{constructor(e){super(),this.Resource="/notifications/status",this.Method=le.Get,this.Data={TokenIdentity:e}}}class jv extends ce{constructor(e){super(),this.Resource="/notifications/enable",this.Method=le.Post,this.Data=e}}class zv extends ce{constructor(e){super(),this.Resource="/notifications/disable",this.Method=le.Post,this.Data=e}}class Jv extends ce{constructor(e){super(),this.Resource="/notifications/enable/for/lavva/user",this.Method=le.Post,this.Data=e}}class Xv extends ce{constructor(e){super(),this.Resource="/notifications/disable/for/lavva/user",this.Method=le.Post,this.Data=e}}class Yv extends ce{constructor(e){super(),this.Resource="/notifications/status/for/lavva/user",this.Method=le.Get,this.Data=e}}class Qv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Delete,this.Data=e}}class Zv{CheckLocationPermissionAsync(){return this.IsAndroidLocationAvailable()?navigator.AndroidLocation.CheckLocationPermissionAsync():Promise.resolve(!1)}RequestLocationPermissionAsync(){return this.IsAndroidLocationAvailable()?navigator.AndroidLocation.RequestLocationPermissionAsync():Promise.resolve(!1)}IsAndroidLocationAvailable(){return void 0!==navigator.AndroidLocation}GetServiceName(){return Zv.ServiceName}}Zv.ServiceName="AndroidLocationService";class ey{IsAndroidNotificationsAvailable(){return void 0!==navigator.AndroidNotifications}CheckNotificationPermissionAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.CheckNotificationPermissionAsync():Promise.resolve(!1)}RequestNotificationPermissionAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.RequestNotificationPermissionAsync():Promise.resolve(!1)}GetDeviceFirebaseTokenAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.GetDeviceFirebaseTokenAsync():Promise.resolve(null)}GetNotificationsQueueAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.GetNotificationsQueueAsync():Promise.resolve(null)}GetServiceName(){return ey.ServiceName}}ey.ServiceName="AndroidNotificationsService";class ty{OpenRateDialogAsync(){if(se.IsIosNative())try{if(null!=window.webkit.messageHandlers.rateApp)return window.webkit.messageHandlers.rateApp.postMessage(!0),Promise.resolve()}catch(e){return Promise.reject(new Error(`Rate dialog is not available on this platform. Error: ${e}`))}else if(this.IsAvailable())return navigator.AndroidAppRate.OpenRateDialogAsync();return Promise.reject(new Error("AppRateService is not available on this platform."))}IsAvailable(){var e,t;return void 0!==navigator.AndroidAppRate||void 0!==(null===(t=null===(e=window.webkit)||void 0===e?void 0:e.messageHandlers)||void 0===t?void 0:t.rateApp)}GetServiceName(){return ty.ServiceName}}ty.ServiceName="AppRateService";class ny{GetCurrentLocalesAsync(){return this.IsAvailable()?navigator.AppLocales.GetCurrentLocalesAsync():Promise.resolve(void 0)}SetCurrentLocalesAsync(e){if(!this.IsAvailable())throw new Error("AppLocalesService is not available");return navigator.AppLocales.SetCurrentLocalesAsync(e)}IsAvailable(){var e,t;return void 0!==navigator.AppLocales||void 0!==(null===(t=null===(e=window.webkit)||void 0===e?void 0:e.messageHandlers)||void 0===t?void 0:t.appLocales)}GetServiceName(){return ny.ServiceName}}ny.ServiceName="AppLocalesService";var ry,sy=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())}))};!function(e){e[e.Lavva=0]="Lavva",e[e.Wisniowski=1]="Wisniowski",e[e.ExalusHome=2]="ExalusHome"}(ry||(ry={}));class oy{GetServiceName(){return oy.ServiceName}SetInstallation(e){return sy(this,void 0,void 0,(function*(){if(void 0===e.InstallationId||void 0===e.InstallationType)return Promise.reject(new Error("Invalid installation info, all fields are required"));if(e.InstallationType!=ry.ExalusHome&&void 0===e.BrokerUrl)return Promise.reject(new Error("Broker url is required for non-ExalusHome installations"));if(hy.Get(a.ServiceName).Info(oy.ServiceName,`Setting Android Auto/CarPlay installation: ${e.InstallationType} (${e.InstallationId}) broker: ${e.BrokerUrl}`),!(this.IsAndroidAutoAvailable()||se.IsIosNative()&&null!=window.webkit.messageHandlers.carPlay))return hy.Get(a.ServiceName).Warning(oy.ServiceName,"Android Auto/CarPlay is not available on this platform!"),Promise.resolve();if(e.InstallationType===ry.ExalusHome){let t=hy.Get(It.ServiceName);e.ControllerSerial=t.GetControllerSerialNumber(),e.ControllerPin=t.GetControllerPin();let n=yield t.GetServerAddressAsync();null!==n&&(n.includes("dev-")?e.BrokerUrl="dev-broker.tr7.pl:4431":e.BrokerUrl="services-broker.tr7.pl");try{let t=yield this.GetTokenFromController();t?e.AuthToken=t:hy.Get(a.ServiceName).Warning(oy.ServiceName,"Failed to get auth token from controller, Android Auto/CarPlay integration might not work properly!")}catch(e){hy.Get(a.ServiceName).Error(oy.ServiceName,"Error while getting auth token from controller, Android Auto/CarPlay integration might not work properly! \n"+e)}}if(this.IsAndroidAutoAvailable())navigator.AndroidAuto.SetInstallation(e);else{if(!se.IsIosNative()||null==window.webkit.messageHandlers.carPlay)return Promise.reject(new Error("Android Auto/CarPlay is not available"));window.webkit.messageHandlers.carPlay.postMessage(e)}return Promise.resolve()}))}GetTokenFromController(){return sy(this,void 0,void 0,(function*(){var e;if(this.IsAndroidAutoAvailable()||se.IsIosNative()&&null!=window.webkit.messageHandlers.carPlay){let t=yield hy.Get(It.ServiceName).SendAndWaitForResponseAsync(new iy,12e3,!1);if((null==t?void 0:t.Status)===ue.OK)return Promise.resolve((null===(e=null==t?void 0:t.Data)||void 0===e?void 0:e.Token)||null)}return Promise.resolve(null)}))}IsAndroidAutoAvailable(){return void 0!==navigator.AndroidAuto}ClearInstallation(){return this.IsAndroidAutoAvailable()&&navigator.AndroidAuto.SetInstallation(null),se.IsIosNative()&&null!=window.webkit.messageHandlers.carPlay?(window.webkit.messageHandlers.carPlay.postMessage(null),Promise.resolve()):Promise.reject(new Error("Android Auto/CarPlay is not available"))}}oy.ServiceName="AndroidAutoCarPlayService";class iy extends ce{constructor(){super(),this.Resource="/webapibridge/get-token",this.Method=le.Get}}var ay=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 cy{constructor(){this._connection=hy.Get(It.ServiceName)}GetServiceName(){return cy.ServiceName}isHomeKitPairingStatusResponse(e){return"object"==typeof e&&null!==e&&"Paired"in e&&"boolean"==typeof e.Paired}GetPairingStatusAsync(){return ay(this,void 0,void 0,(function*(){const e=new ly,t=yield this._connection.SendAndWaitForResponseAsync(e,5e3,!1);if(t.Status!==ue.OK)return t.Status;const n=new uy;return this.isHomeKitPairingStatusResponse(t.Data)&&(n.Paired=t.Data.Paired),n}))}IsPairedAsync(){return ay(this,void 0,void 0,(function*(){const e=yield this.GetPairingStatusAsync();return this.isHomeKitPairingStatusResponse(e)?e.Paired:e}))}ResetPairingAsync(){return ay(this,void 0,void 0,(function*(){const e=new dy;return(yield this._connection.SendAndWaitForResponseAsync(e,5e3,!1)).Status}))}}cy.ServiceName="HomeKitService";class uy{constructor(){this.Paired=!1}}class ly extends ce{constructor(){super(),this.Resource="/homekit/pairing/status",this.Method=le.Get}}class dy extends ce{constructor(){super(),this.Resource="/homekit/pairing/reset",this.Method=le.Post}}fu(Map),fu(Set),(()=>{const e=String.prototype,t=Object.getOwnPropertyNames(_i.prototype);for(const n of t)e[n]=e[n]??_i.prototype[n];e.first=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}throw new mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[0]},e.firstOrDefault=function(e){if(e){for(let t=0;t<this.length;t++){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[0]},e.count=function(e){if(e){let t=0;for(let n=0;n<this.length;n++)!0===e(this[n])&&t++;return t}return this.length},e.elementAt=function(e){if(e<0||e>=this.length)throw new vi("index");return this[e]},e.elementAtOrDefault=function(e){return this[e]||null},e.last=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}throw new mi(yi.NoMatch)}if(0===this.length)throw new mi(yi.NoElements);return this[this.length-1]},e.lastOrDefault=function(e){if(e){for(let t=this.length-1;t>=0;t--){const n=this[t];if(!0===e(n))return n}return null}return 0===this.length?null:this[this.length-1]},e.reverse=function(){const e=this;return new _i((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),mg(Array),mg(Int8Array),mg(Int16Array),mg(Int32Array),mg(Uint8Array),mg(Uint8ClampedArray),mg(Uint16Array),mg(Uint32Array),mg(Float32Array),mg(Float64Array);class hy{static Init(){if(u.IsInitialized)return;console.log("Initializing DependencyContainer");let e=u.Instance;try{e.RegisterService(new Nv),e.RegisterService(new l),e.RegisterService(new _t),e.RegisterService(new Be),e.RegisterService(new Xe),e.RegisterService(new Lv),e.RegisterService(new ty),e.RegisterService(new ny),hy.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new Fv)):e.RegisterService(new It),e.RegisterService(new Zv),e.RegisterService(new oy),e.RegisterService(new ey),e.RegisterService(new Ds),e.RegisterService(new Os),e.RegisterService(new ct),e.RegisterService(new Rv),e.RegisterService(new As),e.RegisterService(new nt),e.RegisterService(new Ge),e.RegisterService(new We),e.RegisterService(new Yo),e.RegisterService(new Ug),e.RegisterService(new ao),e.RegisterService(new ff),e.RegisterService(new Tv),e.RegisterService(new Hf),e.RegisterService(new Lo),e.RegisterService(new Av),e.RegisterService(new Wv),e.RegisterService(new cy)}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.")||e.startsWith("172.16.")}static GetAsync(e,t){return u.Instance.GetServiceAsync(e,t)}static GetWithTimeoutAsync(e,t){return u.Instance.GetServiceWithTimeoutAsync(e,t)}static Get(e){return u.Instance.GetService(e)}static SleepForAsync(e){return new Promise((t=>setTimeout(t,e)))}static ExportStringAsFileToDownload(e,t){const n=new Blob([t],{type:"text/plain"}),r=document.createElement("a"),s=window.URL.createObjectURL(n);return r.href=s,r.download=e,r}}hy.WorksInContextOf="",hy.Version=1})();
|
|
1
|
+
(()=>{"use strict";var e,t,n,r,s,o,i={d:(e,t)=>{for(var n in t)i.o(t,n)&&!i.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})}};i.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),i.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),i.d({},{j:()=>gy}),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 a{constructor(){this._blockedServices=[],this._logLevel=e.Debug;const t=globalThis;void 0!==t.loglevel&&null!==t.loglevel&&(this._logLevel=t.loglevel),t.logger=this}EnableStackTrace(){a.DoesThrowStackTrace=!0}DisableStackTrace(){a.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(a.ServiceName,`Disabling logs from ${e}`)}EnableLogsFrom(e){this._blockedServices.any((t=>t==e))&&(this._blockedServices=this._blockedServices.where((t=>t!=e)).toArray()),this.Debug(a.ServiceName,`Enaabling logs from ${e}`)}get LogLevel(){return this._logLevel}set LogLevel(e){this._logLevel=e}GetServiceName(){return a.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}`):a.DoesThrowStackTrace||!0===globalThis.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}`)))}}a.ServiceName="LoggerService",a.DoesThrowStackTrace=!1;class c{constructor(){this.handlers=[]}Subscribe(e){this.handlers.includes(e)||this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(e){this.handlers.slice(0).forEach((t=>{var n;try{t(e)}catch(e){null===(n=u.Log)||void 0===n||n.Error(e)}}))}}class u{constructor(){this._services=new Map,this._serviceRegistrationEvent=new c,this._pendingResolutions=new Map,this._nextResolutionId=1}static get Timers(){return globalThis}static get Instance(){const e=globalThis;if(e.__dc_instance)return e.__dc_instance;const t=new u;return e.__dc_instance=t,"undefined"==typeof window||window.LavvaDI||(window.appservices=t),this.Log=new a,this.Log.Warning(u.ServiceName,"Initializing DependencyContainer"),t.RegisterService(this.Log),this.IsInitialized=!0,t}RegisterService(e){var t;const n=e.GetServiceName();this._services.has(n)&&(null===(t=u.Log)||void 0===t||t.Warning(u.ServiceName,`Service "${n}" is being re-registered and the previous instance will be overwritten.`)),this._services.set(n,e),this._serviceRegistrationEvent.Invoke(e)}GetService(e){return this._services.get(e)}GetServiceAsync(e,t){var n,r;if(this._services.has(e))return null===(n=u.Log)||void 0===n||n.Debug(u.ServiceName,`Resolved service "${e}" immediately.`),Promise.resolve(this._services.get(e));const s=this.CreatePendingResolution(e);return this._pendingResolutions.set(s.Id,s),null===(r=u.Log)||void 0===r||r.Debug(u.ServiceName,`Waiting for service "${e}" (request #${s.Id}). Registered services: ${this.GetRegisteredServiceNamesForLogs()}.`),new Promise(((n,r)=>{const o=r=>{var a;if(r.GetServiceName()===e&&this.TryCompleteResolution(s.Id)){this._serviceRegistrationEvent.Unsubscribe(o),null==t||t.CancellationEvent.Unsubscribe(i);const c=Date.now()-s.StartedAt;null===(a=u.Log)||void 0===a||a.Info(u.ServiceName,`Resolved service "${e}" after ${c}ms (request #${s.Id}).`),n(r)}},i=()=>{var t;if(this._serviceRegistrationEvent.Unsubscribe(o),!this.TryCompleteResolution(s.Id))return;const n=Date.now()-s.StartedAt;null===(t=u.Log)||void 0===t||t.Warning(u.ServiceName,`Cancelled waiting for service "${e}" after ${n}ms (request #${s.Id}).`),r(new Error("cancelled"))};null==t||t.CancellationEvent.Subscribe(i),this._serviceRegistrationEvent.Subscribe(o)}))}GetServiceWithTimeoutAsync(e,t){var n,r;if(this._services.has(e))return null===(n=u.Log)||void 0===n||n.Debug(u.ServiceName,`Resolved service "${e}" immediately.`),Promise.resolve(this._services.get(e));const s=this.CreatePendingResolution(e);return this._pendingResolutions.set(s.Id,s),null===(r=u.Log)||void 0===r||r.Debug(u.ServiceName,`Waiting for service "${e}" with timeout ${t}ms (request #${s.Id}). Registered services: ${this.GetRegisteredServiceNamesForLogs()}.`),new Promise(((n,r)=>{const o=t=>{var r;if(t.GetServiceName()===e&&this.TryCompleteResolution(s.Id)){u.Timers.clearTimeout(i),this._serviceRegistrationEvent.Unsubscribe(o);const a=Date.now()-s.StartedAt;null===(r=u.Log)||void 0===r||r.Info(u.ServiceName,`Resolved service "${e}" after ${a}ms (request #${s.Id}).`),n(t)}},i=u.Timers.setTimeout((()=>{var t;if(this._serviceRegistrationEvent.Unsubscribe(o),!this.TryCompleteResolution(s.Id))return;const n=Date.now()-s.StartedAt;null===(t=u.Log)||void 0===t||t.Warning(u.ServiceName,`Timeout waiting for service "${e}" after ${n}ms (request #${s.Id}). Registered services: ${this.GetRegisteredServiceNamesForLogs()}.`),r(new Error(`timeout waiting for "${e}"`))}),t);this._serviceRegistrationEvent.Subscribe(o)}))}CreatePendingResolution(e){return{Id:this._nextResolutionId++,ServiceName:e,StartedAt:Date.now()}}TryCompleteResolution(e){return this._pendingResolutions.delete(e)}GetRegisteredServiceNamesForLogs(){const e=[...this._services.keys()].sort();return 0===e.length?"<none>":e.join(", ")}}u.ServiceName="DependencyContainer",u.IsInitialized=!1;class l{GetServiceName(){return l.ServiceName}GetResourceName(e,t){return`_exalus_${gy.WorksInContextOf}_${e}_${t}`}Remove(e,t){localStorage.removeItem(this.GetResourceName(e,t))}DropStorage(e){const t=`_exalus_${gy.WorksInContextOf}_${e}`;Object.keys(localStorage).filter((e=>e.startsWith(t))).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(l.ServiceName,`Clearing API cache for key: ${e}`),localStorage.removeItem(e)}))}Save(e,t,n){localStorage.setItem(this.GetResourceName(e,t),JSON.stringify(n))}Read(e,t){var n;try{let n=this.GetResourceName(e,t),r=localStorage.getItem(n);return null==r?null:JSON.parse(r)}catch(r){return null===(n=u.Log)||void 0===n||n.Error(l.ServiceName,`Exception has occurred while reading ${this.GetResourceName(e,t)}`),null}}}l.ServiceName="LocalStorageService",function(e){e[e.None=0]="None",e[e.WebSockets=1]="WebSockets",e[e.ServerSentEvents=2]="ServerSentEvents",e[e.LongPolling=4]="LongPolling"}(t||(t={})),function(e){e[e.Text=1]="Text",e[e.Binary=2]="Binary"}(n||(n={})),function(e){e[e.Trace=0]="Trace",e[e.Debug=1]="Debug",e[e.Information=2]="Information",e[e.Warning=3]="Warning",e[e.Error=4]="Error",e[e.Critical=5]="Critical",e[e.None=6]="None"}(r||(r={}));class d{static write(e){return`${e}${d.RecordSeparator}`}static parse(e){if(e[e.length-1]!==d.RecordSeparator)throw new Error("Message is incomplete.");const t=e.split(d.RecordSeparator);return t.pop(),t}}d.RecordSeparatorCode=30,d.RecordSeparator=String.fromCharCode(d.RecordSeparatorCode);class h{constructor(){}log(e,t){}}h.instance=new h;class p{static isRequired(e,t){if(null==e)throw new Error(`The '${t}' argument is required.`)}static isNotEmpty(e,t){if(!e||e.match(/^\s*$/))throw new Error(`The '${t}' argument should not be empty.`)}static isIn(e,t,n){if(!(e in t))throw new Error(`Unknown ${n} value: ${e}.`)}}class g{static get isBrowser(){return!g.isNode&&"object"==typeof window&&"object"==typeof window.document}static get isWebWorker(){return!g.isNode&&"object"==typeof self&&"importScripts"in self}static get isReactNative(){return!g.isNode&&"object"==typeof window&&void 0===window.document}static get isNode(){return"undefined"!=typeof process&&process.release&&"node"===process.release.name}}function f(e,t){let n="";return v(e)?(n=`Binary data of length ${e.byteLength}`,t&&(n+=`. Content: '${function(e){const t=new Uint8Array(e);let n="";return t.forEach((e=>{n+=`0x${e<16?"0":""}${e.toString(16)} `})),n.substr(0,n.length-1)}(e)}'`)):"string"==typeof e&&(n=`String data of length ${e.length}`,t&&(n+=`. Content: '${e}'`)),n}function v(e){return e&&"undefined"!=typeof ArrayBuffer&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}async function y(e,t,n,s,o,i){const a={},[c,u]=S();a[c]=u,e.log(r.Trace,`(${t} transport) sending data. ${f(o,i.logMessageContent)}.`);const l=v(o)?"arraybuffer":"text",d=await n.post(s,{content:o,headers:{...a,...i.headers},responseType:l,timeout:i.timeout,withCredentials:i.withCredentials});e.log(r.Trace,`(${t} transport) request complete. Response status: ${d.statusCode}.`)}class m{constructor(e,t){this._subject=e,this._observer=t}dispose(){const e=this._subject.observers.indexOf(this._observer);e>-1&&this._subject.observers.splice(e,1),0===this._subject.observers.length&&this._subject.cancelCallback&&this._subject.cancelCallback().catch((e=>{}))}}class w{constructor(e){this._minLevel=e,this.out=console}log(e,t){if(e>=this._minLevel){const n=`[${(new Date).toISOString()}] ${r[e]}: ${t}`;switch(e){case r.Critical:case r.Error:this.out.error(n);break;case r.Warning:this.out.warn(n);break;case r.Information:this.out.info(n);break;default:this.out.log(n)}}}}function S(){let e="X-SignalR-User-Agent";return g.isNode&&(e="User-Agent"),[e,A("8.0.7",_(),g.isNode?"NodeJS":"Browser",C())]}function A(e,t,n,r){let 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 _(){if(!g.isNode)return"";switch(process.platform){case"win32":return"Windows NT";case"darwin":return"macOS";case"linux":return"Linux";default:return process.platform}}function C(){if(g.isNode)return process.versions.node}function T(e){return e.stack?e.stack:e.message?e.message:`${e}`}class D{writeHandshakeRequest(e){return d.write(JSON.stringify(e))}parseHandshakeResponse(e){let t,n;if(v(e)){const r=new Uint8Array(e),s=r.indexOf(d.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(d.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=d.parse(t),s=JSON.parse(r[0]);if(s.type)throw new Error("Expected a handshake response from the server.");return[n,s]}}class k extends Error{constructor(e,t){const n=new.target.prototype;super(`${e}: Status code '${t}'`),this.statusCode=t,this.__proto__=n}}class I extends Error{constructor(e="A timeout occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class E extends Error{constructor(e="An abort occurred."){const t=new.target.prototype;super(e),this.__proto__=t}}class b extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="UnsupportedTransportError",this.__proto__=n}}class N extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="DisabledTransportError",this.__proto__=n}}class G extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.transport=t,this.errorType="FailedToStartTransportError",this.__proto__=n}}class R extends Error{constructor(e){const t=new.target.prototype;super(e),this.errorType="FailedToNegotiateWithServerError",this.__proto__=t}}class P extends Error{constructor(e,t){const n=new.target.prototype;super(e),this.innerErrors=t,this.__proto__=n}}!function(e){e[e.Invocation=1]="Invocation",e[e.StreamItem=2]="StreamItem",e[e.Completion=3]="Completion",e[e.StreamInvocation=4]="StreamInvocation",e[e.CancelInvocation=5]="CancelInvocation",e[e.Ping=6]="Ping",e[e.Close=7]="Close",e[e.Ack=8]="Ack",e[e.Sequence=9]="Sequence"}(s||(s={}));class U{constructor(){this.observers=[]}next(e){for(const t of this.observers)t.next(e)}error(e){for(const t of this.observers)t.error&&t.error(e)}complete(){for(const e of this.observers)e.complete&&e.complete()}subscribe(e){return this.observers.push(e),new m(this,e)}}class O{constructor(e,t,n){this._bufferSize=1e5,this._messages=[],this._totalMessageCount=0,this._waitForSequenceMessage=!1,this._nextReceivingSequenceId=1,this._latestReceivedSequenceId=0,this._bufferedByteCount=0,this._reconnectInProgress=!1,this._protocol=e,this._connection=t,this._bufferSize=n}async _send(e){const t=this._protocol.writeMessage(e);let n=Promise.resolve();if(this._isInvocationMessage(e)){this._totalMessageCount++;let e=()=>{},r=()=>{};v(t)?this._bufferedByteCount+=t.byteLength:this._bufferedByteCount+=t.length,this._bufferedByteCount>=this._bufferSize&&(n=new Promise(((t,n)=>{e=t,r=n}))),this._messages.push(new M(t,this._totalMessageCount,e,r))}try{this._reconnectInProgress||await this._connection.send(t)}catch{this._disconnected()}await n}_ack(e){let t=-1;for(let n=0;n<this._messages.length;n++){const r=this._messages[n];if(r._id<=e.sequenceId)t=n,v(r._message)?this._bufferedByteCount-=r._message.byteLength:this._bufferedByteCount-=r._message.length,r._resolver();else{if(!(this._bufferedByteCount<this._bufferSize))break;r._resolver()}}-1!==t&&(this._messages=this._messages.slice(t+1))}_shouldProcessMessage(e){if(this._waitForSequenceMessage)return e.type===s.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:s.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 s.Invocation:case s.StreamItem:case s.Completion:case s.StreamInvocation:case s.CancelInvocation:return!0;case s.Close:case s.Sequence:case s.Ping:case s.Ack:return!1}}_ackTimer(){void 0===this._ackTimerHandle&&(this._ackTimerHandle=setTimeout((async()=>{try{this._reconnectInProgress||await this._connection.send(this._protocol.writeMessage({type:s.Ack,sequenceId:this._latestReceivedSequenceId}))}catch{}clearTimeout(this._ackTimerHandle),this._ackTimerHandle=void 0}),1e3))}}class M{constructor(e,t,n,r){this._message=e,this._id=t,this._resolver=n,this._rejector=r}}!function(e){e.Disconnected="Disconnected",e.Connecting="Connecting",e.Connected="Connected",e.Disconnecting="Disconnecting",e.Reconnecting="Reconnecting"}(o||(o={}));class x{static create(e,t,n,r,s,o,i){return new x(e,t,n,r,s,o,i)}constructor(e,t,n,i,a,c,u){this._nextKeepAlive=0,this._freezeEventListener=()=>{this._logger.log(r.Warning,"The page is being frozen, this will likely lead to the connection being closed and messages being lost. For more information see the docs at https://learn.microsoft.com/aspnet/core/signalr/javascript-client#bsleep")},p.isRequired(e,"connection"),p.isRequired(t,"logger"),p.isRequired(n,"protocol"),this.serverTimeoutInMilliseconds=null!=a?a:3e4,this.keepAliveIntervalInMilliseconds=null!=c?c:15e3,this._statefulReconnectBufferSize=null!=u?u:1e5,this._logger=t,this._protocol=n,this.connection=e,this._reconnectPolicy=i,this._handshakeProtocol=new D,this.connection.onreceive=e=>this._processIncomingData(e),this.connection.onclose=e=>this._connectionClosed(e),this._callbacks={},this._methods={},this._closedCallbacks=[],this._reconnectingCallbacks=[],this._reconnectedCallbacks=[],this._invocationId=0,this._receivedHandshakeResponse=!1,this._connectionState=o.Disconnected,this._connectionStarted=!1,this._cachedPingMessage=this._protocol.writeMessage({type:s.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!==o.Disconnected&&this._connectionState!==o.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!==o.Disconnected)return Promise.reject(new Error("Cannot start a HubConnection that is not in the 'Disconnected' state."));this._connectionState=o.Connecting,this._logger.log(r.Debug,"Starting HubConnection.");try{await this._startInternal(),g.isBrowser&&window.document.addEventListener("freeze",this._freezeEventListener),this._connectionState=o.Connected,this._connectionStarted=!0,this._logger.log(r.Debug,"HubConnection connected successfully.")}catch(e){return this._connectionState=o.Disconnected,this._logger.log(r.Debug,`HubConnection failed to start successfully because of error '${e}'.`),Promise.reject(e)}}async _startInternal(){this._stopDuringStartError=void 0,this._receivedHandshakeResponse=!1;const e=new Promise(((e,t)=>{this._handshakeResolver=e,this._handshakeRejecter=t}));await this.connection.start(this._protocol.transferFormat);try{let t=this._protocol.version;this.connection.features.reconnect||(t=1);const n={protocol:this._protocol.name,version:t};if(this._logger.log(r.Debug,"Sending handshake request."),await this._sendMessage(this._handshakeProtocol.writeHandshakeRequest(n)),this._logger.log(r.Information,`Using HubProtocol '${this._protocol.name}'.`),this._cleanupTimeout(),this._resetTimeoutPeriod(),this._resetKeepAliveInterval(),await e,this._stopDuringStartError)throw this._stopDuringStartError;!!this.connection.features.reconnect&&(this._messageBuffer=new O(this._protocol,this.connection,this._statefulReconnectBufferSize),this.connection.features.disconnected=this._messageBuffer._disconnected.bind(this._messageBuffer),this.connection.features.resend=()=>{if(this._messageBuffer)return this._messageBuffer._resend()}),this.connection.features.inherentKeepAlive||await this._sendMessage(this._cachedPingMessage)}catch(e){throw this._logger.log(r.Debug,`Hub handshake failed with error '${e}' during start(). Stopping HubConnection.`),this._cleanupTimeout(),this._cleanupPingTimer(),await this.connection.stop(e),e}}async stop(){const e=this._startPromise;this.connection.features.reconnect=!1,this._stopPromise=this._stopInternal(),await this._stopPromise;try{await e}catch(e){}}_stopInternal(e){if(this._connectionState===o.Disconnected)return this._logger.log(r.Debug,`Call to HubConnection.stop(${e}) ignored because it is already in the disconnected state.`),Promise.resolve();if(this._connectionState===o.Disconnecting)return this._logger.log(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise;const t=this._connectionState;return this._connectionState=o.Disconnecting,this._logger.log(r.Debug,"Stopping HubConnection."),this._reconnectDelayHandle?(this._logger.log(r.Debug,"Connection stopped during reconnect delay. Done reconnecting."),clearTimeout(this._reconnectDelayHandle),this._reconnectDelayHandle=void 0,this._completeClose(),Promise.resolve()):(t===o.Connected&&this._sendCloseMessage(),this._cleanupTimeout(),this._cleanupPingTimer(),this._stopDuringStartError=e||new E("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),o=this._createStreamInvocation(e,t,r);let i;const a=new U;return a.cancelCallback=()=>{const e=this._createCancelInvocation(o.invocationId);return delete this._callbacks[o.invocationId],i.then((()=>this._sendWithProtocol(e)))},this._callbacks[o.invocationId]=(e,t)=>{t?a.error(t):e&&(e.type===s.Completion?e.error?a.error(new Error(e.error)):a.complete():a.next(e.item))},i=this._sendWithProtocol(o).catch((e=>{a.error(e),delete this._callbacks[o.invocationId]})),this._launchStreams(n,i),a}_sendMessage(e){return this._resetKeepAliveInterval(),this.connection.send(e)}_sendWithProtocol(e){return this._messageBuffer?this._messageBuffer._send(e):this._sendMessage(this._protocol.writeMessage(e))}send(e,...t){const[n,r]=this._replaceStreamingParams(t),s=this._sendWithProtocol(this._createInvocation(e,t,!0,r));return this._launchStreams(n,s),s}invoke(e,...t){const[n,r]=this._replaceStreamingParams(t),o=this._createInvocation(e,t,!1,r);return new Promise(((e,t)=>{this._callbacks[o.invocationId]=(n,r)=>{r?t(r):n&&(n.type===s.Completion?n.error?t(new Error(n.error)):e(n.result):t(new Error(`Unexpected message type: ${n.type}`)))};const r=this._sendWithProtocol(o).catch((e=>{t(e),delete this._callbacks[o.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 s.Invocation:this._invokeClientMethod(e).catch((e=>{this._logger.log(r.Error,`Invoke client method threw error: ${T(e)}`)}));break;case s.StreamItem:case s.Completion:{const t=this._callbacks[e.invocationId];if(t){e.type===s.Completion&&delete this._callbacks[e.invocationId];try{t(e)}catch(e){this._logger.log(r.Error,`Stream callback threw error: ${T(e)}`)}}break}case s.Ping:break;case s.Close:{this._logger.log(r.Information,"Close message received from server.");const t=e.error?new Error("Server returned an error on close: "+e.error):void 0;!0===e.allowReconnect?this.connection.stop(t):this._stopPromise=this._stopInternal(t);break}case s.Ack:this._messageBuffer&&this._messageBuffer._ack(e);break;case s.Sequence:this._messageBuffer&&this._messageBuffer._resetSequence(e);break;default:this._logger.log(r.Warning,`Invalid message type: ${e.type}.`)}}this._resetTimeoutPeriod()}_processHandshakeResponse(e){let t,n;try{[n,t]=this._handshakeProtocol.parseHandshakeResponse(e)}catch(e){const t="Error parsing handshake response: "+e;this._logger.log(r.Error,t);const n=new Error(t);throw this._handshakeRejecter(n),n}if(t.error){const e="Server returned handshake error: "+t.error;this._logger.log(r.Error,e);const n=new Error(e);throw this._handshakeRejecter(n),n}return this._logger.log(r.Debug,"Server handshake complete."),this._handshakeResolver(),n}_resetKeepAliveInterval(){this.connection.features.inherentKeepAlive||(this._nextKeepAlive=(new Date).getTime()+this.keepAliveIntervalInMilliseconds,this._cleanupPingTimer())}_resetTimeoutPeriod(){if(!(this.connection.features&&this.connection.features.inherentKeepAlive||(this._timeoutHandle=setTimeout((()=>this.serverTimeout()),this.serverTimeoutInMilliseconds),void 0!==this._pingServerHandle))){let e=this._nextKeepAlive-(new Date).getTime();e<0&&(e=0),this._pingServerHandle=setTimeout((async()=>{if(this._connectionState===o.Connected)try{await this._sendMessage(this._cachedPingMessage)}catch{this._cleanupPingTimer()}}),e)}}serverTimeout(){this.connection.stop(new Error("Server timeout elapsed without receiving a message from the server."))}async _invokeClientMethod(e){const t=e.target.toLowerCase(),n=this._methods[t];if(!n)return this._logger.log(r.Warning,`No client method with the name '${t}' found.`),void(e.invocationId&&(this._logger.log(r.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),await this._sendWithProtocol(this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null))));const s=n.slice(),o=!!e.invocationId;let i,a,c;for(const n of s)try{const s=i;i=await n.apply(this,e.arguments),o&&i&&s&&(this._logger.log(r.Error,`Multiple results provided for '${t}'. Sending error to server.`),c=this._createCompletionMessage(e.invocationId,"Client provided multiple results.",null)),a=void 0}catch(e){a=e,this._logger.log(r.Error,`A callback for the method '${t}' threw error '${e}'.`)}c?await this._sendWithProtocol(c):o?(a?c=this._createCompletionMessage(e.invocationId,`${a}`,null):void 0!==i?c=this._createCompletionMessage(e.invocationId,null,i):(this._logger.log(r.Warning,`No result given for '${t}' method and invocation ID '${e.invocationId}'.`),c=this._createCompletionMessage(e.invocationId,"Client didn't provide a result.",null)),await this._sendWithProtocol(c)):i&&this._logger.log(r.Error,`Result given for '${t}' method but server is not expecting a result.`)}_connectionClosed(e){this._logger.log(r.Debug,`HubConnection.connectionClosed(${e}) called while in state ${this._connectionState}.`),this._stopDuringStartError=this._stopDuringStartError||e||new E("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===o.Disconnecting?this._completeClose(e):this._connectionState===o.Connected&&this._reconnectPolicy?this._reconnect(e):this._connectionState===o.Connected&&this._completeClose(e)}_completeClose(e){if(this._connectionStarted){this._connectionState=o.Disconnected,this._connectionStarted=!1,this._messageBuffer&&(this._messageBuffer._dispose(null!=e?e:new Error("Connection closed.")),this._messageBuffer=void 0),g.isBrowser&&window.document.removeEventListener("freeze",this._freezeEventListener);try{this._closedCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(r.Error,`An onclose callback called with error '${e}' threw error '${t}'.`)}}}async _reconnect(e){const t=Date.now();let n=0,s=void 0!==e?e:new Error("Attempting to reconnect due to a unknown error."),i=this._getNextRetryDelay(n++,0,s);if(null===i)return this._logger.log(r.Debug,"Connection not reconnecting because the IRetryPolicy returned null on the first reconnect attempt."),void this._completeClose(e);if(this._connectionState=o.Reconnecting,e?this._logger.log(r.Information,`Connection reconnecting because of error '${e}'.`):this._logger.log(r.Information,"Connection reconnecting."),0!==this._reconnectingCallbacks.length){try{this._reconnectingCallbacks.forEach((t=>t.apply(this,[e])))}catch(t){this._logger.log(r.Error,`An onreconnecting callback called with error '${e}' threw error '${t}'.`)}if(this._connectionState!==o.Reconnecting)return void this._logger.log(r.Debug,"Connection left the reconnecting state in onreconnecting callback. Done reconnecting.")}for(;null!==i;){if(this._logger.log(r.Information,`Reconnect attempt number ${n} will start in ${i} ms.`),await new Promise((e=>{this._reconnectDelayHandle=setTimeout(e,i)})),this._reconnectDelayHandle=void 0,this._connectionState!==o.Reconnecting)return void this._logger.log(r.Debug,"Connection left the reconnecting state during reconnect delay. Done reconnecting.");try{if(await this._startInternal(),this._connectionState=o.Connected,this._logger.log(r.Information,"HubConnection reconnected successfully."),0!==this._reconnectedCallbacks.length)try{this._reconnectedCallbacks.forEach((e=>e.apply(this,[this.connection.connectionId])))}catch(e){this._logger.log(r.Error,`An onreconnected callback called with connectionId '${this.connection.connectionId}; threw error '${e}'.`)}return}catch(e){if(this._logger.log(r.Information,`Reconnect attempt failed because of error '${e}'.`),this._connectionState!==o.Reconnecting)return this._logger.log(r.Debug,`Connection moved to the '${this._connectionState}' from the reconnecting state during reconnect attempt. Done reconnecting.`),void(this._connectionState===o.Disconnecting&&this._completeClose());s=e instanceof Error?e:new Error(e.toString()),i=this._getNextRetryDelay(n++,Date.now()-t,s)}}this._logger.log(r.Information,`Reconnect retries have been exhausted after ${Date.now()-t} ms and ${n} failed attempts. Connection disconnecting.`),this._completeClose()}_getNextRetryDelay(e,t,n){try{return this._reconnectPolicy.nextRetryDelayInMilliseconds({elapsedMilliseconds:t,previousRetryCount:e,retryReason:n})}catch(n){return this._logger.log(r.Error,`IRetryPolicy.nextRetryDelayInMilliseconds(${e}, ${t}) threw error '${n}'.`),null}}_cancelCallbacksWithError(e){const t=this._callbacks;this._callbacks={},Object.keys(t).forEach((n=>{const s=t[n];try{s(null,e)}catch(t){this._logger.log(r.Error,`Stream 'error' callback called with '${e}' threw error: ${T(t)}`)}}))}_cleanupPingTimer(){this._pingServerHandle&&(clearTimeout(this._pingServerHandle),this._pingServerHandle=void 0)}_cleanupTimeout(){this._timeoutHandle&&clearTimeout(this._timeoutHandle)}_createInvocation(e,t,n,r){if(n)return 0!==r.length?{arguments:t,streamIds:r,target:e,type:s.Invocation}:{arguments:t,target:e,type:s.Invocation};{const n=this._invocationId;return this._invocationId++,0!==r.length?{arguments:t,invocationId:n.toString(),streamIds:r,target:e,type:s.Invocation}:{arguments:t,invocationId:n.toString(),target:e,type:s.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:s.StreamInvocation}:{arguments:t,invocationId:r.toString(),target:e,type:s.StreamInvocation}}_createCancelInvocation(e){return{invocationId:e,type:s.CancelInvocation}}_createStreamItemMessage(e,t){return{invocationId:e,item:t,type:s.StreamItem}}_createCompletionMessage(e,t,n){return t?{error:t,invocationId:e,type:s.Completion}:{invocationId:e,result:n,type:s.Completion}}_createCloseMessage(){return{type:s.Close}}}const F=[0,2e3,1e4,3e4,null];class L{constructor(e){this._retryDelays=void 0!==e?[...e,null]:F}nextRetryDelayInMilliseconds(e){return this._retryDelays[e.previousRetryCount]}}class B{}B.Authorization="Authorization",B.Cookie="Cookie";class W{constructor(e,t,n){this.statusCode=e,this.statusText=t,this.content=n}}class ${get(e,t){return this.send({...t,method:"GET",url:e})}post(e,t){return this.send({...t,method:"POST",url:e})}delete(e,t){return this.send({...t,method:"DELETE",url:e})}getCookieString(e){return""}}class V extends ${constructor(e,t){super(),this._innerClient=e,this._accessTokenFactory=t}async send(e){let t=!0;this._accessTokenFactory&&(!this._accessToken||e.url&&e.url.indexOf("/negotiate?")>0)&&(t=!1,this._accessToken=await this._accessTokenFactory()),this._setAuthorizationHeader(e);const n=await this._innerClient.send(e);return t&&401===n.statusCode&&this._accessTokenFactory?(this._accessToken=await this._accessTokenFactory(),this._setAuthorizationHeader(e),await this._innerClient.send(e)):n}_setAuthorizationHeader(e){e.headers||(e.headers={}),this._accessToken?e.headers[B.Authorization]=`Bearer ${this._accessToken}`:this._accessTokenFactory&&e.headers[B.Authorization]&&delete e.headers[B.Authorization]}getCookieString(e){return this._innerClient.getCookieString(e)}}class q extends ${constructor(e){if(super(),this._logger=e,"undefined"==typeof fetch||g.isNode){const e=require;this._jar=new(e("tough-cookie").CookieJar),"undefined"==typeof fetch?this._fetchType=e("node-fetch"):this._fetchType=fetch,this._fetchType=e("fetch-cookie")(this._fetchType,this._jar)}else this._fetchType=fetch.bind(function(){if("undefined"!=typeof globalThis)return globalThis;if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==i.g)return i.g;throw new Error("could not find global")}());if("undefined"==typeof AbortController){const e=require;this._abortControllerType=e("abort-controller")}else this._abortControllerType=AbortController}async send(e){if(e.abortSignal&&e.abortSignal.aborted)throw new E;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 E});let s,o=null;if(e.timeout){const s=e.timeout;o=setTimeout((()=>{t.abort(),this._logger.log(r.Warning,"Timeout from HTTP request."),n=new I}),s)}""===e.content&&(e.content=void 0),e.content&&(e.headers=e.headers||{},v(e.content)?e.headers["Content-Type"]="application/octet-stream":e.headers["Content-Type"]="text/plain;charset=UTF-8");try{s=await this._fetchType(e.url,{body:e.content,cache:"no-cache",credentials:!0===e.withCredentials?"include":"same-origin",headers:{"X-Requested-With":"XMLHttpRequest",...e.headers},method:e.method,mode:"cors",redirect:"follow",signal:t.signal})}catch(e){if(n)throw n;throw this._logger.log(r.Warning,`Error from HTTP request. ${e}.`),e}finally{o&&clearTimeout(o),e.abortSignal&&(e.abortSignal.onabort=null)}if(!s.ok){const e=await H(s,"text");throw new k(e||s.statusText,s.status)}const i=H(s,e.responseType),a=await i;return new W(s.status,s.statusText,a)}getCookieString(e){let t="";return g.isNode&&this._jar&&this._jar.getCookies(e,((e,n)=>t=n.join("; "))),t}}function H(e,t){let n;switch(t){case"arraybuffer":n=e.arrayBuffer();break;case"text":default:n=e.text();break;case"blob":case"document":case"json":throw new Error(`${t} is not supported.`)}return n}class K extends ${constructor(e){super(),this._logger=e}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new E):e.method?e.url?new Promise(((t,n)=>{const s=new XMLHttpRequest;s.open(e.method,e.url,!0),s.withCredentials=void 0===e.withCredentials||e.withCredentials,s.setRequestHeader("X-Requested-With","XMLHttpRequest"),""===e.content&&(e.content=void 0),e.content&&(v(e.content)?s.setRequestHeader("Content-Type","application/octet-stream"):s.setRequestHeader("Content-Type","text/plain;charset=UTF-8"));const o=e.headers;o&&Object.keys(o).forEach((e=>{s.setRequestHeader(e,o[e])})),e.responseType&&(s.responseType=e.responseType),e.abortSignal&&(e.abortSignal.onabort=()=>{s.abort(),n(new E)}),e.timeout&&(s.timeout=e.timeout),s.onload=()=>{e.abortSignal&&(e.abortSignal.onabort=null),s.status>=200&&s.status<300?t(new W(s.status,s.statusText,s.response||s.responseText)):n(new k(s.response||s.responseText||s.statusText,s.status))},s.onerror=()=>{this._logger.log(r.Warning,`Error from HTTP request. ${s.status}: ${s.statusText}.`),n(new k(s.statusText,s.status))},s.ontimeout=()=>{this._logger.log(r.Warning,"Timeout from HTTP request."),n(new I)},s.send(e.content)})):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}}class j extends ${constructor(e){if(super(),"undefined"!=typeof fetch||g.isNode)this._httpClient=new q(e);else{if("undefined"==typeof XMLHttpRequest)throw new Error("No usable HttpClient found.");this._httpClient=new K(e)}}send(e){return e.abortSignal&&e.abortSignal.aborted?Promise.reject(new E):e.method?e.url?this._httpClient.send(e):Promise.reject(new Error("No url defined.")):Promise.reject(new Error("No method defined."))}getCookieString(e){return this._httpClient.getCookieString(e)}}class z{constructor(){this._isAborted=!1,this.onabort=null}abort(){this._isAborted||(this._isAborted=!0,this.onabort&&this.onabort())}get signal(){return this}get aborted(){return this._isAborted}}class J{get pollAborted(){return this._pollAbort.aborted}constructor(e,t,n){this._httpClient=e,this._logger=t,this._pollAbort=new z,this._options=n,this._running=!1,this.onreceive=null,this.onclose=null}async connect(e,t){if(p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.isIn(t,n,"transferFormat"),this._url=e,this._logger.log(r.Trace,"(LongPolling transport) Connecting."),t===n.Binary&&"undefined"!=typeof XMLHttpRequest&&"string"!=typeof(new XMLHttpRequest).responseType)throw new Error("Binary protocols over XmlHttpRequest not implementing advanced features are not supported.");const[s,o]=S(),i={[s]:o,...this._options.headers},a={abortSignal:this._pollAbort.signal,headers:i,timeout:1e5,withCredentials:this._options.withCredentials};t===n.Binary&&(a.responseType="arraybuffer");const c=`${e}&_=${Date.now()}`;this._logger.log(r.Trace,`(LongPolling transport) polling: ${c}.`);const u=await this._httpClient.get(c,a);200!==u.statusCode?(this._logger.log(r.Error,`(LongPolling transport) Unexpected response code: ${u.statusCode}.`),this._closeError=new k(u.statusText||"",u.statusCode),this._running=!1):this._running=!0,this._receiving=this._poll(this._url,a)}async _poll(e,t){try{for(;this._running;)try{const n=`${e}&_=${Date.now()}`;this._logger.log(r.Trace,`(LongPolling transport) polling: ${n}.`);const s=await this._httpClient.get(n,t);204===s.statusCode?(this._logger.log(r.Information,"(LongPolling transport) Poll terminated by server."),this._running=!1):200!==s.statusCode?(this._logger.log(r.Error,`(LongPolling transport) Unexpected response code: ${s.statusCode}.`),this._closeError=new k(s.statusText||"",s.statusCode),this._running=!1):s.content?(this._logger.log(r.Trace,`(LongPolling transport) data received. ${f(s.content,this._options.logMessageContent)}.`),this.onreceive&&this.onreceive(s.content)):this._logger.log(r.Trace,"(LongPolling transport) Poll timed out, reissuing.")}catch(e){this._running?e instanceof I?this._logger.log(r.Trace,"(LongPolling transport) Poll timed out, reissuing."):(this._closeError=e,this._running=!1):this._logger.log(r.Trace,`(LongPolling transport) Poll errored after shutdown: ${e.message}`)}}finally{this._logger.log(r.Trace,"(LongPolling transport) Polling complete."),this.pollAborted||this._raiseOnClose()}}async send(e){return this._running?y(this._logger,"LongPolling",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}async stop(){this._logger.log(r.Trace,"(LongPolling transport) Stopping polling."),this._running=!1,this._pollAbort.abort();try{await this._receiving,this._logger.log(r.Trace,`(LongPolling transport) sending DELETE request to ${this._url}.`);const e={},[t,n]=S();e[t]=n;const s={headers:{...e,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials};let o;try{await this._httpClient.delete(this._url,s)}catch(e){o=e}o?o instanceof k&&(404===o.statusCode?this._logger.log(r.Trace,"(LongPolling transport) A 404 response was returned from sending a DELETE request."):this._logger.log(r.Trace,`(LongPolling transport) Error sending a DELETE request: ${o}`)):this._logger.log(r.Trace,"(LongPolling transport) DELETE request accepted.")}finally{this._logger.log(r.Trace,"(LongPolling transport) Stop finished."),this._raiseOnClose()}}_raiseOnClose(){if(this.onclose){let e="(LongPolling transport) Firing onclose event.";this._closeError&&(e+=" Error: "+this._closeError),this._logger.log(r.Trace,e),this.onclose(this._closeError)}}}class X{constructor(e,t,n,r){this._httpClient=e,this._accessToken=t,this._logger=n,this._options=r,this.onreceive=null,this.onclose=null}async connect(e,t){return p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.isIn(t,n,"transferFormat"),this._logger.log(r.Trace,"(SSE transport) Connecting."),this._url=e,this._accessToken&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(this._accessToken)}`),new Promise(((s,o)=>{let i,a=!1;if(t===n.Text){if(g.isBrowser||g.isWebWorker)i=new this._options.EventSource(e,{withCredentials:this._options.withCredentials});else{const t=this._httpClient.getCookieString(e),n={};n.Cookie=t;const[r,s]=S();n[r]=s,i=new this._options.EventSource(e,{withCredentials:this._options.withCredentials,headers:{...n,...this._options.headers}})}try{i.onmessage=e=>{if(this.onreceive)try{this._logger.log(r.Trace,`(SSE transport) data received. ${f(e.data,this._options.logMessageContent)}.`),this.onreceive(e.data)}catch(e){return void this._close(e)}},i.onerror=e=>{a?this._close():o(new Error("EventSource failed to connect. The connection could not be found on the server, either the connection ID is not present on the server, or a proxy is refusing/buffering the connection. If you have multiple servers check that sticky sessions are enabled."))},i.onopen=()=>{this._logger.log(r.Information,`SSE connected to ${this._url}`),this._eventSource=i,a=!0,s()}}catch(e){return void o(e)}}else o(new Error("The Server-Sent Events transport only supports the 'Text' transfer format"))}))}async send(e){return this._eventSource?y(this._logger,"SSE",this._httpClient,this._url,e,this._options):Promise.reject(new Error("Cannot send until the transport is connected"))}stop(){return this._close(),Promise.resolve()}_close(e){this._eventSource&&(this._eventSource.close(),this._eventSource=void 0,this.onclose&&this.onclose(e))}}class Y{constructor(e,t,n,r,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 s;return p.isRequired(e,"url"),p.isRequired(t,"transferFormat"),p.isIn(t,n,"transferFormat"),this._logger.log(r.Trace,"(WebSockets transport) Connecting."),this._accessTokenFactory&&(s=await this._accessTokenFactory()),new Promise(((o,i)=>{let a;e=e.replace(/^http/,"ws");const c=this._httpClient.getCookieString(e);let u=!1;if(g.isNode||g.isReactNative){const t={},[n,r]=S();t[n]=r,s&&(t[B.Authorization]=`Bearer ${s}`),c&&(t[B.Cookie]=c),a=new this._webSocketConstructor(e,void 0,{headers:{...t,...this._headers}})}else s&&(e+=(e.indexOf("?")<0?"?":"&")+`access_token=${encodeURIComponent(s)}`);a||(a=new this._webSocketConstructor(e)),t===n.Binary&&(a.binaryType="arraybuffer"),a.onopen=t=>{this._logger.log(r.Information,`WebSocket connected to ${e}.`),this._webSocket=a,u=!0,o()},a.onerror=e=>{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"There was an error with the transport",this._logger.log(r.Information,`(WebSockets transport) ${t}.`)},a.onmessage=e=>{if(this._logger.log(r.Trace,`(WebSockets transport) data received. ${f(e.data,this._logMessageContent)}.`),this.onreceive)try{this.onreceive(e.data)}catch(e){return void this._close(e)}},a.onclose=e=>{if(u)this._close(e);else{let t=null;t="undefined"!=typeof ErrorEvent&&e instanceof ErrorEvent?e.error:"WebSocket failed to connect. The connection could not be found on the server, either the endpoint may not be a SignalR endpoint, the connection ID is not present on the server, or there is a proxy blocking WebSockets. If you have multiple servers check that sticky sessions are enabled.",i(new Error(t))}}}))}send(e){return this._webSocket&&this._webSocket.readyState===this._webSocketConstructor.OPEN?(this._logger.log(r.Trace,`(WebSockets transport) sending data. ${f(e,this._logMessageContent)}.`),this._webSocket.send(e),Promise.resolve()):Promise.reject("WebSocket is not in the OPEN state")}stop(){return this._webSocket&&this._close(void 0),Promise.resolve()}_close(e){this._webSocket&&(this._webSocket.onclose=()=>{},this._webSocket.onmessage=()=>{},this._webSocket.onerror=()=>{},this._webSocket.close(),this._webSocket=void 0),this._logger.log(r.Trace,"(WebSockets transport) socket closed."),this.onclose&&(!this._isCloseEvent(e)||!1!==e.wasClean&&1e3===e.code?e instanceof Error?this.onclose(e):this.onclose():this.onclose(new Error(`WebSocket closed with status code: ${e.code} (${e.reason||"no reason given"}).`)))}_isCloseEvent(e){return e&&"boolean"==typeof e.wasClean&&"number"==typeof e.code}}class Q{constructor(e,t={}){var n;if(this._stopPromiseResolver=()=>{},this.features={},this._negotiateVersion=1,p.isRequired(e,"url"),this._logger=void 0===(n=t.logger)?new w(r.Information):null===n?h.instance:void 0!==n.log?n:new w(n),this.baseUrl=this._resolveUrl(e),(t=t||{}).logMessageContent=void 0!==t.logMessageContent&&t.logMessageContent,"boolean"!=typeof t.withCredentials&&void 0!==t.withCredentials)throw new Error("withCredentials option was not a 'boolean' or 'undefined' value");t.withCredentials=void 0===t.withCredentials||t.withCredentials,t.timeout=void 0===t.timeout?1e5:t.timeout;let s=null,o=null;if(g.isNode){const e=require;s=e("ws"),o=e("eventsource")}g.isNode||"undefined"==typeof WebSocket||t.WebSocket?g.isNode&&!t.WebSocket&&s&&(t.WebSocket=s):t.WebSocket=WebSocket,g.isNode||"undefined"==typeof EventSource||t.EventSource?g.isNode&&!t.EventSource&&void 0!==o&&(t.EventSource=o):t.EventSource=EventSource,this._httpClient=new V(t.httpClient||new j(this._logger),t.accessTokenFactory),this._connectionState="Disconnected",this._connectionStarted=!1,this._options=t,this.onreceive=null,this.onclose=null}async start(e){if(e=e||n.Binary,p.isIn(e,n,"transferFormat"),this._logger.log(r.Debug,`Starting connection with transfer format '${n[e]}'.`),"Disconnected"!==this._connectionState)return Promise.reject(new Error("Cannot start an HttpConnection that is not in the 'Disconnected' state."));if(this._connectionState="Connecting",this._startInternalPromise=this._startInternal(e),await this._startInternalPromise,"Disconnecting"===this._connectionState){const e="Failed to start the HttpConnection before stop() was called.";return this._logger.log(r.Error,e),await this._stopPromise,Promise.reject(new E(e))}if("Connected"!==this._connectionState){const e="HttpConnection.startInternal completed gracefully but didn't enter the connection into the connected state!";return this._logger.log(r.Error,e),Promise.reject(new E(e))}this._connectionStarted=!0}send(e){return"Connected"!==this._connectionState?Promise.reject(new Error("Cannot send data if the connection is not in the 'Connected' State.")):(this._sendQueue||(this._sendQueue=new Z(this.transport)),this._sendQueue.send(e))}async stop(e){return"Disconnected"===this._connectionState?(this._logger.log(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnected state.`),Promise.resolve()):"Disconnecting"===this._connectionState?(this._logger.log(r.Debug,`Call to HttpConnection.stop(${e}) ignored because the connection is already in the disconnecting state.`),this._stopPromise):(this._connectionState="Disconnecting",this._stopPromise=new Promise((e=>{this._stopPromiseResolver=e})),await this._stopInternal(e),void await this._stopPromise)}async _stopInternal(e){this._stopError=e;try{await this._startInternalPromise}catch(e){}if(this.transport){try{await this.transport.stop()}catch(e){this._logger.log(r.Error,`HttpConnection.transport.stop() threw error '${e}'.`),this._stopConnection()}this.transport=void 0}else this._logger.log(r.Debug,"HttpConnection.transport is undefined in HttpConnection.stop() because start() failed.")}async _startInternal(e){let n=this.baseUrl;this._accessTokenFactory=this._options.accessTokenFactory,this._httpClient._accessTokenFactory=this._accessTokenFactory;try{if(this._options.skipNegotiation){if(this._options.transport!==t.WebSockets)throw new Error("Negotiation can only be skipped when using the WebSocket transport directly.");this.transport=this._constructTransport(t.WebSockets),await this._startTransport(n,e)}else{let t=null,r=0;do{if(t=await this._getNegotiationResponse(n),"Disconnecting"===this._connectionState||"Disconnected"===this._connectionState)throw new E("The connection was stopped during negotiation.");if(t.error)throw new Error(t.error);if(t.ProtocolVersion)throw new Error("Detected a connection attempt to an ASP.NET SignalR Server. This client only supports connecting to an ASP.NET Core SignalR Server. See https://aka.ms/signalr-core-differences for details.");if(t.url&&(n=t.url),t.accessToken){const e=t.accessToken;this._accessTokenFactory=()=>e,this._httpClient._accessToken=e,this._httpClient._accessTokenFactory=void 0}r++}while(t.url&&r<100);if(100===r&&t.url)throw new Error("Negotiate redirection limit exceeded.");await this._createTransport(n,this._options.transport,t,e)}this.transport instanceof J&&(this.features.inherentKeepAlive=!0),"Connecting"===this._connectionState&&(this._logger.log(r.Debug,"The HttpConnection connected successfully."),this._connectionState="Connected")}catch(e){return this._logger.log(r.Error,"Failed to start the connection: "+e),this._connectionState="Disconnected",this.transport=void 0,this._stopPromiseResolver(),Promise.reject(e)}}async _getNegotiationResponse(e){const t={},[n,s]=S();t[n]=s;const o=this._resolveNegotiateUrl(e);this._logger.log(r.Debug,`Sending negotiation request: ${o}.`);try{const e=await this._httpClient.post(o,{content:"",headers:{...t,...this._options.headers},timeout:this._options.timeout,withCredentials:this._options.withCredentials});if(200!==e.statusCode)return Promise.reject(new Error(`Unexpected status code returned from negotiate '${e.statusCode}'`));const n=JSON.parse(e.content);return(!n.negotiateVersion||n.negotiateVersion<1)&&(n.connectionToken=n.connectionId),n.useStatefulReconnect&&!0!==this._options._useStatefulReconnect?Promise.reject(new R("Client didn't negotiate Stateful Reconnect but the server did.")):n}catch(e){let t="Failed to complete negotiation with the server: "+e;return e instanceof k&&404===e.statusCode&&(t+=" Either this is not a SignalR endpoint or there is a proxy blocking the connection."),this._logger.log(r.Error,t),Promise.reject(new R(t))}}_createConnectUrl(e,t){return t?e+(-1===e.indexOf("?")?"?":"&")+`id=${t}`:e}async _createTransport(e,n,s,o){let i=this._createConnectUrl(e,s.connectionToken);if(this._isITransport(n))return this._logger.log(r.Debug,"Connection was provided an instance of ITransport, using that directly."),this.transport=n,await this._startTransport(i,o),void(this.connectionId=s.connectionId);const a=[],c=s.availableTransports||[];let u=s;for(const s of c){const c=this._resolveTransportOrError(s,n,o,!0===(null==u?void 0:u.useStatefulReconnect));if(c instanceof Error)a.push(`${s.transport} failed:`),a.push(c);else if(this._isITransport(c)){if(this.transport=c,!u){try{u=await this._getNegotiationResponse(e)}catch(e){return Promise.reject(e)}i=this._createConnectUrl(e,u.connectionToken)}try{return await this._startTransport(i,o),void(this.connectionId=u.connectionId)}catch(e){if(this._logger.log(r.Error,`Failed to start the transport '${s.transport}': ${e}`),u=void 0,a.push(new G(`${s.transport} failed: ${e}`,t[s.transport])),"Connecting"!==this._connectionState){const e="Failed to select transport before stop() was called.";return this._logger.log(r.Debug,e),Promise.reject(new E(e))}}}}return a.length>0?Promise.reject(new P(`Unable to connect to the server with any of the available transports. ${a.join(" ")}`,a)):Promise.reject(new Error("None of the transports supported by the client are supported by the server."))}_constructTransport(e){switch(e){case t.WebSockets:if(!this._options.WebSocket)throw new Error("'WebSocket' is not supported in your environment.");return new Y(this._httpClient,this._accessTokenFactory,this._logger,this._options.logMessageContent,this._options.WebSocket,this._options.headers||{});case t.ServerSentEvents:if(!this._options.EventSource)throw new Error("'EventSource' is not supported in your environment.");return new X(this._httpClient,this._httpClient._accessToken,this._logger,this._options);case t.LongPolling:return new J(this._httpClient,this._logger,this._options);default:throw new Error(`Unknown transport: ${e}.`)}}_startTransport(e,t){return this.transport.onreceive=this.onreceive,this.features.reconnect?this.transport.onclose=async n=>{let r=!1;if(this.features.reconnect){try{this.features.disconnected(),await this.transport.connect(e,t),await this.features.resend()}catch{r=!0}r&&this._stopConnection(n)}else this._stopConnection(n)}:this.transport.onclose=e=>this._stopConnection(e),this.transport.connect(e,t)}_resolveTransportOrError(e,s,o,i){const a=t[e.transport];if(null==a)return this._logger.log(r.Debug,`Skipping transport '${e.transport}' because it is not supported by this client.`),new Error(`Skipping transport '${e.transport}' because it is not supported by this client.`);if(!function(e,t){return!e||!!(t&e)}(s,a))return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it was disabled by the client.`),new N(`'${t[a]}' is disabled by the client.`,a);if(!(e.transferFormats.map((e=>n[e])).indexOf(o)>=0))return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it does not support the requested transfer format '${n[o]}'.`),new Error(`'${t[a]}' does not support ${n[o]}.`);if(a===t.WebSockets&&!this._options.WebSocket||a===t.ServerSentEvents&&!this._options.EventSource)return this._logger.log(r.Debug,`Skipping transport '${t[a]}' because it is not supported in your environment.'`),new b(`'${t[a]}' is not supported in your environment.`,a);this._logger.log(r.Debug,`Selecting transport '${t[a]}'.`);try{return this.features.reconnect=a===t.WebSockets?i:void 0,this._constructTransport(a)}catch(e){return e}}_isITransport(e){return e&&"object"==typeof e&&"connect"in e}_stopConnection(e){if(this._logger.log(r.Debug,`HttpConnection.stopConnection(${e}) called while in state ${this._connectionState}.`),this.transport=void 0,e=this._stopError||e,this._stopError=void 0,"Disconnected"!==this._connectionState){if("Connecting"===this._connectionState)throw this._logger.log(r.Warning,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is still in the connecting state.`),new Error(`HttpConnection.stopConnection(${e}) was called while the connection is still in the connecting state.`);if("Disconnecting"===this._connectionState&&this._stopPromiseResolver(),e?this._logger.log(r.Error,`Connection disconnected with error '${e}'.`):this._logger.log(r.Information,"Connection disconnected."),this._sendQueue&&(this._sendQueue.stop().catch((e=>{this._logger.log(r.Error,`TransportSendQueue.stop() threw error '${e}'.`)})),this._sendQueue=void 0),this.connectionId=void 0,this._connectionState="Disconnected",this._connectionStarted){this._connectionStarted=!1;try{this.onclose&&this.onclose(e)}catch(t){this._logger.log(r.Error,`HttpConnection.onclose(${e}) threw error '${t}'.`)}}}else this._logger.log(r.Debug,`Call to HttpConnection.stopConnection(${e}) was ignored because the connection is already in the disconnected state.`)}_resolveUrl(e){if(0===e.lastIndexOf("https://",0)||0===e.lastIndexOf("http://",0))return e;if(!g.isBrowser)throw new Error(`Cannot resolve '${e}'.`);const t=window.document.createElement("a");return t.href=e,this._logger.log(r.Information,`Normalizing '${e}' to '${t.href}'.`),t.href}_resolveNegotiateUrl(e){const t=new URL(e);t.pathname.endsWith("/")?t.pathname+="negotiate":t.pathname+="/negotiate";const n=new URLSearchParams(t.searchParams);return n.has("negotiateVersion")||n.append("negotiateVersion",this._negotiateVersion.toString()),n.has("useStatefulReconnect")?"true"===n.get("useStatefulReconnect")&&(this._options._useStatefulReconnect=!0):!0===this._options._useStatefulReconnect&&n.append("useStatefulReconnect","true"),t.search=n.toString(),t.toString()}}class Z{constructor(e){this._transport=e,this._buffer=[],this._executing=!0,this._sendBufferedData=new ee,this._transportResult=new ee,this._sendLoopPromise=this._sendLoop()}send(e){return this._bufferData(e),this._transportResult||(this._transportResult=new ee),this._transportResult.promise}stop(){return this._executing=!1,this._sendBufferedData.resolve(),this._sendLoopPromise}_bufferData(e){if(this._buffer.length&&typeof this._buffer[0]!=typeof e)throw new Error(`Expected data to be of type ${typeof this._buffer} but was of type ${typeof e}`);this._buffer.push(e),this._sendBufferedData.resolve()}async _sendLoop(){for(;;){if(await this._sendBufferedData.promise,!this._executing){this._transportResult&&this._transportResult.reject("Connection stopped.");break}this._sendBufferedData=new ee;const e=this._transportResult;this._transportResult=void 0;const t="string"==typeof this._buffer[0]?this._buffer.join(""):Z._concatBuffers(this._buffer);this._buffer.length=0;try{await this._transport.send(t),e.resolve()}catch(t){e.reject(t)}}}static _concatBuffers(e){const t=e.map((e=>e.byteLength)).reduce(((e,t)=>e+t)),n=new Uint8Array(t);let r=0;for(const t of e)n.set(new Uint8Array(t),r),r+=t.byteLength;return n.buffer}}class ee{constructor(){this.promise=new Promise(((e,t)=>[this._resolver,this._rejecter]=[e,t]))}resolve(){this._resolver()}reject(e){this._rejecter(e)}}class te{constructor(){this.name="json",this.version=2,this.transferFormat=n.Text}parseMessages(e,t){if("string"!=typeof e)throw new Error("Invalid input for JSON hub protocol. Expected a string.");if(!e)return[];null===t&&(t=h.instance);const n=d.parse(e),o=[];for(const e of n){const n=JSON.parse(e);if("number"!=typeof n.type)throw new Error("Invalid payload.");switch(n.type){case s.Invocation:this._isInvocationMessage(n);break;case s.StreamItem:this._isStreamItemMessage(n);break;case s.Completion:this._isCompletionMessage(n);break;case s.Ping:case s.Close:break;case s.Ack:this._isAckMessage(n);break;case s.Sequence:this._isSequenceMessage(n);break;default:t.log(r.Information,"Unknown message type '"+n.type+"' ignored.");continue}o.push(n)}return o}writeMessage(e){return d.write(JSON.stringify(e))}_isInvocationMessage(e){this._assertNotEmptyString(e.target,"Invalid payload for Invocation message."),void 0!==e.invocationId&&this._assertNotEmptyString(e.invocationId,"Invalid payload for Invocation message.")}_isStreamItemMessage(e){if(this._assertNotEmptyString(e.invocationId,"Invalid payload for StreamItem message."),void 0===e.item)throw new Error("Invalid payload for StreamItem message.")}_isCompletionMessage(e){if(e.result&&e.error)throw new Error("Invalid payload for Completion message.");!e.result&&e.error&&this._assertNotEmptyString(e.error,"Invalid payload for Completion message."),this._assertNotEmptyString(e.invocationId,"Invalid payload for Completion message.")}_isAckMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Ack message.")}_isSequenceMessage(e){if("number"!=typeof e.sequenceId)throw new Error("Invalid SequenceId for Sequence message.")}_assertNotEmptyString(e,t){if("string"!=typeof e||""===e)throw new Error(t)}}const ne={trace:r.Trace,debug:r.Debug,info:r.Information,information:r.Information,warn:r.Warning,warning:r.Warning,error:r.Error,critical:r.Critical,none:r.None};class re{configureLogging(e){if(p.isRequired(e,"logging"),void 0!==e.log)this.logger=e;else if("string"==typeof e){const t=function(e){const t=ne[e.toLowerCase()];if(void 0!==t)return t;throw new Error(`Unknown log level: ${e}`)}(e);this.logger=new w(t)}else this.logger=new w(e);return this}withUrl(e,t){return p.isRequired(e,"url"),p.isNotEmpty(e,"url"),this.url=e,this.httpConnectionOptions="object"==typeof t?{...this.httpConnectionOptions,...t}:{...this.httpConnectionOptions,transport:t},this}withHubProtocol(e){return p.isRequired(e,"protocol"),this.protocol=e,this}withAutomaticReconnect(e){if(this.reconnectPolicy)throw new Error("A reconnectPolicy has already been set.");return e?Array.isArray(e)?this.reconnectPolicy=new L(e):this.reconnectPolicy=e:this.reconnectPolicy=new L,this}withServerTimeout(e){return p.isRequired(e,"milliseconds"),this._serverTimeoutInMilliseconds=e,this}withKeepAliveInterval(e){return p.isRequired(e,"milliseconds"),this._keepAliveIntervalInMilliseconds=e,this}withStatefulReconnect(e){return void 0===this.httpConnectionOptions&&(this.httpConnectionOptions={}),this.httpConnectionOptions._useStatefulReconnect=!0,this._statefulReconnectBufferSize=null==e?void 0:e.bufferSize,this}build(){const e=this.httpConnectionOptions||{};if(void 0===e.logger&&(e.logger=this.logger),!this.url)throw new Error("The 'HubConnectionBuilder.withUrl' method must be called before building the connection.");const t=new Q(this.url,e);return x.create(t,this.logger||h.instance,this.protocol||new te,this.reconnectPolicy,this._serverTimeoutInMilliseconds,this._keepAliveIntervalInMilliseconds,this._statefulReconnectBufferSize)}}class 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,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)}static IsIosNative(){var e;const t=null!=window.webkit&&null!=window.webkit.messageHandlers,n=void 0!==(null===(e=window.nativeEvent)||void 0===e?void 0:e.exalusFindController);return t&&n}}class oe{static Delay(e){return new Promise((t=>setTimeout(t,e)))}}function ie(e){return new Map(Object.entries(e))}function ae(e,t="export.csv"){const n=new Blob(["\ufeff",e],{type:"text/csv;charset=utf-8;"}),r=URL.createObjectURL(n),s=document.createElement("a");s.href=r,s.download=t,s.style.display="none",document.body.appendChild(s),s.click(),document.body.removeChild(s),URL.revokeObjectURL(r)}class ce{constructor(){this.TransactionId=se.GenerateUUID()}}var ue,le,de,he,pe,ge,fe,ve,ye,me,we,Se,Ae,_e,Ce,Te;(_e=ue||(ue={}))[_e.OK=0]="OK",_e[_e.UnknownError=1]="UnknownError",_e[_e.FatalError=2]="FatalError",_e[_e.WrongData=3]="WrongData",_e[_e.ResourceDoesNotExists=4]="ResourceDoesNotExists",_e[_e.NoPermissionToPerformThisOperation=5]="NoPermissionToPerformThisOperation",_e[_e.SessionHasAlreadyLoggedOnUser=6]="SessionHasAlreadyLoggedOnUser",_e[_e.OperationNotPermitted=7]="OperationNotPermitted",_e[_e.NoPermissionsToCallGivenResource=8]="NoPermissionsToCallGivenResource",_e[_e.ResourceIsNotAvailable=9]="ResourceIsNotAvailable",_e[_e.Error=10]="Error",_e[_e.NoData=11]="NoData",_e[_e.NotSupportedMethod=12]="NotSupportedMethod",_e[_e.UserIsNotLoggedIn=13]="UserIsNotLoggedIn",_e[_e.MultiDataResponseStart=14]="MultiDataResponseStart",_e[_e.MultiDataResponse=15]="MultiDataResponse",_e[_e.MultiDataResponseStop=16]="MultiDataResponseStop",function(e){e[e.Get=0]="Get",e[e.Post=1]="Post",e[e.Delete=2]="Delete",e[e.Put=3]="Put",e[e.Options=4]="Options",e[e.Head=5]="Head"}(le||(le={}));class De{constructor(e,t){this.serialNumber=e,this.pin=t,this.SerialNumber=e,this.PIN=t}}!function(e){e[e.ByCloud=0]="ByCloud",e[e.LocalNetwork=1]="LocalNetwork",e[e.P2P=2]="P2P"}(de||(de={})),function(e){e[e.FailedToConnect=0]="FailedToConnect",e[e.AuthorizationFailed=1]="AuthorizationFailed",e[e.FailedToConnectToServer=2]="FailedToConnectToServer",e[e.Connected=3]="Connected",e[e.ControllerIsNotConnected=4]="ControllerIsNotConnected"}(he||(he={})),function(e){e[e.Disconnected=0]="Disconnected",e[e.Connecting=1]="Connecting",e[e.Connected=3]="Connected",e[e.Disconnecting=4]="Disconnecting",e[e.Failed=5]="Failed",e[e.Reconnecting=6]="Reconnecting",e[e.ConnectedAndAuthorized=7]="ConnectedAndAuthorized"}(pe||(pe={}));class ke{constructor(e,t,n=ge.Production){this.BrokerUrl=e,this.BrokerControllerUrl=t,this.Env=n}}!function(e){e[e.Production=0]="Production",e[e.Development=1]="Development",e[e.Local=2]="Local"}(ge||(ge={}));class Ie extends Error{constructor(e){super(e),this.name="StreamError"}}class Ee{constructor(){this._log=gy.Get(a.ServiceName),this.handlers=[]}Subscribe(e){this.handlers.includes(e)||this.handlers.push(e)}Unsubscribe(e){this.handlers=this.handlers.filter((t=>t!==e))}Invoke(){this.handlers.slice(0).forEach((e=>{try{e()}catch(e){this._log.Error(e)}}))}}!function(e){e.CannotExportConfiguration="CannotExportConfiguration"}(fe||(fe={})),(Te=ve||(ve={}))[Te.Any=0]="Any",Te[Te.Guest=10]="Guest",Te[Te.Standard=20]="Standard",Te[Te.Admin=30]="Admin",Te[Te.Installator=40]="Installator",Te[Te.Support=50]="Support",(Ce=ye||(ye={}))[Ce.Unknown=0]="Unknown",Ce[Ce.Men=1]="Men",Ce[Ce.Woman=2]="Woman",Ce[Ce.Other=3]="Other",function(e){e[e.En_Us=0]="En_Us",e[e.Pl_Pl=1]="Pl_Pl"}(me||(me={})),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"}(we||(we={}));class be{constructor(e,t){this._type=Se.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 Ne{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"}(Se||(Se={})),function(e){e[e.Device=1]="Device",e[e.Person=2]="Person",e[e.DevicesGroups=3]="DevicesGroups"}(Ae||(Ae={}));class Ge{constructor(){this._guid="",this._ownerGuid="",this._ownerIdentity="",this._base64Image="",this._imageType=Ae.Device,this._dateTime=""}get Guid(){return this._guid}get OwnerGuid(){return this._ownerGuid}get OwnerIdentity(){return this._ownerIdentity}get Base64Image(){return this._base64Image}get ImageType(){return this._imageType}get DateTime(){return this._dateTime}set Base64Image(e){this._base64Image=e}set Guid(e){this._guid=e}set OwnerGuid(e){this._ownerGuid=e}set OwnerIdentity(e){this._ownerIdentity=e}set ImageType(e){this._imageType=e}}var Re=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 Pe{constructor(){this._imageExistsCaseNumber=0,this._connection=gy.Get(bt.ServiceName),this._logger=gy.Get(a.ServiceName)}GetServiceName(){return Pe.ServiceName}AddPictureAsync(e){return Re(this,void 0,void 0,(function*(){var t,n;try{if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Pe.ServiceName,"Cannot add picture - Base64Imgae size exceeded."),ue.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(Pe.ServiceName,"Cannot add picture - cannot load image - ensure that given base64 string is an image!"),ue.WrongData;if(0===r.height||0===r.width)return this._logger.Error(Pe.ServiceName,"Cannot add picture - cannot read width/height of image - ensure that given base64 string is an image!"),ue.WrongData;if(null!=e.Guid&&""!=e.Guid)return this._logger.Error(Pe.ServiceName,"Cannot add picture - Guid must be empty."),ue.WrongData;const o=new Oe;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 xe(o.Guid),8e3,!1);if(null==i||null==i.Status)return this._logger.Error(Pe.ServiceName,"Cannot add picture - unknown error!"),ue.UnknownError;if(i.Status==ue.ResourceDoesNotExists){const e=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Be(o),8e3,!1);return null==e||null==e.Status?(this._logger.Error(Pe.ServiceName,"Cannot add picture - unknown error!"),ue.UnknownError):e.Status}return i.Status==ue.OK?(this._logger.Warning(Pe.ServiceName,"Cannot add picture - picture already exists, trying to add with regenerated GUID."),this._imageExistsCaseNumber<2?(this._imageExistsCaseNumber++,this.AddPictureAsync(e)):ue.UnknownError):(this._logger.Error(Pe.ServiceName,"Cannot add picture - cannot get current picture status."),ue.Error)}catch(e){return this._logger.Error(Pe.ServiceName,`Cannot add picture! ${e}`),ue.FatalError}}))}EditPictureAsync(e){return Re(this,void 0,void 0,(function*(){var t,n,r,s;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Pe.ServiceName,"Cannot edit picture - guid is empty."),ue.WrongData;if(e.Base64Image.length*(3/4)>=512e3)return this._logger.Error(Pe.ServiceName,"Cannot edit picture - Base64Imgae size exceeded."),ue.WrongData;let o=new Image;const i=new Promise(((t,n)=>{o.src=e.Base64Image,o.onload=function(){t(!0)},setTimeout((()=>t(!1)),5e3)}));if(!(yield i))return this._logger.Error(Pe.ServiceName,"Cannot edit picture - cannot load image - ensure that given base64 string is an image!"),ue.WrongData;if(0===o.height||0===o.width)return this._logger.Error(Pe.ServiceName,"Cannot edit picture - cannot read width/height of image - ensure that given base64 string is an image!"),ue.WrongData;const a=new Oe;a.DateTime=(new Date).toISOString(),a.ImageType=e.ImageType,a.Base64Image=e.Base64Image,a.Guid=e.Guid,e.Guid.includes("profilePicture")||e.Guid.includes("devices_group")?a.OwnerGuid=e.OwnerGuid:a.OwnerGuid=`${e.OwnerGuid}_${e.OwnerIdentity}`;const c=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new xe(a.Guid),8e3,!1);if(null===(n=u.Log)||void 0===n||n.Error(Pe.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),null==c||null==c.Status)return this._logger.Error(Pe.ServiceName,"Cannot edit picture - unknown error!"),ue.UnknownError;if(c.Status==ue.ResourceDoesNotExists)return this._logger.Error(Pe.ServiceName,"Cannot edit picture - picture not exists."),ue.OperationNotPermitted;if(c.Status==ue.OK){const e=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new Be(a),8e3,!1);return null===(s=u.Log)||void 0===s||s.Error(Pe.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EditPictureAsync()"),gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),null==e||null==e.Status?(this._logger.Error(Pe.ServiceName,"Cannot edit picture - unknown error!"),ue.UnknownError):e.Status}return this._logger.Error(Pe.ServiceName,"Cannot edit picture - cannot get current picture status."),ue.Error}catch(e){return this._logger.Error(Pe.ServiceName,`Cannot edit picture! ${e}`),ue.FatalError}}))}DeletePictureAsync(e){return Re(this,void 0,void 0,(function*(){var t,n;try{if(""==e.Guid||null==e.Guid)return this._logger.Error(Pe.ServiceName,"Cannot delete picture - guid is empty."),ue.WrongData;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new We(e.Guid),8e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Pe.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DeletePictureAsync()"),gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),null==r||null==r.Status?(this._logger.Error(Pe.ServiceName,"Cannot delete picture - unknown error!"),ue.UnknownError):r.Status}catch(e){return this._logger.Error(Pe.ServiceName,`Cannot delete picture! ${e}`),ue.FatalError}}))}GetPicturesInfoAsync(){return Re(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Fe,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Pe.ServiceName,"Cannot get pictures info - unknown error!"),new Ne(ue.UnknownError,"NoDataInResult")):t.Status!=ue.OK?(this._logger.Error(Pe.ServiceName,`Cannot get pictures info - controler responded with status ${t.Status}.`),new Ne(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Pe.ServiceName,"Cannot get pictures info - controler responded with OK, but no data in result.}."),new Ne(ue.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Me;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(Pe.ServiceName,`Cannot get picture info! ${e}`),new Ne(ue.FatalError,"ExceptionOccurred")}}))}GetPictureAsync(e){return Re(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new xe(e),8e3,!1);if(null==n||null==n.Status)return this._logger.Error(Pe.ServiceName,"Cannot get picture - unknown error!"),new Ne(ue.UnknownError,"NoDataInResult");switch(n.Status){case ue.ResourceDoesNotExists:return new Ne(ue.ResourceDoesNotExists,"PictureNotFound");case ue.OK:if(null==n.Data)return new Ne(ue.Error,"RespondedWithOKButNoData");const e=new Ue;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 Ne(n.Status,"UnknownReason")}}catch(e){return this._logger.Error(Pe.ServiceName,`Cannot get picture! ${e}`),new Ne(ue.FatalError,"ExceptionOccurred")}}))}GetPicturesListAsync(){return Re(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Le,8e3,!1);return null==t||null==t.Status?(this._logger.Error(Pe.ServiceName,"Cannot get pictures - unknown error!"),new Ne(ue.UnknownError,"NoDataInResult")):t.Status!=ue.OK?(this._logger.Error(Pe.ServiceName,`Cannot get pictures - controler responded with status ${t.Status}.`),new Ne(t.Status,"UnknownReason")):null==t.Data?(this._logger.Error(Pe.ServiceName,"Cannot get pictures - controler responded with OK, but no data in result.}."),new Ne(ue.UnknownError,"NoDataInResult")):t.Data.map((e=>{const t=new Ue;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(Pe.ServiceName,`Cannot get pictures! ${e}`),new Ne(ue.FatalError,"ExceptionOccurred")}}))}}Pe.ServiceName="PictureService";class Ue extends Ge{set DateTime(e){this._dateTime=e}}class Oe{constructor(){this.Guid="",this.OwnerGuid="",this.Base64Image="",this.ImageType=Ae.Device,this.DateTime=""}}class Me{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 xe extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Get,this.Data=e}}class Fe extends ce{constructor(){super(),this.Resource="/pictures/info",this.Method=le.Get}}class Le extends ce{constructor(){super(),this.Resource="/pictures/list",this.Method=le.Get}}class Be extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Put,this.Data=e}}class We extends ce{constructor(e){super(),this.Resource="/pictures/picture",this.Method=le.Delete,this.Data=e}}class $e{constructor(){this._log=gy.Get(a.ServiceName),$e._localStorageService=gy.Get(l.ServiceName)}GetServiceName(){return $e.ServiceName}GetResourceName(e){return`${e.Resource}${e.Method}`}Cache(e){var t;e.Status===ue.OK&&(this._log.Debug($e.ServiceName,`Caching request: ${e.Resource} ${e.Method}`),null===(t=$e._localStorageService)||void 0===t||t.Save(this.GetServiceName(),this.GetResourceName(e),e))}GetCache(e){var t;let n=null===(t=$e._localStorageService)||void 0===t?void 0:t.Read(this.GetServiceName(),this.GetResourceName(e));return null!=n&&this._log.Debug($e.ServiceName,`Got request response from cache: ${e.Resource} ${e.Method}`),null==n?null:Object.assign(Object.assign({},n),{TransactionId:e.TransactionId})}ClearCache(){var e;null===(e=$e._localStorageService)||void 0===e||e.DropStorage(this.GetServiceName()),this._log.Debug($e.ServiceName,`Clearing cache for ${this.GetServiceName()}`)}Remove(e){var t;null===(t=$e._localStorageService)||void 0===t||t.Remove(this.GetServiceName(),this.GetResourceName(e)),this._log.Debug($e.ServiceName,`Clearing cache for cache: ${e.Resource} ${e.Method}`)}}$e._localStorageService=null,$e.ServiceName="WebApiCacheService";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 qe{constructor(){this._connection=null,this._connection=gy.Get(bt.ServiceName),this._pictureService=gy.Get(Pe.ServiceName),this._sessionService=gy.Get(Qe.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 ve.Support:return n===ve.Support;case ve.Installator:return n>=ve.Installator;case ve.Admin:default:return n>=ve.Admin}}GetServiceName(){return qe.ServiceName}GetUsersAsync(){return Ve(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ze,2e4,!1);if(null==n)return Promise.resolve([]);if((null==n?void 0:n.Status)==ue.OK){if(null!=n.Data){const e=[];return n.Data.forEach((t=>{var n=new Xe;n.AccessLevel=t.AccessLevel,n.Email=t.Email,n.Gender=t.Gender,n.Guid=t.Guid,n.IsAccountOnline=t.IsAccountOnline,n.Name=t.Name,n.IsActive=t.IsActive,n.IsBanned=t.IsBanned,n.Phone=t.Phone,n.Surname=t.Surname,e.push(n)})),e}return Promise.resolve([])}if((null==n?void 0:n.Status)==ue.NoData)return Promise.resolve([]);throw null===(t=u.Log)||void 0===t||t.Debug(qe.ServiceName,`Failed to retrieve users, error: ${n.Status}`),new Error(`Failed to retrieve users, error: ${n.Status}`)}))}GetUserAsync(e){return Ve(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 He(e),2e4,!1);if(null==r||null==r.Data)return Promise.resolve(null);if(r.Status!=ue.OK)return null===(n=u.Log)||void 0===n||n.Debug(qe.ServiceName,`Failed to retrieve user, error: ${r.Status}`),Promise.resolve(null);const s=new Xe;return s.AccessLevel=r.Data.AccessLevel,s.Email=r.Data.Email,s.Gender=r.Data.Gender,s.Guid=r.Data.Guid,s.IsAccountOnline=r.Data.IsAccountOnline,s.Name=r.Data.Name,s.IsActive=r.Data.IsActive,s.IsBanned=r.Data.IsBanned,s.Phone=r.Data.Phone,s.Surname=r.Data.Surname,s}))}CreateUserAsync(e,t){return Ve(this,void 0,void 0,(function*(){var n;if(null!=e.Guid&&""!=e.Guid)return new Ne(ue.WrongData,"GuidMustBeEmpty");const r=new Ke;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 je(r),2e4,!1);return gy.Get($e.ServiceName).ClearCache(),null==s||null==s.Status?new Ne(ue.FatalError,"UnknownError"):(null==s.Data&&(s.Data=""),new Ne(s.Status,s.Data))}))}UpdateUserAsync(e){return Ve(this,void 0,void 0,(function*(){var t;if(null==e.Guid||""==e.Guid)return new Ne(ue.WrongData,"GuidCannotBeEmpty");const n=new Ke;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 je(n),2e4,!1);return gy.Get($e.ServiceName).ClearCache(),null==r||null==r.Status?new Ne(ue.FatalError,"UnknownError"):(null==r.Data&&(r.Data=""),new Ne(r.Status,r.Data))}))}ChangePasswordAsync(e,t){return Ve(this,void 0,void 0,(function*(){var n;if(null==e.Guid||""==e.Guid)return new Ne(ue.WrongData,"GuidCannotBeEmpty");const r=yield this.GetUserAsync(e.Guid);if(null==r)return new Ne(ue.ResourceIsNotAvailable,"CannotGetUser");const s=new Ke;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 je(s),2e4,!1);return null==o||null==o.Status?new Ne(ue.FatalError,"UnknownError"):(null==o.Data&&(o.Data=""),new Ne(o.Status,o.Data))}))}DeleteUserAsync(e){return Ve(this,void 0,void 0,(function*(){var t,n,r;if(""===e)return ue.WrongData;null==e&&(e="");try{const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Je(e),2e4,!1);return gy.Get($e.ServiceName).ClearCache(),null==r||null==r.Status?ue.FatalError:(r.Status!=ue.OK&&(null===(n=u.Log)||void 0===n||n.Debug(qe.ServiceName,`Failed to delete user, error: ${r.Status}`)),r.Status)}catch(e){return null===(r=u.Log)||void 0===r||r.Error(qe.ServiceName,`Failed to delete user: ${e}`),ue.FatalError}}))}GetUserProfilePictureAsync(e){return Ve(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ne(ue.WrongData,"GuidCannotBeEmpty");const t=yield this._pictureService.GetPicturesInfoAsync();if(null!=t.Type)return t;const n=t.find((t=>"profilePicture"==t.OwnerIdentity&&t.OwnerGuid==e.Guid));if(null!=n){const e=yield this._pictureService.GetPictureAsync(n.Guid);return gy.Get($e.ServiceName).ClearCache(),e.Type,e}return new Ne(ue.ResourceDoesNotExists,"PictureNotFound")}))}SetUserProfilePictureAsync(e,t){return Ve(this,void 0,void 0,(function*(){if(null==e.Guid||""==e.Guid)return new Ne(ue.WrongData,"GuidCannotBeEmpty");let n=new Ge;n.ImageType=Ae.Person,n.OwnerGuid=e.Guid,n.OwnerIdentity="profilePicture",n.Base64Image=t;const r=yield this.GetUserProfilePictureAsync(e);if(gy.Get($e.ServiceName).ClearCache(),r.Type==ue.ResourceDoesNotExists){const e=yield this._pictureService.AddPictureAsync(n);return e===ue.OK?new Ne(ue.OK,"PictureSet"):new Ne(e,"PictureServiceError")}if(null!=r.Type)return new Ne(ue.Error,"ErrorWhenTryingToCheckIfCurrentProfilePictureExists");{n.Guid=r.Guid,n.OwnerGuid=r.OwnerGuid;const e=yield this._pictureService.EditPictureAsync(n);return e===ue.OK?new Ne(ue.OK,"PictureSet"):new Ne(e,"PictureServiceError")}}))}}qe.ServiceName="UsersService";class He extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Get,this.Data=e}}class Ke{constructor(){this.Guid="",this.Name="",this.Surname="",this.Email="",this.Password="",this.Phone="",this.Gender=ye.Unknown,this.AccessLevel=ve.Any}}class je extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Put,this.Data=e}}class ze extends ce{constructor(){super(),this.Resource="/users/list",this.Method=le.Get}}class Je extends ce{constructor(e){super(),this.Resource="/users/user",this.Method=le.Delete,this.Data=e}}class Xe{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=ye.Unknown,this._accessLevel=ve.Any,this._localization=me.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 gy.Get(qe.ServiceName).GetUserProfilePictureAsync({Guid:this._guid})}SetUserProfilePictureAsync(e){return gy.Get(qe.ServiceName).SetUserProfilePictureAsync({Guid:this._guid},e)}}var Ye=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Qe{constructor(){this._onUserLoggedInEvent=new c,this._onUserLoggedOutEvent=new c,this._email="",this._password="",this._authToken="",this._alreadySubsribedToNetworkEvents=!1,this._isLoggedIn=!1,this._user=null}isLoginError(e){return"number"==typeof e&&void 0!==we[e]}RestoreSessionAsync(){return Ye(this,void 0,void 0,(function*(){var e,t,n;if(null===(e=u.Log)||void 0===e||e.Debug(Qe.ServiceName,`Creating RestoreSessionAsync ${this._email} ${this._password}`),void 0===this._user||null===this._user||!this._isLoggedIn)return!1;let r=yield this.UserLogInAsync(this._email,this._password);if(this.isLoginError(r)){if(null===(t=u.Log)||void 0===t||t.Error(Qe.ServiceName,"RestoreSessionAsync failed, user login failed"),r==we.WrongAuthData)throw new Error("Wrong authentication data!");return!1}return null===(n=u.Log)||void 0===n||n.Debug(Qe.ServiceName,"RestoreSessionAsync completed successfully"),!0}))}WaitForSessionCreationAsync(){return Ye(this,void 0,void 0,(function*(){return new Promise((e=>{if(this._isLoggedIn&&null!=this._user)return e();const t=n=>{this._onUserLoggedInEvent.Unsubscribe(t),e()};this._onUserLoggedInEvent.Subscribe(t)}))}))}OnUserLoggedInEvent(){return this._onUserLoggedInEvent}OnUserLoggedOutEvent(){return this._onUserLoggedOutEvent}get User(){return this._user}UserLogOutAsync(){return Ye(this,void 0,void 0,(function*(){var e,t;let n=new ce;n.Resource="/users/user/logout",n.Method=le.Put,this._email="",this._password="",(yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(n,2e4,!1)).Status==ue.OK?(this._onUserLoggedOutEvent.Invoke(this._user),null===(e=u.Log)||void 0===e||e.Debug(Qe.ServiceName,"User has been logged out."),this._user=null,gy.Get($e.ServiceName).ClearCache()):null===(t=u.Log)||void 0===t||t.Debug(Qe.ServiceName,"Failed to logout user!")}))}AuthorizeAppAsync(e){return Ye(this,void 0,void 0,(function*(){var t,n,r,s,o;let i=gy.Get(bt.ServiceName);const a=yield i.SendAndWaitForResponseAsync(new et(e),2e4,!1);if(a.Status==ue.OK&&null!=a.Data){const r=!this._isLoggedIn||(null===(t=this._user)||void 0===t?void 0:t.Guid)!==a.Data.Guid;this._authToken=e;let s=new Xe;this._user=s,s.AccessLevel=a.Data.AccessLevel,s.Email=a.Data.Email,this._email=a.Data.Email,s.Gender=a.Data.Gender,s.Guid=a.Data.Guid,s.IsAccountOnline=a.Data.IsAccountOnline,s.Name=a.Data.Name,s.IsActive=a.Data.IsActive,s.IsBanned=a.Data.IsBanned,s.Phone=a.Data.Phone,s.Surname=a.Data.Surname,s.SoftwareVersion=a.Data.SoftwareVersion;let o=gy.Get(lt.ServiceName);return void 0!==a.Data.ConfigurationTime&&null!=a.Data.ConfigurationTime?(lt.ConfigurationTimeRetrieved=new Date(a.Data.ConfigurationTime),yield o.CheckIfConfigurationTimeHasChangedAsync(new Date(a.Data.ConfigurationTime))):yield o.CheckIfConfigurationHasChangedAsync(),r&&gy.Get($e.ServiceName).ClearCache(),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,gy.Get(bt.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>Ye(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Qe.ServiceName,`User logged out: ${JSON.stringify(e.Data)}`),this._isLoggedIn=!1,null===(n=this._onUserLoggedOutEvent)||void 0===n||n.Invoke(this._user),this._user=null,gy.Get($e.ServiceName).ClearCache()}))))),null===(n=u.Log)||void 0===n||n.Debug(Qe.ServiceName,`Did logging in succeded?: ${a.Status==ue.OK}`),this._isLoggedIn=!0,this._onUserLoggedInEvent.Invoke(this._user),s}return a.Status===ue.OperationNotPermitted?(null===(r=u.Log)||void 0===r||r.Debug(Qe.ServiceName,`App login response: ${a.Data}`),we.AuthDisabled):a.Status===ue.ResourceDoesNotExists?(null===(s=u.Log)||void 0===s||s.Debug(Qe.ServiceName,`App login response: ${a.Data}`),we.MethodNotSupported):(null===(o=u.Log)||void 0===o||o.Debug(Qe.ServiceName,`App login response: ${a.Data}`),we.WrongAuthData)}))}UserLogInAsync(e,t){return Ye(this,void 0,void 0,(function*(){var n,r,s;let o=gy.Get(bt.ServiceName);const i=yield o.SendAndWaitForResponseAsync(new tt(e,t),2e4,!1);if(i.Status==ue.OK&&null!=i.Data){const s=!this._isLoggedIn||(null===(n=this._user)||void 0===n?void 0:n.Guid)!==i.Data.Guid;this._email=e,this._password=t;let o=new Xe;this._user=o,o.AccessLevel=i.Data.AccessLevel,o.Email=i.Data.Email,o.Gender=i.Data.Gender,o.Guid=i.Data.Guid,o.IsAccountOnline=i.Data.IsAccountOnline,o.Name=i.Data.Name,o.IsActive=i.Data.IsActive,o.IsBanned=i.Data.IsBanned,o.Phone=i.Data.Phone,o.Surname=i.Data.Surname,o.SoftwareVersion=i.Data.SoftwareVersion;let a=gy.Get(lt.ServiceName);return void 0!==i.Data.ConfigurationTime&&null!=i.Data.ConfigurationTime?(lt.ConfigurationTimeRetrieved=new Date(i.Data.ConfigurationTime),yield a.CheckIfConfigurationTimeHasChangedAsync(new Date(i.Data.ConfigurationTime))):yield a.CheckIfConfigurationHasChangedAsync(),s&&gy.Get($e.ServiceName).ClearCache(),this._alreadySubsribedToNetworkEvents||(this._alreadySubsribedToNetworkEvents=!0,gy.Get(bt.ServiceName).SubscribeTo("/info/users/user/loggedOut",(e=>Ye(this,void 0,void 0,(function*(){var t,n;null===(t=u.Log)||void 0===t||t.Debug(Qe.ServiceName,`User logged out: ${JSON.stringify(e.Data)}`),this._isLoggedIn=!1,null===(n=this._onUserLoggedOutEvent)||void 0===n||n.Invoke(this._user),this._user=null,gy.Get($e.ServiceName).ClearCache()}))))),null===(r=u.Log)||void 0===r||r.Debug(Qe.ServiceName,`Did logging in succeded?: ${i.Status==ue.OK}`),this._isLoggedIn=!0,this._onUserLoggedInEvent.Invoke(this._user),o}return null===(s=u.Log)||void 0===s||s.Debug(Qe.ServiceName,`User login response: ${i.Data}`),we.WrongAuthData}))}GetServiceName(){return Qe.ServiceName}}Qe.ServiceName="SessionService";class Ze{constructor(e,t){this.Email="",this.Password="",this.Email=e,this.Password=t}}class et extends ce{constructor(e){super(),this.Data=e,this.Resource="/applications/app/auth",this.Method=le.Put}}class tt extends ce{constructor(e,t){super(),this.Data=new Ze(e,t),this.Resource="/users/user/login",this.Method=le.Put}}class nt{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.IsLocked=()=>this._running>0,this.AcquireAsync=()=>this._running<this.initialCount?(this._running++,Promise.resolve({Release:this.Release})):new Promise(((e,t)=>{this._waiting.push({Resolve:e,Reject:t})})),this.Release=()=>{if(0===this._running)throw new Error("Release called more times than AcquireAsync");this._running--,this.Take()},this.Purge=()=>{this._waiting.forEach((e=>{e.Reject(new Error("The semaphore was purged and as a result this task has been cancelled"))})),this._running=0,this._waiting=[]},e<1)throw new Error(`The semaphore was created with a max value of ${e} but the max value cannot be less than 1`)}}var 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{constructor(){this._extensionInfoCache=new Map,this._protocolInfoCache=new Map,this._isExtensionInfoInitialized=!1,this._semaphore=new nt(1)}GetServiceName(){return st.ServiceName}GetExtensionsInfoAsync(e){return rt(this,arguments,void 0,(function*(e,t=!1){var n;null===(n=u.Log)||void 0===n||n.Debug(st.ServiceName,`Getting ExtensionsInfo, data loaded from cache: ${!t}`);let r=yield this._semaphore.AcquireAsync();try{this._isExtensionInfoInitialized&&!t||(yield this.GetExtensionInfoFromControllerAsync())}finally{r.Release()}if(0==[...this._extensionInfoCache.values()].length)return[];if(null!=e){const t=this._extensionInfoCache.get(e);if(null==t)throw new at("Cannot get ExtensionsInfo, extension not found.");return[t]}return[...this._extensionInfoCache.values()]}))}GetProtocolInfoAsync(e){return rt(this,arguments,void 0,(function*(e,t=!1,n=!1){var r;if(null===(r=u.Log)||void 0===r||r.Debug(st.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 at("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 at("Cannot get ProtocolInfo, extension not found.");return[t]}return[...this._protocolInfoCache.values()]}))}GetExtensionInfoFromControllerAsync(){return rt(this,void 0,void 0,(function*(){const e=new ot,t=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(e,16e3,!1);if(null==t||null==t.Status)throw new at("Cannot get ExtensionsInfo from controller, controller response does not contain data!");if(t.Status!=ue.OK)throw new at(`Cannot get ExtensionsInfo from controller! Response status: ${t.Status}`);if(null==t.Data)throw new at("Cannot get ExtensionsInfo from controller, controller response does not contain data!");this._extensionInfoCache.clear(),t.Data.forEach((e=>{this._extensionInfoCache.set(e.ExtensionGuid,e)})),0!=[...this._extensionInfoCache.values()].length&&(this._isExtensionInfoInitialized=!0)}))}GetProtocolExtensionInfoFromControllerAsync(){return rt(this,void 0,void 0,(function*(){var e;const t=new it,n=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(t,16e3,!1);if(null==n||null==n.Status)throw new at("Cannot get ProtocolInfo from controller, controller response does not contain data!");switch(n.Status){case ue.OK:if(null==n.Data)throw new at("Cannot get ProtocolInfo from controller, controller response does not contain data!");this._protocolInfoCache.clear(),n.Data.forEach((e=>{this._protocolInfoCache.set(e.PublicGuid,e)}));break;case ue.ResourceDoesNotExists:null===(e=u.Log)||void 0===e||e.Debug(st.ServiceName,"Cannot get ProtocolInfo from controller, controller software does not implement this yet, update controller to the newest software!");break;default:throw new at(`Cannot get ProtocolInfo from controller! Response status: ${n.Status}`)}}))}}st.ServiceName="StatisticsInfoService";class ot extends ce{constructor(){super(),this.Resource="/controller/extensions/",this.Method=le.Get}}class it extends ce{constructor(){super(),this.Resource="/controller/protocols/",this.Method=le.Get}}class at extends Error{constructor(e){super(e),this.message=e,this.name="CannotGetExtensions"}}var ct,ut=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 lt{OnConfigurationChangedEvent(){return this._onConfigurationChangedEvent}GetServiceName(){return lt.ServiceName}constructor(){this._connection=null,this._session=null,this._localStorage=null,this._onEnteredConfigurationEvent=new Ee,this._onExitedConfigurationEvent=new Ee,this._onConfigurationTimeCheckedEvent=new c,this._configurationTime=new Date,this._appEnteredConfigurationMode=!1,this._didConfigurationChange=!0,this._didSynchronization=!1,this._onSynchronized=new Ee,this._onConfigurationChangedEvent=new Ee,this._connection=gy.Get(bt.ServiceName),this._session=gy.Get(Qe.ServiceName),this._localStorage=gy.Get(l.ServiceName),this._connection.SubscribeTo("/info/configuration/mode/entry",(e=>{gy.Get($e.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onEnteredConfigurationEvent.Invoke()})),this._connection.SubscribeTo("/info/configuration/mode/exit",(e=>{var t;gy.Get($e.ServiceName).ClearCache(),this._appEnteredConfigurationMode||this._onExitedConfigurationEvent.Invoke(),null===(t=this.OnConfigurationChangedEvent())||void 0===t||t.Invoke()}))}CheckIfControllerSoftwareVersionIsEnough(e,t){var n,r,s;const o=null!==(s=null===(r=null===(n=this._session)||void 0===n?void 0:n.User)||void 0===r?void 0:r.SoftwareVersion)&&void 0!==s?s:null;if(!o||!o.includes("."))return!1;const i=o.split(".");if(2!==i.length)return!1;const a=i.map((e=>parseInt(e,10)));if(a.some((e=>Number.isNaN(e)||e<0)))return!1;const[c,u]=a;return c>e||c===e&&u>=t}ImportControllerConfigurationAsync(e){return ut(this,void 0,void 0,(function*(){var t,n,r;let s=yield e.text(),o=this.SplitStringBySize(s),i=new dt("");i.Status=ue.MultiDataResponseStart;let a=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(i,6e3,!1);if(void 0===a||(null==a?void 0:a.Status)!=ue.OK)return ue.Error;for(const e of o){let t=new dt(e);t.Status=ue.MultiDataResponse;let r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(t,6e3,!1);if(void 0===r||(null==r?void 0:r.Status)!=ue.OK)return ue.Error}i.Status=ue.MultiDataResponseStop;let c=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(i,12e4,!1);return void 0===c||(null==c?void 0:c.Status)!=ue.OK?ue.Error:ue.OK}))}SplitStringBySize(e,t=1e5){const n=Math.floor(t/2),r=[];let 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 ut(this,void 0,void 0,(function*(){var e,t;try{let t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new wt,8e3,!1);return null==t||null==t.Status?ue.Error:t.Status!=ue.OK?t.Status:null==t.Data?ue.ResourceIsNotAvailable:new Date(t.Data)}catch(e){return null===(t=u.Log)||void 0===t||t.Error(lt.ServiceName,`Cannot get current controller time! ${e}`),ue.FatalError}}))}SetControllerSystemTimeAsync(e){return ut(this,void 0,void 0,(function*(){var t,n;try{let n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new St(e.toISOString()),8e3,!1);return null==n||null==n.Status?ue.Error:n.Status}catch(e){return null===(n=u.Log)||void 0===n||n.Error(lt.ServiceName,`Cannot set current controller time! ${e}`),ue.FatalError}}))}StartNtpTimeSynchronizationAsync(){return ut(this,void 0,void 0,(function*(){var e,t;try{let t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new At,8e3,!1);return null==t||null==t.Status?ue.Error:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(lt.ServiceName,`Cannot set current controller time! ${e}`),ue.FatalError}}))}FactoryResetAsync(e){return ut(this,void 0,void 0,(function*(){var t,n;try{gy.Get($e.ServiceName).ClearCache();let r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new gt,2e3,!1))||void 0===n?void 0:n.Status;if(r==ue.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),gy.Get($e.ServiceName).ClearCache(),clearInterval(s),ue.OK}return r}catch(e){return ue.FatalError}}))}RollbackLastUpdateAsync(e){return ut(this,void 0,void 0,(function*(){var t,n;try{gy.Get($e.ServiceName).ClearCache();let r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ft,2e3,!1))||void 0===n?void 0:n.Status;if(r==ue.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),gy.Get($e.ServiceName).ClearCache(),clearInterval(s),ue.OK}return r}catch(e){return ue.FatalError}}))}RestartControllerAsync(e){return ut(this,void 0,void 0,(function*(){var t,n;try{gy.Get($e.ServiceName).ClearCache();let r=null===(n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new pt,2e3,!1))||void 0===n?void 0:n.Status;if(r==ue.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),gy.Get($e.ServiceName).ClearCache(),clearInterval(s),ue.OK}return r}catch(e){return ue.FatalError}}))}DidCofigurationChangeAsync(){return ut(this,void 0,void 0,(function*(){return new Promise((e=>{var t;this._didSynchronization?e(this._didConfigurationChange):null===(t=this._onSynchronized)||void 0===t||t.Subscribe((()=>{e(this._didConfigurationChange)}))}))}))}GetLastKnownConfigurationChangeTime(){var e;const t=null===(e=this._localStorage)||void 0===e?void 0:e.Read(this.GetServiceName(),"last_configuration_time");return null!=t?new Date(t):new Date}SaveLastConfigurationChangeTime(e){var t;null===(t=this._localStorage)||void 0===t||t.Save(this.GetServiceName(),"last_configuration_time",e.toString())}EnterConfigurationModeAsync(){return ut(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,gy.Get($e.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new vt,2e4,!1)}))}ExitConfigurationModeAsync(){return ut(this,void 0,void 0,(function*(){var e;this._appEnteredConfigurationMode=!0,gy.Get($e.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new yt,2e4,!1),this._didConfigurationChange=!0,gy.Get($e.ServiceName).ClearCache(),this._appEnteredConfigurationMode=!1}))}OnEnteredConfigurationEvent(){return this._onEnteredConfigurationEvent}OnExitedConfigurationEvent(){return this._didConfigurationChange=!0,this._onExitedConfigurationEvent}OnConfigurationTimeCheckedEvent(){return this._onConfigurationTimeCheckedEvent}GetLastConfigurationChangeTimeAsync(){return ut(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new mt,2e4,!1);if(null==t||(null==t?void 0:t.Status)!=ue.OK)throw new Error("Failed to get last configuration change time");return this._configurationTime=new Date(t.Data),this._configurationTime}))}CheckIfConfigurationHasChangedAsync(){return ut(this,void 0,void 0,(function*(){var e,t,n,r;const s=yield this.GetLastConfigurationChangeTimeAsync();return null===(e=u.Log)||void 0===e||e.Info(lt.ServiceName,`Checking if configuration time has changed. Current: ${s.toString()}, Last known: ${this.GetLastKnownConfigurationChangeTime().toString()}`),this.GetLastKnownConfigurationChangeTime().toString()!=s.toString()?(this.SaveLastConfigurationChangeTime(s),gy.Get($e.ServiceName).ClearCache(),this._didSynchronization=!0,this._didConfigurationChange=!0,null===(t=this.OnConfigurationChangedEvent())||void 0===t||t.Invoke(),this._onConfigurationTimeCheckedEvent.Invoke(s),null===(n=this._onSynchronized)||void 0===n||n.Invoke(),!0):(this._didSynchronization=!0,this._didConfigurationChange=!1,null===(r=this._onSynchronized)||void 0===r||r.Invoke(),!1)}))}CheckIfConfigurationTimeHasChangedAsync(e){return ut(this,void 0,void 0,(function*(){var t,n,r,s;return null===(t=u.Log)||void 0===t||t.Info(lt.ServiceName,`Checking if configuration time has changed. Current: ${e.toString()}, Last known: ${this.GetLastKnownConfigurationChangeTime().toString()}`),this.GetLastKnownConfigurationChangeTime().toString()!=e.toString()?(this.SaveLastConfigurationChangeTime(e),gy.Get($e.ServiceName).ClearCache(),this._didSynchronization=!0,this._didConfigurationChange=!0,null===(n=this.OnConfigurationChangedEvent())||void 0===n||n.Invoke(),this._onConfigurationTimeCheckedEvent.Invoke(e),null===(r=this._onSynchronized)||void 0===r||r.Invoke(),!0):(this._didSynchronization=!0,this._didConfigurationChange=!1,null===(s=this._onSynchronized)||void 0===s||s.Invoke(),!1)}))}CanExportOrImportControllerConfigurationAsync(){return ut(this,void 0,void 0,(function*(){try{let e=yield gy.Get(st.ServiceName).GetExtensionsInfoAsync(),t=gy.Get(Qe.ServiceName).User;return null!=t&&null!=t.AccessLevel&&t.AccessLevel>=ve.Admin&&e.any((e=>"f4f0f066-7c43-46c6-a0bd-aedf93903dc0"==e.ExtensionGuid))}catch(e){return!1}}))}ExportControllerConfigurationAsync(){return ut(this,void 0,void 0,(function*(){var e;let t=[],n=null;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndHandleResponseAsync(new ht,3e4,(e=>{switch(e.Status){case ue.MultiDataResponseStart:break;case ue.MultiDataResponse:null!=e.Data&&void 0!==e.Data&&t.push(e.Data);break;case ue.MultiDataResponseStop:break;case ue.Error:case ue.FatalError:n=new Ne(fe.CannotExportConfiguration,"Cannot export configuration! Controller returned error!")}}),!0);let r=JSON.stringify(JSON.parse(t.join("")),null,2);return console.log(r),null!=n?n:gy.ExportStringAsFileToDownload(this.GetCurrentTimestampedFilename(),r)}))}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`}}lt.ServiceName="ControllerConfigurationService",lt.ConfigurationTimeRetrieved=null;class dt extends ce{constructor(e){super(),this.Resource="/configuration/backup/import",this.Method=le.Put,this.Data=e}}class ht extends ce{constructor(){super(),this.Resource="/configuration/backup/export",this.Method=le.Get}}class pt extends ce{constructor(){super(),this.Resource="/controller/restart",this.Method=le.Post}}class gt extends ce{constructor(){super(),this.Resource="/controller/factory_reset",this.Method=le.Post}}class ft extends ce{constructor(){super(),this.Resource="/controller/backups/restore/previous",this.Method=le.Post}}class vt extends ce{constructor(){super(),this.Resource="/system/configuration/mode/entry",this.Method=le.Put}}class yt extends ce{constructor(){super(),this.Resource="/system/configuration/mode/exit",this.Method=le.Put}}class mt extends ce{constructor(){super(),this.Resource="/system/configuration/change/time",this.Method=le.Get}}class wt extends ce{constructor(){super(),this.Resource="/system/time",this.Method=le.Get}}class St extends ce{constructor(e){super(),this.Resource="/system/time",this.Method=le.Put,this.Data=e}}class At extends ce{constructor(){super(),this.Resource="/system/time/ntp/update",this.Method=le.Put}}!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"}(ct||(ct={}));class _t{constructor(){this._promise=Promise.resolve(),this._disable=()=>{}}Lock(){this._promise=new Promise((e=>this._disable=e))}Unlock(){this._disable()}WaitForLockAsync(){return this._promise}}var Ct=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 Tt{constructor(){if(this._isConnectedAndAuthorized=!1,this._syncLock=new _t,this._isInFouces=!0,this._lastVisibilityState=null,this._canHibernate=!0,this._session=null,this._connection=null,this._currentAppState=ct.Disconnected,this._returnedFromSuspension=!1,this._onReturnedFromSuspensionEvent=new Ee,this._onSuspendedEvent=new Ee,this._onEnterLowPowerModeEvent=new Ee,this._onExitLowPowerModeEvent=new Ee,this._onBackButtonPressedEvent=new Ee,this._onForwardButtonPressedEvent=new Ee,this._onAppStateChanged=new c,this.MonitorAppState(),this._onAppStateChanged.Subscribe((e=>this._currentAppState=e)),this._lastVisibilityState=this.IsHidden(),null==navigator.userAgent.match(/Safari/i)||navigator.mediaDevices){const e=()=>Ct(this,void 0,void 0,(function*(){yield this._syncLock.WaitForLockAsync(),this._syncLock.Lock();try{const e=this.IsHidden();if(this._lastVisibilityState===e)return;this._lastVisibilityState=e,e?this.Suspend():this.ReturnFromSuspension()}finally{this._syncLock.Unlock()}}));document.addEventListener("visibilitychange",e),window.addEventListener("visibilitychange",e)}else{const e=()=>{this._isInFouces&&(this._isInFouces=!1,this.Suspend())},t=()=>{this._isInFouces||(this._isInFouces=!0,this.ReturnFromSuspension())};window.addEventListener("blur",e),window.addEventListener("onblur",e),window.addEventListener("focus",t),window.addEventListener("onfocus",t)}window.addEventListener("popstate",(e=>{var t,n,r,s;document.location,e.state&&("forward"==e.state.direction?(null===(t=u.Log)||void 0===t||t.Warning(Tt.ServiceName,"Forward button pressed"),null===(n=this._onForwardButtonPressedEvent)||void 0===n||n.Invoke()):(null===(r=u.Log)||void 0===r||r.Warning(Tt.ServiceName,"Back button pressed"),null===(s=this._onBackButtonPressedEvent)||void 0===s||s.Invoke()))}))}MonitorAppState(){return Ct(this,void 0,void 0,(function*(){this._session=yield gy.GetAsync("SessionService"),this._connection=yield gy.GetAsync("ExalusConnectionService"),this._session.OnUserLoggedInEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Tt.ServiceName,"App state changed to: logged in"),this._onAppStateChanged.Invoke(ct.LoggedIn)})),this._session.OnUserLoggedOutEvent().Subscribe((e=>{var t;null===(t=u.Log)||void 0===t||t.Warning(Tt.ServiceName,"App state changed to: logged out"),this._onAppStateChanged.Invoke(ct.LoggedOut)})),this._connection.OnConnectionStateChangedEvent().Subscribe((e=>{var t,n,r,s,o,i;switch(e){case pe.ConnectedAndAuthorized:null===(t=u.Log)||void 0===t||t.Warning(Tt.ServiceName,"App state changed to: connected"),this._isConnectedAndAuthorized=!0,this._onAppStateChanged.Invoke(ct.Connected);break;case pe.Disconnected:null===(n=u.Log)||void 0===n||n.Warning(Tt.ServiceName,"App state changed to: disconnected"),this._isConnectedAndAuthorized&&this._onAppStateChanged.Invoke(ct.Disconnected),this._isConnectedAndAuthorized=!1;break;case pe.Connecting:null===(r=u.Log)||void 0===r||r.Warning(Tt.ServiceName,"App state changed to: connecting"),this._onAppStateChanged.Invoke(ct.Connecting);break;case pe.Disconnecting:null===(s=u.Log)||void 0===s||s.Warning(Tt.ServiceName,"App state changed to: disconnecting"),this._onAppStateChanged.Invoke(ct.Disconnecting);break;case pe.Reconnecting:null===(o=u.Log)||void 0===o||o.Warning(Tt.ServiceName,"App state changed to: reconnecting"),this._onAppStateChanged.Invoke(ct.Reconnecting);break;case pe.Failed:null===(i=u.Log)||void 0===i||i.Warning(Tt.ServiceName,"App state changed to: failed"),this._onAppStateChanged.Invoke(ct.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(ct.Suspended),null===(e=u.Log)||void 0===e||e.Warning(Tt.ServiceName,"App state changed to: suspended"),null===(t=u.Log)||void 0===t||t.Warning(Tt.ServiceName,"App switched to background"))}ReturnFromSuspension(){var e,t;this.IsHibernationAllowed()&&(this._returnedFromSuspension=!0,this._onReturnedFromSuspensionEvent.Invoke(),this._onAppStateChanged.Invoke(ct.ReturnedFromSuspension),null===(e=u.Log)||void 0===e||e.Warning(Tt.ServiceName,"App state changed to: returned from suspension"),null===(t=u.Log)||void 0===t||t.Warning(Tt.ServiceName,"App switched to foreground"))}EnterLowPowerMode(){this._onEnterLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(ct.EnteredLowPowerMode)}ExitLowPowerMode(){this._onExitLowPowerModeEvent.Invoke(),this._onAppStateChanged.Invoke(ct.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 Tt.ServiceName}}Tt.ServiceName="AppStateService";var Dt=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class kt{nextRetryDelayInMilliseconds(){return 1e3}}const It=[t.WebSockets,t.ServerSentEvents,t.LongPolling];class Et{constructor(){this._log=gy.Get(a.ServiceName)}log(e,t){if(!(e<bt.SignalRLogLevel))switch(t=`[SignalR] ${t}`,e){case r.Critical:case r.Error:this._log.Error(t);break;case r.Warning:this._log.Warning(t);break;case r.Information:this._log.Info(t);break;default:this._log.Debug(t)}}}class bt{constructor(){this._connectTask=null,this._authorizeTask=null,this._pingTimerId=null,this._consecutivePingFailures=0,this._disconnectedOnPurpose=!1,this._address="packets-broker1.tr7.pl",this._serversBrokerAddress="https://servers-broker.tr7.pl",this._serversBrokerAddressList=["https://servers-broker.tr7.pl","https://broker.tr7.pl","https://dev-broker.tr7.pl"],this._allBrokersChecked=!1,this._packetsBrokerServers=["packets-broker1.tr7.pl","packets-broker2.tr7.pl"],this._connectedServerAddressResult=null,this._connectedServerAddressWaiters=[],this._isAuthorized=!1,this._lastReceivedPacket=Date.now(),this._everConnected=!1,this._pendingRequests=new Map,this._log=gy.Get(a.ServiceName),this._appState=gy.Get(Tt.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._dataReceivedEvent=new c,this._pongReceivedEvent=new Ee,this._authorizationReceivedEvent=new c,this._registrationReceivedEvent=new c,this._streamStartedEvent=new c,this._connectionStateChangedEvent=new c,this._errorOccuredEvent=new c,this._tryReconnect=()=>{this._connectTask||navigator.onLine&&this.validateConnectionToController().then((e=>{e||(this._log.Debug(bt.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))},this._onVisibility=()=>{this._connectTask||"visible"===document.visibilityState&&(this._log.Debug(bt.ServiceName,"Page visible → connection check"),this.validateConnectionToController().then((e=>{e||(this._log.Debug(bt.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())})))},this._onHidden=()=>{},this._onVisible=()=>{this._connectTask||this.validateConnectionToController().then((e=>{e||(this._log.Debug(bt.ServiceName,"Connection lost → reconnecting..."),this.serialisedConnect())}))},this._appState.OnAppStateChanged().Subscribe((e=>Dt(this,void 0,void 0,(function*(){var t;switch(this._log.Debug(bt.ServiceName,`App state changed: ${e}`),e){case ct.ExitedLowPowerMode:case ct.ReturnedFromSuspension:this._log.Debug(bt.ServiceName,`Handling app state change: ${e}`),(yield this.RestoreConnectionAsync())&&(null===(t=this._session)||void 0===t||t.RestoreSessionAsync());break;case ct.Connected:this.resolveConnectedBrokerInfo(this._serversBrokerAddress,this._address)}}))))}GetServiceName(){return bt.ServiceName}GetAuthorizationInfo(){return this._serialId&&this._PIN?new De(this._serialId,this._PIN):null}GetControllerSerialNumber(){return this._serialId}GetControllerPin(){return this._PIN}SetServersBrokerAddress(e){this._serversBrokerAddress=e}SetDefaultPacketsBrokerAddress(e){this._address=e}GetConnectedBrokerInfoAsync(){return Dt(this,arguments,void 0,(function*(e=8e3){return null!==this._connectedServerAddressResult?this._connectedServerAddressResult:new Promise(((t,n)=>{let r;const s=e=>{void 0!==r&&window.clearTimeout(r),t(e)};this._connectedServerAddressWaiters.push(s),null!==e&&(r=window.setTimeout((()=>{const e=this._connectedServerAddressWaiters.indexOf(s);e>=0&&this._connectedServerAddressWaiters.splice(e,1),n(new Error("GetConnectedBrokerInfoAsync timed out"))}),e))}))}))}EnablePacketsLogging(){window.packets=!0}DisablePacketsLogging(){window.packets=!1}SubscribeTo(e,t){const n=n=>{n.Resource===e&&t(n)};return this._dataReceivedEvent.Subscribe(n),()=>this._dataReceivedEvent.Unsubscribe(n)}reauthorizeIfPossible(){return Dt(this,void 0,void 0,(function*(){if(!this._serialId||!this._PIN)return this._isAuthorized=!1,!1;const e=yield this.AuthorizeAsync(new De(this._serialId,this._PIN));return this._isAuthorized=e,e}))}GetServerAddressAsync(){return Dt(this,void 0,void 0,(function*(){if(!this._serialId)return this._log.Warning(bt.ServiceName,"GetServerAddressAsync() – serialId not set"),null;const e=`${this._serversBrokerAddress}/api/connections/broker/whichserver/${this._serialId}`;try{const t=yield fetch(e);switch(t.status){case 200:{const e=(yield t.text()).trim();return e?(this._log.Debug(bt.ServiceName,`Broker address resolved: ${e}`),e):(this._log.Warning(bt.ServiceName,"Broker returned empty address"),null)}case 204:return this._allBrokersChecked?(this._log.Error(bt.ServiceName,"All servers-brokers checked, controller not found – likely offline"),null):(this._log.Warning(bt.ServiceName,`Servers-broker ${this._serversBrokerAddress} returned 204 (no content) – controller not found on this server`),yield this.rotateServersBroker(),this.GetServerAddressAsync());default:return this._log.Warning(bt.ServiceName,`GetServerAddressAsync() – HTTP ${t.status}`),null}}catch(e){return this._log.Error(bt.ServiceName,String(e)),null}}))}rotateServersBroker(){return Dt(this,void 0,void 0,(function*(){const e=this._serversBrokerAddressList.indexOf(this._serversBrokerAddress),t=e+1<this._serversBrokerAddressList.length?e+1:0;this._serversBrokerAddress=this._serversBrokerAddressList[t],this._allBrokersChecked=0===t,this._log.Info(bt.ServiceName,`Switching servers-broker to: ${this._serversBrokerAddress}`)}))}ConnectAsync(e){return Dt(this,void 0,void 0,(function*(){return this._address=e,this.serialisedConnect()}))}ConnectAndAuthorizeAsync(e){return Dt(this,void 0,void 0,(function*(){this.resetConnectedServerAddressResolution(),this._serialId=e.serialNumber,this._PIN=e.pin,gy.WorksInContextOf=this._serialId,this._allBrokersChecked=!1,this._serversBrokerAddress=this._serversBrokerAddressList[0];const t=yield this.GetServerAddressAsync();if(t&&(this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===he.Connected&&(yield this.AuthorizeAsync(e))))return he.Connected;for(const t of this._packetsBrokerServers)if(this._log.Info(bt.ServiceName,`Fallback broker: ${t}`),this.SetDefaultPacketsBrokerAddress(t),(yield this.serialisedConnect())===he.Connected&&(yield this.AuthorizeAsync(e)))return this._disconnectedOnPurpose=!1,he.Connected;return he.FailedToConnect}))}resetConnectedServerAddressResolution(){this._connectedServerAddressResult=null}resolveConnectedBrokerInfo(e,t){const n=this._serversBrokerAddress.includes("dev-broker.tr7.pl")&&!this._packetsBrokerServers.any((e=>{var t;return e.includes(null!==(t=this._currentAddress)&&void 0!==t?t:"")}));for(this._connectedServerAddressResult=new ke(e,t,n?ge.Development:ge.Production);this._connectedServerAddressWaiters.length>0;){const e=this._connectedServerAddressWaiters.shift();null==e||e(this._connectedServerAddressResult)}}AuthorizeAsync(e){return Dt(this,void 0,void 0,(function*(){return this._authorizeTask||(this._authorizeTask=new Promise((t=>Dt(this,void 0,void 0,(function*(){var n;const r=window.setTimeout((()=>{this._authorizationReceivedEvent.Unsubscribe(s),this._isAuthorized=!1,this._log.Debug(bt.ServiceName,`AuthorizeAsync timed out for id ${r}`),t(!1)}),2e3);this._log.Debug(bt.ServiceName,`AuthorizeAsync - created timeoutId ${r}`);const s=e=>{window.clearTimeout(r),this._authorizationReceivedEvent.Unsubscribe(s),this._log.Debug(bt.ServiceName,`Authorization → ${e}`),this._isAuthorized=e,e&&this._connectionStateChangedEvent.Invoke(pe.ConnectedAndAuthorized),this._log.Debug(bt.ServiceName,`AuthorizeAsync isAuthorized: ${e} cleared timeoutId ${r}`),t(e)};this._authorizationReceivedEvent.Subscribe(s),this._log.Debug(bt.ServiceName,`Authorizing to ${e.SerialNumber}... for timoeoutId ${r}`),yield null===(n=this._connection)||void 0===n?void 0:n.send("AuthorizeTo",e.SerialNumber,e.PIN)})))).finally((()=>{this._authorizeTask=null}))),this._authorizeTask}))}IsConnected(){var e;return(null===(e=this._connection)||void 0===e?void 0:e.state)===o.Connected}DisconnectAsync(){return Dt(this,void 0,void 0,(function*(){var e;this._disconnectedOnPurpose=!0,this._log.Debug(bt.ServiceName,"Disconnecting..."),yield null===(e=this._connection)||void 0===e?void 0:e.stop(),this.cleanup()}))}SendAsync(e){return Dt(this,arguments,void 0,(function*(e,t=!1){var n,r;if(!this.IsConnected())throw new Error("Not connected");const s=()=>Dt(this,void 0,void 0,(function*(){yield this._connection.invoke("SendTo",this._serialId,e)})),o=!0===window.packets;(o||t)&&this._log.Debug(bt.ServiceName,`⇢ ${e.Resource} ${e.Method} ${e.TransactionId}`+(o?`\n${JSON.stringify(e,null,2)}`:""));try{return yield s(),!0}catch(e){if(String(null!==(n=null==e?void 0:e.message)&&void 0!==n?n:e).toLowerCase().includes("unauthorized")){if(!(yield this.reauthorizeIfPossible())){this._allBrokersChecked=!1,this._serversBrokerAddress=this._serversBrokerAddressList[0];const e=yield this.GetServerAddressAsync();if(e&&e!==this._address){this._log.Info(bt.ServiceName,`Switching to resolved broker: ${e}`);try{yield null===(r=this._connection)||void 0===r?void 0:r.stop()}catch(e){}this.cleanup(),yield this.ConnectAsync(e),yield this.reauthorizeIfPossible()}}if(this.IsConnected()&&this._isAuthorized)try{return yield s(),!0}catch(t){e=t}}return this._log.Error(bt.ServiceName,String(e)),!1}}))}RestoreConnectionAsync(){return Dt(this,void 0,void 0,(function*(){var e,t;if(this._disconnectedOnPurpose)return!1;const n=this.GetAuthorizationInfo();if(null===n)return null===(e=u.Log)||void 0===e||e.Error(bt.ServiceName,"RestoreSessionAsync failed, no authorization info"),!1;const r=Date.now();let s=0;do{if(this.IsConnected()&&(yield this.AuthorizeAsync(n)))return!0;if((yield this.ConnectAndAuthorizeAsync(n))===he.Connected)return!0;const e=Math.min(3e4,5e3*Math.pow(2,s++));yield new Promise((t=>setTimeout(t,e))),this._allBrokersChecked=!1,this._serversBrokerAddress=this._serversBrokerAddressList[0]}while(Date.now()-r<18e5);return null===(t=u.Log)||void 0===t||t.Error(bt.ServiceName,"RestoreSessionAsync failed, authorization failed"),!1}))}SendAndWaitForResponseAsync(e,t,n){return Dt(this,arguments,void 0,(function*(e,t,n,r=!0,s=!0){var o,i,a;if(e.Method===le.Get&&n&&!(yield null===(o=this._controllerConfiguration)||void 0===o?void 0:o.DidCofigurationChangeAsync())){const t=null===(i=this._cache)||void 0===i?void 0:i.GetCache(e);if(t)return t}if(!this.IsConnected()&&!(yield this.RestoreConnectionAsync()))throw new Error("Failed to restore connection!");return"/users/user/login"!==e.Resource&&(yield null===(a=this._session)||void 0===a?void 0:a.WaitForSessionCreationAsync()),new Promise(((o,i)=>Dt(this,void 0,void 0,(function*(){const a=window.setTimeout((()=>{this._dataReceivedEvent.Unsubscribe(c),this._pendingRequests.delete(e.TransactionId),i(new I("Response timeout"))}),t),c=u=>{var l;u.TransactionId===e.TransactionId&&(window.clearTimeout(a),this._dataReceivedEvent.Unsubscribe(c),this._pendingRequests.delete(e.TransactionId),e.Method===le.Get&&n&&u.Status!==ue.UserIsNotLoggedIn&&(null===(l=this._cache)||void 0===l||l.Cache(u)),s&&u.Status===ue.UserIsNotLoggedIn?(()=>{Dt(this,void 0,void 0,(function*(){var s;try{yield null===(s=this._session)||void 0===s?void 0:s.RestoreSessionAsync(),o(yield this.SendAndWaitForResponseAsync(e,t,n,r,!1))}catch(e){i(e)}}))})():o(u))};this._dataReceivedEvent.Subscribe(c),this._pendingRequests.set(e.TransactionId,{resolve:e=>o(e),reject:i,timeoutId:a}),(yield this.SendAsync(e,r))||(window.clearTimeout(a),this._dataReceivedEvent.Unsubscribe(c),this._pendingRequests.delete(e.TransactionId),i(new Error("Failed to send request")))}))))}))}SendAndHandleResponseAsync(e,t,n){return Dt(this,arguments,void 0,(function*(e,t,n,r=!0){var s;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,o)=>Dt(this,void 0,void 0,(function*(){const i=()=>window.setTimeout((()=>{c(),o(new I("MultiDataResponse timeout"))}),t);let a=i();const c=()=>{window.clearTimeout(a),this._dataReceivedEvent.Unsubscribe(u),this._pendingRequests.delete(e.TransactionId)},u=t=>{if(t.TransactionId===e.TransactionId)switch(window.clearTimeout(a),t.Status){case ue.MultiDataResponseStart:case ue.MultiDataResponse:n(t),a=i();break;case ue.MultiDataResponseStop:case ue.OK:n(t),c(),s();break;default:c(),o(new Error(`Unexpected status ${t.Status}`))}};this._dataReceivedEvent.Subscribe(u),this._pendingRequests.set(e.TransactionId,{resolve:()=>s(),reject:o,timeoutId:a}),(yield this.SendAsync(e,r))||(c(),o(new Error("Failed to send request")))}))))}))}SendAndHandleStreamAsync(e,t){return Dt(this,arguments,void 0,(function*(e,t,n=!0){var r;if(!this.IsConnected())throw new Error("Connection is not established");return"/users/user/login"!==e.Resource&&(yield null===(r=this._session)||void 0===r?void 0:r.WaitForSessionCreationAsync()),new Promise(((r,s)=>Dt(this,void 0,void 0,(function*(){const o=window.setTimeout((()=>{this._streamStartedEvent.Unsubscribe(i),s(new I("Stream registration timeout"))}),8e3),i=n=>{n===e.TransactionId&&(window.clearTimeout(o),this._streamStartedEvent.Unsubscribe(i),this._connection.stream("WatchStream",n).subscribe({next:e=>t.Next(e),complete:()=>{t.Complete(),r()},error:e=>{t.Error(e),s(new Ie(String(e)))}}))};this._streamStartedEvent.Subscribe(i),(yield this.SendAsync(e,n))||(window.clearTimeout(o),this._streamStartedEvent.Unsubscribe(i),s(new Error("Failed to send request")))}))))}))}PingControllerAsync(){return Dt(this,void 0,void 0,(function*(){if(!this.IsConnected()||!this._isAuthorized)return!1;if(Date.now()-this._lastReceivedPacket<bt.PING_INTERVAL_MS)return!1;const e=new ce;e.Resource="/system/ping",e.Method=le.Get;try{return yield this.SendAndWaitForResponseAsync(e,2e3,!1,!1),!0}catch(e){return!1}}))}OnDataReceivedEvent(){return this._dataReceivedEvent}OnConnectionStateChangedEvent(){return this._connectionStateChangedEvent}OnErrorOccuredEvent(){return this._errorOccuredEvent}serialisedConnect(){return this._connectTask||(this._connectTask=this.connectCore().finally((()=>this._connectTask=null))),this._connectTask}waitForState(e){return Dt(this,arguments,void 0,(function*(e,t=1e4){var n;const r=Date.now();for(;;){const s=null===(n=this._connection)||void 0===n?void 0:n.state;if(null!=s&&e.includes(s))return;if(Date.now()-r>t)throw new Error(`waitForState timeout; state=${s}`);yield new Promise((e=>setTimeout(e,50)))}}))}connectCore(){return Dt(this,void 0,void 0,(function*(){var n,s;if(!this._address)return he.ControllerIsNotConnected;if(this._connection&&this._currentAddress!==this._address){this._log.Info(bt.ServiceName,"Broker changed → rebuilding connection");try{yield this._connection.stop()}catch(e){}this.cleanup()}if(this._connection){const e=this._connection.state;if(e===o.Connected)return this._isAuthorized||(yield this.reauthorizeIfPossible()),he.Connected;if(e===o.Connecting||e===o.Reconnecting){this._log.Info(bt.ServiceName,"Existing connection is starting/reconnecting – waiting.");try{yield this.waitForState([o.Connected,o.Disconnected])}catch(e){}if((null===(n=this._connection)||void 0===n?void 0:n.state)===o.Connected)return this._isAuthorized||(yield this.reauthorizeIfPossible()),he.Connected}e===o.Disconnecting&&(yield this.waitForState([o.Disconnected]).catch((()=>{})))}this.initializeServices(),this.cleanup();for(const n of It){const o=(new re).withAutomaticReconnect(new kt).configureLogging(new Et).withStatefulReconnect({bufferSize:256e3}).withServerTimeout(bt.SERVER_TIMOUT_MS).withKeepAliveInterval(bt.PING_INTERVAL_MS-1e3).withUrl(`https://${this._address}/broker`,{skipNegotiation:n===t.WebSockets,transport:n});this._log.LogLevel===e.Debug&&o.configureLogging(r.Debug);const i=o.build();this._connection=i,this._currentAddress=this._address,this.wireConnectionEvents();try{return yield i.start(),yield this.reauthorizeIfPossible(),this.startPingLoop(),this._connectionStateChangedEvent.Invoke(pe.Connected),he.Connected}catch(e){this._log.Warning(bt.ServiceName,`Transport ${t[n]} failed (${null==e?void 0:e.message}).`);try{yield i.stop()}catch(e){}try{null===(s=null==i?void 0:i.off)||void 0===s||s.call(i)}catch(e){}}}return this._connectionStateChangedEvent.Invoke(pe.Failed),he.FailedToConnect}))}waitForReconnection(e=0){return new Promise(((t,n)=>{if(!this._connection||this._connection.state!==o.Reconnecting)return void n(new Error("Connection is not in reconnecting state"));let r;e>0&&(r=window.setTimeout((()=>{this._connectionStateChangedEvent.Unsubscribe(s),n(new Error("Reconnection timeout"))}),e));const s=e=>{e===pe.Connected?(r&&window.clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(s),t()):e!==pe.Disconnected&&e!==pe.Failed||(r&&window.clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(s),n(new Error("Connection closed during reconnection")))};this._connectionStateChangedEvent.Subscribe(s),this._connection.state!==o.Reconnecting&&(r&&window.clearTimeout(r),this._connectionStateChangedEvent.Unsubscribe(s),this._connection.state===o.Connected?t():n(new Error(`Connection is in unexpected state: ${this._connection.state}`)))}))}initializeServices(){this._controllerConfiguration=gy.Get(lt.ServiceName),this._cache=gy.Get($e.ServiceName),this._session=gy.Get(Qe.ServiceName)}wireConnectionEvents(){this._connection&&(this._connection.on("Pong",(()=>{this._lastReceivedPacket=Date.now(),this._pongReceivedEvent.Invoke()})),this._connection.on("controllerdisconnected",(()=>{this._isAuthorized=!1,this._connectionStateChangedEvent.Invoke(pe.Disconnected)})),this._connection.on("Authorization",(e=>this._authorizationReceivedEvent.Invoke(e))),this._connection.on("Registration",(e=>this._registrationReceivedEvent.Invoke(e))),this._connection.on("SendError",((e,t)=>{e.startsWith("NotAuthorized:")?this.AuthorizeAsync(new De(this._serialId,this._PIN)):this._errorOccuredEvent.Invoke([e,t])})),this._connection.on("Data",((e,t)=>{this._lastReceivedPacket=Date.now(),!0===window.packets&&this._log.Debug(bt.ServiceName,`Received: ${JSON.stringify(JSON.parse(t),null,2)}`),this._dataReceivedEvent.Invoke(JSON.parse(t))})),this._connection.onclose((()=>{this._isAuthorized=!1,this.cleanup(),this._connectionStateChangedEvent.Invoke(pe.Disconnected)})),this._connection.onreconnecting((()=>this._connectionStateChangedEvent.Invoke(pe.Reconnecting))),this._connection.onreconnected((()=>Dt(this,void 0,void 0,(function*(){var e;this._connectionStateChangedEvent.Invoke(pe.Connected),(yield this.RestoreConnectionAsync())&&(null===(e=this._session)||void 0===e||e.RestoreSessionAsync())})))))}startPingLoop(){null!==this._pingTimerId&&clearInterval(this._pingTimerId),this._pingTimerId=window.setInterval((()=>{this.pingOnce()}),bt.PING_INTERVAL_MS),window.addEventListener("online",this._tryReconnect),window.addEventListener("offline",this._tryReconnect),document.addEventListener("visibilitychange",this._onVisibility,!0),window.addEventListener("pagehide",this._onHidden,!0),window.addEventListener("pageshow",this._onVisible,!0)}isBusy(){var e;const t=null===(e=this._connection)||void 0===e?void 0:e.state;return t===o.Connecting||t===o.Disconnecting||t===o.Reconnecting}pingOnce(){return Dt(this,void 0,void 0,(function*(){this.IsConnected()&&!this.isBusy()&&(Date.now()-this._lastReceivedPacket<bt.PING_INTERVAL_MS||((yield this.PingControllerAsync())?this._consecutivePingFailures=0:++this._consecutivePingFailures>=bt.MAX_CONSECUTIVE_PING_FAILURES&&(this._consecutivePingFailures=0,this._log.Warning(bt.ServiceName,"Ping failed too many times → reconnecting..."),this.serialisedConnect())))}))}validateConnectionToController(){return Dt(this,void 0,void 0,(function*(){var e;if(!this.IsConnected())return this._log.Warning(bt.ServiceName,"Connection was lost"),!1;{const t=new ce;t.Resource="/system/ping",t.Method=le.Get;try{const n=yield this.SendAndWaitForResponseAsync(t,bt.SERVER_TIMOUT_MS+1e3,!1,!1);return(null==n?void 0:n.Status)!==ue.OK?(this._log.Warning(bt.ServiceName,"Connection check failed, "+(null==n?"result is null":`status: ${n.Status}`)),!1):(null===(e=this._connection)||void 0===e?void 0:e.state)===o.Reconnecting?(this._log.Warning(bt.ServiceName,"Connection check failed, connection is in reconnecting state"),!1):(this._log.Info(bt.ServiceName,"Connection still active"),!0)}catch(e){return!1}}}))}cleanup(){var e,t;null!==this._pingTimerId&&(clearInterval(this._pingTimerId),this._pingTimerId=null);for(const[,e]of this._pendingRequests)window.clearTimeout(e.timeoutId),e.reject(new Error("Connection lost"));this._pendingRequests.clear(),window.removeEventListener("online",this._tryReconnect),window.removeEventListener("offline",this._tryReconnect),document.removeEventListener("visibilitychange",this._onVisibility,!0),window.removeEventListener("pagehide",this._onHidden,!0),window.removeEventListener("pageshow",this._onVisible,!0);try{null===(t=null===(e=this._connection)||void 0===e?void 0:e.off)||void 0===t||t.call(e)}catch(e){}this._connection=void 0,this._currentAddress=void 0}}var Nt,Gt,Rt,Pt,Ut,Ot,Mt,xt,Ft,Lt,Bt,Wt,$t,Vt,qt,Ht;bt.PING_INTERVAL_MS=5e3,bt.MAX_CONSECUTIVE_PING_FAILURES=6,bt.SERVER_TIMOUT_MS=1e4,bt.SignalRLogLevel=r.Warning,bt.ServiceName="ExalusConnectionService",function(e){e[e.NoTasksExecuting=0]="NoTasksExecuting",e[e.ExecutingTasks=1]="ExecutingTasks"}(Nt||(Nt={})),(Wt=Gt||(Gt={}))[Wt.Default=0]="Default",Wt[Wt.Monostable=1]="Monostable",Wt[Wt.Bistable=2]="Bistable",Wt[Wt.Gate=3]="Gate",Wt[Wt.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"}(Rt||(Rt={}));class Kt{constructor(){this._type=Ut.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}($t=Pt||(Pt={}))[$t.Unknown=0]="Unknown",$t[$t.BlindMotor=1]="BlindMotor",$t[$t.DinModule=2]="DinModule",$t[$t.DinModuleWithAntenna=3]="DinModuleWithAntenna",$t[$t.Remote=4]="Remote",$t[$t.RemoteForBlinds=5]="RemoteForBlinds",$t[$t.RemoteForFacadeBlinds=6]="RemoteForFacadeBlinds",$t[$t.MovementSensor=7]="MovementSensor",$t[$t.TemperatureSensor=8]="TemperatureSensor",$t[$t.HumiditySensor=9]="HumiditySensor",$t[$t.DinPowerMeter=10]="DinPowerMeter",$t[$t.Intercom=11]="Intercom",$t[$t.SecurityCamera=12]="SecurityCamera",$t[$t.Multisensor=13]="Multisensor",$t[$t.FloodSensor=14]="FloodSensor",$t[$t.FlushMountedReceiver=15]="FlushMountedReceiver",$t[$t.FlushMountedBlindController=16]="FlushMountedBlindController",$t[$t.FlushMountedDimmer=17]="FlushMountedDimmer",$t[$t.FlushMountedRelay=18]="FlushMountedRelay",$t[$t.FlushMountedGateController=19]="FlushMountedGateController",$t[$t.WindSensor=20]="WindSensor",$t[$t.FlushMountedGateAndGatewayController=21]="FlushMountedGateAndGatewayController",$t[$t.AirPressureSensor=22]="AirPressureSensor",$t[$t.LightBrightnessSensor=23]="LightBrightnessSensor",$t[$t.ReedSensor=24]="ReedSensor",$t[$t.FlushMountedTransceiver=25]="FlushMountedTransceiver",$t[$t.FlushMountedRGBLightController=26]="FlushMountedRGBLightController",$t[$t.WallMountedThermoregulator=27]="WallMountedThermoregulator",$t[$t.ImpulseCounter=28]="ImpulseCounter",$t[$t.FlushMountedFacadeController=29]="FlushMountedFacadeController",$t[$t.WallMountedGateController=30]="WallMountedGateController",$t[$t.WallMountedRGBLightController=31]="WallMountedRGBLightController",$t[$t.WallMountedDimmer=32]="WallMountedDimmer",$t[$t.WallMountedRemote=33]="WallMountedRemote",$t[$t.DinRelay=34]="DinRelay",$t[$t.DinReceiver=35]="DinReceiver",$t[$t.DinBlindController=36]="DinBlindController",$t[$t.DinTransceiver=37]="DinTransceiver",$t[$t.SocketPlugIn=38]="SocketPlugIn",$t[$t.WallMountedRelay=39]="WallMountedRelay",$t[$t.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",e.PreciseGateControlSecure="IPreciseGateControlSecure"}(Ut||(Ut={}));class jt{constructor(){this._type=Ot.Unknown,this._interfaceType=""}get Type(){return this._type}get InterfaceType(){return this._interfaceType}set InterfaceType(e){this._interfaceType=e,this._type=e}}!function(e){e.Unknown="Unknown",e.BatteryState="IBatteryState",e.BinarySensorState="IBinarySensor",e.BlindOpenCloseTime="IBlindOpenCloseTime",e.BlindPosition="IBlindPosition",e.BlindRemoteButtonState="IBlindsControlButton",e.BlindErrorState="IBlindError",e.MeasuredBrightness="IBrightness",e.RemoteButtonState="IButtonState",e.ChannelOnOffState="IChannelOnOff",e.IntercomState="IIntercom",e.DoorBellState="IDoorBell",e.FacadeRemoteButtonState="IFacadeControlButton",e.FacadePosition="IFacadeState",e.FacadeType="IFacadeType",e.FloodSensorState="IFloodSensor",e.GatePosition="IGatePosition",e.GatewayPosition="IGatewayPosition",e.GateControllerHealth="IGateControllerHealth",e.HumiditySensorState="IHumiditySensor",e.LightBrightness="ILightBrightness",e.LightColor="ILightColor",e.LightWarmth="ILightTemperature",e.LightTreshold="ILightTreshold",e.MovementSensorState="IMovementSensor",e.OnlineCamera="IOnlineCamera",e.OvercurrentProtectionState="IOvercurrentProtection",e.OvercurrentProtectionThreshold="IOvercurrentProtectionThreshold",e.ReedState="IReedState",e.SignalStrength="ISignalStrength",e.SmokeSensorState="ISmokeSensor",e.MeasuredTemperature="ITemperature",e.VibrationSensorState="IVibrationSensor",e.MeasuredWindSpeed="IWindSpeed",e.WindThreshold="IWindThreshold",e.MeasuredEnergy="IEnergy",e.MeasuredDistance="DistanceSensor",e.BlindCalibration="BlindCalibration",e.ConfigurationState="ConfigurationState",e.CurrentWindThreshold="CurrentWindThreshold",e.CurrentLightThreshold="CurrentLightThreshold",e.WindSpeedState="WindSpeed",e.TamperProtectionState="ITamperProtection",e.PressureSensorState="IPressureSensor",e.LightRGBWState="ILightRGBW",e.SceneExecuted="ISceneExecuted",e.HallState="IHallState",e.Intercom="IIntercom"}(Ot||(Ot={})),(Ht=Mt||(Mt={}))[Ht.NotResponding=0]="NotResponding",Ht[Ht.Working=1]="Working",Ht[Ht.Broken=2]="Broken",Ht[Ht.FirmareUpgradeMode=3]="FirmareUpgradeMode",(qt=xt||(xt={}))[qt.TwoWay=1]="TwoWay",qt[qt.OneWay=2]="OneWay",qt[qt.ConditionalTwoWay=3]="ConditionalTwoWay",(Vt=Ft||(Ft={}))[Vt.Unknown=-1]="Unknown",Vt[Vt.Multipurpose=0]="Multipurpose",Vt[Vt.Controller=1]="Controller",Vt[Vt.Driver=2]="Driver",Vt[Vt.Receiver=3]="Receiver",Vt[Vt.Remote=4]="Remote",Vt[Vt.Sensor=5]="Sensor",Vt[Vt.Scene=6]="Scene";class zt{constructor(){this.DeviceGuid="",this.Channel=0,this.Status=Nt.NoTasksExecuting}}!function(e){e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed",e[e.ResponseTimeout=2]="ResponseTimeout",e[e.TaskRepeatedAndExecuted=3]="TaskRepeatedAndExecuted",e[e.TaskRepeatedResponseTimeout=4]="TaskRepeatedResponseTimeout",e[e.FlowControlNotAvailable=5]="FlowControlNotAvailable",e[e.ExecutionError=6]="ExecutionError"}(Lt||(Lt={})),function(e){e[e.ControllerResponseTimeout=-4]="ControllerResponseTimeout",e[e.DeviceNotFound=-3]="DeviceNotFound",e[e.DeviceResponseTimeout=-2]="DeviceResponseTimeout",e[e.Failed=-1]="Failed",e[e.Unknown=0]="Unknown",e[e.Executed=1]="Executed"}(Bt||(Bt={}));class Jt{constructor(){this.Device=null,this.Channel=0,this.Task=null,this.Result=Bt.Unknown}}var Xt,Yt,Qt,Zt,en,tn,nn,rn,sn,on,an,cn,un,ln,dn,hn,pn,gn,fn,vn,yn,mn,wn,Sn,An,_n,Cn,Tn,Dn,kn,In;class En{constructor(){this._type="",this._data=null,this._typeAsEnum=Ot.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}}(In=Xt||(Xt={}))[In.Confident=0]="Confident",In[In.Unconfident=1]="Unconfident";class bn extends En{constructor(e){super(),this.TypeAsEnum=Ot.ChannelOnOffState,this.Type="ChannelOnOffState",this.Data=e.state}}class Nn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=Yt.Unknown,this.Time=""}}!function(e){e[e.On=0]="On",e[e.Off=1]="Off",e[e.Unknown=2]="Unknown"}(Yt||(Yt={}));class Gn extends En{constructor(e){super(),this.TypeAsEnum=Ot.HallState,this.Type="IHallState",this.Data=e.state}}class Rn extends En{constructor(e){super(),this.TypeAsEnum=Ot.SceneExecuted,this.Type="ISceneExecuted",this.Data=e.state}}class Pn extends En{constructor(e){super(),this.TypeAsEnum=Ot.IntercomState,this.Type="IntercomState",this.Data=e.state}}!function(e){e[e.Idle=0]="Idle",e[e.IncomingCall=1]="IncomingCall",e[e.AnsweringCall=2]="AnsweringCall",e[e.Busy=3]="Busy",e[e.NoAnswerToCall=4]="NoAnswerToCall",e[e.Unknown=5]="Unknown"}(Qt||(Qt={}));class Un extends En{constructor(e){super(),this.TypeAsEnum=Ot.OnlineCamera,this.Type="OnlineCameraState",this.Data=e.state}}class On extends En{constructor(e){super(),this.TypeAsEnum=Ot.DoorBellState,this.Type="DoorBellState",this.Data=e.state}}class Mn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=Zt.Relased,this.Time=""}}!function(e){e[e.Pressed=0]="Pressed",e[e.Relased=1]="Relased",e[e.PressedAndRelased=2]="PressedAndRelased"}(Zt||(Zt={}));class xn extends En{constructor(e){super(),this.TypeAsEnum=Ot.ReedState,this.Type="ReedState",this.Data=e.state}}class Fn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=!1,this.Time=""}}class Ln extends En{constructor(e){super(),this.TypeAsEnum=Ot.BlindPosition,this.Type="BlindPostionState",this.Data=e.state}GetBlindStatus(){switch(this.Data.Position){case 200:return en.UnableToMove;case 201:return en.MotorOverheatedPleaseWait;default:return en.Working}}}!function(e){e[e.Unknown=0]="Unknown",e[e.Working=1]="Working",e[e.UnableToMove=200]="UnableToMove",e[e.MotorOverheatedPleaseWait=201]="MotorOverheatedPleaseWait"}(en||(en={}));class Bn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Position=0,this.RawPosition=0,this.Time=""}}class Wn extends En{constructor(e){super(),this.TypeAsEnum=Ot.RemoteButtonState,this.Type="RemoteButtonState",this.Data=e.state}}class $n{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=tn.Relased,this.Time=""}}!function(e){e[e.Pressed=1]="Pressed",e[e.Relased=2]="Relased",e[e.PressedAndRelased=3]="PressedAndRelased"}(tn||(tn={}));class Vn extends En{constructor(e){super(),this.TypeAsEnum=Ot.LightColor,this.Type="LightColorState",this.Data=e.state}}class qn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.R=0,this.G=0,this.B=0,this.Time=""}}class Hn extends En{constructor(e){super(),this.TypeAsEnum=Ot.LightWarmth,this.Type="LightWarmthState",this.Data=e.state}}class Kn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Temperature=0,this.Time=""}}class jn extends En{constructor(e){super(),this.TypeAsEnum=Ot.LightBrightness,this.Type="LightBrightnessState",this.Data=e.state}}class zn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Brightness=0,this.Time=""}}class Jn extends En{constructor(e){super(),this.TypeAsEnum=Ot.MeasuredTemperature,this.Type="MeasuredTemperatureState",this.Data=e.state}}class Xn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Temperature=0,this.Type=nn.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"}(nn||(nn={}));class Yn extends En{constructor(e){super(),this.TypeAsEnum=Ot.BatteryState,this.Type="BatteryState",this.Data=e.state}}class Qn{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=rn.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"}(rn||(rn={}));class Zn extends En{constructor(e){super(),this.TypeAsEnum=Ot.MeasuredBrightness,this.Type="MeasuredBrightnessState",this.Data=e.state}}class er{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Brightness=0,this.Time=""}}class tr extends En{constructor(e){super(),this.TypeAsEnum=Ot.MeasuredEnergy,this.Type="MeasuredEnergyState",this.Data=e.state,this.Data.MeasurementParameters=new Map(Object.entries(e.state.MeasurementParameters))}}class nr{constructor(){this.Channel=0,this.StateReliability=Xt.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"}(sn||(sn={}));class rr extends En{constructor(e){super(),this.TypeAsEnum=Ot.MeasuredDistance,this.Type="MeasuredDistanceState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(on||(on={}));class sr extends En{constructor(e){super(),this.TypeAsEnum=Ot.MovementSensorState,this.Type="MovementSensorState",this.Data=e.state}}class or{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Intensity=0,this.Movement=an.No,this.Time=""}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(an||(an={}));class ir extends En{constructor(e){super(),this.TypeAsEnum=Ot.BlindRemoteButtonState,this.Type="BlindRemoteButtonState",this.Data=e.state}}class ar{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=cn.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"}(cn||(cn={}));class cr extends En{constructor(e){super(),this.TypeAsEnum=Ot.FacadeRemoteButtonState,this.Type="FacadeRemoteButtonState",this.Data=e.state}}class ur{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=un.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"}(un||(un={}));class lr extends En{constructor(e){super(),this.TypeAsEnum=Ot.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"}(ln||(ln={}));class dr extends En{constructor(e){super(),this.TypeAsEnum=Ot.GatePosition,this.Type="GatePositionState",this.Data=e.state}}class hr{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.PositionType=dn.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"}(dn||(dn={}));class pr extends En{constructor(e){super(),this.TypeAsEnum=Ot.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"}(hn||(hn={}));class gr extends En{constructor(e){super(),this.TypeAsEnum=Ot.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"}(pn||(pn={}));class fr extends En{constructor(e){super(),this.TypeAsEnum=Ot.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"}(gn||(gn={}));class vr extends En{constructor(e){super(),this.TypeAsEnum=Ot.HumiditySensorState,this.Type="HumiditySensorState",this.Data=e.state}}class yr{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Type=fn.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"}(fn||(fn={}));class mr extends En{constructor(e){super(),this.TypeAsEnum=Ot.VibrationSensorState,this.Type="VibrationSensorState",this.Data=e.state}}!function(e){e[e.No=0]="No",e[e.Yes=1]="Yes"}(vn||(vn={}));class wr extends En{constructor(e){super(),this.TypeAsEnum=Ot.BinarySensorState,this.Type="BinarySensorState",this.Data=e.state}}class Sr{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=yn.Low,this.Time=""}}!function(e){e[e.High=1]="High",e[e.Low=0]="Low"}(yn||(yn={}));class Ar extends En{constructor(e){super(),this.TypeAsEnum=Ot.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"}(mn||(mn={}));class _r extends En{constructor(e){super(),this.TypeAsEnum=Ot.BlindOpenCloseTime,this.Type="BlindOpenCloseTimeState",this.Data=e.state}}class Cr extends En{constructor(e){super(),this.TypeAsEnum=Ot.OvercurrentProtectionState,this.Type="OvercurrentProtectionState",this.Data=e.state}}class Tr extends En{constructor(e){super(),this.TypeAsEnum=Ot.OvercurrentProtectionThreshold,this.Type="OvercurrentProtectionThresholdState",this.Data=e.state}}class Dr extends En{constructor(e){super(),this.TypeAsEnum=Ot.FacadePosition,this.Type="FacadePositionState",this.Data=e.state}}class kr extends En{constructor(e){super(),this.TypeAsEnum=Ot.FacadeType,this.Type="FacadeTypeState",this.Data=e.state}}class Ir extends En{constructor(e){super(),this.TypeAsEnum=Ot.CurrentWindThreshold,this.Type="CurrentWindThresholdState",this.Data=e.state}}class Er{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.WindThreshold=wn.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"}(wn||(wn={}));class br extends En{constructor(e){super(),this.TypeAsEnum=Ot.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"}(Sn||(Sn={}));class Nr extends En{constructor(e){super(),this.TypeAsEnum=Ot.WindSpeedState,this.Type="WindSpeedState",this.Data=e.state}}class Gr{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Value=0,this.Time=""}}class Rr extends En{constructor(e){super(),this.TypeAsEnum=Ot.FloodSensorState,this.Type="FloodSensorState",this.Data=e.state}}class Pr{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.State=An.NoFloodDetected,this.Time=""}}!function(e){e[e.FloodDetected=1]="FloodDetected",e[e.NoFloodDetected=0]="NoFloodDetected"}(An||(An={})),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"}(_n||(_n={}));class Ur extends En{constructor(e){super(),this.TypeAsEnum=Ot.PressureSensorState,this.Type="PressureSensorState",this.Data=e.state}}class Or{constructor(){this.Channel=0,this.StateReliability=Xt.Unconfident,this.Pressure=0,this.Time="",this.PressureType=Cn.OutsidePressure}}!function(e){e[e.InsidePressure=0]="InsidePressure",e[e.OutsidePressure=1]="OutsidePressure",e[e.SetPressure=2]="SetPressure"}(Cn||(Cn={})),function(e){e[e.Facade90=0]="Facade90",e[e.Facade180=1]="Facade180"}(Tn||(Tn={}));class Mr extends En{constructor(e){super(),this.TypeAsEnum=Ot.TamperProtectionState,this.Type="TamperProtection",this.Data=e.state}}!function(e){e[e.OK=0]="OK",e[e.Breach=1]="Breach"}(Dn||(Dn={}));class xr extends En{constructor(e){super(),this.TypeAsEnum=Ot.LightRGBWState,this.Type="LightRGBW",this.Data=e.state}}class Fr extends En{constructor(e){super(),this.TypeAsEnum=Ot.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"}(kn||(kn={}));class Lr{constructor(){this._onDeviceStateChangedEvent=new c,this._onDeviceStateRefreshedOrChangedEvent=new c,this._onDeviceTasksExecutionChangedOnChannelsEvent=new c,this._onDeviceFirmwareVersionChangedEvent=new c,this._iconType=Pt.Unknown,this._serialNumber=null,this._model=null,this._modelGuid=null,this._manufacturerGuid=null,this._isVirtual=!1,this._isEnabled=!1,this._deviceState=Mt.Working,this._deviceType=Ft.Unknown,this._communicationWay=xt.OneWay,this._availableTasksTypes=[],this._availableResponseTypes=[],this._channels=[],this._protocolGuid=null,this._softwareVersion=null,null==Lr._devicesService&&(Lr._devicesService=gy.Get(Zo.ServiceName));const e=this._onDeviceStateChangedEvent,t=this._onDeviceTasksExecutionChangedOnChannelsEvent;Lr._devicesService.OnDeviceStateChangedEvent().Subscribe((t=>{t.Device.Guid==this._guid&&e.Invoke(t.State)})),Lr._devicesService.OnDeviceStateRefreshedOrChangedEvent().Subscribe((e=>{e.Device.Guid==this._guid&&this._onDeviceStateRefreshedOrChangedEvent.Invoke(e.State)})),Lr._devicesService.OnDevicesTasksExecutionChangeEvent().Subscribe((e=>{t.Invoke(e.filter((e=>e.DeviceGuid==this._guid)).map((e=>e.Channel)))}))}OnDeviceFirmwareVersionChangedEvent(){return this._onDeviceFirmwareVersionChangedEvent}OnDeviceStateRefreshedOrChangedEvent(){return this._onDeviceStateRefreshedOrChangedEvent}get ShouldChannelsBeGrouped(){if(this._deviceType===Ft.Remote)switch(this._modelGuid){case"afea26ac-d5de-4aa9-8e74-ff69679d097b":case"908a71ec-ca46-4431-9504-05b7801e77f8":case"d8fea502-541e-42d9-8ece-a1bcfaaa93f9":return!1;default:return this._availableTasksTypes.all((e=>e.Type!==Ut.SetBlindPositionSimple))}return!1}get States(){return a.DoesThrowStackTrace?gy.Get(Zo.ServiceName).GetDeviceStates(this).selectMany((e=>e.States)).toArray():Lr._devicesService.GetDeviceStates(this).selectMany((e=>e.States)).toArray()}RemoveDeviceAsync(){return Lr._devicesService.RemoveDeviceAsync(this)}ExecuteDeviceTaskAsync(e){return Lr._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*(){var t;try{const n=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(new Br(this,e),2e4,!1);switch(n.Status){case ue.OK:return this._name=e,null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeDeviceNameAsync()"),gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),new be(Se.Changed,"");case ue.WrongData:if("DeviceNotFound"==n.Data)return new be(Se.Failed,"DeviceNotFound");break;case ue.NoPermissionsToCallGivenResource:return new be(Se.NoPermissions,"")}}catch(e){return e.message.includes("timeout")?new be(Se.ControllerResponseTimeout,""):new be(Se.UnknownError,"")}return new be(Se.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 Lr._devicesService.ExecuteDeviceTaskAsync(this,e)}}class Br extends ce{constructor(e,t){super(),this.Resource="/devices/device/name",this.Method=le.Put;const n=new Wr;n.DeviceGuid=e.Guid,n.Name=t,this.Data=n}}class Wr{constructor(){this.DeviceGuid="",this.Name=""}}var $r,Vr,qr,Hr,Kr;class jr{constructor(){this._device=new Lr,this._number=0,this._name="",this._iconName="",this._channelId="",this._mode=Gt.Default,this._channelGroups=[],this._isHidden=!1,this._availableTasksTypes=[],this._availableResponseTypes=[],this._customData={},this._roles=[],this._configurations={},this.CustomDataAndRolesSupported=!1,this._onTasksExecutionChangedEvent=new c,this._onChannelStateChangedEvent=new c,this._onChannelStateRefreshedOrChangedEvent=new c,null==jr._devicesService&&(jr._devicesService=gy.Get(Zo.ServiceName))}SetCustomDataAsync(e,t){const n=this.GetChannelConfigurationData();if(Array.isArray(e))for(const t of e)n.CustomData[t.dataId]=t.data,this._customData[t.dataId]=t.data;else n.CustomData[e]=t,this._customData[e]=t;const r=new zr;return r.DeviceGuid=this._device.Guid,r.ChannelConfiguration=n,this.ChangeConfigurationAsync(r)}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}RemoveCustomDataAsync(e){const t=this.GetChannelConfigurationData();delete t.CustomData[e],delete this._customData[e];const n=new zr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this.ChangeConfigurationAsync(n)}GetChannelConfigurationData(){const e=new Jr;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 zr;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 zr;return t.DeviceGuid=this._device.Guid,t.ChannelConfiguration=e,this.ChangeConfigurationAsync(t)}ChangeNameAsync(e){const t=this.GetChannelConfigurationData(),n=new zr;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 zr;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 zr;return n.DeviceGuid=this._device.Guid,n.ChannelConfiguration=t,this._channelGroups=e,this.ChangeConfigurationAsync(n)}ChangeConfigurationAsync(e){return t=this,n=void 0,s=function*(){var t,n;try{const r=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(new Xr(e),2e4,!1);switch(null===(t=u.Log)||void 0===t||t.Error("Device","EXIT CONFIGURATION MODE WILL BE FIRED! ChangeConfigurationAsync()"),yield gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),r.Status){case ue.OK:return this._name=e.ChannelConfiguration.ChannelName,this._iconName=e.ChannelConfiguration.IconName,this._channelGroups=e.ChannelConfiguration.GroupsGuids,this._isHidden=e.ChannelConfiguration.Hidden,this._mode=e.ChannelConfiguration.Configuration,this._customData=e.ChannelConfiguration.CustomData,this._roles=e.ChannelConfiguration.Roles,this._configurations=e.ChannelConfiguration.Configurations,new be(Se.Changed,"");case ue.WrongData:if("DeviceNotFound"===r.Data)return null===(n=u.Log)||void 0===n||n.Error("Failed to change channel configuration, referenced device does not exist!"),new be(Se.WrongData,"DeviceNotFound");break;case ue.FatalError:return new be(Se.UnknownError,"")}}catch(e){if(e.message.includes("timeout"))return new be(Se.ControllerResponseTimeout,"")}return new be(Se.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}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 a.DoesThrowStackTrace?gy.Get(Zo.ServiceName).GetDeviceStates(this.GetDevice()).where((e=>e.Channel==this.Number)).selectMany((e=>e.States)).toArray():jr._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,jr._devicesService.ExecuteDeviceTaskAsync(this._device,e)):Promise.resolve(Bt.Failed)}}jr._devicesService=null;class zr{constructor(){this.DeviceGuid="",this.ChannelConfiguration=new Jr}}class Jr{constructor(){this.Channel=0,this.ChannelName="",this.Configuration=Gt.Default,this.GroupsGuids=[],this.IconName="",this.Hidden=!1,this.Configurations={},this.CustomData={},this.Roles=[]}}class Xr extends ce{constructor(e){super(),this.Resource="/devices/device/channel/configuration",this.Method=le.Put,this.Data=e}}!function(e){e[e.TurnOn=0]="TurnOn",e[e.TurnOff=1]="TurnOff",e[e.ToggleState=2]="ToggleState",e[e.SetBlindPosition=3]="SetBlindPosition",e[e.SetLightColor=4]="SetLightColor",e[e.SetLightTemperature=5]="SetLightTemperature",e[e.SetLightBrightness=6]="SetLightBrightness",e[e.SetTemperature=7]="SetTemperature",e[e.GetState=8]="GetState",e[e.TurnOnWithTimeout=9]="TurnOnWithTimeout",e[e.SetLightBrightnessDynamicly=10]="SetLightBrightnessDynamicly",e[e.IdentifyDevice=11]="IdentifyDevice",e[e.SetBlindOpenCloseTime=12]="SetBlindOpenCloseTime",e[e.SetBlindMicroventilation=13]="SetBlindMicroventilation",e[e.GatewayPulse=25]="GatewayPulse",e[e.GatePulse=26]="GatePulse",e[e.SetFacadePositionAndTilt=29]="SetFacadePositionAndTilt",e[e.GetFacadeType=30]="GetFacadeType",e[e.LightRGBW=31]="LightRGBW",e[e.SetGatePositionPrecise=32]="SetGatePositionPrecise",e[e.SetGatePositionPreciseSecure=33]="SetGatePositionPreciseSecure"}($r||($r={}));class Yr{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 Qr{constructor(){this._taskType=Ut.GetChannelsState,this._featureType=$r.GetState,this._channel=0,this._guid=Yr.NewGuid(),this._deviceGuid=""}get TaskType(){return this._taskType}set TaskType(e){this._taskType=e}get FeatureType(){return this._featureType}set FeatureType(e){this._featureType=e}get Guid(){return this._guid}set Guid(e){this._guid=e}get DeviceGuid(){return this._deviceGuid}set DeviceGuid(e){this._deviceGuid=e}get Channel(){return this._channel}set Channel(e){this._channel=e}}class Zr extends Qr{constructor(){super(),this.Temperature=0,this.FeatureType=$r.SetTemperature,this.TaskType=Ut.SetTemperature}}class es extends Qr{constructor(){super(),this.FeatureType=$r.TurnOff,this.TaskType=Ut.TurnOff}}class ts extends Qr{constructor(){super(),this.FeatureType=$r.TurnOn,this.TaskType=Ut.TurnOn}}class ns extends Qr{constructor(){super(),this.SwitchOffDelaySeconds=0,this.FeatureType=$r.TurnOnWithTimeout,this.TaskType=Ut.TurnOnWithTime}}class rs extends Qr{constructor(){super(),this.Brightness=0,this.FeatureType=$r.SetLightBrightness,this.TaskType=Ut.SetLightBrightness}}class ss extends Qr{constructor(){super(),this.FeatureType=$r.ToggleState,this.TaskType=Ut.TogleState}}class os extends Qr{constructor(){super(),this.R=0,this.G=0,this.B=0,this.FeatureType=$r.SetLightColor,this.TaskType=Ut.SetLightColor}}class is extends Qr{constructor(){super(),this.Temperature=0,this.FeatureType=$r.SetLightTemperature,this.TaskType=Ut.SetLightTemperature}}class as extends Qr{constructor(){super(),this.Action=Vr.Stop,this.Position=0,this.FeatureType=$r.SetBlindPosition,this.TaskType=Ut.SetBlindPosition}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(Vr||(Vr={}));class cs extends Qr{constructor(){super(),this.GateControlAction=qr.Stop,this.Position=0,this.FeatureType=$r.SetGatePositionPrecise,this.TaskType=Ut.PreciseGateControl}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop",e[e.Percentage=3]="Percentage"}(qr||(qr={}));class us extends Qr{constructor(){super(),this.Action=Hr.Stop,this.Position=0,this.FeatureType=$r.SetBlindPosition,this.TaskType=Ut.SetBlindPositionSimple}}!function(e){e[e.Open=0]="Open",e[e.Close=1]="Close",e[e.Stop=2]="Stop"}(Hr||(Hr={}));class ls extends Qr{constructor(){super(),this.Brightness=0,this.FeatureType=$r.SetLightBrightnessDynamicly,this.TaskType=Ut.SetLightBrightnessDynamicly}}class ds extends Qr{constructor(){super(),this.FeatureType=$r.IdentifyDevice,this.TaskType=Ut.IdentifyDevice}}class hs extends Qr{constructor(){super(),this.Data=new ps,this.FeatureType=$r.SetBlindOpenCloseTime,this.TaskType=Ut.SetBlindOpenCloseTime}}class ps{constructor(){this.Channel=0,this.CloseTime=0,this.OpenTime=0}}class gs extends Qr{constructor(){super(),this.FeatureType=$r.GetState,this.TaskType=Ut.GetChannelsState}}class fs extends Qr{constructor(){super(),this.Position=0,this.FeatureType=$r.SetBlindMicroventilation,this.TaskType=Ut.SetBlindMicroventilation}}class vs extends Qr{constructor(){super(),this.FeatureType=$r.GatePulse,this.TaskType=Ut.ChangeGatewayPositionPulse}}class ys extends Qr{constructor(){super(),this.FeatureType=$r.GatewayPulse,this.TaskType=Ut.ChangeGatewayPositionPulse}}class ms extends Qr{constructor(){super(),this.FacadeAction=Kr.Stop,this.Tilt=0,this.Position=0,this.FeatureType=$r.SetFacadePositionAndTilt,this.TaskType=Ut.SetFacadePosition}}class ws extends Qr{constructor(){super(),this.FeatureType=$r.GetFacadeType,this.TaskType=Ut.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"}(Kr||(Kr={}));class Ss{constructor(){this.R=0,this.G=0,this.B=0,this.W=0,this.Brightness=0,this.Channel=0}}class As extends Qr{constructor(){super(),this.Data=new Ss,this.FeatureType=$r.LightRGBW,this.TaskType=Ut.LightRGBW}}var _s=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 Cs{constructor(){this._manualDeviceProtocolServices=new Map}GetServiceName(){return Cs.ServiceName}RegisterManuallyPairedDevicesProtocol(e){var t;null===(t=u.Log)||void 0===t||t.Debug(Cs.ServiceName,`Registering new manual device protocol service: ${e.GetServiceName()}`),this._manualDeviceProtocolServices.set(e.GetServiceName(),e)}GetDevicesForManualPairingAsync(e){return _s(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 _s(this,void 0,void 0,(function*(){var t;const n=[...this._manualDeviceProtocolServices.values()].find((t=>t.ProtocolExtensionGuid==e.ProtocolExtensionGuid));return null!=n?n.AddManuallyPairedDeviceAsync(e):(null===(t=u.Log)||void 0===t||t.Error(Cs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDeviceAsync()"),gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),Bt.Failed)}))}GetRegisteredProtocolGuids(){return[...this._manualDeviceProtocolServices.values()].map((e=>e.ProtocolExtensionGuid))}}Cs.ServiceName="ManualDeviceService";class Ts{constructor(){this.ResourceGuid="",this.Data=null,this.IsGlobal=!1,this.InsertTime=new Date}}var Ds,ks=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Is{constructor(){this._connection=null,this._localDb=null,this._connection=gy.Get(bt.ServiceName),this._localDb=gy.Get(l.ServiceName)}GetLocalDbName(e,t){return`${e}_${t}`}SaveAsync(e,t,n){return ks(this,void 0,void 0,(function*(){try{let r=new Es(e,t,n),s=yield this._connection.SendAndWaitForResponseAsync(r,35e3,!1);if(s.Status===ue.OK){const r=new Gs;r.ResourceGuid=e,r.Data=JSON.stringify(n),r.IsGlobal=t,this._localDb.Save(Is.ServiceName,this.GetLocalDbName(e,t),r)}return s.Status}catch(e){return ue.FatalError}}))}ReadAsync(e,t,n){return ks(this,void 0,void 0,(function*(){try{let r=new bs(e,t);if(!n){const n=this._localDb.Read(Is.ServiceName,this.GetLocalDbName(e,t));if(null!=n){const e=n,t=new Ts;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===ue.OK){const e=new Ts;return e.ResourceGuid=s.ResourceGuid,e.Data=JSON.parse(s.Data),e.IsGlobal=s.IsGlobal,e}return s.Status}catch(e){return ue.FatalError}}))}RemoveAsync(e,t){return ks(this,void 0,void 0,(function*(){try{let n=new Ns(e,t);return(yield this._connection.SendAndWaitForResponseAsync(n,35e3,!1)).Status}catch(e){return ue.FatalError}}))}GetServiceName(){return Is.ServiceName}}Is.ServiceName="RemoteStorageService";class Es extends ce{constructor(e,t,n){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Put,this.ResourceGuid=e,this.Global=t,this.Data=JSON.stringify(n)}}class bs extends ce{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Get,this.ResourceGuid=e,this.Global=t}}class Ns extends ce{constructor(e,t){super(),this.ResourceGuid="",this.Global=!1,this.Resource="/sync/config/",this.Method=le.Delete,this.ResourceGuid=e,this.Global=t}}class Gs extends ce{constructor(){super(...arguments),this.ResourceGuid="",this.Data="",this.IsGlobal=!1,this.InsertTime=new Date}}class Rs{constructor(){this.Longitude=0,this.Latitude=0}}class Ps{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 Us,Os,Ms=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 xs{IsControllerGeolocationSetAsync(){return Ms(this,void 0,void 0,(function*(){let e=new Fs,t=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(e,15e3,!0);return(null==t?void 0:t.Status)===ue.OK?null==t?void 0:t.Data:null==t?void 0:t.Status}))}GetCurrentGeolocationAsync(){return Ms(this,void 0,void 0,(function*(){return new Promise(((e,t)=>Ms(this,void 0,void 0,(function*(){window.navigator.geolocation.getCurrentPosition((t=>{e(t)}),(t=>{e(t)}))}))))}))}SetControllerGeolocationAsync(e){return Ms(this,void 0,void 0,(function*(){var t,n,r;let s=new Bs;s.Data.Latitude=e.Latitude,s.Data.Longitude=e.Longitude,null===(t=u.Log)||void 0===t||t.Warning(xs.ServiceName,`SetControllerGeolocationAsync() ${JSON.stringify(s)}`);let o=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(s,15e3,!1);switch(null===(n=u.Log)||void 0===n||n.Warning(xs.ServiceName,`${JSON.stringify(o)}`),null===(r=u.Log)||void 0===r||r.Error(xs.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetControllerGeolocationAsync()"),gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),null==o?void 0:o.Status){case ue.OK:const e=gy.Get($e.ServiceName);return e.Remove(new Fs),e.Remove(new Ls),new Ne(Ds.OK,"");case ue.NoPermissionToPerformThisOperation:case ue.NoPermissionsToCallGivenResource:return new Ne(Ds.NoPermissions,"");case ue.UserIsNotLoggedIn:return new Ne(Ds.UserIsNotLoggedIn,"");default:return new Ne(Ds.UnknownError,"")}}))}GetControlllerGeolocationAsync(){return Ms(this,void 0,void 0,(function*(){var e,t;let n=new Ls;null===(e=u.Log)||void 0===e||e.Warning(xs.ServiceName,`GetControlllerGeolocationAsync(): ${JSON.stringify(n)}`);let r=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(n,15e3,!0);if(null===(t=u.Log)||void 0===t||t.Warning(xs.ServiceName,`${JSON.stringify(r)}`),(null==r?void 0:r.Status)===ue.OK){let e=new Ps;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 xs.ServiceName}}xs.ServiceName="GeolocationService";class Fs extends ce{constructor(){super(),this.Resource="/geolocation/isset",this.Method=le.Get}}class Ls extends ce{constructor(){super(),this.Resource="/geolocation/get",this.Method=le.Get}}class Bs extends ce{constructor(){super(),this.Data=new Rs,this.Resource="/geolocation/save",this.Method=le.Put}}!function(e){e[e.Device=0]="Device",e[e.Controller=1]="Controller"}(Us||(Us={}));class Ws{constructor(){this.UpdateGuid="",this.Channel="",this.Version="",this.CurrentVersion="",this.DownloadUri="",this.Download="",this.Name="",this.Description="",this.UpdateType=Os.Unknown,this.ResourceGuid=""}}class $s{constructor(){this.UpdateDescription=new Map,this.Update=new Ws,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"}(Os||(Os={}));class Vs extends Error{constructor(e){super(e),this.message=e,this.name="UpdateProviderNotFound"}}var qs,Hs,Ks,js,zs,Js,Xs,Ys,Qs,Zs,eo,to,no,ro,so,oo,io,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._services=new Map,this._runtimeInfo=new lo,this._hardwareInfo=new po,this._semaphore=new nt(1),this._isRuntimeInfoInitialized=!1,this._isHardwareInfoInitialized=!1}GetServiceName(){return uo.ServiceName}RegisterUpdatesProvider(e){var t;null===(t=u.Log)||void 0===t||t.Debug(uo.ServiceName,`Registering new update provider: ${e.GetUpdateProviderName()}`),this._services.set(e.GetUpdateProviderName(),e)}GetUpdatesProviderAsync(e){return co(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(uo.ServiceName,`Getting update provider [${e}] by GetUpdateProviderAsync<T>()`);const n=this._services.get(e);if(null==n)throw new Vs("Cannot get update provider! Requested update provider has not been registered.");return n}))}GetUpdatesProvidersAsync(e){return co(this,void 0,void 0,(function*(){var t;null===(t=u.Log)||void 0===t||t.Debug(uo.ServiceName,`Getting update providers with type ${e} by GetUpdateProvidersAsync<T>()`);let n=[];if(n=[...this._services.values()].filter((t=>t.ProviderType==e)),0==n.length)throw new Vs("Cannot get update providers! Requested update providers has not been registered.");return n}))}GetUpdatesProvidersByProtocolAsync(e,t,n){return co(this,void 0,void 0,(function*(){var r;if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){null===(r=u.Log)||void 0===r||r.Debug(uo.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 Vs("Cannot get update providers! Requested update providers has not been registered.");return s}throw new Vs("Cannot get update providers! Bad parameters.")}))}GetUpdatesProvidersByExtensionAsync(e,t,n){return co(this,void 0,void 0,(function*(){var r;if(new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$").test(e)){null===(r=u.Log)||void 0===r||r.Debug(uo.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 Vs("Cannot get update providers! Requested update providers has not been registered.");return s}throw new Vs("Cannot get update providers! Bad parameters.")}))}GetSoftwareRuntimeInfoAsync(){return co(this,arguments,void 0,(function*(e=!1){var t=yield this._semaphore.AcquireAsync();try{return this._isRuntimeInfoInitialized&&!e||(yield this.GetRuntimeControllerInfoAsync()),this._runtimeInfo}finally{t.Release()}}))}GetRuntimeControllerInfoAsync(){return co(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(uo.ServiceName,"Getting runtime version info from controller.");try{const e=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(new ho,16e3,!1);if(null==e||null==e.Status)throw new fo('Cannot get runtime info, controller response result is empty."',qs.EmptyResponse);if(e.Status!=ue.OK)throw new fo(`Cannot get runtime info, controller responded with status ${e.Status}.`,qs.WrongResponseStatus);if(null==e.Data)throw new fo("Cannot get runtime info, controller responded with status OK but response does not contains data.",qs.NoDataInResponse);this._runtimeInfo=e.Data,this._isRuntimeInfoInitialized=!0}catch(e){throw e instanceof I?new fo("Cannot get runtime info, controller response timeout.",qs.Timeout):e}}))}GetHardwareInfoAsync(){return co(this,arguments,void 0,(function*(e=!1){return!this._isHardwareInfoInitialized||e?(yield this.GetHardwareControllerInfoAsync(),this._hardwareInfo):this._hardwareInfo}))}GetHardwareControllerInfoAsync(){return co(this,void 0,void 0,(function*(){var e;null===(e=u.Log)||void 0===e||e.Debug(uo.ServiceName,"Getting hardware info from controller.");const t=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(new go,8e3,!1);if(null==t||null==t.Status)throw new fo('Cannot get hardware info, controller response result is empty."',qs.EmptyResponse);if(t.Status!=ue.OK)throw new fo(`Cannot get hardware info, controller responded with status ${t.Status}.`,qs.WrongResponseStatus);if(null==t.Data)throw new fo("Cannot get hardware info, controller responded with status OK but response does not contains data.",qs.NoDataInResponse);this._hardwareInfo=t.Data,this._isHardwareInfoInitialized=!0}))}}uo.ServiceName="UpdateProvider";class lo{constructor(){this.BaseLinuxVersion="",this.BaseMonoVersion="",this.RuntimeVersion="",this.UpdateChannel="",this.SoftwareVersion=""}}class ho extends ce{constructor(){super(),this.Resource="/controller/software/info",this.Method=le.Get}}class po{constructor(){this.GetControllerHardwareVersion=0,this.DevicePIN="",this.GetControllerSerialNumber="",this.HostnamePrefix="",this.DefaultStaticIpAddress="",this.GetAvailableHardware=[],this.ControllerSecret=""}}class go extends ce{constructor(){super(),this.Resource="/controller/hardware/info",this.Method=le.Get}}class fo 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"}(qs||(qs={})),function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.InvalidSceneGuid="InvalidSceneGuid"}(Hs||(Hs={}));class vo{constructor(){this._comparisonParams=new Map,this.Type=Ot.Unknown,this.DeviceGuid="",this.ComparisonMethod=Ks.Default}GetCheckDeviceState(){return this._checkDeviceState}SetCheckDeviceState(e){this._checkDeviceState=e,e instanceof Qn&&(this.Type=Ot.BatteryState),e instanceof Sr&&(this.Type=Ot.BinarySensorState),e instanceof Bn&&(this.Type=Ot.BlindPosition),e instanceof zn&&(this.Type=Ot.LightBrightness),e instanceof er&&(this.Type=Ot.MeasuredBrightness),e instanceof $n&&(this.Type=Ot.RemoteButtonState),e instanceof Nn&&(this.Type=Ot.ChannelOnOffState),e instanceof Mn&&(this.Type=Ot.DoorBellState),e instanceof nr&&(this.Type=Ot.MeasuredEnergy),e instanceof Pr&&(this.Type=Ot.FloodSensorState),e instanceof hr&&(this.Type=Ot.GatePosition),e instanceof qn&&(this.Type=Ot.LightColor),e instanceof Kn&&(this.Type=Ot.LightWarmth),e instanceof Fn&&(this.Type=Ot.ReedState),e instanceof Xn&&(this.Type=Ot.MeasuredTemperature),e instanceof yr&&(this.Type=Ot.HumiditySensorState),e instanceof ar&&(this.Type=Ot.BlindRemoteButtonState),e instanceof ur&&(this.Type=Ot.FacadeRemoteButtonState),e instanceof or&&(this.Type=Ot.MovementSensorState),e instanceof nr&&(this.Type=Ot.MeasuredEnergy),e instanceof Or&&(this.Type=Ot.PressureSensorState),e instanceof Gr&&(this.Type=Ot.WindSpeedState),e instanceof Er&&(this.Type=Ot.CurrentWindThreshold)}GetComparisonParam(e){return this._comparisonParams.get(e)}GetComparisonParams(){return this._comparisonParams}SetComparisonParam(e,t){this._comparisonParams.set(e,t)}}class yo{constructor(e){this._value=e}get Value(){return this._value}set Value(e){this._value=e}}class mo{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"}(Ks||(Ks={})),function(e){e[e.DeltaValue=0]="DeltaValue",e[e.DeltaCalculationTimeRange=1]="DeltaCalculationTimeRange",e[e.StateRepeatCount=2]="StateRepeatCount",e[e.StateRepeatTimeRange=3]="StateRepeatTimeRange"}(js||(js={})),function(e){e[e.SunRise=1]="SunRise",e[e.SunSet=2]="SunSet"}(zs||(zs={}));class wo{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"}(Js||(Js={})),function(e){e.Unknown="Unknown",e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.NotifyTask="NotifyTask",e.LockExecution="LockExecution"}(Xs||(Xs={})),(ao=Ys||(Ys={}))[ao.Unknown=0]="Unknown",ao[ao.Second=1]="Second",ao[ao.Minute=2]="Minute",ao[ao.Hour=3]="Hour",ao[ao.Day=4]="Day",ao[ao.DayOfWeek=5]="DayOfWeek",ao[ao.Month=6]="Month",ao[ao.Year=7]="Year",ao[ao.Date=8]="Date",ao[ao.Time=9]="Time",ao[ao.WeatherType=11]="WeatherType",ao[ao.CompareNumbers=12]="CompareNumbers",ao[ao.CompareBooleans=13]="CompareBooleans",ao[ao.DeviceState=14]="DeviceState",ao[ao.Timer=15]="Timer",ao[ao.Temperature=17]="Temperature",ao[ao.DaysOfWeek=18]="DaysOfWeek",ao[ao.AstronomicalClockWithOffset=19]="AstronomicalClockWithOffset",ao[ao.SceneExecuted=20]="SceneExecuted",(io=Qs||(Qs={}))[io.Unknown=0]="Unknown",io[io.Equal=1]="Equal",io[io.NotEqueal=2]="NotEqueal",io[io.BiggerThan=3]="BiggerThan",io[io.SmallerThan=4]="SmallerThan",io[io.BiggerThanOrEqual=5]="BiggerThanOrEqual",io[io.SmallerThanOrEqual=6]="SmallerThanOrEqual",io[io.OneOfBothIsTrue=7]="OneOfBothIsTrue",io[io.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"}(Zs||(Zs={})),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"}(eo||(eo={})),(oo=to||(to={})).Null="Null",oo.Condition="Condition",oo.ConditionGroup="ConditionGroup",oo.ArgumentAsInt="ArgumentAsInt",oo.ArgumentAsTimeSpan="ArgumentAsTimeSpan",oo.ArgumentAsBoolean="ArgumentAsBoolean",oo.ArgumentAsTimeout="ArgumentAsTimeout",oo.ArgumentAsDayOfWeek="ArgumentAsDayOfWeek",oo.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",oo.ArgumentAsAstronomicalClock="ArgumentAsAstronomicalClock",oo.ArgumentAsTime="ArgumentAsTime",oo.ArgumentAsDeviceState="ArgumentAsDeviceState",oo.ArgumentAsNumber="ArgumentAsNumber",oo.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",oo.ArgumentAsConditionInfo="ArgumentAsConditionInfo",function(e){e.DeviceTask="DeviceTask",e.DelayTask="DelayTask",e.LockExecutionTask="LockExecutionTask",e.NotifyTaskAppNotify="NotifyTaskAppNotify",e.NotifyTaskEmailNotify="NotifyTaskEmailNotify"}(no||(no={}));class So 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"}(ro||(ro={})),function(e){e[e.Timeout=0]="Timeout",e[e.TimeRange=1]="TimeRange"}(so||(so={}));var Ao,_o,Co;class To{constructor(e,t="Cube"){this._result=null,this._tmp=new Do,this._tmpTask=null,this._prevSeqGuid="",this._currentSeqGuid="",this._editingExistingSequence=!1,this._rawExistingSequenceTasks=null,this._sequenceName="",this._sequenceIcon="",this._service=gy.Get(Wo.ServiceName),e&&(this._sequenceName=e,this._sequenceIcon=t,this._tmp.Guid=Yr.NewGuid())}SetSequenceName(e){const t=n=>{if(n.RightArgumentType!=Co.Null)return t(n.RightArgument);n.Tasks.ControllerTasks.where((e=>e.TaskType==Js.NotifyTask)).toArray().forEach((t=>{t.Title=e}))};this._sequenceName=e,this._editingExistingSequence&&null!=this._result&&(this._result.Name=e,t(this._result))}SetSequenceIcon(e){this._sequenceIcon=e,this._editingExistingSequence&&null!=this._result&&(this._result.Icon=e)}GetNext(){if(null==this._result)return null;if(""==this._currentSeqGuid)return this._currentSeqGuid=this._result.Guid,this._service.MapSequence(JSON.parse(JSON.stringify(this._result)),!0);{const e=this.FindArgumentWithGuid(this._result,this._currentSeqGuid);return null==e?null:e.RightArgumentType==Co.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 To;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=Yr.NewGuid(),e.RightArgumentType==Co.Condition&&t(e.RightArgument)};null!=e._result&&t(e._result),null!=this._tmp&&(this._tmp.Guid=Yr.NewGuid())})(e),e}GetPrevious(){let e="";const t=(n,r)=>n.Guid==r?{sequence:n,prevGuid:e}:n.RightArgumentType==Co.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!=Co.Null)return t(e.RightArgument);this._rawExistingSequenceTasks=JSON.parse(JSON.stringify(e.Tasks))};return this._editingExistingSequence=!0,t(e._rawRequestData),Object.hasOwn(e._rawRequestData,"Condition")?this._result=e._rawRequestData.Condition:this._result=e._rawRequestData,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequence:e=>this.RemoveSequenceByGuid(e),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=Qs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Qs.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=Yr.NewGuid(),this._tmp.HandledType=Ys.AstronomicalClockWithOffset,this._tmp.LeftArgumentType=Co.ArgumentAsAstronomicalClockWithOffset,this._tmp.AtMeetCondition=t,e.Offset<-3600||e.Offset>3600)throw new Oo("Offset must be in range between -3600 and 3600 seconds.");if(t)this._tmp.ConditionType=Qs.Equal;else{if(t||null==n)throw new Oo("Comparasion type must be provided if atMeetCondition is false!");this._tmp.ConditionType=n}return this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Co.ArgumentAsAstronomicalClockWithOffset,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsActionWithEmptyCondition(){return this._tmp.Guid=Yr.NewGuid(),this._tmp.HandledType=Ys.Unknown,this._tmp.LeftArgumentType=Co.Null,this._tmp.ConditionType=Qs.Equal,this._tmp.LeftArgument.Argument=null,this._tmp.LeftArgument.HandledType=Co.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=Qs.Equal){return this._tmp.Guid=Yr.NewGuid(),this._tmp.HandledType=Ys.DaysOfWeek,this._tmp.LeftArgumentType=Co.ArgumentAsDaysOfWeek,this._tmp.ConditionType=n,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Co.ArgumentAsDaysOfWeek,this._tmp.AtMeetCondition=t,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTimeSpan(e,t=Qs.Equal){return this._tmp.Guid=Yr.NewGuid(),this._tmp.HandledType=Ys.Timer,this._tmp.LeftArgumentType=Co.ArgumentAsTimeSpan,this._tmp.ConditionType=t,this._tmp.AtMeetCondition=!0,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Co.ArgumentAsTimeSpan,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsTime(e,t,n=Qs.Equal){return this._tmp.Guid=Yr.NewGuid(),this._tmp.HandledType=Ys.Time,this._tmp.LeftArgumentType=Co.ArgumentAsTime,this._tmp.ConditionType=n,this._tmp.AtMeetCondition=t,this._tmp.LeftArgument.Argument=e,this._tmp.LeftArgument.HandledType=Co.ArgumentAsTime,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsDeviceState(e,t,n,r=Qs.Equal){return this._tmp.Guid=Yr.NewGuid(),this._tmp.HandledType=Ys.DeviceState,this._tmp.LeftArgumentType=Co.ArgumentAsDeviceState,this._tmp.ConditionType=r,this._tmp.AtMeetCondition=t,this._tmp.ConditionTimeout=n,this._tmp.LeftArgument.Argument=this.GenerateDeviceStateArgument(e),this._tmp.LeftArgument.HandledType=Co.ArgumentAsDeviceState,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}ArgumentAsSceneExecuted(e){this._tmp.Guid=Yr.NewGuid(),this._tmp.HandledType=Ys.SceneExecuted,this._tmp.LeftArgumentType=Co.ArgumentAsConditionInfo,this._tmp.ConditionType=Qs.Equal,this._tmp.AtMeetCondition=!0;const t=new wo;return t.DeviceGuid=e.DeviceGuid,this._tmp.LeftArgument.Argument=t,this._tmp.LeftArgument.HandledType=Co.ArgumentAsConditionInfo,{AddArgument:()=>this.AddSequence(),EditArgument:e=>this.EditSequence(e)}}GenerateDeviceStateArgument(e){const t=new Eo;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),{[js[e]]:t.Value});switch(t.ComparisonParams=n,t.DeviceGuid=e.DeviceGuid,t.DeviceStateType=this.MapResponseTypeToDeviceStateType(e.Type),e.Type){case Ot.BatteryState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State,t.CheckedDeviceState.Percentage=e.GetCheckDeviceState().Percentage;break;case Ot.BinarySensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Ot.BlindPosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position;break;case Ot.LightBrightness:case Ot.MeasuredBrightness:t.CheckedDeviceState.Brightness=e.GetCheckDeviceState().Brightness;break;case Ot.RemoteButtonState:case Ot.ChannelOnOffState:case Ot.DoorBellState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Ot.MeasuredEnergy:{let n={},r=e.GetCheckDeviceState().MeasurementParameters.entries();for(const[e,t]of r)n=Object.assign(Object.assign({},n),{[sn[e]]:t});t.CheckedDeviceState.MeasurementParameters=n;break}case Ot.FloodSensorState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Ot.GatePosition:t.CheckedDeviceState.Position=e.GetCheckDeviceState().Position,t.CheckedDeviceState.PositionType=e.GetCheckDeviceState().PositionType;break;case Ot.LightColor:{const n=e.GetCheckDeviceState();t.CheckedDeviceState.R=n.R,t.CheckedDeviceState.G=n.G,t.CheckedDeviceState.B=n.B;break}case Ot.LightWarmth:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case Ot.ReedState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Ot.SmokeSensorState:throw new So("Unsupported device state!");case Ot.MeasuredTemperature:t.CheckedDeviceState.Temperature=e.GetCheckDeviceState().Temperature;break;case Ot.HumiditySensorState:t.CheckedDeviceState.Humidity=e.GetCheckDeviceState().Humidity;break;case Ot.BlindRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Ot.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 Ot.FacadeRemoteButtonState:t.CheckedDeviceState.State=e.GetCheckDeviceState().State;break;case Ot.MovementSensorState:{let n=e.GetCheckDeviceState();t.CheckedDeviceState.Movement=n.Movement,t.CheckedDeviceState.Intensity=n.Intensity;break}case Ot.PressureSensorState:t.CheckedDeviceState.Pressure=e.GetCheckDeviceState().Pressure,t.CheckedDeviceState.PressureType=e.GetCheckDeviceState().PressureType;break;case Ot.WindSpeedState:t.CheckedDeviceState.Value=e.GetCheckDeviceState().Value;break;case Ot.CurrentWindThreshold:t.CheckedDeviceState.WindThreshold=e.GetCheckDeviceState().WindThreshold;break;case Ot.Unknown:t.CheckedDeviceState={};break;default:throw new So("Unsupported device state!")}return t}MapResponseTypeToDeviceStateType(e){switch(e){case Ot.BatteryState:return Zs.BatteryState;case Ot.BinarySensorState:return Zs.BinarySensor;case Ot.BlindPosition:return Zs.BlindPosition;case Ot.LightBrightness:return Zs.LightBrightness;case Ot.RemoteButtonState:return Zs.ButtonState;case Ot.ChannelOnOffState:return Zs.ChannelOnOff;case Ot.DoorBellState:return Zs.DoorBell;case Ot.MeasuredEnergy:return Zs.Energy;case Ot.FloodSensorState:return Zs.FloodSensor;case Ot.GatePosition:return Zs.GatePosition;case Ot.MeasuredBrightness:return Zs.Brightness;case Ot.LightColor:return Zs.LightColor;case Ot.LightWarmth:return Zs.LightTemperature;case Ot.ReedState:return Zs.ReedState;case Ot.SmokeSensorState:return Zs.SmokeSensor;case Ot.MeasuredTemperature:return Zs.Temperature;case Ot.HumiditySensorState:return Zs.Humidity;case Ot.BlindRemoteButtonState:return Zs.BlindsControlButton;case Ot.FacadeRemoteButtonState:return Zs.FacadeControlButton;case Ot.MovementSensorState:return Zs.Movement;case Ot.PressureSensorState:return Zs.AirPressure;case Ot.WindSpeedState:return Zs.WindSpeed;case Ot.CurrentWindThreshold:return Zs.WindThreshold;default:return Zs.Unknown}}AddSequence(){const e=(t,n)=>{if(t.RightArgumentType!=Co.Null)return e(t.RightArgument,n);t.RightArgumentType=Co.Condition,t.RightArgument=n,this._editingExistingSequence&&null!=this._rawExistingSequenceTasks&&(n.Tasks=JSON.parse(JSON.stringify(this._rawExistingSequenceTasks)),t.Tasks=new bo)};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 Do,{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=Qs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Qs.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!=Co.Condition){if(n.RightArgumentType==Co.Condition)return t(n.RightArgument,r);throw new Mo(`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 Mo(`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 Do,console.log(`new tmp guid: ${this._tmp.Guid}`),this._result.AtMeetCondition||(this._result.AtMeetCondition=!0),{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=Qs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Qs.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==Co.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==Co.Null)throw new Mo(`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 Mo("Cannot remove sequence, sequence not configured!");return this._result.Guid==e&&this._result.RightArgumentType!=Co.Null?(this._result.RightArgument.Name=this._result.Name,this._result.RightArgument.Icon=this._result.Icon,this._result.RightArgument.Guid=this._result.Guid,this._result=this._result.RightArgument,this._result.AtMeetCondition=!0,n(this._result,e)):r(this._result,e),{GetNext:()=>this.GetNext(),GetPrevious:()=>this.GetPrevious(),GetByGuid:e=>this.GetByGuid(e),GetAllowedArguments:()=>this.GetAllowedArguments(),RemoveSequenceByGuid:e=>this.RemoveSequenceByGuid(e),Commit:()=>this.Commit(),ArgumentAsActionWithEmptyCondition:()=>this.ArgumentAsActionWithEmptyCondition(),ArgumentAsAstronomicalClockWithOffset:(e,t,n)=>this.ArgumentAsAstronomicalClockWithOffset(e,t,n),ArgumentAsDaysOfWeek:(e,t,n)=>this.ArgumentAsDaysOfWeek(e,t,n),ArgumentAsDeviceState:(e,t,n,r=Qs.Equal)=>this.ArgumentAsDeviceState(e,t,n,r),ArgumentAsTime:(e,t,n=Qs.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!=Co.Null)return e(t.RightArgument);null!=this._rawExistingSequenceTasks&&(t.Tasks=this._rawExistingSequenceTasks)};if(null==this._result)throw new Mo("Sequence are not initialized! Not found root sequence.");return this._editingExistingSequence&&e(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}DeviceTask(e){if(this._tmpTask=this.ParseDeviceTask(e),null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:se.GenerateMd5(JSON.stringify(this._tmpTask))}}ParseDeviceTask(e){const t=new Go;return t.Channel=e.Channel,t.DeviceGuid=e.DeviceGuid,t.ControlFeature=this.MapTaskTypeToControlFeature(e.TaskType),t.Data={},t.Data.Channel=e.Channel,e.TaskType==Ut.SetBlindPosition||e instanceof as?(t.Data.Position=e.Position,t.Data.Action=e.Action):e.TaskType==Ut.SetBlindPositionSimple||e instanceof us?(t.Data.Action=e.Action,t.Data.Position=0):e.TaskType==Ut.SetLightColor||e instanceof os?(t.Data.R=e.R,t.Data.G=e.G,t.Data.B=e.B):e.TaskType==Ut.SetLightTemperature||e instanceof is?t.Data.Temperature=e.Temperature:e.TaskType==Ut.SetLightBrightness||e instanceof rs?t.Data.Brightness=e.Brightness:e.TaskType==Ut.SetTemperature||e instanceof Zr?t.Data.Temperature=e.Temperature:e.TaskType==Ut.TurnOnWithTime||e instanceof ns?t.Data.SwitchOffDelaySeconds=e.SwitchOffDelaySeconds:e.TaskType==Ut.SetLightBrightnessDynamicly||e instanceof ls?t.Data.Brightness=e.Brightness:e.TaskType==Ut.SetBlindOpenCloseTime||e instanceof hs?(t.Data.CloseTime=e.Data.CloseTime,t.Data.OpenTime=e.Data.OpenTime):e.TaskType==Ut.SetBlindMicroventilation||e instanceof fs?t.Data.Position=e.Position:e.TaskType==Ut.SetFacadePosition||e instanceof ms?(t.Data.FacadeAction=e.FacadeAction,t.Data.Position=e.Position,t.Data.Tilt=e.Tilt):e.TaskType==Ut.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):(e.TaskType==Ut.PreciseGateControl||e instanceof cs)&&(t.Data.Position=e.Position,t.Data.GateControlAction=e.GateControlAction),t}DelayTask(e){const t=new Ro;if("00:00:00"==e.Delay.Value)throw new Oo("Delay must be other than 00:00:00!");if(t.Delay=e.Delay.Value,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:se.GenerateMd5(JSON.stringify(t))}}NotifyTask(e){if(e.NotifyType==ro.Email)throw new Fo("NotifyType 'Email' is not supported!");if(e.NotifyType==ro.None)throw new Error("NotifyType mus be set!");if(""==e.Message)throw new Oo("Message must be set!");if(e.Message.length>1e3)throw new Oo("Message is too long! Max length is 1000 characters.");const t=new Uo;if(t.NotifyType=e.NotifyType,t.Message=e.Message,t.NotificationClients=e.NotificationClients,t.Title=this._sequenceName,this._tmpTask=t,null==this._result)throw new Error("No context!");return{AddTask:()=>this.AddTask(),EditTask:e=>this.EditTask(e),TaskId:se.GenerateMd5(JSON.stringify(t))}}LockExecutionTask(e){const t=new Po;if(t.LockType=e.LockType,t.LockType==so.Timeout&&"00:00:00"!=t.LockEndHour)throw new Fo("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=>{var n;if(t.RightArgumentType!=Co.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 Go&&t.Tasks.DevicesTasks.push(structuredClone(this._tmpTask)),t.Tasks.ControllerTasks.push(structuredClone(this._tmpTask)),this._tmpTask=null,null===(n=u.Log)||void 0===n||n.Debug(`Task added to sequence: \n${JSON.stringify(this._tmpTask)} \ntasks on a list: \n${JSON.stringify(t.Tasks)}`)};if(null==this._result)throw new Error("No context!");return e(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}EditTask(e){const t=n=>{var r;if(n.RightArgumentType!=Co.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 xo("Task not found, cannot edit!");this._tmpTask instanceof Go&&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,null===(r=u.Log)||void 0===r||r.Debug(`Task edited in sequence: \n${JSON.stringify(this._tmpTask)} \ntasks on a list: \n${JSON.stringify(n.Tasks)}`)};if(null==this._result)throw new Error("No context!");return t(this._result),{GetSupportedTypesOfTasks:()=>this.GetSupportedTaskTypesAsync(),DeviceTask:e=>this.DeviceTask(e),DelayTask:e=>this.DelayTask(e),NotifyTask:e=>this.NotifyTask(e),LockExecutionTask:e=>this.LockExecutionTask(e),RemoveTask:e=>this.RemoveTask(e),Build:()=>this.Build(),BuildToISequence:()=>this._service.MapSequence(JSON.parse(JSON.stringify(this._result))),ValidateScene:()=>this.ValidateScene()}}RemoveTask(e){const t=(e,n)=>{var r,s;if(e.RightArgumentType!=Co.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,null===(s=null===(r=e.Tasks)||void 0===r?void 0:r.DevicesTasks)||void 0===s?void 0:s.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 Ut.Unknown:throw new Oo("Unsupported task type!");case Ut.SetBlindPosition:case Ut.SetBlindPositionSimple:return $r.SetBlindPosition;case Ut.SetBlindMicroventilation:return $r.SetBlindMicroventilation;case Ut.TurnOff:return $r.TurnOff;case Ut.TurnOn:return $r.TurnOn;case Ut.TurnOnWithTime:return $r.TurnOnWithTimeout;case Ut.TogleState:return $r.ToggleState;case Ut.SetLightBrightnessDynamicly:return $r.SetLightBrightnessDynamicly;case Ut.SetLightBrightness:return $r.SetLightBrightness;case Ut.SetLightColor:return $r.SetLightColor;case Ut.SetLightTemperature:return $r.SetLightTemperature;case Ut.PairDevice:case Ut.UnpairDevice:throw new Oo("Unsupported task type!");case Ut.IdentifyDevice:return $r.IdentifyDevice;case Ut.GetChannelsState:return $r.GetState;case Ut.GetPowerMeasurements:case Ut.GetAvailableData:case Ut.MultipleDataRequest:throw new Oo("Unsupported task type!");case Ut.SetBlindOpenCloseTime:return $r.SetBlindOpenCloseTime;case Ut.SetTemperature:return $r.SetTemperature;case Ut.ChangeGatePositionPulse:return $r.GatePulse;case Ut.ChangeGatewayPositionPulse:return $r.GatewayPulse;case Ut.SetFacadePosition:case Ut.GetFacadeType:return $r.SetFacadePositionAndTilt;case Ut.LightRGBW:return $r.LightRGBW;case Ut.PreciseGateControl:return $r.SetGatePositionPrecise;default:throw new Oo("Unsupported task type!")}}GetSupportedTaskTypesAsync(){return e=this,t=void 0,r=function*(){const e=yield gy.Get(uo.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[no.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(no.DelayTask),(t>5||5==t&&n>=37)&&r.push(no.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(no.NotifyTaskAppNotify),r},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}Build(){const e=t=>{if(t.RightArgumentType!=Co.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==Co.Condition?this.FindArgumentWithGuid(e.RightArgument,t):null}GetAllowedArguments(){const e=[];return null==this._result?(e.push({ArgumentType:_o.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:_o.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:_o.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:_o.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:_o.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e.push({ArgumentType:_o.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1})):null!=this._result&&(null==this._result.RightArgument||this._result.RightArgument instanceof ko)&&(this._result.LeftArgumentType==Co.ArgumentAsDaysOfWeek&&(e.push({ArgumentType:_o.ArgumentAsTime,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),e.push({ArgumentType:_o.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0})),this._result.LeftArgumentType==Co.ArgumentAsTime&&e.push({ArgumentType:_o.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1}),this._result.LeftArgumentType==Co.ArgumentAsAstronomicalClockWithOffset&&e.push({ArgumentType:_o.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!1})),0==e.any((e=>e.ArgumentType==_o.ArgumentAsAstronomicalClockWithOffset))&&e.push({ArgumentType:_o.ArgumentAsAstronomicalClockWithOffset,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==_o.ArgumentAsDaysOfWeek))&&e.push({ArgumentType:_o.ArgumentAsDaysOfWeek,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==_o.ArgumentAsDeviceState))&&e.push({ArgumentType:_o.ArgumentAsDeviceState,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==_o.ArgumentAsSceneExecuted))&&e.push({ArgumentType:_o.ArgumentAsSceneExecuted,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),0==e.any((e=>e.ArgumentType==_o.ArgumentAsTime))&&e.push({ArgumentType:_o.ArgumentAsTime,InitialAtMeetConditionValue:!1,ChangableAtMeetCondition:!0}),0==e.any((e=>e.ArgumentType==_o.ArgumentAsTimeSpan))&&e.push({ArgumentType:_o.ArgumentAsTimeSpan,InitialAtMeetConditionValue:!0,ChangableAtMeetCondition:!1}),e}ValidateScene(){var e,t,n,r;if(null==this._result)throw new Error("No context!");const s=[],o=(e,t,n)=>e.RightArgumentType==Co.Null?e.LeftArgumentType==t&&e.AtMeetCondition==n?e:null:e.LeftArgumentType==t&&e.AtMeetCondition==n?e:o(e.RightArgument,t,n),i=o(this._result,Co.ArgumentAsDaysOfWeek,!0);null!=i&&((null===(e=i.RightArgument)||void 0===e?void 0:e.LeftArgumentType)==Co.ArgumentAsTime||(null===(t=i.RightArgument)||void 0===t?void 0:t.LeftArgumentType)==Co.ArgumentAsAstronomicalClockWithOffset)&&s.push(Ao.OptimizeDayOfWeekArgument);const a=o(this._result,Co.ArgumentAsTime,!0);return null!=a&&(null===(n=a.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==Co.ArgumentAsDaysOfWeek&&(null===(r=a.RightArgument)||void 0===r?void 0:r.AtMeetCondition)&&s.push(Ao.OptimizeAtInDayOfWeekArgument),{IsValid:0==s.length,Errors:s,TryFix:()=>this.TryFix(s),Ignore:()=>this.Commit()}}TryFix(e){if(null==this._result)throw new Error("No context!");if(e.includes(Ao.OptimizeDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==Co.ArgumentAsDaysOfWeek?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==Co.ArgumentAsTime||(null===(r=t.RightArgument)||void 0===r?void 0:r.LeftArgumentType)==Co.ArgumentAsAstronomicalClockWithOffset?t:e(t.RightArgument):t.RightArgumentType==Co.Null?null:e(t.RightArgument)},t=e(this._result);if(null==t)throw new Error("Something wrong! Cannot find 'days of week' argument! Cannot fix!");const n=structuredClone(t),r=t.RightArgument;t.LeftArgument=r.LeftArgument,t.LeftArgumentType=r.LeftArgumentType,t.HandledType=r.HandledType,r.LeftArgument=n.LeftArgument,r.LeftArgumentType=n.LeftArgumentType,r.HandledType=n.HandledType,r.AtMeetCondition=!1}if(this.ValidateScene().Errors.includes(Ao.OptimizeAtInDayOfWeekArgument)){const e=t=>{var n,r;return t.LeftArgumentType==Co.ArgumentAsTime?(null===(n=t.RightArgument)||void 0===n?void 0:n.LeftArgumentType)==Co.ArgumentAsDaysOfWeek&&(null===(r=t.RightArgument)||void 0===r?void 0:r.AtMeetCondition)?t:e(t.RightArgument):t.RightArgumentType==Co.Null?null:e(t.RightArgument)},t=e(this._result);if(null==t)return this.Commit();t.RightArgument.AtMeetCondition=!1}return this.Commit()}}!function(e){e.OptimizeDayOfWeekArgument="OptimizeDayOfWeekArgument",e.OptimizeAtInDayOfWeekArgument="OptimizeAtInDayOfWeekArgument"}(Ao||(Ao={})),function(e){e.Unknown="Unknown",e.ArgumentAsAstronomicalClockWithOffset="ArgumentAsAstronomicalClockWithOffset",e.ArgumentAsDaysOfWeek="ArgumentAsDaysOfWeek",e.ArgumentAsTimeSpan="ArgumentAsTimeSpan",e.ArgumentAsTime="ArgumentAsTime",e.ArgumentAsDeviceState="ArgumentAsDeviceState",e.ArgumentAsSceneExecuted="ArgumentAsSceneExecuted"}(_o||(_o={}));class Do{constructor(){this.Tasks=new bo,this.Guid="",this.ObjectType=1,this.Name="",this.Icon="",this.AtMeetCondition=!1,this.ExecuteOnce=!1,this.IsDisabled=!1,this.HandledType=Ys.Unknown,this.ConditionType=Qs.Unknown,this.ConditionTimeout=0,this.LeftArgumentType=Co.Null,this.RightArgumentType=Co.Null,this.LeftArgument=new Io({},Co.Null),this.RightArgument=new ko}}class ko{constructor(){this.HandledType=0,this.Argument=null}}class Io{constructor(e,t){this.Argument=e,this.HandledType=t}}class Eo{constructor(){this.DeviceStateType=Zs.Unknown,this.Channel=0,this.DeviceGuid="",this.ComparisonMethod=Ks.Default,this.ComparisonParams=null,this.CheckedDeviceState={}}}class bo{constructor(){this.ControllerTasks=[],this.DevicesTasks=[]}}class No{constructor(){this.Guid=Yr.NewGuid(),this.RunParallel=!1,this.TaskType=Js.Unknown}}class Go extends No{constructor(){super(...arguments),this.TaskType=Js.DeviceTask,this.DeviceGuid="",this.Channel=0,this.ControlFeature=$r.TurnOn}}class Ro extends No{constructor(){super(...arguments),this.TaskType=Js.DelayTask,this.Delay="00:00:00"}}class Po extends No{constructor(){super(...arguments),this.TaskType=Js.LockExecution,this.LockType=so.Timeout,this.LockStartHour="00:00:00",this.LockEndHour="00:00:00",this.ResetLockScenesGuids=[]}}class Uo extends No{constructor(){super(...arguments),this.TaskType=Js.NotifyTask,this.Title="",this.Message="",this.NotifyType=ro.None,this.NotificationClients=[]}}!function(e){e[e.Null=0]="Null",e[e.Condition=1]="Condition",e[e.ConditionGroup=2]="ConditionGroup",e[e.ArgumentAsInt=3]="ArgumentAsInt",e[e.ArgumentAsTimeSpan=4]="ArgumentAsTimeSpan",e[e.ArgumentAsBoolean=5]="ArgumentAsBoolean",e[e.ArgumentAsTimeout=6]="ArgumentAsTimeout",e[e.ArgumentAsDayOfWeek=7]="ArgumentAsDayOfWeek",e[e.ArgumentAsDaysOfWeek=8]="ArgumentAsDaysOfWeek",e[e.ArgumentAsAstronomicalClock=9]="ArgumentAsAstronomicalClock",e[e.ArgumentAsTime=10]="ArgumentAsTime",e[e.ArgumentAsDeviceState=11]="ArgumentAsDeviceState",e[e.ArgumentAsNumber=12]="ArgumentAsNumber",e[e.ArgumentAsAstronomicalClockWithOffset=13]="ArgumentAsAstronomicalClockWithOffset",e[e.ArgumentAsConditionInfo=14]="ArgumentAsConditionInfo"}(Co||(Co={}));class Oo extends Error{constructor(e){super(e),this.message=e,this.name="BadParametersScenesBuilderException"}}class Mo extends Error{constructor(e){super(e),this.message=e,this.name="SequenceNotFoundScenesBuilderException"}}class xo extends Error{constructor(e){super(e),this.message=e,this.name="TaskNotFoundScenesBuilderException"}}class Fo extends Error{constructor(e){super(e),this.message=e,this.name="UnsupportedArgumentScenesBuilderException"}}var Lo,Bo=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 Wo{constructor(){this._connection=gy.Get(bt.ServiceName),this._configurationService=gy.Get(lt.ServiceName)}GetServiceName(){return Wo.ServiceName}GetSequencesListAsync(){return Bo(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new $o,12e3,!1);return null===(t=u.Log)||void 0===t||t.Debug(`GetSequencesListAsync result:\n ${JSON.stringify(n)}}`),null==n?new Ne(Hs.OtherError,"Cannot get sequences list - response is null."):n.Status!=ue.OK?new Ne(Hs.OtherError,`Cannot get sequences list - controller responded with response code ${n.Status}.`):null==n.Data?new Ne(Hs.NoData,"Cannot get sequences list - controller responded with status OK, but response does not contain data!"):n.Data}))}GetSequenceAsync(e){return Bo(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 Vo(n),12e3,!1);if(null==r)return new Ne(Hs.OtherError,"Cannot get sequence - response is null.");if(r.Status!=ue.OK)return new Ne(Hs.OtherError,`Cannot get sequence - controller responded with response code ${r.Status}.`);if(null==r.Data)return new Ne(Hs.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");const s=r.Data;let o=this.MapSequence(s);if("string"==typeof e){let e=yield this.GetSequencesListAsync();if(e instanceof Ne){let t=e;console.warn(`Cannot get sequence - response is null. Error: ${t.Data} ${t.Type}`)}else{const t=e.find((e=>e.Guid==n));if(!t)return new Ne(Hs.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!");o.IsDisabled=t.IsDisabled}}else{const e=s;o.IsDisabled=e.IsDisabled}return o}))}GetSequenceBuilder(e,t){return new To(e,t)}CreateSequenceAsync(e){return Bo(this,void 0,void 0,(function*(){var t,n,r,s;try{yield this._configurationService.EnterConfigurationModeAsync(),null===(t=u.Log)||void 0===t||t.Debug(`Creating sequence ${e.Name} json: \n${JSON.stringify(e)}`);const r=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new jo(e),2e4,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(t){return null===(r=u.Log)||void 0===r||r.Error(`Creating sequence ${e.Name} error: ${t}`),ue.FatalError}finally{null===(s=u.Log)||void 0===s||s.Error(Wo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! CreateSequenceAsync()"),yield this._configurationService.ExitConfigurationModeAsync(),yield gy.Get(Zo.ServiceName).GetDevicesAsync(!0)}}))}CheckIfSequenceIsUsedInAnotherSequenceAsync(e){return Bo(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 qo(n),12e3,!1);if(null==r)return new Ne(Hs.OtherError,"Cannot get sequence - response is null.");switch(r.Status){case ue.WrongData:return new Ne(Hs.InvalidSceneGuid,"Cannot check if sequence is used in another sequence! Sequence not found, invalid sequence guid!");case ue.OK:return null==r.Data?new Ne(Hs.NoData,"Cannot get sequence - controller responded with status OK, but response does not contain data!"):r.Data;default:return new Ne(Hs.OtherError,`Cannot check if sequence is used in another sequence! Controller responded with code: ${r.Status}`)}}catch(e){return new Ne(Hs.FatalError,`Cannot check if sequence is used in another sequence! Fatal error! ${e}`)}}))}DeleteSequenceAsync(e){return Bo(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 Jo(n),12e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield gy.Get(Zo.ServiceName).GetDevicesAsync(!0)}}))}EditSequenceAsync(e){return Bo(this,void 0,void 0,(function*(){var t,n;try{const n={Guid:e.Guid,Icon:e.Icon,Name:e.Name,Condition:e};var r=n.Condition.IsDisabled;n.Condition.IsDisabled=!1,yield this._configurationService.EnterConfigurationModeAsync();const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new zo(n),2e4,!1);return n.Condition.IsDisabled=r,null==s||null==s.Status?ue.Error:s.Status}catch(t){return null===(n=u.Log)||void 0===n||n.Error(`Editing sequence ${e.Name} error: ${t}`),ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync(),yield gy.Get(Zo.ServiceName).GetDevicesAsync(!0)}}))}EnableSequenceAsync(e){return Bo(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 Xo(n),12e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}DisableSequenceAsync(e){return Bo(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 Yo(n),12e3,!1);return null==r||null==r.Status?ue.Error:r.Status}catch(e){return ue.FatalError}finally{yield this._configurationService.ExitConfigurationModeAsync()}}))}RunSequenceAsync(e){return Bo(this,void 0,void 0,(function*(){let t="";if("string"==typeof e){const n=yield this.GetSequencesListAsync();if(null!=n.Type)return ue.Error;{const r=n.find((t=>t.Guid==e));if(!r)return ue.Error;t=r.DeviceGuid}}else t=e.DeviceGuid;const n=new ts;switch(n.Channel=1,n.DeviceGuid=t,yield gy.Get(Zo.ServiceName).ExecuteDeviceTaskAsync({Guid:t},n)){case Bt.Executed:return ue.OK;case Bt.DeviceNotFound:return ue.WrongData;default:return ue.Error}}))}GetUtilsAsync(){return Bo(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 Bo(this,void 0,void 0,(function*(){var e;const t=gy.Get(xs.ServiceName),n=new Rs;let r=!1;n.Latitude=49.9958888026741,n.Longitude=18.9172596008914;try{if(!0===(yield t.IsControllerGeolocationSetAsync())){const e=yield t.GetControlllerGeolocationAsync();e instanceof Ps&&(n.Latitude=e.Latitude,n.Longitude=e.Longitude)}}catch(t){null===(e=u.Log)||void 0===e||e.Warning(`Cannot get localization data, using default values: 49.9958888026741, 18.9172596008914. Error: ${t}`)}const s=e=>{let t=7.95204*Math.sin(.01768*e+3.03217)+9.98906*Math.sin(.03383*e+3.4687)+4*(n.Longitude-15*Math.round(n.Longitude/15));return((e=new Date)=>{const t=new Date(e.getFullYear(),0,1).getTimezoneOffset(),n=new Date(e.getFullYear(),6,1).getTimezoneOffset();return Math.max(t,n)!==e.getTimezoneOffset()})()&&(t-=60),t},o=e=>Math.asin(-.39795*Math.cos(2*Math.PI*(e+10)/365)),i=e=>{const t=n.Latitude*Math.PI/180;let r=Math.sin(t)*Math.sin(e)/(Math.cos(t)*Math.cos(e));return r=(e=>(e<-1&&(e=-1),e>1&&(e=1),e))(r),r},a=e=>{const t=Math.ceil(e/60),n=e-60*t,r=new Date;return new Date(r.getFullYear(),r.getMonth(),r.getDate(),t,n)},c=e=>{const t=new Date;t.setDate(t.getDate()+e);const n=(u=t,Math.floor((u.valueOf()-new Date(u.getFullYear(),0,0).valueOf())/1e3/60/60/24));var u;const l=s(n),d=o(n),h=((e,t)=>{let n=720-720/Math.PI*Math.acos(-e)-t;return n<0&&(n+=1440),n})(i(d),l),p=a(h);return new Date>p&&!r?(r=!0,c(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),p.getHours(),p.getMinutes()))},l=e=>{const t=new Date;t.setDate(t.getDate()+e);const n=(c=t,Math.floor((c.valueOf()-new Date(c.getFullYear(),0,0).valueOf())/1e3/60/60/24));var c;const u=s(n),d=o(n),h=i(d),p=Math.floor(((e,t)=>{let n=720+720/Math.PI*Math.acos(-e)-t;return n>1439&&(n-=1439),n})(h,u)),g=a(p);return new Date>g&&!r?(r=!0,l(1)):(r=!1,new Date(t.getFullYear(),t.getMonth(),t.getDate(),g.getHours(),g.getMinutes()))};return{GetSunRiseTime:()=>c(0),GetSunSetTime:()=>l(0)}}))}MapSequence(e,t=!1){const n=Object.assign({},e),r=e=>{if(e.RightArgumentType!=Lo.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=Js.DeviceTask,e.RunParallel=!1}))),null!=e.Tasks.ControllerTasks&&e.Tasks.ControllerTasks.map((e=>{null==(null==e?void 0:e.Guid)&&(e.Guid=Yr.NewGuid())}))};return r(e),n._rawRequestData=JSON.parse(JSON.stringify(e)),t?(n.RightArgument=null,n.RightArgumentType=to.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==to.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===to.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 to.ArgumentAsAstronomicalClock:n.Argument.ArgumentAsAstronomicalClock={Position:e.Argument};break;case to.ArgumentAsAstronomicalClockWithOffset:n.Argument.ArgumentAsAstronomicalClockWithOffset={Offset:e.Argument.Offset,Position:e.Argument.Position};break;case to.ArgumentAsBoolean:n.Argument.ArgumentAsBoolean=e.Argument;break;case to.ArgumentAsDayOfWeek:n.Argument.ArgumentAsDayOfWeek=e.Argument;break;case to.ArgumentAsDaysOfWeek:n.Argument.ArgumentAsDaysOfWeek=e.Argument;break;case to.ArgumentAsInt:n.Argument.ArgumentAsInt=e.Argument;break;case to.ArgumentAsTimeout:n.Argument.ArgumentAsTimeout=e.Argument;break;case to.ArgumentAsTimeSpan:n.Argument.ArgumentAsTimeSpan={days:e.Argument.days,hours:e.Argument.hours,minutes:e.Argument.minutes,seconds:e.Argument.seconds};break;case to.ArgumentAsTime:n.Argument.ArgumentAsTime={Hour:e.Argument.Hour,Minute:e.Argument.Minute,Second:e.Argument.Second};break;case to.ArgumentAsDeviceState:{const t=new vo;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?Ks.Default:e.Argument.ComparisonMethod,null!=e.Argument.ComparisonParams&&Object.entries(e.Argument.ComparisonParams).forEach((e=>{switch(e[0]){case"DeltaValue":case"StateRepeatCount":t.SetComparisonParam(js[e[0]],new yo(e[1]));break;case"DeltaCalculationTimeRange":case"StateRepeatTimeRange":t.SetComparisonParam(js[e[0]],new mo(e[1]))}})),n.Argument.ArgumentAsDeviceState=t;break}case to.ArgumentAsConditionInfo:n.Argument.ArgumentAsConditionInfo={DeviceGuid:e.Argument.DeviceGuid}}return n}MapArgumentType(e){return to[Lo[e]]}MapDeviceStateTypeToResponseType(e){switch(e){case Zs.BatteryState:return Ot.BatteryState;case Zs.BinarySensor:return Ot.BinarySensorState;case Zs.BlindPosition:return Ot.BlindPosition;case Zs.Brightness:return Ot.MeasuredBrightness;case Zs.ButtonState:return Ot.RemoteButtonState;case Zs.ChannelOnOff:return Ot.ChannelOnOffState;case Zs.DoorBell:return Ot.DoorBellState;case Zs.Energy:return Ot.MeasuredEnergy;case Zs.FloodSensor:return Ot.FloodSensorState;case Zs.GatePosition:return Ot.GatePosition;case Zs.LightBrightness:return Ot.LightBrightness;case Zs.LightColor:return Ot.LightColor;case Zs.LightTemperature:return Ot.LightWarmth;case Zs.ReedState:return Ot.ReedState;case Zs.SmokeSensor:return Ot.SmokeSensorState;case Zs.Temperature:return Ot.MeasuredTemperature;case Zs.Humidity:return Ot.HumiditySensorState;case Zs.BlindsControlButton:return Ot.BlindRemoteButtonState;case Zs.FacadeControlButton:return Ot.FacadeRemoteButtonState;case Zs.Movement:return Ot.MovementSensorState;case Zs.AirPressure:return Ot.PressureSensorState;case Zs.WindSpeed:return Ot.WindSpeedState;case Zs.WindThreshold:return Ot.CurrentWindThreshold;default:return Ot.Unknown}}CreateDeviceState(e,t,n){switch(n){case Ot.BatteryState:return{Channel:t,StateReliability:Xt.Unconfident,Percentage:e.Percentage,State:e.State,Time:""};case Ot.BinarySensorState:return{Channel:t,StateReliability:Xt.Unconfident,State:e.State,Time:""};case Ot.BlindPosition:return{Channel:t,StateReliability:Xt.Unconfident,Position:e.Position,RawPosition:e.RawPosition,Time:""};case Ot.LightBrightness:case Ot.MeasuredBrightness:return{Channel:t,StateReliability:Xt.Unconfident,Brightness:e.Brightness,Time:""};case Ot.RemoteButtonState:case Ot.ChannelOnOffState:case Ot.DoorBellState:return{Channel:t,StateReliability:Xt.Unconfident,State:e.State,Time:""};case Ot.MeasuredEnergy:{const n=new Map;for(let[t,r]of Object.entries(e.MeasurementParameters))n.set(sn[t],r);return{Channel:t,StateReliability:Xt.Unconfident,MeasurementParameters:n,Time:""}}case Ot.FloodSensorState:return{Channel:t,StateReliability:Xt.Unconfident,State:e.State,Time:""};case Ot.GatePosition:return{Channel:t,StateReliability:Xt.Unconfident,Position:e.Position,PositionType:e.PositionType,Time:""};case Ot.LightColor:return{Channel:t,StateReliability:Xt.Unconfident,R:e.R,G:e.G,B:e.B,Time:""};case Ot.LightWarmth:return{Channel:t,StateReliability:Xt.Unconfident,Temperature:e.Temperature,Time:""};case Ot.ReedState:return{Channel:t,StateReliability:Xt.Unconfident,State:e.State,Time:""};case Ot.SmokeSensorState:throw new So("Unsupported device state!");case Ot.MeasuredTemperature:return{Channel:t,StateReliability:Xt.Unconfident,Temperature:e.Temperature,Time:"",Type:e.Type};case Ot.HumiditySensorState:return{Channel:t,StateReliability:Xt.Unconfident,Humidity:e.Humidity,Time:"",Type:e.Type};case Ot.BlindRemoteButtonState:return{Channel:t,StateReliability:Xt.Unconfident,State:e.State,Time:""};case Ot.LightRGBWState:return{StateReliability:Xt.Unconfident,Channel:t,Time:"",Brightness:100,R:e.R,G:e.G,B:e.B,W:e.W};case Ot.FacadeRemoteButtonState:return{Channel:t,Time:"",StateReliability:Xt.Unconfident,State:e.State};case Ot.MovementSensorState:return{Channel:t,Time:"",StateReliability:Xt.Unconfident,Movement:e.Movement,Intensity:e.Intensity};case Ot.PressureSensorState:return{Channel:t,Time:"",StateReliability:Xt.Unconfident,Pressure:e.Pressure,PressureType:e.PressureType};case Ot.WindSpeedState:return{Channel:t,Time:"",StateReliability:Xt.Unconfident,Value:e.Value};case Ot.CurrentWindThreshold:return{Channel:t,Time:"",StateReliability:Xt.Unconfident,WindThreshold:e.WindThreshold};case Ot.Unknown:return new En;default:throw new So("Unsupported device state!")}}MapDeviceTask(e){var t;let n=new Qr,r=e;switch(null===(t=u.Log)||void 0===t||t.Debug(`[TASK] object: ${JSON.stringify(r)}`),r.ControlFeature){case $r.TurnOn:n=new ts,n.TaskType=Ut.TurnOn;break;case $r.TurnOff:n=new es,n.TaskType=Ut.TurnOff;break;case $r.ToggleState:n=new ss,n.TaskType=Ut.TogleState;break;case $r.SetBlindPosition:{const e=gy.Get(Zo.ServiceName).GetDevice(r.DeviceGuid);(null==e?void 0:e.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType)))?(n=new us,n.TaskType=Ut.SetBlindPositionSimple,n.Action=r.Data.Action):(n=new as,n.TaskType=Ut.SetBlindPosition,n.Action=r.Data.Action,n.Position=r.Data.Position);break}case $r.SetLightColor:n=new os,n.TaskType=Ut.SetLightColor,n.R=r.Data.R,n.G=r.Data.G,n.B=r.Data.B;break;case $r.SetLightTemperature:n=new is,n.TaskType=Ut.SetLightTemperature,n.Temperature=r.Data.Temperature;break;case $r.SetLightBrightness:n=new rs,n.TaskType=Ut.SetLightBrightness,n.Brightness=r.Data.Brightness;break;case $r.SetTemperature:n=new Zr,n.TaskType=Ut.SetTemperature,n.Temperature=r.Data.Temperature;break;case $r.GetState:n=new gs,n.TaskType=Ut.GetChannelsState;break;case $r.TurnOnWithTimeout:n=new ns,n.TaskType=Ut.TurnOnWithTime,n.SwitchOffDelaySeconds=r.Data.SwitchOffDelaySeconds;break;case $r.SetLightBrightnessDynamicly:n=new ls,n.TaskType=Ut.SetLightBrightnessDynamicly,n.Brightness=r.Data.Brightness;break;case $r.IdentifyDevice:n=new ds,n.TaskType=Ut.IdentifyDevice;break;case $r.SetBlindOpenCloseTime:n=new hs,n.TaskType=Ut.SetBlindOpenCloseTime,n.Data.CloseTime=r.Data;break;case $r.SetBlindMicroventilation:n=new fs,n.TaskType=Ut.SetBlindMicroventilation,n.Position=r.Data.Position;break;case $r.GatewayPulse:n=new ys,n.TaskType=Ut.ChangeGatewayPositionPulse;break;case $r.GatePulse:n=new vs,n.TaskType=Ut.ChangeGatePositionPulse;break;case $r.SetFacadePositionAndTilt:n=new ms,n.TaskType=Ut.SetFacadePosition,n.Position=r.Data.Position,n.Tilt=r.Data.Tilt,n.FacadeAction=Kr.TiltAndPercentage;break;case $r.GetFacadeType:n=new ws,n.TaskType=Ut.GetFacadeType;break;case $r.LightRGBW:n=new As,n.TaskType=Ut.LightRGBW,n.Data=r.Data;break;case $r.SetGatePositionPrecise:n=new cs,n.TaskType=Ut.PreciseGateControl,n.Position=r.Data.Position,n.GateControlAction=r.Data.GateControlAction}return n.Channel=r.Channel,n.DeviceGuid=r.DeviceGuid,n.FeatureType=r.ControlFeature,n.Guid=Yr.NewGuid(),n}MapControllerTasks(e){var t,n;const r=[];null===(t=u.Log)||void 0===t||t.Debug(`[TASKS] received tasks object: ${JSON.stringify(e)}`);for(let t of e){const e=new Ko;switch(e.Guid=t.Guid,e.TaskId=se.GenerateMd5(JSON.stringify(t)),t.TaskType){case Js.DeviceTask:e.TaskType=Xs.DeviceTask,e.Task.DeviceTask=this.MapDeviceTask(t);break;case Js.DelayTask:e.TaskType=Xs.DelayTask,e.Task.DelayTask={Delay:new mo(t.Delay)};break;case Js.NotifyTask:e.TaskType=Xs.NotifyTask,e.Task.NotifyTask={Message:t.Message,NotifyType:t.NotifyType,NotificationClients:t.NotificationClients};break;case Js.LockExecution:case Js.LockExecution:e.TaskType=Xs.LockExecution,null===(n=u.Log)||void 0===n||n.Debug(`[TASKS] received task LockExecution object: ${JSON.stringify(t)}`),e.Task.LockExecution={LockStartHour:new mo(t.LockStartHour),LockEndHour:new mo(t.LockEndHour),LockType:t.LockType,ResetLockScenesGuids:t.ResetLockScenesGuids};case Js.Unknown:}r.push(e)}return r}GetSupportedTaskTypesAsync(){return Bo(this,void 0,void 0,(function*(){const e=yield gy.Get(uo.ServiceName).GetSoftwareRuntimeInfoAsync(),[t,n]=e.SoftwareVersion.split(".").map((e=>parseInt(e))),r=[no.DeviceTask];return(t>5||5==t&&n>=27)&&r.push(no.DelayTask),(t>5||5==t&&n>=37)&&r.push(no.LockExecutionTask),(t>6||6==t&&n>=3)&&r.push(no.NotifyTaskAppNotify),r}))}}Wo.ServiceName="ScenesService";class $o extends ce{constructor(){super(),this.Resource="/logic/sequences/list",this.Method=le.Get}}class Vo extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Get,this.Data=e}}class qo extends ce{constructor(e){super(),this.Resource="/logic/sequences/used",this.Method=le.Get,this.Data=e}}class Ho{constructor(){this.HandledType=Lo.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"}(Lo||(Lo={}));class Ko{constructor(){this.TaskId="",this.Guid="",this.TaskType=Xs.Unknown,this.Task={}}}class jo extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Put,this.Data=e}}class zo extends ce{constructor(e){super(),this.Resource="/logic/sequence/edit",this.Method=le.Put,this.Data=e}}class Jo extends ce{constructor(e){super(),this.Resource="/logic/sequence",this.Method=le.Delete,this.Data=e}}class Xo extends ce{constructor(e){super(),this.Resource="/logic/sequence/enable",this.Method=le.Post,this.Data=e}}class Yo extends ce{constructor(e){super(),this.Resource="/logic/sequence/disable",this.Method=le.Post,this.Data=e}}var Qo=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 Zo{constructor(){var e;this._devices=[],this._onDevicesTasksChangedEvent=new c,this._onDeviceFoundEvent=new c,this._onDeviceRegisteredEvent=new c,this._onDeviceRemovedEvent=new c,this._onDeviceFirmwareVersionChangedEvent=new c,this._onDeviceStateChangedEvent=new c,this._onDeviceStateRefreshedOrChangedEvent=new c,this._connection=null,this._session=null,this._controllerConfiguration=null,this._synchronized=!1,this._synchronizedDevicesStates=!1,this._devicesChannelsStates=[],this._onDevicesSynchronized=new Ee,this._onDevicesStatesSynchronized=new Ee,this._syncSemaphore=new nt(1),this._connection=gy.Get(bt.ServiceName),this._session=gy.Get(Qe.ServiceName),this._controllerConfiguration=gy.Get(lt.ServiceName),this._onDeviceStateChangedEvent.Subscribe((e=>Qo(this,void 0,void 0,(function*(){return this.PutDeviceStateOnList(e.Device,e.State)})))),null===(e=this._session)||void 0===e||e.OnUserLoggedInEvent().Subscribe((e=>Qo(this,void 0,void 0,(function*(){var t,n;try{null===(t=u.Log)||void 0===t||t.Debug(Zo.ServiceName,`User logged in: ${e.Guid} syncing devices...`),yield this.ResyncDevicesAsync()}catch(e){null===(n=u.Log)||void 0===n||n.Error(Zo.ServiceName,`Failed to sync devices and states: ${e}`)}})))),this._connection.SubscribeTo("/info/devices/tasks",(e=>{this.ParseDeviceTaskInfo(e.Data)})),this._connection.SubscribeTo("/info/devices/device/found",(e=>{this.MapApiDevices(e.Data).forEach((e=>{var t;e.DeviceType!=Ft.Scene&&(null===(t=u.Log)||void 0===t||t.Debug(Zo.ServiceName,`Found device: ${e.Name} guid: ${e.Guid}`),this._onDeviceFoundEvent.Invoke(e))}))})),this._connection.SubscribeTo("/info/devices/device/firmware/updated",(e=>{const t=e.Data.DeviceGuid,n=e.Data.Version,r=this._devices.find((e=>e.Guid==t));void 0!==r&&(this._onDeviceFirmwareVersionChangedEvent.Invoke({Device:r,FirmwareVersion:n}),r.SoftwareVersion=n,r.OnDeviceFirmwareVersionChangedEvent().Invoke({FirmwareVersion:n}))})),this._connection.SubscribeTo("/info/devices/device/state/changed",(e=>{var t;const n=e.Data,r=this._devices.filter((e=>e.Guid==n.DeviceGuid));if(r.length>0){const e=r[0],s=this.MapApiDeviceStateToDeviceState(e,n);if(null!=s){this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:s}),s.TypeAsEnum==Ot.SignalStrength?e.Channels.forEach((t=>{let r=new lr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateRefreshedOrChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==Ot.BatteryState&&e.Channels.forEach((t=>{let r=new Yn(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==Ot.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==Ot.SignalStrength?e.Channels.forEach((t=>{let r=new lr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==Ot.BatteryState&&e.Channels.forEach((t=>{let r=new Yn(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==Ot.SignalStrength?e.Channels.forEach((t=>{let r=new lr(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})})):s.TypeAsEnum==Ot.BatteryState&&e.Channels.forEach((t=>{let r=new Yn(Object.assign({},n));r.Data.Channel=t.Number,this._onDeviceStateChangedEvent.Invoke({Device:e,State:r})}))}}})),this._connection.SubscribeTo("/info/devices/devices/registered",(e=>{gy.Get($e.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Zo.ServiceName,`Registered device: ${e.Name} guid: ${e.Guid}`),this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e)}))})),this._connection.SubscribeTo("/info/devices/devices/removed",(e=>{gy.Get($e.ServiceName).ClearCache(),this.MapApiDevices(e.Data).forEach((e=>{var t;null===(t=u.Log)||void 0===t||t.Debug(Zo.ServiceName,`Removed device: ${e.Name} guid: ${e.Guid}`),this._devices=this._devices.filter((t=>t.Guid!=e.Guid)),this._onDeviceRemovedEvent.Invoke(e)}))}))}ResyncDevicesAsync(){return Qo(this,void 0,void 0,(function*(){var e;const t=yield this._syncSemaphore.AcquireAsync();try{this._synchronized=!1,this._synchronizedDevicesStates=!1,this._devices=yield this.GetPairedDevicesAsync(!0),this._synchronized=!0,this._onDevicesSynchronized.Invoke(),yield this.SyncDevicesStatesAsync(),this._synchronizedDevicesStates=!0,this._onDevicesStatesSynchronized.Invoke()}catch(t){null===(e=u.Log)||void 0===e||e.Error(Zo.ServiceName,`Failed to sync devices and states: ${t}`)}finally{t.Release()}}))}WaitForSynchronizationAsync(){var e;return this._synchronized?(null===(e=u.Log)||void 0===e||e.Debug(Zo.ServiceName,"Already synchronized"),Promise.resolve()):new Promise((e=>{const t=window.setTimeout((()=>{this._onDevicesSynchronized.Unsubscribe(n),e()}),3e4),n=()=>{var r;null===(r=u.Log)||void 0===r||r.Debug(Zo.ServiceName,"Fired onDevicesSynchronized event – clearing timeout & resolving promise"),window.clearTimeout(t),this._onDevicesSynchronized.Unsubscribe(n),e()};this._onDevicesSynchronized.Subscribe(n)}))}WaitForDevicesStatesSynchronizationAsync(){var e;return this._synchronizedDevicesStates?(null===(e=u.Log)||void 0===e||e.Debug(Zo.ServiceName,"Already synchronized states"),Promise.resolve()):new Promise((e=>{const t=window.setTimeout((()=>{this._onDevicesStatesSynchronized.Unsubscribe(n),e()}),12e4),n=()=>{var r;null===(r=u.Log)||void 0===r||r.Debug(Zo.ServiceName,"Fired onDevicesStatesSynchronized event, CLEARING timeout AND resolving WaitForDevicesStatesSynchronizationAsync promise"),window.clearTimeout(t),this._onDevicesStatesSynchronized.Unsubscribe(n),e()};this._onDevicesStatesSynchronized.Subscribe(n)}))}ProtocolGuidToProtocolName(e){switch(e){case"1fca7e8a-a2dc-4883-bd94-4e9b2012f685":return"ExtaLife";case"cd25bdff-628c-4dbc-a16a-648c96a819d4":return"Portos 433MHz";case"634c2bb2-1a4f-4db6-8dd4-d5fbaf92678e":return"Supla";case"194aeb81-990c-4a02-9236-59e902958fda":return"RTSP";case"b3e4644e-ab5b-494e-b3c5-66fabe7fff64":return"Wekta";case"247198e1-e360-4355-9886-232ac1456eea":return"Lavva Wi-Fi";default:return null}}CanDisplaySceneDevices(){return this.CheckIfControllerSoftwareVersionIsEnough(6,56)}CheckIfControllerSoftwareVersionIsEnough(e,t){var n,r,s;const o=null!==(s=null===(r=null===(n=this._session)||void 0===n?void 0:n.User)||void 0===r?void 0:r.SoftwareVersion)&&void 0!==s?s:null;if(!o||!o.includes("."))return!1;const i=o.split(".");if(2!==i.length)return!1;const a=i.map((e=>parseInt(e,10)));if(a.some((e=>Number.isNaN(e)||e<0)))return!1;const[c,u]=a;return c>e||c===e&&u>=t}CheckIfDeviceUsedInScenesAsync(e){return Qo(this,void 0,void 0,(function*(){var t,n,r,s,o,i;try{let i;if("string"==typeof e){const n=this.GetDevice(e);if(null==n)return null===(t=u.Log)||void 0===t||t.Error("Cannot check if device is used in scenes! Device with given guid not exists"),ue.ResourceDoesNotExists;i=n}else i=e;const a=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new pi(i.Guid),2e4,!1);if(null==a||null==a.Status)return null===(r=u.Log)||void 0===r||r.Error("Cannot check if device is used in scenes! Response or status is null!"),ue.FatalError;if(a.Status!=ue.OK)return a.Status;if(null==a.Data)return null===(s=u.Log)||void 0===s||s.Error("Cannot check if device is used in scenes! No data!"),ue.FatalError;let c=yield gy.Get(Wo.ServiceName).GetSequencesListAsync();if(c instanceof Ne)return null===(o=u.Log)||void 0===o||o.Error(`Cannot check if device is used in scenes! Cannot get sequence list, ScenesServiceErrorCode: ${c.Type}`),ue.Error;const l=new yi;return l.DeviceGuid=i.Guid,a.Data.ConditionsAsCondition.forEach((e=>{const t=c.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),a.Data.ConditionsAsTask.forEach((e=>{const t=c.find((t=>t.Guid==e));t&&l.ConditionsAsCondition.push(t)})),l}catch(e){return null===(i=u.Log)||void 0===i||i.Error(`Cannot check if device is used in scenes! ${e}`),ue.FatalError}}))}CanEditDevicesInfo(){var e,t;return null!==this._session&&void 0!==this._session&&null!==this._session.User&&void 0!==this._session.User&&(null===(t=null===(e=this._session)||void 0===e?void 0:e.User)||void 0===t?void 0:t.AccessLevel)>=ve.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)>=ve.Installator}GetDeviceChannelByChannelId(e){return this._devices.firstOrDefault((t=>t.Channels.any((t=>t.ChannelId==e)))).Channels.firstOrDefault((t=>t.ChannelId==e))}EnableFastStatesSyncAsync(){return Qo(this,void 0,void 0,(function*(){var e;const t=gy.Get(Is.ServiceName).SaveAsync("FastDevicesSync",!1,!0);return null===(e=u.Log)||void 0===e||e.Error(Zo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! EnableFastStatesSyncAsync()"),yield gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),t}))}DisableFastStatesSyncAsync(){return Qo(this,void 0,void 0,(function*(){var e;const t=gy.Get(Is.ServiceName).SaveAsync("FastDevicesSync",!1,!1);return null===(e=u.Log)||void 0===e||e.Error(Zo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! DisableFastStatesSyncAsync()"),yield gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),t}))}IsFastStatesSyncEnabledAsync(){return Qo(this,void 0,void 0,(function*(){const e=yield gy.Get(Is.ServiceName).ReadAsync("FastDevicesSync",!1,!1);return e instanceof Ts?e.Data:e!=ue.ResourceDoesNotExists&&e}))}GetDevicesForManualPairingAsync(e){return Qo(this,void 0,void 0,(function*(){let t=gy.Get(Cs.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 Qo(this,void 0,void 0,(function*(){var t;let n=yield gy.Get(Cs.ServiceName).AddManuallyPairedDeviceAsync(e);return null===(t=u.Log)||void 0===t||t.Error(Zo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddManuallyPairedDevice()"),yield gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),n}))}GetDeviceChannelStates(e,t){var n,r;return null!==(r=null===(n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===n?void 0:n.ChannelsStates.filter((e=>e.Channel==t)))&&void 0!==r?r:[]}GetDeviceStates(e){var t,n;return null!==(n=null===(t=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid)))||void 0===t?void 0:t.ChannelsStates)&&void 0!==n?n:[]}PutDeviceStateOnList(e,t){let n=this._devicesChannelsStates.firstOrDefault((t=>t.DeviceGuid==e.Guid));if(null==n){let r=new ei;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 ei,e.Channel=t.Data.Channel,e.States=[t],n.ChannelsStates.push(e);else{let n=e.States.firstOrDefault((e=>e.Type==t.Type));null!=n&&(n.TypeAsEnum==Ot.BlindErrorState?e.States=e.States.where((e=>e.Data.ErrorCode!=t.Data.ErrorCode)).toArray():e.States=e.States.where((e=>e.Type!=t.Type)).toArray()),e.States.push(t)}}}GetCurrentlyRunningTaksAsync(){return Qo(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ai,15e3,!1);(null==t?void 0:t.Status)==ue.OK&&null!=t.Data&&this.ParseDeviceTaskInfo(t.Data)}))}ParseDeviceTaskInfo(e){const t=[];e.forEach((e=>{const n=e.split(";"),r=new zt;if(r.DeviceGuid=n[0],r.Channel=Number(n[1]),r.Status=Nt.ExecutingTasks,t.push(r),0===r.Channel){const e=this._devices.find((e=>e.Guid==r.DeviceGuid));void 0!==e&&e.Channels.forEach((n=>{const r=new zt;r.DeviceGuid=e.Guid,r.Channel=n.Number,r.Status=Nt.ExecutingTasks,t.push(r)}))}})),this._onDevicesTasksChangedEvent.Invoke(t)}MapApiDeviceStateToDeviceState(e,t){var n;switch(t.state,t.DataType){case"ChannelOnOff":return new bn(t);case"DoorBell":return new On(t);case"ReedPosition":return new xn(t);case"BlindPosition":return new Ln(t);case"ButtonState":return new Wn(t);case"LightColor":return new Vn(t);case"LightTemperature":return new Hn(t);case"LightBrightness":return new jn(t);case"TemperatureSensor":case"TemperatureState":case"MeasuredTemperature":return new Jn(t);case"BatteryState":return new Yn(t);case"MeasuredBrightness":case"DeviceBrightnessState":return new Zn(t);case"EnergyMeasuredPower":case"EnergyMeasuredCurrent":case"EnergyMeasuredVoltage":break;case"IEnergy":case"Energy":case"IGetPowerMeasurements":return new tr(t);case"DistanceSensor":return new rr(t);case"MovementSensor":return new sr(t);case"BlindsControlButton":return new ir(t);case"FacadeControlButton":return new cr(t);case"SignalStrength":return new lr(t);case"GatePosition":return new dr(t);case"GatewayPosition":return new pr(t);case"GateControllerHealth":return new gr(t);case"IBlindCalibrationStatus":case"BlindCalibration":return new fr(t);case"HumiditySensor":case"HumidityState":return new vr(t);case"VibrationSensor":return new mr(t);case"DigitalInputSensor":return new wr(t);case"ConfigurationState":return new Ar(t);case"BlindOpenCloseTime":case"IBlindOpenCloseTime":return new _r(t);case"IOvercurrentProtection":case"OvercurrentProtection":return new Cr(t);case"IOvercurrentProtectionThreshold":case"OvercurrentProtectionThreshold":return new Tr(t);case"FacadePosition":case"FacadeState":return new Dr(t);case"FacadeTypeState":return new kr(t);case"CurrentWindThreshold":return new Ir(t);case"CurrentLightThreshold":return new br(t);case"WindSpeed":return new Nr(t);case"FloodSensor":return new Rr(t);case"PressureState":return new Ur(t);case"ITamperProtection":case"TamperProtection":return new Mr(t);case"ILightRGBW":case"LightRGBW":return new xr(t);case"OnlineCamera":case"IOnlineCamera":return new Un(t);case"BlindError":case"IBlindError":return t.state.ErrorData=ie(t.state.ErrorData),new Fr(t);case"HallState":return new Gn(t);case"SceneExecuted":return new Rn(t);case"Intercom":return new Pn(t);default:null===(n=u.Log)||void 0===n||n.Debug(Zo.ServiceName,`Not supported device state ${t.DataType}`)}return null}GetServiceName(){return Zo.ServiceName}SyncDevicesStatesAsync(){return Qo(this,arguments,void 0,(function*(e=!1){var t,n;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ni,15e3,!1);if(!0!==(yield this.IsFastStatesSyncEnabledAsync())||e){let e=new ri;e.Data=!0;const t=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(e,35e3,!1);return(null==t?void 0:t.Status)==ue.OK}return(null==r?void 0:r.Status)==ue.OK}))}OnDevicesTasksExecutionChangeEvent(){return this._onDevicesTasksChangedEvent}OnDeviceStateChangedEvent(){return this._onDeviceStateChangedEvent}OnDeviceStateRefreshedOrChangedEvent(){return this._onDeviceStateRefreshedOrChangedEvent}OnDeviceRegisteredEvent(){return this._onDeviceRegisteredEvent}OnDeviceRemovedEvent(){return this._onDeviceRemovedEvent}OnDeviceFoundEvent(){return this._onDeviceFoundEvent}MapApiDevices(e){const t=[];return null==e?[]:(e.forEach((e=>{var n,r,s,o;let i=new Lr;i.Guid=e.Guid,i.Name=e.DeviceName,i.ChannelsAmount=e.ChannelsNumber,i.DeviceType=e.DeviceType,i.CommunicationWay=e.CommunicationWay,i.DeviceState=e.DeviceState,i.IsEnabled=e.IsEnabled,i.IsVirtual=e.IsVirtual,i.SerialNumber=e.DeviceSerialNumber,i.ManufacturerGuid=e.ManufacturerGuid,i.ModelGuid=e.DeviceModelGuid,i.Model=e.DeviceModel,i.Name=e.DeviceName,i.ProtocolGuid=e.ProtocolGuid,void 0!==e.IconType&&null!==e.IconType?i.IconType=e.IconType:i.IconType=Pt.Unknown;try{if(null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{let t=new Kt;if(i.CommunicationWay==xt.OneWay)"IBlindPosition"===e&&(t.InterfaceType="IBlindPositionSimple");else switch(e){case"IGatePosition":t.InterfaceType="IGatePulse";break;case"IGatewayPosition":t.InterfaceType="IGatewayPulse";break;default:t.InterfaceType=e}i.AvailableTaskTypes.push(t)})),null===(r=e.AvailableResponses)||void 0===r||r.forEach((e=>{let t=new jt;t.InterfaceType=e,i.AvailableResponseTypes.push(t)})),null===(s=e.ChannelsConfiguration)||void 0===s||s.forEach((e=>{var t,n,r;try{let r=new jr;r.Number=e.Channel,i.Channels.push(r),r.SetDevice(i),r.Name=e.ChannelName,r.ChannelGroups=e.GroupsGuids,r.IconName=e.IconName,r.IsHidden=e.Hidden,r.Configurations=e.Configurations,r.CustomDataAndRolesSupported=void 0!==e.CustomData&&null!==e.CustomData,void 0!==e.CustomData&&null!==e.CustomData&&(r.CustomData=e.CustomData),void 0!==e.Roles&&null!==e.Roles&&(r.Roles=e.Roles),null===(t=e.AvailableResponses)||void 0===t||t.forEach((e=>{let t=new jt;t.InterfaceType=e,r.AvailableResponseTypes.push(t)})),null===(n=e.AvailableTasks)||void 0===n||n.forEach((e=>{let t=new Kt;i.AvailableTaskTypes.any((e=>"IBlindPositionSimple"==e.InterfaceType))?"IBlindPosition"==e&&(t.InterfaceType="IBlindPositionSimple"):t.InterfaceType=e,r.AvailableTaskTypes.push(t)}))}catch(e){null===(r=u.Log)||void 0===r||r.Error(e)}})),"f4cc5043-2198-47df-9361-4cd130ed0323"===i.ModelGuid&&i.Channels.first().AvailableTaskTypes.all((e=>e.Type!=Ut.GetPowerMeasurements))){let e=new Kt;e.InterfaceType="IGetPowerMeasurements",i.Channels.first().AvailableTaskTypes.push(e)}}catch(e){null===(o=u.Log)||void 0===o||o.Error(e)}t.push(i)})),t)}GetPairedDevicesAsync(){return Qo(this,arguments,void 0,(function*(e=!1){var t,n,r;let s=yield null===(t=this._controllerConfiguration)||void 0===t?void 0:t.DidCofigurationChangeAsync();if(this._synchronized&&!s)return e?Promise.resolve(this._devices):Promise.resolve(this._devices.filter((e=>e.DeviceType!=Ft.Scene)));const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new ti,15e3,!0);return null==o||void 0===o?[]:o.Status==ue.OK&&null!=o.Data?(this._devices=this.MapApiDevices(o.Data),e?this._devices:this._devices.filter((e=>e.DeviceType!=Ft.Scene))):(null===(r=u.Log)||void 0===r||r.Error(Zo.ServiceName,`Failed to get devices. ${o.Status} ${o.Data}`),[])}))}GetDevicesAsync(){return Qo(this,arguments,void 0,(function*(e=!1){return yield this.WaitForSynchronizationAsync(),this.GetPairedDevicesAsync(e)}))}GetFoundDevicesAsync(){return Qo(this,void 0,void 0,(function*(){var e,t;const n=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new ii,15e3,!1);return null==n?[]:n.Status==ue.OK&&null!=n.Data?this.MapApiDevices(n.Data).where((e=>e.DeviceType!==Ft.Scene)).toArray():(null===(t=u.Log)||void 0===t||t.Error(Zo.ServiceName,`Failed to get found devices. ${n.Status} ${n.Data}`),[])}))}GetDevice(e){return this._devices.find((t=>t.Guid===e))}FindDevicesAsync(){return Qo(this,void 0,void 0,(function*(){var e;gy.Get($e.ServiceName).ClearCache(),yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new si,35e3,!1)}))}StopSearchingForDevices(){return Qo(this,void 0,void 0,(function*(){var e;yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new oi,2e4,!1)}))}RegisterDeviceAsync(e){return Qo(this,void 0,void 0,(function*(){var t,n,r;try{const r=new ci;r.Data=e.Guid;const s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(r,2e4,!1);return null===(n=u.Log)||void 0===n||n.Error(Zo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RegisterDeviceAsync()"),gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),(null==s?void 0:s.Status)==ue.OK?(this._devices.any((t=>t.Guid==e.Guid))||this._devices.push(e),this._onDeviceRegisteredEvent.Invoke(e),Bt.Executed):Bt.Failed}catch(e){return null===(r=u.Log)||void 0===r||r.Error(Zo.ServiceName,`Failed to paired devices: ${e}`),Bt.ControllerResponseTimeout}}))}RemoveDeviceAsync(e){return Qo(this,arguments,void 0,(function*(e,t=!1){var n,r,s;try{let s=new ui;t&&(s=new li),s.Data=e.Guid;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(s,35e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Zo.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! RemoveDeviceAsync()"),gy.Get(lt.ServiceName).ExitConfigurationModeAsync(),(null==o?void 0:o.Status)==ue.OK?(this._devices=this._devices.where((t=>t.Guid!=e.Guid)).toArray(),this._onDeviceRemovedEvent.Invoke(e),Bt.Executed):Bt.Failed}catch(e){return null===(s=u.Log)||void 0===s||s.Error(Zo.ServiceName,`Failed to unpair device: ${e}`),Bt.ControllerResponseTimeout}}))}MapDeviceTaskToDeviceTaskInfo(e,t){let n=new gi;const r=t;switch(r.FeatureType){case $r.SetTemperature:n.Data=r.Temperature;break;case $r.SetLightBrightness:n.Data=r.Brightness;break;case $r.SetLightColor:n=new fi;const e=r;n.R=e.R,n.G=e.G,n.B=e.B;break;case $r.SetLightTemperature:n.Data=r.Temperature;break;case $r.SetGatePositionPrecise:switch(r.GateControlAction){case qr.Open:n.Data=101;break;case qr.Close:n.Data=102;break;case qr.Stop:n.Data=103;break;case qr.Percentage:n.Data=r.Position}break;case $r.SetGatePositionPreciseSecure:let t=0,s=r.Pin;switch(r.GateControlAction){case qr.Open:t=101;break;case qr.Close:t=102;break;case qr.Stop:t=103;break;case qr.Percentage:t=r.Position}n.Data={Position:t,Pin:s};break;case $r.SetBlindPosition:switch(r.Action){case Vr.Open:n.Data=101;break;case Vr.Close:n.Data=102;break;case Vr.Stop:n.Data=103;break;case Vr.Percentage:n.Data=r.Position}break;case $r.SetLightBrightnessDynamicly:n.Data=r.Brightness;break;case $r.SetBlindOpenCloseTime:n.Data=r.Data;break;case $r.SetBlindMicroventilation:n.Data=r.Position;break;case $r.SetFacadePositionAndTilt:n=new vi;const o=r;n.FacadeAction=o.FacadeAction,n.Tilt=o.Tilt,n.Position=o.Position;break;case $r.LightRGBW:n.Data=r.Data;break;case $r.GatePulse:case $r.GatewayPulse:n.Data=0;break;case $r.TurnOnWithTimeout:n.Data=r.SwitchOffDelaySeconds}return n.Channel=r.Channel,n.DeviceGuid=e.Guid,n.ControlFeature=r.FeatureType,n}ExecuteDeviceTaskAsync(e,t){return Qo(this,void 0,void 0,(function*(){var n,r,s,o,i,a,c,l;try{null===(n=u.Log)||void 0===n||n.Debug(Zo.ServiceName,`Preparing device task execution, device: ${e.Guid} task: ${t.TaskType} channel: ${t.Channel}`);let l=this.MapDeviceTaskToDeviceTaskInfo(e,t);try{const e=new di(l);null===(r=u.Log)||void 0===r||r.Debug(Zo.ServiceName,`Sending device task for execution, device: ${l.DeviceGuid} task: ${l.ControlFeature} channel: ${l.Channel} request: ${JSON.stringify(e)}`);const t=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(e,15e3,!1);switch(null==t?void 0:t.Status){case ue.OK:return Bt.Executed;case ue.FatalError:return null===(o=u.Log)||void 0===o||o.Error(Zo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),Bt.Failed;case ue.WrongData:if("DeviceNotFound"===t.Data)return Bt.DeviceNotFound;break;case ue.Error:return"DeviceResponseTimeout"===t.Data?Bt.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Zo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${t.Data}`),Bt.Failed)}}catch(e){return e.message.includes("timeout")?(null===(a=u.Log)||void 0===a||a.Error(Zo.ServiceName,`Failed to get controller response in time.\n${e}`),Bt.ControllerResponseTimeout):(null===(c=u.Log)||void 0===c||c.Error(Zo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Bt.Failed)}return Bt.Unknown}catch(e){return null===(l=u.Log)||void 0===l||l.Error(Zo.ServiceName,`Unknown error occured when tried to execute task on device.\n${e}`),Bt.Failed}}))}ExecuteDevicesTasksAsync(e){return Qo(this,void 0,void 0,(function*(){var t,n,r,s;let o=[],i=[],a=0;for(const[t,n]of e){const e=this.MapDeviceTaskToDeviceTaskInfo(t,n);e.SequnceExecutionOrder=a,a++,i.push(e)}const c=new hi(i);try{const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(c,12e4,!1);let s=-1;null===(n=null==r?void 0:r.Data)||void 0===n||n.forEach((t=>{var n,i;s++;let a=Bt.Unknown;switch(t.Status){case ue.OK:a=Bt.Executed;break;case ue.FatalError:null===(n=u.Log)||void 0===n||n.Error(Zo.ServiceName,`Fatal error occured when tried to execute task on device. Error code: ${t.Data}`),a=Bt.Failed;break;case ue.WrongData:"DeviceNotFound"===t.Data&&(a=Bt.DeviceNotFound);break;case ue.Error:"DeviceResponseTimeout"===t.Data?a=Bt.DeviceResponseTimeout:(null===(i=u.Log)||void 0===i||i.Error(Zo.ServiceName,`Unknown error occured when trying to execute task on device. Error code: ${r.Data}`),a=Bt.Failed)}let c=0,l=new Jt;for(const[t,n]of e){if(c==s){l.Device=t,l.Task=n,l.Channel=n.Channel,l.Result=a,o.push(l);break}c++}}))}catch(t){if(t.message.includes("timeout")){null===(r=u.Log)||void 0===r||r.Error(Zo.ServiceName,`Failed to get controller response in time.\n${t}`);for(const[t,n]of e){let e=new Jt;o.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Bt.ControllerResponseTimeout}}else{null===(s=u.Log)||void 0===s||s.Error(Zo.ServiceName,`Unknown error occured when tried to execute task on device.\n${t}`);for(const[t,n]of e){let e=new Jt;o.push(e),e.Device=t,e.Task=n,e.Channel=n.Channel,e.Result=Bt.Failed}}}return o}))}}Zo.ServiceName="DevicesService";class ei{constructor(){this.Channel=0,this.States=[]}}class ti extends ce{constructor(){super(),this.Resource="/devices/list",this.Method=le.Get}}class ni extends ce{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states",this.Method=le.Get}}class ri extends ce{constructor(){super(),this.Data=!1,this.Resource="/devices/channels/states/sync",this.Method=le.Get}}class si extends ce{constructor(){super(),this.Resource="/devices/search",this.Method=le.Post}}class oi extends ce{constructor(){super(),this.Resource="/devices/search/stop",this.Method=le.Post}}class ii extends ce{constructor(){super(),this.Resource="/devices/found/list",this.Method=le.Get}}class ai extends ce{constructor(){super(),this.Resource="/devices/tasks",this.Method=le.Get}}class ci extends ce{constructor(){super(),this.Resource="/devices/device/pair",this.Method=le.Put}}class ui extends ce{constructor(){super(),this.Resource="/devices/device/unpair",this.Method=le.Put}}class li extends ce{constructor(){super(),this.Resource="/devices/device/unpair/force",this.Method=le.Put}}class di extends ce{constructor(e){super(),this.Resource="/devices/device/control",this.Method=le.Post,this.Data=e}}class hi extends ce{constructor(e){super(),this.Resource="/devices/devices/control",this.Method=le.Post,this.Data=e}}class pi extends ce{constructor(e){super(),this.Resource="/logic/device/used",this.Method=le.Get,this.Data=e}}class gi{constructor(){this.DeviceGuid="",this.Channel=0,this.ControlFeature=$r.GetState,this.SequnceExecutionOrder=0}}class fi extends gi{constructor(){super(...arguments),this.R=0,this.G=0,this.B=0}}class vi extends gi{constructor(){super(...arguments),this.FacadeAction=Kr.Stop,this.Tilt=0,this.Position=0}}class yi{constructor(){this.DeviceGuid="",this.ConditionsAsCondition=[],this.ConditionsAsTask=[]}}class mi 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 wi=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 Si extends Error{constructor(e){super(e),this.name="InvalidOperationException",this.stack=this.stack||(new Error).stack}}const Ai=(e,t)=>e===t;class _i{iterator;constructor(e){this.iterator=e}[Symbol.asyncIterator](){return this.iterator()}}class Ci{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 Ti{iterator;constructor(e){this.iterator=e}[Symbol.iterator](){return this.iterator()}}class Di extends Array{}const ki=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return bi(e,t,n,r)}return n?Ei(e,t,n):Ii(e,t)},Ii=(e,t)=>{let n;for(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Si(wi.NoElements);return n},Ei=(e,t,n)=>{let r=t;for(const t of e)r=n(r,t);return r},bi=(e,t,n,r)=>{let s=t;for(const t of e)s=n(s,t);return r(s)},Ni=(e,t)=>{for(const n of e)if(!1===t(n))return!1;return!0},Gi=async(e,t)=>{for(const n of e)if(!1===await t(n))return!1;return!0},Ri=(e,t)=>t?Ui(e,t):Pi(e),Pi=e=>{for(const t of e)return!0;return!1},Ui=(e,t)=>{for(const n of e)if(!0===t(n))return!0;return!1},Oi=async(e,t)=>{for(const n of e)if(!0===await t(n))return!0;return!1},Mi=(e,t)=>new Ti((function*(){yield*e,yield t})),xi=e=>{if(Array.isArray(e)){if(0===e.length)throw new Si(wi.NoElements);return new _i((async function*(){for await(const t of e)yield t}))}return new _i(e)},Fi=e=>xi((async function*(){for(const t of e)yield t})),Li=(e,t)=>new Ci({generator:t,type:e}),Bi=e=>Li(0,(async()=>{const t=[];for(const n of e)t.push(n);return t})),Wi=(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 Si(wi.NoElements);return n/r},$i=async(e,t)=>{let n=0,r=0;for(const s of e)n+=await t(s),r+=1;if(0===r)throw new Si(wi.NoElements);return n/r},Vi=(e,t)=>{if(t<1)throw new mi("size");return new Ti((function*(){let n=[];for(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},qi=(e,t)=>new Ti((function*(){yield*e,yield*t})),Hi=(e,t,n=Ai)=>{for(const r of e)if(n(t,r))return!0;return!1},Ki=async(e,t,n)=>{for(const r of e)if(await n(t,r))return!0;return!1},ji=(e,t)=>t?Ji(e,t):zi(e),zi=e=>{let t=0;for(const n of e)t++;return t},Ji=(e,t)=>{let n=0;for(const r of e)!0===t(r)&&n++;return n},Xi=async(e,t)=>{let n=0;for(const r of e)!0===await t(r)&&n++;return n},Yi=(e,t)=>new Ti((function*(){let n=!1;for(const t of e)n=!0,yield t;n||(yield t)})),Qi=(e,t=Ai)=>new Ti((function*(){const n=[];for(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),Zi=(e,t)=>xi((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}})),ea=(e,t)=>new Ti((function*(){for(const n of e)t(n),yield n})),ta=(e,t)=>xi((async function*(){for(const n of e)await t(n),yield n})),na=(e,t)=>{if(t<0)throw new mi("index");let n=0;for(const r of e)if(t===n++)return r;throw new mi("index")},ra=(e,t)=>{let n=0;for(const r of e)if(t===n++)return r;return null},sa=(e,t,n=Ai)=>new Ti((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)}})),oa=(e,t,n)=>xi((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)}})),ia=(e,t)=>t?ca(e,t):aa(e),aa=e=>{const t=e[Symbol.iterator]().next();if(!0===t.done)throw new Si(wi.NoElements);return t.value},ca=(e,t)=>{for(const n of e)if(!0===t(n))return n;throw new Si(wi.NoMatch)},ua=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;throw new Si(wi.NoMatch)},la=(e,t)=>t?ha(e,t):da(e),da=e=>e[Symbol.iterator]().next().value??null,ha=(e,t)=>{for(const n of e)if(!0===t(n))return n;return null},pa=async(e,t)=>{for(const n of e)if(!0===await t(n))return n;return null};class ga extends Di{key;constructor(e,t){super(1),this.key=e,this[0]=t}}const fa=(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 ga(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 ga(e,r)}for(const e in n)yield n[e]})(e,t),new Ti(r)},va=(e,t,n)=>n?ma(e,t,n):ya(e,t),ya=(e,t)=>xi((async function*(){const n={};for(const r of e){const e=await t(r),s=n[e];s?s.push(r):n[e]=new ga(e,r)}for(const e in n)yield n[e]})),ma=(e,t,n)=>xi((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 ga(e,s))}for(const e of r)yield e})),wa=(e,t,n,r)=>r?((e,t,n,r)=>new Ti((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 ga(e,t))}}for(const e of s)yield e})))(e,t,n,r):((e,t,n)=>new Ti((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 ga(e,i)}for(const e in r)yield r[e]})))(e,t,n),Sa=(e,t,n,r,s,o)=>{const i=o?Aa(e,t,n,r,s,o):_a(e,t,n,r,s);return new Ti(i)},Aa=(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)}},_a=(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)}},Ca=(e,t,n,r,s,o)=>{const i=o?Ta(e,t,n,r,s,o):Da(e,t,n,r,s);return xi(i)},Ta=(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)}},Da=(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)}},ka=(e,t,n=Ai)=>new Ti((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}}})),Ia=(e,t,n)=>xi((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}}}})),Ea=(e,t,n,r,s,o=Ai)=>new Ti((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))}}})),ba=(e,t)=>t?Ga(e,t):Na(e),Na=e=>{let t;for(const n of e)t=n;if(!t)throw new Si(wi.NoElements);return t},Ga=(e,t)=>{let n;for(const r of e)!0===t(r)&&(n=r);if(!n)throw new Si(wi.NoMatch);return n},Ra=async(e,t)=>{let n;for(const r of e)!0===await t(r)&&(n=r);if(!n)throw new Si(wi.NoMatch);return n},Pa=(e,t)=>t?Oa(e,t):Ua(e),Ua=e=>{let t=null;for(const n of e)t=n;return t},Oa=(e,t)=>{let n=null;for(const r of e)!0===t(r)&&(n=r);return n},Ma=async(e,t)=>{let n=null;for(const r of e)!0===await t(r)&&(n=r);return n},xa=(e,t)=>t?La(e,t):Fa(e),Fa=e=>{let t=null;for(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new Si(wi.NoElements);return t},La=(e,t)=>{let n=null;for(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new Si(wi.NoElements);return n},Ba=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 Si(wi.NoElements);return n},Wa=(e,t)=>t?Va(e,t):$a(e),$a=e=>{let t=null;for(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new Si(wi.NoElements);return t},Va=(e,t)=>{let n=null;for(const r of e)n=Math.min(n??Number.POSITIVE_INFINITY,t(r));if(null===n)throw new Si(wi.NoElements);return n},qa=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 Si(wi.NoElements);return n},Ha=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new Ti((function*(){for(const t of e)n(t)&&(yield t)}))};async function*Ka(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*ja(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 za extends _i{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 za?async function*(){for await(const s of e.orderedPairs())yield*Ka(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 za(s)}static generate(e,t,n,r){let s;return s=e instanceof za?async function*(){for await(const s of e.orderedPairs())yield*ja(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 za(s)}thenBy(e,t){return za.generate(this,e,!0,t)}thenByAsync(e,t){return za.generateAsync(this,e,!0,t)}thenByDescending(e,t){return za.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return za.generateAsync(this,e,!1,t)}}function*Ja(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*Xa(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 Ti{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*Ja(s,t,n,r)}:()=>Ja(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*Xa(s,t,n,r)}:()=>Xa(e,t,n,r),new za(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 Qa=(e,t)=>Ya.generate(e,(e=>e),!0,t),Za=(e,t,n)=>Ya.generate(e,t,!0,n),ec=(e,t,n)=>Ya.generateAsync(e,t,!0,n),tc=(e,t,n)=>Ya.generate(e,t,!1,n),nc=(e,t,n)=>Ya.generateAsync(e,t,!1,n),rc=(e,t)=>Ya.generate(e,(e=>e),!1,t),sc=(e,t)=>{const n=[],r=[];for(const s of e)!0===t(s)?r.push(s):n.push(s);return[r,n]},oc=async(e,t)=>{const n=[],r=[];for(const s of e)!0===await t(s)?r.push(s):n.push(s);return[r,n]},ic=(e,t)=>new Ti((function*(){yield t,yield*e})),ac=e=>new Ti((function*(){const t=[...e];for(let e=t.length-1;e>=0;e--)yield t[e]})),cc=(e,t)=>{if("function"==typeof t){const{length:n}=t;return 1===n?uc(e,t):lc(e,t)}return dc(e,t)},uc=(e,t)=>new Ti((function*(){for(const n of e)yield t(n)})),lc=(e,t)=>new Ti((function*(){let n=0;for(const r of e)yield t(r,n),n++})),dc=(e,t)=>new Ti((function*(){for(const n of e)yield n[t]})),hc=(e,t)=>"function"==typeof t?1===t.length?pc(e,t):gc(e,t):fc(e,t),pc=(e,t)=>xi((async function*(){for(const n of e)yield t(n)})),gc=(e,t)=>xi((async function*(){let n=0;for(const r of e)yield t(r,n),n++})),fc=(e,t)=>xi((async function*(){for(const n of e)yield n[t]})),vc=(e,t)=>"function"==typeof t?1===t.length?yc(e,t):mc(e,t):wc(e,t),yc=(e,t)=>new Ti((function*(){for(const n of e)for(const e of t(n))yield e})),mc=(e,t)=>new Ti((function*(){let n=0;for(const r of e){for(const e of t(r,n))yield e;n++}})),wc=(e,t)=>new Ti((function*(){for(const n of e)for(const e of n[t])yield e})),Sc=(e,t)=>1===t.length?Ac(e,t):_c(e,t),Ac=(e,t)=>xi((async function*(){for(const n of e){const e=await t(n);for(const t of e)yield t}})),_c=(e,t)=>xi((async function*(){let n=0;for(const r of e){const e=await t(r,n);for(const t of e)yield t;n++}})),Cc=(e,t,n=Ai)=>{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},Tc=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},Dc=(e,t)=>t?Ic(e,t):kc(e),kc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new Si(wi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new Si(wi.NoElements);return n},Ic=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new Si(wi.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Si(wi.NoMatch);return r},Ec=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new Si(wi.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Si(wi.NoMatch);return r},bc=(e,t)=>t?Gc(e,t):Nc(e),Nc=e=>{let t=!1,n=null;for(const r of e){if(!0===t)throw new Si(wi.MoreThanOneElement);t=!0,n=r}return n},Gc=(e,t)=>{let n=!1,r=null;for(const s of e)if(t(s)){if(!0===n)throw new Si(wi.MoreThanOneMatchingElement);n=!0,r=s}return r},Rc=async(e,t)=>{let n=!1,r=null;for(const s of e)if(await t(s)){if(!0===n)throw new Si(wi.MoreThanOneElement);n=!0,r=s}return r},Pc=(e,t)=>new Ti((function*(){let n=0;for(const r of e)n++>=t&&(yield r)})),Uc=(e,t)=>1===t.length?Oc(e,t):Mc(e,t),Oc=(e,t)=>new Ti((function*(){let n=!0;for(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),Mc=(e,t)=>new Ti((function*(){let n=0,r=!0;for(const s of e)!1===r?yield s:!1===t(s,n)&&(r=!1,yield s),n++})),xc=(e,t)=>1===t.length?Fc(e,t):Lc(e,t),Fc=(e,t)=>xi((async function*(){let n=!0;for(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),Lc=(e,t)=>xi((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++})),Bc=(e,t)=>t?$c(e,t):Wc(e),Wc=e=>{let t=0;for(const n of e)t+=n;return t},$c=(e,t)=>{let n=0;for(const r of e)n+=t(r);return n},Vc=async(e,t)=>{let n=0;for(const r of e)n+=await t(r);return n},qc=(e,t)=>new Ti((function*(){let n=t>0?t:0;for(const t of e){if(0==n--)break;yield t}})),Hc=(e,t)=>1===t.length?Kc(e,t):jc(e,t),Kc=(e,t)=>new Ti((function*(){for(const n of e){if(!t(n))break;yield n}})),jc=(e,t)=>new Ti((function*(){let n=0;for(const r of e){if(!t(r,n++))break;yield r}})),zc=(e,t)=>1===t.length?Jc(e,t):Xc(e,t),Jc=(e,t)=>xi((async function*(){for(const n of e){if(!await t(n))break;yield n}})),Xc=(e,t)=>xi((async function*(){let n=0;for(const r of e){if(!await t(r,n++))break;yield r}})),Yc=e=>[...e],Qc=(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},Zc=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},eu=(e,t)=>{const n={};for(const r of e)n[t(r)]=r;return n},tu=async(e,t)=>{const n={};for(const r of e)n[await t(r)]=r;return n},nu=e=>new Set(e),ru=(e,t,n)=>n?ou(e,t,n):su(e,t),su=(e,t)=>new Ti((function*(){const n=new Set;for(const t of e)!1===n.has(t)&&(yield t,n.add(t));for(const e of t)!1===n.has(e)&&(yield e,n.add(e))})),ou=(e,t,n)=>new Ti((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))}})),iu=(e,t,n)=>xi((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))}})),au=(e,t)=>1===t.length?cu(e,t):uu(e,t),cu=(e,t)=>new Ti((function*(){for(const n of e)!0===t(n)&&(yield n)})),uu=(e,t)=>new Ti((function*(){let n=0;for(const r of e)!0===t(r,n++)&&(yield r)})),lu=(e,t)=>1===t.length?du(e,t):hu(e,t),du=(e,t)=>xi((async function*(){for(const n of e)!0===await t(n)&&(yield n)})),hu=(e,t)=>xi((async function*(){let n=0;for(const r of e)!0===await t(r,n++)&&(yield r)})),pu=(e,t,n)=>n?fu(e,t,n):gu(e,t),gu=(e,t)=>new Ti((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]}})),fu=(e,t,n)=>new Ti((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)}})),vu=(e,t,n)=>xi((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)}})),yu=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(ki,"aggregate"),n(Ni,"all"),n(Gi,"allAsync"),n(Ri,"any"),n(Oi,"anyAsync"),n(Mi,"append"),n(Fi,"asAsync"),n(Bi,"asParallel"),n(Wi,"average"),n($i,"averageAsync"),n(Vi,"chunk"),n(qi,"concatenate"),n(Hi,"contains"),n(Ki,"containsAsync"),n(ji,"count"),n(Xi,"countAsync"),n(Yi,"defaultIfEmpty"),n(Qi,"distinct"),n(Zi,"distinctAsync"),n(ea,"each"),n(ta,"eachAsync"),n(na,"elementAt"),n(ra,"elementAtOrDefault"),n(sa,"except"),n(oa,"exceptAsync"),n(ia,"first"),n(ua,"firstAsync"),n(la,"firstOrDefault"),n(pa,"firstOrDefaultAsync"),n(fa,"groupBy"),n(va,"groupByAsync"),n(wa,"groupByWithSel"),n(Sa,"groupJoin"),n(Ca,"groupJoinAsync"),n(ka,"intersect"),n(Ia,"intersectAsync"),n(Ea,"joinByKey"),n(ba,"last"),n(Ra,"lastAsync"),n(Pa,"lastOrDefault"),n(Ma,"lastOrDefaultAsync"),n(xa,"max"),n(Ba,"maxAsync"),n(Wa,"min"),n(qa,"minAsync"),n(Ha,"ofType"),n(Qa,"order"),n(Za,"orderBy"),n(ec,"orderByAsync"),n(tc,"orderByDescending"),n(nc,"orderByDescendingAsync"),n(rc,"orderDescending"),n(ic,"prepend"),n(ac,"reverse"),n(cc,"select"),n(hc,"selectAsync"),n(vc,"selectMany"),n(Sc,"selectManyAsync"),n(Cc,"sequenceEquals"),n(Tc,"sequenceEqualsAsync"),n(Dc,"single"),n(Ec,"singleAsync"),n(bc,"singleOrDefault"),n(Rc,"singleOrDefaultAsync"),n(Pc,"skip"),n(Uc,"skipWhile"),n(xc,"skipWhileAsync"),n(Bc,"sum"),n(Vc,"sumAsync"),n(qc,"take"),n(Hc,"takeWhile"),n(zc,"takeWhileAsync"),n(Yc,"toArray"),n(Qc,"toMap"),n(Zc,"toMapAsync"),n(eu,"toObject"),n(tu,"toObjectAsync"),n(sc,"partition"),n(oc,"partitionAsync"),n(nu,"toSet"),n(ru,"union"),n(iu,"unionAsync"),n(au,"where"),n(lu,"whereAsync"),n(pu,"zip"),n(vu,"zipAsync")},mu=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return Au(e,t,n,r)}return n?Su(e,t,n):wu(e,t)},wu=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Si(wi.NoElements);return n},Su=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},Au=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},_u=async(e,t)=>{for await(const n of e)if(!1===t(n))return!1;return!0},Cu=async(e,t)=>{for await(const n of e)if(!1===await t(n))return!1;return!0},Tu=(e,t)=>new _i((async function*(){yield*e,yield t})),Du=(e,t)=>t?Iu(e,t):ku(e),ku=async e=>{for await(const t of e)return!0;return!1},Iu=async(e,t)=>{for await(const n of e)if(!0===t(n))return!0;return!1},Eu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return!0;return!1},bu=e=>Li(0,(async()=>{const t=[];for await(const n of e)t.push(n);return t})),Nu=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 Si(wi.NoElements);return n/r},Gu=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 Si(wi.NoElements);return n/r},Ru=(e,t)=>{if(t<1)throw new mi("size");return new _i((async function*(){let n=[];for await(const r of e)n.push(r),n.length===t&&(yield n,n=[]);n.length&&(yield n)}))},Pu=(e,t)=>new _i((async function*(){yield*e,yield*t})),Uu=async(e,t,n=Ai)=>{for await(const r of e)if(n(t,r))return!0;return!1},Ou=async(e,t,n)=>{for await(const r of e)if(await n(t,r))return!0;return!1},Mu=(e,t)=>t?Fu(e,t):xu(e),xu=async e=>{let t=0;for await(const n of e)t++;return t},Fu=async(e,t)=>{let n=0;for await(const r of e)!0===t(r)&&n++;return n},Lu=async(e,t)=>{let n=0;for await(const r of e)!0===await t(r)&&n++;return n},Bu=(e,t)=>new _i((async function*(){let n=!1;for await(const t of e)n=!0,yield t;n||(yield t)})),Wu=(e,t=Ai)=>new _i((async function*(){const n=[];for await(const r of e)n.find((e=>t(e,r)))||(n.push(r),yield r)})),$u=(e,t)=>new _i((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}})),Vu=(e,t)=>new _i((async function*(){for await(const n of e)t(n),yield n})),qu=(e,t)=>new _i((async function*(){for await(const n of e)await t(n),yield n})),Hu=async(e,t)=>{if(t<0)throw new mi("index");let n=0;for await(const r of e)if(t===n++)return r;throw new mi("index")},Ku=async(e,t)=>{let n=0;for await(const r of e)if(t===n++)return r;return null},ju=(e,t,n=Ai)=>new _i((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)}})),zu=(e,t,n)=>new _i((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)}})),Ju=(e,t)=>t?Yu(e,t):Xu(e),Xu=async e=>{const t=await e[Symbol.asyncIterator]().next();if(!0===t.done)throw new Si(wi.NoElements);return t.value},Yu=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;throw new Si(wi.NoMatch)},Qu=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;throw new Si(wi.NoMatch)},Zu=(e,t)=>t?tl(e,t):el(e),el=async e=>(await e[Symbol.asyncIterator]().next()).value??null,tl=async(e,t)=>{for await(const n of e)if(!0===t(n))return n;return null},nl=async(e,t)=>{for await(const n of e)if(!0===await t(n))return n;return null},rl=(e,t,n)=>n?sl(e,t,n):ol(e,t),sl=(e,t,n)=>new _i((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 ga(e,s))}for(const e of r)yield e})),ol=(e,t)=>new _i((async function*(){const n={};for await(const r of e){const e=t(r),s=n[e];s?s.push(r):n[e]=new ga(e,r)}for(const e in n)yield n[e]})),il=(e,t,n)=>n?cl(e,t,n):al(e,t),al=(e,t)=>new _i((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 ga(e,r)}for(const e in n)yield n[e]})),cl=(e,t,n)=>new _i((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 ga(e,s))}for(const e of r)yield e})),ul=(e,t,n,r)=>r?dl(e,t,n,r):ll(e,t,n),ll=(e,t,n)=>new _i((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 ga(e,i)}for(const e in r)yield r[e]})),dl=(e,t,n,r)=>new _i((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 ga(e,t))}}for(const e of s)yield e})),hl=(e,t,n,r,s,o)=>{const i=o?pl(e,t,n,r,s,o):gl(e,t,n,r,s);return new _i(i)},pl=(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)}},gl=(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)}},fl=(e,t,n,r,s,o)=>{const i=o?vl(e,t,n,r,s,o):yl(e,t,n,r,s);return new _i(i)},vl=(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)}},yl=(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)}},ml=(e,t,n=Ai)=>new _i((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}}}})),wl=(e,t,n)=>new _i((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}}}})),Sl=(e,t,n,r,s,o=Ai)=>new _i((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))}}})),Al=(e,t)=>t?Cl(e,t):_l(e),_l=async e=>{let t=null;for await(const n of e)t=n;if(!t)throw new Si(wi.NoElements);return t},Cl=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);if(!n)throw new Si(wi.NoMatch);return n},Tl=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);if(!n)throw new Si(wi.NoMatch);return n},Dl=(e,t)=>t?Il(e,t):kl(e),kl=async e=>{let t=null;for await(const n of e)t=n;return t},Il=async(e,t)=>{let n=null;for await(const r of e)!0===t(r)&&(n=r);return n},El=async(e,t)=>{let n=null;for await(const r of e)!0===await t(r)&&(n=r);return n},bl=(e,t)=>t?Gl(e,t):Nl(e),Nl=async e=>{let t=null;for await(const n of e)t=Math.max(t??Number.NEGATIVE_INFINITY,n);if(null===t)throw new Si(wi.NoElements);return t},Gl=async(e,t)=>{let n=null;for await(const r of e)n=Math.max(n??Number.NEGATIVE_INFINITY,t(r));if(null===n)throw new Si(wi.NoElements);return n},Rl=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 Si(wi.NoElements);return n},Pl=(e,t)=>t?Ol(e,t):Ul(e),Ul=async e=>{let t=null;for await(const n of e)t=Math.min(t??Number.POSITIVE_INFINITY,n);if(null===t)throw new Si(wi.NoElements);return t},Ol=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 Si(wi.NoElements);return n},Ml=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 Si(wi.NoElements);return n},xl=(e,t)=>{const n="string"==typeof t?e=>typeof e===t:e=>e instanceof t;return new _i((async function*(){for await(const t of e)n(t)&&(yield t)}))},Fl=(e,t)=>za.generate(e,(e=>e),!0,t),Ll=(e,t,n)=>za.generate(e,t,!0,n),Bl=(e,t,n)=>za.generateAsync(e,t,!0,n),Wl=(e,t,n)=>za.generate(e,t,!1,n),$l=(e,t,n)=>za.generateAsync(e,t,!1,n),Vl=(e,t)=>za.generate(e,(e=>e),!1,t),ql=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]},Kl=(e,t)=>new _i((async function*(){yield t,yield*e})),jl=e=>new _i((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]})),zl=(e,t)=>"function"==typeof t?1===t.length?Jl(e,t):Xl(e,t):Yl(e,t),Jl=(e,t)=>new _i((async function*(){for await(const n of e)yield t(n)})),Xl=(e,t)=>new _i((async function*(){let n=0;for await(const r of e)yield t(r,n),n++})),Yl=(e,t)=>new _i((async function*(){for await(const n of e)yield n[t]})),Ql=(e,t)=>"string"==typeof t?ed(e,t):Zl(e,t),Zl=(e,t)=>new _i((async function*(){for await(const n of e)yield t(n)})),ed=(e,t)=>new _i((async function*(){for await(const n of e)yield n[t]})),td=(e,t)=>"function"==typeof t?1===t.length?nd(e,t):rd(e,t):sd(e,t),nd=(e,t)=>new _i((async function*(){for await(const n of e)for(const e of t(n))yield e})),rd=(e,t)=>new _i((async function*(){let n=0;for await(const r of e){for(const e of t(r,n))yield e;n++}})),sd=(e,t)=>new _i((async function*(){for await(const n of e)for(const e of n[t])yield e})),od=(e,t)=>1===t.length?new _i((async function*(){for await(const n of e){const e=await t(n);for(const t of e)yield t}})):new _i((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++}})),id=async(e,t,n=Ai)=>{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},ad=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},cd=(e,t)=>t?ld(e,t):ud(e),ud=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new Si(wi.MoreThanOneElement);t=!0,n=r}if(!1===t)throw new Si(wi.NoElements);return n},ld=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new Si(wi.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Si(wi.NoMatch);return r},dd=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new Si(wi.MoreThanOneMatchingElement);n=!0,r=s}if(!1===n)throw new Si(wi.NoMatch);return r},hd=(e,t)=>t?gd(e,t):pd(e),pd=async e=>{let t=!1,n=null;for await(const r of e){if(!0===t)throw new Si(wi.MoreThanOneElement);t=!0,n=r}return n},gd=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(t(s)){if(!0===n)throw new Si(wi.MoreThanOneMatchingElement);n=!0,r=s}return r},fd=async(e,t)=>{let n=!1,r=null;for await(const s of e)if(await t(s)){if(!0===n)throw new Si(wi.MoreThanOneMatchingElement);n=!0,r=s}return r},vd=(e,t)=>new _i((async function*(){let n=0;for await(const r of e)n++>=t&&(yield r)})),yd=(e,t)=>1===t.length?md(e,t):wd(e,t),md=(e,t)=>new _i((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===t(r)&&(n=!1,yield r)})),wd=(e,t)=>new _i((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++})),Sd=(e,t)=>1===t.length?Ad(e,t):_d(e,t),Ad=(e,t)=>new _i((async function*(){let n=!0;for await(const r of e)!1===n?yield r:!1===await t(r)&&(n=!1,yield r)})),_d=(e,t)=>new _i((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++})),Cd=(e,t)=>t?Dd(e,t):Td(e),Td=async e=>{let t=0;for await(const n of e)t+=n;return t},Dd=async(e,t)=>{let n=0;for await(const r of e)n+=t(r);return n},kd=async(e,t)=>{let n=0;for await(const r of e)n+=await t(r);return n},Id=(e,t)=>new _i((async function*(){let n=t>0?t:0;for await(const t of e){if(0==n--)break;yield t}})),Ed=(e,t)=>1===t.length?bd(e,t):Nd(e,t),bd=(e,t)=>new _i((async function*(){for await(const n of e){if(!t(n))break;yield n}})),Nd=(e,t)=>new _i((async function*(){let n=0;for await(const r of e){if(!t(r,n++))break;yield r}})),Gd=(e,t)=>1===t.length?Rd(e,t):Pd(e,t),Rd=(e,t)=>new _i((async function*(){for await(const n of e){if(!await t(n))break;yield n}})),Pd=(e,t)=>new _i((async function*(){let n=0;for await(const r of e){if(!await t(r,n++))break;yield r}})),Ud=async e=>{const t=[];for await(const n of e)t.push(n);return t},Od=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},Md=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},xd=async(e,t)=>{const n={};for await(const r of e)n[t(r)]=r;return n},Fd=async(e,t)=>{const n={};for await(const r of e)n[await t(r)]=r;return n},Ld=async e=>{const t=new Set;for await(const n of e)t.add(n);return t},Bd=(e,t,n)=>n?$d(e,t,n):Wd(e,t),Wd=(e,t)=>new _i((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))})),$d=(e,t,n)=>new _i((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))}})),Vd=(e,t,n)=>new _i((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))}})),qd=(e,t)=>1===t.length?Hd(e,t):Kd(e,t),Hd=(e,t)=>new _i((async function*(){for await(const n of e)!0===t(n)&&(yield n)})),Kd=(e,t)=>new _i((async function*(){let n=0;for await(const r of e)!0===t(r,n++)&&(yield r)})),jd=(e,t)=>1===t.length?zd(e,t):Jd(e,t),zd=(e,t)=>new _i((async function*(){for await(const n of e)!0===await t(n)&&(yield n)})),Jd=(e,t)=>new _i((async function*(){let n=0;for await(const r of e)!0===await t(r,n++)&&(yield r)})),Xd=(e,t,n)=>n?Qd(e,t,n):Yd(e,t),Yd=(e,t)=>new _i((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]}})),Qd=(e,t,n)=>new _i((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)}})),Zd=(e,t,n)=>new _i((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)}})),eh=(e,t,n,r)=>{if(r){if(!n)throw new ReferenceError("TAccumulate function is undefined");return rh(e,t,n,r)}return n?nh(e,t,n):th(e,t)},th=async(e,t)=>{let n;for await(const r of e)n=n?t(n,r):r;if(void 0===n)throw new Si(wi.NoElements);return n},nh=async(e,t,n)=>{let r=t;for await(const t of e)r=n(r,t);return r},rh=async(e,t,n,r)=>{let s=t;for await(const t of e)s=n(s,t);return r(s)},sh=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return{generator:()=>n.generator().then((e=>{const n=new Array(e.length);for(let r=0;r<e.length;r++)n[r]=t(e[r]);return n})),type:0};case 1:return{generator:()=>{const e=n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then(t);return r},type:1};case 2:return{generator:async()=>{const e=await n.generator(),r=new Array(e.length);for(let n=0;n<e.length;n++)r[n]=e[n].then(t);return r},type:2}}},oh=(e,t)=>{const n=sh(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))}},ih=(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}}},ah=(e,t)=>{const n=ih(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))}},ch=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ci({generator:()=>{const e=n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 2:return new Ci({generator:async()=>{const e=await n.generator();return e.push(Promise.resolve(t)),e},type:n.type});case 0:return new Ci({generator:async()=>{const e=await n.generator();return e.push(t),e},type:n.type})}},uh=(e,t)=>t?dh(e,t):lh(e),lh=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}},dh=async(e,t)=>{const n=sh(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)}},hh=async(e,t)=>{const n=ih(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)}},ph=e=>xi((async function*(){for await(const t of e)yield t})),gh=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)}},fh=async(e,t)=>{let n;n=t?sh(e,t):e.dataFunc;const r=await gh(n);if(0===r.length)throw new Si(wi.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},vh=async(e,t)=>{const n=ih(e,t),r=await gh(n);if(0===r.length)throw new Si(wi.NoElements);let s=0;for(const e of r)s+=e;return s/r.length},yh=(e,t)=>{if(t<1)throw new mi("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 Ci(n)},mh=(e,t)=>new Ci({generator:async()=>{const[n,r]=await Promise.all([e.toArray(),t.toArray()]);return[...n,...r]},type:0}),wh=async(e,t,n=Ai)=>{let r;switch(r=sh(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))}},Sh=async(e,t,n)=>{const r=ih(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))}},Ah=(e,t)=>t?Ch(e,t):_h(e),_h=async e=>{const t=e.dataFunc;switch(t.type){case 0:case 2:return(await e.toArray()).length;case 1:return t.generator().length}},Ch=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},Th=async(e,t)=>{const n=ih(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},Dh=(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 Ci(s)},kh=(e,t=Ai)=>new Ci({generator:async()=>{const n=[];for(const r of await e.toArray())n.find((e=>t(e,r)))||n.push(r);return n},type:0}),Ih=(e,t)=>new Ci({generator:async()=>{const n=[];e:for(const r of await e.toArray()){for(const e of n)if(await t(e,r))continue e;n.push(r)}return n},type:0}),Eh=(e,t)=>new Ci(sh(e,(e=>(t(e),e)))),bh=(e,t)=>{const n=ih(e,(async e=>(await t(e),e)));return new Ci(n)},Nh=async(e,t)=>{if(t<0)throw new mi("index");const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();if(t>=e.length)throw new mi("index");return e[t]}case 1:{const e=n.generator();if(t>=e.length)throw new mi("index");return await e[t]}case 2:{const e=await n.generator();if(t>=e.length)throw new mi("index");return await e[t]}}},Gh=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();return t>=e.length?null:e[t]}case 1:{const e=n.generator();return t>=e.length?null:await e[t]}case 2:{const e=await n.generator();return t>=e.length?null:await e[t]}}},Rh=(e,t,n=Ai)=>new Ci({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}),Ph=(e,t,n)=>new Ci({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}),Uh=e=>gh(e.dataFunc),Oh=(e,t)=>t?xh(e,t):Mh(e),Mh=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new Si(wi.NoElements);return e[0]}case 1:{const e=t.generator();if(0===e.length)throw new Si(wi.NoElements);return await e[0]}case 2:{const e=await t.generator();if(0===e.length)throw new Si(wi.NoElements);return await e[0]}}},xh=async(e,t)=>{const n=await Uh(e);for(const e of n)if(!0===t(e))return e;throw new Si(wi.NoMatch)},Fh=async(e,t)=>{const n=await Uh(e);for(const e of n)if(!0===await t(e))return e;throw new Si(wi.NoMatch)},Lh=(e,t)=>t?Wh(e,t):Bh(e),Bh=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]}}},Wh=async(e,t)=>{const n=await Uh(e);for(const e of n)if(!0===t(e))return e;return null},$h=async(e,t)=>{const n=await Uh(e);for(const e of n)if(!0===await t(e))return e;return null},Vh=(e,t,n)=>n?Hh(e,t,n):qh(e,t),qh=(e,t)=>new Ci({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 ga(e,r)}const r=new Array;for(const e in n)r.push(n[e]);return r},type:0}),Hh=(e,t,n)=>new Ci({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 ga(e,s))}const s=new Array;for(const e of r)s.push(e);return s},type:0}),Kh=(e,t,n)=>n?jh(e,t,n):zh(e,t),jh=(e,t,n)=>new Ci({generator:async()=>{const r=ih(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 ga(e,t))}const i=new Array;for(const e of o)i.push(e);return i},type:0}),zh=(e,t)=>new Ci({generator:async()=>{const n=ih(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 ga(e,t)}const o=new Array;for(const e in s)o.push(s[e]);return o},type:0}),Jh=(e,t,n,r)=>r?Xh(e,t,n,r):Yh(e,t,n),Xh=(e,t,n,r)=>new Ci({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 ga(e,t))}}const o=new Array;for(const e of s)o.push(e);return o},type:0}),Yh=(e,t,n)=>new Ci({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 ga(e,i)}const s=new Array;for(const e in r)s.push(r[e]);return s},type:0}),Qh=(e,t,n,r,s,o)=>{const i=o?Zh(e,t,n,r,s,o):ep(e,t,n,r,s);return new Ci({generator:i,type:0})},Zh=(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)}))},ep=(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)}))},tp=(e,t,n,r,s,o)=>{const i=o?np(e,t,n,r,s,o):rp(e,t,n,r,s);return new Ci({generator:i,type:0})},np=(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)},rp=(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)},sp=(e,t,n=Ai)=>new Ci({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}),op=(e,t,n)=>new Ci({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}),ip=(e,t,n,r,s,o=Ai)=>new Ci({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}),ap=(e,t)=>t?up(e,t):cp(e),cp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(0===e.length)throw new Si(wi.NoElements);return e[e.length-1]}case 1:{const e=t.generator();if(0===e.length)throw new Si(wi.NoElements);return await e[e.length-1]}case 2:{const e=await t.generator();if(0===e.length)throw new Si(wi.NoElements);return await e[e.length-1]}}},up=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=e[n];if(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 Si(wi.NoMatch)},lp=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 Si(wi.NoMatch)},dp=(e,t)=>t?pp(e,t):hp(e),hp=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]}}},pp=async(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:{const e=await n.generator();for(let n=e.length-1;n>=0;n--){const r=e[n];if(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},gp=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},fp=async(e,t)=>{let n;n=t?sh(e,t):e.dataFunc;const r=await gh(n);if(0===r.length)throw new Si(wi.NoElements);return Math.max.apply(null,r)},vp=async(e,t)=>{const n=ih(e,t),r=await gh(n);if(0===r.length)throw new Si(wi.NoElements);return Math.max.apply(null,r)},yp=async(e,t)=>{let n;n=t?sh(e,t):e.dataFunc;const r=await gh(n);if(0===r.length)throw new Si(wi.NoElements);return Math.min.apply(null,r)},mp=async(e,t)=>{const n=ih(e,t),r=await gh(n);if(0===r.length)throw new Si(wi.NoElements);return Math.min.apply(null,r)},wp=(e,t)=>{const n="string"==typeof t?e=>[typeof e===t,e]:e=>[e instanceof t,e];return new Ci({generator:async()=>{const t=sh(e,n),r=await gh(t),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0})};async function*Sp(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*Ap(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 _p extends Ci{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 _p?async function*(){for await(const s of e.orderedPairs())yield*Sp(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 _p(s)}static generate(e,t,n,r){let s;return s=e instanceof _p?async function*(){for await(const s of e.orderedPairs())yield*Ap(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 _p(s)}thenBy(e,t){return _p.generate(this,e,!0,t)}thenByAsync(e,t){return _p.generateAsync(this,e,!0,t)}thenByDescending(e,t){return _p.generate(this,e,!1,t)}thenByDescendingAsync(e,t){return _p.generateAsync(this,e,!1,t)}}const Cp=(e,t)=>_p.generate(e,(e=>e),!0,t),Tp=(e,t,n)=>_p.generate(e,t,!0,n),Dp=(e,t,n)=>_p.generateAsync(e,t,!0,n),kp=(e,t,n)=>_p.generate(e,t,!1,n),Ip=(e,t,n)=>_p.generateAsync(e,t,!1,n),Ep=(e,t)=>_p.generate(e,(e=>e),!1,t),bp=async(e,t)=>{const n=sh(e,(e=>[t(e),e])),r=await gh(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Np=async(e,t)=>{const n=ih(e,(async e=>[await t(e),e])),r=await gh(n),s=[],o=[];for(const[e,t]of r)e?o.push(t):s.push(t);return[o,s]},Gp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 1:return new Ci({generator:()=>{const e=n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 2:return new Ci({generator:async()=>{const e=await n.generator();return e.unshift(Promise.resolve(t)),e},type:n.type});case 0:return new Ci({generator:async()=>{const e=await n.generator();return e.unshift(t),e},type:n.type})}},Rp=e=>{const t=e.dataFunc;switch(t.type){case 1:return new Ci({generator:()=>t.generator().reverse(),type:t.type});case 2:case 0:return new Ci({generator:async()=>(await t.generator()).reverse(),type:t.type})}},Pp=(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}}},Up=(e,t)=>"function"==typeof t?1===t.length?new Ci(sh(e,t)):new Ci(Pp(e,t)):new Ci(sh(e,(e=>e[t]))),Op=(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}}},Mp=(e,t)=>{let n;return n="function"==typeof t?1===t.length?ih(e,t):Op(e,t):ih(e,(e=>e[t])),new Ci(n)},xp=(e,t)=>new Ci({generator:async()=>{let n;n="function"==typeof t?1===t.length?sh(e,t):Pp(e,t):sh(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}),Fp=(e,t)=>new Ci({generator:async()=>{let n;n=1===t.length?ih(e,t):Op(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}),Lp=async(e,t,n=Ai)=>{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},Bp=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},Wp=(e,t)=>t?Vp(e,t):$p(e),$p=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new Si(wi.MoreThanOneElement);if(0===e.length)throw new Si(wi.NoElements);return e[0]}case 1:{const e=t.generator();if(e.length>1)throw new Si(wi.MoreThanOneElement);if(0===e.length)throw new Si(wi.NoElements);return e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new Si(wi.MoreThanOneElement);if(0===e.length)throw new Si(wi.NoElements);return await e[0]}}},Vp=async(e,t)=>{const n=await Uh(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new Si(wi.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new Si(wi.NoMatch);return s},qp=async(e,t)=>{const n=await Uh(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new Si(wi.MoreThanOneMatchingElement);r=!0,s=e}if(!1===r)throw new Si(wi.NoMatch);return s},Hp=(e,t)=>t?jp(e,t):Kp(e),Kp=async e=>{const t=e.dataFunc;switch(t.type){case 0:{const e=await t.generator();if(e.length>1)throw new Si(wi.MoreThanOneElement);return 0===e.length?null:e[0]}case 1:{const e=t.generator();if(e.length>1)throw new Si(wi.MoreThanOneElement);return 0===e.length?null:e[0]}case 2:{const e=await t.generator();if(e.length>1)throw new Si(wi.MoreThanOneElement);return 0===e.length?null:await e[0]}}},jp=async(e,t)=>{const n=await Uh(e);let r=!1,s=null;for(const e of n)if(t(e)){if(!0===r)throw new Si(wi.MoreThanOneElement);r=!0,s=e}return s},zp=async(e,t)=>{const n=await Uh(e);let r=!1,s=null;for(const e of n)if(!0===await t(e)){if(!0===r)throw new Si(wi.MoreThanOneElement);r=!0,s=e}return s},Jp=(e,t)=>{const n=e.dataFunc;switch(n.type){case 0:return new Ci({generator:async()=>(await n.generator()).slice(t),type:0});case 1:return new Ci({generator:()=>n.generator().slice(t),type:1});case 2:return new Ci({generator:async()=>(await n.generator()).slice(t),type:2})}},Xp=(e,t)=>new Ci({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 Ci({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}),Qp=(e,t)=>t?eg(e,t):Zp(e),Zp=async e=>{let t=0;for(const n of await e.toArray())t+=n;return t},eg=async(e,t)=>{let n=0;for(const r of await e.toArray())n+=t(r);return n},tg=async(e,t)=>{const n=ih(e,t),r=await gh(n);let s=0;for(const e of r)s+=e;return s},ng=(e,t)=>{const n=t>0?t:0,r=e.dataFunc;switch(r.type){case 1:return new Ci({generator:()=>r.generator().splice(0,n),type:1});case 2:return new Ci({generator:()=>r.generator().then((e=>e.splice(0,n))),type:2});default:return new Ci({generator:()=>r.generator().then((e=>e.splice(0,n))),type:0})}},rg=(e,t)=>new Ci({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}),sg=(e,t)=>new Ci({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}),og=async(e,t)=>{const n=new Map,r=sh(e,(e=>[t(e),e])),s=await gh(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},ig=async(e,t)=>{const n=new Map,r=ih(e,(async e=>[await t(e),e])),s=await gh(r);for(const[e,t]of s){const r=n.get(e);void 0===r?n.set(e,[t]):r.push(t)}return n},ag=async(e,t)=>{const n=e.dataFunc,r=await gh(n),s={};for(const e of r)s[t(e)]=e;return s},cg=async(e,t)=>{const n=ih(e,(async e=>[await t(e),e])),r=await gh(n),s={};for(const[e,t]of r)s[e]=t;return s},ug=async e=>{const t=e.dataFunc,n=await gh(t);return new Set(n)},lg=(e,t,n)=>n?hg(e,t,n):dg(e,t),dg=(e,t)=>new Ci({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}),hg=(e,t,n)=>new Ci({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}),pg=(e,t,n)=>new Ci({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}),gg=(e,t)=>new Ci({generator:async()=>(await e.toArray()).filter(t),type:0}),fg=(e,t)=>new Ci({generator:async()=>{const n=Op(e,(async(e,n)=>[await t(e,n),e])),r=await gh(n),s=[];for(const[e,t]of r)e&&s.push(t);return s},type:0}),vg=(e,t,n)=>n?mg(e,t,n):yg(e,t),yg=(e,t)=>new Ci({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}),mg=(e,t,n)=>new Ci({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}),wg=(e,t,n)=>new Ci({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}),Sg=e=>{const t=Di.prototype,n=e.prototype,r=Object.getOwnPropertyNames(t);for(const e of r)n[e]=n[e]??t[e]};yu(Ti),(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(mu,"aggregate"),n(_u,"all"),n(Cu,"allAsync"),n(Tu,"append"),n(Du,"any"),n(Eu,"anyAsync"),n(bu,"asParallel"),n(Nu,"average"),n(Gu,"averageAsync"),n(Ru,"chunk"),n(Pu,"concatenate"),n(Uu,"contains"),n(Ou,"containsAsync"),n(Mu,"count"),n(Lu,"countAsync"),n(Bu,"defaultIfEmpty"),n(Wu,"distinct"),n($u,"distinctAsync"),n(Vu,"each"),n(qu,"eachAsync"),n(Hu,"elementAt"),n(Ku,"elementAtOrDefault"),n(ju,"except"),n(zu,"exceptAsync"),n(Ju,"first"),n(Qu,"firstAsync"),n(Zu,"firstOrDefault"),n(nl,"firstOrDefaultAsync"),n(rl,"groupBy"),n(il,"groupByAsync"),n(ul,"groupByWithSel"),n(hl,"groupJoin"),n(fl,"groupJoinAsync"),n(ml,"intersect"),n(wl,"intersectAsync"),n(Sl,"joinByKey"),n(Al,"last"),n(Tl,"lastAsync"),n(Dl,"lastOrDefault"),n(El,"lastOrDefaultAsync"),n(bl,"max"),n(Rl,"maxAsync"),n(Pl,"min"),n(Ml,"minAsync"),n(xl,"ofType"),n(Fl,"order"),n(Ll,"orderBy"),n(Bl,"orderByAsync"),n(Wl,"orderByDescending"),n($l,"orderByDescendingAsync"),n(Vl,"orderDescending"),n(ql,"partition"),n(Hl,"partitionAsync"),n(Kl,"prepend"),n(jl,"reverse"),n(zl,"select"),n(Ql,"selectAsync"),n(td,"selectMany"),n(od,"selectManyAsync"),n(id,"sequenceEquals"),n(ad,"sequenceEqualsAsync"),n(cd,"single"),n(dd,"singleAsync"),n(hd,"singleOrDefault"),n(fd,"singleOrDefaultAsync"),n(vd,"skip"),n(yd,"skipWhile"),n(Sd,"skipWhileAsync"),n(Cd,"sum"),n(kd,"sumAsync"),n(Id,"take"),n(Ed,"takeWhile"),n(Gd,"takeWhileAsync"),n(Ud,"toArray"),n(Od,"toMap"),n(Md,"toMapAsync"),n(xd,"toObject"),n(Fd,"toObjectAsync"),n(Ld,"toSet"),n(Bd,"union"),n(Vd,"unionAsync"),n(qd,"where"),n(jd,"whereAsync"),n(Xd,"zip"),n(Zd,"zipAsync")})(_i),(e=>{const t=e.prototype,n=(e,n)=>{const r=function(...t){return e(this,...t)};Object.defineProperty(r,"length",{value:e.length-1}),t[n]=r};n(eh,"aggregate"),n(oh,"all"),n(ah,"allAsync"),n(ch,"append"),n(uh,"any"),n(hh,"anyAsync"),n(ph,"asAsync"),n(fh,"average"),n(vh,"averageAsync"),n(yh,"chunk"),n(mh,"concatenate"),n(wh,"contains"),n(Sh,"containsAsync"),n(Ah,"count"),n(Th,"countAsync"),n(Dh,"defaultIfEmpty"),n(kh,"distinct"),n(Ih,"distinctAsync"),n(Eh,"each"),n(bh,"eachAsync"),n(Nh,"elementAt"),n(Gh,"elementAtOrDefault"),n(Rh,"except"),n(Ph,"exceptAsync"),n(Oh,"first"),n(Fh,"firstAsync"),n(Lh,"firstOrDefault"),n($h,"firstOrDefaultAsync"),n(Vh,"groupBy"),n(Kh,"groupByAsync"),n(Jh,"groupByWithSel"),n(Qh,"groupJoin"),n(tp,"groupJoinAsync"),n(Qh,"groupJoin"),n(tp,"groupJoinAsync"),n(sp,"intersect"),n(op,"intersectAsync"),n(ip,"joinByKey"),n(ap,"last"),n(lp,"lastAsync"),n(dp,"lastOrDefault"),n(gp,"lastOrDefaultAsync"),n(fp,"max"),n(vp,"maxAsync"),n(yp,"min"),n(mp,"minAsync"),n(wp,"ofType"),n(Cp,"order"),n(Tp,"orderBy"),n(Dp,"orderByAsync"),n(kp,"orderByDescending"),n(Ip,"orderByDescendingAsync"),n(Ep,"orderDescending"),n(bp,"partition"),n(Np,"partitionAsync"),n(Gp,"prepend"),n(Rp,"reverse"),n(Up,"select"),n(Mp,"selectAsync"),n(xp,"selectMany"),n(Fp,"selectManyAsync"),n(Lp,"sequenceEquals"),n(Bp,"sequenceEqualsAsync"),n(Wp,"single"),n(qp,"singleAsync"),n(Hp,"singleOrDefault"),n(zp,"singleOrDefaultAsync"),n(Jp,"skip"),n(Xp,"skipWhile"),n(Yp,"skipWhileAsync"),n(Qp,"sum"),n(tg,"sumAsync"),n(ng,"take"),n(rg,"takeWhile"),n(sg,"takeWhileAsync"),n(Uh,"toArray"),n(og,"toMap"),n(ig,"toMapAsync"),n(ag,"toObject"),n(cg,"toObjectAsync"),n(ug,"toSet"),n(lg,"union"),n(pg,"unionAsync"),n(gg,"where"),n(fg,"whereAsync"),n(vg,"zip"),n(wg,"zipAsync")})(Ci),(()=>{const{prototype:e}=Di,t=Object.getOwnPropertyNames(Ti.prototype);for(const n of t)e[n]=e[n]??Ti.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 mi("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 Si(wi.NoMatch);return t}if(0===this.length)throw new Si(wi.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 Si(wi.NoMatch)}if(0===this.length)throw new Si(wi.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 Si(wi.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 Si(wi.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 Ag,_g;!function(e){e.Success="Success",e.GroupDoesNotExists="GroupDoesNotExists",e.ObjectDoesNotExists="ObjectDoesNotExists",e.FatalError="FatalError",e.FunctionNotSupported="FunctionNotSupported"}(Ag||(Ag={})),function(e){e.Success="Success",e.NoPermissions="NoPermissions",e.NameToShort="NameToShort",e.NameAlreadyExists="NameAlreadyExists",e.OtherError="OtherError",e.UnknownError="UnknownError"}(_g||(_g={}));class Cg{constructor(){this._guid="",this._name="",this._iconName="",this._position=0,this._objectsOrder={},null==Cg._devicesService&&(Cg._devicesService=gy.Get(Zo.ServiceName))}GetDevicesChannelsInGroupAsync(){return e=this,t=arguments,r=function*(e=!1){let t=[],n=[];const r=yield Cg._devicesService.GetDevicesAsync(e);if(void 0===this._objectsOrder||null===this._objectsOrder||0==Object.entries(this._objectsOrder).length){gy.Get(a.ServiceName).Error("Old controller API fallback to old groups API.");for(let e of r)for(let t of e.Channels.where((e=>e.ChannelGroups.any((e=>e===this._guid)))))n.push(t);return n}const s=Object.keys(this._objectsOrder).map(Number).sort(((e,t)=>e-t));Object.values(this._objectsOrder).forEach((e=>{const n=r.select((t=>t.Channels.where((t=>t.ChannelId===e))));if(null!==n)for(let e of n)for(let n of e)t.push(n)}));for(let e of s){const r=t.firstOrDefault((t=>t.ChannelId===this._objectsOrder[e]));null!==r&&n.push(r)}return n},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}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 gy.Get(Mg.ServiceName).ChangeGroupNameAsync(this,e)}ChangeIconNameAsync(e){return gy.Get(Mg.ServiceName).ChangeGroupIconNameAsync(this,e)}}var Tg,Dg,kg,Ig,Eg,bg,Ng,Gg,Rg,Pg,Ug,Og=function(e,t,n,r){return new(n||(n=Promise))((function(s,o){function i(e){try{c(r.next(e))}catch(e){o(e)}}function a(e){try{c(r.throw(e))}catch(e){o(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(i,a)}c((r=r.apply(e,t||[])).next())}))};class Mg{constructor(){this._connection=null,this._synchronized=!1,this._onSynchronized=new Ee,this._groups=[],this._objectsGroupingSupported=!1,this._configurationService=gy.Get(lt.ServiceName),this._syncSemaphore=new nt(1),this._connection=gy.Get(bt.ServiceName),gy.Get(Qe.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Og(this,void 0,void 0,(function*(){yield this.ResyncGroupsAsync()}))))}ResyncGroupsAsync(){return Og(this,void 0,void 0,(function*(){var e;const t=yield this._syncSemaphore.AcquireAsync();try{this._synchronized=!1,yield this.GetGroupsAsync(!0),this._synchronized=!0,this._onSynchronized.Invoke()}catch(t){null===(e=u.Log)||void 0===e||e.Error(Mg.ServiceName,`Failed to sync groups: ${t}`)}finally{t.Release()}}))}WaitForSynchronizationAsync(){return this._synchronized?Promise.resolve():new Promise((e=>{const t=window.setTimeout((()=>{this._onSynchronized.Unsubscribe(n),e()}),3e4),n=()=>{window.clearTimeout(t),this._onSynchronized.Unsubscribe(n),e()};this._onSynchronized.Subscribe(n)}))}SetObjectsInGroupAndOrderAsync(e,t){return Og(this,void 0,void 0,(function*(){var n,r;let s=[],o=[];for(let e of t)if(this.IsDevice(e)){for(let t of e.Channels)s.push(`${t.ChannelId}`);o.push(`${e.Guid}`)}else{if(!this.IsDeviceChannel(e))throw new Error("Passed object is not a device or device channel!");s.push(`${e.ChannelId}`),o.push(`${e.ChannelId}`)}const i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Lg(e,o),15e3,!1);switch(null===(r=u.Log)||void 0===r||r.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! SetObjectsInGroupAndOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),yield gy.Get(Zo.ServiceName).GetDevicesAsync(),null==i?void 0:i.Status){case ue.OK:return new Ne(Ag.Success,"");case ue.NotSupportedMethod:case ue.ResourceDoesNotExists:case ue.ResourceIsNotAvailable:return new Ne(Ag.FunctionNotSupported,"");case ue.WrongData:return"GroupDoesNotExists"===i.Data?new Ne(Ag.GroupDoesNotExists,i.Data):new Ne(Ag.FatalError,i.Data);case ue.Error:case ue.FatalError:default:return new Ne(Ag.FatalError,"")}}))}IsDevice(e){return void 0!==e.Channels}IsDeviceChannel(e){return void 0!==e.GetDevice}LogGroupsOrder(e){const t=gy.Get(a.ServiceName);e.forEach(((e,n)=>{t.Debug(Mg.ServiceName,`Group ${e.Name} order position [on array]: ${n} set position: ${e.OrderPosition}`)}))}LogObjectsInGroupOrder(e,t){const n=gy.Get(a.ServiceName);n.Debug(Mg.ServiceName,`Group ${e.Name} objects order:`),t.forEach(((e,t)=>{n.Debug(Mg.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 Og(this,void 0,void 0,(function*(){var t,n;const r=e.select((e=>e.Guid)).toArray(),s=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Fg(r),15e3,!1);return null===(n=u.Log)||void 0===n||n.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeGroupsOrderAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==s?void 0:s.Status)===ue.OK?(yield this.GetGroupsAsync(!1),ue.OK):(gy.Get(a.ServiceName).Error(Mg.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 Og(this,void 0,void 0,(function*(){var n,r,s;const o=t.select((e=>e.ChannelId)).toArray(),i=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new Vg(e.Guid,o),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! ChangeObjectsPositionsInGroupAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==i?void 0:i.Status)===ue.OK?(yield this.GetGroupsAsync(!1),yield gy.Get(Zo.ServiceName).GetDevicesAsync(),ue.OK):(null===(s=u.Log)||void 0===s||s.Error(Mg.ServiceName,`Failed to change objects positions in group, controller responded with error ${null==i?void 0:i.Status} data: ${null==i?void 0:i.Data}`),this.LogObjectsInGroupOrder(e,t),null==i?void 0:i.Status)}))}IsGroupsAndObjectsOrderingAvailable(){return this._objectsGroupingSupported}MoveGroupPositionAsync(e,t){return Og(this,void 0,void 0,(function*(){var n,r,s;const o=yield null===(n=this._connection)||void 0===n?void 0:n.SendAndWaitForResponseAsync(new xg(e.Guid,t),15e3,!1);return null===(r=u.Log)||void 0===r||r.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==o?void 0:o.Status)===ue.OK?(yield this.GetGroupsAsync(!1),ue.OK):(null===(s=u.Log)||void 0===s||s.Error(Mg.ServiceName,`Failed to move group position, controller responded with error ${null==o?void 0:o.Status} data: ${null==o?void 0:o.Data}`),null==o?void 0:o.Status)}))}MoveObjectInGroupPositionAsync(e,t,n){return Og(this,void 0,void 0,(function*(){var r,s,o;const i=`${t.GetDevice().Guid}_${t.Number}`,a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(new $g(e.Guid,i,n),15e3,!1);return null===(s=u.Log)||void 0===s||s.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! MoveObjectInGroupPositionAsync()"),this._configurationService.ExitConfigurationModeAsync(),(null==a?void 0:a.Status)===ue.OK?(yield this.GetGroupsAsync(!1),yield gy.Get(Zo.ServiceName).GetDevicesAsync(),ue.OK):(null===(o=u.Log)||void 0===o||o.Error(Mg.ServiceName,`Failed to move object in group position, controller responded with error ${null==a?void 0:a.Status} data: ${null==a?void 0:a.Data}`),null==a?void 0:a.Status)}))}AddDeviceChannelToGroupByGuidAsync(e,t){return Og(this,arguments,void 0,(function*(e,t,n=!1){var r,s,o,i;const a=new Jg;if(a.Data.Channel=e.Number,null==e.GetDevice())throw new Error("Device is not set on this channel!");a.Data.DeviceGuid=null===(r=e.GetDevice())||void 0===r?void 0:r.Guid,a.Data.GroupGuid=t;const c=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(a,15e3,!1);return null===(o=u.Log)||void 0===o||o.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! AddDeviceChannelToGroupByGuidAsync()"),this._configurationService.ExitConfigurationModeAsync(),null!=c&&null!=c.Status?(c.Status==ue.OK?e.ChannelGroups.push(t):null===(i=u.Log)||void 0===i||i.Error(Mg.ServiceName,`Failed to add device channel ${e.Name} to group ${t}, controller responded with error ${c.Status} data: ${c.Data}`),n||(yield this.GetGroupsAsync(!1),yield gy.Get(Zo.ServiceName).GetDevicesAsync()),c.Status):(n||(yield this.GetGroupsAsync(!1),yield gy.Get(Zo.ServiceName).GetDevicesAsync()),ue.Error)}))}RemoveDeviceChannelFromGroupByGuidAsync(e,t){return Og(this,arguments,void 0,(function*(e,t,n=!1){var r,s,o;const i=new Xg;if(null==e.GetDevice())throw new Error("Device is not set on this channel!");i.Data.DeviceGuid=null===(r=e.GetDevice())||void 0===r?void 0:r.Guid,i.Data.Channel=e.Number,i.Data.GroupGuid=t;const a=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(i,15e3,!1);return n||this._configurationService.ExitConfigurationModeAsync(),null!=a&&null!=a.Status?(a.Status==ue.OK?e.ChannelGroups=e.ChannelGroups.where((e=>e!=t)).toArray():null===(o=u.Log)||void 0===o||o.Error(Mg.ServiceName,`Failed to remove device channel ${e.Name} from group ${t}, controller responded with error ${a.Status} data: ${a.Data}`),n||(yield this.GetGroupsAsync(!1)),yield gy.Get(Zo.ServiceName).GetDevicesAsync(),a.Status):(n||(yield this.GetGroupsAsync(!1)),yield gy.Get(Zo.ServiceName).GetDevicesAsync(),ue.Error)}))}UpsertGroupWithDevicesChannelsAsync(e,t){return Og(this,void 0,void 0,(function*(){var n,r,s;if(this._groups.all((t=>t.Guid!=e.Guid))){let t=yield this.AddNewGroupWithIconAsync(e.Name,e.IconName);if(!(t instanceof Cg))return t instanceof Ne?t:new Ne(_g.UnknownError,"");e=t}for(let r of t.where((t=>t.ChannelGroups.all((t=>t!==e.Guid))))){let t=yield this.AddDeviceChannelToGroupAsync(r,e,!0);if(t!==ue.OK)return null===(n=u.Log)||void 0===n||n.Error(Mg.ServiceName,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`),new Ne(_g.UnknownError,`Failed to add device channel ${r.Name} to group ${e.Name}, controller responded with error ${t}`)}let o=yield gy.Get(Zo.ServiceName).GetDevicesAsync();for(let n of o)for(let o of n.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(let t of o.ChannelGroups.where((t=>e.Guid==t))){let t=yield this.RemoveDeviceChannelFromGroupAsync(o,e,!0);if(t!==ue.OK)return null===(r=u.Log)||void 0===r||r.Error(Mg.ServiceName,`Failed to remove device channel ${o.Name} from group ${e.Name}, controller responded with error ${t}`),null===(s=u.Log)||void 0===s||s.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpsertGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),new Ne(_g.UnknownError,`Failed to remove device channel ${o.Name} from group ${e.Name}, controller responded with error ${t}`)}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),e}))}UpdateGroupWithDevicesChannelsAsync(e,t){return Og(this,void 0,void 0,(function*(){var n,r,s,o;for(let s of t.where((t=>t.ChannelGroups.all((t=>t!==e))))){let t=yield this.AddDeviceChannelToGroupByGuidAsync(s,e,!0);if(t!==ue.OK)return null===(n=u.Log)||void 0===n||n.Error(Mg.ServiceName,`Failed to add device channel ${s.Name} to group ${e}, controller responded with error ${t}`),null===(r=u.Log)||void 0===r||r.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.FatalError}let i=yield gy.Get(Zo.ServiceName).GetDevicesAsync();for(let n of i)for(let r of n.Channels.except(t,((e,t)=>e.GetDevice().Guid==t.GetDevice().Guid&&e.Number==t.Number)))for(let t of r.ChannelGroups.where((t=>e==t))){let t=yield this.RemoveDeviceChannelFromGroupByGuidAsync(r,e,!0);if(t!==ue.OK)return null===(s=u.Log)||void 0===s||s.Error(Mg.ServiceName,`Failed to remove device channel ${r.Name} from group ${e}, controller responded with error ${t}`),null===(o=u.Log)||void 0===o||o.Error(Mg.ServiceName,"EXIT CONFIGURATION MODE WILL BE FIRED! UpdateGroupWithDevicesChannelsAsync()"),this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.FatalError}return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),ue.OK}))}ChangeGroupNameByGuidAsync(e,t){return Og(this,void 0,void 0,(function*(){var n,r;let s=new zg,o=new Yg,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(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ue.OK:return new Ne(_g.Success,"");case ue.WrongData:switch(a.Data){case"NameToShort":return new Ne(_g.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ne(_g.NameAlreadyExists,"Group with this name already exists");default:return new Ne(_g.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ne(_g.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ne(_g.UnknownError,"")}))}ChangeGroupNameAndIconAsync(e,t,n){return this.ChangeGroupNameAndIconByGuidAsync(e.Guid,t,n)}ChangeGroupNameAndIconByGuidAsync(e,t,n){return Og(this,void 0,void 0,(function*(){var r,s;let o=new zg,i=new Yg,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(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=c&&null!=c.Status)switch(c.Status){case ue.OK:return new Ne(_g.Success,"");case ue.WrongData:switch(c.Data){case"NameToShort":return new Ne(_g.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ne(_g.NameAlreadyExists,"Group with this name already exists");default:return new Ne(_g.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}default:return new Ne(_g.OtherError,`Response error: ${c.Status} data: ${c.Data}`)}return new Ne(_g.UnknownError,"")}))}ChangeGroupIconNameByGuidAsync(e,t){return Og(this,void 0,void 0,(function*(){var n,r;let s=new zg,o=new Yg,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(this._configurationService.ExitConfigurationModeAsync(),this._groups=yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ue.OK:return new Ne(_g.Success,"");case ue.WrongData:switch(a.Data){case"NameToShort":return new Ne(_g.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ne(_g.NameAlreadyExists,"Group with this name already exists");default:return new Ne(_g.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ne(_g.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ne(_g.UnknownError,"")}))}GetServiceName(){return Mg.ServiceName}GetGroupByGuid(e){return this._groups.first((t=>t.Guid===e))}ChangeGroupNameAsync(e,t){return this.ChangeGroupNameByGuidAsync(e.Guid,t)}ChangeGroupIconNameAsync(e,t){return this.ChangeGroupIconNameByGuidAsync(e.Guid,t)}RemoveGroupAsync(e){return this.RemoveGroupByGuidAsync(e.Guid)}RemoveGroupByGuidAsync(e){return Og(this,void 0,void 0,(function*(){var t;let n=new Kg;n.Data=e;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(n,15e3,!1);return this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=r&&null!=r.Status?null==r?void 0:r.Status:ue.Error}))}GetGroupsAsync(){return Og(this,arguments,void 0,(function*(e=!0){var t,n;const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new jg,15e3,e);let s=[];if((null==r?void 0:r.Status)===ue.OK){let t=0,o=gy.Get(a.ServiceName),i=yield gy.Get(Zo.ServiceName).GetDevicesAsync();return null===(n=r.Data)||void 0===n||n.forEach((n=>{t++;let r=new Cg;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||o.Info(Mg.ServiceName,`Got group: ${r.Name} ${r.Guid} order: ${r.OrderPosition} objects order: ${JSON.stringify(r.ObjectsOrder)}`),s.push(r)})),this._groups=s,s}throw new Error(`Failed to get groups, API responded with status ${null==r?void 0:r.Status} data: ${null==r?void 0:r.Data}`)}))}AddDeviceChannelToGroupAsync(e,t,n=!1){return this.AddDeviceChannelToGroupByGuidAsync(e,t.Guid,n)}RemoveDeviceChannelFromGroupAsync(e,t,n=!1){return this.RemoveDeviceChannelFromGroupByGuidAsync(e,t.Guid,n)}AddNewGroupAsync(e){return Og(this,void 0,void 0,(function*(){var t,n,r;let s=new zg,o=new Yg;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(this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=i&&null!=i.Status)switch(i.Status){case ue.OK:return this._groups.first((t=>t.Name===e));case ue.WrongData:switch(null===(r=u.Log)||void 0===r||r.Error(Mg.ServiceName,`Failed to add new group, controller responded with error ${i.Status} data: ${i.Data}`),i.Data){case"NameToShort":return new Ne(_g.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ne(_g.NameAlreadyExists,"Group with this name already exists");default:return new Ne(_g.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}default:return new Ne(_g.OtherError,`Response error: ${i.Status} data: ${i.Data}`)}return new Ne(_g.UnknownError,"")}))}AddNewGroupWithIconAsync(e,t){return Og(this,void 0,void 0,(function*(){var n,r,s;let o=new zg,i=new Yg;i.Name=e,i.IconName=t,null===(n=o.Data)||void 0===n||n.push(i);const a=yield null===(r=this._connection)||void 0===r?void 0:r.SendAndWaitForResponseAsync(o,15e3,!1);if(this._configurationService.ExitConfigurationModeAsync(),yield this.GetGroupsAsync(!1),null!=a&&null!=a.Status)switch(a.Status){case ue.OK:return this._groups.first((t=>t.Name===e));case ue.WrongData:switch(null===(s=u.Log)||void 0===s||s.Error(Mg.ServiceName,`Failed to add new group, controller responded with error ${a.Status} data: ${a.Data}`),a.Data){case"NameToShort":return new Ne(_g.NameToShort,"At least 3 characters required");case"NameAlreadyExists":return new Ne(_g.NameAlreadyExists,"Group with this name already exists");default:return new Ne(_g.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}default:return new Ne(_g.OtherError,`Response error: ${a.Status} data: ${a.Data}`)}return new Ne(_g.UnknownError,"")}))}}Mg.ServiceName="ChannelsGroupsService";class xg extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/move",this.Method=le.Post,this.Data=new Wg,this.Data.GroupGuid=e,this.Data.NewPosition=t}}class Fg extends ce{constructor(e){super(),this.Resource="/devices/groups/move",this.Method=le.Post,this.Data=e}}class Lg extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/set",this.Method=le.Post,this.Data=new Bg,this.Data.GroupGuid=e.Guid,this.Data.ObjectsIds=t}}class Bg{constructor(){this.GroupGuid="",this.ObjectsIds=[]}}class Wg{constructor(){this.GroupGuid="",this.NewPosition=0}}class $g extends ce{constructor(e,t,n){super(),this.Resource="/devices/groups/group/object/move",this.Method=le.Post,this.Data=new qg,this.Data.GroupGuid=e,this.Data.NewPosition=n,this.Data.ObjectId=t}}class Vg extends ce{constructor(e,t){super(),this.Resource="/devices/groups/group/objects/move",this.Method=le.Post,this.Data=new Hg,this.Data.GroupGuid=e,this.Data.OrderedObjectsIds=t}}class qg{constructor(){this.GroupGuid="",this.ObjectId="",this.NewPosition=0}}class Hg{constructor(){this.GroupGuid="",this.OrderedObjectsIds=[]}}class Kg extends ce{constructor(){super(),this.Resource="/devices/groups/group",this.Method=le.Delete}}class jg extends ce{constructor(){super(),this.Resource="/devices/groups/",this.Method=le.Get}}class zg extends ce{constructor(){super(),this.Resource="/devices/groups/group",this.Method=le.Put,this.Data=[]}}class Jg extends ce{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=le.Put,this.Data=new Qg}}class Xg extends ce{constructor(){super(),this.Resource="/devices/device/channel/groups/group/",this.Method=le.Delete,this.Data=new Qg}}class Yg{constructor(){this.Id=0,this.Guid="",this.Name="",this.IconName="",this.OrderPosition=0,this.ObjectsOrder={}}}class Qg{constructor(){this.GroupGuid="",this.DeviceGuid="",this.Channel=0}}class Zg{constructor(){this.DeviceGuid="",this.CurrentVersion="",this.NewVersion=""}}class ef{constructor(){this.UpdatesAvailable=[],this.UpdatesNotAvailable=[]}}class tf{constructor(){this.UpdatedResourceName=new Map,this.UpdateDescription=new Map,this.UpdateCreationTime=null,this.Version="",this.UpdateChannel=""}}class nf{constructor(){this.Resource="",this.Version="",this.Type=null}}!function(e){e[e.RadioUpdate=0]="RadioUpdate",e[e.SoftwareUpdate=1]="SoftwareUpdate"}(Tg||(Tg={})),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"}(Dg||(Dg={})),(Ug=kg||(kg={}))[Ug.WaitingForUser=1]="WaitingForUser",Ug[Ug.Downloading=2]="Downloading",Ug[Ug.Unpackaging=3]="Unpackaging",Ug[Ug.CheckingApplicability=4]="CheckingApplicability",Ug[Ug.MigratingData=5]="MigratingData",Ug[Ug.CreatingBackup=6]="CreatingBackup",Ug[Ug.Deploying=7]="Deploying",Ug[Ug.Installing=8]="Installing",Ug[Ug.Removing=9]="Removing",Ug[Ug.Error=10]="Error",Ug[Ug.ReadyToDownload=11]="ReadyToDownload",Ug[Ug.PreparingSystem=12]="PreparingSystem",Ug[Ug.CheckingPackageIntegrity=13]="CheckingPackageIntegrity",Ug[Ug.CheckingIntegrity=14]="CheckingIntegrity",Ug[Ug.UndoingInstallation=15]="UndoingInstallation",Ug[Ug.Installed=16]="Installed",(Pg=Ig||(Ig={}))[Pg.Ignore=0]="Ignore",Pg[Pg.Cancel=1]="Cancel",Pg[Pg.Install=2]="Install";class rf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.Status=Dg.Error,this.UpdateNumber=1,this.AvailableUpdates=1}}class sf{constructor(){this.UpdatedResourceName=new Map,this.Percentage=0,this.PercentageTotal=0,this.SpeedMbps=0,this.CurrentTask=Ng.Unknown,this.DownloadOnly=!1}}class of{constructor(){this.BulkUpdateStatus=Eg.Success,this.DevicesUpdateResults=new Map}}!function(e){e[e.Success=0]="Success",e[e.PartialSuccess=1]="PartialSuccess",e[e.UpdatesNotFound=2]="UpdatesNotFound",e[e.CannotUnpairRetransmitters=3]="CannotUnpairRetransmitters",e[e.CannotPairRetransmitters=4]="CannotPairRetransmitters"}(Eg||(Eg={})),function(e){e[e.Unknown=0]="Unknown",e[e.Updated=1]="Updated",e[e.InsufficientConnection=2]="InsufficientConnection",e[e.Error=3]="Error",e[e.UnknownError=4]="UnknownError",e[e.ControllerSoftwareTooOld=5]="ControllerSoftwareTooOld"}(bg||(bg={})),function(e){e[e.Unknown=0]="Unknown",e[e.DownloadingUpdate=1]="DownloadingUpdate",e[e.DownloadingInstaller=2]="DownloadingInstaller",e[e.CheckingUpdate=3]="CheckingUpdate",e[e.UpdateDownloadedAndChecked=4]="UpdateDownloadedAndChecked"}(Ng||(Ng={})),function(e){e[e.DeviceIsUpToDate=0]="DeviceIsUpToDate",e[e.CannotFindDevice=1]="CannotFindDevice",e[e.UnsupportedApiVersion=2]="UnsupportedApiVersion",e[e.UnsupportedDevice=3]="UnsupportedDevice",e[e.CannotGetFirmwareVersion=4]="CannotGetFirmwareVersion",e[e.CannotGetUpdates=5]="CannotGetUpdates",e[e.CannotProcessUpdate=6]="CannotProcessUpdate",e[e.UpdateActionsNotSupported=7]="UpdateActionsNotSupported",e[e.UnsupportedExtensionVersion=8]="UnsupportedExtensionVersion",e[e.UpdatesPartiallyInstalled=9]="UpdatesPartiallyInstalled",e[e.RetransmitterFound=10]="RetransmitterFound",e[e.ProtocolRadioUnsupported=11]="ProtocolRadioUnsupported",e[e.FeatureUnsupportedInCurrentVersion=12]="FeatureUnsupportedInCurrentVersion",e[e.CannotGetUpdatesBranch=13]="CannotGetUpdatesBranch",e[e.CannotSetUpdatesBranch=14]="CannotSetUpdatesBranch",e[e.UpdateAlreadyDownloaded=15]="UpdateAlreadyDownloaded",e[e.UpdateDownloadFailed=16]="UpdateDownloadFailed",e[e.UpdateAlreadyInstalled=17]="UpdateAlreadyInstalled",e[e.CannotGetCurrentControllerVersionTimeout=18]="CannotGetCurrentControllerVersionTimeout",e[e.CannotGetCurrentControllerVersion=19]="CannotGetCurrentControllerVersion",e[e.InstallerFileSignCheckFailed=20]="InstallerFileSignCheckFailed",e[e.UpdateFileSignCheckFailed=21]="UpdateFileSignCheckFailed",e[e.UpdateFileCheckFailed=22]="UpdateFileCheckFailed",e[e.UpdateInstallationFailed=23]="UpdateInstallationFailed"}(Gg||(Gg={})),function(e){e.Public="public",e.Beta="beta",e.Development="dev"}(Rg||(Rg={}));var af,cf,uf,lf,df,hf,pf,gf,ff,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 yf{constructor(){this._controllerUpdates=[],this._updateRequestTimeout=12e4,this._oldUpdateVersion=5,this._oldUpdateBuild=56,this._updateOfflineStageTime=15,this._updateProviders=gy.Get(uo.ServiceName),this._logger=gy.Get(a.ServiceName),this._connection=gy.Get(bt.ServiceName),this._appStateService=gy.Get(Tt.ServiceName),this._extensionService=gy.Get(st.ServiceName)}IsBranchAndAutomaticUpdatesSettingSupportedAsync(){return vf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ne)return!1;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);return!(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)}))}DownloadControllerUpdateAsync(e){return vf(this,void 0,void 0,(function*(){try{const t=yield this.getRuntimeInfoAsync();if(t instanceof Ne)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);return n<this._oldUpdateVersion||n===this._oldUpdateVersion&&r<=this._oldUpdateBuild?new Ne(Gg.FeatureUnsupportedInCurrentVersion,`Cannot download update, feature unsupported in current version. Current version: ${t}`):yield this.DownloadControllerUpdateUsingApiAsync((()=>{}),e,!0)}catch(e){return new Ne(Gg.CannotProcessUpdate,`Failed to download controller update: ${e}`)}}))}InstallControllerOrRadioUpdateAsync(e,t,n){return vf(this,void 0,void 0,(function*(){const r=new RegExp("^[{]?[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}[}]?$"),s=this._controllerUpdates.length,o=yield this.getRuntimeInfoAsync();if(o instanceof Ne)return o;const i=parseInt(o.SoftwareVersion.toString().split(".")[0]),a=parseInt(o.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Ne(Gg.CannotGetUpdates,"Cannot find any updates, make sure you check for available updates by calling CheckControllerUpdateAsync().");if(void 0===n||"string"!=typeof n||!r.test(n)){const r=[1],o=t=>{t.UpdateNumber=r[0],t.AvailableUpdates=s,e(t)},c=e=>vf(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let u=this._controllerUpdates.where((e=>e.UpdateType==Tg.RadioUpdate)).toArray(),l=[];this._appStateService.DisallowHibernation();for(let e=0;e<u.length;e++){const t=yield(yield this._updateProviders.GetUpdatesProviderAsync(u[e].ProviderName)).InstallRadioUpdateAsync(u[e],o);yield c(5e3),t==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((t=>t.UpdateIdentifier!=u[e].UpdateIdentifier))),l.push(t),r[0]++}const d=this._controllerUpdates.find((e=>e.UpdateType==Tg.SoftwareUpdate));if(null!=d)if(i<this._oldUpdateVersion||i===this._oldUpdateVersion&&a<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(d.Update,o);e==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=d.UpdateIdentifier))),l.push(e),r[0]++}else{const e=yield this.UpdateControllerUsingApiAsync(o,t,!1);this._appStateService.AllowHibernation(),e==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),l.push(e),r[0]++}const h=l.where((e=>e instanceof Ne)).toArray();if(null!=h&&0!=h.length){let e="";return h.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),h.any((e=>e.Type==Gg.UpdateDownloadFailed))?new Ne(Gg.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new Ne(Gg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ue.OK}{let r;const s=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==s)return new Ne(Gg.CannotGetUpdates,`Update with requested guid (${n}) not found.`);switch(this._logger.Debug(`Installing single update type: ${s.Update.UpdateType}, resource: ${s.UpdatedResourceName}, version: ${s.Update.Version}`),this._appStateService.DisallowHibernation(),s.UpdateType){case Tg.RadioUpdate:return r=yield(yield this._updateProviders.GetUpdatesProviderAsync(s.ProviderName)).InstallRadioUpdateAsync(s,e),this._appStateService.AllowHibernation(),this._logger.Debug(`Radio update result: ${r}`),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),r;case Tg.SoftwareUpdate:return i<this._oldUpdateVersion||i===this._oldUpdateVersion&&a<=this._oldUpdateBuild?(r=yield this.UpdateControllerUsingScriptAsync(s.Update,e),this._appStateService.AllowHibernation(),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))):(yield this.CheckControllerUpdatesAsync(),r=yield this.UpdateControllerUsingApiAsync(e,t,!1),this._appStateService.AllowHibernation(),r==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))),r;default:return new Ne(Gg.CannotProcessUpdate,`Update with type ${s.UpdateType} is not supported by UpdateService.`)}}}))}GetAutomaticControllerUpdateDownloadStatusAsync(){return vf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ne)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ne(Gg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);let r=yield this._connection.SendAndWaitForResponseAsync(new Pf,1e4,!1);return!(r.Status!=ue.OK||!r.Data)}))}GetServiceName(){return yf.ServiceName}CheckDeviceVersionAsync(e){return vf(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield gy.Get(Zo.ServiceName).GetDevice(e);if(null==t)return new Ne(Gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ne(Gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Us.Device)).first())||void 0===t?void 0:t.GetSoftwareVersionAsync(n);return r.Type,r}))}CheckDeviceUpdateAsync(e){return vf(this,void 0,void 0,(function*(){var t;let n;if("string"==typeof e){const t=yield gy.Get(Zo.ServiceName).GetDevice(e);if(null==t)return new Ne(Gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);n=t}else n=e;if(null==n.ProtocolGuid)return new Ne(Gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const r=yield null===(t=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(n.ProtocolGuid,Us.Device)).first())||void 0===t?void 0:t.GetAvailableUpdateAsync(n);if(null!=r.Type)return r;const s=new Sf;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 gy.Get(Zo.ServiceName).GetDevicesAsync()).any((e=>"952ddc14-76c4-4f47-b0bc-5d106c1f9b02"==e.ModelGuid))&&(s.IsUpdateSafe=!1),s}))}CheckDeviceUpdatesBulkAsync(e){return vf(this,void 0,void 0,(function*(){const t=yield yield this._updateProviders.GetUpdatesProvidersAsync(Us.Device),n=[];for(var r of t){const t=yield r.CheckUpdateBulkAsync(e);if(t instanceof Ne)return t;for(const e of t){const t=new Sf;t.CurrentResourceVersion=e.CurrentResourceVersion,t.NewResourceVersion=e.Update.Version,t.UpdatedResourceName=e.UpdatedResourceName,t.UpdateDescription=e.UpdateDescription,t.IsUpdateSafe=!0;let s="n/a";try{s=(yield this._extensionService.GetProtocolInfoAsync(r.ProtocolGuid)).first().Name}catch(e){this._logger.Warning(`Cannot get protocol name! error: ${e}`)}t.Protocol=s,t.ProtocolGuid=r.ProtocolGuid,t.UpdateResourceGuid=e.Update.ResourceGuid,n.push(t)}}return n}))}InstallDeviceUpdateAsync(e,t,n){return vf(this,arguments,void 0,(function*(e,t,n,r=!1){var s;let o;if("string"==typeof e){const t=yield gy.Get(Zo.ServiceName).GetDevice(e);if(null==t)return new Ne(Gg.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);o=t}else o=e;if(null==o.ProtocolGuid)return new Ne(Gg.UnsupportedDevice,"Device does not contains data about protocol GUID.");const i=yield null===(s=(yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(o.ProtocolGuid,Us.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,Us.Device)).first().InstallUpdateAsync(i,t,n,r);return null!=a.Type?(this._appStateService.AllowHibernation(),a):(this._appStateService.AllowHibernation(),ue.OK)}))}InstallDevicesUpdateBulkAsync(e,t,n){return vf(this,void 0,void 0,(function*(){const r=(yield gy.Get(Zo.ServiceName).GetDevicesAsync()).where((t=>e.includes(t.Guid))).groupBy((e=>e.ProtocolGuid)),s=[];this._appStateService.DisallowHibernation();const o=r.count();for(let e=0;e<o;e++){const i=r.elementAt(e),a=e*(100/o),c=(e+1)*(100/o),u=e=>{e.PercentageTotal=Math.floor(e.PercentageTotal/100*(c-a)+a),t(e)},l=yield yield this._updateProviders.GetUpdatesProvidersByProtocolAsync(i.key,Us.Device),d=yield l.first().InstalUpdateBulkAsync(i.select((e=>e.Guid)).toArray(),u,n);if(d instanceof Ne)return d;s.push(d)}if(this._appStateService.AllowHibernation(),1==s.length)return s[0];{const e=new of;s.some((e=>e.DevicesUpdateResults.count()>0))&&s.any((e=>e.BulkUpdateStatus!=Eg.Success))?e.BulkUpdateStatus=Eg.PartialSuccess:s.any((e=>e.BulkUpdateStatus!=Eg.Success))?e.BulkUpdateStatus=s.first().BulkUpdateStatus:e.BulkUpdateStatus=Eg.Success;for(const t of s)t.DevicesUpdateResults.forEach(((t,n)=>{e.DevicesUpdateResults.set(n,t)}));return e}}))}CheckControllerSoftwareUpdateAvailabilityAsync(){return vf(this,void 0,void 0,(function*(){const e=gy.Get(Qe.ServiceName).User;if(null==e)return!1;if(""==e.SoftwareVersion||null==e.SoftwareVersion)return!0;const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<this._oldUpdateVersion||parseFloat(t)==this._oldUpdateVersion&&parseFloat(n)<=this._oldUpdateBuild)return!0;const r=yield this._connection.SendAndWaitForResponseAsync(new bf,1e4,!1);if(null==r||r.Status!=ue.OK||null==r.Data)return!1;const[s,o]=r.Data.Update.Version.ContainerSoftwareVersion.toString().split(".");return parseInt(s)>parseInt(t)||parseInt(s)==parseInt(t)&&parseInt(o)>parseInt(n)}))}CanCancelFailedControllerUpdateOrGetPendingUpdateProgress(){return gy.Get(lt.ServiceName).CheckIfControllerSoftwareVersionIsEnough(6,66)}CancelFailedControllerUpdateAsync(){return vf(this,void 0,void 0,(function*(){switch((yield this._connection.SendAndWaitForResponseAsync(new If,1e4,!1)).Status){case ue.OK:return ue.OK;case ue.OperationNotPermitted:return ue.OperationNotPermitted;case ue.Error:default:return ue.Error}}))}CheckControllerPendingUpdateProgressAsync(e,t){return vf(this,void 0,void 0,(function*(){return new Promise(((n,r)=>vf(this,void 0,void 0,(function*(){var s;const o=gy.Get(Qe.ServiceName).User;if(null==o)return n(new Ne(Gg.UpdateActionsNotSupported,"No user data found, cannot check pending update progress."));if(""==o.SoftwareVersion||null==o.SoftwareVersion)return n(new Ne(Gg.CannotGetCurrentControllerVersion,"No software version data found, cannot check pending update progress."));const[i,a]=o.SoftwareVersion.split(".");if(parseFloat(i)<this._oldUpdateVersion||parseFloat(i)==this._oldUpdateVersion&&parseFloat(a)<=this._oldUpdateBuild)return n(new Ne(Gg.UnsupportedApiVersion,"Not supported API version, cannot check pending update progress."));const c=yield this._connection.SendAndWaitForResponseAsync(new bf,1e4,!1);if(c.Status!=ue.OK)return n(new Ne(Gg.CannotGetUpdates,"No pending updates found."));let u=null===(s=c.Data)||void 0===s?void 0:s.DownloadOnly,l=100;const d=60*this._updateOfflineStageTime*1e3;let h=0;const p=new rf;let g=50,f=new sf,v=new rf,y=!1;u||(f.DownloadOnly=u,g=100);let m=100/g;const w=n=>{let r=n.Data;switch(this._logger.Debug(`Update progress: ${r.UpdateStep}, ${r.StepProgressInPercentage}%, ${r.UpdateProgressInPercentage}% data frame status: ${n.Status}`),p.Percentage=Math.round(r.StepProgressInPercentage),p.PercentageTotal=Math.round(r.UpdateProgressInPercentage),f.SpeedMbps=r.DownloadSpeedInMbs,f.Percentage=Math.round(r.StepProgressInPercentage),f.PercentageTotal=Math.round(r.UpdateProgressInPercentage),f.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),v.AvailableUpdates=1,v.Percentage=r.StepProgressInPercentage,v.PercentageTotal=r.UpdateProgressInPercentage,v.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),h=r.StepProgressInPercentage,r.UpdateStep){case lf.DownloadingInstaller:f.CurrentTask=Ng.DownloadingInstaller,v.Status=Dg.DownloadingPackage,t(f);break;case lf.DownloadingUpdate:f.CurrentTask=Ng.DownloadingUpdate,v.Status=Dg.DownloadingPackage,t(f);break;case lf.CheckingUpdate:f.CurrentTask=Ng.CheckingUpdate,v.Status=Dg.CheckingPackage,e(v);break;case lf.PreparingUpdate:v.Status=Dg.PreparingForUpgrade,f.CurrentTask=Ng.CheckingUpdate,e(v);break;case lf.OfflineUpdateStep:case lf.InstallingUpdate:v.Status=Dg.Upgrading,e(v);break;case lf.InstallerFileSignCheckFailed:case lf.UpdateFileSignCheckFailed:v.Status=Dg.InstallationError,e(v);break;case lf.UpdateDownloadFailed:v.Status=Dg.InstallationStopped,e(v);break;case lf.UpdateInstallationFailed:v.Status=Dg.InstallationError,e(v);break;case lf.UpdateFileCheckFailed:v.Status=Dg.IncompatiblePackage,e(v);break;case lf.UpdateDownloaded:f.Percentage=100,f.PercentageTotal=u?Math.round(r.UpdateProgressInPercentage*m):Math.round(r.UpdateProgressInPercentage),f.SpeedMbps=0,f.CurrentTask=Ng.CheckingUpdate,t(f),f.CurrentTask=Ng.UpdateDownloadedAndChecked,t(f)}};let S=null;const A=t=>vf(this,void 0,void 0,(function*(){t==ct.Connected&&(clearInterval(S),p.Status=Dg.Upgraded,p.Percentage=100,p.PercentageTotal=100,e(p),clearInterval(S),yield oe.Delay(5e3),n(ue.OK),gy.Get(Tt.ServiceName).OnAppStateChanged().Unsubscribe(A))}));yield this._connection.SendAndHandleResponseAsync(new Ef,1e5,(s=>{var o,i,a,c,g;switch(s.Status){case ue.MultiDataResponseStart:y||(l=(null===(o=s.Data)||void 0===o?void 0:o.UpdateStep)==lf.UpdateDownloaded?100:50,y=!0),w(s);break;case ue.MultiDataResponse:w(s);break;case ue.MultiDataResponseStop:switch(null===(i=s.Data)||void 0===i?void 0:i.UpdateStep){case lf.UpdateInstallationFailed:v.Status=Dg.InstallationError,e(v),p.Percentage=0,p.PercentageTotal=0,e(p),n(new Ne(Gg.CannotProcessUpdate,"Update installation failed!"));break;case lf.InstallerFileSignCheckFailed:case lf.UpdateFileSignCheckFailed:case lf.UpdateDownloadFailed:case lf.UpdateFileCheckFailed:v.Status=Dg.DownloadingFailure,e(v),p.Percentage=0,p.PercentageTotal=0,e(p),n(new Ne(Gg.UpdateDownloadFailed,"Update download failed!"));break;case lf.OfflineUpdateStep:w(s),p.Percentage=Math.round(s.Data.StepProgressInPercentage),p.PercentageTotal=Math.round(s.Data.UpdateProgressInPercentage);let r=(100-p.PercentageTotal)/100,o=p.PercentageTotal;S=setInterval((()=>{h++,o+=r,o>100&&(o=100),h>=l?(p.Status=Dg.Upgraded,p.Percentage=100,p.PercentageTotal=100,e(p),clearInterval(S),n(ue.OK)):(p.Status=Dg.Upgrading,p.Percentage=Math.round(h),p.PercentageTotal=Math.round(o),e(p))}),d/(l-h)),gy.Get(Tt.ServiceName).OnAppStateChanged().Subscribe(A);break;case lf.UpdateDownloaded:f.Percentage=100,f.PercentageTotal=u?Math.round((null===(a=s.Data)||void 0===a?void 0:a.UpdateProgressInPercentage)*m):Math.round(null===(c=s.Data)||void 0===c?void 0:c.UpdateProgressInPercentage),f.SpeedMbps=0,f.CurrentTask=Ng.CheckingUpdate,t(f),f.CurrentTask=Ng.UpdateDownloadedAndChecked,t(f),u&&n(ue.OK);break;default:w(s),n(new Ne(Gg.CannotProcessUpdate,`Update installation failed, received UpdateStep code: ${null===(g=s.Data)||void 0===g?void 0:g.UpdateStep}!`))}break;default:r(new Ne(Gg.CannotGetUpdates,`Cannot get pending update progress, response is empty or status is not OK. Status: ${null==s?void 0:s.Status}`))}}),!0)}))))}))}CheckDevicesUpdatesAvailabilityAsync(){return vf(this,void 0,void 0,(function*(){const e=gy.Get(Qe.ServiceName).User;if(null==e)return[];if(""==e.SoftwareVersion||null==e.SoftwareVersion)return[];const[t,n]=e.SoftwareVersion.split(".");if(parseFloat(t)<6||6==parseFloat(t)&&parseFloat(n)<=4)return[];const r=yield this._connection.SendAndWaitForResponseAsync(new xf,1e4,!1),s=[];return null==r||(null==r?void 0:r.Status)!=ue.OK||null==(null==r?void 0:r.Data)?[]:(null==r||r.Data.forEach((e=>{if(!e.IsAvailable)return;const t=new Zg;t.DeviceGuid=e.DeviceGuid,t.CurrentVersion=e.CurrentVersion,t.NewVersion=e.NewVersion,s.push(t)})),s)}))}CheckControllerUpdatesAsync(){return vf(this,void 0,void 0,(function*(){this._controllerUpdates=[];let e=[];const t=new ef,n=yield this.getRuntimeInfoAsync();if(n instanceof Ne){const e=new mf;return e.UpdateType=Tg.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(Us.Controller)}catch(e){if(!(e instanceof Vs))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 mf;s.ResponseResult=r,s.UpdateType=Tg.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 wf;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=Tg.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:Tg.RadioUpdate}))}}let o=!0;if((r<this._oldUpdateVersion||r===this._oldUpdateVersion&&s<=this._oldUpdateBuild)&&(o=!1),o){const e=yield this._connection.SendAndWaitForResponseAsync(new bf,15e3,!1);if(null==e||e.Status!=ue.OK&&e.Status!=ue.NoData)throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==e?void 0:e.Status}`);if(null!=e.Data){const r=new $s;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 wf;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=Tg.SoftwareUpdate,s.UpdateIdentifier=e.Data.Update.Guid,s.UpdateIsDownloading=e.Data.UpdateStep==lf.DownloadingInstaller||e.Data.UpdateStep==lf.DownloadingUpdate||e.Data.UpdateStep==lf.CheckingUpdate,s.DownloadProgress=e.Data.DownloadProgress,s.UpdateCreationTime=e.Data.Update.Creationtime,s.IsDownloadOnly=e.Data.DownloadOnly,t.UpdatesAvailable.push(s),this._controllerUpdates.push(Object.assign(Object.assign({},r),{UpdateIdentifier:s.UpdateIdentifier,ProviderName:yf.ServiceName,UpdateType:Tg.SoftwareUpdate}))}else{const e=yield this._connection.SendAndWaitForResponseAsync(new Nf,15e3,!1);if(null==e)throw new Error("Cannot check updates! Response is empty.");switch(e.Status){case ue.NoData:const r=new mf;r.UpdateType=Tg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ne(Gg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(r);break;case ue.OK:if(null==e.Data)throw new Error("Cannot check updates! Response data is empty.");const s=new $s;s.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,s.UpdateDescription=ie(e.Data.UpdateDescription),s.UpdatedResourceName=ie(e.Data.UpdateName).get("en-US");const o=new wf;o.UpdatedResourceName=ie(e.Data.UpdateName),o.UpdateDescription=ie(e.Data.UpdateDescription),o.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,o.UpdateType=Tg.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:yf.ServiceName,UpdateType:Tg.SoftwareUpdate}));break;default:throw new Error(`Cannot check updates! Response status is not OK. Status: ${e.Status}`)}}}else{const e=`https://exalus-updates.tr7.pl/software/${n.UpdateChannel}/${n.RuntimeVersion}/${n.SoftwareVersion}/update.json`;try{const r=yield fetch(e);let s,o=new $s;const i=new mf;switch(i.UpdateType=Tg.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 Ne(Gg.DeviceIsUpToDate,"Updates not found, controller is already up-to-date."),t.UpdatesNotAvailable.push(i);break;default:i.ResponseResult=new Ne(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 wf;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=Tg.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:yf.ServiceName,UpdateType:Tg.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 Ne){const e=new mf;e.UpdateType=Tg.SoftwareUpdate,e.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),e.ResponseResult=n,t.UpdatesNotAvailable.push(e)}else{const r=new mf;r.UpdateType=Tg.SoftwareUpdate,r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.ResponseResult=new Ne(Gg.CannotGetUpdates,`Cannot get available updates! ${e}`),r.CurrentResourceVersion=`${n.RuntimeVersion}.${n.SoftwareVersion}`,t.UpdatesNotAvailable.push(r)}}}return t}))}CheckControllerVersionAsync(){return vf(this,void 0,void 0,(function*(){const e=yield this._updateProviders.GetUpdatesProvidersAsync(Us.Controller),t=yield this.getRuntimeInfoAsync();if(t instanceof Ne)return t;const n=[];let r;r=new nf,r.Resource="Controller software",r.Type=Tg.SoftwareUpdate,r.Version=`${t.RuntimeVersion}.${t.SoftwareVersion}`,n.push(r);for(let t=0;t<e.length;t++){r=new nf,r.Version=yield e[t].GetCurrentRadioVersionAsync(),r.Type=Tg.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 vf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ne)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ne(Gg.FeatureUnsupportedInCurrentVersion,`Cannot get update branch, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Df,1e4,!1);if(null==r||(null==r?void 0:r.Status)!=ue.OK)return new Ne(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 Rg.Public;case 1:return Rg.Beta;case 2:return Rg.Development;default:return new Ne(Gg.CannotGetUpdatesBranch,`Cannot get update branch, unknown branch number. Branch number: ${r.Data}`)}}))}SetControllerUpdateBranchAsync(e){return vf(this,void 0,void 0,(function*(){const t=yield this.getRuntimeInfoAsync();if(t instanceof Ne)return t;const n=parseInt(t.SoftwareVersion.toString().split(".")[0]),r=parseInt(t.SoftwareVersion.toString().split(".")[1]);if(n<this._oldUpdateVersion||n===this._oldUpdateVersion&&r<=this._oldUpdateBuild)return new Ne(Gg.FeatureUnsupportedInCurrentVersion,`Cannot set update branch, feature unsupported in current version. Current version: ${t}`);const s=yield this._connection.SendAndWaitForResponseAsync(new kf(e),1e4,!1);return null==s||(null==s?void 0:s.Status)!=ue.OK?new Ne(Gg.CannotSetUpdatesBranch,`Cannot set update branch, response is empty or status is not OK. Status: ${null==s?void 0:s.Status}`):ue.OK}))}EnableAutomaticControllerUpdateDownloadAsync(){return vf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ne)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ne(Gg.FeatureUnsupportedInCurrentVersion,`Cannot enable automatic updates download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Uf,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ue.OK?new Ne(Gg.CannotSetUpdatesBranch,`Cannot enable automatic updates download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ue.OK}))}DisableAutomaticControllerUpdateDownloadAsync(){return vf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ne)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ne(Gg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Of,1e4,!1);return null==r||(null==r?void 0:r.Status)!=ue.OK?new Ne(Gg.CannotSetUpdatesBranch,`Cannot disable automatic update download, response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`):ue.OK}))}GetControllerUpdatesHistoryAsync(){return vf(this,void 0,void 0,(function*(){const e=yield this.getRuntimeInfoAsync();if(e instanceof Ne)return e;const t=parseInt(e.SoftwareVersion.toString().split(".")[0]),n=parseInt(e.SoftwareVersion.toString().split(".")[1]);if(t<this._oldUpdateVersion||t===this._oldUpdateVersion&&n<=this._oldUpdateBuild)return new Ne(Gg.FeatureUnsupportedInCurrentVersion,`Cannot disable automatic update download, feature unsupported in current version. Current version: ${e}`);const r=yield this._connection.SendAndWaitForResponseAsync(new Mf,1e4,!1);if(null==r)return new Ne(Gg.CannotGetUpdates,"Cannot get updates history, response is empty.");switch(r.Status){case ue.OK:return null!=r.Data?r.Data.map((e=>{const t=new tf;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 Ne(Gg.CannotGetUpdates,"Cannot get updates history, response data is empty.");case ue.NoData:return[];default:return new Ne(Gg.CannotGetUpdates,`Cannot get updates history, response status is not OK. Status: ${r.Status}`)}}))}InstallControllerUpdateAsync(e,t,n,r,s){return vf(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 Ne)return a;const c=parseInt(a.SoftwareVersion.toString().split(".")[0]),u=parseInt(a.SoftwareVersion.toString().split(".")[1]);if(0==this._controllerUpdates.length)return new Ne(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=>vf(this,void 0,void 0,(function*(){return new Promise((t=>setTimeout(t,e)))}));let l=this._controllerUpdates.where((e=>e.UpdateType==Tg.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==ue.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==Tg.SoftwareUpdate));if(null!=h)if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){const e=yield this.UpdateControllerUsingScriptAsync(h.Update,o);e==ue.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==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),d.push(e),s[0]++}const p=d.where((e=>e instanceof Ne)).toArray();if(null!=p&&0!=p.length){let e="";return p.forEach((t=>e+=`${t.Type}, `)),this._appStateService.AllowHibernation(),p.any((e=>e.Type==Gg.UpdateDownloadFailed))?new Ne(Gg.UpdateDownloadFailed,`Update download failed - not all updates were successfully downloaded. Installation error codes: ${e}`):new Ne(Gg.UpdatesPartiallyInstalled,`Update installation finished - not all updates were successfully installed. Installation error codes: ${e}`)}return this._appStateService.AllowHibernation(),ue.OK}{let o;const i=this._controllerUpdates.find((e=>e.UpdateIdentifier==n));if(null==i)return new Ne(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 Tg.RadioUpdate:return r?new Ne(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==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n))),o);case Tg.SoftwareUpdate:if(c<this._oldUpdateVersion||c===this._oldUpdateVersion&&u<=this._oldUpdateBuild){if(r)return new Ne(Gg.UpdateAlreadyDownloaded,"Update already downloaded set flag downloadOnly to false to install it.");o=yield this.UpdateControllerUsingScriptAsync(i.Update,e),this._appStateService.AllowHibernation(),o==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}else{let s=(yield this.CheckControllerUpdatesAsync()).UpdatesAvailable.any((e=>e.IsDownloadOnly));o=yield this.UpdateControllerUsingApiAsync(e,t,!s&&r),this._appStateService.AllowHibernation(),o==ue.OK&&(this._controllerUpdates=this._controllerUpdates.filter((e=>e.UpdateIdentifier!=n)))}return o;default:return new Ne(Gg.CannotProcessUpdate,`Update with type ${i.UpdateType} is not supported by UpdateService.`)}}}))}UpdateControllerUsingScriptAsync(e,t){return vf(this,void 0,void 0,(function*(){var n,r,s,o,i,a;switch(e.UpdateType){case Os.Container:case Os.ContainerSoftware:try{return yield null===(n=this._connection)||void 0===n?void 0:n.SendAndHandleResponseAsync(new Af(e.DownloadUri),this._updateRequestTimeout,(n=>{const r=new rf;switch(r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Status){case ue.MultiDataResponseStart:r.Status=Dg.PreparingForUpgrade;break;case ue.MultiDataResponse:if(null==n.Data)return void this._logger.Warning(yf.ServiceName,`Recived update response without data! URI: ${e.DownloadUri}`);switch(r.Percentage=Math.round(n.Data.Progress),n.Data.State){case kg.CheckingApplicability:case kg.CheckingIntegrity:case kg.CheckingPackageIntegrity:r.Status=Dg.CheckingPackage;break;case kg.CreatingBackup:case kg.MigratingData:case kg.Removing:r.Status=Dg.MovingData;break;case kg.Deploying:case kg.Installing:r.Status=Dg.Upgrading;break;case kg.Downloading:r.Status=Dg.DownloadingPackage;break;case kg.Error:r.Status=Dg.Error;break;case kg.Installed:r.Status=Dg.Upgraded;break;case kg.PreparingSystem:case kg.ReadyToDownload:r.Status=Dg.PreparingForUpgrade;break;case kg.UndoingInstallation:r.Status=Dg.InstallationStopped;break;case kg.Unpackaging:r.Status=Dg.MovingData;break;case kg.WaitingForUser:r.Status=Dg.Upgrading}break;case ue.MultiDataResponseStop:r.Status=Dg.OK;break;case ue.Error:case ue.FatalError:r.Status=Dg.Error}t(r)}),!1),ue.OK}catch(e){return new Ne(Gg.CannotProcessUpdate,`Cannot process update, error: ${e}`)}case Os.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 Ne)return h;var l=parseFloat(h.RuntimeVersion)>=2||parseFloat(u)>=1.2201125;try{c=(yield gy.Get(Zo.ServiceName).GetDevicesAsync()).length}catch(e){this._logger.Warning(yf.ServiceName,`Cannot get number of devices in system! Error: ${e}. Using default value of 10 devices.`)}if(l){let n,r=new rf;r.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),r.Percentage=1,r.Status=Dg.PreparingForUpgrade,t(r);let s=2;const o=Date.now(),i=900*c+16e5,a=i/100,u=o+i,l=new Promise(((o,c)=>vf(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=Dg.Upgraded,t(r),o(ue.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=Dg.Upgraded,t(r),o(ue.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=Dg.Upgraded,t(r),o(ue.OK);else{var e=s;e<99&&(r.Percentage=Math.round(e),r.PercentageTotal=Math.round(r.Percentage),r.Status=Dg.Upgrading,t(r))}s++}),a);const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new _f(e.DownloadUri),this._updateRequestTimeout,!1);d.Status!=ue.OK&&(clearInterval(n),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Dg.InstallationError,t(r),this._logger.Debug(yf.ServiceName,`Update failed with error. Update response status: ${d.Status}`),o(new Ne(Gg.CannotProcessUpdate,`Update failed with error. Update response status: ${d.Status}`)))}catch(e){this._logger.Debug(yf.ServiceName,`Update failed with error. ${e}`),r.Percentage=0,r.PercentageTotal=Math.round(r.Percentage),r.Status=Dg.Error,t(r),clearInterval(n),o(new Ne(Gg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}{let n=new rf;n.UpdatedResourceName=new Map([["pl-PL","Oprogramowanie kontrolera"],["en-US","Controller software"]]),n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Dg.PreparingForUpgrade,t(n);const u=this._connection.GetAuthorizationInfo();if(null==u)return new Ne(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 Cf({Email:"support@support",Password:`support@${u.SerialNumber}:${u.PIN}`}),12e3,!1)).Status===ue.OK){n.Percentage=1,n.PercentageTotal=Math.round(n.Percentage),n.Status=Dg.PreparingForUpgrade,t(n);let r=yield null===(s=this._connection)||void 0===s?void 0:s.SendAndWaitForResponseAsync(new Tf("rm /runtime/tmp/update.sh"),12e3,!1);if(r.Status==ue.OK){if(this._logger.Debug("Removed previous script"),n.Percentage=2,n.PercentageTotal=Math.round(n.Percentage),n.Status=Dg.PreparingForUpgrade,t(n),r=yield null===(o=this._connection)||void 0===o?void 0:o.SendAndWaitForResponseAsync(new Tf(`wget ${e.DownloadUri} -O /runtime/tmp/update.sh --no-check-certificate`),this._updateRequestTimeout,!1),r.Status==ue.OK){this._logger.Debug("Downloaded update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Dg.PreparingForUpgrade,t(n);try{if(r=yield null===(i=this._connection)||void 0===i?void 0:i.SendAndWaitForResponseAsync(new Tf("chmod a+x /runtime/tmp/update.sh"),12e3,!1),r.Status==ue.OK){this._logger.Debug("Executed update script"),n.Percentage=5,n.PercentageTotal=Math.round(n.Percentage),n.Status=Dg.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)=>vf(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=Dg.Upgraded,t(n),o(ue.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=Dg.Upgraded,t(n),o(ue.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=Dg.Upgraded,t(n),o(ue.OK);else{var i=5+r*s;i<99&&(n.Percentage=Math.round(i),n.PercentageTotal=Math.round(n.Percentage),n.Status=Dg.Upgrading,t(n))}r++}),a),null===(c=this._connection)||void 0===c||c.SendAndWaitForResponseAsync(new Tf("/runtime/tmp/update.sh"),12e3,!1)}catch(e){o(new Ne(Gg.CannotProcessUpdate,`Update failed with error. ${e}`))}}))));return yield l}return n.Percentage=0,n.PercentageTotal=Math.round(n.Percentage),n.Status=Dg.InstallationError,t(n),new Ne(Gg.CannotProcessUpdate,"Execution failed!")}catch(e){return null===(a=this._connection)||void 0===a||a.SendAndWaitForResponseAsync(new Tf("/runtime/scripts/restart_all.sh"),12e3,!1),new Ne(Gg.CannotProcessUpdate,`Execution failed! Error ${e}`)}}return new Ne(Gg.CannotProcessUpdate,"Execution failed! Cannot clear old update script!")}}return new Ne(Gg.CannotProcessUpdate,"Execution failed! Cannot loggin using support account!")}default:return new Ne(Gg.CannotProcessUpdate,`Not supported update type, type: ${e.UpdateType}`)}}))}DownloadControllerUpdateNewApiAsync(e,t,n,r){return vf(this,void 0,void 0,(function*(){return new Promise(((t,s)=>vf(this,void 0,void 0,(function*(){let s=50;r||(s=100);let o=100/s;yield this._connection.SendAndHandleResponseAsync(new Gf,this._updateRequestTimeout,(s=>{var i,a,c,u,l,d;const h=new sf;switch(h.DownloadOnly=r,h.UpdatedResourceName=ie(e.Update.UpdateName),s.Status){case ue.MultiDataResponseStart:h.Percentage=0,h.SpeedMbps=0,h.PercentageTotal=0,h.CurrentTask=Ng.DownloadingInstaller,n(h);break;case ue.MultiDataResponse:if(null!=s.Data){switch(h.Percentage=s.Data.StepProgressInPercentage,h.SpeedMbps=s.Data.DownloadSpeedInMbs,h.PercentageTotal=r?Math.round((null===(i=s.Data)||void 0===i?void 0:i.UpdateProgressInPercentage)*o):Math.round(null===(a=s.Data)||void 0===a?void 0:a.UpdateProgressInPercentage),s.Data.UpdateStep){case lf.DownloadingInstaller:h.CurrentTask=Ng.DownloadingInstaller;break;case lf.DownloadingUpdate:h.CurrentTask=Ng.DownloadingUpdate;break;case lf.UpdateDownloaded:h.Percentage=100,h.PercentageTotal=r?Math.round((null===(c=s.Data)||void 0===c?void 0:c.UpdateProgressInPercentage)*o):Math.round(null===(u=s.Data)||void 0===u?void 0:u.UpdateProgressInPercentage),h.SpeedMbps=0,h.CurrentTask=Ng.CheckingUpdate,n(h),h.CurrentTask=Ng.UpdateDownloadedAndChecked,n(h),t(ue.OK);break;default:h.CurrentTask=Ng.CheckingUpdate}n(h)}break;case ue.MultiDataResponseStop:if(null!=s.Data)switch(s.Data.UpdateStep){case lf.UpdateDownloaded:h.Percentage=100,h.PercentageTotal=r?Math.round((null===(l=s.Data)||void 0===l?void 0:l.UpdateProgressInPercentage)*o):Math.round(null===(d=s.Data)||void 0===d?void 0:d.UpdateProgressInPercentage),h.SpeedMbps=0,h.CurrentTask=Ng.CheckingUpdate,n(h),h.CurrentTask=Ng.UpdateDownloadedAndChecked,n(h),t(ue.OK);break;case lf.UpdateDownloadFailed:h.Percentage=0,h.PercentageTotal=0,h.SpeedMbps=0,h.CurrentTask=Ng.Unknown,n(h),t(new Ne(Gg.UpdateDownloadFailed,"Update download failed!"))}break;case ue.Error:case ue.FatalError:h.Percentage=0,h.PercentageTotal=0,h.SpeedMbps=0,h.CurrentTask=Ng.Unknown,n(h),t(new Ne(Gg.CannotProcessUpdate,"Update download failed!"))}}),!1)}))))}))}InstallUpdateNewApiAsync(e,t,n,r){return vf(this,void 0,void 0,(function*(){return new Promise(((n,r)=>vf(this,void 0,void 0,(function*(){const r=60*this._updateOfflineStageTime*1e3;let s=0;const o=new rf;let i=null;e.DownloadOnly=!1;const a=e=>vf(this,void 0,void 0,(function*(){e==ct.Connected&&(clearInterval(i),o.Status=Dg.Upgraded,o.Percentage=100,o.PercentageTotal=100,t(o),clearInterval(i),yield oe.Delay(5e3),n(ue.OK),gy.Get(Tt.ServiceName).OnAppStateChanged().Unsubscribe(a))}));yield this._connection.SendAndHandleResponseAsync(new Rf,this._updateRequestTimeout,(c=>{var u,l;switch(o.UpdatedResourceName=ie(e.Update.UpdateName),c.Status){case ue.MultiDataResponseStart:o.Status=Dg.PreparingForUpgrade,o.Percentage=null===(u=c.Data)||void 0===u?void 0:u.StepProgressInPercentage,o.PercentageTotal=null===(l=c.Data)||void 0===l?void 0:l.UpdateProgressInPercentage,t(o);break;case ue.MultiDataResponse:null!=c.Data&&(o.Status=Dg.Upgrading,o.Percentage=Math.round(c.Data.StepProgressInPercentage),o.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage),s=c.Data.StepProgressInPercentage,t(o));break;case ue.MultiDataResponseStop:if(null!=c.Data)switch(c.Data.UpdateStep){case lf.UpdateInstallationFailed:o.Status=Dg.InstallationError,o.Percentage=0,o.PercentageTotal=0,t(o),n(new Ne(Gg.CannotProcessUpdate,"Update installation failed!"));break;case lf.OfflineUpdateStep:{o.Percentage=Math.round(c.Data.StepProgressInPercentage),o.PercentageTotal=Math.round(c.Data.UpdateProgressInPercentage);let e=(100-o.PercentageTotal)/100,u=o.PercentageTotal;i=setInterval((()=>{s++,u+=e,u>100&&(u=100),s>=100?(o.Status=Dg.Upgraded,o.Percentage=100,o.PercentageTotal=100,t(o),clearInterval(i),n(ue.OK)):(o.Status=Dg.Upgrading,o.Percentage=Math.round(s),o.PercentageTotal=Math.round(u),t(o))}),r/(100-s)),gy.Get(Tt.ServiceName).OnAppStateChanged().Subscribe(a)}}break;case ue.Error:case ue.FatalError:o.Status=Dg.Error,o.Percentage=0,o.PercentageTotal=0,t(o),n(new Ne(Gg.CannotProcessUpdate,"Update installation failed!"))}}),!1)}))))}))}InstallControllerUpdateUsingApiAsync(e,t){return vf(this,void 0,void 0,(function*(){const n=yield this._connection.SendAndWaitForResponseAsync(new bf,1e4,!1);if((null==n?void 0:n.Status)==ue.NoData)return new Ne(Gg.DeviceIsUpToDate,"No updates available!");if(null==n||(null==n?void 0:n.Status)!=ue.OK||null==(null==n?void 0:n.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==n?void 0:n.Status}`);switch(n.Data.UpdateStep){case lf.DownloadingInstaller:case lf.DownloadingUpdate:return new Ne(Gg.UpdateAlreadyDownloaded,"Update already downloaded, or download in progress.");case lf.InstallingUpdate:case lf.PreparingUpdate:return new Ne(Gg.UpdateAlreadyInstalled,"Update already installed, or installation in progress.");case lf.UpdateDownloaded:return n.Data.DownloadOnly=!1,yield this.InstallUpdateNewApiAsync(n.Data,e,t,!1);default:this._logger.Debug(yf.ServiceName,`Installing update using new API. Update step: ${n.Data.UpdateStep} downloadOnly: false`),n.Data.DownloadOnly=!1;var r=yield this.DownloadControllerUpdateNewApiAsync(n.Data,e,t,!1);return r!=ue.OK?r:yield this.InstallUpdateNewApiAsync(n.Data,e,t,!1)}}))}DownloadControllerUpdateUsingApiAsync(e,t,n){return vf(this,void 0,void 0,(function*(){const r=yield this._connection.SendAndWaitForResponseAsync(new bf,1e4,!1);if((null==r?void 0:r.Status)==ue.NoData)return new Ne(Gg.DeviceIsUpToDate,"No updates available!");if(null==r||(null==r?void 0:r.Status)!=ue.OK||null==(null==r?void 0:r.Data))throw new Error(`Cannot get pending updates! Response is empty or status is not OK. Status: ${null==r?void 0:r.Status}`);switch(r.Data.UpdateStep){case lf.DownloadingInstaller:case lf.DownloadingUpdate:case lf.UpdateDownloaded:return new Ne(Gg.UpdateAlreadyDownloaded,"Update already downloaded, or download is in progress.");case lf.InstallingUpdate:case lf.PreparingUpdate:return new Ne(Gg.UpdateAlreadyInstalled,"Update already installed, or installation is in progress.");default:return yield this.DownloadControllerUpdateNewApiAsync(r.Data,e,t,n)}}))}UpdateControllerUsingApiAsync(e,t,n){return vf(this,void 0,void 0,(function*(){return n?yield this.DownloadControllerUpdateUsingApiAsync(e,t,!0):yield this.InstallControllerUpdateUsingApiAsync(e,t)}))}getRuntimeInfoAsync(){return vf(this,void 0,void 0,(function*(){try{return yield this._updateProviders.GetSoftwareRuntimeInfoAsync()}catch(e){return e instanceof fo&&e.code==qs.Timeout?new Ne(Gg.CannotGetCurrentControllerVersionTimeout,"Cannot get runtime info (current controller version), timeout error - please restart controller to fix issue."):new Ne(Gg.CannotGetCurrentControllerVersion,`Cannot get runtime info (current controller version), error: ${e}`)}}))}}yf.ServiceName="UpdatesService";class mf{constructor(){this.UpdatedResourceName=new Map,this.CurrentResourceVersion="",this.UpdateType=null,this.ResponseResult=null}}class wf{constructor(){this._updateIdentifier="",this._updateResourceName=new Map,this._updateType=null,this._currentResourceVersion="",this._newResourceVersion="",this._updateDescription=new Map,this._updateIsDownloading=!1,this._updateCheckDownloadProgress=0,this._updateCreationTime=null,this._isDownloadOnly=!1}get IsDownloadOnly(){return this._isDownloadOnly}set IsDownloadOnly(e){this._isDownloadOnly=e}get UpdateCreationTime(){return this._updateCreationTime}get DownloadProgress(){return this._updateCheckDownloadProgress}get UpdateDescription(){return this._updateDescription}get UpdateIdentifier(){return this._updateIdentifier}get UpdatedResourceName(){return this._updateResourceName}get UpdateType(){return this._updateType}get CurrentResourceVersion(){return this._currentResourceVersion}get NewResourceVersion(){return this._newResourceVersion}get UpdateIsDownloading(){return this._updateIsDownloading}set UpdateCreationTime(e){this._updateCreationTime=e}set DownloadProgress(e){this._updateCheckDownloadProgress=e}set UpdateDescription(e){this._updateDescription=e}set UpdateIdentifier(e){this._updateIdentifier=e}set UpdatedResourceName(e){this._updateResourceName=e}set UpdateType(e){this._updateType=e}set CurrentResourceVersion(e){this._currentResourceVersion=e}set NewResourceVersion(e){this._newResourceVersion=e}set UpdateIsDownloading(e){this._updateIsDownloading=e}}class Sf{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 Af extends ce{constructor(e){super(),this.Resource="/updates/update/from/uri",this.Method=le.Post,this.Data=e}}!function(e){e[e.Windows=0]="Windows",e[e.Linux=1]="Linux",e[e.Unix=2]="Unix",e[e.OSX=3]="OSX",e[e.Android=4]="Android",e[e.iOS=5]="iOS",e[e.WindowsMobile=6]="WindowsMobile"}(af||(af={})),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"}(cf||(cf={})),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"}(uf||(uf={})),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"}(lf||(lf={}));class _f extends ce{constructor(e){super(),this.Resource="/updates/install/from/url",this.Method=le.Put,this.Data=e}}class Cf extends ce{constructor(e){super(),this.Resource="/users/user/login",this.Method=le.Put,this.Data=e}}class Tf extends ce{constructor(e){super(),this.Resource="/controller/runtime/execute",this.Method=le.Post,this.Data=e}}class Df extends ce{constructor(){super(),this.Resource="/updates/branch",this.Method=le.Get}}class kf extends ce{constructor(e){super(),this.Resource="/updates/branch",this.Method=le.Put,this.Data=e}}class If extends ce{constructor(){super(),this.Resource="/updates/failed/cancel",this.Method=le.Put}}class Ef extends ce{constructor(){super(),this.Resource="/updates/pending/progress",this.Method=le.Get}}class bf extends ce{constructor(){super(),this.Resource="/updates/pending",this.Method=le.Get}}class Nf extends ce{constructor(){super(),this.Resource="/updates/check",this.Method=le.Get}}class Gf extends ce{constructor(){super(),this.Resource="/updates/download",this.Method=le.Post}}class Rf extends ce{constructor(){super(),this.Resource="/updates/install",this.Method=le.Post}}class Pf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/status",this.Method=le.Get}}class Uf extends ce{constructor(){super(),this.Resource="/updates/download/automatic/enable",this.Method=le.Put}}class Of extends ce{constructor(){super(),this.Resource="/updates/download/automatic/disable",this.Method=le.Put}}class Mf extends ce{constructor(){super(),this.Resource="/updates/history",this.Method=le.Get}}class xf extends ce{constructor(){super(),this.Resource="/updates/devices/availability",this.Method=le.Get}}!function(e){e.CannotFindDevice="CannotFindDevice",e.ResponseTypeNotSupported="ResponseTypeNotSupported",e.InvalidChannelNumber="InvalidChannelNumber",e.IncorrectLimitValue="IncorrectLimitValue",e.IncorrectOffsetValue="IncorrectOffsetValue",e.OtherError="OtherError",e.FatalError="FatalError",e.NoData="NoData",e.FunctionalityNotSupported="FunctionalityNotSupported"}(df||(df={})),function(e){e[e.None=0]="None",e[e.DataRange=1]="DataRange",e[e.Hour=2]="Hour",e[e.Day=3]="Day",e[e.Week=4]="Week",e[e.Month=5]="Month",e[e.Year=6]="Year",e[e.ThisHour=7]="ThisHour",e[e.ThisDay=8]="ThisDay",e[e.ThisWeek=9]="ThisWeek",e[e.ThisMonth=10]="ThisMonth",e[e.ThisYear=11]="ThisYear"}(hf||(hf={})),function(e){e[e.Day=0]="Day",e[e.Week=1]="Week",e[e.Month=2]="Month",e[e.Year=3]="Year",e[e.Hour=4]="Hour"}(pf||(pf={})),function(e){e.Min="Min",e.Max="Max",e.Avg="Avg"}(gf||(gf={}));class Ff{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"}(ff||(ff={}));var Lf,Bf,Wf,$f,Vf,qf,Hf,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 jf{constructor(){this.DELIM=";",this._connection=null,this._connection=gy.Get(bt.ServiceName)}numToCsv(e){const t="string"==typeof e?Number(e.replace(",",".")):e;return Number.isFinite(t)?t.toLocaleString("en-US",{useGrouping:!1}):""}quoteIfNeeded(e){return e.includes(this.DELIM)||e.includes('"')?`"${e.replace(/"/g,'""')}"`:e}ExportPressureToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`PressureHistory_${e.Name}_${t}.csv`)}ExportBrightnessToCsv(e,t,n){var r;if(!(null===(r=null==n?void 0:n.Data)||void 0===r?void 0:r.length))return;const s=[],o=(n.Data[0],["Time","AggregatedBy"]);o.push("LuxValue","LuxToLinearScale","LightCondition"),s.push(o.join(this.DELIM)),n.Data.forEach((e=>{var t,n,r;const o=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null!==e.Values&&(o.push(this.numToCsv(null===(t=e.Values)||void 0===t?void 0:t.LuxValue)),o.push(this.numToCsv(null===(n=e.Values)||void 0===n?void 0:n.LuxToLinearScale)),o.push(this.numToCsv(null===(r=e.Values)||void 0===r?void 0:r.LightCondition))),s.push(o.join(this.DELIM))})),ae(s.join("\n"),`BrightnessHistory_${e.Name}_${t}.csv`)}ExportHumidityToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`HumidityHistory_${e.Name}_${t}.csv`)}ExportWindSpeedToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`WindSpeedHistory_${e.Name}_${t}.csv`)}ExportTemperatureToCsv(e,t,n){ae(this.ExportAveragingStateValuesToCsv(e,t,n),`TemperatureHistory_${e.Name}_${t}.csv`)}ExportAveragingStateValuesToCsv(e,t,n){var r;if(!(null===(r=null==n?void 0:n.Data)||void 0===r?void 0:r.length))return"";const s=[],o=(n.Data[0],["Time","AggregatedBy"]);return o.push("LastValue","Average","Mode","Min","Max"),s.push(o.join(this.DELIM)),n.Data.forEach((e=>{var t,n,r,o,i;const a=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null!==e.Values&&(a.push(this.numToCsv(null===(t=e.Values)||void 0===t?void 0:t.LastValue)),a.push(this.numToCsv(null===(n=e.Values)||void 0===n?void 0:n.Average)),a.push(this.numToCsv(null===(r=e.Values)||void 0===r?void 0:r.Mode)),a.push(this.numToCsv(null===(o=e.Values)||void 0===o?void 0:o.Min)),a.push(this.numToCsv(null===(i=e.Values)||void 0===i?void 0:i.Max))),s.push(a.join(this.DELIM))})),s.join("\n")}ExportEnergyToCsv(e,t,n){var r,s;let o=n.Data;if(!(null==o?void 0:o.length))return;const i=[],a=o[0],c=["Time","AggregatedBy"];null===(r=a.Values)||void 0===r||r.MeasurementAveragingParameters.forEach(((e,t)=>{c.push(`${t}:LastValue`,`${t}:Average`,`${t}:Mode`,`${t}:Min`,`${t}:Max`)})),null===(s=a.Values)||void 0===s||s.MeasurementNonAveragingParmeters.forEach(((e,t)=>c.push(`${t}`))),i.push(c.join(this.DELIM)),o.forEach((e=>{var t,n;const r=[this.quoteIfNeeded(e.Time),this.quoteIfNeeded(e.AggregatedBy)];null===(t=e.Values)||void 0===t||t.MeasurementAveragingParameters.forEach((e=>{r.push(this.numToCsv(e.LastValue),this.numToCsv(e.Average),this.numToCsv(e.Mode),this.numToCsv(e.Min),this.numToCsv(e.Max))})),null===(n=e.Values)||void 0===n||n.MeasurementNonAveragingParmeters.forEach((e=>r.push(this.numToCsv(e)))),i.push(r.join(this.DELIM))})),ae(i.join("\n"),`EnergyHistory_${e.Name}_${t}.csv`)}GetStatesByTimeRangeAsync(e,t,n,r,s,o,i){return Kf(this,arguments,void 0,(function*(e,t,n,r,s,o,i,a=!1){var c;try{if(!(yield this.DoesSupportPreciseTimeFramesAsync()))return new Ne(df.FunctionalityNotSupported,"State history data in time range is not supported with this version of controller software, update software to get this functionality.");let u;if("string"==typeof e){const t=yield gy.Get(Zo.ServiceName).GetDevice(e);if(null==t)return new Ne(df.CannotFindDevice,`Device with specified GUID ${e} does not exist.`);u=t}else u=e;if(!u.Channels.any((e=>e.Number===t)))return new Ne(df.InvalidChannelNumber,`Given channel not found in device with guid: ${u.Guid}.`);if(!u.Channels.any((e=>e.Number===t&&e.AvailableResponseTypes.any((e=>e.Type===n)))))return new Ne(df.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const l=new Yf;l.DeviceGuid=u.Guid,l.DeviceChannel=t,l.StateInterfaceType=n,l.ReverseOrder=a,l.DataRange=r,l.Time=s,l.Limit=o,l.Offset=i;const d=yield null===(c=this._connection)||void 0===c?void 0:c.SendAndWaitForResponseAsync(new Xf(l),3e4,!1);if(null==d)return new Ne(df.OtherError,"Cannot get state history data - response is null.");switch(d.Status){case ue.WrongData:switch(d.Data){case"IncorrectLimitValue":return new Ne(df.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ne(df.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ne(df.OtherError,"Cannot get state history data - some parameters are incorrect!");case"UnsupportedRange":return new Ne(df.OtherError,"Cannot get state history data - time range is incorrect!");default:return new Ne(df.OtherError,"Cannot get state history data - unknown error!")}case ue.FatalError:return new Ne(df.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ue.ResourceDoesNotExists:return new Ne(df.ResponseTypeNotSupported,`Device or channel not supporting requested DeviceResponseType or device/channel does not exist. ${d.Data}`);case ue.OK:if(null==d.Data)return new Ne(df.NoData,"Controller responded with status OK, but response does not contain data!");if(d.Data.AggregateDataList=d.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===Ot.MeasuredEnergy){const e=d.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return d.Data.Data=e,d.Data}return d.Data;default:return new Ne(df.OtherError,`Cannot get state history data - controller responded with response code ${d.Status}`)}}catch(e){return new Ne(df.FatalError,`Cannot get state history data - exception occurs! ${e}`)}}))}GetServiceName(){return jf.ServiceName}DoesSupportPreciseTimeFramesAsync(){return Kf(this,void 0,void 0,(function*(){let e=(yield gy.Get(uo.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");return Number(e[0])>6||6===Number(e[0])&&Number(e[1])>=101}))}GetStatesByIntervalAsync(e,t,n,r,s,o){return Kf(this,arguments,void 0,(function*(e,t,n,r,s,o,i=!1){var a;try{if(!(yield this.IsFunctionalitySupportedAsync()))return new Ne(df.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 gy.Get(Zo.ServiceName).GetDevice(e);if(null==t)return new Ne(df.CannotFindDevice,`Device with specified GUID ${e} does not exists.`);c=t}else c=e;if(!c.Channels.any((e=>e.Number==t)))return new Ne(df.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 Ne(df.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");const u=new Jf;u.DeviceGuid=c.Guid,u.DeviceChannel=t,u.StateInterfaceType=n,u.ReverseOrder=i,u.Limit=s,u.Offset=o;let l=(yield gy.Get(uo.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");if(Number(l[0])>6||6===Number(l[0])&&Number(l[1])>=101)switch(r){case hf.ThisHour:u.Range=hf.Hour;break;case hf.ThisDay:u.Range=hf.Day;break;case hf.ThisWeek:u.Range=hf.Week;break;case hf.ThisMonth:u.Range=hf.Month;break;case hf.ThisYear:u.Range=hf.Year}else u.Range=r;const d=yield null===(a=this._connection)||void 0===a?void 0:a.SendAndWaitForResponseAsync(new zf(u),3e4,!1);if(null==d)return new Ne(df.OtherError,"Cannot get state history data - response is null.");switch(d.Status){case ue.WrongData:switch(d.Data){case"IncorrectLimitValue":return new Ne(df.IncorrectLimitValue,"Cannot get state history data - limit value is incorrect!");case"IncorrectOffsetValue":return new Ne(df.IncorrectOffsetValue,"Cannot get state history data - offset value is incorrect!");case"IncorrectArguments":return new Ne(df.OtherError,"Cannot get state history data - some parameters are incorrect!");default:return new Ne(df.OtherError,"Cannot get state history data - unknown error!")}case ue.FatalError:return new Ne(df.FatalError,"Cannot get state history data - an exception occurred in the controller while reading data!");case ue.ResourceDoesNotExists:return new Ne(df.ResponseTypeNotSupported,"Device or channel not supporting requested DeviceResponseType.");case ue.OK:if(null==d.Data)return new Ne(df.NoData,"Controller responede with status OK, but response does not contain data!");if(d.Data.AggregateDataList=d.Data.AggregateDataList.map((e=>(e.AggregateData=ie(e.AggregateData),e))),n===Ot.MeasuredEnergy){const e=d.Data.Data.map((e=>{const t=e;return t.Values.MeasurementAveragingParameters=ie(e.Values.MeasurementAveragingParameters),t.Values.MeasurementNonAveragingParmeters=ie(e.Values.MeasurementNonAveragingParmeters),t}));return d.Data.Data=e,d.Data}return d.Data;default:return new Ne(df.OtherError,`Cannot get state history data - controller responded with response code ${d.Status}`)}}catch(e){return new Ne(df.FatalError,`Cannot get state history data - exeption occurs! ${e}`)}}))}GetAvailableStatesAsync(){return Kf(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Qf,12e3,!1);return null==t?new Ne(df.OtherError,"Cannot get available states - response is null."):t.Status!=ue.OK?new Ne(df.OtherError,`Cannot get available states - controller responded with response code ${t.Status}.`):null==t.Data?new Ne(df.NoData,"Cannot get available states - controller responede with status OK, but response does not contain data!"):t.Data.map((e=>{const t=new Ff;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}))}catch(e){return new Ne(df.FatalError,`Cannot get available states - exeption occurs! ${e}`)}}))}IsFunctionalitySupportedAsync(){return Kf(this,void 0,void 0,(function*(){let e=(yield gy.Get(uo.ServiceName).GetSoftwareRuntimeInfoAsync()).SoftwareVersion.split(".");return Number(e[0])>3||3===Number(e[0])&&Number(e[1])>=42}))}GetAvailableStatesPerChannelAsync(e,t){return Kf(this,void 0,void 0,(function*(){var n;let r;if("string"==typeof e){const t=yield gy.Get(Zo.ServiceName).GetDevice(e);if(null==t)return new Ne(df.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 Zf(new ev(r.Guid,t)),8e3,!1);if(null==s)return new Ne(df.OtherError,"Cannot get available states - response is null.");switch(s.Status){case ue.ResourceDoesNotExists:switch(s.Data){case"DeviceNotFound":return new Ne(df.CannotFindDevice,"Cannot get available states - device does not exists!");case"ChannelNotFound":return new Ne(df.InvalidChannelNumber,"Cannot get available states - wrong channel!");default:return new Ne(df.OtherError,"Cannot get available states - unknown error!")}case ue.OK:{if(null==s.Data)return new Ne(df.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 Ff;return t.StateInterfaceType=e.StateInterfaceType,t.StateObjectType=e.StateObjectType,t}));return s.Data.AvailableStates=e,s.Data}default:return new Ne(df.OtherError,`Cannot get available states - controller responded with response code ${s.Status}`)}}))}}jf.ServiceName="StatesHistoryService";class zf extends ce{constructor(e){super(),this.Resource="/statehistory/states/get/last",this.Method=le.Get,this.Data=e}}class Jf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.Range=hf.Day,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class Xf extends ce{constructor(e){super(),this.Resource="/statehistory/states/get/timerange",this.Method=le.Get,this.Data=e}}class Yf{constructor(){this.DeviceGuid="",this.DeviceChannel=0,this.StateInterfaceType="",this.DataRange=pf.Day,this.Time=new Date,this.ReverseOrder=!1,this.Limit=0,this.Offset=0}}class Qf extends ce{constructor(){super(),this.Resource="/statehistory/states/available",this.Method=le.Get}}class Zf extends ce{constructor(e){super(),this.Resource="/statehistory/states/available/per/channel",this.Method=le.Get,this.Data=e}}class ev{constructor(e,t){this.DeviceGuid=e,this.Channel=t}}(Hf=Lf||(Lf={}))[Hf.User=0]="User",Hf[Hf.Controller=1]="Controller",Hf[Hf.Marketing=2]="Marketing",(qf=Bf||(Bf={}))[qf.Notification=0]="Notification",qf[qf.Message=1]="Message",qf[qf.Alarm=2]="Alarm",qf[qf.Warning=3]="Warning",qf[qf.Info=4]="Info",(Vf=Wf||(Wf={}))[Vf.Other=0]="Other",Vf[Vf.UserLoggedIn=1]="UserLoggedIn",Vf[Vf.UserLoggedOut=2]="UserLoggedOut",Vf[Vf.FoundNewDevice=3]="FoundNewDevice",Vf[Vf.DoorBellPress=4]="DoorBellPress",Vf[Vf.AddedNewDevice=5]="AddedNewDevice",Vf[Vf.RemovedDevice=6]="RemovedDevice",Vf[Vf.RegisteredNewUser=7]="RegisteredNewUser",Vf[Vf.GotAccessToTheInternet=8]="GotAccessToTheInternet",Vf[Vf.LostAccessToTheInternet=9]="LostAccessToTheInternet",Vf[Vf.RemovedUser=10]="RemovedUser",Vf[Vf.NetworkChanged=11]="NetworkChanged",function(e){e.WeatherWidget="WeatherWidget"}($f||($f={}));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._chatSubscriptions=[],this._connection=gy.Get(bt.ServiceName),this._connection.SubscribeTo("/homemessaging/notify/message/new",(e=>{const t=e.Data;if(null==t.RecipientUserGuid&&t.MessageType==Bf.Message)return;const n=new rv;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($f[e],r);for(let[e,r]of Object.entries(t.MessageActionsData))n.MessageActionsData.set(e,r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}GetCachedMessagesAsync(){return tv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new sv,12e3,!1);if(null==e)return new Ne(fv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ue.OK)return new Ne(fv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ne(fv.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==Bf.Message)return;const n=new rv;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($f[t],r);for(let[t,r]of Object.entries(e.MessageActionsData))n.MessageActionsData.set(t,r);t.push(n)})),t}catch(e){return new Ne(fv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return tv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new ov(`recipient:home ${e}`),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(Cv.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class rv{constructor(){this._sender=Lf.Controller,this._messageType=Bf.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 sv extends ce{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=le.Get}}class ov extends ce{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=le.Put,this.Data=e}}var iv,av,cv,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._chatSubscriptions=[],this._connection=gy.Get(bt.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==Bf.Message){const e=new dv;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 uv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new pv,12e3,!1);if(null==e)return new Ne(fv.OtherError,"Cannot get messages - response is null.");if(e.Status!=ue.OK)return new Ne(fv.OtherError,`Cannot get messages - controller responded with response code ${e.Status}.`);if(null==e.Data)return new Ne(fv.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==Bf.Message){const n=new dv;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 Ne(fv.FatalError,`Cannot get messages - exception occurred ${e}`)}}))}SendMessageAsync(e){return uv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new hv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(Cv.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){this._chatSubscriptions.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class dv{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 hv extends ce{constructor(e){super(),this.Resource="/homemessaging/message",this.Method=le.Put,this.Data=e}}class pv extends ce{constructor(){super(),this.Resource="/homemessaging/messages",this.Method=le.Get}}!function(e){e[e.None=0]="None",e[e.ChangeDeviceState=1]="ChangeDeviceState"}(iv||(iv={})),function(e){e.GPT3_5_TURBO="gpt-3.5-turbo",e.GPT3_5_TURBO_16K="gpt-3.5-turbo-16k",e.GPT4="gpt-4"}(av||(av={})),function(e){e[e.UnknownError=0]="UnknownError",e[e.ChatNotConfigured=1]="ChatNotConfigured",e[e.MessageNotSend=2]="MessageNotSend",e[e.InvalidMessageResponseFormat=3]="InvalidMessageResponseFormat"}(cv||(cv={}));var gv,fv,vv,yv=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 mv{constructor(){this._chatSubscriptions=[],this._connection=gy.Get(bt.ServiceName),this._connection.SubscribeTo("/homemessaging/gpt/notify/message/new",(e=>{const t=e.Data,n=new _v;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=iv[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(cv[e],r);this._chatSubscriptions.forEach((e=>{e(n)}))}))}IsGptChatAvailableAsync(){return yv(this,void 0,void 0,(function*(){return(yield gy.Get(st.ServiceName).GetExtensionsInfoAsync()).any((e=>"80daeab9-104f-4c1b-9464-61f5fc9bf2bf"==e.ExtensionGuid))}))}GetChatConfigurationAsync(){return yv(this,void 0,void 0,(function*(){try{const e=yield this._connection.SendAndWaitForResponseAsync(new Sv,8e3,!1);return null==e||null==e.Status?new Ne(fv.FatalError,"Cannot get chat configuration! No data in result"):e.Status!=ue.OK?new Ne(fv.Error,`Cannot get chat configuration! Controller responded with code: ${e.Status}`):null==e.Data?new Ne(fv.NoData,"Cannot get chat configuration! Controller responded with success, but no data in response!"):e.Data}catch(e){return new Ne(fv.FatalError,`Cannot get chat configuration! ${e}`)}}))}SetChatConfigurationAsync(e){return yv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new Av(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(Cv.ServiceName,`Cannot set chat configuration! ${e}`),ue.FatalError}}))}SendMessageAsync(e){return yv(this,void 0,void 0,(function*(){var t;try{const t=yield this._connection.SendAndWaitForResponseAsync(new wv(e),8e3,!1);return null==t||null==t.Status?ue.FatalError:t.Status}catch(e){return null===(t=u.Log)||void 0===t||t.Error(Cv.ServiceName,`Cannot send message! ${e}`),ue.FatalError}}))}SubscribeToMessages(e){var t;null===(t=this._chatSubscriptions)||void 0===t||t.push(e)}UnsubscribeFromMessages(e){this._chatSubscriptions&&(this._chatSubscriptions=this._chatSubscriptions.filter((t=>t!==e)))}}class wv extends ce{constructor(e){super(),this.Resource="/homemessaging/gpt/message",this.Method=le.Put,this.Data=e}}class Sv extends ce{constructor(){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=le.Get}}class Av extends ce{constructor(e){super(),this.Resource="/homemessaging/gpt/configuration",this.Method=le.Put,this.Data=e}}class _v{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"}(gv||(gv={}));class Cv{constructor(){this._services={ControllerChat:new nv,GptChat:new mv,FamillyChat:new lv}}GetServiceName(){return Cv.ServiceName}GetChatImplementation(e){switch(e){case gv.ControllerChat:return this._services.ControllerChat;case gv.FamilyChat:return this._services.FamillyChat;case gv.GptChat:return this._services.GptChat;default:throw new Tv(`Chat with type ${e} not implemented!`)}}}Cv.ServiceName="ChatService",function(e){e.OtherError="OtherError",e.FatalError="FatalError",e.Error="Error",e.NoData="NoData"}(fv||(fv={}));class Tv 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"}(vv||(vv={}));var Dv=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 kv{constructor(){this._connection=gy.Get(bt.ServiceName),this._log=gy.Get(a.ServiceName),this._cache=gy.Get($e.ServiceName)}GetServiceName(){return kv.ServiceName}IsSupportedAsync(){return Dv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Iv,2e3,!1);return this._log.Debug(kv.ServiceName,`IsSupportedAsync: ${null==e?void 0:e.Status} resp: ${JSON.stringify(e)}`),null!=e&&e.Status==ue.WrongData}))}GetConnectedAppsAsync(){return Dv(this,void 0,void 0,(function*(){let e=yield this._connection.SendAndWaitForResponseAsync(new Ev,2e3,!0);return(null==e?void 0:e.Status)===ue.OK?null==e?void 0:e.Data:null==e?void 0:e.Status}))}UpsertConnectedAppAsync(e){return Dv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new Nv(e),2e3,!1);switch(null==t?void 0:t.Status){case ue.OK:return this._cache.Remove(new Ev),new Ne(vv.Changed,"");case ue.WrongData:switch(t.Data){case"AccessTokenToShort":return new Ne(vv.AccessTokenToShort,t.Data);case"AnotherAppWithGivenAccessTokenAlreadyExists":return new Ne(vv.AnotherAppWithGivenAccessTokenAlreadyExists,t.Data);case"AppGuidDoesNotExists":return new Ne(vv.AppGuidDoesNotExists,t.Data);case"AppNameToShort":return new Ne(vv.AppNameToShort,t.Data);case"AppUrlToShort":return new Ne(vv.AppUrlToShort,t.Data);case"AppUserIdToShort":return new Ne(vv.AppUserIdToShort,t.Data);case"AppUserNameToShort":return new Ne(vv.AppUserNameToShort,t.Data);default:return new Ne(vv.UnkownError,t.Data)}case ue.ResourceDoesNotExists:case ue.ResourceIsNotAvailable:return new Ne(vv.ResourceIsNotAvailable,t.Data);default:return new Ne(vv.UnkownError,t.Data)}}))}RemoveConnectedAppAsync(e){return Dv(this,void 0,void 0,(function*(){let t=yield this._connection.SendAndWaitForResponseAsync(new bv(e.Guid),2e3,!1);return(null==t?void 0:t.Status)===ue.OK&&this._cache.Remove(new Ev),null==t?void 0:t.Status}))}}kv.ServiceName="ConnectedAppsService";class Iv extends ce{constructor(){super(),this.Resource="/applications/app/auth",this.Method=le.Put,this.Data=""}}class Ev extends ce{constructor(){super(),this.Resource="/applications/get",this.Method=le.Get}}class bv extends ce{constructor(e){super(),this.Resource="/applications/app/delete",this.Method=le.Delete,this.Data=e}}class Nv extends ce{constructor(e){super(),this.Resource="/applications/app/upsert",this.Method=le.Put,this.Data=e}}var Gv=function(e,t,n,r){return new(n||(n=Promise))((function(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(){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(Rv.AppUserControllersKeyName,e)}null!==s&&localStorage.setItem(Rv.AppUserControllersKeyName,decodeURIComponent(s)),null!==o&&localStorage.setItem(Rv.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 Rv.ServiceName}IsMigrationDataAvailableAsync(){return Gv(this,void 0,void 0,(function*(){try{if(se.IsIosNative()){var e=yield Rv.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(Rv.AppSelectedLanguageKeyName)||null!==localStorage.getItem(Rv.AppUserControllersKeyName)}catch(e){return console.error(e),!1}}))}GetControllersDataAsync(){return Gv(this,void 0,void 0,(function*(){try{if(se.IsIosNative()){let e=yield Rv.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(Rv.AppUserControllersKeyName);return null!==e?JSON.parse(e):null}}catch(e){return console.error(e),null}}))}GetLanguageCodeAsync(){return Gv(this,void 0,void 0,(function*(){try{if(se.IsIosNative()){let e=yield Rv.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(Rv.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)}}))}}Rv.AppSelectedLanguageKeyName="App___SelectedLanguage",Rv.AppUserControllersKeyName="App___UserControllersListDatabase",Rv.ServiceName="DataMigrationService";var Pv=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 Uv{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=gy.Get(bt.ServiceName),this._logger=gy.Get(a.ServiceName),this._storage=gy.Get(l.ServiceName),gy.Get(Qe.ServiceName).OnUserLoggedInEvent().Subscribe((e=>Pv(this,void 0,void 0,(function*(){var e;try{yield oe.Delay(5e3);const t=yield this.GetControllerNetworkConfigurationAsync();if(null!=t){this._localIpAddress=t.LocalIPv4,this._publicIpAddress=t.PublicIPv4,this._gatewayIpAddress=t.GatewayIPv4,this._macAddress=t.MAC,this._storage.Save(Uv.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;se.IsIosNative()?r=yield this.getIosControllerIpAsync(n):null!==this.nativeFindControllerApi&&(r=yield null===(e=this.nativeFindControllerApi)||void 0===e?void 0:e.FindControllerAsync(n)),null!=r&&""!=r?(this._isInLocalNetwork=!0,this._logger.Debug(Uv.ServiceName,`Controller found in local network with ip address: ${r}`)):(this._isInLocalNetwork=!1,this._logger.Debug(Uv.ServiceName,"Controller not found in local network."))}else this._logger.Error(Uv.ServiceName,"Failed to get network configuration data.")}catch(e){this._logger.Error(Uv.ServiceName,`Failed to get network configuration data - ${e}`)}}))))}FindControllerInLocalNetworkAsync(e){return Pv(this,void 0,void 0,(function*(){if(se.IsIosNative()){const t=yield this.getIosControllerIpAsync(e);return""==t?null:t}return null!==this.nativeFindControllerApi?this.nativeFindControllerApi.FindControllerAsync(e):Promise.resolve(null)}))}GetLastKnownControllerLocalIpAddress(){return null!==this._localIpAddress?this._localIpAddress:this._storage.Read(Uv.ServiceName,"LocalIpAddress")}GetControllerHostName(e){return`ExalusTR7-${e}`}GetMdnsHostName(){return`ExalusTR7-${this.GetControllerHostName(this._connection.GetControllerSerialNumber())}.local`.toLowerCase()}GetControllerNetworkConfigurationAsync(){return Pv(this,void 0,void 0,(function*(){var e;const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new Ov,2e4,!1);return null==t||null==t.Status||null==t.Data?(this._logger.Error(Uv.ServiceName,"Failed to get network configuration data - unknow error."),null):t.Data}))}GetServiceName(){return Uv.ServiceName}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("")}}))}}Uv.ServiceName="FindControllerService";class Ov extends ce{constructor(){super(),this.Resource="/network/lan/",this.Method=le.Get}}var Mv,xv,Fv,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 Bv{SendAndHandleStreamAsync(e,t,n){return Promise.reject(new Error("Streams are not supported over local network connection."))}constructor(){this._errorOccuredEvent=new c,this._connectionStateChangedEvent=new c,this._dataReceivedEvent=new c,this._onMessageReceived=new c,this._log=gy.Get(a.ServiceName),this._controllerConfiguration=null,this._cache=null,this._session=null,this._logPackets=!0,this.socket=null,this._address=null,this._port="81",this._isOpen=!1,this._pin=void 0,this._serial=void 0,this._auth=null,this._initialized=!1,this._pingInterval=5e3,this._pingIntervalId=null,this._lastReceivedPacketTime=Date.now(),this._disconnectedOnPurpose=!1,this._restoreTask=null,gy.Get(Tt.ServiceName).OnAppStateChanged().Subscribe((e=>Lv(this,void 0,void 0,(function*(){var t;switch(e){case ct.ExitedLowPowerMode:case ct.ReturnedFromSuspension:(yield this.RestoreConnectionAsync())&&(null===(t=this._session)||void 0===t||t.RestoreSessionAsync())}}))))}GetConnectedBrokerInfoAsync(){return Lv(this,arguments,void 0,(function*(e=8e3){var t;const n=yield this.GetServerAddressAsync();return new ke(null!==(t=this._address)&&void 0!==t?t:"",null!=n?n:"",ge.Local)}))}Initialize(){this._initialized||(this._initialized=!0,this._controllerConfiguration=gy.Get(lt.ServiceName),this._cache=gy.Get($e.ServiceName),this._session=gy.Get(Qe.ServiceName))}checkIfAuthInfoIsCorrectAsync(e){return Lv(this,void 0,void 0,(function*(){const t=`http://${window.location.hostname}/controller_info`;let n=yield fetch(t,{method:"GET"});return!!n.ok&&(yield n.text())===`${e.SerialNumber}:${e.PIN}`}))}PingControllerAsync(){return Lv(this,void 0,void 0,(function*(){var e;if((null===(e=this.socket)||void 0===e?void 0:e.readyState)!==WebSocket.OPEN)return!1;if(null!==this._lastReceivedPacketTime&&Date.now()-this._lastReceivedPacketTime<this._pingInterval)return!1;let t=new ce;return t.Resource="/system/ping",t.Method=le.Get,yield this.SendAndWaitForResponseAsync(t,2e3,!1,!1).then((()=>!0)).catch((()=>!1))}))}SubscribeTo(e,t){let n=n=>{n.Resource===e&&t(n)};return this.OnDataReceivedEvent().Subscribe(n),()=>this.OnDataReceivedEvent().Unsubscribe(n)}GetControllerSerialNumber(){return this._serial}GetControllerPin(){return this._pin}SetServersBrokerAddress(e){}SetDefaultPacketsBrokerAddress(e){}GetServerAddressAsync(){return gy.IsRunningFromLocalNetwork()&&(this._address=`${window.location.hostname}:${this._port}`),Promise.resolve(this._address)}ConnectAsync(e){return new Promise(((t,n)=>{this.Initialize(),this._disconnectedOnPurpose=!1,this._address=e;const r=this.socket,s=new WebSocket(`ws://${e}/api`);this.socket=s,null!==this._pingIntervalId&&(clearInterval(this._pingIntervalId),this._pingIntervalId=null),null==r||r.close(),this._log.Debug(Bv.ServiceName,`Connecting to the WebSockets server ${e}`),s.onerror=t=>{if(this.socket===s)return this._log.Debug(Bv.ServiceName,`Error occured in the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,this._errorOccuredEvent.Invoke(["WebSockets",t.toString()]),n(he.FailedToConnect)},s.onopen=n=>{if(this.socket===s)return this._log.Debug(Bv.ServiceName,`Connected to the WebSockets server ${e} info: \n${JSON.stringify(n)}`),this._isOpen=!0,this._connectionStateChangedEvent.Invoke(pe.Connected),this._pingIntervalId=setInterval((()=>Lv(this,void 0,void 0,(function*(){yield this.PingControllerAsync()}))),this._pingInterval),t(he.Connected)},s.onclose=t=>{this.socket===s&&(this._log.Debug(Bv.ServiceName,`Disconnected from the WebSockets server ${e} info: \n${JSON.stringify(t)}`),this._isOpen=!1,null!==this._pingIntervalId&&(clearInterval(this._pingIntervalId),this._pingIntervalId=null),this._connectionStateChangedEvent.Invoke(pe.Disconnected))},s.onmessage=t=>{if(this.socket===s){this._log.Debug(Bv.ServiceName,`Message received from the WebSockets server ${e}: ${t.data}`),this._onMessageReceived.Invoke(t.data);try{let e=JSON.parse(t.data);this._log.Debug(Bv.ServiceName,`Received data frame: ${e.Status}`),this._dataReceivedEvent.Invoke(e)}catch(e){this._log.Error(Bv.ServiceName,`Failed to parse message: ${t.data}`)}}},this._connectionStateChangedEvent.Invoke(pe.Connecting)}))}AuthorizeAsync(e){return Lv(this,void 0,void 0,(function*(){return gy.WorksInContextOf=e.SerialNumber,!!(yield this.checkIfAuthInfoIsCorrectAsync(e))&&(this._log.Debug(Bv.ServiceName,`Authorization successful for controller ${e.SerialNumber}`),this._pin=e.PIN,this._serial=e.SerialNumber,this._auth=e,this.IsConnected()&&this._connectionStateChangedEvent.Invoke(pe.ConnectedAndAuthorized),!0)}))}ConnectAndAuthorizeAsync(e){return Lv(this,void 0,void 0,(function*(){var t;gy.WorksInContextOf=e.SerialNumber,this._log.Debug(Bv.ServiceName,`Connecting and authorizing to the controller ${e.SerialNumber}`);let n=yield this.GetServerAddressAsync();if(null==n)return he.FailedToConnectToServer;const r=yield this.ConnectAsync(n);return r!==he.Connected?r:(yield this.AuthorizeAsync(e))?he.Connected:(null===(t=this.socket)||void 0===t||t.close(),he.AuthorizationFailed)}))}DisconnectAsync(){var e;return this._log.Debug(Bv.ServiceName,`Disconnecting from the WebSockets server ${this._address}`),this._disconnectedOnPurpose=!0,this._connectionStateChangedEvent.Invoke(pe.Disconnecting),null!==this._pingIntervalId&&clearInterval(this._pingIntervalId),null===(e=this.socket)||void 0===e||e.close(),Promise.resolve()}IsConnected(){return this._isOpen}EnablePacketsLogging(){this._log.Debug(Bv.ServiceName,"Packets logging enabled"),this._logPackets=!0}DisablePacketsLogging(){this._log.Debug(Bv.ServiceName,"Packets logging disabled"),this._logPackets=!1}SendData(e,t){var n;let r=JSON.stringify(e);return t&&this._log.Debug(Bv.ServiceName,`Sending data frame: ${r}`),this._isOpen?null===(n=this.socket)||void 0===n||n.send(r):this._log.Error(Bv.ServiceName,`Failed to send data frame: ${r}`),this._isOpen}SendAsync(e){return this._isOpen?Promise.resolve(this.SendData(e,this._logPackets)):Promise.resolve(!1)}SendAndWaitForResponseAsync(e,t,n,r=!0){return this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!0,r)}SendAndHandleResponseAsync(e,t,n,r){return Lv(this,void 0,void 0,(function*(){var s;let o=0;const i=Date.now();if(!this.IsConnected()&&!(yield this.RestoreConnectionAsync()))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)=>Lv(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(Bv.ServiceName,t),a(new Error(t))}),t);let u=l=>Lv(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;if((r||!0===window.packets)&&this._log.Debug(Bv.ServiceName,`Received response for: ${null==l?void 0:l.Resource} ${null==l?void 0:l.Method} id: ${null==l?void 0:l.TransactionId} in ${g}ms`),(null==l?void 0:l.Status)===ue.UserIsNotLoggedIn){this._dataReceivedEvent.Unsubscribe(u),(null===(d=this._session)||void 0===d?void 0:d.OnUserLoggedOutEvent()).Invoke(null===(h=this._session)||void 0===h?void 0:h.User);try{yield null===(p=this._session)||void 0===p?void 0:p.RestoreSessionAsync(),s(yield this.SendAndHandleResponseAsync(e,t,n,r))}catch(e){a(e)}return}switch(null==l?void 0:l.Status){case ue.MultiDataResponseStart:case ue.MultiDataResponse:n(l),o=c();break;case ue.MultiDataResponseStop:case ue.FatalError:case ue.Error: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 Lv(this,arguments,void 0,(function*(e,t,n,r=!0,s=!0){var o,i,a;if(e.Method===le.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()&&!(yield this.RestoreConnectionAsync()))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)=>Lv(this,void 0,void 0,(function*(){let a=l=>Lv(this,void 0,void 0,(function*(){var d,h,p,g;if((null==l?void 0:l.TransactionId)==e.TransactionId){window.clearTimeout(c),this._dataReceivedEvent.Unsubscribe(a);const f=Date.now()-u;if(s&&this._log.Debug(Bv.ServiceName,`Received response for: ${null==l?void 0:l.Resource} ${null==l?void 0:l.Method} id: ${null==l?void 0:l.TransactionId} in ${f}ms`),e.Method===le.Get&&n&&(null==l?void 0:l.Status)!==ue.UserIsNotLoggedIn&&(null===(d=this._cache)||void 0===d||d.Cache(l)),(null==l?void 0:l.Status)===ue.UserIsNotLoggedIn&&r){(null===(h=this._session)||void 0===h?void 0:h.OnUserLoggedOutEvent()).Invoke(null===(p=this._session)||void 0===p?void 0:p.User);try{yield null===(g=this._session)||void 0===g?void 0:g.RestoreSessionAsync(),o(yield this.SendAndWaitForResponseWithRepeatAsync(e,t,n,!1,s))}catch(e){i(e)}return}o(l)}}));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(Bv.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 Bv.ServiceName}RestoreConnectionAsync(){return Lv(this,void 0,void 0,(function*(){return!this._disconnectedOnPurpose&&(this._restoreTask||(this._restoreTask=(()=>Lv(this,void 0,void 0,(function*(){const e=this._auth;if(null==e)return!1;if(this.IsConnected())return this.AuthorizeAsync(e);const t=yield this.GetServerAddressAsync();return null!=t&&((yield this.ConnectAsync(t))===he.Connected&&this.AuthorizeAsync(e))})))().finally((()=>{this._restoreTask=null}))),this._restoreTask)}))}}Bv.ServiceName="ExalusConnectionService";class Wv{constructor(){var e,t;this.OnEnteredPictureInPicture=new Ee,this.OnExitedPictureInPicture=new Ee,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 Wv.ServiceName}}Wv.ServiceName="PictureInPictureService",(Fv=Mv||(Mv={}))[Fv.Unknown=-1]="Unknown",Fv[Fv.Web=0]="Web",Fv[Fv.Android=1]="Android",Fv[Fv.iOS=2]="iOS";class $v{constructor(){this.ClientName="",this.LavvaUserName="",this.ClientType=Mv.Unknown,this.TokenGuid="",this.Token="",this.RegistrationDate=new Date}}!function(e){e.FeatureUnsupported="FeatureUnsupported",e.UnknownError="UnknownError",e.NoData="NoData",e.IncorrectGuid="IncorrectGuid",e.IdentityIsEmpty="IdentityIsEmpty",e.DeviceTokenIsEmpty="DeviceTokenIsEmpty",e.ClientNameIsEmpty="ClientNameIsEmpty",e.LavvaUserNameIsEmpty="LavvaUserNameIsEmpty",e.TokenNotFound="TokenNotFound",e.TokensNotFoundForLavvaUser="TokensNotFoundForLavvaUser"}(xv||(xv={}));var Vv=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 qv{constructor(){this._connection=gy.Get(bt.ServiceName),this._logger=gy.Get(a.ServiceName)}GetServiceName(){return qv.ServiceName}RegisterNotificationsClientAsync(e){return Vv(this,void 0,void 0,(function*(){var t;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 Ne(xv.UnknownError,"Cannot register notifications client - unknown error!");switch(r.Status){case ue.WrongData:{const e=this.isValidErrorCode(r.Data)?r.Data:xv.UnknownError;return new Ne(e,"Cannot register notifications client - wrong data!")}case ue.ResourceDoesNotExists:return new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!");case ue.OK:return"string"==typeof r.Data?r.Data:new Ne(xv.NoData,"Cannot register notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ne(xv.UnknownError,"Cannot register notifications client - unknown error!")}}catch(e){return new Ne(xv.UnknownError,`Cannot register notifications client - error: ${e}`)}}))}UpdateNotificationsClientAsync(e,t){return Vv(this,void 0,void 0,(function*(){var n;try{const r=new Kv({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 Ne(xv.UnknownError,"Cannot update notifications client - unknown error!");switch(s.Status){case ue.WrongData:{const e=this.isValidErrorCode(s.Data)?s.Data:xv.UnknownError;return new Ne(e,"Cannot update notifications client - wrong data!")}case ue.ResourceDoesNotExists:return new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!");case ue.OK:return"string"==typeof s.Data?s.Data==e?ue.OK:new Ne(xv.UnknownError,`Cannot update notifications client - result status is OK, but token guid is different! request guid ${e}, response guid: ${s.Data}`):new Ne(xv.NoData,"Cannot update notifications client - result status is OK, but no token guid presented in paylode, unknown error!");default:return new Ne(xv.UnknownError,"Cannot update notifications client - unknown error!")}}catch(e){return this._logger.Error(`Cannot update notifications client - error: ${e}`),new Ne(xv.UnknownError,`Cannot update notifications client - error: ${e}`)}}))}GetRegisteredNotificationsClientsMetadataAsync(e){return Vv(this,void 0,void 0,(function*(){var e;try{const t=yield null===(e=this._connection)||void 0===e?void 0:e.SendAndWaitForResponseAsync(new jv,8e3,!1);return null==t||null==t.Status?new Ne(xv.UnknownError,"Cannot get notifications clients metadata - unknown error!"):t.Status==ue.ResourceDoesNotExists?new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!"):t.Status!=ue.OK?new Ne(xv.UnknownError,`Cannot get notifications clients metadata - response status: ${t.Status}}`):null==t.Data?new Ne(xv.NoData,"Cannot get notifications clients metadata - response status is OK, but no data!"):t.Data.map((e=>{const t=new $v;return t.ClientName=e.ClientName,t.LavvaUserName=e.LavvaUserName,t.ClientType=e.ClientType,t.TokenGuid=e.TokenGuid,t.Token=e.Token,t.RegistrationDate=new Date(e.RegistrationDate),t}))}catch(e){return this._logger.Error(`Cannot get notifications clients metadata - error: ${e}`),new Ne(xv.UnknownError,`Cannot get notifications clients metadata - error: ${e}`)}}))}IsNotificationsEnabledForAllUserTokensAsync(e){return Vv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Zv(e),8e3,!1);if(null==n||null==n.Status)return new Ne(xv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:xv.UnknownError;return new Ne(e,"Cannot get notifications status!")}case ue.OK:return"boolean"==typeof n.Data?n.Data:new Ne(xv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ne(xv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ne(xv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}IsNotificationsEnabledAsync(e){return Vv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new zv(e),8e3,!1);if(null==n||null==n.Status)return new Ne(xv.UnknownError,"Cannot get notifications status - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:if(null==n.Data)return new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:xv.UnknownError;return new Ne(e,"Cannot get notifications status - resource not exists!")}case ue.OK:return"boolean"==typeof n.Data?n.Data:new Ne(xv.NoData,"Cannot get notifications status - result status is OK, but no data, or data type is wrong!");default:return new Ne(xv.UnknownError,`Cannot get notifications - response code ${n.Status}}!`)}}catch(e){return this._logger.Error(`Cannot get notifications status - error: ${e}`),new Ne(xv.UnknownError,`Cannot get notifications status - error: ${e}`)}}))}EnableNotificationsAsync(e){return Vv(this,void 0,void 0,(function*(){var t;try{let n=null;null!=e&&""!=e&&(n=e);const r=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Jv(n),8e3,!1);if(null==r||null==r.Status)return new Ne(xv.UnknownError,"Cannot enable notifications - unknown error!");switch(r.Status){case ue.ResourceDoesNotExists:if(null==r.Data)return new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:xv.UnknownError;return new Ne(e,"Cannot enable notifications - resource not exists!")}case ue.OK:return ue.OK;default:return new Ne(xv.UnknownError,`Cannot enable notifications - response code ${r.Status}}!`)}}catch(e){return this._logger.Error(`Cannot enable notifications - error: ${e}`),new Ne(xv.UnknownError,`Cannot enable notifications - error: ${e}`)}}))}EnableNotificationsForAllUserTokensAsync(e){return Vv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Yv(e),8e3,!1);if(null==n||null==n.Status)return new Ne(xv.UnknownError,"Cannot enable notifications - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:xv.UnknownError;return new Ne(e,"Cannot enable notifications!")}case ue.OK:return ue.OK;default:return new Ne(xv.UnknownError,`Cannot enable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot enable notifications for lavva user ${e} - error: ${t}`),new Ne(xv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DisableNotificationsAsync(e){return Vv(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 Xv(n),8e3,!1);if(null==r||null==r.Status)return new Ne(xv.UnknownError,"Cannot disable notifications - unknown error!");switch(r.Status){case ue.ResourceDoesNotExists:if(null==r.Data)return new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(r.Data)?r.Data:xv.UnknownError;return new Ne(e,"Cannot disable notifications - resource not exists!")}case ue.OK:return ue.OK;default:return new Ne(xv.UnknownError,`Cannot disable notifications - response code ${r.Status}!`)}}catch(e){return this._logger.Error(`Cannot disable notifications - error: ${e}`),new Ne(xv.UnknownError,`Cannot disable notifications - error: ${e}`)}}))}DisableNotificationsForAllUserTokensAsync(e){return Vv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new Qv(e),8e3,!1);if(null==n||null==n.Status)return new Ne(xv.UnknownError,"Cannot disable notifications - unknown error!");switch(n.Status){case ue.ResourceDoesNotExists:case ue.WrongData:if(null==n.Data)return new Ne(xv.FeatureUnsupported,"Notifications feature not supported in controller!");{const e=this.isValidErrorCode(n.Data)?n.Data:xv.UnknownError;return new Ne(e,"Cannot disable notifications!")}case ue.OK:return ue.OK;default:return new Ne(xv.UnknownError,`Cannot disable notifications - response code ${n.Status}!`)}}catch(t){return this._logger.Error(`Cannot disable notifications for lavva user ${e} - error: ${t}`),new Ne(xv.UnknownError,`Cannot disable notifications for lavva user ${e} - error: ${t}`)}}))}DeleteNotificationsTokenAsync(e){return Vv(this,void 0,void 0,(function*(){var t;try{const n=yield null===(t=this._connection)||void 0===t?void 0:t.SendAndWaitForResponseAsync(new ey(e),8e3,!1);return null==n||null==n.Status?new Ne(xv.UnknownError,"Cannot delete notifications token - unknown error!"):n.Status==ue.OK?ue.OK:new Ne(xv.UnknownError,`Cannot delete notifications token - response code ${n.Status}!`)}catch(e){return this._logger.Error(`Cannot delete notifications token - error: ${e}`),new Ne(xv.UnknownError,`Cannot delete notifications token - error: ${e}`)}}))}getClientType(){return se.IsIosNative()?Mv.iOS:navigator.userAgent.endsWith("LavvaAndroidNative")?Mv.Android:Mv.Web}isValidErrorCode(e){return Object.values(xv).includes(e)}}qv.ServiceName="NotificationsService";class Hv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Post,this.Data=e}}class Kv extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Put,this.Data=e}}class jv extends ce{constructor(){super(),this.Resource="/notifications/tokens/metadata",this.Method=le.Get}}class zv extends ce{constructor(e){super(),this.Resource="/notifications/status",this.Method=le.Get,this.Data={TokenIdentity:e}}}class Jv extends ce{constructor(e){super(),this.Resource="/notifications/enable",this.Method=le.Post,this.Data=e}}class Xv extends ce{constructor(e){super(),this.Resource="/notifications/disable",this.Method=le.Post,this.Data=e}}class Yv extends ce{constructor(e){super(),this.Resource="/notifications/enable/for/lavva/user",this.Method=le.Post,this.Data=e}}class Qv extends ce{constructor(e){super(),this.Resource="/notifications/disable/for/lavva/user",this.Method=le.Post,this.Data=e}}class Zv extends ce{constructor(e){super(),this.Resource="/notifications/status/for/lavva/user",this.Method=le.Get,this.Data=e}}class ey extends ce{constructor(e){super(),this.Resource="/notifications/token",this.Method=le.Delete,this.Data=e}}class ty{CheckLocationPermissionAsync(){return this.IsAndroidLocationAvailable()?navigator.AndroidLocation.CheckLocationPermissionAsync():Promise.resolve(!1)}RequestLocationPermissionAsync(){return this.IsAndroidLocationAvailable()?navigator.AndroidLocation.RequestLocationPermissionAsync():Promise.resolve(!1)}IsAndroidLocationAvailable(){return void 0!==navigator.AndroidLocation}GetServiceName(){return ty.ServiceName}}ty.ServiceName="AndroidLocationService";class ny{IsAndroidNotificationsAvailable(){return void 0!==navigator.AndroidNotifications}CheckNotificationPermissionAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.CheckNotificationPermissionAsync():Promise.resolve(!1)}RequestNotificationPermissionAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.RequestNotificationPermissionAsync():Promise.resolve(!1)}GetDeviceFirebaseTokenAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.GetDeviceFirebaseTokenAsync():Promise.resolve(null)}GetNotificationsQueueAsync(){return this.IsAndroidNotificationsAvailable()?navigator.AndroidNotifications.GetNotificationsQueueAsync():Promise.resolve(null)}GetServiceName(){return ny.ServiceName}}ny.ServiceName="AndroidNotificationsService";class ry{OpenRateDialogAsync(){if(se.IsIosNative())try{if(null!=window.webkit.messageHandlers.rateApp)return window.webkit.messageHandlers.rateApp.postMessage(!0),Promise.resolve()}catch(e){return Promise.reject(new Error(`Rate dialog is not available on this platform. Error: ${e}`))}else if(this.IsAvailable())return navigator.AndroidAppRate.OpenRateDialogAsync();return Promise.reject(new Error("AppRateService is not available on this platform."))}IsAvailable(){var e,t;return void 0!==navigator.AndroidAppRate||void 0!==(null===(t=null===(e=window.webkit)||void 0===e?void 0:e.messageHandlers)||void 0===t?void 0:t.rateApp)}GetServiceName(){return ry.ServiceName}}ry.ServiceName="AppRateService";class sy{GetCurrentLocalesAsync(){return this.IsAvailable()?navigator.AppLocales.GetCurrentLocalesAsync():Promise.resolve(void 0)}SetCurrentLocalesAsync(e){if(!this.IsAvailable())throw new Error("AppLocalesService is not available");return navigator.AppLocales.SetCurrentLocalesAsync(e)}IsAvailable(){var e,t;return void 0!==navigator.AppLocales||void 0!==(null===(t=null===(e=window.webkit)||void 0===e?void 0:e.messageHandlers)||void 0===t?void 0:t.appLocales)}GetServiceName(){return sy.ServiceName}}sy.ServiceName="AppLocalesService";var oy,iy=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())}))};!function(e){e[e.Lavva=0]="Lavva",e[e.Wisniowski=1]="Wisniowski",e[e.ExalusHome=2]="ExalusHome"}(oy||(oy={}));class ay{GetServiceName(){return ay.ServiceName}SetInstallation(e){return iy(this,void 0,void 0,(function*(){if(void 0===e.InstallationId||void 0===e.InstallationType)return Promise.reject(new Error("Invalid installation info, InstallationId and InstallationType are required"));if(e.InstallationType!=oy.ExalusHome&&void 0===e.BrokerUrl)return Promise.reject(new Error("Broker url is required for non-ExalusHome installations"));if(gy.Get(a.ServiceName).Info(ay.ServiceName,`Setting Android Auto/CarPlay installation: ${e.InstallationType} (${e.InstallationId}) broker: ${e.BrokerUrl}`),!(this.IsAndroidAutoAvailable()||se.IsIosNative()&&null!=window.webkit.messageHandlers.carPlay))return gy.Get(a.ServiceName).Warning(ay.ServiceName,"Android Auto/CarPlay is not available on this platform!"),Promise.resolve();if(e.InstallationType===oy.ExalusHome){let t=gy.Get(bt.ServiceName);e.ControllerSerial=t.GetControllerSerialNumber(),e.ControllerPin=t.GetControllerPin(),(yield t.GetConnectedBrokerInfoAsync(5e3)).Env===ge.Development?e.BrokerUrl="dev-broker.tr7.pl:4431":e.BrokerUrl="services-broker.tr7.pl";try{let t=yield this.GetTokenFromController();t?e.AuthToken=t:gy.Get(a.ServiceName).Warning(ay.ServiceName,"Failed to get auth token from controller, Android Auto/CarPlay integration might not work properly!")}catch(e){gy.Get(a.ServiceName).Error(ay.ServiceName,"Error while getting auth token from controller, Android Auto/CarPlay integration might not work properly! \n"+e)}}if(this.IsAndroidAutoAvailable())navigator.AndroidAuto.SetInstallation(e);else{if(!se.IsIosNative()||null==window.webkit.messageHandlers.carPlay)return Promise.reject(new Error("Android Auto/CarPlay is not available"));window.webkit.messageHandlers.carPlay.postMessage(e)}return Promise.resolve()}))}GetTokenFromController(){return iy(this,void 0,void 0,(function*(){var e;if(this.IsAndroidAutoAvailable()||se.IsIosNative()&&null!=window.webkit.messageHandlers.carPlay){let t=yield gy.Get(bt.ServiceName).SendAndWaitForResponseAsync(new cy,12e3,!1);if((null==t?void 0:t.Status)===ue.OK)return Promise.resolve((null===(e=null==t?void 0:t.Data)||void 0===e?void 0:e.Token)||null)}return Promise.resolve(null)}))}IsAndroidAutoAvailable(){return void 0!==navigator.AndroidAuto}ClearInstallation(){return this.IsAndroidAutoAvailable()&&navigator.AndroidAuto.SetInstallation(null),se.IsIosNative()&&null!=window.webkit.messageHandlers.carPlay?(window.webkit.messageHandlers.carPlay.postMessage(null),Promise.resolve()):Promise.reject(new Error("Android Auto/CarPlay is not available"))}}ay.ServiceName="AndroidAutoCarPlayService";class cy extends ce{constructor(){super(),this.Resource="/webapibridge/get-token",this.Method=le.Get}}var uy=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 ly{constructor(){this._connection=gy.Get(bt.ServiceName)}GetServiceName(){return ly.ServiceName}isHomeKitPairingStatusResponse(e){return"object"==typeof e&&null!==e&&"Paired"in e&&"boolean"==typeof e.Paired}GetPairingStatusAsync(){return uy(this,void 0,void 0,(function*(){const e=new hy,t=yield this._connection.SendAndWaitForResponseAsync(e,5e3,!1);if(t.Status!==ue.OK)return t.Status;const n=new dy;return this.isHomeKitPairingStatusResponse(t.Data)&&(n.Paired=t.Data.Paired),n}))}IsPairedAsync(){return uy(this,void 0,void 0,(function*(){const e=yield this.GetPairingStatusAsync();return this.isHomeKitPairingStatusResponse(e)?e.Paired:e}))}ResetPairingAsync(){return uy(this,void 0,void 0,(function*(){const e=new py;return(yield this._connection.SendAndWaitForResponseAsync(e,5e3,!1)).Status}))}}ly.ServiceName="HomeKitService";class dy{constructor(){this.Paired=!1}}class hy extends ce{constructor(){super(),this.Resource="/homekit/pairing/status",this.Method=le.Get}}class py extends ce{constructor(){super(),this.Resource="/homekit/pairing/reset",this.Method=le.Post}}yu(Map),yu(Set),(()=>{const e=String.prototype,t=Object.getOwnPropertyNames(Ti.prototype);for(const n of t)e[n]=e[n]??Ti.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 Si(wi.NoMatch)}if(0===this.length)throw new Si(wi.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 mi("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 Si(wi.NoMatch)}if(0===this.length)throw new Si(wi.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 Ti((function*(){for(let t=e.length-1;t>=0;t--)yield e[t]}))}})(),Sg(Array),Sg(Int8Array),Sg(Int16Array),Sg(Int32Array),Sg(Uint8Array),Sg(Uint8ClampedArray),Sg(Uint16Array),Sg(Uint32Array),Sg(Float32Array),Sg(Float64Array);class gy{static Init(){if(u.IsInitialized)return;console.log("Initializing DependencyContainer");let e=u.Instance;try{e.RegisterService(new Rv),e.RegisterService(new l),e.RegisterService(new Tt),e.RegisterService(new $e),e.RegisterService(new Qe),e.RegisterService(new Wv),e.RegisterService(new ry),e.RegisterService(new sy),gy.IsRunningFromLocalNetwork()?(console.log("\n\nRunning from local network!\n\n"),e.RegisterService(new Bv)):e.RegisterService(new bt),e.RegisterService(new ty),e.RegisterService(new ay),e.RegisterService(new ny),e.RegisterService(new Is),e.RegisterService(new xs),e.RegisterService(new lt),e.RegisterService(new Uv),e.RegisterService(new Cs),e.RegisterService(new st),e.RegisterService(new Pe),e.RegisterService(new qe),e.RegisterService(new Zo),e.RegisterService(new Mg),e.RegisterService(new uo),e.RegisterService(new yf),e.RegisterService(new kv),e.RegisterService(new jf),e.RegisterService(new Wo),e.RegisterService(new Cv),e.RegisterService(new qv),e.RegisterService(new ly)}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.")||e.startsWith("172.16.")}static GetAsync(e,t){return u.Instance.GetServiceAsync(e,t)}static GetWithTimeoutAsync(e,t){return u.Instance.GetServiceWithTimeoutAsync(e,t)}static Get(e){return u.Instance.GetService(e)}static SleepForAsync(e){return new Promise((t=>setTimeout(t,e)))}static ExportStringAsFileToDownload(e,t){const n=new Blob([t],{type:"text/plain"}),r=document.createElement("a"),s=window.URL.createObjectURL(n);return r.href=s,r.download=e,r}}gy.WorksInContextOf="",gy.Version=1})();
|
|
2
2
|
//# sourceMappingURL=exalushome-library-bundle.js.map
|