UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

245 lines (244 loc) 21 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, Input } from '@angular/core'; import { NotificationManager } from '../service/NotificationManager.service'; import { ObservableManager } from '../service/ObservableManager.service'; import { ToastNotification } from './ToastNotification.component'; import { Option } from '../decorator/Option.decorator'; import { AbstractHasOptions } from '../share/AbstractHasOptions'; const /** @type {?} */ TYPE_NAME = "phx-notification-container"; const /** @type {?} */ ALIGN_LEFT = "left"; const /** @type {?} */ ALIGN_RIGHT = "right"; /** class... */ export class NotificationContainer extends AbstractHasOptions { /** * @param {?} notifyMgr * @param {?} elementRef * @param {?} observableMgr */ constructor(notifyMgr, elementRef, observableMgr) { super(); this.notifyMgr = notifyMgr; this.observableMgr = observableMgr; this.elementRef = elementRef; this.DELAY_INTERVAL = ToastNotification.ANIMATE_OUT_INTERVAL + ToastNotification.ANIMATE_REMOVE_INTERVAL; // out + remove this.hideNotification = false; this.align = ALIGN_RIGHT; } /** * @return {?} */ ngOnInit() { } /** * comment for method * @param {?} notificationModel Notification. * @return {?} number. */ getModelIndex(notificationModel) { if (notificationModel === null || typeof notificationModel === 'undefined') { return -1; } let /** @type {?} */ notifications = this.getNonTimeoutNotifications(); return notifications.indexOf(notificationModel); } /** * comment for method * @param {?} $event * @return {?} */ onNotificationClosed($event) { if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { let /** @type {?} */ evData = null; if ($event.detail !== null && typeof $event.detail !== 'undefined') { if ($event.detail.data !== null && typeof $event.detail.data !== 'undefined') { evData = $event.detail.data; this.notifyMgr.clear(evData.model); } } } } /** * comment for method * @param {?} $event * @return {?} */ onNotificationShowActionBar($event) { if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { let /** @type {?} */ evData = null; if ($event.detail !== null && typeof $event.detail !== 'undefined') { if ($event.detail.data !== null && typeof $event.detail.data !== 'undefined') { evData = $event.detail.data; this.notifyMgr.pinNotification(evData.model); } } } } /** * comment for method * @param {?} $event * @return {?} */ onNotificationHideActionBar($event) { if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { let /** @type {?} */ evData = null; if ($event.detail !== null && typeof $event.detail !== 'undefined') { if ($event.detail.data !== null && typeof $event.detail.data !== 'undefined') { evData = $event.detail.data; this.notifyMgr.unpinNotification(evData.model); } } } } /** * comment for method * @return {?} Notification[]. */ getNonTimeoutNotifications() { let /** @type {?} */ result = []; if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { let /** @type {?} */ notis = this.notifyMgr.getShowingNotifications(); for (let /** @type {?} */ i = notis.length - 1; i >= 0; i--) { let /** @type {?} */ notify = notis[i]; result.push(notify); } } return result; } /** * @param {?} show * @return {?} */ setShow(show) { if (show) { this.hideNotification = false; } else { this.hideNotification = true; } } /** * @return {?} */ show() { this.setShow(true); } /** * @return {?} */ hide() { this.setShow(false); } /** * @return {?} */ isHideNotification() { return this.hideNotification; } /** * @return {?} */ _isAlignLeft() { if (this.align !== null && this.align !== undefined && this.align !== '') { if (ALIGN_LEFT === this.align.toLowerCase()) { return true; } } return false; } /** * @param {?} align * @return {?} */ setAlign(align) { this.align = align; } /** * @return {?} */ getAlign() { return this.align; } } NotificationContainer.TYPE_NAME = TYPE_NAME; NotificationContainer.ALIGN_LEFT = ALIGN_LEFT; NotificationContainer.ALIGN_RIGHT = ALIGN_RIGHT; NotificationContainer.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: 'phx-notification-container', template: `<div class="phx-notification-container" [class.show]="!isHideNotification()" [class.left]="_isAlignLeft()"> <ng-template ngFor let-item [ngForOf]="getNonTimeoutNotifications()" let-i="index"> <phx-toast-notification [model]="item" (closeDone)="onNotificationClosed($event)" (showActionBar)="onNotificationShowActionBar($event)" (hideActionBarDone)="onNotificationHideActionBar($event)"></phx-toast-notification> </ng-template> </div> ` },] }, ]; /** @nocollapse */ NotificationContainer.ctorParameters = () => [ { type: NotificationManager, }, { type: ElementRef, }, { type: ObservableManager, }, ]; NotificationContainer.propDecorators = { "align": [{ type: Input },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], NotificationContainer.prototype, "align", void 0); function NotificationContainer_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ NotificationContainer.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ NotificationContainer.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ NotificationContainer.propDecorators; /** @type {?} */ NotificationContainer.TYPE_NAME; /** @type {?} */ NotificationContainer.ALIGN_LEFT; /** @type {?} */ NotificationContainer.ALIGN_RIGHT; /** * This is a doc comment for "DELAY_INTERVAL". * @type {?} */ NotificationContainer.prototype.DELAY_INTERVAL; /** * This is a doc comment for "notifyMgr". * @type {?} */ NotificationContainer.prototype.notifyMgr; /** * This is a doc comment for "elementRef". * @type {?} */ NotificationContainer.prototype.elementRef; /** * This is a doc comment for "closeDelayTimer". * @type {?} */ NotificationContainer.prototype.closeDelayTimer; /** * This is a doc comment for "observableMgr". * @type {?} */ NotificationContainer.prototype.observableMgr; /** * This is a doc comment for "hideNotification". * @type {?} */ NotificationContainer.prototype.hideNotification; /** @type {?} */ NotificationContainer.prototype.align; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"NotificationContainer.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/NotificationContainer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input } from '@angular/core';\nimport { Notification } from './model/Notification';\nimport { NotificationManager } from '../service/NotificationManager.service';\nimport { ObservableManager } from '../service/ObservableManager.service';\nimport { ToastNotification } from './ToastNotification.component';\nimport { Option } from '../decorator/Option.decorator';\nimport { AbstractHasOptions } from '../share/AbstractHasOptions';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-notification-container\";\nconst ALIGN_LEFT: string = \"left\";\nconst ALIGN_RIGHT: string = \"right\";\n\n@Component({\n  moduleId: module.id,\n  selector: 'phx-notification-container',\n  template: `<div class=\"phx-notification-container\" [class.show]=\"!isHideNotification()\" [class.left]=\"_isAlignLeft()\">\n\t<ng-template ngFor let-item [ngForOf]=\"getNonTimeoutNotifications()\" let-i=\"index\">\n\t\t<phx-toast-notification [model]=\"item\" (closeDone)=\"onNotificationClosed($event)\"\n\t\t(showActionBar)=\"onNotificationShowActionBar($event)\" (hideActionBarDone)=\"onNotificationHideActionBar($event)\"></phx-toast-notification>\n\t</ng-template>\n</div>\n`\n})\n/** class... */\nexport class NotificationContainer extends AbstractHasOptions implements OnInit {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n  public static readonly ALIGN_LEFT: string = ALIGN_LEFT;\n  public static readonly ALIGN_RIGHT: string = ALIGN_RIGHT;\n\n  /**\n   * This is a doc comment for \"DELAY_INTERVAL\".\n   */\n  private DELAY_INTERVAL: number;\n  /**\n   * This is a doc comment for \"notifyMgr\".\n   */\n  private notifyMgr: NotificationManager;\n  /**\n   * This is a doc comment for \"elementRef\".\n   */\n  private elementRef: ElementRef;\n  /**\n   * This is a doc comment for \"closeDelayTimer\".\n   */\n  private closeDelayTimer: any;\n  /**\n   * This is a doc comment for \"observableMgr\".\n   */\n  private observableMgr: ObservableManager;\n  /**\n   * This is a doc comment for \"hideNotification\".\n   */\n  private hideNotification: boolean;\n\n  // --- from self\n  @Option()\n  @Input()\n  private align: string;\n\n  constructor(notifyMgr: NotificationManager, elementRef: ElementRef, observableMgr: ObservableManager) {\n    super();\n    this.notifyMgr = notifyMgr;\n    this.observableMgr = observableMgr;\n    this.elementRef = elementRef;\n    this.DELAY_INTERVAL = ToastNotification.ANIMATE_OUT_INTERVAL + ToastNotification.ANIMATE_REMOVE_INTERVAL; // out + remove\n    this.hideNotification = false;\n    this.align = ALIGN_RIGHT;\n  }\n\n  public ngOnInit(): void {\n\n  }\n\n  /**\n   * comment for method\n   * @param notificationModel  Notification.\n   * @returns   number.\n   */\n  private getModelIndex(notificationModel: Notification): number {\n    if (notificationModel === null || typeof notificationModel === 'undefined') {\n      return -1;\n    }\n    let notifications: Notification[] = this.getNonTimeoutNotifications();\n\n    return notifications.indexOf(notificationModel);\n  }\n\n  /**\n   * comment for method\n   * @param event  CustomEvent\n   */\n  public onNotificationClosed($event: CustomEvent): void {\n    if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') {\n      let evData = null;\n      if ($event.detail !== null && typeof $event.detail !== 'undefined') {\n        if ($event.detail.data !== null && typeof $event.detail.data !== 'undefined') {\n          evData = $event.detail.data;\n          this.notifyMgr.clear(evData.model);\n        }\n      }\n    }\n  }\n\n  /**\n   * comment for method\n   * @param event  CustomEvent\n   */\n  public onNotificationShowActionBar($event: CustomEvent): void {\n    if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') {\n      let evData = null;\n      if ($event.detail !== null && typeof $event.detail !== 'undefined') {\n        if ($event.detail.data !== null && typeof $event.detail.data !== 'undefined') {\n          evData = $event.detail.data;\n          this.notifyMgr.pinNotification(evData.model);\n        }\n      }\n    }\n  }\n\n  /**\n   * comment for method\n   * @param event  CustomEvent\n   */\n  public onNotificationHideActionBar($event: CustomEvent): void {\n    if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') {\n      let evData = null;\n      if ($event.detail !== null && typeof $event.detail !== 'undefined') {\n        if ($event.detail.data !== null && typeof $event.detail.data !== 'undefined') {\n          evData = $event.detail.data;\n          this.notifyMgr.unpinNotification(evData.model);\n        }\n      }\n    }\n  }\n\n  /**\n   * comment for method\n   * @returns   Notification[].\n   */\n  public getNonTimeoutNotifications(): Notification[] {\n    let result = [];\n    if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') {\n      let notis = this.notifyMgr.getShowingNotifications();\n      for (let i = notis.length - 1; i >= 0; i--) {\n        let notify = notis[i];\n        result.push(notify);\n      }\n    }\n    return result;\n  }\n\n  public setShow(show: boolean): void {\n    if (show) {\n      this.hideNotification = false;\n    } else {\n      this.hideNotification = true;\n    }\n  }\n\n  public show(): void {\n    this.setShow(true);\n  }\n\n  public hide(): void {\n    this.setShow(false);\n  }\n\n  public isHideNotification(): boolean {\n    return this.hideNotification;\n  }\n\n  public _isAlignLeft(): boolean {\n    if (this.align !== null && this.align !== undefined && this.align !== '') {\n      if (ALIGN_LEFT === this.align.toLowerCase()) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  public setAlign(align: string): void {\n    this.align = align;\n  }\n\n  public getAlign(): string {\n    return this.align;\n  }\n}\n"]}