UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

287 lines (286 loc) 22.7 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'; var /** @type {?} */ TYPE_NAME = "phx-notification-container"; var /** @type {?} */ ALIGN_LEFT = "left"; var /** @type {?} */ ALIGN_RIGHT = "right"; var NotificationContainer = /** @class */ (function (_super) { tslib_1.__extends(NotificationContainer, _super); function NotificationContainer(notifyMgr, elementRef, observableMgr) { var _this = _super.call(this) || this; _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 _this; } /** * @return {?} */ NotificationContainer.prototype.ngOnInit = /** * @return {?} */ function () { }; /** * comment for method * @param {?} notificationModel Notification. * @return {?} number. */ NotificationContainer.prototype.getModelIndex = /** * comment for method * @param {?} notificationModel Notification. * @return {?} number. */ function (notificationModel) { if (notificationModel === null || typeof notificationModel === 'undefined') { return -1; } var /** @type {?} */ notifications = this.getNonTimeoutNotifications(); return notifications.indexOf(notificationModel); }; /** * comment for method * @param {?} $event * @return {?} */ NotificationContainer.prototype.onNotificationClosed = /** * comment for method * @param {?} $event * @return {?} */ function ($event) { if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { var /** @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 {?} */ NotificationContainer.prototype.onNotificationShowActionBar = /** * comment for method * @param {?} $event * @return {?} */ function ($event) { if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { var /** @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 {?} */ NotificationContainer.prototype.onNotificationHideActionBar = /** * comment for method * @param {?} $event * @return {?} */ function ($event) { if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { var /** @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[]. */ NotificationContainer.prototype.getNonTimeoutNotifications = /** * comment for method * @return {?} Notification[]. */ function () { var /** @type {?} */ result = []; if (this.notifyMgr !== null && typeof this.notifyMgr !== 'undefined') { var /** @type {?} */ notis = this.notifyMgr.getShowingNotifications(); for (var /** @type {?} */ i = notis.length - 1; i >= 0; i--) { var /** @type {?} */ notify = notis[i]; result.push(notify); } } return result; }; /** * @param {?} show * @return {?} */ NotificationContainer.prototype.setShow = /** * @param {?} show * @return {?} */ function (show) { if (show) { this.hideNotification = false; } else { this.hideNotification = true; } }; /** * @return {?} */ NotificationContainer.prototype.show = /** * @return {?} */ function () { this.setShow(true); }; /** * @return {?} */ NotificationContainer.prototype.hide = /** * @return {?} */ function () { this.setShow(false); }; /** * @return {?} */ NotificationContainer.prototype.isHideNotification = /** * @return {?} */ function () { return this.hideNotification; }; /** * @return {?} */ NotificationContainer.prototype._isAlignLeft = /** * @return {?} */ function () { if (this.align !== null && this.align !== undefined && this.align !== '') { if (ALIGN_LEFT === this.align.toLowerCase()) { return true; } } return false; }; /** * @param {?} align * @return {?} */ NotificationContainer.prototype.setAlign = /** * @param {?} align * @return {?} */ function (align) { this.align = align; }; /** * @return {?} */ NotificationContainer.prototype.getAlign = /** * @return {?} */ function () { 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()\">\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" },] }, ]; /** @nocollapse */ NotificationContainer.ctorParameters = function () { return [ { 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); return NotificationContainer; }(AbstractHasOptions)); export { NotificationContainer }; 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"]}