@c8y/ngx-components 1021.22.67 → 1021.22.69

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/alarms/alarm-details.component.d.ts +0 -4
  2. package/alarms/alarm-details.component.d.ts.map +1 -1
  3. package/core/common/interval-based-reload.abstract.d.ts +12 -1
  4. package/core/common/interval-based-reload.abstract.d.ts.map +1 -1
  5. package/esm2022/alarms/alarm-details.component.mjs +10 -10
  6. package/esm2022/core/common/interval-based-reload.abstract.mjs +50 -2
  7. package/esm2022/widgets/implementations/alarms/alarm-widget-alarms-reload.component.mjs +9 -7
  8. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.mjs +9 -7
  9. package/fesm2022/c8y-ngx-components-alarms.mjs +5 -5
  10. package/fesm2022/c8y-ngx-components-alarms.mjs.map +1 -1
  11. package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs +8 -6
  12. package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs.map +1 -1
  13. package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs +8 -6
  14. package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs.map +1 -1
  15. package/fesm2022/c8y-ngx-components.mjs +392 -346
  16. package/fesm2022/c8y-ngx-components.mjs.map +1 -1
  17. package/locales/de.po +9 -0
  18. package/locales/es.po +9 -0
  19. package/locales/fr.po +9 -0
  20. package/locales/ja_JP.po +9 -0
  21. package/locales/ko.po +9 -0
  22. package/locales/locales.pot +9 -0
  23. package/locales/nl.po +9 -0
  24. package/locales/pl.po +9 -0
  25. package/locales/pt_BR.po +9 -0
  26. package/locales/zh_CN.po +9 -0
  27. package/locales/zh_TW.po +9 -0
  28. package/package.json +1 -1
  29. package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts +7 -2
  30. package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts.map +1 -1
  31. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts +7 -2
  32. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts.map +1 -1
@@ -70,10 +70,6 @@ export declare class AlarmDetailsComponent implements OnChanges {
70
70
  * Indicates when alarms status change was started (Acknowledge/Reactivate)
71
71
  */
72
72
  isAlarmStatusChanging: boolean;
73
- /**
74
- * Represents a value for a 'Last updated' section in details.
75
- */
76
- lastUpdated: string;
77
73
  /**
78
74
  * Represents a value for a 'Status' section in details.
79
75
  */
@@ -1 +1 @@
1
- {"version":3,"file":"alarm-details.component.d.ts","sourceRoot":"","sources":["../../alarms/alarm-details.component.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"alarm-details.component.d.ts","sourceRoot":"","sources":["../../alarms/alarm-details.component.ts"],"names":[],"mappings":"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"}
@@ -1,11 +1,18 @@
1
1
  import { EventEmitter } from '@angular/core';
2
2
  import { BehaviorSubject, Subscription } from 'rxjs';
3
3
  import { CountdownIntervalComponent } from '../countdown-interval';
4
+ import { GainsightService } from '../product-experience';
5
+ export declare const WIDGET_TYPE_VALUES: {
6
+ readonly ALARMS: "alarms";
7
+ readonly DATA_POINTS_TABLE: "dataPointsTable";
8
+ };
9
+ type WidgetType = (typeof WIDGET_TYPE_VALUES)[keyof typeof WIDGET_TYPE_VALUES];
4
10
  /**
5
11
  * Abstract class representing an interval reload functionality.
6
12
  * This class provides methods and properties for managing an interval-based reload mechanism.
7
13
  */
8
14
  export declare abstract class IntervalBasedReload {
15
+ protected gainsightService: GainsightService;
9
16
  abstract countdownIntervalComponent: CountdownIntervalComponent;
10
17
  /**
11
18
  * Holds the subscription to a countdown observable.
@@ -91,8 +98,9 @@ export declare abstract class IntervalBasedReload {
91
98
  * is set to false.
92
99
  *
93
100
  * @param $event - The MouseEvent that triggered this method.
101
+ * @param widgetType - The type of the widget that triggered the event
94
102
  */
95
- onToggleCountdownButtonState($event: MouseEvent): void;
103
+ onToggleCountdownButtonState($event: MouseEvent, widgetType: WidgetType): void;
96
104
  /**
97
105
  * This function listens for changes in the `isLoading` observable, filtering out any truthy values.
98
106
  * Once a falsy value is detected (indicating that loading has finished), it attempts to start the countdown.
@@ -126,5 +134,8 @@ export declare abstract class IntervalBasedReload {
126
134
  * Updates the countdown button tooltip text based on the state of the interval refresh toggle state.
127
135
  */
128
136
  protected abstract updateCountdownButtonTooltipText(): void;
137
+ private triggerGainsightEvent;
138
+ private determineComponentName;
129
139
  }
140
+ export {};
130
141
  //# sourceMappingURL=interval-based-reload.abstract.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"interval-based-reload.abstract.d.ts","sourceRoot":"","sources":["../../../core/common/interval-based-reload.abstract.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAU,YAAY,EAAO,MAAM,MAAM,CAAC;AAClE,OAAO,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AAEnE;;;GAGG;AACH,8BAAsB,mBAAmB;IACvC,QAAQ,CAAC,0BAA0B,EAAE,0BAA0B,CAAC;IAChE;;OAEG;IACH,SAAS,CAAC,qBAAqB,EAAE,YAAY,CAAC;IAC9C;;OAEG;IACH,oBAAoB,EAAE,OAAO,CAAC;IAC9B;;;OAGG;IACH,QAAQ,CAAC,iBAAiB,EAAE,OAAO,CAAC;IACpC;;OAEG;IACH,QAAQ,CAAC,SAAS,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC;IAC7C;;OAEG;IACH,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC;IAC9B;;OAEG;IACH,QAAQ,CAAC,eAAe,EAAE,MAAM,CAAC;IACjC;;OAEG;IACH,QAAQ,CAAC,gBAAgB,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC;IAC9C;;OAEG;IACH,QAAQ,CAAC,yBAAyB,EAAE,OAAO,CAAC;IAE5C,QAAQ,CAAC,gCAAgC,EAAE,MAAM,CAAC;IAClD;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,yBAAyB,EAAE,OAAO,CAAC;IACtD;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,OAAO,CAAC;IAE1C;;;;;;OAMG;IACH,eAAe,IAAI,IAAI;IAOvB;;;;;;;;;;;;;OAaG;IACH,eAAe,IAAI,IAAI;IAoBvB,QAAQ,CAAC,MAAM,IAAI,IAAI;IACvB;;OAEG;IACH,QAAQ,CAAC,cAAc,IAAI,IAAI;IAE/B;;;;;;;;;;;;;;OAcG;IACH,4BAA4B,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI;IAmBtD;;;;;;;;;OASG;IACH,cAAc,IAAI,IAAI;IAWtB;;;;;;;OAOG;IACH,QAAQ,CAAC,eAAe,IAAI,IAAI;IAEhC;;;;;;;OAOG;IACH,gBAAgB,IAAI,IAAI;IAMxB;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,gCAAgC,IAAI,IAAI;CAC5D"}
1
+ {"version":3,"file":"interval-based-reload.abstract.d.ts","sourceRoot":"","sources":["../../../core/common/interval-based-reload.abstract.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAU,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,eAAe,EAAU,YAAY,EAAO,MAAM,MAAM,CAAC;AAClE,OAAO,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAmBzD,eAAO,MAAM,kBAAkB;;;CAGrB,CAAC;AAEX,KAAK,UAAU,GAAG,CAAC,OAAO,kBAAkB,CAAC,CAAC,MAAM,OAAO,kBAAkB,CAAC,CAAC;AAE/E;;;GAGG;AACH,8BAAsB,mBAAmB;IACvC,SAAS,CAAC,gBAAgB,mBAA4B;IAEtD,QAAQ,CAAC,0BAA0B,EAAE,0BAA0B,CAAC;IAChE;;OAEG;IACH,SAAS,CAAC,qBAAqB,EAAE,YAAY,CAAC;IAC9C;;OAEG;IACH,oBAAoB,EAAE,OAAO,CAAC;IAC9B;;;OAGG;IACH,QAAQ,CAAC,iBAAiB,EAAE,OAAO,CAAC;IACpC;;OAEG;IACH,QAAQ,CAAC,SAAS,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC;IAC7C;;OAEG;IACH,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC;IAC9B;;OAEG;IACH,QAAQ,CAAC,eAAe,EAAE,MAAM,CAAC;IACjC;;OAEG;IACH,QAAQ,CAAC,gBAAgB,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC;IAC9C;;OAEG;IACH,QAAQ,CAAC,yBAAyB,EAAE,OAAO,CAAC;IAE5C,QAAQ,CAAC,gCAAgC,EAAE,MAAM,CAAC;IAClD;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,yBAAyB,EAAE,OAAO,CAAC;IACtD;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,OAAO,CAAC;IAE1C;;;;;;OAMG;IACH,eAAe,IAAI,IAAI;IAOvB;;;;;;;;;;;;;OAaG;IACH,eAAe,IAAI,IAAI;IAoBvB,QAAQ,CAAC,MAAM,IAAI,IAAI;IACvB;;OAEG;IACH,QAAQ,CAAC,cAAc,IAAI,IAAI;IAE/B;;;;;;;;;;;;;;;OAeG;IACH,4BAA4B,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,GAAG,IAAI;IA+B9E;;;;;;;;;OASG;IACH,cAAc,IAAI,IAAI;IAWtB;;;;;;;OAOG;IACH,QAAQ,CAAC,eAAe,IAAI,IAAI;IAEhC;;;;;;;OAOG;IACH,gBAAgB,IAAI,IAAI;IAMxB;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,gCAAgC,IAAI,IAAI;IAE3D,OAAO,CAAC,qBAAqB;IAc7B,OAAO,CAAC,sBAAsB;CAU/B"}
@@ -15,11 +15,12 @@ import * as i4 from "./ng1-smart-rules-upgrade.service";
15
15
  import * as i5 from "@ngx-translate/core";
16
16
  import * as i6 from "./alarms-view.service";
17
17
  import * as i7 from "@angular/common";
18
- import * as i8 from "@angular/router";
19
- import * as i9 from "./alarm-details-custom-button/alarm-details-button.pipe";
20
- import * as i10 from "./alarm-severity-to-icon.pipe";
21
- import * as i11 from "./alarm-status-to-icon.pipe";
22
- import * as i12 from "./audit-changes-message.pipe";
18
+ import * as i8 from "ngx-bootstrap/popover";
19
+ import * as i9 from "@angular/router";
20
+ import * as i10 from "./alarm-details-custom-button/alarm-details-button.pipe";
21
+ import * as i11 from "./alarm-severity-to-icon.pipe";
22
+ import * as i12 from "./alarm-status-to-icon.pipe";
23
+ import * as i13 from "./audit-changes-message.pipe";
23
24
  export class AlarmDetailsComponent {
24
25
  constructor(alarmDetailsService, alarmService, alertService, appState, auditService, relativeTime, ng1SmartRulesUpgradeService, translateService, inventoryService, alarmsViewService, colorService) {
25
26
  this.alarmDetailsService = alarmDetailsService;
@@ -75,7 +76,6 @@ export class AlarmDetailsComponent {
75
76
  await this.updateStatusMessage();
76
77
  const { data } = await this.inventoryService.detail(this.selectedAlarm.source.id);
77
78
  this.selectedAlarmMO = data;
78
- this.updateLastUpdatedDate(this.auditLog.data[0]);
79
79
  this.customFragments = this.getCustomFragments(this.selectedAlarm);
80
80
  }
81
81
  }
@@ -213,7 +213,7 @@ export class AlarmDetailsComponent {
213
213
  return;
214
214
  }
215
215
  const { creationTime } = updatedAuditRecords;
216
- this.lastUpdated = creationTime;
216
+ this.selectedAlarm.lastUpdated = creationTime;
217
217
  }
218
218
  getActiveStatusMessage(time) {
219
219
  return this.translateService.instant(gettext('ACTIVE`alarm`: triggered {{alarmTimeFromNow}}'), {
@@ -338,14 +338,14 @@ export class AlarmDetailsComponent {
338
338
  return customProperties;
339
339
  }
340
340
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AlarmDetailsComponent, deps: [{ token: i1.AlarmDetailsService }, { token: i2.AlarmService }, { token: i3.AlertService }, { token: i3.AppStateService }, { token: i2.AuditService }, { token: i3.RelativeTimePipe }, { token: i4.Ng1SmartRulesUpgradeService, optional: true }, { token: i5.TranslateService }, { token: i2.InventoryService }, { token: i6.AlarmsViewService }, { token: i3.ColorService }], target: i0.ɵɵFactoryTarget.Component }); }
341
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: AlarmDetailsComponent, selector: "c8y-alarm-details", inputs: { selectedAlarm: "selectedAlarm" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"d-flex row tight-grid flex-wrap a-i-stretch\">\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 c8y-icon\"\n [c8yIcon]=\"selectedAlarm.status | AlarmStatusToIcon\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Status' | translate }}</p>\n <p class=\"small\">{{ statusMessage }}</p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n [c8yIcon]=\"selectedAlarm.severity | AlarmSeverityToIcon\"\n [ngClass]=\"selectedAlarm.severity?.toString() | lowercase\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Severity' | translate }}</p>\n <p class=\"small\">{{ SEVERITY_LABELS[selectedAlarm.severity] | translate }}</p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n c8yIcon=\"contactless-payment\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Source' | translate }}</p>\n <p class=\"small\">\n <button\n class=\"btn-link text-muted p-0 m-r-8 text-left\"\n title=\"{{ selectedAlarm.source.name }}\"\n type=\"button\"\n routerLink=\"{{ selectedAlarmMO | assetLink }}\"\n >\n <small class=\"icon-flex\">\n <i c8yIcon=\"exchange\"></i>\n {{ selectedAlarm.source.name || selectedAlarm.source.id }}\n </small>\n </button>\n <ng-container *ngIf=\"showSourceNavigationLink\">\n <button\n class=\"btn-link p-0 text-left\"\n title=\"{{\n linkTitle\n | translate: { appName: userDeviceManagementApp | humanizeAppName | async }\n }}\"\n type=\"button\"\n (click)=\"goToAlarmSource(selectedAlarm.id)\"\n data-cy=\"alarm-details-device-management-link\"\n >\n {{ userDeviceManagementApp | humanizeAppName | async }}\n <i c8yIcon=\"external-link\"></i>\n </button>\n </ng-container>\n </p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <span\n class=\"circle-icon-wrapper\"\n [ngStyle]=\"{ 'background-color': typeColor }\"\n >\n <i\n class=\"stroked-icon\"\n c8yIcon=\"bell\"\n ></i>\n </span>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8 min-width-0\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Type' | translate }}</p>\n <p\n class=\"small text-truncate\"\n title=\"{{ selectedAlarm.type }}\"\n >\n <code>{{ selectedAlarm.type }}</code>\n </p>\n </div>\n </div>\n </div>\n\n <div class=\"col-xs-12 col-md-12 p-b-16\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4\"\n c8yIcon=\"calendar\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-0 p-r-8 flex-grow\">\n <div class=\"content-flex-50\">\n <div class=\"col-4 p-b-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Last updated' | translate }}</p>\n <p class=\"small\">\n {{ lastUpdated | c8yDate: 'medium' }}\n </p>\n </div>\n <div\n class=\"col-4 p-b-8\"\n *ngIf=\"selectedAlarm.count > 1\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Number of occurrences' | translate }}</p>\n <p>\n <span class=\"badge badge-info\">{{ selectedAlarm.count }}</span>\n </p>\n </div>\n <div\n class=\"col-4 p-b-8\"\n *ngIf=\"selectedAlarm.count > 1\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'First occurrence' | translate }}</p>\n <p class=\"small\">\n {{ selectedAlarm.creationTime | c8yDate: 'medium' }}\n </p>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div\n class=\"col-xs-12 col-md-12 p-b-16\"\n *ngIf=\"customFragments\"\n >\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4\"\n c8yIcon=\"outgoing-data\"\n ></i>\n </div>\n <div\n class=\"p-t-8 p-b-0 p-r-8 flex-grow\"\n data-cy=\"alarm-details-custom-data\"\n >\n <p class=\"text-label-small m-b-4 m-r-8\">{{ 'Custom data' | translate }}</p>\n <pre><code>{{ customFragments | json }}</code></pre>\n </div>\n </div>\n </div>\n</div>\n\n<div class=\"d-flex flex-wrap gap-8\">\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Reload audit logs' | translate\"\n type=\"submit\"\n (click)=\"reloadAuditLog(true, true)\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading }\"\n ></i>\n {{ 'Reload audit logs' | translate }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? (ACKNOWLEDGE_LABEL | translate)\n : (REACTIVATE_LABEL | translate)\n \"\n type=\"submit\"\n (click)=\"\n onUpdateDetails(\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? ACKNOWLEDGED_STATUS_VALUE\n : ACTIVE_STATUS_VALUE\n )\n \"\n [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE || isAlarmStatusChanging\"\n >\n <i\n [c8yIcon]=\"selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE ? BELL_SLASH_ICON : BELL_ICON\"\n ></i>\n {{\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? (ACKNOWLEDGE_LABEL | translate)\n : (REACTIVATE_LABEL | translate)\n }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Create smart rule' | translate\"\n type=\"submit\"\n *ngIf=\"isCreateSmartRulesButtonAvailable\"\n (click)=\"createSmartRule()\"\n >\n <i c8yIcon=\"c8y-icon c8y-icon-smart-rules\"></i>\n {{ 'Create smart rule' | translate }}\n </button>\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Clear`alarm`' | translate\"\n type=\"submit\"\n (click)=\"onUpdateDetails(CLEARED_STATUS_VALUE)\"\n [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE\"\n >\n <i c8yIcon=\"c8y-alert-idle\"></i>\n {{ 'Clear`alarm`' | translate }}\n </button>\n\n <button\n *ngFor=\"let button of selectedAlarm | alarmDetailsButton: selectedAlarmMO | async\"\n class=\"btn btn-default btn-sm\"\n [ngClass]=\"button.additionalButtonClasses\"\n [title]=\"button.title | translate\"\n type=\"button\"\n (click)=\"detailsButtonAction(button, selectedAlarm)\"\n [disabled]=\"button.disabled\"\n >\n <i [ngClass]=\"button.additionalIconClasses\" [c8yIcon]=\"button.icon\"></i>\n <span *ngIf=\"button.label\">{{ button.label | translate }}</span>\n </button>\n</div>\n\n<ng-template #noAuditLogAvailable>\n <div class=\"p-16\">\n <c8y-ui-empty-state\n [icon]=\"'archive'\"\n [title]=\"'No audit logs found.' | translate\"\n [horizontal]=\"true\"\n ></c8y-ui-empty-state>\n </div>\n</ng-template>\n\n<div class=\"legend form-block\">{{ 'Audit logs' | translate }}</div>\n\n<ng-container *ngIf=\"isLoading || auditLog?.data.length; else noAuditLogAvailable\">\n <c8y-loading *ngIf=\"isLoading\"></c8y-loading>\n\n <c8y-list-group\n data-cy=\"c8y-alarms-details--audit-logs\"\n *ngIf=\"!isLoading\"\n >\n <c8y-li-timeline *c8yFor=\"let log of auditLog; loadMore: 'hidden'\">\n {{ log.creationTime | date: 'mediumDate' }}\n {{ log.creationTime | date: 'mediumTime' }}\n <c8y-li>\n <c8y-li-body>\n <p class=\"text-truncate-wrap separator-bottom p-b-4\">\n {{ log | auditChangesMessage }}\n </p>\n <div class=\"c8y-list__item__footer\">\n <span\n class=\"m-r-16 small\"\n *ngIf=\"log.user\"\n >\n <span class=\"text-label-small\">\n {{ 'by`user`' | translate }}\n </span>\n {{ log.user }}\n </span>\n <span class=\"small\">\n <span class=\"text-label-small\">\n {{ 'device time' | translate }}\n </span>\n {{ log.time | c8yDate: 'medium' }}\n </span>\n </div>\n </c8y-li-body>\n </c8y-li>\n </c8y-li-timeline>\n </c8y-list-group>\n</ng-container>\n", dependencies: [{ kind: "component", type: i3.EmptyStateComponent, selector: "c8y-ui-empty-state", inputs: ["icon", "title", "subtitle", "horizontal"] }, { kind: "directive", type: i3.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.ForOfDirective, selector: "[c8yFor]", inputs: ["c8yForOf", "c8yForLoadMore", "c8yForPipe", "c8yForNotFound", "c8yForMaxIterations", "c8yForLoadingTemplate", "c8yForLoadNextLabel", "c8yForLoadingLabel", "c8yForRealtime", "c8yForRealtimeOptions", "c8yForComparator", "c8yForEnableVirtualScroll", "c8yForVirtualScrollElementSize", "c8yForVirtualScrollStrategy", "c8yForVirtualScrollContainerHeight"], outputs: ["c8yForCount", "c8yForChange", "c8yForLoadMoreComponent"] }, { kind: "component", type: i3.LoadingComponent, selector: "c8y-loading", inputs: ["layout", "progress", "message"] }, { kind: "component", type: i3.ListGroupComponent, selector: "c8y-list-group" }, { kind: "component", type: i3.ListItemComponent, selector: "c8y-list-item, c8y-li", inputs: ["active", "highlighted", "emptyActions", "dense", "collapsed", "selectable"], outputs: ["collapsedChange"] }, { kind: "component", type: i3.ListItemBodyComponent, selector: "c8y-list-item-body, c8y-li-body", inputs: ["body"] }, { kind: "component", type: i3.ListItemTimelineComponent, selector: "c8y-list-item-timeline, c8y-li-timeline" }, { kind: "directive", type: i8.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.LowerCasePipe, name: "lowercase" }, { kind: "pipe", type: i7.JsonPipe, name: "json" }, { kind: "pipe", type: i7.DatePipe, name: "date" }, { kind: "pipe", type: i3.HumanizeAppNamePipe, name: "humanizeAppName" }, { kind: "pipe", type: i3.DatePipe, name: "c8yDate" }, { kind: "pipe", type: i3.AssetLinkPipe, name: "assetLink" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "pipe", type: i9.AlarmDetailsButtonPipe, name: "alarmDetailsButton" }, { kind: "pipe", type: i10.AlarmSeverityToIconPipe, name: "AlarmSeverityToIcon" }, { kind: "pipe", type: i11.AlarmStatusToIconPipe, name: "AlarmStatusToIcon" }, { kind: "pipe", type: i12.AuditChangesMessagePipe, name: "auditChangesMessage" }] }); }
341
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: AlarmDetailsComponent, selector: "c8y-alarm-details", inputs: { selectedAlarm: "selectedAlarm" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"d-flex row tight-grid flex-wrap a-i-stretch\">\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 c8y-icon\"\n [c8yIcon]=\"selectedAlarm.status | AlarmStatusToIcon\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Status' | translate }}</p>\n <p class=\"small\">{{ statusMessage }}</p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n [c8yIcon]=\"selectedAlarm.severity | AlarmSeverityToIcon\"\n [ngClass]=\"selectedAlarm.severity?.toString() | lowercase\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Severity' | translate }}</p>\n <p class=\"small\">{{ SEVERITY_LABELS[selectedAlarm.severity] | translate }}</p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n c8yIcon=\"contactless-payment\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Source' | translate }}</p>\n <p class=\"small\">\n <button\n class=\"btn-link text-muted p-0 m-r-8 text-left\"\n title=\"{{ selectedAlarm.source.name }}\"\n type=\"button\"\n routerLink=\"{{ selectedAlarmMO | assetLink }}\"\n >\n <small class=\"icon-flex\">\n <i c8yIcon=\"exchange\"></i>\n {{ selectedAlarm.source.name || selectedAlarm.source.id }}\n </small>\n </button>\n <ng-container *ngIf=\"showSourceNavigationLink\">\n <button\n class=\"btn-link p-0 text-left\"\n title=\"{{\n linkTitle\n | translate: { appName: userDeviceManagementApp | humanizeAppName | async }\n }}\"\n type=\"button\"\n (click)=\"goToAlarmSource(selectedAlarm.id)\"\n data-cy=\"alarm-details-device-management-link\"\n >\n {{ userDeviceManagementApp | humanizeAppName | async }}\n <i c8yIcon=\"external-link\"></i>\n </button>\n </ng-container>\n </p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <span\n class=\"circle-icon-wrapper\"\n [ngStyle]=\"{ 'background-color': typeColor }\"\n >\n <i\n class=\"stroked-icon\"\n c8yIcon=\"bell\"\n ></i>\n </span>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8 min-width-0\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Type' | translate }}</p>\n <p\n class=\"small text-truncate\"\n title=\"{{ selectedAlarm.type }}\"\n >\n <code>{{ selectedAlarm.type }}</code>\n </p>\n </div>\n </div>\n </div>\n\n <div class=\"col-xs-12 col-md-12 p-b-16\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4\"\n c8yIcon=\"calendar\"\n data-cy=\"c8y-alarm-details--last-updated-icon\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-0 p-r-8 flex-grow\">\n <div class=\"content-flex-50\">\n <div\n class=\"col-4 p-b-8\"\n *ngIf=\"selectedAlarm.count > 1\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Number of occurrences' | translate }}</p>\n <p>\n <span class=\"badge badge-info\">{{ selectedAlarm.count }}</span>\n </p>\n </div>\n <div\n class=\"col-4 p-b-8\"\n *ngIf=\"selectedAlarm.count > 1\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'First occurrence' | translate }}</p>\n <p class=\"small\">\n {{ selectedAlarm.creationTime | c8yDate: 'medium' }}\n\n <button\n class=\"btn-help btn-help--sm\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Time in which the alarm was created. The time shown corresponds to the server\\'s time. Device time can be different from server time.'\n | translate\n }}\"\n placement=\"right\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n ></button>\n </p>\n </div>\n <div\n class=\"col-4 p-b-8\"\n data-cy=\"c8y-alarm-details--last-updated-wrapper\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Last occurrence' | translate }}</p>\n <p class=\"small\">\n {{ selectedAlarm.lastUpdated | c8yDate: 'medium' }}\n\n <button\n class=\"btn-help btn-help--sm\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Time in which the alarm was last updated. The time shown corresponds to the server\\'s time. Device time can be different from server time.'\n | translate\n }}\"\n placement=\"right\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n ></button>\n </p>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div\n class=\"col-xs-12 col-md-12 p-b-16\"\n *ngIf=\"customFragments\"\n >\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4\"\n c8yIcon=\"outgoing-data\"\n ></i>\n </div>\n <div\n class=\"p-t-8 p-b-0 p-r-8 flex-grow\"\n data-cy=\"alarm-details-custom-data\"\n >\n <p class=\"text-label-small m-b-4 m-r-8\">{{ 'Custom data' | translate }}</p>\n <pre><code>{{ customFragments | json }}</code></pre>\n </div>\n </div>\n </div>\n</div>\n\n<div class=\"d-flex flex-wrap gap-8\">\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Reload audit logs' | translate\"\n type=\"submit\"\n (click)=\"reloadAuditLog(true, true)\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading }\"\n ></i>\n {{ 'Reload audit logs' | translate }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? (ACKNOWLEDGE_LABEL | translate)\n : (REACTIVATE_LABEL | translate)\n \"\n type=\"submit\"\n (click)=\"\n onUpdateDetails(\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? ACKNOWLEDGED_STATUS_VALUE\n : ACTIVE_STATUS_VALUE\n )\n \"\n [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE || isAlarmStatusChanging\"\n >\n <i\n [c8yIcon]=\"selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE ? BELL_SLASH_ICON : BELL_ICON\"\n ></i>\n {{\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? (ACKNOWLEDGE_LABEL | translate)\n : (REACTIVATE_LABEL | translate)\n }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Create smart rule' | translate\"\n type=\"submit\"\n *ngIf=\"isCreateSmartRulesButtonAvailable\"\n (click)=\"createSmartRule()\"\n >\n <i c8yIcon=\"c8y-icon c8y-icon-smart-rules\"></i>\n {{ 'Create smart rule' | translate }}\n </button>\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Clear`alarm`' | translate\"\n type=\"submit\"\n (click)=\"onUpdateDetails(CLEARED_STATUS_VALUE)\"\n [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE\"\n >\n <i c8yIcon=\"c8y-alert-idle\"></i>\n {{ 'Clear`alarm`' | translate }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"button.title | translate\"\n type=\"button\"\n *ngFor=\"let button of selectedAlarm | alarmDetailsButton: selectedAlarmMO | async\"\n [ngClass]=\"button.additionalButtonClasses\"\n (click)=\"detailsButtonAction(button, selectedAlarm)\"\n [disabled]=\"button.disabled\"\n >\n <i\n [c8yIcon]=\"button.icon\"\n [ngClass]=\"button.additionalIconClasses\"\n ></i>\n <span *ngIf=\"button.label\">{{ button.label | translate }}</span>\n </button>\n</div>\n\n<ng-template #noAuditLogAvailable>\n <div class=\"p-16\">\n <c8y-ui-empty-state\n [icon]=\"'archive'\"\n [title]=\"'No audit logs found.' | translate\"\n [horizontal]=\"true\"\n ></c8y-ui-empty-state>\n </div>\n</ng-template>\n\n<div class=\"legend form-block\">{{ 'Audit logs' | translate }}</div>\n\n<ng-container *ngIf=\"isLoading || auditLog?.data.length; else noAuditLogAvailable\">\n <c8y-loading *ngIf=\"isLoading\"></c8y-loading>\n\n <c8y-list-group\n data-cy=\"c8y-alarms-details--audit-logs\"\n *ngIf=\"!isLoading\"\n >\n <c8y-li-timeline *c8yFor=\"let log of auditLog; loadMore: 'hidden'\">\n {{ log.creationTime | date: 'mediumDate' }}\n {{ log.creationTime | date: 'mediumTime' }}\n <c8y-li>\n <c8y-li-body>\n <p class=\"text-truncate-wrap separator-bottom p-b-4\">\n {{ log | auditChangesMessage }}\n </p>\n <div class=\"c8y-list__item__footer\">\n <span\n class=\"m-r-16 small\"\n *ngIf=\"log.user\"\n >\n <span class=\"text-label-small\">\n {{ 'by`user`' | translate }}\n </span>\n {{ log.user }}\n </span>\n <span class=\"small\">\n <span class=\"text-label-small\">\n {{ 'device time' | translate }}\n </span>\n {{ log.time | c8yDate: 'medium' }}\n </span>\n </div>\n </c8y-li-body>\n </c8y-li>\n </c8y-li-timeline>\n </c8y-list-group>\n</ng-container>\n", dependencies: [{ kind: "component", type: i3.EmptyStateComponent, selector: "c8y-ui-empty-state", inputs: ["icon", "title", "subtitle", "horizontal"] }, { kind: "directive", type: i3.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.ForOfDirective, selector: "[c8yFor]", inputs: ["c8yForOf", "c8yForLoadMore", "c8yForPipe", "c8yForNotFound", "c8yForMaxIterations", "c8yForLoadingTemplate", "c8yForLoadNextLabel", "c8yForLoadingLabel", "c8yForRealtime", "c8yForRealtimeOptions", "c8yForComparator", "c8yForEnableVirtualScroll", "c8yForVirtualScrollElementSize", "c8yForVirtualScrollStrategy", "c8yForVirtualScrollContainerHeight"], outputs: ["c8yForCount", "c8yForChange", "c8yForLoadMoreComponent"] }, { kind: "component", type: i3.LoadingComponent, selector: "c8y-loading", inputs: ["layout", "progress", "message"] }, { kind: "component", type: i3.ListGroupComponent, selector: "c8y-list-group" }, { kind: "component", type: i3.ListItemComponent, selector: "c8y-list-item, c8y-li", inputs: ["active", "highlighted", "emptyActions", "dense", "collapsed", "selectable"], outputs: ["collapsedChange"] }, { kind: "component", type: i3.ListItemBodyComponent, selector: "c8y-list-item-body, c8y-li-body", inputs: ["body"] }, { kind: "component", type: i3.ListItemTimelineComponent, selector: "c8y-list-item-timeline, c8y-li-timeline" }, { kind: "directive", type: i8.PopoverDirective, selector: "[popover]", inputs: ["adaptivePosition", "boundariesElement", "popover", "popoverContext", "popoverTitle", "placement", "outsideClick", "triggers", "container", "containerClass", "isOpen", "delay"], outputs: ["onShown", "onHidden"], exportAs: ["bs-popover"] }, { kind: "directive", type: i9.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.LowerCasePipe, name: "lowercase" }, { kind: "pipe", type: i7.JsonPipe, name: "json" }, { kind: "pipe", type: i7.DatePipe, name: "date" }, { kind: "pipe", type: i3.HumanizeAppNamePipe, name: "humanizeAppName" }, { kind: "pipe", type: i3.DatePipe, name: "c8yDate" }, { kind: "pipe", type: i3.AssetLinkPipe, name: "assetLink" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "pipe", type: i10.AlarmDetailsButtonPipe, name: "alarmDetailsButton" }, { kind: "pipe", type: i11.AlarmSeverityToIconPipe, name: "AlarmSeverityToIcon" }, { kind: "pipe", type: i12.AlarmStatusToIconPipe, name: "AlarmStatusToIcon" }, { kind: "pipe", type: i13.AuditChangesMessagePipe, name: "auditChangesMessage" }] }); }
342
342
  }
343
343
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AlarmDetailsComponent, decorators: [{
344
344
  type: Component,
345
- args: [{ selector: 'c8y-alarm-details', template: "<div class=\"d-flex row tight-grid flex-wrap a-i-stretch\">\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 c8y-icon\"\n [c8yIcon]=\"selectedAlarm.status | AlarmStatusToIcon\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Status' | translate }}</p>\n <p class=\"small\">{{ statusMessage }}</p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n [c8yIcon]=\"selectedAlarm.severity | AlarmSeverityToIcon\"\n [ngClass]=\"selectedAlarm.severity?.toString() | lowercase\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Severity' | translate }}</p>\n <p class=\"small\">{{ SEVERITY_LABELS[selectedAlarm.severity] | translate }}</p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n c8yIcon=\"contactless-payment\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Source' | translate }}</p>\n <p class=\"small\">\n <button\n class=\"btn-link text-muted p-0 m-r-8 text-left\"\n title=\"{{ selectedAlarm.source.name }}\"\n type=\"button\"\n routerLink=\"{{ selectedAlarmMO | assetLink }}\"\n >\n <small class=\"icon-flex\">\n <i c8yIcon=\"exchange\"></i>\n {{ selectedAlarm.source.name || selectedAlarm.source.id }}\n </small>\n </button>\n <ng-container *ngIf=\"showSourceNavigationLink\">\n <button\n class=\"btn-link p-0 text-left\"\n title=\"{{\n linkTitle\n | translate: { appName: userDeviceManagementApp | humanizeAppName | async }\n }}\"\n type=\"button\"\n (click)=\"goToAlarmSource(selectedAlarm.id)\"\n data-cy=\"alarm-details-device-management-link\"\n >\n {{ userDeviceManagementApp | humanizeAppName | async }}\n <i c8yIcon=\"external-link\"></i>\n </button>\n </ng-container>\n </p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <span\n class=\"circle-icon-wrapper\"\n [ngStyle]=\"{ 'background-color': typeColor }\"\n >\n <i\n class=\"stroked-icon\"\n c8yIcon=\"bell\"\n ></i>\n </span>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8 min-width-0\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Type' | translate }}</p>\n <p\n class=\"small text-truncate\"\n title=\"{{ selectedAlarm.type }}\"\n >\n <code>{{ selectedAlarm.type }}</code>\n </p>\n </div>\n </div>\n </div>\n\n <div class=\"col-xs-12 col-md-12 p-b-16\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4\"\n c8yIcon=\"calendar\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-0 p-r-8 flex-grow\">\n <div class=\"content-flex-50\">\n <div class=\"col-4 p-b-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Last updated' | translate }}</p>\n <p class=\"small\">\n {{ lastUpdated | c8yDate: 'medium' }}\n </p>\n </div>\n <div\n class=\"col-4 p-b-8\"\n *ngIf=\"selectedAlarm.count > 1\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Number of occurrences' | translate }}</p>\n <p>\n <span class=\"badge badge-info\">{{ selectedAlarm.count }}</span>\n </p>\n </div>\n <div\n class=\"col-4 p-b-8\"\n *ngIf=\"selectedAlarm.count > 1\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'First occurrence' | translate }}</p>\n <p class=\"small\">\n {{ selectedAlarm.creationTime | c8yDate: 'medium' }}\n </p>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div\n class=\"col-xs-12 col-md-12 p-b-16\"\n *ngIf=\"customFragments\"\n >\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4\"\n c8yIcon=\"outgoing-data\"\n ></i>\n </div>\n <div\n class=\"p-t-8 p-b-0 p-r-8 flex-grow\"\n data-cy=\"alarm-details-custom-data\"\n >\n <p class=\"text-label-small m-b-4 m-r-8\">{{ 'Custom data' | translate }}</p>\n <pre><code>{{ customFragments | json }}</code></pre>\n </div>\n </div>\n </div>\n</div>\n\n<div class=\"d-flex flex-wrap gap-8\">\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Reload audit logs' | translate\"\n type=\"submit\"\n (click)=\"reloadAuditLog(true, true)\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading }\"\n ></i>\n {{ 'Reload audit logs' | translate }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? (ACKNOWLEDGE_LABEL | translate)\n : (REACTIVATE_LABEL | translate)\n \"\n type=\"submit\"\n (click)=\"\n onUpdateDetails(\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? ACKNOWLEDGED_STATUS_VALUE\n : ACTIVE_STATUS_VALUE\n )\n \"\n [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE || isAlarmStatusChanging\"\n >\n <i\n [c8yIcon]=\"selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE ? BELL_SLASH_ICON : BELL_ICON\"\n ></i>\n {{\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? (ACKNOWLEDGE_LABEL | translate)\n : (REACTIVATE_LABEL | translate)\n }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Create smart rule' | translate\"\n type=\"submit\"\n *ngIf=\"isCreateSmartRulesButtonAvailable\"\n (click)=\"createSmartRule()\"\n >\n <i c8yIcon=\"c8y-icon c8y-icon-smart-rules\"></i>\n {{ 'Create smart rule' | translate }}\n </button>\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Clear`alarm`' | translate\"\n type=\"submit\"\n (click)=\"onUpdateDetails(CLEARED_STATUS_VALUE)\"\n [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE\"\n >\n <i c8yIcon=\"c8y-alert-idle\"></i>\n {{ 'Clear`alarm`' | translate }}\n </button>\n\n <button\n *ngFor=\"let button of selectedAlarm | alarmDetailsButton: selectedAlarmMO | async\"\n class=\"btn btn-default btn-sm\"\n [ngClass]=\"button.additionalButtonClasses\"\n [title]=\"button.title | translate\"\n type=\"button\"\n (click)=\"detailsButtonAction(button, selectedAlarm)\"\n [disabled]=\"button.disabled\"\n >\n <i [ngClass]=\"button.additionalIconClasses\" [c8yIcon]=\"button.icon\"></i>\n <span *ngIf=\"button.label\">{{ button.label | translate }}</span>\n </button>\n</div>\n\n<ng-template #noAuditLogAvailable>\n <div class=\"p-16\">\n <c8y-ui-empty-state\n [icon]=\"'archive'\"\n [title]=\"'No audit logs found.' | translate\"\n [horizontal]=\"true\"\n ></c8y-ui-empty-state>\n </div>\n</ng-template>\n\n<div class=\"legend form-block\">{{ 'Audit logs' | translate }}</div>\n\n<ng-container *ngIf=\"isLoading || auditLog?.data.length; else noAuditLogAvailable\">\n <c8y-loading *ngIf=\"isLoading\"></c8y-loading>\n\n <c8y-list-group\n data-cy=\"c8y-alarms-details--audit-logs\"\n *ngIf=\"!isLoading\"\n >\n <c8y-li-timeline *c8yFor=\"let log of auditLog; loadMore: 'hidden'\">\n {{ log.creationTime | date: 'mediumDate' }}\n {{ log.creationTime | date: 'mediumTime' }}\n <c8y-li>\n <c8y-li-body>\n <p class=\"text-truncate-wrap separator-bottom p-b-4\">\n {{ log | auditChangesMessage }}\n </p>\n <div class=\"c8y-list__item__footer\">\n <span\n class=\"m-r-16 small\"\n *ngIf=\"log.user\"\n >\n <span class=\"text-label-small\">\n {{ 'by`user`' | translate }}\n </span>\n {{ log.user }}\n </span>\n <span class=\"small\">\n <span class=\"text-label-small\">\n {{ 'device time' | translate }}\n </span>\n {{ log.time | c8yDate: 'medium' }}\n </span>\n </div>\n </c8y-li-body>\n </c8y-li>\n </c8y-li-timeline>\n </c8y-list-group>\n</ng-container>\n" }]
345
+ args: [{ selector: 'c8y-alarm-details', template: "<div class=\"d-flex row tight-grid flex-wrap a-i-stretch\">\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 c8y-icon\"\n [c8yIcon]=\"selectedAlarm.status | AlarmStatusToIcon\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Status' | translate }}</p>\n <p class=\"small\">{{ statusMessage }}</p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n [c8yIcon]=\"selectedAlarm.severity | AlarmSeverityToIcon\"\n [ngClass]=\"selectedAlarm.severity?.toString() | lowercase\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Severity' | translate }}</p>\n <p class=\"small\">{{ SEVERITY_LABELS[selectedAlarm.severity] | translate }}</p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n c8yIcon=\"contactless-payment\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Source' | translate }}</p>\n <p class=\"small\">\n <button\n class=\"btn-link text-muted p-0 m-r-8 text-left\"\n title=\"{{ selectedAlarm.source.name }}\"\n type=\"button\"\n routerLink=\"{{ selectedAlarmMO | assetLink }}\"\n >\n <small class=\"icon-flex\">\n <i c8yIcon=\"exchange\"></i>\n {{ selectedAlarm.source.name || selectedAlarm.source.id }}\n </small>\n </button>\n <ng-container *ngIf=\"showSourceNavigationLink\">\n <button\n class=\"btn-link p-0 text-left\"\n title=\"{{\n linkTitle\n | translate: { appName: userDeviceManagementApp | humanizeAppName | async }\n }}\"\n type=\"button\"\n (click)=\"goToAlarmSource(selectedAlarm.id)\"\n data-cy=\"alarm-details-device-management-link\"\n >\n {{ userDeviceManagementApp | humanizeAppName | async }}\n <i c8yIcon=\"external-link\"></i>\n </button>\n </ng-container>\n </p>\n </div>\n </div>\n </div>\n <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <span\n class=\"circle-icon-wrapper\"\n [ngStyle]=\"{ 'background-color': typeColor }\"\n >\n <i\n class=\"stroked-icon\"\n c8yIcon=\"bell\"\n ></i>\n </span>\n </div>\n <div class=\"p-t-8 p-b-8 p-r-8 min-width-0\">\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Type' | translate }}</p>\n <p\n class=\"small text-truncate\"\n title=\"{{ selectedAlarm.type }}\"\n >\n <code>{{ selectedAlarm.type }}</code>\n </p>\n </div>\n </div>\n </div>\n\n <div class=\"col-xs-12 col-md-12 p-b-16\">\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4\"\n c8yIcon=\"calendar\"\n data-cy=\"c8y-alarm-details--last-updated-icon\"\n ></i>\n </div>\n <div class=\"p-t-8 p-b-0 p-r-8 flex-grow\">\n <div class=\"content-flex-50\">\n <div\n class=\"col-4 p-b-8\"\n *ngIf=\"selectedAlarm.count > 1\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Number of occurrences' | translate }}</p>\n <p>\n <span class=\"badge badge-info\">{{ selectedAlarm.count }}</span>\n </p>\n </div>\n <div\n class=\"col-4 p-b-8\"\n *ngIf=\"selectedAlarm.count > 1\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'First occurrence' | translate }}</p>\n <p class=\"small\">\n {{ selectedAlarm.creationTime | c8yDate: 'medium' }}\n\n <button\n class=\"btn-help btn-help--sm\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Time in which the alarm was created. The time shown corresponds to the server\\'s time. Device time can be different from server time.'\n | translate\n }}\"\n placement=\"right\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n ></button>\n </p>\n </div>\n <div\n class=\"col-4 p-b-8\"\n data-cy=\"c8y-alarm-details--last-updated-wrapper\"\n >\n <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Last occurrence' | translate }}</p>\n <p class=\"small\">\n {{ selectedAlarm.lastUpdated | c8yDate: 'medium' }}\n\n <button\n class=\"btn-help btn-help--sm\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Time in which the alarm was last updated. The time shown corresponds to the server\\'s time. Device time can be different from server time.'\n | translate\n }}\"\n placement=\"right\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n ></button>\n </p>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div\n class=\"col-xs-12 col-md-12 p-b-16\"\n *ngIf=\"customFragments\"\n >\n <div class=\"border-all fit-w d-flex\">\n <div class=\"p-8\">\n <i\n class=\"icon-24 text-gray-dark m-t-4\"\n c8yIcon=\"outgoing-data\"\n ></i>\n </div>\n <div\n class=\"p-t-8 p-b-0 p-r-8 flex-grow\"\n data-cy=\"alarm-details-custom-data\"\n >\n <p class=\"text-label-small m-b-4 m-r-8\">{{ 'Custom data' | translate }}</p>\n <pre><code>{{ customFragments | json }}</code></pre>\n </div>\n </div>\n </div>\n</div>\n\n<div class=\"d-flex flex-wrap gap-8\">\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Reload audit logs' | translate\"\n type=\"submit\"\n (click)=\"reloadAuditLog(true, true)\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading }\"\n ></i>\n {{ 'Reload audit logs' | translate }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? (ACKNOWLEDGE_LABEL | translate)\n : (REACTIVATE_LABEL | translate)\n \"\n type=\"submit\"\n (click)=\"\n onUpdateDetails(\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? ACKNOWLEDGED_STATUS_VALUE\n : ACTIVE_STATUS_VALUE\n )\n \"\n [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE || isAlarmStatusChanging\"\n >\n <i\n [c8yIcon]=\"selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE ? BELL_SLASH_ICON : BELL_ICON\"\n ></i>\n {{\n selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n ? (ACKNOWLEDGE_LABEL | translate)\n : (REACTIVATE_LABEL | translate)\n }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Create smart rule' | translate\"\n type=\"submit\"\n *ngIf=\"isCreateSmartRulesButtonAvailable\"\n (click)=\"createSmartRule()\"\n >\n <i c8yIcon=\"c8y-icon c8y-icon-smart-rules\"></i>\n {{ 'Create smart rule' | translate }}\n </button>\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"'Clear`alarm`' | translate\"\n type=\"submit\"\n (click)=\"onUpdateDetails(CLEARED_STATUS_VALUE)\"\n [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE\"\n >\n <i c8yIcon=\"c8y-alert-idle\"></i>\n {{ 'Clear`alarm`' | translate }}\n </button>\n\n <button\n class=\"btn btn-default btn-sm\"\n [title]=\"button.title | translate\"\n type=\"button\"\n *ngFor=\"let button of selectedAlarm | alarmDetailsButton: selectedAlarmMO | async\"\n [ngClass]=\"button.additionalButtonClasses\"\n (click)=\"detailsButtonAction(button, selectedAlarm)\"\n [disabled]=\"button.disabled\"\n >\n <i\n [c8yIcon]=\"button.icon\"\n [ngClass]=\"button.additionalIconClasses\"\n ></i>\n <span *ngIf=\"button.label\">{{ button.label | translate }}</span>\n </button>\n</div>\n\n<ng-template #noAuditLogAvailable>\n <div class=\"p-16\">\n <c8y-ui-empty-state\n [icon]=\"'archive'\"\n [title]=\"'No audit logs found.' | translate\"\n [horizontal]=\"true\"\n ></c8y-ui-empty-state>\n </div>\n</ng-template>\n\n<div class=\"legend form-block\">{{ 'Audit logs' | translate }}</div>\n\n<ng-container *ngIf=\"isLoading || auditLog?.data.length; else noAuditLogAvailable\">\n <c8y-loading *ngIf=\"isLoading\"></c8y-loading>\n\n <c8y-list-group\n data-cy=\"c8y-alarms-details--audit-logs\"\n *ngIf=\"!isLoading\"\n >\n <c8y-li-timeline *c8yFor=\"let log of auditLog; loadMore: 'hidden'\">\n {{ log.creationTime | date: 'mediumDate' }}\n {{ log.creationTime | date: 'mediumTime' }}\n <c8y-li>\n <c8y-li-body>\n <p class=\"text-truncate-wrap separator-bottom p-b-4\">\n {{ log | auditChangesMessage }}\n </p>\n <div class=\"c8y-list__item__footer\">\n <span\n class=\"m-r-16 small\"\n *ngIf=\"log.user\"\n >\n <span class=\"text-label-small\">\n {{ 'by`user`' | translate }}\n </span>\n {{ log.user }}\n </span>\n <span class=\"small\">\n <span class=\"text-label-small\">\n {{ 'device time' | translate }}\n </span>\n {{ log.time | c8yDate: 'medium' }}\n </span>\n </div>\n </c8y-li-body>\n </c8y-li>\n </c8y-li-timeline>\n </c8y-list-group>\n</ng-container>\n" }]
346
346
  }], ctorParameters: () => [{ type: i1.AlarmDetailsService }, { type: i2.AlarmService }, { type: i3.AlertService }, { type: i3.AppStateService }, { type: i2.AuditService }, { type: i3.RelativeTimePipe }, { type: i4.Ng1SmartRulesUpgradeService, decorators: [{
347
347
  type: Optional
348
348
  }] }, { type: i5.TranslateService }, { type: i2.InventoryService }, { type: i6.AlarmsViewService }, { type: i3.ColorService }], propDecorators: { selectedAlarm: [{
349
349
  type: Input
350
350
  }] } });
351
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarm-details.component.js","sourceRoot":"","sources":["../../../alarms/alarm-details.component.ts","../../../alarms/alarm-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, Optional, SimpleChanges } from '@angular/core';\nimport {\n  ALARM_STATUS_LABELS,\n  AlarmStatus,\n  AlarmService,\n  AlarmStatusType,\n  AuditService,\n  IAlarm,\n  IApplication,\n  IAuditRecord,\n  IManagedObject,\n  IResultList,\n  InventoryService,\n  SEVERITY_LABELS\n} from '@c8y/client';\nimport {\n  AlertService,\n  AppStateService,\n  ColorService,\n  RelativeTimePipe,\n  gettext\n} from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { cloneDeep } from 'lodash-es';\nimport { AlarmDetailsService } from './alarm-details.service';\nimport {\n  ALARM_DEFAULT_PROPERTIES,\n  ALARM_STATUS_ICON,\n  AlarmDetailsButton,\n  CustomFragment\n} from './alarms.model';\nimport { Ng1SmartRulesUpgradeService } from './ng1-smart-rules-upgrade.service';\nimport { AlarmsViewService } from './alarms-view.service';\n\n@Component({\n  selector: 'c8y-alarm-details',\n  templateUrl: './alarm-details.component.html'\n})\nexport class AlarmDetailsComponent implements OnChanges {\n  @Input() selectedAlarm: IAlarm;\n\n  readonly ACKNOWLEDGED_STATUS_VALUE = AlarmStatus.ACKNOWLEDGED;\n  readonly ACTIVE_STATUS_VALUE = AlarmStatus.ACTIVE;\n  readonly CLEARED_STATUS_VALUE = AlarmStatus.CLEARED;\n  readonly ACKNOWLEDGE_LABEL = gettext('Acknowledge');\n  readonly REACTIVATE_LABEL = gettext('Reactivate');\n  readonly SEVERITY_LABELS = SEVERITY_LABELS;\n  readonly BELL_SLASH_ICON = ALARM_STATUS_ICON.BELL_SLASH;\n  readonly BELL_ICON = ALARM_STATUS_ICON.BELL;\n\n  /**\n   * Represents a Device Management application used by the user.\n   * Determines the accurate name and context path required for navigating to alarms of the current device\n   */\n  userDeviceManagementApp: IApplication;\n  /**\n   * Manages the visibility of the navigation link.\n   * If set to true, the link is visible, otherwise, it remains hidden.\n   */\n  showSourceNavigationLink = false;\n  readonly linkTitle = gettext('Open in {{ appName }}');\n  /**\n   * Contains audit logs, including the very first audit log record in the alarms' history.\n   * This ensures that the historical starting point of the audit logs is always included in the data set.\n   * Usually it's an 'Alarm created' audit log.\n   *\n   * Only used when audit logs exceed PAGE_SIZE.\n   *\n   * @private\n   */\n  private extendedAuditLogs: IResultList<IAuditRecord>;\n  private readonly PAGE_SIZE = 100;\n\n  /**\n   * Prevents the pipeline from failing for a tutorial application\n   * because it's a pure Angular application and doesn't support any\n   * AngularJS services.\n   */\n  isCreateSmartRulesButtonAvailable: boolean;\n  /**\n   * Property contains a 100 (see PAGE_SIZE) of most recent audit logs records.\n   */\n  auditLog: IResultList<IAuditRecord>;\n\n  isLoading: boolean;\n  /**\n   * Indicates when alarms status change was started (Acknowledge/Reactivate)\n   */\n  isAlarmStatusChanging = false;\n  /**\n   * Represents a value for a 'Last updated' section in details.\n   */\n  lastUpdated: string;\n  /**\n   * Represents a value for a 'Status' section in details.\n   */\n  statusMessage: string;\n  /**\n   * The color of the alarm type.\n   */\n  typeColor: string;\n  /**\n   * Custom fragments of the selected alarm. If none exist, null is returned.\n   */\n  customFragments: CustomFragment = null;\n\n  selectedAlarmMO: IManagedObject;\n\n  constructor(\n    private alarmDetailsService: AlarmDetailsService,\n    private alarmService: AlarmService,\n    private alertService: AlertService,\n    private appState: AppStateService,\n    private auditService: AuditService,\n    private relativeTime: RelativeTimePipe,\n    @Optional() private ng1SmartRulesUpgradeService: Ng1SmartRulesUpgradeService,\n    private translateService: TranslateService,\n    private inventoryService: InventoryService,\n    private alarmsViewService: AlarmsViewService,\n    private colorService: ColorService\n  ) {}\n\n  async ngOnInit(): Promise<void> {\n    const isSmartRulesServiceSubscribed = !!(await this.alarmDetailsService.getApplication(\n      this.alarmDetailsService.SMART_RULES_APPLICATION_KEY\n    ));\n    const hasAnyRoleAllowingToCreateSmartRule =\n      this.alarmDetailsService.checkIfHasAnyRoleAllowingToCreateSmartRule();\n    this.isCreateSmartRulesButtonAvailable =\n      !!this.ng1SmartRulesUpgradeService &&\n      isSmartRulesServiceSubscribed &&\n      hasAnyRoleAllowingToCreateSmartRule;\n    this.userDeviceManagementApp = await this.alarmDetailsService.getApplication(\n      this.alarmDetailsService.DEVICE_MANAGEMENT_APPLICATION_KEY\n    );\n    this.showSourceNavigationLink =\n      !!this.userDeviceManagementApp && !this.isDeviceManagementView();\n    this.typeColor = await this.colorService.generateColor(this.selectedAlarm.type);\n  }\n\n  async ngOnChanges(changes: SimpleChanges): Promise<void> {\n    if (changes.selectedAlarm && changes.selectedAlarm.currentValue) {\n      await this.reloadAuditLog(true, true);\n      await this.updateStatusMessage();\n      const { data } = await this.inventoryService.detail(this.selectedAlarm.source.id);\n      this.selectedAlarmMO = data;\n      this.updateLastUpdatedDate(this.auditLog.data[0]);\n      this.customFragments = this.getCustomFragments(this.selectedAlarm);\n    }\n  }\n\n  createSmartRule(): void {\n    if (!this.isCreateSmartRulesButtonAvailable) {\n      return;\n    }\n    this.ng1SmartRulesUpgradeService.addNewForInputAlarmAndOutputUserWithUI(\n      this.selectedAlarm,\n      this.appState.currentUser.value\n    );\n  }\n\n  /**\n   * Navigates to a specific alarm source device based on the provided source.\n   *\n   * @param sourceId - The source id.\n   */\n  async goToAlarmSource(sourceId: string | number): Promise<void> {\n    const { data } = await this.alarmService.detail(sourceId);\n    const baseUrl = `/apps/${this.userDeviceManagementApp.contextPath}`;\n    const path = `#/device/${data.source.id}/alarms`;\n    const url = `${baseUrl}/${path}`;\n\n    window.open(url, '_blank');\n  }\n\n  /**\n   * Reloads audit log data asynchronously.\n   *\n   * This method fetches audit records using `getAlarmAuditRecords` and optionally updates the audit logs\n   * state in the component based on the `isSetAuditLogs` flag. It handles the loading state and potential\n   * errors during the fetch operation.\n   *\n   * @param isRevert - A boolean flag indicating whether to retrieve a 100 (see PAGE_SIZE) records (true)\n   *                   or only record, that chronologically will be the oldest one (false). Defaults to true.\n   *                   If set to false, it will set PAGE_SIZE to 1 and trigger a logic\n   *                   concatenating a most recent record with the very first one to\n   *                   calculate the alarm duration (change to CLEARED status).\n   *                   It's passed to the `getAlarmAuditRecords` method.\n   * @param isSetAuditLogs - A boolean flag to determine if the fetched audit logs should be set in the component state. Defaults to `false`.\n   * @returns A promise that resolves to a list of `IAuditRecord` objects.\n   */\n  async reloadAuditLog(\n    isRevert = true,\n    isSetAuditLogs = false\n  ): Promise<IResultList<IAuditRecord>> {\n    try {\n      this.isLoading = true;\n      const auditLogs = await this.getAlarmAuditRecords(isRevert);\n\n      if (isSetAuditLogs) {\n        this.setAuditLogs(auditLogs);\n      }\n\n      return auditLogs;\n    } catch (error) {\n      this.alertService.addServerFailure(error);\n    } finally {\n      this.isLoading = false;\n    }\n  }\n\n  async onUpdateDetails(status: AlarmStatusType): Promise<void> {\n    try {\n      this.isAlarmStatusChanging = true;\n      await this.updateAlarmStatus(status);\n      await this.reloadAuditLog(true, true);\n      await this.updateStatusMessage();\n      this.updateLastUpdatedDate(this.auditLog.data[0]);\n    } catch (error) {\n      this.alertService.addServerFailure(error);\n    } finally {\n      this.isAlarmStatusChanging = false;\n    }\n  }\n\n  async detailsButtonAction(button: AlarmDetailsButton, alarm: IAlarm): Promise<void> {\n    const result = button.action(alarm);\n    let shouldReload: boolean | IAlarm = false;\n    if (result instanceof Promise) {\n      shouldReload = await result;\n    } else {\n      shouldReload = result;\n    }\n\n    if (shouldReload) {\n      let alarm: IAlarm;\n      if (shouldReload === true) {\n        const { data: updatedAlarm } = await this.alarmService.detail(this.selectedAlarm.id);\n        alarm = updatedAlarm;\n      } else {\n        alarm = shouldReload;\n      }\n      this.alarmsViewService.updateAlarmList();\n\n      const previousValue = this.selectedAlarm;\n      this.selectedAlarm = alarm;\n      this.ngOnChanges({\n        selectedAlarm: {\n          currentValue: alarm,\n          previousValue,\n          firstChange: false,\n          isFirstChange: () => false\n        }\n      });\n    }\n  }\n\n  private async updateAlarmStatus(status: AlarmStatusType): Promise<void> {\n    const partiallyUpdatedAlarm: Partial<IAlarm> = { id: this.selectedAlarm.id, status };\n    await this.alarmService.update(partiallyUpdatedAlarm);\n    const translatedStatusLabel = this.translateService.instant(ALARM_STATUS_LABELS[status]);\n    this.alertService.success(\n      this.translateService.instant(gettext('Alarm status changed to {{ status }}'), {\n        status: translatedStatusLabel.toUpperCase()\n      })\n    );\n    this.selectedAlarm.status = status;\n    this.alarmsViewService.updateAlarmList();\n  }\n\n  /**\n   * Retrieves the audit log and appends the last audit record to it.\n   *\n   * This method fetches the existing audit log data and makes a deep copy of it. It then\n   * retrieves the last audit record and appends it to the copied audit log data. This is\n   * useful for scenarios where the most recent audit record needs to be included in the\n   * existing audit log data (calculating the CLEARED period).\n   *\n   * @returns A promise of `IResultList<IAuditRecord>`, which includes the\n   *          existing audit log data along with the last audit record appended.\n   * @private\n   */\n  private async auditLogWithFirstRecord(): Promise<IResultList<IAuditRecord>> {\n    const existingData = this.auditLog;\n    const copiedExistingData = cloneDeep(existingData);\n\n    const lastAuditRecord = await this.reloadAuditLog(false);\n    const lastRecord = lastAuditRecord.data[lastAuditRecord.data.length - 1];\n    copiedExistingData.data.push(lastRecord);\n    return copiedExistingData;\n  }\n\n  private setAuditLogs(auditLogs: IResultList<IAuditRecord>): void {\n    this.auditLog = auditLogs;\n  }\n\n  private updateLastUpdatedDate(updatedAuditRecords: IAuditRecord): void {\n    if (!updatedAuditRecords) {\n      return;\n    }\n\n    const { creationTime } = updatedAuditRecords;\n    this.lastUpdated = creationTime;\n  }\n\n  private getActiveStatusMessage(time: string): string {\n    return this.translateService.instant(gettext('ACTIVE`alarm`: triggered {{alarmTimeFromNow}}'), {\n      alarmTimeFromNow: this.relativeTime.transform(new Date(time))\n    });\n  }\n\n  private getAcknowledgedStatusMessage(status: AlarmStatusType, changeLog: IAuditRecord[]): string {\n    if (changeLog.length === 0) {\n      return this.translateService.instant(gettext('ACKNOWLEDGED`alarm`'));\n    }\n\n    const acknowledgedBy = this.alarmDetailsService.getAcknowledgedBy(status, changeLog);\n    const acknowledgeTime = this.alarmDetailsService.getAcknowledgeTime(changeLog);\n\n    if (acknowledgedBy) {\n      return this.translateService.instant(\n        gettext('ACKNOWLEDGED`alarm` by: {{ackBy}} {{ackTimeFromNow}}'),\n        {\n          ackBy: acknowledgedBy,\n          ackTimeFromNow: this.relativeTime.transform(new Date(acknowledgeTime))\n        }\n      );\n    }\n\n    return this.translateService.instant(gettext('ACKNOWLEDGED`alarm` {{ackTimeFromNow}}'), {\n      ackTimeFromNow: this.relativeTime.transform(new Date(acknowledgeTime))\n    });\n  }\n\n  private getClearedStatusMessage(auditLog: IAuditRecord[]): string {\n    if (auditLog.length === 0) {\n      return this.translateService.instant(gettext('CLEARED`alarm`'));\n    }\n\n    const differenceInMs = this.calculateAlarmDuration(auditLog);\n\n    return this.translateService.instant(\n      gettext('CLEARED`alarm`: was active for {{alarmDuration}}'),\n      {\n        alarmDuration: this.relativeTime.transform(differenceInMs, true)\n      }\n    );\n  }\n\n  /**\n   * Calculates the duration of an alarm based on audit log records.\n   *\n   * This method computes the duration of an alarm by finding the difference\n   * between the start and end times of the alarm. The start time is determined\n   * from the last record in the audit log, using the first available time field\n   * (`firstOccurrenceTime`, `time`, or `creationTime`). The end time is obtained\n   * from the `alarmDetailsService`.\n   *\n   * @param auditLog - An array of `IAuditRecord` objects representing the audit log records.\n   * @returns The duration of the alarm in milliseconds, or `null` if the end time is not available.\n   * @private\n   */\n  private calculateAlarmDuration(auditLog: IAuditRecord[]): number | null {\n    const firstAlarm = auditLog[auditLog.length - 1];\n    const startTime = firstAlarm.firstOccurrenceTime || firstAlarm.time || firstAlarm.creationTime;\n    const endTime = this.alarmDetailsService.getEndTime(auditLog);\n\n    if (!endTime) {\n      return null;\n    }\n\n    const startTimeToDate = new Date(startTime);\n    const endTimeToDate = new Date(endTime);\n\n    return endTimeToDate.getTime() - startTimeToDate.getTime();\n  }\n\n  /**\n   * Retrieves a list of audit records for a selected alarm.\n   *\n   * This method fetches audit records based on the specified properties, including\n   * the date, page size, whether to revert, the source alarm ID, and whether to include total pages.\n   *\n   * @param isRevert - A boolean flag indicating whether to retrieve a 100 (see PAGE_SIZE) records (true)\n   *                   or only record, that chronologically will be the oldest one (false). Defaults to true.\n   *                   If set to false, it will set PAGE_SIZE to 1 and trigger a logic\n   *                   concatenating a most recent record with the very first one to\n   *                   calculate the alarm duration (change to CLEARED status).\n   * @returns A Promise that resolves to an IResultList of IAuditRecord objects, representing the audit records.\n   * @async\n   * @private\n   */\n  private async getAlarmAuditRecords(isRevert = true): Promise<IResultList<IAuditRecord>> {\n    const properties = {\n      dateTo: new Date(Date.now()).toISOString(),\n      pageSize: isRevert ? this.PAGE_SIZE : 1,\n      revert: isRevert,\n      source: this.selectedAlarm.id,\n      withTotalPages: true\n    };\n\n    return await this.auditService.list(properties);\n  }\n\n  private async updateStatusMessage(): Promise<void> {\n    switch (this.selectedAlarm.status) {\n      case this.ACTIVE_STATUS_VALUE:\n        this.statusMessage = this.getActiveStatusMessage(this.selectedAlarm.time);\n        break;\n      case this.ACKNOWLEDGED_STATUS_VALUE:\n        this.statusMessage = this.getAcknowledgedStatusMessage(\n          this.selectedAlarm.status as unknown as AlarmStatusType,\n          this.auditLog.data\n        );\n        break;\n      case this.CLEARED_STATUS_VALUE:\n        if (this.hasReachedOrExceededPageSizeLimit()) {\n          this.extendedAuditLogs = await this.auditLogWithFirstRecord();\n          this.statusMessage = this.getClearedStatusMessage(this.extendedAuditLogs.data);\n          return;\n        }\n        this.statusMessage = this.getClearedStatusMessage(this.auditLog.data);\n        break;\n    }\n  }\n\n  private hasReachedOrExceededPageSizeLimit(): boolean {\n    return this.auditLog.data.length >= this.PAGE_SIZE;\n  }\n\n  /**\n   * This method checks if the current URL includes the context path of the\n   * device management application, indicating whether the user is in the\n   * device management view.\n   *\n   * @returns Returns `true` if the current view is in device management, otherwise, returns `false`.\n   */\n  private isDeviceManagementView(): boolean {\n    return window.location.href.includes(this.userDeviceManagementApp.contextPath);\n  }\n\n  private getCustomFragments(selectedAlarm: IAlarm): CustomFragment {\n    let customProperties = null;\n    for (const key in selectedAlarm) {\n      if (!ALARM_DEFAULT_PROPERTIES.find(k => k === key)) {\n        if (!customProperties) {\n          customProperties = {};\n        }\n        customProperties[key] = selectedAlarm[key];\n      }\n    }\n\n    return customProperties;\n  }\n}\n","<div class=\"d-flex row tight-grid flex-wrap a-i-stretch\">\n  <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4 c8y-icon\"\n          [c8yIcon]=\"selectedAlarm.status | AlarmStatusToIcon\"\n        ></i>\n      </div>\n      <div class=\"p-t-8 p-b-8 p-r-8\">\n        <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Status' | translate }}</p>\n        <p class=\"small\">{{ statusMessage }}</p>\n      </div>\n    </div>\n  </div>\n  <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n          [c8yIcon]=\"selectedAlarm.severity | AlarmSeverityToIcon\"\n          [ngClass]=\"selectedAlarm.severity?.toString() | lowercase\"\n        ></i>\n      </div>\n      <div class=\"p-t-8 p-b-8 p-r-8\">\n        <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Severity' | translate }}</p>\n        <p class=\"small\">{{ SEVERITY_LABELS[selectedAlarm.severity] | translate }}</p>\n      </div>\n    </div>\n  </div>\n  <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n          c8yIcon=\"contactless-payment\"\n        ></i>\n      </div>\n      <div class=\"p-t-8 p-b-8 p-r-8\">\n        <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Source' | translate }}</p>\n        <p class=\"small\">\n          <button\n            class=\"btn-link text-muted p-0 m-r-8 text-left\"\n            title=\"{{ selectedAlarm.source.name }}\"\n            type=\"button\"\n            routerLink=\"{{ selectedAlarmMO | assetLink }}\"\n          >\n            <small class=\"icon-flex\">\n              <i c8yIcon=\"exchange\"></i>\n              {{ selectedAlarm.source.name || selectedAlarm.source.id }}\n            </small>\n          </button>\n          <ng-container *ngIf=\"showSourceNavigationLink\">\n            <button\n              class=\"btn-link p-0 text-left\"\n              title=\"{{\n                linkTitle\n                  | translate: { appName: userDeviceManagementApp | humanizeAppName | async }\n              }}\"\n              type=\"button\"\n              (click)=\"goToAlarmSource(selectedAlarm.id)\"\n              data-cy=\"alarm-details-device-management-link\"\n            >\n              {{ userDeviceManagementApp | humanizeAppName | async }}\n              <i c8yIcon=\"external-link\"></i>\n            </button>\n          </ng-container>\n        </p>\n      </div>\n    </div>\n  </div>\n  <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <span\n          class=\"circle-icon-wrapper\"\n          [ngStyle]=\"{ 'background-color': typeColor }\"\n        >\n          <i\n            class=\"stroked-icon\"\n            c8yIcon=\"bell\"\n          ></i>\n        </span>\n      </div>\n      <div class=\"p-t-8 p-b-8 p-r-8 min-width-0\">\n        <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Type' | translate }}</p>\n        <p\n          class=\"small text-truncate\"\n          title=\"{{ selectedAlarm.type }}\"\n        >\n          <code>{{ selectedAlarm.type }}</code>\n        </p>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"col-xs-12 col-md-12 p-b-16\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4\"\n          c8yIcon=\"calendar\"\n        ></i>\n      </div>\n      <div class=\"p-t-8 p-b-0 p-r-8 flex-grow\">\n        <div class=\"content-flex-50\">\n          <div class=\"col-4 p-b-8\">\n            <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Last updated' | translate }}</p>\n            <p class=\"small\">\n              {{ lastUpdated | c8yDate: 'medium' }}\n            </p>\n          </div>\n          <div\n            class=\"col-4 p-b-8\"\n            *ngIf=\"selectedAlarm.count > 1\"\n          >\n            <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Number of occurrences' | translate }}</p>\n            <p>\n              <span class=\"badge badge-info\">{{ selectedAlarm.count }}</span>\n            </p>\n          </div>\n          <div\n            class=\"col-4 p-b-8\"\n            *ngIf=\"selectedAlarm.count > 1\"\n          >\n            <p class=\"text-label-small m-b-0 m-r-8\">{{ 'First occurrence' | translate }}</p>\n            <p class=\"small\">\n              {{ selectedAlarm.creationTime | c8yDate: 'medium' }}\n            </p>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div\n    class=\"col-xs-12 col-md-12 p-b-16\"\n    *ngIf=\"customFragments\"\n  >\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4\"\n          c8yIcon=\"outgoing-data\"\n        ></i>\n      </div>\n      <div\n        class=\"p-t-8 p-b-0 p-r-8 flex-grow\"\n        data-cy=\"alarm-details-custom-data\"\n      >\n        <p class=\"text-label-small m-b-4 m-r-8\">{{ 'Custom data' | translate }}</p>\n        <pre><code>{{ customFragments | json }}</code></pre>\n      </div>\n    </div>\n  </div>\n</div>\n\n<div class=\"d-flex flex-wrap gap-8\">\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"'Reload audit logs' | translate\"\n    type=\"submit\"\n    (click)=\"reloadAuditLog(true, true)\"\n  >\n    <i\n      c8yIcon=\"refresh\"\n      [ngClass]=\"{ 'icon-spin': isLoading }\"\n    ></i>\n    {{ 'Reload audit logs' | translate }}\n  </button>\n\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"\n      selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n        ? (ACKNOWLEDGE_LABEL | translate)\n        : (REACTIVATE_LABEL | translate)\n    \"\n    type=\"submit\"\n    (click)=\"\n      onUpdateDetails(\n        selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n          ? ACKNOWLEDGED_STATUS_VALUE\n          : ACTIVE_STATUS_VALUE\n      )\n    \"\n    [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE || isAlarmStatusChanging\"\n  >\n    <i\n      [c8yIcon]=\"selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE ? BELL_SLASH_ICON : BELL_ICON\"\n    ></i>\n    {{\n      selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n        ? (ACKNOWLEDGE_LABEL | translate)\n        : (REACTIVATE_LABEL | translate)\n    }}\n  </button>\n\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"'Create smart rule' | translate\"\n    type=\"submit\"\n    *ngIf=\"isCreateSmartRulesButtonAvailable\"\n    (click)=\"createSmartRule()\"\n  >\n    <i c8yIcon=\"c8y-icon c8y-icon-smart-rules\"></i>\n    {{ 'Create smart rule' | translate }}\n  </button>\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"'Clear`alarm`' | translate\"\n    type=\"submit\"\n    (click)=\"onUpdateDetails(CLEARED_STATUS_VALUE)\"\n    [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE\"\n  >\n    <i c8yIcon=\"c8y-alert-idle\"></i>\n    {{ 'Clear`alarm`' | translate }}\n  </button>\n\n  <button\n    *ngFor=\"let button of selectedAlarm | alarmDetailsButton: selectedAlarmMO | async\"\n    class=\"btn btn-default btn-sm\"\n    [ngClass]=\"button.additionalButtonClasses\"\n    [title]=\"button.title | translate\"\n    type=\"button\"\n    (click)=\"detailsButtonAction(button, selectedAlarm)\"\n    [disabled]=\"button.disabled\"\n  >\n    <i [ngClass]=\"button.additionalIconClasses\" [c8yIcon]=\"button.icon\"></i>\n    <span *ngIf=\"button.label\">{{ button.label | translate }}</span>\n  </button>\n</div>\n\n<ng-template #noAuditLogAvailable>\n  <div class=\"p-16\">\n    <c8y-ui-empty-state\n      [icon]=\"'archive'\"\n      [title]=\"'No audit logs found.' | translate\"\n      [horizontal]=\"true\"\n    ></c8y-ui-empty-state>\n  </div>\n</ng-template>\n\n<div class=\"legend form-block\">{{ 'Audit logs' | translate }}</div>\n\n<ng-container *ngIf=\"isLoading || auditLog?.data.length; else noAuditLogAvailable\">\n  <c8y-loading *ngIf=\"isLoading\"></c8y-loading>\n\n  <c8y-list-group\n    data-cy=\"c8y-alarms-details--audit-logs\"\n    *ngIf=\"!isLoading\"\n  >\n    <c8y-li-timeline *c8yFor=\"let log of auditLog; loadMore: 'hidden'\">\n      {{ log.creationTime | date: 'mediumDate' }}\n      {{ log.creationTime | date: 'mediumTime' }}\n      <c8y-li>\n        <c8y-li-body>\n          <p class=\"text-truncate-wrap separator-bottom p-b-4\">\n            {{ log | auditChangesMessage }}\n          </p>\n          <div class=\"c8y-list__item__footer\">\n            <span\n              class=\"m-r-16 small\"\n              *ngIf=\"log.user\"\n            >\n              <span class=\"text-label-small\">\n                {{ 'by`user`' | translate }}\n              </span>\n              {{ log.user }}\n            </span>\n            <span class=\"small\">\n              <span class=\"text-label-small\">\n                {{ 'device time' | translate }}\n              </span>\n              {{ log.time | c8yDate: 'medium' }}\n            </span>\n          </div>\n        </c8y-li-body>\n      </c8y-li>\n    </c8y-li-timeline>\n  </c8y-list-group>\n</ng-container>\n"]}
351
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarm-details.component.js","sourceRoot":"","sources":["../../../alarms/alarm-details.component.ts","../../../alarms/alarm-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, Optional, SimpleChanges } from '@angular/core';\nimport {\n  ALARM_STATUS_LABELS,\n  AlarmStatus,\n  AlarmService,\n  AlarmStatusType,\n  AuditService,\n  IAlarm,\n  IApplication,\n  IAuditRecord,\n  IManagedObject,\n  IResultList,\n  InventoryService,\n  SEVERITY_LABELS\n} from '@c8y/client';\nimport {\n  AlertService,\n  AppStateService,\n  ColorService,\n  RelativeTimePipe,\n  gettext\n} from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { cloneDeep } from 'lodash-es';\nimport { AlarmDetailsService } from './alarm-details.service';\nimport {\n  ALARM_DEFAULT_PROPERTIES,\n  ALARM_STATUS_ICON,\n  AlarmDetailsButton,\n  CustomFragment\n} from './alarms.model';\nimport { Ng1SmartRulesUpgradeService } from './ng1-smart-rules-upgrade.service';\nimport { AlarmsViewService } from './alarms-view.service';\n\n@Component({\n  selector: 'c8y-alarm-details',\n  templateUrl: './alarm-details.component.html'\n})\nexport class AlarmDetailsComponent implements OnChanges {\n  @Input() selectedAlarm: IAlarm;\n\n  readonly ACKNOWLEDGED_STATUS_VALUE = AlarmStatus.ACKNOWLEDGED;\n  readonly ACTIVE_STATUS_VALUE = AlarmStatus.ACTIVE;\n  readonly CLEARED_STATUS_VALUE = AlarmStatus.CLEARED;\n  readonly ACKNOWLEDGE_LABEL = gettext('Acknowledge');\n  readonly REACTIVATE_LABEL = gettext('Reactivate');\n  readonly SEVERITY_LABELS = SEVERITY_LABELS;\n  readonly BELL_SLASH_ICON = ALARM_STATUS_ICON.BELL_SLASH;\n  readonly BELL_ICON = ALARM_STATUS_ICON.BELL;\n\n  /**\n   * Represents a Device Management application used by the user.\n   * Determines the accurate name and context path required for navigating to alarms of the current device\n   */\n  userDeviceManagementApp: IApplication;\n  /**\n   * Manages the visibility of the navigation link.\n   * If set to true, the link is visible, otherwise, it remains hidden.\n   */\n  showSourceNavigationLink = false;\n  readonly linkTitle = gettext('Open in {{ appName }}');\n  /**\n   * Contains audit logs, including the very first audit log record in the alarms' history.\n   * This ensures that the historical starting point of the audit logs is always included in the data set.\n   * Usually it's an 'Alarm created' audit log.\n   *\n   * Only used when audit logs exceed PAGE_SIZE.\n   *\n   * @private\n   */\n  private extendedAuditLogs: IResultList<IAuditRecord>;\n  private readonly PAGE_SIZE = 100;\n\n  /**\n   * Prevents the pipeline from failing for a tutorial application\n   * because it's a pure Angular application and doesn't support any\n   * AngularJS services.\n   */\n  isCreateSmartRulesButtonAvailable: boolean;\n  /**\n   * Property contains a 100 (see PAGE_SIZE) of most recent audit logs records.\n   */\n  auditLog: IResultList<IAuditRecord>;\n\n  isLoading: boolean;\n  /**\n   * Indicates when alarms status change was started (Acknowledge/Reactivate)\n   */\n  isAlarmStatusChanging = false;\n  /**\n   * Represents a value for a 'Status' section in details.\n   */\n  statusMessage: string;\n  /**\n   * The color of the alarm type.\n   */\n  typeColor: string;\n  /**\n   * Custom fragments of the selected alarm. If none exist, null is returned.\n   */\n  customFragments: CustomFragment = null;\n\n  selectedAlarmMO: IManagedObject;\n\n  constructor(\n    private alarmDetailsService: AlarmDetailsService,\n    private alarmService: AlarmService,\n    private alertService: AlertService,\n    private appState: AppStateService,\n    private auditService: AuditService,\n    private relativeTime: RelativeTimePipe,\n    @Optional() private ng1SmartRulesUpgradeService: Ng1SmartRulesUpgradeService,\n    private translateService: TranslateService,\n    private inventoryService: InventoryService,\n    private alarmsViewService: AlarmsViewService,\n    private colorService: ColorService\n  ) {}\n\n  async ngOnInit(): Promise<void> {\n    const isSmartRulesServiceSubscribed = !!(await this.alarmDetailsService.getApplication(\n      this.alarmDetailsService.SMART_RULES_APPLICATION_KEY\n    ));\n    const hasAnyRoleAllowingToCreateSmartRule =\n      this.alarmDetailsService.checkIfHasAnyRoleAllowingToCreateSmartRule();\n    this.isCreateSmartRulesButtonAvailable =\n      !!this.ng1SmartRulesUpgradeService &&\n      isSmartRulesServiceSubscribed &&\n      hasAnyRoleAllowingToCreateSmartRule;\n    this.userDeviceManagementApp = await this.alarmDetailsService.getApplication(\n      this.alarmDetailsService.DEVICE_MANAGEMENT_APPLICATION_KEY\n    );\n    this.showSourceNavigationLink =\n      !!this.userDeviceManagementApp && !this.isDeviceManagementView();\n    this.typeColor = await this.colorService.generateColor(this.selectedAlarm.type);\n  }\n\n  async ngOnChanges(changes: SimpleChanges): Promise<void> {\n    if (changes.selectedAlarm && changes.selectedAlarm.currentValue) {\n      await this.reloadAuditLog(true, true);\n      await this.updateStatusMessage();\n      const { data } = await this.inventoryService.detail(this.selectedAlarm.source.id);\n      this.selectedAlarmMO = data;\n      this.customFragments = this.getCustomFragments(this.selectedAlarm);\n    }\n  }\n\n  createSmartRule(): void {\n    if (!this.isCreateSmartRulesButtonAvailable) {\n      return;\n    }\n    this.ng1SmartRulesUpgradeService.addNewForInputAlarmAndOutputUserWithUI(\n      this.selectedAlarm,\n      this.appState.currentUser.value\n    );\n  }\n\n  /**\n   * Navigates to a specific alarm source device based on the provided source.\n   *\n   * @param sourceId - The source id.\n   */\n  async goToAlarmSource(sourceId: string | number): Promise<void> {\n    const { data } = await this.alarmService.detail(sourceId);\n    const baseUrl = `/apps/${this.userDeviceManagementApp.contextPath}`;\n    const path = `#/device/${data.source.id}/alarms`;\n    const url = `${baseUrl}/${path}`;\n\n    window.open(url, '_blank');\n  }\n\n  /**\n   * Reloads audit log data asynchronously.\n   *\n   * This method fetches audit records using `getAlarmAuditRecords` and optionally updates the audit logs\n   * state in the component based on the `isSetAuditLogs` flag. It handles the loading state and potential\n   * errors during the fetch operation.\n   *\n   * @param isRevert - A boolean flag indicating whether to retrieve a 100 (see PAGE_SIZE) records (true)\n   *                   or only record, that chronologically will be the oldest one (false). Defaults to true.\n   *                   If set to false, it will set PAGE_SIZE to 1 and trigger a logic\n   *                   concatenating a most recent record with the very first one to\n   *                   calculate the alarm duration (change to CLEARED status).\n   *                   It's passed to the `getAlarmAuditRecords` method.\n   * @param isSetAuditLogs - A boolean flag to determine if the fetched audit logs should be set in the component state. Defaults to `false`.\n   * @returns A promise that resolves to a list of `IAuditRecord` objects.\n   */\n  async reloadAuditLog(\n    isRevert = true,\n    isSetAuditLogs = false\n  ): Promise<IResultList<IAuditRecord>> {\n    try {\n      this.isLoading = true;\n      const auditLogs = await this.getAlarmAuditRecords(isRevert);\n\n      if (isSetAuditLogs) {\n        this.setAuditLogs(auditLogs);\n      }\n\n      return auditLogs;\n    } catch (error) {\n      this.alertService.addServerFailure(error);\n    } finally {\n      this.isLoading = false;\n    }\n  }\n\n  async onUpdateDetails(status: AlarmStatusType): Promise<void> {\n    try {\n      this.isAlarmStatusChanging = true;\n      await this.updateAlarmStatus(status);\n      await this.reloadAuditLog(true, true);\n      await this.updateStatusMessage();\n      this.updateLastUpdatedDate(this.auditLog.data[0]);\n    } catch (error) {\n      this.alertService.addServerFailure(error);\n    } finally {\n      this.isAlarmStatusChanging = false;\n    }\n  }\n\n  async detailsButtonAction(button: AlarmDetailsButton, alarm: IAlarm): Promise<void> {\n    const result = button.action(alarm);\n    let shouldReload: boolean | IAlarm = false;\n    if (result instanceof Promise) {\n      shouldReload = await result;\n    } else {\n      shouldReload = result;\n    }\n\n    if (shouldReload) {\n      let alarm: IAlarm;\n      if (shouldReload === true) {\n        const { data: updatedAlarm } = await this.alarmService.detail(this.selectedAlarm.id);\n        alarm = updatedAlarm;\n      } else {\n        alarm = shouldReload;\n      }\n      this.alarmsViewService.updateAlarmList();\n\n      const previousValue = this.selectedAlarm;\n      this.selectedAlarm = alarm;\n      this.ngOnChanges({\n        selectedAlarm: {\n          currentValue: alarm,\n          previousValue,\n          firstChange: false,\n          isFirstChange: () => false\n        }\n      });\n    }\n  }\n\n  private async updateAlarmStatus(status: AlarmStatusType): Promise<void> {\n    const partiallyUpdatedAlarm: Partial<IAlarm> = { id: this.selectedAlarm.id, status };\n    await this.alarmService.update(partiallyUpdatedAlarm);\n    const translatedStatusLabel = this.translateService.instant(ALARM_STATUS_LABELS[status]);\n    this.alertService.success(\n      this.translateService.instant(gettext('Alarm status changed to {{ status }}'), {\n        status: translatedStatusLabel.toUpperCase()\n      })\n    );\n    this.selectedAlarm.status = status;\n    this.alarmsViewService.updateAlarmList();\n  }\n\n  /**\n   * Retrieves the audit log and appends the last audit record to it.\n   *\n   * This method fetches the existing audit log data and makes a deep copy of it. It then\n   * retrieves the last audit record and appends it to the copied audit log data. This is\n   * useful for scenarios where the most recent audit record needs to be included in the\n   * existing audit log data (calculating the CLEARED period).\n   *\n   * @returns A promise of `IResultList<IAuditRecord>`, which includes the\n   *          existing audit log data along with the last audit record appended.\n   * @private\n   */\n  private async auditLogWithFirstRecord(): Promise<IResultList<IAuditRecord>> {\n    const existingData = this.auditLog;\n    const copiedExistingData = cloneDeep(existingData);\n\n    const lastAuditRecord = await this.reloadAuditLog(false);\n    const lastRecord = lastAuditRecord.data[lastAuditRecord.data.length - 1];\n    copiedExistingData.data.push(lastRecord);\n    return copiedExistingData;\n  }\n\n  private setAuditLogs(auditLogs: IResultList<IAuditRecord>): void {\n    this.auditLog = auditLogs;\n  }\n\n  private updateLastUpdatedDate(updatedAuditRecords: IAuditRecord): void {\n    if (!updatedAuditRecords) {\n      return;\n    }\n\n    const { creationTime } = updatedAuditRecords;\n    this.selectedAlarm.lastUpdated = creationTime;\n  }\n\n  private getActiveStatusMessage(time: string): string {\n    return this.translateService.instant(gettext('ACTIVE`alarm`: triggered {{alarmTimeFromNow}}'), {\n      alarmTimeFromNow: this.relativeTime.transform(new Date(time))\n    });\n  }\n\n  private getAcknowledgedStatusMessage(status: AlarmStatusType, changeLog: IAuditRecord[]): string {\n    if (changeLog.length === 0) {\n      return this.translateService.instant(gettext('ACKNOWLEDGED`alarm`'));\n    }\n\n    const acknowledgedBy = this.alarmDetailsService.getAcknowledgedBy(status, changeLog);\n    const acknowledgeTime = this.alarmDetailsService.getAcknowledgeTime(changeLog);\n\n    if (acknowledgedBy) {\n      return this.translateService.instant(\n        gettext('ACKNOWLEDGED`alarm` by: {{ackBy}} {{ackTimeFromNow}}'),\n        {\n          ackBy: acknowledgedBy,\n          ackTimeFromNow: this.relativeTime.transform(new Date(acknowledgeTime))\n        }\n      );\n    }\n\n    return this.translateService.instant(gettext('ACKNOWLEDGED`alarm` {{ackTimeFromNow}}'), {\n      ackTimeFromNow: this.relativeTime.transform(new Date(acknowledgeTime))\n    });\n  }\n\n  private getClearedStatusMessage(auditLog: IAuditRecord[]): string {\n    if (auditLog.length === 0) {\n      return this.translateService.instant(gettext('CLEARED`alarm`'));\n    }\n\n    const differenceInMs = this.calculateAlarmDuration(auditLog);\n\n    return this.translateService.instant(\n      gettext('CLEARED`alarm`: was active for {{alarmDuration}}'),\n      {\n        alarmDuration: this.relativeTime.transform(differenceInMs, true)\n      }\n    );\n  }\n\n  /**\n   * Calculates the duration of an alarm based on audit log records.\n   *\n   * This method computes the duration of an alarm by finding the difference\n   * between the start and end times of the alarm. The start time is determined\n   * from the last record in the audit log, using the first available time field\n   * (`firstOccurrenceTime`, `time`, or `creationTime`). The end time is obtained\n   * from the `alarmDetailsService`.\n   *\n   * @param auditLog - An array of `IAuditRecord` objects representing the audit log records.\n   * @returns The duration of the alarm in milliseconds, or `null` if the end time is not available.\n   * @private\n   */\n  private calculateAlarmDuration(auditLog: IAuditRecord[]): number | null {\n    const firstAlarm = auditLog[auditLog.length - 1];\n    const startTime = firstAlarm.firstOccurrenceTime || firstAlarm.time || firstAlarm.creationTime;\n    const endTime = this.alarmDetailsService.getEndTime(auditLog);\n\n    if (!endTime) {\n      return null;\n    }\n\n    const startTimeToDate = new Date(startTime);\n    const endTimeToDate = new Date(endTime);\n\n    return endTimeToDate.getTime() - startTimeToDate.getTime();\n  }\n\n  /**\n   * Retrieves a list of audit records for a selected alarm.\n   *\n   * This method fetches audit records based on the specified properties, including\n   * the date, page size, whether to revert, the source alarm ID, and whether to include total pages.\n   *\n   * @param isRevert - A boolean flag indicating whether to retrieve a 100 (see PAGE_SIZE) records (true)\n   *                   or only record, that chronologically will be the oldest one (false). Defaults to true.\n   *                   If set to false, it will set PAGE_SIZE to 1 and trigger a logic\n   *                   concatenating a most recent record with the very first one to\n   *                   calculate the alarm duration (change to CLEARED status).\n   * @returns A Promise that resolves to an IResultList of IAuditRecord objects, representing the audit records.\n   * @async\n   * @private\n   */\n  private async getAlarmAuditRecords(isRevert = true): Promise<IResultList<IAuditRecord>> {\n    const properties = {\n      dateTo: new Date(Date.now()).toISOString(),\n      pageSize: isRevert ? this.PAGE_SIZE : 1,\n      revert: isRevert,\n      source: this.selectedAlarm.id,\n      withTotalPages: true\n    };\n\n    return await this.auditService.list(properties);\n  }\n\n  private async updateStatusMessage(): Promise<void> {\n    switch (this.selectedAlarm.status) {\n      case this.ACTIVE_STATUS_VALUE:\n        this.statusMessage = this.getActiveStatusMessage(this.selectedAlarm.time);\n        break;\n      case this.ACKNOWLEDGED_STATUS_VALUE:\n        this.statusMessage = this.getAcknowledgedStatusMessage(\n          this.selectedAlarm.status as unknown as AlarmStatusType,\n          this.auditLog.data\n        );\n        break;\n      case this.CLEARED_STATUS_VALUE:\n        if (this.hasReachedOrExceededPageSizeLimit()) {\n          this.extendedAuditLogs = await this.auditLogWithFirstRecord();\n          this.statusMessage = this.getClearedStatusMessage(this.extendedAuditLogs.data);\n          return;\n        }\n        this.statusMessage = this.getClearedStatusMessage(this.auditLog.data);\n        break;\n    }\n  }\n\n  private hasReachedOrExceededPageSizeLimit(): boolean {\n    return this.auditLog.data.length >= this.PAGE_SIZE;\n  }\n\n  /**\n   * This method checks if the current URL includes the context path of the\n   * device management application, indicating whether the user is in the\n   * device management view.\n   *\n   * @returns Returns `true` if the current view is in device management, otherwise, returns `false`.\n   */\n  private isDeviceManagementView(): boolean {\n    return window.location.href.includes(this.userDeviceManagementApp.contextPath);\n  }\n\n  private getCustomFragments(selectedAlarm: IAlarm): CustomFragment {\n    let customProperties = null;\n    for (const key in selectedAlarm) {\n      if (!ALARM_DEFAULT_PROPERTIES.find(k => k === key)) {\n        if (!customProperties) {\n          customProperties = {};\n        }\n        customProperties[key] = selectedAlarm[key];\n      }\n    }\n\n    return customProperties;\n  }\n}\n","<div class=\"d-flex row tight-grid flex-wrap a-i-stretch\">\n  <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4 c8y-icon\"\n          [c8yIcon]=\"selectedAlarm.status | AlarmStatusToIcon\"\n        ></i>\n      </div>\n      <div class=\"p-t-8 p-b-8 p-r-8\">\n        <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Status' | translate }}</p>\n        <p class=\"small\">{{ statusMessage }}</p>\n      </div>\n    </div>\n  </div>\n  <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n          [c8yIcon]=\"selectedAlarm.severity | AlarmSeverityToIcon\"\n          [ngClass]=\"selectedAlarm.severity?.toString() | lowercase\"\n        ></i>\n      </div>\n      <div class=\"p-t-8 p-b-8 p-r-8\">\n        <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Severity' | translate }}</p>\n        <p class=\"small\">{{ SEVERITY_LABELS[selectedAlarm.severity] | translate }}</p>\n      </div>\n    </div>\n  </div>\n  <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4 stroked-icon status\"\n          c8yIcon=\"contactless-payment\"\n        ></i>\n      </div>\n      <div class=\"p-t-8 p-b-8 p-r-8\">\n        <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Source' | translate }}</p>\n        <p class=\"small\">\n          <button\n            class=\"btn-link text-muted p-0 m-r-8 text-left\"\n            title=\"{{ selectedAlarm.source.name }}\"\n            type=\"button\"\n            routerLink=\"{{ selectedAlarmMO | assetLink }}\"\n          >\n            <small class=\"icon-flex\">\n              <i c8yIcon=\"exchange\"></i>\n              {{ selectedAlarm.source.name || selectedAlarm.source.id }}\n            </small>\n          </button>\n          <ng-container *ngIf=\"showSourceNavigationLink\">\n            <button\n              class=\"btn-link p-0 text-left\"\n              title=\"{{\n                linkTitle\n                  | translate: { appName: userDeviceManagementApp | humanizeAppName | async }\n              }}\"\n              type=\"button\"\n              (click)=\"goToAlarmSource(selectedAlarm.id)\"\n              data-cy=\"alarm-details-device-management-link\"\n            >\n              {{ userDeviceManagementApp | humanizeAppName | async }}\n              <i c8yIcon=\"external-link\"></i>\n            </button>\n          </ng-container>\n        </p>\n      </div>\n    </div>\n  </div>\n  <div class=\"col-xs-12 col-md-6 d-flex p-b-8\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <span\n          class=\"circle-icon-wrapper\"\n          [ngStyle]=\"{ 'background-color': typeColor }\"\n        >\n          <i\n            class=\"stroked-icon\"\n            c8yIcon=\"bell\"\n          ></i>\n        </span>\n      </div>\n      <div class=\"p-t-8 p-b-8 p-r-8 min-width-0\">\n        <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Type' | translate }}</p>\n        <p\n          class=\"small text-truncate\"\n          title=\"{{ selectedAlarm.type }}\"\n        >\n          <code>{{ selectedAlarm.type }}</code>\n        </p>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"col-xs-12 col-md-12 p-b-16\">\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4\"\n          c8yIcon=\"calendar\"\n          data-cy=\"c8y-alarm-details--last-updated-icon\"\n        ></i>\n      </div>\n      <div class=\"p-t-8 p-b-0 p-r-8 flex-grow\">\n        <div class=\"content-flex-50\">\n          <div\n            class=\"col-4 p-b-8\"\n            *ngIf=\"selectedAlarm.count > 1\"\n          >\n            <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Number of occurrences' | translate }}</p>\n            <p>\n              <span class=\"badge badge-info\">{{ selectedAlarm.count }}</span>\n            </p>\n          </div>\n          <div\n            class=\"col-4 p-b-8\"\n            *ngIf=\"selectedAlarm.count > 1\"\n          >\n            <p class=\"text-label-small m-b-0 m-r-8\">{{ 'First occurrence' | translate }}</p>\n            <p class=\"small\">\n              {{ selectedAlarm.creationTime | c8yDate: 'medium' }}\n\n              <button\n                class=\"btn-help btn-help--sm\"\n                [attr.aria-label]=\"'Help' | translate\"\n                popover=\"{{\n                  'Time in which the alarm was created. The time shown corresponds to the server\\'s time. Device time can be different from server time.'\n                    | translate\n                }}\"\n                placement=\"right\"\n                triggers=\"focus\"\n                container=\"body\"\n                type=\"button\"\n              ></button>\n            </p>\n          </div>\n          <div\n            class=\"col-4 p-b-8\"\n            data-cy=\"c8y-alarm-details--last-updated-wrapper\"\n          >\n            <p class=\"text-label-small m-b-0 m-r-8\">{{ 'Last occurrence' | translate }}</p>\n            <p class=\"small\">\n              {{ selectedAlarm.lastUpdated | c8yDate: 'medium' }}\n\n              <button\n                class=\"btn-help btn-help--sm\"\n                [attr.aria-label]=\"'Help' | translate\"\n                popover=\"{{\n                  'Time in which the alarm was last updated. The time shown corresponds to the server\\'s time. Device time can be different from server time.'\n                    | translate\n                }}\"\n                placement=\"right\"\n                triggers=\"focus\"\n                container=\"body\"\n                type=\"button\"\n              ></button>\n            </p>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div\n    class=\"col-xs-12 col-md-12 p-b-16\"\n    *ngIf=\"customFragments\"\n  >\n    <div class=\"border-all fit-w d-flex\">\n      <div class=\"p-8\">\n        <i\n          class=\"icon-24 text-gray-dark m-t-4\"\n          c8yIcon=\"outgoing-data\"\n        ></i>\n      </div>\n      <div\n        class=\"p-t-8 p-b-0 p-r-8 flex-grow\"\n        data-cy=\"alarm-details-custom-data\"\n      >\n        <p class=\"text-label-small m-b-4 m-r-8\">{{ 'Custom data' | translate }}</p>\n        <pre><code>{{ customFragments | json }}</code></pre>\n      </div>\n    </div>\n  </div>\n</div>\n\n<div class=\"d-flex flex-wrap gap-8\">\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"'Reload audit logs' | translate\"\n    type=\"submit\"\n    (click)=\"reloadAuditLog(true, true)\"\n  >\n    <i\n      c8yIcon=\"refresh\"\n      [ngClass]=\"{ 'icon-spin': isLoading }\"\n    ></i>\n    {{ 'Reload audit logs' | translate }}\n  </button>\n\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"\n      selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n        ? (ACKNOWLEDGE_LABEL | translate)\n        : (REACTIVATE_LABEL | translate)\n    \"\n    type=\"submit\"\n    (click)=\"\n      onUpdateDetails(\n        selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n          ? ACKNOWLEDGED_STATUS_VALUE\n          : ACTIVE_STATUS_VALUE\n      )\n    \"\n    [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE || isAlarmStatusChanging\"\n  >\n    <i\n      [c8yIcon]=\"selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE ? BELL_SLASH_ICON : BELL_ICON\"\n    ></i>\n    {{\n      selectedAlarm.status !== ACKNOWLEDGED_STATUS_VALUE\n        ? (ACKNOWLEDGE_LABEL | translate)\n        : (REACTIVATE_LABEL | translate)\n    }}\n  </button>\n\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"'Create smart rule' | translate\"\n    type=\"submit\"\n    *ngIf=\"isCreateSmartRulesButtonAvailable\"\n    (click)=\"createSmartRule()\"\n  >\n    <i c8yIcon=\"c8y-icon c8y-icon-smart-rules\"></i>\n    {{ 'Create smart rule' | translate }}\n  </button>\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"'Clear`alarm`' | translate\"\n    type=\"submit\"\n    (click)=\"onUpdateDetails(CLEARED_STATUS_VALUE)\"\n    [disabled]=\"selectedAlarm.status === CLEARED_STATUS_VALUE\"\n  >\n    <i c8yIcon=\"c8y-alert-idle\"></i>\n    {{ 'Clear`alarm`' | translate }}\n  </button>\n\n  <button\n    class=\"btn btn-default btn-sm\"\n    [title]=\"button.title | translate\"\n    type=\"button\"\n    *ngFor=\"let button of selectedAlarm | alarmDetailsButton: selectedAlarmMO | async\"\n    [ngClass]=\"button.additionalButtonClasses\"\n    (click)=\"detailsButtonAction(button, selectedAlarm)\"\n    [disabled]=\"button.disabled\"\n  >\n    <i\n      [c8yIcon]=\"button.icon\"\n      [ngClass]=\"button.additionalIconClasses\"\n    ></i>\n    <span *ngIf=\"button.label\">{{ button.label | translate }}</span>\n  </button>\n</div>\n\n<ng-template #noAuditLogAvailable>\n  <div class=\"p-16\">\n    <c8y-ui-empty-state\n      [icon]=\"'archive'\"\n      [title]=\"'No audit logs found.' | translate\"\n      [horizontal]=\"true\"\n    ></c8y-ui-empty-state>\n  </div>\n</ng-template>\n\n<div class=\"legend form-block\">{{ 'Audit logs' | translate }}</div>\n\n<ng-container *ngIf=\"isLoading || auditLog?.data.length; else noAuditLogAvailable\">\n  <c8y-loading *ngIf=\"isLoading\"></c8y-loading>\n\n  <c8y-list-group\n    data-cy=\"c8y-alarms-details--audit-logs\"\n    *ngIf=\"!isLoading\"\n  >\n    <c8y-li-timeline *c8yFor=\"let log of auditLog; loadMore: 'hidden'\">\n      {{ log.creationTime | date: 'mediumDate' }}\n      {{ log.creationTime | date: 'mediumTime' }}\n      <c8y-li>\n        <c8y-li-body>\n          <p class=\"text-truncate-wrap separator-bottom p-b-4\">\n            {{ log | auditChangesMessage }}\n          </p>\n          <div class=\"c8y-list__item__footer\">\n            <span\n              class=\"m-r-16 small\"\n              *ngIf=\"log.user\"\n            >\n              <span class=\"text-label-small\">\n                {{ 'by`user`' | translate }}\n              </span>\n              {{ log.user }}\n            </span>\n            <span class=\"small\">\n              <span class=\"text-label-small\">\n                {{ 'device time' | translate }}\n              </span>\n              {{ log.time | c8yDate: 'medium' }}\n            </span>\n          </div>\n        </c8y-li-body>\n      </c8y-li>\n    </c8y-li-timeline>\n  </c8y-list-group>\n</ng-container>\n"]}