alarms/alarms.component.ts
OnInit
OnDestroy
providers |
AlarmWithChildrenRealtimeService
|
selector | c8y-alarms |
templateUrl | ./alarms.component.html |
Properties |
Methods |
constructor(activatedRoute: ActivatedRoute, alarmsViewService: AlarmsViewService, alarmWithChildrenRealtimeService: AlarmWithChildrenRealtimeService, alertService: AlertService, contextRouteService: ContextRouteService, modalService: ModalService, translateService: TranslateService, router: Router)
|
|||||||||||||||||||||||||||
Parameters :
|
Async applyDateFilter | ||||||
applyDateFilter(selectedDates: [Date, Date])
|
||||||
Parameters :
Returns :
Promise<void>
|
applyFormFilters | |||||
applyFormFilters(undefined: AlarmListFormFilters)
|
|||||
Parameters :
Returns :
void
|
applyTypeFilters | ||||||
applyTypeFilters(typeFilters: AlarmDetails[])
|
||||||
Parameters :
Returns :
void
|
changeInterval | ||||||
changeInterval(value)
|
||||||
Parameters :
Returns :
void
|
Async clearAll |
clearAll()
|
Returns :
Promise<void>
|
ngOnDestroy |
ngOnDestroy()
|
Returns :
void
|
ngOnInit |
ngOnInit()
|
Returns :
void
|
refresh |
refresh()
|
Returns :
void
|
toggleRealtimeState |
toggleRealtimeState()
|
Returns :
void
|
Public activatedRoute |
Type : ActivatedRoute
|
alarmIntervalRefreshComponent |
Type : AlarmsIntervalRefreshComponent
|
Decorators :
@ViewChild(AlarmsIntervalRefreshComponent)
|
alarms$ |
Type : BehaviorSubject<IResultList<IAlarm>>
|
Default value : new BehaviorSubject<IResultList<IAlarm>>(null)
|
contextSourceId |
Type : number | string | null
|
isDisabled |
Default value : false
|
isIntervalRefresh |
Type : boolean
|
responsible for showing either realtime button or intervals, based on 'refreshType' key in OptionsService |
isLoading$ |
Type : BehaviorSubject<boolean>
|
Default value : new BehaviorSubject<boolean>(false)
|
isRealtimeActive |
Default value : new BehaviorSubject<boolean>(false)
|
isRealtimeToggleOn |
Default value : true
|
Readonly NEW_REALTIME_ALARM_MESSAGE |
Default value : this.alarmsViewService.REALTIME_UPDATE_ALARMS_MESSAGE
|
realtimeIconTitle |
Type : string
|
Readonly REFRESH_LABEL |
Default value : gettext('Refresh')
|
shouldShowIntervalToggle$ |
Default value : new BehaviorSubject<boolean>(true)
|
Readonly TITLE |
Default value : gettext('Alarms')
|
typeFilters |
Type : AlarmDetails[]
|
Default value : []
|
<ng-container *ngIf="(activatedRoute.data | async)?.title">
<c8y-title>{{ TITLE | translate }}</c8y-title>
</ng-container>
<c8y-action-bar-item
[placement]="'left'"
itemClass="navbar-form min-width-fit"
>
<c8y-alarms-filter
class="d-block fit-w"
[contextSourceId]="contextSourceId"
(onFilterApplied)="applyFormFilters($event)"
></c8y-alarms-filter>
</c8y-action-bar-item>
<c8y-action-bar-item
[placement]="'left'"
itemClass="navbar-form min-width-fit"
>
<c8y-alarms-date-filter (dateFilterChange)="applyFormFilters($event)"></c8y-alarms-date-filter>
</c8y-action-bar-item>
<c8y-action-bar-item
[placement]="'left'"
itemClass="navbar-form"
>
<c8y-alarms-type-filter
class="d-block fit-w"
[alarms]="alarms$ | async"
(onFilterChanged)="applyTypeFilters($event)"
></c8y-alarms-type-filter>
</c8y-action-bar-item>
<c8y-action-bar-item
[placement]="'right'"
[priority]="0"
>
<button
class="btn btn-link"
[title]="'Clear all alarms' | translate"
type="button"
(click)="clearAll()"
data-cy="c8y-alarms-view--clear-all-button"
>
<i c8yIcon="c8y-alert-idle"></i>
{{ 'Clear all`alarms`' | translate }}
</button>
</c8y-action-bar-item>
<!--Realtime button-->
<ng-template #realtimeRefresh>
<div class="input-group-btn">
<button
class="btn btn-default btn-sm"
[attr.aria-label]="'Refresh' | translate"
[tooltip]="
(isRealtimeActive | async)
? (NEW_REALTIME_ALARM_MESSAGE | translate)
: (REFRESH_LABEL | translate)
"
placement="left"
container="body"
type="button"
[adaptivePosition]="false"
[delay]="500"
[disabled]="isLoading$ | async"
(click)="refresh()"
>
<span
class="tag tag--info m-r-8"
*ngIf="isRealtimeActive | async"
>
{{ 'New alarms' | translate }}
</span>
<i
c8yIcon="refresh"
[ngClass]="{ 'icon-spin': isLoading$ | async }"
></i>
</button>
<button
class="c8y-realtime btn btn-default btn-sm"
[attr.aria-label]="realtimeIconTitle"
[tooltip]="realtimeIconTitle"
placement="bottom"
type="button"
data-cy="c8y-alarms--realtime-button"
[container]="'body'"
(click)="toggleRealtimeState()"
>
<span
class="c8y-pulse m-0"
[ngClass]="{
active: isRealtimeToggleOn,
inactive: !isRealtimeToggleOn
}"
></span>
</button>
</div>
</ng-template>
<c8y-help
src="/docs/device-management-application/monitoring-and-controlling-devices/#working-with-alarms"
></c8y-help>
<div class="card content-fullpage split-view--5-7 grid__row--1">
<c8y-alarms-list
class="d-contents"
[isInitialLoading]="isLoading$ | async"
[alarms]="alarms$ | async"
[typeFilters]="typeFilters"
(onScrollingStateChange)="changeInterval(!$event)"
(onSelectedAlarm)="changeInterval(false)"
[splitView]="true"
[hasPermissions]="!isDisabled"
>
<ng-container *ngIf="isIntervalRefresh; else realtimeRefresh">
<c8y-alarms-interval-refresh
[alarmsListLoading$]="isLoading$"
[isIntervalToggleEnabled]="shouldShowIntervalToggle$ | async"
(onCountdownEnded)="refresh()"
[isDisabled]="isDisabled"
></c8y-alarms-interval-refresh>
</ng-container>
</c8y-alarms-list>
<router-outlet class="d-contents"></router-outlet>
</div>