2023-01-20 15:08:44 +02:00
|
|
|
///
|
2023-02-14 11:39:29 +02:00
|
|
|
/// Copyright © 2016-2023 The Thingsboard Authors
|
2023-01-20 15:08:44 +02:00
|
|
|
///
|
|
|
|
|
/// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
/// you may not use this file except in compliance with the License.
|
|
|
|
|
/// You may obtain a copy of the License at
|
|
|
|
|
///
|
|
|
|
|
/// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
///
|
|
|
|
|
/// Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
/// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
/// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
/// See the License for the specific language governing permissions and
|
|
|
|
|
/// limitations under the License.
|
|
|
|
|
///
|
|
|
|
|
|
2023-01-20 18:08:30 +02:00
|
|
|
import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';
|
2023-02-09 12:31:06 +02:00
|
|
|
import {
|
|
|
|
|
AlarmSeverityNotificationColors,
|
|
|
|
|
Notification,
|
|
|
|
|
NotificationType,
|
|
|
|
|
NotificationTypeIcons
|
|
|
|
|
} from '@shared/models/notification.models';
|
2023-01-20 18:08:30 +02:00
|
|
|
import { UtilsService } from '@core/services/utils.service';
|
|
|
|
|
import { Router } from '@angular/router';
|
|
|
|
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
2023-02-09 12:31:06 +02:00
|
|
|
import { alarmSeverityTranslations } from '@shared/models/alarm.models';
|
2023-02-06 13:31:00 +02:00
|
|
|
import * as tinycolor_ from 'tinycolor2';
|
2023-01-20 15:08:44 +02:00
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
|
selector: 'tb-notification',
|
|
|
|
|
templateUrl: './notification.component.html',
|
|
|
|
|
styleUrls: ['./notification.component.scss']
|
|
|
|
|
})
|
2023-01-20 18:08:30 +02:00
|
|
|
export class NotificationComponent implements OnInit {
|
2023-01-20 15:08:44 +02:00
|
|
|
|
|
|
|
|
@Input()
|
|
|
|
|
notification: Notification;
|
|
|
|
|
|
2023-01-20 18:08:30 +02:00
|
|
|
@Input()
|
|
|
|
|
onClose: () => void;
|
|
|
|
|
|
2023-01-20 15:08:44 +02:00
|
|
|
@Output()
|
|
|
|
|
markAsRead = new EventEmitter<string>();
|
2023-01-20 18:08:30 +02:00
|
|
|
|
|
|
|
|
private previewValue = false;
|
|
|
|
|
get preview(): boolean {
|
|
|
|
|
return this.previewValue;
|
|
|
|
|
}
|
|
|
|
|
@Input()
|
|
|
|
|
set preview(value: boolean) {
|
|
|
|
|
this.previewValue = coerceBooleanProperty(value);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
showIcon = false;
|
|
|
|
|
showButton = false;
|
|
|
|
|
buttonLabel = '';
|
|
|
|
|
|
2023-02-06 13:31:00 +02:00
|
|
|
tinycolor = tinycolor_;
|
|
|
|
|
|
|
|
|
|
notificationType = NotificationType;
|
|
|
|
|
notificationTypeIcons = NotificationTypeIcons;
|
|
|
|
|
alarmSeverityTranslations = alarmSeverityTranslations;
|
|
|
|
|
|
2023-01-20 18:08:30 +02:00
|
|
|
constructor(
|
|
|
|
|
private utils: UtilsService,
|
|
|
|
|
private router: Router
|
|
|
|
|
) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ngOnInit() {
|
|
|
|
|
this.showIcon = this.notification.additionalConfig?.icon?.enabled;
|
|
|
|
|
this.showButton = this.notification.additionalConfig?.actionButtonConfig?.enabled;
|
|
|
|
|
if (this.showButton) {
|
|
|
|
|
this.buttonLabel = this.utils.customTranslation(this.notification.additionalConfig.actionButtonConfig.text,
|
|
|
|
|
this.notification.additionalConfig.actionButtonConfig.text);
|
|
|
|
|
}
|
2023-01-20 15:08:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
markRead($event: Event) {
|
|
|
|
|
if ($event) {
|
|
|
|
|
$event.stopPropagation();
|
|
|
|
|
}
|
2023-01-20 18:08:30 +02:00
|
|
|
if (!this.preview) {
|
|
|
|
|
this.markAsRead.next(this.notification.id.id);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
navigate($event: Event) {
|
|
|
|
|
if ($event) {
|
|
|
|
|
$event.stopPropagation();
|
|
|
|
|
}
|
|
|
|
|
if (!this.preview) {
|
2023-02-09 12:31:06 +02:00
|
|
|
if (this.notification.additionalConfig.actionButtonConfig.link.startsWith('/')) {
|
|
|
|
|
this.router.navigateByUrl(this.router.parseUrl(this.notification.additionalConfig.actionButtonConfig.link)).then(() => {
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
window.open(this.notification.additionalConfig.actionButtonConfig.link, '_blank');
|
|
|
|
|
}
|
2023-01-20 18:08:30 +02:00
|
|
|
if (this.onClose) {
|
|
|
|
|
this.onClose();
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-01-20 15:08:44 +02:00
|
|
|
}
|
2023-02-06 13:31:00 +02:00
|
|
|
|
|
|
|
|
alarmColorSeverity(alpha: number) {
|
2023-02-09 12:31:06 +02:00
|
|
|
return this.tinycolor(AlarmSeverityNotificationColors.get(this.notification.info.alarmSeverity)).setAlpha(alpha).toRgbString();
|
2023-02-06 13:31:00 +02:00
|
|
|
}
|
|
|
|
|
|
2023-02-07 17:31:01 +02:00
|
|
|
notificationColor(): string {
|
2023-02-09 12:31:06 +02:00
|
|
|
if (this.notification.type === NotificationType.ALARM) {
|
|
|
|
|
return AlarmSeverityNotificationColors.get(this.notification.info.alarmSeverity);
|
2023-02-06 13:31:00 +02:00
|
|
|
}
|
2023-02-07 17:31:01 +02:00
|
|
|
return 'transparent';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
notificationIconColor(): object {
|
2023-02-09 12:31:06 +02:00
|
|
|
if (this.notification.type === NotificationType.ALARM) {
|
|
|
|
|
return {color: AlarmSeverityNotificationColors.get(this.notification.info.alarmSeverity)};
|
2023-02-07 17:31:01 +02:00
|
|
|
}
|
|
|
|
|
return null;
|
2023-02-06 13:31:00 +02:00
|
|
|
}
|
2023-01-20 15:08:44 +02:00
|
|
|
}
|