com.phloxui
Version:
PhloxUI Ng2+ Framework
214 lines (212 loc) • 22 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import { Component, HostListener } from '@angular/core';
import { PhloxAppService } from '../../../../service/PhloxAppService.service';
import { NeedFocusService } from '../../../../service/NeedFocusService.service';
import { ObservableManager } from '../../../../service/ObservableManager.service';
import { NotificationManager } from '../../../../service/NotificationManager.service';
import { PhloxAppInfoService } from '../../../../service/PhloxAppInfoService.service';
import { PhloxAppInfo } from '../../../../component/model/PhloxAppInfo';
import { AbstractSideSlidePanel } from '../../../AbstractSideSlidePanel';
const /** @type {?} */ TYPE_NAME = "phx-notifier";
const /** @type {?} */ SUB_TOPIC_NAME = 'phlox-notifier';
export class PhloxNotifier extends AbstractSideSlidePanel {
/**
* @param {?} phloxAppService
* @param {?} observableMgr
* @param {?} needFocusService
* @param {?} notificationManager
* @param {?} phloxAppInfoService
*/
constructor(phloxAppService, observableMgr, needFocusService, notificationManager, phloxAppInfoService) {
super(phloxAppService, observableMgr, needFocusService, PhloxNotifier.SUB_TOPIC_NAME);
this.notificationManager = notificationManager;
if (phloxAppInfoService != null) {
phloxAppInfoService.getAppInfo().then((result) => {
this.phloxAppInfo = result;
});
}
}
/**
* @return {?}
*/
ngOnInit() {
super.ngOnInit();
}
/**
* @return {?}
*/
isRinging() {
if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {
let /** @type {?} */ unReadArray = this.getUnreadNotifications();
if (unReadArray !== null && typeof unReadArray !== 'undefined') {
return unReadArray.length > 0;
}
}
return false;
}
/**
* @return {?}
*/
getUnreadNotifications() {
if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {
let /** @type {?} */ unReadArray = this.notificationManager.getUnreadNotifications();
if (unReadArray !== null && typeof unReadArray !== 'undefined') {
return unReadArray;
}
}
return [];
}
/**
* @return {?}
*/
getNotifications() {
let /** @type {?} */ result = [];
if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {
let /** @type {?} */ allNotifyArray = this.notificationManager.getNotifications();
let /** @type {?} */ maxNotification = PhloxAppInfo.DEFAULT_MAX_NOTIFICATIONS;
if (this.phloxAppInfo !== null && typeof this.phloxAppInfo !== 'undefined') {
if (this.phloxAppInfo.settings !== null && typeof this.phloxAppInfo.settings !== 'undefined') {
maxNotification = this.phloxAppInfo.settings.MAX_NOTIFICATIONS;
}
}
if (allNotifyArray !== null && typeof allNotifyArray !== 'undefined') {
let /** @type {?} */ overLength = 0;
if (allNotifyArray.length > maxNotification) {
overLength = allNotifyArray.length - maxNotification;
let /** @type {?} */ removeArray = allNotifyArray.slice(0, overLength);
for (let /** @type {?} */ r of removeArray) {
this.notificationManager.clear(r);
}
allNotifyArray = this.notificationManager.getNotifications();
}
for (let /** @type {?} */ n of allNotifyArray) {
result.push(n);
}
}
}
return result;
}
/**
* @param {?} $event
* @param {?} notification
* @return {?}
*/
onNotificationClicked($event, notification) {
if (notification === null || typeof notification === 'undefined') {
return;
}
if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {
this.notificationManager.clear(notification);
}
}
/**
* @param {?} event
* @return {?}
*/
onToggle(event) {
super.onToggle(event);
// mark as read
if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {
this.notificationManager.markAsReadAll();
}
}
/**
* @param {?} event
* @return {?}
*/
onClick(event) {
event.stopPropagation();
}
}
PhloxNotifier.TYPE_NAME = TYPE_NAME;
PhloxNotifier.SUB_TOPIC_NAME = SUB_TOPIC_NAME;
PhloxNotifier.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: `<div class="phx-notifier" [class.active]="isActive()" (click)="onToggle($event)">
<div class="wrapper">
<div>
<div class="table-wrapper fluid">
<div class="table-row-wrapper">
<div class="table-cell-wrapper middle">
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" class="bell" [class.ringing]="isRinging()"
xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
viewBox="0 0 30 30" style="enable-background: new 0 0 30 30;"
xml:space="preserve">
<g>
<g>
<path
d="M21.951,19.175l-1-1.221v-3.271c0-3.123-2-5.723-5-6.294V7.575c0-0.673-0.827-1.221-1.5-1.221
c-0.673,0-1.5,0.548-1.5,1.221v0.814c-3,0.57-5,3.171-5,6.294v3.271l-1,1.221v0.71h-1v2h17v-2h-1V19.175z M22.779,19.175" />
</g>
</g>
</svg>
</div>
</div>
</div>
</div>
<div>
<div class="table-wrapper fluid">
<div class="table-row-wrapper">
<div class="table-cell-wrapper middle">
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" class="bell" [class.ringing]="isRinging()"
xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
viewBox="0 0 30 30" style="enable-background: new 0 0 30 30;"
xml:space="preserve">
<g>
<g>
</g>
<path
d="M15.147,24.513c1.136,0,2.117-0.628,2.574-1.628h-5.149C13.03,23.885,14.011,24.513,15.147,24.513
L15.147,24.513z M15.147,24.873" />
</g>
</svg>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="phx-notifier-side-panel right" [class.active]="isActive()">
<div class="row" *ngFor="let notify of getNotifications(); let i = index;" (click)="onNotificationClicked($event, notify)">
{{notify.title}} --> click to clear
</div>
</div>
`
},] },
];
/** @nocollapse */
PhloxNotifier.ctorParameters = () => [
{ type: PhloxAppService, },
{ type: ObservableManager, },
{ type: NeedFocusService, },
{ type: NotificationManager, },
{ type: PhloxAppInfoService, },
];
PhloxNotifier.propDecorators = {
"onClick": [{ type: HostListener, args: ['click', ['$event'],] },],
};
function PhloxNotifier_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
PhloxNotifier.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
PhloxNotifier.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
PhloxNotifier.propDecorators;
/** @type {?} */
PhloxNotifier.TYPE_NAME;
/** @type {?} */
PhloxNotifier.SUB_TOPIC_NAME;
/** @type {?} */
PhloxNotifier.prototype.notificationManager;
/** @type {?} */
PhloxNotifier.prototype.phloxAppInfo;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PhloxNotifier.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/page/main/menu.internal/PhloxNotifier.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, HostListener, ElementRef, Type } from '@angular/core';\n\nimport { PhloxApp } from '../../../PhloxApp.component';\nimport { PhloxAppService } from '../../../../service/PhloxAppService.service';\nimport { NeedFocusService } from '../../../../service/NeedFocusService.service';\nimport { ObservableManager } from '../../../../service/ObservableManager.service';\nimport { NotificationManager } from '../../../../service/NotificationManager.service';\nimport { PhloxAppInfoService } from '../../../../service/PhloxAppInfoService.service';\nimport { Notification } from '../../.././model/Notification';\nimport { PhloxAppInfo } from '../../../../component/model/PhloxAppInfo';\nimport { AbstractSideSlidePanel } from '../../../AbstractSideSlidePanel';\nimport { INotificationManager } from '../../../../share/INotificationManager';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-notifier\";\n\nconst SUB_TOPIC_NAME: string = 'phlox-notifier';\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-notifier\" [class.active]=\"isActive()\" (click)=\"onToggle($event)\">\n\t<div class=\"wrapper\">\n\t\t<div>\n\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t<div class=\"table-row-wrapper\">\n\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t<svg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" class=\"bell\" [class.ringing]=\"isRinging()\"\n\t\t\t\t\t\t\txmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n\t\t\t\t\t\t\tviewBox=\"0 0 30 30\" style=\"enable-background: new 0 0 30 30;\"\n\t\t\t\t\t\t\txml:space=\"preserve\">\n\t\t\t\t\t\t\t\t<g>\n\t\t\t\t\t\t\t\t\t<g>\n\t\t\t\t\t\t\t\t\t\t<path\n\t\t\t\t\t\t\t\t\t\t\td=\"M21.951,19.175l-1-1.221v-3.271c0-3.123-2-5.723-5-6.294V7.575c0-0.673-0.827-1.221-1.5-1.221\n\t\t\t\t\t\t\t\t\t\t\tc-0.673,0-1.5,0.548-1.5,1.221v0.814c-3,0.57-5,3.171-5,6.294v3.271l-1,1.221v0.71h-1v2h17v-2h-1V19.175z M22.779,19.175\" />\n\t\t\t\t\t\t\t\t\t</g>\n\t\t\t\t\t\t\t\t</g>\n\t\t\t\t\t\t\t</svg>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div>\n\t\t\t<div class=\"table-wrapper fluid\">\n\t\t\t\t<div class=\"table-row-wrapper\">\n\t\t\t\t\t<div class=\"table-cell-wrapper middle\">\n\t\t\t\t\t\t<svg version=\"1.1\" id=\"Layer_1\" xmlns=\"http://www.w3.org/2000/svg\" class=\"bell\" [class.ringing]=\"isRinging()\"\n\t\t\t\t\t\t\txmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0px\" y=\"0px\"\n\t\t\t\t\t\t\tviewBox=\"0 0 30 30\" style=\"enable-background: new 0 0 30 30;\"\n\t\t\t\t\t\t\txml:space=\"preserve\">\n\t\t\t\t\t\t\t\t<g>\n\t\t\t\t\t\t\t\t\t<g>\n\n\t\t\t\t\t\t\t\t\t</g>\n\t\t\t\t\t\t\t\t\t<path\n\t\t\t\t\t\t\t\t\t\t\td=\"M15.147,24.513c1.136,0,2.117-0.628,2.574-1.628h-5.149C13.03,23.885,14.011,24.513,15.147,24.513\n\t\t\t\t\t\t\t\t\t\tL15.147,24.513z M15.147,24.873\" />\n\t\t\t\t\t\t\t\t</g>\n\t\t\t\t\t\t\t</svg>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</div>\n<div class=\"phx-notifier-side-panel right\" [class.active]=\"isActive()\">\n\t<div class=\"row\" *ngFor=\"let notify of getNotifications(); let i = index;\" (click)=\"onNotificationClicked($event, notify)\">\n\t\t{{notify.title}} --> click to clear\n\t</div>\n</div>\n`\n})\nexport class PhloxNotifier extends AbstractSideSlidePanel implements OnInit {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  public static readonly SUB_TOPIC_NAME: string = SUB_TOPIC_NAME;\n\n  private notificationManager: INotificationManager;\n  private phloxAppInfo: PhloxAppInfo;\n\n  constructor(phloxAppService: PhloxAppService, observableMgr: ObservableManager, needFocusService: NeedFocusService, notificationManager: NotificationManager, phloxAppInfoService: PhloxAppInfoService) {\n    super(phloxAppService, observableMgr, needFocusService, PhloxNotifier.SUB_TOPIC_NAME);\n\n    this.notificationManager = notificationManager;\n\n    if (phloxAppInfoService != null) {\n      phloxAppInfoService.getAppInfo().then((result) => {\n        this.phloxAppInfo = result;\n      });\n    }\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n  }\n\n  public isRinging(): boolean {\n    if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {\n      let unReadArray = this.getUnreadNotifications();\n\n      if (unReadArray !== null && typeof unReadArray !== 'undefined') {\n        return unReadArray.length > 0;\n      }\n    }\n    return false;\n  }\n\n  public getUnreadNotifications(): Notification[] {\n    if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {\n      let unReadArray = this.notificationManager.getUnreadNotifications();\n\n      if (unReadArray !== null && typeof unReadArray !== 'undefined') {\n        return unReadArray;\n      }\n    }\n\n    return [];\n  }\n\n  public getNotifications(): Notification[] {\n    let result = [];\n    if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {\n      let allNotifyArray = this.notificationManager.getNotifications();\n      let maxNotification = PhloxAppInfo.DEFAULT_MAX_NOTIFICATIONS;\n      if (this.phloxAppInfo !== null && typeof this.phloxAppInfo !== 'undefined') {\n        if (this.phloxAppInfo.settings !== null && typeof this.phloxAppInfo.settings !== 'undefined') {\n          maxNotification = this.phloxAppInfo.settings.MAX_NOTIFICATIONS;\n        }\n      }\n\n      if (allNotifyArray !== null && typeof allNotifyArray !== 'undefined') {\n        let overLength = 0;\n        if (allNotifyArray.length > maxNotification) {\n          overLength = allNotifyArray.length - maxNotification;\n\n          let removeArray = allNotifyArray.slice(0, overLength);\n\n          for (let r of removeArray) {\n            this.notificationManager.clear(r);\n          }\n          allNotifyArray = this.notificationManager.getNotifications();\n        }\n\n        for (let n of allNotifyArray) {\n          result.push(n);\n        }\n      }\n    }\n\n    return result;\n  }\n\n  public onNotificationClicked($event: Event, notification: Notification): void {\n    if (notification === null || typeof notification === 'undefined') {\n      return;\n    }\n    if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {\n      this.notificationManager.clear(notification);\n    }\n  }\n\n  public onToggle(event: MouseEvent): void {\n    super.onToggle(event);\n\n    // mark as read\n    if (this.notificationManager !== null && typeof this.notificationManager !== 'undefined') {\n      this.notificationManager.markAsReadAll();\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  public onClick(event: MouseEvent): void {\n    event.stopPropagation();\n  }\n}\n"]}