UNPKG

design-angular-kit

Version:

Un toolkit Angular conforme alle linee guida di design per i servizi web della PA

111 lines 18.9 kB
import { ChangeDetectionStrategy, Component, Input } from '@angular/core'; import { NotificationType } from '../../../interfaces/core'; import { Notification as BSNotification } from 'bootstrap-italia'; import { ItIconComponent } from '../../utils/icon/icon.component'; import { TranslateModule } from '@ngx-translate/core'; import { inputToBoolean } from '../../../utils/coercion'; import * as i0 from "@angular/core"; import * as i1 from "../../../services/notification/notification.service"; import * as i2 from "@ngx-translate/core"; export class ItNotificationsComponent { constructor(_changeDetectorRef, _notificationService) { this._changeDetectorRef = _changeDetectorRef; this._notificationService = _notificationService; /** * Default notifications duration (milliseconds) * @default 8000 */ this.duration = 8000; /** * Default notifications is dismissible * @default true */ this.dismissible = true; this.notificationCount = 0; this.notifications = []; this.subscription = this._notificationService.onNotification().subscribe(notification => { if (!notification.duration) { notification.duration = this.duration; // Add duration if not is set } if (!notification.position && this.position) { notification.position = this.position; // Add position if not is set } if (notification.dismissible === undefined && this.dismissible) { notification.dismissible = true; // Add dismissible if not is set } if (!notification.icon) { notification.icon = this.getNotificationIcon(notification); } const newNotification = { ...notification, id: `${notification.type}-${this.notificationCount++}-notification`, }; this.notifications.push(newNotification); this._changeDetectorRef.detectChanges(); setTimeout(() => { // Show the notification new BSNotification(document.getElementById(newNotification.id), { timeout: notification.duration, }).show(); // Clear notification after the duration setTimeout(() => { const index = this.notifications.findIndex(n => n.id === newNotification.id); if (index > -1) { this.notifications.splice(index, 1); if (!this.notifications.length) { this.notificationCount = 0; } this._changeDetectorRef.detectChanges(); } }, notification.duration); }, 200); }); } ngOnDestroy() { this.subscription.unsubscribe(); } get NotificationType() { return NotificationType; } /** * Hide the notification * @param id */ hideNotification(id) { BSNotification.getInstance(document.getElementById(id))?.hide(); } /** * Retrieve the icon name by notification type * @param notification the notification * @protected */ getNotificationIcon(notification) { switch (notification.type) { case NotificationType.Success: return 'check-circle'; case NotificationType.Error: return 'close-circle'; case NotificationType.Warning: return 'error'; case NotificationType.Info: return 'info-circle'; case NotificationType.Standard: default: return undefined; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItNotificationsComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.ItNotificationService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItNotificationsComponent, isStandalone: true, selector: "it-notifications", inputs: { duration: "duration", position: "position", dismissible: ["dismissible", "dismissible", inputToBoolean] }, ngImport: i0, template: "@for (notification of notifications; track notification.id) {\n <div\n [id]=\"notification.id\"\n class=\"notification {{ notification.position }} {{ notification.type }}\"\n [class.with-icon]=\"!!notification.icon\"\n [class.dismissable]=\"notification.dismissible\"\n role=\"alert\"\n [attr.aria-labelledby]=\"notification.id + '-title'\">\n <h2 [id]=\"notification.id + '-title'\" class=\"h5\">\n @if (notification.icon) {\n <it-icon [name]=\"notification.icon\"></it-icon>\n }\n <ng-container>{{ notification.title }}</ng-container>\n </h2>\n @if (notification.message) {\n <p>{{ notification.message }}</p>\n }\n @if (notification.dismissible) {\n <button type=\"button\" class=\"btn notification-close\" (click)=\"hideNotification(notification.id)\">\n <it-icon name=\"close\"></it-icon>\n <span class=\"visually-hidden\">{{ 'it.core.close-notification' | translate: { title: notification.title } }}</span>\n </button>\n }\n </div>\n}\n", styles: [".notification{z-index:10000}\n"], dependencies: [{ kind: "component", type: ItIconComponent, selector: "it-icon", inputs: ["name", "size", "color", "padded", "svgClass", "title", "labelWaria"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItNotificationsComponent, decorators: [{ type: Component, args: [{ standalone: true, selector: 'it-notifications', changeDetection: ChangeDetectionStrategy.OnPush, imports: [ItIconComponent, TranslateModule], template: "@for (notification of notifications; track notification.id) {\n <div\n [id]=\"notification.id\"\n class=\"notification {{ notification.position }} {{ notification.type }}\"\n [class.with-icon]=\"!!notification.icon\"\n [class.dismissable]=\"notification.dismissible\"\n role=\"alert\"\n [attr.aria-labelledby]=\"notification.id + '-title'\">\n <h2 [id]=\"notification.id + '-title'\" class=\"h5\">\n @if (notification.icon) {\n <it-icon [name]=\"notification.icon\"></it-icon>\n }\n <ng-container>{{ notification.title }}</ng-container>\n </h2>\n @if (notification.message) {\n <p>{{ notification.message }}</p>\n }\n @if (notification.dismissible) {\n <button type=\"button\" class=\"btn notification-close\" (click)=\"hideNotification(notification.id)\">\n <it-icon name=\"close\"></it-icon>\n <span class=\"visually-hidden\">{{ 'it.core.close-notification' | translate: { title: notification.title } }}</span>\n </button>\n }\n </div>\n}\n", styles: [".notification{z-index:10000}\n"] }] }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.ItNotificationService }], propDecorators: { duration: [{ type: Input }], position: [{ type: Input }], dismissible: [{ type: Input, args: [{ transform: inputToBoolean }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/notifications/notifications.component.ts","../../../../../../../projects/design-angular-kit/src/lib/components/core/notifications/notifications.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnDestroy } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { ItNotificationService } from '../../../services/notification/notification.service';\nimport { Notification, NotificationPosition, NotificationType } from '../../../interfaces/core';\nimport { Notification as BSNotification } from 'bootstrap-italia';\nimport { IconName } from '../../../interfaces/icon';\nimport { ItIconComponent } from '../../utils/icon/icon.component';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { inputToBoolean } from '../../../utils/coercion';\n\n@Component({\n  standalone: true,\n  selector: 'it-notifications',\n  templateUrl: './notifications.component.html',\n  styleUrls: ['./notifications.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [ItIconComponent, TranslateModule],\n})\nexport class ItNotificationsComponent implements OnDestroy {\n  /**\n   * Default notifications duration (milliseconds)\n   * @default 8000\n   */\n  @Input() duration: number = 8000;\n\n  /**\n   * Default notifications position\n   */\n  @Input() position: NotificationPosition | undefined;\n\n  /**\n   * Default notifications is dismissible\n   * @default true\n   */\n  @Input({ transform: inputToBoolean }) dismissible: boolean = true;\n\n  private subscription: Subscription;\n  private notificationCount: number = 0;\n  protected notifications: Array<Notification & { id: string }> = [];\n\n  constructor(\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    private readonly _notificationService: ItNotificationService\n  ) {\n    this.subscription = this._notificationService.onNotification().subscribe(notification => {\n      if (!notification.duration) {\n        notification.duration = this.duration; // Add duration if not is set\n      }\n      if (!notification.position && this.position) {\n        notification.position = this.position; // Add position if not is set\n      }\n      if (notification.dismissible === undefined && this.dismissible) {\n        notification.dismissible = true; // Add dismissible if not is set\n      }\n      if (!notification.icon) {\n        notification.icon = this.getNotificationIcon(notification);\n      }\n\n      const newNotification = {\n        ...notification,\n        id: `${notification.type}-${this.notificationCount++}-notification`,\n      };\n      this.notifications.push(newNotification);\n      this._changeDetectorRef.detectChanges();\n\n      setTimeout(() => {\n        // Show the notification\n        new BSNotification(document.getElementById(newNotification.id)!, {\n          timeout: notification.duration,\n        }).show();\n\n        // Clear notification after the duration\n        setTimeout(() => {\n          const index = this.notifications.findIndex(n => n.id === newNotification.id);\n          if (index > -1) {\n            this.notifications.splice(index, 1);\n            if (!this.notifications.length) {\n              this.notificationCount = 0;\n            }\n            this._changeDetectorRef.detectChanges();\n          }\n        }, notification.duration);\n      }, 200);\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n\n  protected get NotificationType(): typeof NotificationType {\n    return NotificationType;\n  }\n\n  /**\n   * Hide the notification\n   * @param id\n   */\n  protected hideNotification(id: string): void {\n    BSNotification.getInstance(document.getElementById(id)!)?.hide();\n  }\n\n  /**\n   * Retrieve the icon name by notification type\n   * @param notification the notification\n   * @protected\n   */\n  private getNotificationIcon(notification: Notification): IconName | undefined {\n    switch (notification.type) {\n      case NotificationType.Success:\n        return 'check-circle';\n      case NotificationType.Error:\n        return 'close-circle';\n      case NotificationType.Warning:\n        return 'error';\n      case NotificationType.Info:\n        return 'info-circle';\n      case NotificationType.Standard:\n      default:\n        return undefined;\n    }\n  }\n}\n","@for (notification of notifications; track notification.id) {\n  <div\n    [id]=\"notification.id\"\n    class=\"notification {{ notification.position }} {{ notification.type }}\"\n    [class.with-icon]=\"!!notification.icon\"\n    [class.dismissable]=\"notification.dismissible\"\n    role=\"alert\"\n    [attr.aria-labelledby]=\"notification.id + '-title'\">\n    <h2 [id]=\"notification.id + '-title'\" class=\"h5\">\n      @if (notification.icon) {\n        <it-icon [name]=\"notification.icon\"></it-icon>\n      }\n      <ng-container>{{ notification.title }}</ng-container>\n    </h2>\n    @if (notification.message) {\n      <p>{{ notification.message }}</p>\n    }\n    @if (notification.dismissible) {\n      <button type=\"button\" class=\"btn notification-close\" (click)=\"hideNotification(notification.id)\">\n        <it-icon name=\"close\"></it-icon>\n        <span class=\"visually-hidden\">{{ 'it.core.close-notification' | translate: { title: notification.title } }}</span>\n      </button>\n    }\n  </div>\n}\n"]}