nuxeo-development-framework 3.8.2 → 3.8.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/nuxeo-development-framework.umd.js +31221 -30524
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/notifications/components/base-list-notfications.component.js +156 -0
- package/esm2015/lib/components/notifications/components/base-notifications.component.js +31 -0
- package/esm2015/lib/components/notifications/components/index.js +7 -0
- package/esm2015/lib/components/notifications/components/notification-item/get-icon.pipe.js +44 -0
- package/esm2015/lib/components/notifications/components/notification-item/notification-item.component.js +41 -129
- package/esm2015/lib/components/notifications/components/notification-source-select/notification-source-select.component.js +38 -0
- package/esm2015/lib/components/notifications/components/notification-status-toggle/notification-status-toggle.component.js +26 -0
- package/esm2015/lib/components/notifications/components/notifications-button/notifications-button.component.js +77 -165
- package/esm2015/lib/components/notifications/components/notifications-date-select/notifications-date-select.component.js +63 -0
- package/esm2015/lib/components/notifications/components/notifications-list/notifications-list.component.js +53 -175
- package/esm2015/lib/components/notifications/components/notifications-list/options.js +24 -0
- package/esm2015/lib/components/notifications/components/notifications-list-actions/notifications-list-actions.component.js +43 -0
- package/esm2015/lib/components/notifications/components/notifications-settings/check-if-subscribed.pipe.js +28 -0
- package/esm2015/lib/components/notifications/components/notifications-settings/notifications-settings.adapter.js +30 -0
- package/esm2015/lib/components/notifications/components/notifications-settings/notifications-settings.component.js +163 -0
- package/esm2015/lib/components/notifications/components/notifications-sidebar/notifications-sidebar-content.js +28 -0
- package/esm2015/lib/components/notifications/components/notifications-sidebar/notifications-sidebar.component.js +158 -0
- package/esm2015/lib/components/notifications/constants/date.js +8 -0
- package/esm2015/lib/components/notifications/constants/index.js +5 -0
- package/esm2015/lib/components/notifications/constants/pagination.js +5 -0
- package/esm2015/lib/components/notifications/constants/panel.js +5 -0
- package/esm2015/lib/components/notifications/constants/status.js +10 -0
- package/esm2015/lib/components/notifications/containers/index.js +3 -0
- package/esm2015/lib/components/notifications/containers/notifications-list-container/notifications-list-container.component.js +98 -0
- package/esm2015/lib/components/notifications/containers/notifications-list-container/options.js +18 -0
- package/esm2015/lib/components/notifications/containers/notifications-settings-container/notifications-settings-container.component.js +67 -0
- package/esm2015/lib/components/notifications/directives/button.directive.js +28 -0
- package/esm2015/lib/components/notifications/directives/index.js +3 -0
- package/esm2015/lib/components/notifications/directives/notification.directive.js +28 -0
- package/esm2015/lib/components/notifications/index.js +2 -0
- package/esm2015/lib/components/notifications/models/common.js +2 -0
- package/esm2015/lib/components/notifications/models/index.js +11 -0
- package/esm2015/lib/components/notifications/models/notification-definition.model.js +2 -0
- package/esm2015/lib/components/notifications/models/notification-options.js +2 -0
- package/esm2015/lib/components/notifications/models/notification-setting.presenter.js +2 -0
- package/esm2015/lib/components/notifications/models/notification-subscription.model.js +2 -0
- package/esm2015/lib/components/notifications/models/notification.model.js +2 -0
- package/esm2015/lib/components/notifications/models/notifications-list-options.js +3 -0
- package/esm2015/lib/components/notifications/models/paging-response.model.js +2 -0
- package/esm2015/lib/components/notifications/models/params.model.js +2 -0
- package/esm2015/lib/components/notifications/models/vocabularies.js +2 -0
- package/esm2015/lib/components/notifications/notifications.module.js +80 -46
- package/esm2015/lib/components/notifications/public-api.js +9 -0
- package/esm2015/lib/components/notifications/services/index.js +2 -0
- package/esm2015/lib/components/notifications/services/listener.service.js +19 -0
- package/esm2015/lib/components/notifications/services/notifications.service.js +156 -0
- package/esm2015/lib/components/notifications/services/params.service.js +31 -0
- package/esm2015/lib/components/notifications/services/response.service.js +65 -0
- package/esm2015/lib/components/notifications/utilities/index.js +2 -0
- package/esm2015/lib/components/notifications/utilities/response.adapter.js +12 -0
- package/esm2015/lib/components/{notifications → toasts}/components/notification-toast/notification-toast.component.js +7 -11
- package/esm2015/lib/components/toasts/index.js +2 -0
- package/esm2015/lib/components/toasts/public-api.js +3 -0
- package/esm2015/lib/components/toasts/toasts.module.js +19 -0
- package/esm2015/lib/core/models/api-response.model.js +2 -0
- package/esm2015/lib/core/models/automation-response.model.js +2 -0
- package/esm2015/lib/core/models/base-response.models.js +2 -0
- package/esm2015/lib/core/models/index.js +5 -0
- package/esm2015/lib/core/services/nuxeo/nuxeo.service.js +3 -3
- package/esm2015/lib/core/services/translation/translation.service.js +3 -3
- package/esm2015/public-api.js +136 -142
- package/fesm2015/nuxeo-development-framework.js +23227 -22604
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/notifications/components/base-list-notfications.component.d.ts +42 -0
- package/lib/components/notifications/components/base-notifications.component.d.ts +17 -0
- package/lib/components/notifications/components/index.d.ts +6 -0
- package/lib/components/notifications/components/notification-item/get-icon.pipe.d.ts +8 -0
- package/lib/components/notifications/components/notification-item/notification-item.component.d.ts +21 -22
- package/lib/components/notifications/components/notification-source-select/notification-source-select.component.d.ts +15 -0
- package/lib/components/notifications/components/notification-status-toggle/notification-status-toggle.component.d.ts +8 -0
- package/lib/components/notifications/components/notifications-button/notifications-button.component.d.ts +31 -30
- package/lib/components/notifications/components/notifications-date-select/notifications-date-select.component.d.ts +22 -0
- package/lib/components/notifications/components/notifications-list/notifications-list.component.d.ts +15 -54
- package/lib/components/notifications/components/notifications-list/options.d.ts +2 -0
- package/lib/components/notifications/components/notifications-list-actions/notifications-list-actions.component.d.ts +15 -0
- package/lib/components/notifications/components/notifications-settings/check-if-subscribed.pipe.d.ts +8 -0
- package/lib/components/notifications/components/notifications-settings/notifications-settings.adapter.d.ts +3 -0
- package/lib/components/notifications/components/notifications-settings/notifications-settings.component.d.ts +40 -0
- package/lib/components/notifications/components/notifications-sidebar/notifications-sidebar-content.d.ts +9 -0
- package/lib/components/notifications/components/notifications-sidebar/notifications-sidebar.component.d.ts +43 -0
- package/lib/components/notifications/constants/date.d.ts +7 -0
- package/lib/components/notifications/constants/index.d.ts +4 -0
- package/lib/components/notifications/constants/pagination.d.ts +4 -0
- package/lib/components/notifications/constants/panel.d.ts +4 -0
- package/lib/components/notifications/constants/status.d.ts +9 -0
- package/lib/components/notifications/containers/index.d.ts +2 -0
- package/lib/components/notifications/containers/notifications-list-container/notifications-list-container.component.d.ts +27 -0
- package/lib/components/notifications/containers/notifications-list-container/options.d.ts +2 -0
- package/lib/components/notifications/containers/notifications-settings-container/notifications-settings-container.component.d.ts +22 -0
- package/lib/components/notifications/directives/button.directive.d.ts +9 -0
- package/lib/components/notifications/directives/index.d.ts +2 -0
- package/lib/components/notifications/directives/notification.directive.d.ts +9 -0
- package/lib/components/notifications/index.d.ts +1 -0
- package/lib/components/notifications/models/common.d.ts +64 -0
- package/lib/components/notifications/models/index.d.ts +10 -0
- package/lib/components/notifications/models/notification-definition.model.d.ts +17 -0
- package/lib/components/notifications/models/notification-options.d.ts +7 -0
- package/lib/components/notifications/models/notification-setting.presenter.d.ts +24 -0
- package/lib/components/notifications/models/notification-subscription.model.d.ts +13 -0
- package/lib/components/notifications/models/notification.model.d.ts +16 -0
- package/lib/components/notifications/models/notifications-list-options.d.ts +34 -0
- package/lib/components/notifications/models/paging-response.model.d.ts +12 -0
- package/lib/components/notifications/models/params.model.d.ts +6 -0
- package/lib/components/notifications/models/vocabularies.d.ts +12 -0
- package/lib/components/notifications/notifications.module.d.ts +32 -16
- package/lib/components/notifications/public-api.d.ts +8 -0
- package/lib/components/notifications/services/index.d.ts +1 -0
- package/lib/components/notifications/services/listener.service.d.ts +8 -0
- package/lib/components/notifications/services/notifications.service.d.ts +56 -0
- package/lib/components/notifications/services/params.service.d.ts +19 -0
- package/lib/components/notifications/services/response.service.d.ts +19 -0
- package/lib/components/notifications/utilities/index.d.ts +1 -0
- package/lib/components/notifications/utilities/response.adapter.d.ts +3 -0
- package/lib/components/{notifications → toasts}/components/notification-toast/notification-toast.component.d.ts +1 -3
- package/lib/components/toasts/index.d.ts +1 -0
- package/lib/components/toasts/public-api.d.ts +2 -0
- package/lib/components/toasts/toasts.module.d.ts +8 -0
- package/lib/core/models/api-response.model.d.ts +24 -0
- package/lib/core/models/automation-response.model.d.ts +24 -0
- package/lib/core/models/base-response.models.d.ts +12 -0
- package/lib/core/models/index.d.ts +4 -0
- package/lib/core/services/nuxeo/nuxeo.service.d.ts +1 -1
- package/lib/core/services/translation/translation.service.d.ts +3 -3
- package/package.json +1 -1
- package/public-api.d.ts +130 -136
- package/esm2015/lib/components/notifications/components/notification-options/notification-options.component.js +0 -22
- package/esm2015/lib/components/notifications/notifications.service.js +0 -358
- package/lib/components/notifications/components/notification-options/notification-options.component.d.ts +0 -10
- package/lib/components/notifications/notifications.service.d.ts +0 -87
|
@@ -1,191 +1,69 @@
|
|
|
1
|
-
import { Component, EventEmitter,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Optional, Output, } from '@angular/core';
|
|
2
|
+
import _ from 'lodash';
|
|
3
|
+
import { NOTIFICATION_STATUS } from '../../constants';
|
|
4
|
+
import { NOTIFICATIONS_LIST_OPTIONS, } from '../../models';
|
|
5
|
+
import { ParamsService } from '../../services/params.service';
|
|
6
|
+
import { ResponseService } from '../../services/response.service';
|
|
7
|
+
import { BaseListNotifications } from '../base-list-notfications.component';
|
|
8
|
+
import { DEFAULT_LIST_OPTIONS } from './options';
|
|
2
9
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "
|
|
4
|
-
import * as i2 from "
|
|
5
|
-
import * as i3 from "
|
|
6
|
-
import * as i4 from "
|
|
7
|
-
import * as i5 from "
|
|
8
|
-
import * as i6 from "@angular/material/
|
|
9
|
-
import * as i7 from "
|
|
10
|
-
import * as i8 from "@angular/
|
|
10
|
+
import * as i1 from "../notification-source-select/notification-source-select.component";
|
|
11
|
+
import * as i2 from "../notifications-date-select/notifications-date-select.component";
|
|
12
|
+
import * as i3 from "../notification-status-toggle/notification-status-toggle.component";
|
|
13
|
+
import * as i4 from "../notifications-list-actions/notifications-list-actions.component";
|
|
14
|
+
import * as i5 from "../notification-item/notification-item.component";
|
|
15
|
+
import * as i6 from "@angular/material/progress-spinner";
|
|
16
|
+
import * as i7 from "@angular/material/menu";
|
|
17
|
+
import * as i8 from "@angular/common";
|
|
11
18
|
import * as i9 from "ngx-infinite-scroll";
|
|
12
19
|
import * as i10 from "@ngx-translate/core";
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
this.
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
this._itemHeight = 79;
|
|
25
|
-
this._divider = true;
|
|
26
|
-
this._all = true;
|
|
27
|
-
this._title = "notifications.title";
|
|
28
|
-
this.throttle = 300;
|
|
29
|
-
this.scrollDistance = 7;
|
|
30
|
-
this.scrollUpDistance = 2;
|
|
31
|
-
this.loading = false;
|
|
32
|
-
this.hasMore = true;
|
|
33
|
-
this.compareDate = (item, itemIndex, items) => {
|
|
34
|
-
if (!this.divider) {
|
|
35
|
-
return null;
|
|
36
|
-
}
|
|
37
|
-
const today = new Date();
|
|
38
|
-
const itemDate = new Date(item.sendDate);
|
|
39
|
-
const isToday = itemDate.getDate() === today.getDate() &&
|
|
40
|
-
itemDate.getMonth() === today.getMonth() &&
|
|
41
|
-
itemDate.getFullYear() === today.getFullYear();
|
|
42
|
-
const prevItem = items[itemIndex - 1];
|
|
43
|
-
let isPrevToday = 0;
|
|
44
|
-
if (prevItem) {
|
|
45
|
-
const NextItemDate = new Date(prevItem.sendDate);
|
|
46
|
-
isPrevToday =
|
|
47
|
-
NextItemDate.getDate() === today.getDate() &&
|
|
48
|
-
NextItemDate.getMonth() === today.getMonth() &&
|
|
49
|
-
NextItemDate.getFullYear() === today.getFullYear()
|
|
50
|
-
? 2
|
|
51
|
-
: 1;
|
|
52
|
-
}
|
|
53
|
-
if (!isToday && (isPrevToday === 0 || isPrevToday === 2)) {
|
|
54
|
-
return "notifications.earlier";
|
|
55
|
-
}
|
|
56
|
-
if (isToday && (isPrevToday === 0 || isPrevToday === 1)) {
|
|
57
|
-
return "notifications.new";
|
|
58
|
-
}
|
|
59
|
-
return null;
|
|
60
|
-
};
|
|
61
|
-
this.getItemHeight = () => {
|
|
62
|
-
return this.itemHeight;
|
|
63
|
-
};
|
|
64
|
-
}
|
|
65
|
-
get notifications() {
|
|
66
|
-
return this.notificationsService.notifications;
|
|
67
|
-
}
|
|
68
|
-
get itemHeight() {
|
|
69
|
-
return this._itemHeight;
|
|
70
|
-
}
|
|
71
|
-
set itemHeight(value) {
|
|
72
|
-
this._itemHeight = value;
|
|
73
|
-
}
|
|
74
|
-
get divider() {
|
|
75
|
-
return this._divider;
|
|
76
|
-
}
|
|
77
|
-
set divider(value) {
|
|
78
|
-
this._divider = value;
|
|
79
|
-
}
|
|
80
|
-
get all() {
|
|
81
|
-
return this._all;
|
|
82
|
-
}
|
|
83
|
-
set all(value) {
|
|
84
|
-
this._all = value;
|
|
85
|
-
}
|
|
86
|
-
get title() {
|
|
87
|
-
return this._title;
|
|
88
|
-
}
|
|
89
|
-
set title(value) {
|
|
90
|
-
this._title = value;
|
|
91
|
-
}
|
|
92
|
-
ngOnInit() {
|
|
93
|
-
this.changeContentBasedOnUserLang();
|
|
94
|
-
this.notificationsService.pageSize = this.showFilters ? 30 : 15;
|
|
95
|
-
}
|
|
96
|
-
markAllAsRead() {
|
|
97
|
-
this.notificationsService.markAllAsRead();
|
|
98
|
-
}
|
|
99
|
-
openNotification(notification) {
|
|
100
|
-
if (notification.status === "UN_READ" || notification.status === "NEW") {
|
|
101
|
-
this.notificationsService.updateStatus(notification, true);
|
|
102
|
-
}
|
|
103
|
-
this.listItemClick.next(notification);
|
|
104
|
-
// do something when notification clicked
|
|
105
|
-
}
|
|
106
|
-
onUpdate(data) {
|
|
107
|
-
if (data.notification) {
|
|
108
|
-
switch (data.action) {
|
|
109
|
-
case "delete":
|
|
110
|
-
this.notificationsService.deleteNotification(data.notification);
|
|
111
|
-
break;
|
|
112
|
-
case "status":
|
|
113
|
-
this.notificationsService.updateStatus(data.notification);
|
|
114
|
-
break;
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
trackBy(index, item) {
|
|
119
|
-
return item.id;
|
|
120
|
-
}
|
|
121
|
-
handleOpen(item) {
|
|
122
|
-
// this.modalController.dismiss();
|
|
123
|
-
this.notificationsService.updateStatus(item, true);
|
|
124
|
-
}
|
|
125
|
-
goToDetails(notification) { }
|
|
126
|
-
onScrollDown() {
|
|
127
|
-
if (this.hasMore) {
|
|
128
|
-
this.fetchMore();
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
fetchMore() {
|
|
132
|
-
this.loading = true;
|
|
133
|
-
this.notificationsService.fetchNotifications().subscribe((data) => {
|
|
134
|
-
this.loading = false;
|
|
135
|
-
if (data["items"].length === 0 ||
|
|
136
|
-
data["items"].length < this.notificationsService.pageSize) {
|
|
137
|
-
this.hasMore = false;
|
|
138
|
-
}
|
|
139
|
-
this.ref.markForCheck();
|
|
20
|
+
export class NotificationsListComponent extends BaseListNotifications {
|
|
21
|
+
constructor(inject, _options) {
|
|
22
|
+
super(inject);
|
|
23
|
+
this.inject = inject;
|
|
24
|
+
this.openSettings = new EventEmitter();
|
|
25
|
+
this.openNotifications = new EventEmitter();
|
|
26
|
+
this.options = _.merge(DEFAULT_LIST_OPTIONS, _options ? _options : {});
|
|
27
|
+
this._paramsService.setDefaultParams({
|
|
28
|
+
pageSize: this.options.pageSize || 20,
|
|
29
|
+
sortBy: 'dc:created',
|
|
30
|
+
sortOrder: 'desc',
|
|
140
31
|
});
|
|
141
32
|
}
|
|
142
|
-
|
|
143
|
-
this.
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
// this.modalController.dismiss();
|
|
147
|
-
}
|
|
148
|
-
changeContentBasedOnUserLang() {
|
|
149
|
-
this.translationService.isArabic.subscribe((ar) => {
|
|
150
|
-
this.isArabic = ar;
|
|
151
|
-
});
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
this._prepareLanguage();
|
|
35
|
+
this._prepareData();
|
|
36
|
+
this._paramsService.applyParams();
|
|
152
37
|
}
|
|
153
|
-
|
|
154
|
-
|
|
38
|
+
typeChanged(event) {
|
|
39
|
+
this._applyFilter(Object.assign({ currentPageIndex: 0 }, (event ? { notf_notification_sourceTypee: event } : {})));
|
|
155
40
|
}
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
this.notificationsService.selectedFilterType = type;
|
|
159
|
-
// front end filtering;
|
|
160
|
-
console.log(this.notifications);
|
|
161
|
-
this.trigger.closeMenu();
|
|
162
|
-
this.notificationsService.setNotifications(this.notificationsService.filterNotifications(this.notificationsService.storedNotifications));
|
|
41
|
+
statusChanged({ checked }) {
|
|
42
|
+
this._applyFilter(Object.assign({ currentPageIndex: 0 }, (checked ? { notfnotificationcontent_status: NOTIFICATION_STATUS.read } : {})));
|
|
163
43
|
}
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
this.notificationsService.isReaded = event.checked;
|
|
167
|
-
// front end filtering
|
|
168
|
-
console.log(this.notifications);
|
|
169
|
-
this.notificationsService.setNotifications(this.notificationsService.filterNotifications(this.notificationsService.storedNotifications));
|
|
44
|
+
dateChanged(date) {
|
|
45
|
+
this._applyFilter(Object.assign({ currentPageIndex: 0 }, (date ? { dublincore_created_agg: [date] } : {})));
|
|
170
46
|
}
|
|
171
47
|
}
|
|
172
|
-
NotificationsListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NotificationsListComponent, deps: [{ token:
|
|
173
|
-
NotificationsListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: NotificationsListComponent, selector: "app-notifications-list", inputs: { showFilters: "showFilters" }, outputs: { listItemClick: "listItemClick" }, host: { classAttribute: "notification-list" }, viewQueries: [{ propertyName: "trigger", first: true, predicate: ["filterTypeMenuTrigger"], descendants: true }], ngImport: i0, template: "<div class=\"toolbar\">\r\n <div class=\"title\">\r\n <div>{{ \"notifications.notifications\" | translate }}</div>\r\n </div>\r\n <div class=\"flex justify-end\">\r\n <button\r\n mat-button\r\n (click)=\"markAllAsRead()\"\r\n size=\"small\"\r\n fill=\"none\"\r\n class=\"markAllAsRead-btn\"\r\n >\r\n {{ \"notifications.markAllAsRead\" | translate }}\r\n </button>\r\n <ng-container *ngIf=\"showFilters\">\r\n <div class=\"type-filter\">\r\n <button (click)=\"stop($event)\" class=\"type-filter-trigger\"\r\n [matMenuTriggerFor]=\"filterTypeMenu\" #filterTypeMenuTrigger=\"matMenuTrigger\">\r\n {{'notifications.' + notificationsService.selectedFilterType.name | translate}} \r\n <span class=\"icon icon-chevron-down\"></span>\r\n </button>\r\n <mat-menu class=\"new-menu-design\" #filterTypeMenu=\"matMenu\" >\r\n <div (click)=\"stop($event)\">\r\n <div class=\"single-menu-action notification-filter-menu-item\" *ngFor=\"let type of notificationsService.types\" (click)=\"selectFilterType($event ,type)\">\r\n {{'notifications.' + type.name | translate}}\r\n </div>\r\n </div>\r\n </mat-menu>\r\n <div class=\"notification-toggle\" (click)=\"stop($event)\">\r\n <mat-slide-toggle [checked]=\"notificationsService.isReaded\" (change)=\"changeReadFilter($event)\">{{'notifications.Readed' | translate }}</mat-slide-toggle>\r\n </div>\r\n </div>\r\n \r\n </ng-container>\r\n </div>\r\n</div>\r\n<!-- [matTooltip]=\"'notifications.markAllAsRead' | translate\"\r\n [matTooltipPosition]=\"'before'\" -->\r\n<div *ngIf=\"!notifications?.length\" class=\"no-notifications\">\r\n <p *ngIf=\"!notificationsService.loading\">\r\n {{ \"notifications.noNotifications\" | translate }}\r\n </p>\r\n <p *ngIf=\"notificationsService.loading\">\r\n {{ \"notifications.loading_notification\" | translate }}\r\n </p>\r\n</div>\r\n<div\r\n infiniteScroll\r\n [scrollWindow]=\"false\"\r\n [infiniteScrollDistance]=\"scrollDistance\"\r\n [infiniteScrollThrottle]=\"throttle\"\r\n (scrolled)=\"onScrollDown()\"\r\n class=\"notifications-container scroll\"\r\n>\r\n <mat-list class=\"\">\r\n <ng-container\r\n *ngFor=\"\r\n let notification of notifications;\r\n let i = index;\r\n trackBy: trackBy\r\n \"\r\n >\r\n <!-- <mat-divider class=\"marginize\"></mat-divider> -->\r\n <app-notification-item\r\n (click)=\"openNotification(notification)\"\r\n (update)=\"onUpdate($event)\"\r\n [notification]=\"notification\"\r\n [isArabic]=\"isArabic\"\r\n ></app-notification-item>\r\n </ng-container>\r\n <div\r\n *ngIf=\"loading\"\r\n style=\"display: grid; place-items: center; margin-top: 10px\"\r\n >\r\n <mat-spinner [diameter]=\"48\" style=\"margin: 0 auto\"></mat-spinner>\r\n </div>\r\n </mat-list>\r\n</div>\r\n", styles: [".bi{margin:0!important}.memo-sorting-wrapper{width:265px;margin:0 10px;height:100%;display:flex}.memo-sorting-wrapper .sorting-direction{width:65px;height:40px;background-color:#465573;color:#fff;font-size:20px;display:flex;justify-content:center;align-items:center;cursor:pointer}.memo-sorting-wrapper .memo-sorting-trigger{width:calc(100% - 65px);height:100%;background-color:transparent;border:1px solid lightgrey;display:flex;justify-content:space-between;align-items:center;padding:0 15px;font-size:14px}.memo-sorting-wrapper .memo-sorting-trigger i{font-size:16px;color:gray}.memo-sorting-menu{width:200px}.my-button{border:1px solid #465573;color:#465573;border-radius:5px;background-color:transparent;font-weight:bold;min-width:80px;height:40px}.my-button.reset{border:none}.my-button:hover{color:#fff;background-color:#465573}.my-button:hover.reset{color:#465573;border:1px solid #465573;background-color:#fff}.app-property-value .app-input-wrapper label{color:#646f85;font-size:13px;margin-bottom:5px}.app-property-value .app-input-wrapper label .text-danger{font-size:16px;line-height:14px;margin:0 5px!important}.app-property-value .app-input-wrapper .form-control{border:1px solid #ccc;border-radius:5px;background-color:#8f98aa1a;height:40px}.app-property-value .app-input-wrapper .form-control:disabled{background-color:#e9ecef!important}.app-property-value .app-input-wrapper .form-control:focus{border:1px solid #1a96c6;box-shadow:0 0 4px #79c3c26b!important}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers{list-style:none;padding:0;margin:0;font-size:14px}.app-property-value .app-input-wrapper .app-textitem-editable-error .error-containers .error{margin-top:5px}.autocomplete-container .input-container input:focus,hijri-gregorian-datepicker .form-group .input-group .form-control:focus,.ng-select.ng-select-focused .ng-select-container{border:1px solid #1a96c6!important;box-shadow:0 0 4px #79c3c26b!important}input::placeholder{font-size:12px}.form-control:focus{box-shadow:none!important}.mat-stepper-horizontal{margin-top:-25px}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header.cdk-program-focused{background-color:transparent}.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-icon-selected{background-color:transparent;color:#fff;background-image:linear-gradient(to right,#0dbab5,#1a96c6)}@media only screen and (max-width: 576px){.mat-stepper-horizontal .mat-horizontal-stepper-header-container .mat-step-header .mat-step-label .mat-step-text-label{white-space:pre-wrap;overflow:visible}}.mat-stepper-horizontal .mat-horizontal-content-container{overflow:visible}@media only screen and (max-width: 768px){.mat-stepper-horizontal .mat-horizontal-content-container{padding:0 0 24px}}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:after,.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:before{display:none}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:first-child:before{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);left:0}.mat-stepper-horizontal.rtl .mat-horizontal-stepper-header:last-child:after{border-top-width:1px;border-top-style:solid;content:\"\";display:inline-block;height:0;position:absolute;width:calc(50% - 20px);right:0}.form-wrapper{padding:30px 15px;border:1px solid #dde0e2}.form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.form-wrapper .buttons-wrapper button:hover{opacity:.7}.form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.form-wrapper .upload-wrapper button span{margin:0 10px}.renameFileComponent .form-wrapper{padding:30px 15px;border:none!important}.renameFileComponent .form-wrapper .buttons-wrapper{display:flex;justify-content:space-between}.renameFileComponent .form-wrapper .buttons-wrapper .action-buttons-wrapper{display:flex}.renameFileComponent .form-wrapper .buttons-wrapper button{background-image:linear-gradient(to right,#0dbab5,#1a96c6);height:40px;color:#fff;border:none;width:125px;margin-top:20px;border-radius:5px}.renameFileComponent .form-wrapper .buttons-wrapper button:disabled{opacity:.4;cursor:not-allowed}.renameFileComponent .form-wrapper .buttons-wrapper button:hover{opacity:.7}.renameFileComponent .form-wrapper .upload-wrapper{display:flex;flex-direction:column;justify-content:flex-end}.renameFileComponent .form-wrapper .upload-wrapper label{color:#8f98aa;font-size:14px}.renameFileComponent .form-wrapper .upload-wrapper button{padding:10px;border:1px solid lightgray}.renameFileComponent .form-wrapper .upload-wrapper button span{margin:0 10px}.my-dynamic-viewer{display:flex;align-items:center;font-size:12px;min-height:30px}.my-dynamic-viewer .my-label{font-size:12px;font-weight:500;width:150px;word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-label{width:50%}}.my-dynamic-viewer .my-value{width:calc(100% - 150px);word-break:break-word}@media (max-width: 992px){.my-dynamic-viewer .my-value{width:50%}}.my-dynamic-viewer .direction-img{font-size:14px}.my-dynamic-viewer .direction-img .incoming{display:none}.my-dynamic-viewer .direction-img .outgoing{display:none}.my-dynamic-viewer .direction-img .internal{display:none}.my-dynamic-viewer.draft .my-value{color:#596973}.my-dynamic-viewer.inProgress .my-value{color:#3c3cf0}.my-dynamic-viewer.registered .my-value{color:#4f008c}.my-dynamic-viewer.archived .my-value{color:#fbb62c}.my-dynamic-viewer.closed .my-value{color:#00dca5}.my-dynamic-viewer.approved .my-value{color:#06a57e}.my-dynamic-viewer.assigned .my-value{color:#fd6670}.my-dynamic-viewer.sent .my-value{color:#3c3cf0}.my-dynamic-viewer.published .my-value{color:#00dca5}.my-dynamic-viewer.Outgoing .my-value{display:flex}.my-dynamic-viewer.Outgoing .my-value .direction-img .outgoing{color:#fbb62c;margin:1px 5px;display:flex}.my-dynamic-viewer.Outgoing .my-value .text{margin:0 5px}.my-dynamic-viewer.Internal .my-value{display:flex}.my-dynamic-viewer.Internal .my-value .direction-img .internal{color:#3c3cf0;margin:1px 5px;display:flex}.my-dynamic-viewer.Internal .my-value .text{margin:0 5px}.my-dynamic-viewer.Incoming .my-value{display:flex}.my-dynamic-viewer.Incoming .my-value .direction-img .incoming{color:#00dca5;display:flex}.my-dynamic-viewer.Incoming .my-value .text{margin:-3px 5px 0}.my-dynamic-viewer.vertical{display:block}.my-dynamic-viewer.vertical .my-label{width:auto}.my-dynamic-viewer.vertical .my-value{width:auto}.my-dynamic-viewer.with-out-label{width:100%!important}:host{height:100%;position:relative}.toolbar{background-image:linear-gradient(to right,#0dbab5,#1a96c6);display:flex;justify-content:space-between;align-items:center;color:#fff;font-weight:700;padding:.25rem 1.5rem}.toolbar .title{font-size:1.125rem;line-height:1.75rem;display:flex;align-items:center}.toolbar .markAllAsRead-btn{background:none;border:none;margin:0;padding:0;cursor:pointer;font-size:.75rem;line-height:1rem;display:flex;align-items:center;color:#fff}.no-notifications{margin-top:1.25rem;display:flex;justify-content:center;align-items:center}.no-notifications p{text-align:center;color:#b4bac6}.notifications-container{height:100%;overflow:scroll}.notifications-container ::-webkit-scrollbar{width:8px}.notifications-container mat-list{padding:16px;display:grid;grid-row-gap:8px;row-gap:8px}.scroll::-webkit-scrollbar-thumb{background-color:#d9dce2}div[scrollx=true],div[scrolly=true]{position:relative;overflow:hidden;max-height:80vh}div[scrollx=true] ::-webkit-scrollbar,div[scrolly=true] ::-webkit-scrollbar{display:none}div[scrollx=true]{overflow-x:auto}div[scrolly=true]{overflow-y:auto}ion-toolbar{min-height:40px;height:40px;--min-height: 40px;box-shadow:0 0 1px 1px #cbcbcb}ion-toolbar ion-title{height:14px;font-size:13px;font-weight:bold}ion-toolbar ion-button{font-size:12px;letter-spacing:0px}ion-item-divider{--background: rgba(var(--ion-color-light-rgb), 1);color:#666}\n"], components: [{ type: i4.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i5.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex", "name", "id", "labelPosition", "aria-label", "aria-labelledby", "required", "checked"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { type: i6.MatList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { type: i7.NotificationItemComponent, selector: "app-notification-item", inputs: ["notification", "isArabic"], outputs: ["update"] }, { type: i8.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["matMenuTriggerRestoreFocus", "mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i9.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }], pipes: { "translate": i10.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
48
|
+
NotificationsListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NotificationsListComponent, deps: [{ token: i0.Injector }, { token: NOTIFICATIONS_LIST_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
+
NotificationsListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: NotificationsListComponent, selector: "app-notifications-list", outputs: { openSettings: "openSettings", openNotifications: "openNotifications" }, providers: [ParamsService, ResponseService], usesInheritance: true, ngImport: i0, template: "<div class=\"notifications-list\">\r\n <div class=\"notifications-list__header\">\r\n <span *ngIf=\"options.title\">\r\n <strong class=\"notifications-list__title\">{{ options.title | translate }}</strong>\r\n </span>\r\n <div class=\"notifications-list__actions\">\r\n <ng-container *ngIf=\"options?.filters?.active\">\r\n <app-notification-source-select\r\n *ngIf=\"options?.filters?.type\"\r\n\r\n (typeChanged)=\"typeChanged($event)\"\r\n ></app-notification-source-select>\r\n <app-notifications-date-select\r\n *ngIf=\"options?.filters?.date\"\r\n\r\n (dateChanged)=\"dateChanged($event)\"\r\n ></app-notifications-date-select>\r\n <app-notification-status-toggle\r\n *ngIf=\"options?.filters?.state\"\r\n (statusChanged)=\"statusChanged($event)\"\r\n ></app-notification-status-toggle>\r\n </ng-container>\r\n\r\n <app-notifications-list-actions\r\n [options]=\"options.actions\"\r\n [direction]=\"direction$ | async\"\r\n (markAllAsRead)=\"markAllAsRead($event)\"\r\n (openNotifications)=\"openNotifications.emit($event)\"\r\n (openSettings)=\"openSettings.emit($event)\"\r\n ></app-notifications-list-actions>\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"response$ | async as response; else loading\"\r\n class=\"notifications-list__body\"\r\n infiniteScroll\r\n [scrollWindow]=\"false\"\r\n [infiniteScrollDistance]=\"options.scroll?.distance || 2\"\r\n [infiniteScrollThrottle]=\"options.scroll?.throttle || 300\"\r\n (scrolled)=\"onScrollDown()\"\r\n >\r\n <ng-container *ngIf=\"response.data?.length; else noData\">\r\n <app-notification-item\r\n *ngFor=\"let item of response.data; trackBy: trackByFn\"\r\n [iconOptions]=\"options?.icons\"\r\n [notification]=\"item\"\r\n [currentLang]=\"currentLang\"\r\n [class.cursor-pointer]=\"item.properties?.['notf_nt:isClickable']\"\r\n (click)=\"onItemClick(item)\"\r\n (markAsUnread)=\"markAsUnread(item)\"\r\n (markAsRead)=\"markAsRead(item)\"\r\n (markAsDeleted)=\"markAsDeleted(item)\"\r\n ></app-notification-item>\r\n </ng-container>\r\n <mat-spinner\r\n *ngIf=\"isLoadingResult\"\r\n class=\"notifications-list__loader mt-2 mx-auto\"\r\n [diameter]=\"48\"\r\n ></mat-spinner>\r\n </div>\r\n</div>\r\n\r\n<ng-template #filters>\r\n <button\r\n (click)=\"$event.stopPropagation()\"\r\n class=\"type-filter-trigger\"\r\n [matMenuTriggerFor]=\"filterTypeMenu\"\r\n #filterTypeMenuTrigger=\"matMenuTrigger\"\r\n >\r\n {{ 'notifications.all' | translate }}\r\n <span class=\"icon icon-chevron-down\"></span>\r\n </button>\r\n <mat-menu class=\"new-menu-design\" #filterTypeMenu=\"matMenu\">\r\n <div (click)=\"$event.stopPropagation()\">\r\n <div class=\"single-menu-action notification-filter-menu-item\">\r\n {{ 'notifications.' + type.name | translate }}\r\n </div>\r\n </div>\r\n </mat-menu>\r\n</ng-template>\r\n\r\n<ng-template #noData>\r\n <div class=\"no-notifications text-center p-3\">\r\n <p>\r\n {{ 'notifications.noNotifications' | translate }}\r\n </p>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #loading>\r\n <div class=\"no-notifications text-center p-3\">\r\n <p>{{ 'notifications.loading_notification' | translate }}</p>\r\n </div>\r\n</ng-template>\r\n", styles: [".notifications-list{padding:var(--nto-list-padding, 0)}.notifications-list__header{padding:var(--nto-list-header-padding, .5rem);display:var(--nto-list-header-display, flex);justify-content:var(--nto-list-header-justify, space-between);align-items:var(--nto-list-header-align-items, center);box-sizing:border-box;background:var(--nto-list-header-background, transparent);color:var(--nto-list-header-color, currentColor)}.notifications-list__title{color:var(--nto-list-title-color, #234990);font-size:var(--nto-list-title-size, 1rem);font-weight:var(--nto-list-title-weight, 600)}.notifications-list__actions{display:var(--nto-container-filters-display, flex);grid-gap:var(--nto-container-filters-gap, .5rem);gap:var(--nto-container-filters-gap, .5rem)}.notifications-list__loader{display:grid;place-items:center}.notifications-list__body{height:var(--nto-list-height, 60vh);overflow-y:auto}.no-notifications{color:var(--no-notifications-color, #b4bac6);font-size:var(--no-notifications-size, 1rem)}\n"], components: [{ type: i1.NotificationSourceSelectComponent, selector: "app-notification-source-select", outputs: ["typeChanged"] }, { type: i2.NotificationsDateSelectComponent, selector: "app-notifications-date-select", outputs: ["dateChanged"] }, { type: i3.NotificationStatusToggleComponent, selector: "app-notification-status-toggle", inputs: ["status"], outputs: ["statusChanged"] }, { type: i4.NotificationsListActionsComponent, selector: "app-notifications-list-actions", inputs: ["options", "direction"], outputs: ["markAllAsRead", "openSettings", "openNotifications"] }, { type: i5.NotificationItemComponent, selector: "app-notification-item", inputs: ["iconOptions", "currentLang", "notification"], outputs: ["markAsUnread", "markAsRead", "markAsDeleted"] }, { type: i6.MatSpinner, selector: "mat-spinner", inputs: ["color"] }, { type: i7.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["matMenuTriggerRestoreFocus", "mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }], pipes: { "translate": i10.TranslatePipe, "async": i8.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
174
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NotificationsListComponent, decorators: [{
|
|
175
51
|
type: Component,
|
|
176
52
|
args: [{
|
|
177
|
-
selector:
|
|
178
|
-
templateUrl:
|
|
179
|
-
styleUrls: [
|
|
180
|
-
|
|
181
|
-
|
|
53
|
+
selector: 'app-notifications-list',
|
|
54
|
+
templateUrl: './notifications-list.component.html',
|
|
55
|
+
styleUrls: ['./notifications-list.component.scss'],
|
|
56
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
57
|
+
providers: [ParamsService, ResponseService],
|
|
182
58
|
}]
|
|
183
|
-
}], ctorParameters: function () { return [{ type:
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
59
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: undefined, decorators: [{
|
|
60
|
+
type: Optional
|
|
61
|
+
}, {
|
|
62
|
+
type: Inject,
|
|
63
|
+
args: [NOTIFICATIONS_LIST_OPTIONS]
|
|
64
|
+
}] }]; }, propDecorators: { openSettings: [{
|
|
65
|
+
type: Output
|
|
66
|
+
}], openNotifications: [{
|
|
189
67
|
type: Output
|
|
190
68
|
}] } });
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-list/notifications-list.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-list/notifications-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnDestroy, Output, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { DatePipe } from \"@angular/common\";\r\nimport { NotificationsService } from \"../../notifications.service\";\r\nimport { TranslationService } from \"../../../../core/services/translation/translation.service\";\r\nimport { MatMenuTrigger } from \"@angular/material/menu\";\r\n\r\n/**\r\n * Notifications Modal Component\r\n */\r\n@Component({\r\n  selector: \"app-notifications-list\",\r\n  templateUrl: \"./notifications-list.component.html\",\r\n  styleUrls: [\"./notifications-list.component.scss\"],\r\n  host: { class: \"notification-list\" },\r\n  encapsulation : ViewEncapsulation.None\r\n})\r\nexport class NotificationsListComponent implements OnDestroy {\r\n@Input() showFilters = false;\r\n@ViewChild('filterTypeMenuTrigger') trigger: MatMenuTrigger;\r\n  @Output()\r\n  listItemClick = new EventEmitter();\r\n  get notifications() {\r\n    return this.notificationsService.notifications;\r\n  }\r\n  _itemHeight = 79;\r\n  get itemHeight(): number {\r\n    return this._itemHeight;\r\n  }\r\n  set itemHeight(value: number) {\r\n    this._itemHeight = value;\r\n  }\r\n  _divider = true;\r\n  get divider(): boolean {\r\n    return this._divider;\r\n  }\r\n  set divider(value: boolean) {\r\n    this._divider = value;\r\n  }\r\n  _all = true;\r\n  get all(): boolean {\r\n    return this._all;\r\n  }\r\n  set all(value: boolean) {\r\n    this._all = value;\r\n  }\r\n  _title = \"notifications.title\";\r\n  get title(): string {\r\n    return this._title;\r\n  }\r\n  set title(value: string) {\r\n    this._title = value;\r\n  }\r\n  isArabic;\r\n  throttle = 300;\r\n  scrollDistance = 7;\r\n  scrollUpDistance = 2;\r\n  loading = false;\r\n  hasMore = true;\r\n\r\n  constructor(\r\n    public notificationsService: NotificationsService,\r\n    private ref: ChangeDetectorRef,\r\n    public datePipe: DatePipe,\r\n    private translationService: TranslationService\r\n  ) {}\r\n  ngOnInit(): void {\r\n    this.changeContentBasedOnUserLang();\r\n    this.notificationsService.pageSize = this.showFilters ? 30 : 15;\r\n  }\r\n  markAllAsRead() {\r\n    this.notificationsService.markAllAsRead();\r\n  }\r\n\r\n  openNotification(notification) {\r\n    if (notification.status === \"UN_READ\" || notification.status === \"NEW\") {\r\n      this.notificationsService.updateStatus(notification, true);\r\n    }\r\n    this.listItemClick.next(notification);\r\n    // do something when notification clicked\r\n  }\r\n  onUpdate(data) {\r\n    if (data.notification) {\r\n      switch (data.action) {\r\n        case \"delete\":\r\n          this.notificationsService.deleteNotification(data.notification);\r\n          break;\r\n        case \"status\":\r\n          this.notificationsService.updateStatus(data.notification);\r\n          break;\r\n      }\r\n    }\r\n  }\r\n  trackBy(index, item) {\r\n    return item.id;\r\n  }\r\n  handleOpen(item) {\r\n    // this.modalController.dismiss();\r\n    this.notificationsService.updateStatus(item, true);\r\n  }\r\n\r\n  compareDate = (item, itemIndex, items) => {\r\n    if (!this.divider) {\r\n      return null;\r\n    }\r\n    const today = new Date();\r\n    const itemDate = new Date(item.sendDate);\r\n    const isToday =\r\n      itemDate.getDate() === today.getDate() &&\r\n      itemDate.getMonth() === today.getMonth() &&\r\n      itemDate.getFullYear() === today.getFullYear();\r\n    const prevItem = items[itemIndex - 1];\r\n    let isPrevToday = 0;\r\n    if (prevItem) {\r\n      const NextItemDate = new Date(prevItem.sendDate);\r\n      isPrevToday =\r\n        NextItemDate.getDate() === today.getDate() &&\r\n        NextItemDate.getMonth() === today.getMonth() &&\r\n        NextItemDate.getFullYear() === today.getFullYear()\r\n          ? 2\r\n          : 1;\r\n    }\r\n    if (!isToday && (isPrevToday === 0 || isPrevToday === 2)) {\r\n      return \"notifications.earlier\";\r\n    }\r\n    if (isToday && (isPrevToday === 0 || isPrevToday === 1)) {\r\n      return \"notifications.new\";\r\n    }\r\n    return null;\r\n  };\r\n\r\n  getItemHeight = () => {\r\n    return this.itemHeight;\r\n  };\r\n\r\n  goToDetails(notification) {}\r\n\r\n  onScrollDown() {\r\n    if (this.hasMore) {\r\n      this.fetchMore();\r\n    }\r\n  }\r\n  fetchMore() {\r\n    this.loading = true;\r\n      this.notificationsService.fetchNotifications().subscribe((data) => {\r\n        this.loading = false;\r\n        if (\r\n          data[\"items\"].length === 0 ||\r\n          data[\"items\"].length < this.notificationsService.pageSize\r\n        ) {\r\n          this.hasMore = false;\r\n        }\r\n        this.ref.markForCheck();\r\n      });\r\n  }\r\n  ngOnDestroy() {\r\n    this.notificationsService.reset();\r\n  }\r\n  close() {\r\n    //  this.modalController.dismiss();\r\n  }\r\n  changeContentBasedOnUserLang() {\r\n    this.translationService.isArabic.subscribe((ar) => {\r\n      this.isArabic = ar;\r\n    });\r\n  }\r\n\r\n\r\n  stop(event) {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  selectFilterType(event , type){\r\n    // event.stopPropagation();\r\n    this.notificationsService.selectedFilterType = type;\r\n    // front end filtering;\r\n    console.log(this.notifications);\r\n    this.trigger.closeMenu();\r\n   this.notificationsService.setNotifications(this.notificationsService.filterNotifications(this.notificationsService.storedNotifications)) ;\r\n  }\r\n\r\n  changeReadFilter(event){\r\n    // event.stopPropagation();\r\n    this.notificationsService.isReaded = event.checked;\r\n    // front end filtering\r\n    console.log(this.notifications);\r\n    this.notificationsService.setNotifications(this.notificationsService.filterNotifications(this.notificationsService.storedNotifications)) ;\r\n  }\r\n  \r\n}\r\n","<div class=\"toolbar\">\r\n  <div class=\"title\">\r\n    <div>{{ \"notifications.notifications\" | translate }}</div>\r\n  </div>\r\n  <div class=\"flex justify-end\">\r\n    <button\r\n      mat-button\r\n      (click)=\"markAllAsRead()\"\r\n      size=\"small\"\r\n      fill=\"none\"\r\n      class=\"markAllAsRead-btn\"\r\n    >\r\n      {{ \"notifications.markAllAsRead\" | translate }}\r\n    </button>\r\n    <ng-container *ngIf=\"showFilters\">\r\n      <div class=\"type-filter\">\r\n        <button (click)=\"stop($event)\" class=\"type-filter-trigger\"\r\n        [matMenuTriggerFor]=\"filterTypeMenu\" #filterTypeMenuTrigger=\"matMenuTrigger\">\r\n        {{'notifications.' + notificationsService.selectedFilterType.name | translate}} \r\n        <span class=\"icon icon-chevron-down\"></span>\r\n      </button>\r\n      <mat-menu class=\"new-menu-design\" #filterTypeMenu=\"matMenu\" >\r\n          <div (click)=\"stop($event)\">\r\n            <div class=\"single-menu-action notification-filter-menu-item\" *ngFor=\"let type of notificationsService.types\" (click)=\"selectFilterType($event ,type)\">\r\n              {{'notifications.' + type.name | translate}}\r\n            </div>\r\n          </div>\r\n          </mat-menu>\r\n        <div class=\"notification-toggle\" (click)=\"stop($event)\">\r\n          <mat-slide-toggle [checked]=\"notificationsService.isReaded\" (change)=\"changeReadFilter($event)\">{{'notifications.Readed' | translate }}</mat-slide-toggle>\r\n        </div>\r\n      </div>\r\n      \r\n    </ng-container>\r\n  </div>\r\n</div>\r\n<!-- [matTooltip]=\"'notifications.markAllAsRead' | translate\"\r\n      [matTooltipPosition]=\"'before'\" -->\r\n<div *ngIf=\"!notifications?.length\" class=\"no-notifications\">\r\n  <p *ngIf=\"!notificationsService.loading\">\r\n    {{ \"notifications.noNotifications\" | translate }}\r\n  </p>\r\n  <p *ngIf=\"notificationsService.loading\">\r\n    {{ \"notifications.loading_notification\" | translate }}\r\n  </p>\r\n</div>\r\n<div\r\n  infiniteScroll\r\n  [scrollWindow]=\"false\"\r\n  [infiniteScrollDistance]=\"scrollDistance\"\r\n  [infiniteScrollThrottle]=\"throttle\"\r\n  (scrolled)=\"onScrollDown()\"\r\n  class=\"notifications-container scroll\"\r\n>\r\n  <mat-list class=\"\">\r\n    <ng-container\r\n      *ngFor=\"\r\n        let notification of notifications;\r\n        let i = index;\r\n        trackBy: trackBy\r\n      \"\r\n    >\r\n      <!-- <mat-divider class=\"marginize\"></mat-divider> -->\r\n      <app-notification-item\r\n        (click)=\"openNotification(notification)\"\r\n        (update)=\"onUpdate($event)\"\r\n        [notification]=\"notification\"\r\n        [isArabic]=\"isArabic\"\r\n      ></app-notification-item>\r\n    </ng-container>\r\n    <div\r\n      *ngIf=\"loading\"\r\n      style=\"display: grid; place-items: center; margin-top: 10px\"\r\n    >\r\n      <mat-spinner [diameter]=\"48\" style=\"margin: 0 auto\"></mat-spinner>\r\n    </div>\r\n  </mat-list>\r\n</div>\r\n"]}
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-list/notifications-list.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-list/notifications-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,MAAM,EAGN,QAAQ,EACR,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,CAAC,MAAM,QAAQ,CAAC;AACvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,EAEL,0BAA0B,GAE3B,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAC5E,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;;;;;;;;;;;;AASjD,MAAM,OAAO,0BAA2B,SAAQ,qBAAqB;IAInE,YACY,MAAgB,EAG1B,QAAmC;QAEnC,KAAK,CAAC,MAAM,CAAC,CAAC;QALJ,WAAM,GAAN,MAAM,CAAU;QAJlB,iBAAY,GAAG,IAAI,YAAY,EAAS,CAAC;QACzC,sBAAiB,GAAG,IAAI,YAAY,EAAS,CAAC;QAStD,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,KAAK,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACvE,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC;YACnC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,EAAE;YACrC,MAAM,EAAE,YAAY;YACpB,SAAS,EAAE,MAAM;SAClB,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,IAAI,CAAC,YAAY,iBACf,gBAAgB,EAAE,CAAC,IAChB,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,6BAA6B,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAC1D,CAAC;IACL,CAAC;IAED,aAAa,CAAC,EAAE,OAAO,EAAE;QACvB,IAAI,CAAC,YAAY,iBACf,gBAAgB,EAAE,CAAC,IAChB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,8BAA8B,EAAE,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAChF,CAAC;IACL,CAAC;IAED,WAAW,CAAC,IAA2B;QACrC,IAAI,CAAC,YAAY,iBACf,gBAAgB,EAAE,CAAC,IAChB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,sBAAsB,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EACnD,CAAC;IACL,CAAC;;wHA5CU,0BAA0B,0CAO3B,0BAA0B;4GAPzB,0BAA0B,oIAF1B,CAAC,aAAa,EAAE,eAAe,CAAC,iDC5B7C,o6GA8FA;4FDhEa,0BAA0B;kBAPtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,WAAW,EAAE,qCAAqC;oBAClD,SAAS,EAAE,CAAC,qCAAqC,CAAC;oBAClD,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE,CAAC,aAAa,EAAE,eAAe,CAAC;iBAC5C;;0BAOI,QAAQ;;0BACR,MAAM;2BAAC,0BAA0B;4CAN1B,YAAY;sBAArB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter,\r\n  Inject,\r\n  Injector,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n} from '@angular/core';\r\nimport _ from 'lodash';\r\nimport { NOTIFICATION_STATUS } from '../../constants';\r\nimport {\r\n  FilterDateType,\r\n  NOTIFICATIONS_LIST_OPTIONS,\r\n  NotificationsListOptions,\r\n} from '../../models';\r\n\r\nimport { ParamsService } from '../../services/params.service';\r\nimport { ResponseService } from '../../services/response.service';\r\nimport { BaseListNotifications } from '../base-list-notfications.component';\r\nimport { DEFAULT_LIST_OPTIONS } from './options';\r\n\r\n@Component({\r\n  selector: 'app-notifications-list',\r\n  templateUrl: './notifications-list.component.html',\r\n  styleUrls: ['./notifications-list.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [ParamsService, ResponseService],\r\n})\r\nexport class NotificationsListComponent extends BaseListNotifications implements OnInit {\r\n  @Output() openSettings = new EventEmitter<Event>();\r\n  @Output() openNotifications = new EventEmitter<Event>();\r\n\r\n  constructor(\r\n    protected inject: Injector,\r\n    @Optional()\r\n    @Inject(NOTIFICATIONS_LIST_OPTIONS)\r\n    _options?: NotificationsListOptions\r\n  ) {\r\n    super(inject);\r\n    this.options = _.merge(DEFAULT_LIST_OPTIONS, _options ? _options : {});\r\n    this._paramsService.setDefaultParams({\r\n      pageSize: this.options.pageSize || 20,\r\n      sortBy: 'dc:created',\r\n      sortOrder: 'desc',\r\n    });\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._prepareLanguage();\r\n    this._prepareData();\r\n    this._paramsService.applyParams();\r\n  }\r\n\r\n  typeChanged(event: string) {\r\n    this._applyFilter({\r\n      currentPageIndex: 0,\r\n      ...(event ? { notf_notification_sourceTypee: event } : {}),\r\n    });\r\n  }\r\n\r\n  statusChanged({ checked }) {\r\n    this._applyFilter({\r\n      currentPageIndex: 0,\r\n      ...(checked ? { notfnotificationcontent_status: NOTIFICATION_STATUS.read } : {}),\r\n    });\r\n  }\r\n\r\n  dateChanged(date: FilterDateType | null) {\r\n    this._applyFilter({\r\n      currentPageIndex: 0,\r\n      ...(date ? { dublincore_created_agg: [date] } : {}),\r\n    });\r\n  }\r\n}\r\n","<div class=\"notifications-list\">\r\n  <div class=\"notifications-list__header\">\r\n    <span *ngIf=\"options.title\">\r\n      <strong class=\"notifications-list__title\">{{ options.title | translate }}</strong>\r\n    </span>\r\n    <div class=\"notifications-list__actions\">\r\n      <ng-container *ngIf=\"options?.filters?.active\">\r\n        <app-notification-source-select\r\n          *ngIf=\"options?.filters?.type\"\r\n\r\n          (typeChanged)=\"typeChanged($event)\"\r\n        ></app-notification-source-select>\r\n        <app-notifications-date-select\r\n          *ngIf=\"options?.filters?.date\"\r\n\r\n          (dateChanged)=\"dateChanged($event)\"\r\n        ></app-notifications-date-select>\r\n        <app-notification-status-toggle\r\n          *ngIf=\"options?.filters?.state\"\r\n          (statusChanged)=\"statusChanged($event)\"\r\n        ></app-notification-status-toggle>\r\n      </ng-container>\r\n\r\n      <app-notifications-list-actions\r\n        [options]=\"options.actions\"\r\n        [direction]=\"direction$ | async\"\r\n        (markAllAsRead)=\"markAllAsRead($event)\"\r\n        (openNotifications)=\"openNotifications.emit($event)\"\r\n        (openSettings)=\"openSettings.emit($event)\"\r\n      ></app-notifications-list-actions>\r\n    </div>\r\n  </div>\r\n  <div\r\n    *ngIf=\"response$ | async as response; else loading\"\r\n    class=\"notifications-list__body\"\r\n    infiniteScroll\r\n    [scrollWindow]=\"false\"\r\n    [infiniteScrollDistance]=\"options.scroll?.distance || 2\"\r\n    [infiniteScrollThrottle]=\"options.scroll?.throttle || 300\"\r\n    (scrolled)=\"onScrollDown()\"\r\n  >\r\n    <ng-container *ngIf=\"response.data?.length; else noData\">\r\n      <app-notification-item\r\n        *ngFor=\"let item of response.data; trackBy: trackByFn\"\r\n        [iconOptions]=\"options?.icons\"\r\n        [notification]=\"item\"\r\n        [currentLang]=\"currentLang\"\r\n        [class.cursor-pointer]=\"item.properties?.['notf_nt:isClickable']\"\r\n        (click)=\"onItemClick(item)\"\r\n        (markAsUnread)=\"markAsUnread(item)\"\r\n        (markAsRead)=\"markAsRead(item)\"\r\n        (markAsDeleted)=\"markAsDeleted(item)\"\r\n      ></app-notification-item>\r\n    </ng-container>\r\n    <mat-spinner\r\n      *ngIf=\"isLoadingResult\"\r\n      class=\"notifications-list__loader mt-2 mx-auto\"\r\n      [diameter]=\"48\"\r\n    ></mat-spinner>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #filters>\r\n  <button\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"type-filter-trigger\"\r\n    [matMenuTriggerFor]=\"filterTypeMenu\"\r\n    #filterTypeMenuTrigger=\"matMenuTrigger\"\r\n  >\r\n    {{ 'notifications.all' | translate }}\r\n    <span class=\"icon icon-chevron-down\"></span>\r\n  </button>\r\n  <mat-menu class=\"new-menu-design\" #filterTypeMenu=\"matMenu\">\r\n    <div (click)=\"$event.stopPropagation()\">\r\n      <div class=\"single-menu-action notification-filter-menu-item\">\r\n        {{ 'notifications.' + type.name | translate }}\r\n      </div>\r\n    </div>\r\n  </mat-menu>\r\n</ng-template>\r\n\r\n<ng-template #noData>\r\n  <div class=\"no-notifications text-center p-3\">\r\n    <p>\r\n      {{ 'notifications.noNotifications' | translate }}\r\n    </p>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #loading>\r\n  <div class=\"no-notifications text-center p-3\">\r\n    <p>{{ 'notifications.loading_notification' | translate }}</p>\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { PAGINATION_MODE, PANEL_MODE } from '../../constants';
|
|
2
|
+
export const DEFAULT_LIST_OPTIONS = {
|
|
3
|
+
title: 'notifications.notifications',
|
|
4
|
+
pageSize: 20,
|
|
5
|
+
panelMode: PANEL_MODE.sidebar,
|
|
6
|
+
paginationMode: PAGINATION_MODE.scroll,
|
|
7
|
+
filters: {
|
|
8
|
+
active: true,
|
|
9
|
+
state: false,
|
|
10
|
+
date: false,
|
|
11
|
+
type: true,
|
|
12
|
+
},
|
|
13
|
+
actions: {
|
|
14
|
+
active: true,
|
|
15
|
+
openNotification: true,
|
|
16
|
+
openSetting: true,
|
|
17
|
+
updateState: true,
|
|
18
|
+
},
|
|
19
|
+
scroll: {
|
|
20
|
+
distance: 2,
|
|
21
|
+
throttle: 300,
|
|
22
|
+
},
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvbm90aWZpY2F0aW9ucy9jb21wb25lbnRzL25vdGlmaWNhdGlvbnMtbGlzdC9vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQUUsVUFBVSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHOUQsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQTZCO0lBQzVELEtBQUssRUFBRSw2QkFBNkI7SUFDcEMsUUFBUSxFQUFFLEVBQUU7SUFDWixTQUFTLEVBQUUsVUFBVSxDQUFDLE9BQU87SUFDN0IsY0FBYyxFQUFHLGVBQWUsQ0FBQyxNQUFNO0lBQ3ZDLE9BQU8sRUFBRTtRQUNQLE1BQU0sRUFBRSxJQUFJO1FBQ1osS0FBSyxFQUFFLEtBQUs7UUFDWixJQUFJLEVBQUUsS0FBSztRQUNYLElBQUksRUFBRSxJQUFJO0tBQ1g7SUFDRCxPQUFPLEVBQUU7UUFDUCxNQUFNLEVBQUUsSUFBSTtRQUNaLGdCQUFnQixFQUFFLElBQUk7UUFDdEIsV0FBVyxFQUFFLElBQUk7UUFDakIsV0FBVyxFQUFFLElBQUk7S0FDbEI7SUFDRCxNQUFNLEVBQUU7UUFDTixRQUFRLEVBQUUsQ0FBQztRQUNYLFFBQVEsRUFBRSxHQUFHO0tBQ2Q7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUEFHSU5BVElPTl9NT0RFLCBQQU5FTF9NT0RFIH0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJztcclxuaW1wb3J0IHsgTm90aWZpY2F0aW9uc0xpc3RPcHRpb25zIH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcclxuXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX0xJU1RfT1BUSU9OUzogTm90aWZpY2F0aW9uc0xpc3RPcHRpb25zID0ge1xyXG4gIHRpdGxlOiAnbm90aWZpY2F0aW9ucy5ub3RpZmljYXRpb25zJyxcclxuICBwYWdlU2l6ZTogMjAsXHJcbiAgcGFuZWxNb2RlOiBQQU5FTF9NT0RFLnNpZGViYXIsXHJcbiAgcGFnaW5hdGlvbk1vZGUgOiBQQUdJTkFUSU9OX01PREUuc2Nyb2xsLFxyXG4gIGZpbHRlcnM6IHtcclxuICAgIGFjdGl2ZTogdHJ1ZSxcclxuICAgIHN0YXRlOiBmYWxzZSxcclxuICAgIGRhdGU6IGZhbHNlLFxyXG4gICAgdHlwZTogdHJ1ZSxcclxuICB9LFxyXG4gIGFjdGlvbnM6IHtcclxuICAgIGFjdGl2ZTogdHJ1ZSxcclxuICAgIG9wZW5Ob3RpZmljYXRpb246IHRydWUsXHJcbiAgICBvcGVuU2V0dGluZzogdHJ1ZSxcclxuICAgIHVwZGF0ZVN0YXRlOiB0cnVlLFxyXG4gIH0sXHJcbiAgc2Nyb2xsOiB7XHJcbiAgICBkaXN0YW5jZTogMixcclxuICAgIHRocm90dGxlOiAzMDAsXHJcbiAgfSxcclxufTtcclxuIl19
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/material/button";
|
|
4
|
+
import * as i2 from "@angular/material/icon";
|
|
5
|
+
import * as i3 from "@angular/material/menu";
|
|
6
|
+
import * as i4 from "@angular/common";
|
|
7
|
+
import * as i5 from "@angular/cdk/bidi";
|
|
8
|
+
import * as i6 from "@ngx-translate/core";
|
|
9
|
+
export class NotificationsListActionsComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.direction = 'rtl';
|
|
12
|
+
this.markAllAsRead = new EventEmitter();
|
|
13
|
+
this.openSettings = new EventEmitter();
|
|
14
|
+
this.openNotifications = new EventEmitter();
|
|
15
|
+
}
|
|
16
|
+
closeMenu(event, menu) {
|
|
17
|
+
event.stopPropagation();
|
|
18
|
+
menu.closed.emit();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
NotificationsListActionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NotificationsListActionsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
+
NotificationsListActionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: NotificationsListActionsComponent, selector: "app-notifications-list-actions", inputs: { options: "options", direction: "direction" }, outputs: { markAllAsRead: "markAllAsRead", openSettings: "openSettings", openNotifications: "openNotifications" }, ngImport: i0, template: "<span [dir]=\"direction\" *ngIf=\"options?.active\">\r\n <button\r\n [matMenuTriggerFor]=\"actions\"\r\n mat-icon-button\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n <mat-icon>more_horiz</mat-icon>\r\n </button>\r\n <mat-menu #actions=\"matMenu\" class=\"notifications-actions-menu\">\r\n <span (click)=\"closeMenu($event, actions)\">\r\n <button\r\n *ngIf=\"options.updateState\"\r\n mat-menu-item\r\n class=\"notifications-actions-menu__action\"\r\n (click)=\"markAllAsRead.emit($event)\"\r\n >\r\n <mat-icon>done_all</mat-icon>\r\n <span>{{ 'notifications.markAllAsRead' | translate }}</span>\r\n </button>\r\n <button\r\n *ngIf=\"options.openSetting\"\r\n mat-menu-item\r\n class=\"notifications-actions-menu__action\"\r\n (click)=\"openSettings.emit($event)\"\r\n >\r\n <mat-icon>tune</mat-icon>\r\n <span>{{ 'notifications.notificationSettings' | translate }}</span>\r\n </button>\r\n <button\r\n *ngIf=\"options.openNotification\"\r\n mat-menu-item\r\n class=\"notifications-actions-menu__action\"\r\n (click)=\"openNotifications.emit($event)\"\r\n >\r\n <mat-icon>open_in_browser</mat-icon>\r\n <span>{{ 'notifications.openNotifications' | translate }}</span>\r\n </button>\r\n </span>\r\n </mat-menu>\r\n</span>\r\n", styles: [".notifications-actions-menu{box-shadow:var(--n-actions-menu-shadow, 0px 1px 4px -1px rgba(28, 52, 84, .26))}.notifications-actions-menu .mat-menu-content:not(:empty){padding:var(--n-actions-menu-padding, .5rem)}.notifications-actions-menu__action{background:var(--n-menu-action-background, transparent)!important;border-radius:var(--n-menu-action-radius, 4px);font-size:var(--n-menu-action-size, 14px);color:var(--n-menu-action-color, #28282d);height:var(--n-menu-action-height, 40px);line-height:var(--n-menu-action-line-height, 40px)}.notifications-actions-menu__action:hover{--n-menu-action-background: var(--n-menu-action-hover-background, #e6f7ff);--n-menu-action-color: var(--n-menu-action-hover-color, #005fdb)}.notifications-actions-menu__action .mat-icon{color:currentColor}\n"], components: [{ type: i1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["matMenuTriggerRestoreFocus", "mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }], pipes: { "translate": i6.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NotificationsListActionsComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{
|
|
26
|
+
selector: 'app-notifications-list-actions',
|
|
27
|
+
templateUrl: './notifications-list-actions.component.html',
|
|
28
|
+
styleUrls: ['./notifications-list-actions.component.scss'],
|
|
29
|
+
encapsulation: ViewEncapsulation.None,
|
|
30
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
31
|
+
}]
|
|
32
|
+
}], propDecorators: { options: [{
|
|
33
|
+
type: Input
|
|
34
|
+
}], direction: [{
|
|
35
|
+
type: Input
|
|
36
|
+
}], markAllAsRead: [{
|
|
37
|
+
type: Output
|
|
38
|
+
}], openSettings: [{
|
|
39
|
+
type: Output
|
|
40
|
+
}], openNotifications: [{
|
|
41
|
+
type: Output
|
|
42
|
+
}] } });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9ucy1saXN0LWFjdGlvbnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9ub3RpZmljYXRpb25zL2NvbXBvbmVudHMvbm90aWZpY2F0aW9ucy1saXN0LWFjdGlvbnMvbm90aWZpY2F0aW9ucy1saXN0LWFjdGlvbnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9ub3RpZmljYXRpb25zL2NvbXBvbmVudHMvbm90aWZpY2F0aW9ucy1saXN0LWFjdGlvbnMvbm90aWZpY2F0aW9ucy1saXN0LWFjdGlvbnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEVBQ04saUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDOzs7Ozs7OztBQVd2QixNQUFNLE9BQU8saUNBQWlDO0lBUDlDO1FBU1csY0FBUyxHQUFjLEtBQUssQ0FBQztRQUM1QixrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7UUFDMUMsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBUyxDQUFDO1FBQ3pDLHNCQUFpQixHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7S0FNekQ7SUFKQyxTQUFTLENBQUMsS0FBWSxFQUFFLElBQWE7UUFDbkMsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDckIsQ0FBQzs7K0hBVlUsaUNBQWlDO21IQUFqQyxpQ0FBaUMsaVBDbkI5QyxrNUNBd0NBOzRGRHJCYSxpQ0FBaUM7a0JBUDdDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGdDQUFnQztvQkFDMUMsV0FBVyxFQUFFLDZDQUE2QztvQkFDMUQsU0FBUyxFQUFFLENBQUMsNkNBQTZDLENBQUM7b0JBQzFELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQ7OEJBRVUsT0FBTztzQkFBZixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0ksYUFBYTtzQkFBdEIsTUFBTTtnQkFDRyxZQUFZO3NCQUFyQixNQUFNO2dCQUNHLGlCQUFpQjtzQkFBMUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9iaWRpJztcclxuaW1wb3J0IHtcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBDb21wb25lbnQsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIElucHV0LFxyXG4gIE91dHB1dCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0TWVudSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL21lbnUnO1xyXG5pbXBvcnQgeyBOb3RpZmljYXRpb25zTGlzdE9wdGlvbnMgfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtbm90aWZpY2F0aW9ucy1saXN0LWFjdGlvbnMnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9ub3RpZmljYXRpb25zLWxpc3QtYWN0aW9ucy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbm90aWZpY2F0aW9ucy1saXN0LWFjdGlvbnMuY29tcG9uZW50LnNjc3MnXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgTm90aWZpY2F0aW9uc0xpc3RBY3Rpb25zQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBvcHRpb25zOiBOb3RpZmljYXRpb25zTGlzdE9wdGlvbnNbJ2FjdGlvbnMnXTtcclxuICBASW5wdXQoKSBkaXJlY3Rpb246IERpcmVjdGlvbiA9ICdydGwnO1xyXG4gIEBPdXRwdXQoKSBtYXJrQWxsQXNSZWFkID0gbmV3IEV2ZW50RW1pdHRlcjxFdmVudD4oKTtcclxuICBAT3V0cHV0KCkgb3BlblNldHRpbmdzID0gbmV3IEV2ZW50RW1pdHRlcjxFdmVudD4oKTtcclxuICBAT3V0cHV0KCkgb3Blbk5vdGlmaWNhdGlvbnMgPSBuZXcgRXZlbnRFbWl0dGVyPEV2ZW50PigpO1xyXG5cclxuICBjbG9zZU1lbnUoZXZlbnQ6IEV2ZW50LCBtZW51OiBNYXRNZW51KSB7XHJcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcclxuICAgIG1lbnUuY2xvc2VkLmVtaXQoKTtcclxuICB9XHJcbn1cclxuIiwiPHNwYW4gW2Rpcl09XCJkaXJlY3Rpb25cIiAqbmdJZj1cIm9wdGlvbnM/LmFjdGl2ZVwiPlxyXG4gIDxidXR0b25cclxuICAgIFttYXRNZW51VHJpZ2dlckZvcl09XCJhY3Rpb25zXCJcclxuICAgIG1hdC1pY29uLWJ1dHRvblxyXG4gICAgKGNsaWNrKT1cIiRldmVudC5zdG9wUHJvcGFnYXRpb24oKVwiXHJcbiAgPlxyXG4gICAgPG1hdC1pY29uPm1vcmVfaG9yaXo8L21hdC1pY29uPlxyXG4gIDwvYnV0dG9uPlxyXG4gIDxtYXQtbWVudSAjYWN0aW9ucz1cIm1hdE1lbnVcIiBjbGFzcz1cIm5vdGlmaWNhdGlvbnMtYWN0aW9ucy1tZW51XCI+XHJcbiAgICA8c3BhbiAoY2xpY2spPVwiY2xvc2VNZW51KCRldmVudCwgYWN0aW9ucylcIj5cclxuICAgICAgPGJ1dHRvblxyXG4gICAgICAgICpuZ0lmPVwib3B0aW9ucy51cGRhdGVTdGF0ZVwiXHJcbiAgICAgICAgbWF0LW1lbnUtaXRlbVxyXG4gICAgICAgIGNsYXNzPVwibm90aWZpY2F0aW9ucy1hY3Rpb25zLW1lbnVfX2FjdGlvblwiXHJcbiAgICAgICAgKGNsaWNrKT1cIm1hcmtBbGxBc1JlYWQuZW1pdCgkZXZlbnQpXCJcclxuICAgICAgPlxyXG4gICAgICAgIDxtYXQtaWNvbj5kb25lX2FsbDwvbWF0LWljb24+XHJcbiAgICAgICAgPHNwYW4+e3sgJ25vdGlmaWNhdGlvbnMubWFya0FsbEFzUmVhZCcgfCB0cmFuc2xhdGUgfX08L3NwYW4+XHJcbiAgICAgIDwvYnV0dG9uPlxyXG4gICAgICA8YnV0dG9uXHJcbiAgICAgICAgKm5nSWY9XCJvcHRpb25zLm9wZW5TZXR0aW5nXCJcclxuICAgICAgICBtYXQtbWVudS1pdGVtXHJcbiAgICAgICAgY2xhc3M9XCJub3RpZmljYXRpb25zLWFjdGlvbnMtbWVudV9fYWN0aW9uXCJcclxuICAgICAgICAoY2xpY2spPVwib3BlblNldHRpbmdzLmVtaXQoJGV2ZW50KVwiXHJcbiAgICAgID5cclxuICAgICAgICA8bWF0LWljb24+dHVuZTwvbWF0LWljb24+XHJcbiAgICAgICAgPHNwYW4+e3sgJ25vdGlmaWNhdGlvbnMubm90aWZpY2F0aW9uU2V0dGluZ3MnIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxyXG4gICAgICA8L2J1dHRvbj5cclxuICAgICAgPGJ1dHRvblxyXG4gICAgICAgICpuZ0lmPVwib3B0aW9ucy5vcGVuTm90aWZpY2F0aW9uXCJcclxuICAgICAgICBtYXQtbWVudS1pdGVtXHJcbiAgICAgICAgY2xhc3M9XCJub3RpZmljYXRpb25zLWFjdGlvbnMtbWVudV9fYWN0aW9uXCJcclxuICAgICAgICAoY2xpY2spPVwib3Blbk5vdGlmaWNhdGlvbnMuZW1pdCgkZXZlbnQpXCJcclxuICAgICAgPlxyXG4gICAgICAgIDxtYXQtaWNvbj5vcGVuX2luX2Jyb3dzZXI8L21hdC1pY29uPlxyXG4gICAgICAgIDxzcGFuPnt7ICdub3RpZmljYXRpb25zLm9wZW5Ob3RpZmljYXRpb25zJyB8IHRyYW5zbGF0ZSB9fTwvc3Bhbj5cclxuICAgICAgPC9idXR0b24+XHJcbiAgICA8L3NwYW4+XHJcbiAgPC9tYXQtbWVudT5cclxuPC9zcGFuPlxyXG4iXX0=
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { SUBSCRIPTION_STATE } from '../../constants';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class CheckIfSubscribedPipe {
|
|
5
|
+
transform(definition, subscriptions) {
|
|
6
|
+
if (!definition || !Array.isArray(subscriptions)) {
|
|
7
|
+
return false;
|
|
8
|
+
}
|
|
9
|
+
const _subscription = subscriptions.find((sub) => {
|
|
10
|
+
return (sub.channel == definition.channel &&
|
|
11
|
+
sub.applicationKey == definition.applicationKey &&
|
|
12
|
+
sub.notificationKey == definition.notificationKey);
|
|
13
|
+
});
|
|
14
|
+
if (_subscription) {
|
|
15
|
+
return _subscription.state === SUBSCRIPTION_STATE.subscribed;
|
|
16
|
+
}
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
CheckIfSubscribedPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CheckIfSubscribedPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
21
|
+
CheckIfSubscribedPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CheckIfSubscribedPipe, name: "checkIfSubscribed" });
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CheckIfSubscribedPipe, decorators: [{
|
|
23
|
+
type: Pipe,
|
|
24
|
+
args: [{
|
|
25
|
+
name: 'checkIfSubscribed',
|
|
26
|
+
}]
|
|
27
|
+
}] });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2staWYtc3Vic2NyaWJlZC5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9ub3RpZmljYXRpb25zL2NvbXBvbmVudHMvbm90aWZpY2F0aW9ucy1zZXR0aW5ncy9jaGVjay1pZi1zdWJzY3JpYmVkLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDcEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBU3JELE1BQU0sT0FBTyxxQkFBcUI7SUFDaEMsU0FBUyxDQUNQLFVBQTJDLEVBQzNDLGFBQWtEO1FBRWxELElBQUksQ0FBQyxVQUFVLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxFQUFFO1lBQ2hELE9BQU8sS0FBSyxDQUFDO1NBQ2Q7UUFFRCxNQUFNLGFBQWEsR0FBRyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDL0MsT0FBTyxDQUNMLEdBQUcsQ0FBQyxPQUFPLElBQUksVUFBVSxDQUFDLE9BQU87Z0JBQ2pDLEdBQUcsQ0FBQyxjQUFjLElBQUksVUFBVSxDQUFDLGNBQWM7Z0JBQy9DLEdBQUcsQ0FBQyxlQUFlLElBQUksVUFBVSxDQUFDLGVBQWUsQ0FDbEQsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxhQUFhLEVBQUU7WUFDakIsT0FBTyxhQUFhLENBQUMsS0FBSyxLQUFLLGtCQUFrQixDQUFDLFVBQVUsQ0FBQztTQUM5RDtRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQzs7bUhBdEJVLHFCQUFxQjtpSEFBckIscUJBQXFCOzRGQUFyQixxQkFBcUI7a0JBSGpDLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLG1CQUFtQjtpQkFDMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNVQlNDUklQVElPTl9TVEFURSB9IGZyb20gJy4uLy4uL2NvbnN0YW50cyc7XHJcbmltcG9ydCB7XHJcbiAgTm90aWZpY2F0aW9uRGVmaW5pdGlvblByZXNlbnRlcixcclxuICBOb3RpZmljYXRpb25TdWJzY3JpcHRpb25QcmVzZW50ZXIsXHJcbn0gZnJvbSAnLi4vLi4vbW9kZWxzJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnY2hlY2tJZlN1YnNjcmliZWQnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hlY2tJZlN1YnNjcmliZWRQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcbiAgdHJhbnNmb3JtKFxyXG4gICAgZGVmaW5pdGlvbjogTm90aWZpY2F0aW9uRGVmaW5pdGlvblByZXNlbnRlcixcclxuICAgIHN1YnNjcmlwdGlvbnM6IE5vdGlmaWNhdGlvblN1YnNjcmlwdGlvblByZXNlbnRlcltdXHJcbiAgKTogYm9vbGVhbiB7XHJcbiAgICBpZiAoIWRlZmluaXRpb24gfHwgIUFycmF5LmlzQXJyYXkoc3Vic2NyaXB0aW9ucykpIHtcclxuICAgICAgcmV0dXJuIGZhbHNlO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IF9zdWJzY3JpcHRpb24gPSBzdWJzY3JpcHRpb25zLmZpbmQoKHN1YikgPT4ge1xyXG4gICAgICByZXR1cm4gKFxyXG4gICAgICAgIHN1Yi5jaGFubmVsID09IGRlZmluaXRpb24uY2hhbm5lbCAmJlxyXG4gICAgICAgIHN1Yi5hcHBsaWNhdGlvbktleSA9PSBkZWZpbml0aW9uLmFwcGxpY2F0aW9uS2V5ICYmXHJcbiAgICAgICAgc3ViLm5vdGlmaWNhdGlvbktleSA9PSBkZWZpbml0aW9uLm5vdGlmaWNhdGlvbktleVxyXG4gICAgICApO1xyXG4gICAgfSk7XHJcblxyXG4gICAgaWYgKF9zdWJzY3JpcHRpb24pIHtcclxuICAgICAgcmV0dXJuIF9zdWJzY3JpcHRpb24uc3RhdGUgPT09IFNVQlNDUklQVElPTl9TVEFURS5zdWJzY3JpYmVkO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBmYWxzZTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export const mapDefinitionToPresenter = (definition) => {
|
|
2
|
+
const _properties = definition.properties;
|
|
3
|
+
return {
|
|
4
|
+
uid: definition.uid,
|
|
5
|
+
sourceType: _properties['notf_nt:sourceTypee'],
|
|
6
|
+
isActive: _properties['notif_def:isActive'],
|
|
7
|
+
autoSubscription: _properties['notif_def:autoSubscription'],
|
|
8
|
+
sendByDefault: _properties['notif_def:sendByDefault'],
|
|
9
|
+
applicationKey: _properties['notif_def:applicationKey'],
|
|
10
|
+
channel: _properties['notif_def:channel'],
|
|
11
|
+
title: definition.title,
|
|
12
|
+
arTitle: _properties['notif_def:arTitle'],
|
|
13
|
+
enTitle: _properties['notif_def:enTitle'],
|
|
14
|
+
notificationKey: _properties['notf_nt:key'],
|
|
15
|
+
arDescription: _properties['notif_def:arDescription'],
|
|
16
|
+
enDescription: _properties['notif_def:enDescription'],
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
export const mapSubscriptionToPresenter = (subscription) => {
|
|
20
|
+
const _properties = subscription.properties;
|
|
21
|
+
return {
|
|
22
|
+
uid: subscription.uid,
|
|
23
|
+
applicationKey: _properties['notfsub:applicationKey'],
|
|
24
|
+
channel: _properties['notfsub:channel'],
|
|
25
|
+
title: subscription.title,
|
|
26
|
+
notificationKey: _properties['notfsub:notificationKey'],
|
|
27
|
+
state: subscription.state,
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9ucy1zZXR0aW5ncy5hZGFwdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9ub3RpZmljYXRpb25zL2NvbXBvbmVudHMvbm90aWZpY2F0aW9ucy1zZXR0aW5ncy9ub3RpZmljYXRpb25zLXNldHRpbmdzLmFkYXB0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBRUUsQ0FBQyxVQUFVLEVBQUUsRUFBRTtJQUNwRCxNQUFNLFdBQVcsR0FBRyxVQUFVLENBQUMsVUFBVSxDQUFDO0lBQzFDLE9BQU87UUFDTCxHQUFHLEVBQUUsVUFBVSxDQUFDLEdBQUc7UUFDbkIsVUFBVSxFQUFFLFdBQVcsQ0FBQyxxQkFBcUIsQ0FBQztRQUM5QyxRQUFRLEVBQUUsV0FBVyxDQUFDLG9CQUFvQixDQUFDO1FBQzNDLGdCQUFnQixFQUFFLFdBQVcsQ0FBQyw0QkFBNEIsQ0FBQztRQUMzRCxhQUFhLEVBQUUsV0FBVyxDQUFDLHlCQUF5QixDQUFDO1FBQ3JELGNBQWMsRUFBRSxXQUFXLENBQUMsMEJBQTBCLENBQUM7UUFDdkQsT0FBTyxFQUFFLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQztRQUN6QyxLQUFLLEVBQUUsVUFBVSxDQUFDLEtBQUs7UUFDdkIsT0FBTyxFQUFFLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQztRQUN6QyxPQUFPLEVBQUUsV0FBVyxDQUFDLG1CQUFtQixDQUFDO1FBQ3pDLGVBQWUsRUFBRSxXQUFXLENBQUMsYUFBYSxDQUFDO1FBQzNDLGFBQWEsRUFBRSxXQUFXLENBQUMseUJBQXlCLENBQUM7UUFDckQsYUFBYSxFQUFFLFdBQVcsQ0FBQyx5QkFBeUIsQ0FBQztLQUN0RCxDQUFDO0FBQ0osQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sMEJBQTBCLEdBRUUsQ0FBQyxZQUFZLEVBQUUsRUFBRTtJQUN4RCxNQUFNLFdBQVcsR0FBRyxZQUFZLENBQUMsVUFBVSxDQUFDO0lBQzVDLE9BQU87UUFDTCxHQUFHLEVBQUUsWUFBWSxDQUFDLEdBQUc7UUFDckIsY0FBYyxFQUFFLFdBQVcsQ0FBQyx3QkFBd0IsQ0FBQztRQUNyRCxPQUFPLEVBQUUsV0FBVyxDQUFDLGlCQUFpQixDQUFDO1FBQ3ZDLEtBQUssRUFBRSxZQUFZLENBQUMsS0FBSztRQUN6QixlQUFlLEVBQUUsV0FBVyxDQUFDLHlCQUF5QixDQUFDO1FBQ3ZELEtBQUssRUFBRSxZQUFZLENBQUMsS0FBbUQ7S0FDeEUsQ0FBQztBQUNKLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgTm90aWZpY2F0aW9uRGVmaW5pdGlvbk1vZGVsLFxyXG4gIE5vdGlmaWNhdGlvbkRlZmluaXRpb25QcmVzZW50ZXIsXHJcbiAgTm90aWZpY2F0aW9uU3Vic2NyaXB0aW9uTW9kZWwsXHJcbiAgTm90aWZpY2F0aW9uU3Vic2NyaXB0aW9uUHJlc2VudGVyLFxyXG59IGZyb20gJy4uLy4uL21vZGVscyc7XHJcblxyXG5leHBvcnQgY29uc3QgbWFwRGVmaW5pdGlvblRvUHJlc2VudGVyOiAoXHJcbiAgZGVmaW5pdGlvbjogTm90aWZpY2F0aW9uRGVmaW5pdGlvbk1vZGVsXHJcbikgPT4gTm90aWZpY2F0aW9uRGVmaW5pdGlvblByZXNlbnRlciA9IChkZWZpbml0aW9uKSA9PiB7XHJcbiAgY29uc3QgX3Byb3BlcnRpZXMgPSBkZWZpbml0aW9uLnByb3BlcnRpZXM7XHJcbiAgcmV0dXJuIHtcclxuICAgIHVpZDogZGVmaW5pdGlvbi51aWQsXHJcbiAgICBzb3VyY2VUeXBlOiBfcHJvcGVydGllc1snbm90Zl9udDpzb3VyY2VUeXBlZSddLFxyXG4gICAgaXNBY3RpdmU6IF9wcm9wZXJ0aWVzWydub3RpZl9kZWY6aXNBY3RpdmUnXSxcclxuICAgIGF1dG9TdWJzY3JpcHRpb246IF9wcm9wZXJ0aWVzWydub3RpZl9kZWY6YXV0b1N1YnNjcmlwdGlvbiddLFxyXG4gICAgc2VuZEJ5RGVmYXVsdDogX3Byb3BlcnRpZXNbJ25vdGlmX2RlZjpzZW5kQnlEZWZhdWx0J10sXHJcbiAgICBhcHBsaWNhdGlvbktleTogX3Byb3BlcnRpZXNbJ25vdGlmX2RlZjphcHBsaWNhdGlvbktleSddLFxyXG4gICAgY2hhbm5lbDogX3Byb3BlcnRpZXNbJ25vdGlmX2RlZjpjaGFubmVsJ10sXHJcbiAgICB0aXRsZTogZGVmaW5pdGlvbi50aXRsZSxcclxuICAgIGFyVGl0bGU6IF9wcm9wZXJ0aWVzWydub3RpZl9kZWY6YXJUaXRsZSddLFxyXG4gICAgZW5UaXRsZTogX3Byb3BlcnRpZXNbJ25vdGlmX2RlZjplblRpdGxlJ10sXHJcbiAgICBub3RpZmljYXRpb25LZXk6IF9wcm9wZXJ0aWVzWydub3RmX250OmtleSddLFxyXG4gICAgYXJEZXNjcmlwdGlvbjogX3Byb3BlcnRpZXNbJ25vdGlmX2RlZjphckRlc2NyaXB0aW9uJ10sXHJcbiAgICBlbkRlc2NyaXB0aW9uOiBfcHJvcGVydGllc1snbm90aWZfZGVmOmVuRGVzY3JpcHRpb24nXSxcclxuICB9O1xyXG59O1xyXG5cclxuZXhwb3J0IGNvbnN0IG1hcFN1YnNjcmlwdGlvblRvUHJlc2VudGVyOiAoXHJcbiAgc3Vic2NyaXB0aW9uOiBOb3RpZmljYXRpb25TdWJzY3JpcHRpb25Nb2RlbFxyXG4pID0+IE5vdGlmaWNhdGlvblN1YnNjcmlwdGlvblByZXNlbnRlciA9IChzdWJzY3JpcHRpb24pID0+IHtcclxuICBjb25zdCBfcHJvcGVydGllcyA9IHN1YnNjcmlwdGlvbi5wcm9wZXJ0aWVzO1xyXG4gIHJldHVybiB7XHJcbiAgICB1aWQ6IHN1YnNjcmlwdGlvbi51aWQsXHJcbiAgICBhcHBsaWNhdGlvbktleTogX3Byb3BlcnRpZXNbJ25vdGZzdWI6YXBwbGljYXRpb25LZXknXSxcclxuICAgIGNoYW5uZWw6IF9wcm9wZXJ0aWVzWydub3Rmc3ViOmNoYW5uZWwnXSxcclxuICAgIHRpdGxlOiBzdWJzY3JpcHRpb24udGl0bGUsXHJcbiAgICBub3RpZmljYXRpb25LZXk6IF9wcm9wZXJ0aWVzWydub3Rmc3ViOm5vdGlmaWNhdGlvbktleSddLFxyXG4gICAgc3RhdGU6IHN1YnNjcmlwdGlvbi5zdGF0ZSBhcyBOb3RpZmljYXRpb25TdWJzY3JpcHRpb25QcmVzZW50ZXJbJ3N0YXRlJ10sXHJcbiAgfTtcclxufTtcclxuIl19
|