UNPKG

angular9-notifications-gpu

Version:

> A light and easy to use notifications library for Angular 2. ~~It features both regular page notifications (toasts) and push notifications.~~

207 lines 26.3 kB
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core'; import { NotificationsService } from '../../services/notifications.service'; import { NotificationAnimationType } from '../../enums/notification-animation-type.enum'; export class SimpleNotificationsComponent { constructor(service, cdr) { this.service = service; this.cdr = cdr; this.onCreate = new EventEmitter(); this.onDestroy = new EventEmitter(); this.notifications = []; this.position = ['bottom', 'right']; // Received values this.lastOnBottom = true; this.maxStack = 8; this.preventLastDuplicates = false; this.preventDuplicates = false; // Sent values this.timeOut = 0; this.maxLength = 0; this.clickToClose = true; this.clickIconToClose = false; this.showProgressBar = true; this.pauseOnHover = true; this.theClass = ''; this.rtl = false; this.animate = NotificationAnimationType.FromRight; this._usingComponentOptions = false; } set options(opt) { this._usingComponentOptions = true; this.attachChanges(opt); } ngOnInit() { /** * Only attach global options if config * options were never sent through input */ if (!this._usingComponentOptions) { this.attachChanges(this.service.globalOptions); } this.listener = this.service.emitter .subscribe(item => { switch (item.command) { case 'cleanAll': this.notifications = []; break; case 'clean': this.cleanSingle(item.id); break; case 'set': if (item.add) { this.add(item.notification); } else { this.defaultBehavior(item); } break; default: this.defaultBehavior(item); break; } if (!this.cdr['destroyed']) { this.cdr.detectChanges(); } }); } ngOnDestroy() { if (this.listener) { this.listener.unsubscribe(); } this.cdr.detach(); } // Default behavior on event defaultBehavior(value) { this.notifications.splice(this.notifications.indexOf(value.notification), 1); this.onDestroy.emit(this.buildEmit(value.notification, false)); } // Add the new notification to the notification array add(item) { item.createdOn = new Date(); let toBlock = this.preventLastDuplicates || this.preventDuplicates ? this.block(item) : false; // Save this as the last created notification this.lastNotificationCreated = item; // Override icon if set if (item.override && item.override.icons && item.override.icons[item.type]) { item.icon = item.override.icons[item.type]; } if (!toBlock) { // Check if the notification should be added at the start or the end of the array if (this.lastOnBottom) { if (this.notifications.length >= this.maxStack) { this.notifications.splice(0, 1); } this.notifications.push(item); } else { if (this.notifications.length >= this.maxStack) { this.notifications.splice(this.notifications.length - 1, 1); } this.notifications.splice(0, 0, item); } this.onCreate.emit(this.buildEmit(item, true)); } } // Check if notifications should be prevented block(item) { const toCheck = item.html ? this.checkHtml : this.checkStandard; if (this.preventDuplicates && this.notifications.length > 0) { for (let i = 0; i < this.notifications.length; i++) { if (toCheck(this.notifications[i], item)) { return true; } } } if (this.preventLastDuplicates) { let comp; if (this.preventLastDuplicates === 'visible' && this.notifications.length > 0) { if (this.lastOnBottom) { comp = this.notifications[this.notifications.length - 1]; } else { comp = this.notifications[0]; } } else if (this.preventLastDuplicates === 'all' && this.lastNotificationCreated) { comp = this.lastNotificationCreated; } else { return false; } return toCheck(comp, item); } return false; } checkStandard(checker, item) { return checker.type === item.type && checker.title === item.title && checker.content === item.content; } checkHtml(checker, item) { return checker.html ? checker.type === item.type && checker.title === item.title && checker.content === item.content && checker.html === item.html : false; } // Attach all the changes received in the options object attachChanges(options) { for (const key in options) { if (this.hasOwnProperty(key)) { this[key] = options[key]; } else if (key === 'icons') { this.service.icons = options[key]; } } } buildEmit(notification, to) { const toEmit = { createdOn: notification.createdOn, type: notification.type, icon: notification.icon, id: notification.id }; if (notification.html) { toEmit.html = notification.html; } else { toEmit.title = notification.title; toEmit.content = notification.content; } if (!to) { toEmit.destroyedOn = new Date(); } return toEmit; } cleanSingle(id) { let indexOfDelete = 0; let doDelete = false; let noti; this.notifications.forEach((notification, idx) => { if (notification.id === id) { indexOfDelete = idx; noti = notification; doDelete = true; } }); if (doDelete) { this.notifications.splice(indexOfDelete, 1); this.onDestroy.emit(this.buildEmit(noti, false)); } } } SimpleNotificationsComponent.decorators = [ { type: Component, args: [{ selector: 'simple-notifications', encapsulation: ViewEncapsulation.None, template: "<div class=\"simple-notification-wrapper\" [ngClass]=\"position\">\r\n <simple-notification\r\n *ngFor=\"let a of notifications; let i = index\"\r\n [item]=\"a\"\r\n [timeOut]=\"timeOut\"\r\n [clickToClose]=\"clickToClose\"\r\n [clickIconToClose]=\"clickIconToClose\"\r\n [maxLength]=\"maxLength\"\r\n [showProgressBar]=\"showProgressBar\"\r\n [pauseOnHover]=\"pauseOnHover\"\r\n [theClass]=\"theClass\"\r\n [rtl]=\"rtl\"\r\n [animate]=\"animate\"\r\n [position]=\"i\">\r\n </simple-notification>\r\n</div>", changeDetection: ChangeDetectionStrategy.OnPush, styles: [".simple-notification-wrapper{position:fixed;width:300px;z-index:1000}.simple-notification-wrapper.left{left:20px}.simple-notification-wrapper.top{top:20px}.simple-notification-wrapper.right{right:20px}.simple-notification-wrapper.bottom{bottom:20px}.simple-notification-wrapper.center{left:50%;transform:translateX(-50%)}.simple-notification-wrapper.middle{top:50%;transform:translateY(-50%)}.simple-notification-wrapper.middle.center{transform:translate(-50%,-50%)}@media (max-width:340px){.simple-notification-wrapper{width:auto;left:20px;right:20px}}"] }] } ]; /** @nocollapse */ SimpleNotificationsComponent.ctorParameters = () => [ { type: NotificationsService }, { type: ChangeDetectorRef } ]; SimpleNotificationsComponent.propDecorators = { options: [{ type: Input }], onCreate: [{ type: Output }], onDestroy: [{ type: Output }] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-notifications.component.js","sourceRoot":"ng://angular9-notifications-gpu/","sources":["lib/components/simple-notifications/simple-notifications.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewEncapsulation\n} from '@angular/core';\nimport {Subscription} from 'rxjs';\nimport {Options, Position} from '../../interfaces/options.type';\nimport {Notification} from '../../interfaces/notification.type';\nimport {NotificationsService} from '../../services/notifications.service';\nimport {NotificationAnimationType} from '../../enums/notification-animation-type.enum';\n\n@Component({\n  selector: 'simple-notifications',\n  encapsulation: ViewEncapsulation.None,\n  templateUrl: './simple-notifications.component.html',\n  styleUrls: ['./simple-notifications.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class SimpleNotificationsComponent implements OnInit, OnDestroy {\n  constructor(\n    private service: NotificationsService,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  @Input() set options(opt: Options) {\n    this._usingComponentOptions = true;\n    this.attachChanges(opt);\n  }\n\n  @Output() onCreate = new EventEmitter();\n  @Output() onDestroy = new EventEmitter();\n\n  notifications: Notification[] = [];\n  position: Position = ['bottom', 'right'];\n\n  private lastNotificationCreated: Notification;\n  private listener: Subscription;\n\n  // Received values\n  private lastOnBottom = true;\n  private maxStack = 8;\n  private preventLastDuplicates: any = false;\n  private preventDuplicates = false;\n\n  // Sent values\n  timeOut = 0;\n  maxLength = 0;\n  clickToClose = true;\n  clickIconToClose = false;\n  showProgressBar = true;\n  pauseOnHover = true;\n  theClass = '';\n  rtl = false;\n  animate: NotificationAnimationType = NotificationAnimationType.FromRight;\n\n  private _usingComponentOptions = false;\n\n  ngOnInit() {\n\n    /**\n     * Only attach global options if config\n     * options were never sent through input\n     */\n    if (!this._usingComponentOptions) {\n      this.attachChanges(\n        this.service.globalOptions\n      );\n    }\n\n    this.listener = this.service.emitter\n      .subscribe(item => {\n        switch (item.command) {\n          case 'cleanAll':\n            this.notifications = [];\n            break;\n\n          case 'clean':\n            this.cleanSingle(item.id!);\n            break;\n\n          case 'set':\n            if (item.add) {\n              this.add(item.notification!);\n            } else {\n              this.defaultBehavior(item);\n            }\n            break;\n\n          default:\n            this.defaultBehavior(item);\n            break;\n        }\n        if (!this.cdr['destroyed']) {\n          this.cdr.detectChanges();\n        }\n      });\n  }\n\n  ngOnDestroy() {\n    if (this.listener) {\n      this.listener.unsubscribe();\n    }\n    this.cdr.detach();\n  }\n\n  // Default behavior on event\n  defaultBehavior(value: any): void {\n    this.notifications.splice(this.notifications.indexOf(value.notification), 1);\n    this.onDestroy.emit(this.buildEmit(value.notification, false));\n  }\n\n\n  // Add the new notification to the notification array\n  add(item: Notification): void {\n    item.createdOn = new Date();\n\n    let toBlock: boolean = this.preventLastDuplicates || this.preventDuplicates ? this.block(item) : false;\n\n    // Save this as the last created notification\n    this.lastNotificationCreated = item;\n    // Override icon if set\n    if (item.override && item.override.icons && item.override.icons[item.type]) {\n      item.icon = item.override.icons[item.type];\n    }\n\n    if (!toBlock) {\n      // Check if the notification should be added at the start or the end of the array\n      if (this.lastOnBottom) {\n        if (this.notifications.length >= this.maxStack) {\n          this.notifications.splice(0, 1);\n        }\n\n        this.notifications.push(item);\n      } else {\n        if (this.notifications.length >= this.maxStack) {\n          this.notifications.splice(this.notifications.length - 1, 1);\n        }\n\n        this.notifications.splice(0, 0, item);\n      }\n\n      this.onCreate.emit(this.buildEmit(item, true));\n    }\n  }\n\n  // Check if notifications should be prevented\n  block(item: Notification): boolean {\n\n    const toCheck = item.html ? this.checkHtml : this.checkStandard;\n\n    if (this.preventDuplicates && this.notifications.length > 0) {\n      for (let i = 0; i < this.notifications.length; i++) {\n        if (toCheck(this.notifications[i], item)) {\n          return true;\n        }\n      }\n    }\n\n    if (this.preventLastDuplicates) {\n\n      let comp: Notification;\n\n      if (this.preventLastDuplicates === 'visible' && this.notifications.length > 0) {\n        if (this.lastOnBottom) {\n          comp = this.notifications[this.notifications.length - 1];\n        } else {\n          comp = this.notifications[0];\n        }\n      } else if (this.preventLastDuplicates === 'all' && this.lastNotificationCreated) {\n        comp = this.lastNotificationCreated;\n      } else {\n        return false;\n      }\n      return toCheck(comp, item);\n    }\n\n    return false;\n  }\n\n  checkStandard(checker: Notification, item: Notification): boolean {\n    return checker.type === item.type && checker.title === item.title && checker.content === item.content;\n  }\n\n  checkHtml(checker: Notification, item: Notification): boolean {\n    return checker.html ? checker.type === item.type && checker.title === item.title && checker.content === item.content && checker.html === item.html : false;\n  }\n\n  // Attach all the changes received in the options object\n  attachChanges(options: any) {\n    for (const key in options) {\n      if (this.hasOwnProperty(key)) {\n        (<any>this)[key] = options[key];\n      } else if (key === 'icons') {\n        this.service.icons = options[key];\n      }\n    }\n  }\n\n  buildEmit(notification: Notification, to: boolean) {\n    const toEmit: Notification = {\n      createdOn: notification.createdOn,\n      type: notification.type,\n      icon: notification.icon,\n      id: notification.id\n    };\n\n    if (notification.html) {\n      toEmit.html = notification.html;\n    } else {\n      toEmit.title = notification.title;\n      toEmit.content = notification.content;\n    }\n\n    if (!to) {\n      toEmit.destroyedOn = new Date();\n    }\n\n    return toEmit;\n  }\n\n  cleanSingle(id: string): void {\n    let indexOfDelete = 0;\n    let doDelete = false;\n    let noti;\n\n    this.notifications.forEach((notification, idx) => {\n      if (notification.id === id) {\n        indexOfDelete = idx;\n        noti = notification;\n        doDelete = true;\n      }\n    });\n\n    if (doDelete) {\n      this.notifications.splice(indexOfDelete, 1);\n      this.onDestroy.emit(this.buildEmit(noti, false));\n    }\n  }\n}\n"]}