@progress-chef/platform-shared-components 0.0.109 → 0.0.110
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/esm2022/lib/atoms/toast-notification/toast-notification.service.mjs +45 -9
- package/fesm2022/progress-chef-platform-shared-components.mjs +44 -8
- package/fesm2022/progress-chef-platform-shared-components.mjs.map +1 -1
- package/lib/atoms/toast-notification/toast-notification.service.d.ts +9 -3
- package/package.json +1 -1
|
@@ -5,6 +5,9 @@ export class ToastNotificationService {
|
|
|
5
5
|
constructor(notificationService) {
|
|
6
6
|
this.notificationService = notificationService;
|
|
7
7
|
this.httpStatusHandledInHttpInterceptor = new Set([0, 202, 207, 401, 402, 403, 405, 500, 502, 503, 504]);
|
|
8
|
+
this.httpErrorStatusSet = new Set();
|
|
9
|
+
this.allSubscriptions = [];
|
|
10
|
+
this.errorNotifications = [];
|
|
8
11
|
}
|
|
9
12
|
/**
|
|
10
13
|
* @param notification
|
|
@@ -28,15 +31,48 @@ export class ToastNotificationService {
|
|
|
28
31
|
if (this.httpStatusHandledInHttpInterceptor.has(mergedNotification?.action?.payload?.error?.status || mergedNotification?.action?.payload?.response?.code)) {
|
|
29
32
|
return;
|
|
30
33
|
}
|
|
31
|
-
this.
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
34
|
+
if (mergedNotification.type.style === 'error' && this.httpErrorStatusSet.has(mergedNotification.content)) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
if (mergedNotification.type.style === 'error') {
|
|
38
|
+
this.httpErrorStatusSet.add(mergedNotification.content);
|
|
39
|
+
const notification = this.notificationService.show({
|
|
40
|
+
content: mergedNotification.content,
|
|
41
|
+
cssClass: mergedNotification.cssClass,
|
|
42
|
+
animation: mergedNotification.animation,
|
|
43
|
+
position: mergedNotification.position,
|
|
44
|
+
type: mergedNotification.type,
|
|
45
|
+
closable: mergedNotification.closable,
|
|
46
|
+
hideAfter: mergedNotification.hideAfter,
|
|
47
|
+
});
|
|
48
|
+
this.errorNotifications.push(notification);
|
|
49
|
+
if (notification && notification.afterHide) {
|
|
50
|
+
let notificationAfterHideSubscription = notification.afterHide.subscribe(() => {
|
|
51
|
+
this.httpErrorStatusSet.delete(mergedNotification.content);
|
|
52
|
+
notificationAfterHideSubscription.unsubscribe();
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
this.notificationService.show({
|
|
58
|
+
content: mergedNotification.content,
|
|
59
|
+
cssClass: mergedNotification.cssClass,
|
|
60
|
+
animation: mergedNotification.animation,
|
|
61
|
+
position: mergedNotification.position,
|
|
62
|
+
type: mergedNotification.type,
|
|
63
|
+
closable: mergedNotification.closable,
|
|
64
|
+
hideAfter: mergedNotification.hideAfter,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
hideErrorToastNotifications() {
|
|
69
|
+
this.errorNotifications.forEach((notification) => {
|
|
70
|
+
notification.hide();
|
|
39
71
|
});
|
|
72
|
+
this.errorNotifications = [];
|
|
73
|
+
}
|
|
74
|
+
ngOnDestroy() {
|
|
75
|
+
this.allSubscriptions.forEach((subs) => subs.unsubscribe());
|
|
40
76
|
}
|
|
41
77
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ToastNotificationService, deps: [{ token: i1.NotificationService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
42
78
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ToastNotificationService, providedIn: 'root' }); }
|
|
@@ -47,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
47
83
|
providedIn: 'root',
|
|
48
84
|
}]
|
|
49
85
|
}], ctorParameters: function () { return [{ type: i1.NotificationService }]; } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast-notification.service.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/atoms/toast-notification/toast-notification.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy, TemplateRef } from '@angular/core';\nimport { NotificationRef, NotificationService } from '@progress/kendo-angular-notification';\nimport { Subscription } from 'rxjs';\n\nexport interface ToastNotification {\n  content: string | TemplateRef<any> | Function,\n  cssClass?: string | Array<string> | Object,\n  animation?: any,\n  position?: any,\n  type?: any,\n  closable?: boolean,\n  hideAfter?: number\n  action: any\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ToastNotificationService implements OnDestroy {\n\n  httpStatusHandledInHttpInterceptor = new Set([0, 202, 207, 401, 402, 403, 405, 500, 502, 503, 504]);\n  httpErrorStatusSet = new Set();\n  allSubscriptions: Subscription[] = [];\n  errorNotifications: NotificationRef[] = [];\n\n  constructor(private notificationService: NotificationService) { }\n\n  /**\n   * @param notification \n   * default notification config:\n   * - content: '',\n   * - animation: { type: 'slide', duration: 400 },\n   * - position: { horizontal: 'center', vertical: 'top' },\n   * - type: { style: 'success', icon: true },\n   * - hideAfter: 4000,\n   */\n\n  public showToastNotification(notification: ToastNotification) {\n    const defaultNotification: ToastNotification = {\n      content: '',\n      animation: { type: 'slide', duration: 400 },\n      position: { horizontal: 'center', vertical: 'top' },\n      type: { style: 'success', icon: true },\n      hideAfter: 4000,\n      action: {}\n    }\n    const mergedNotification = { ...defaultNotification, ...notification };\n    if (this.httpStatusHandledInHttpInterceptor.has(mergedNotification?.action?.payload?.error?.status || mergedNotification?.action?.payload?.response?.code)) {\n      return;\n    }\n\n    if(mergedNotification.type.style === 'error' && this.httpErrorStatusSet.has(mergedNotification.content)) {\n      return;\n    }\n\n    if(mergedNotification.type.style === 'error') { \n      this.httpErrorStatusSet.add(mergedNotification.content);\n      const notification: NotificationRef = this.notificationService.show({\n        content: mergedNotification.content,\n        cssClass: mergedNotification.cssClass,\n        animation: mergedNotification.animation,\n        position: mergedNotification.position,\n        type: mergedNotification.type,\n        closable: mergedNotification.closable,\n        hideAfter: mergedNotification.hideAfter,\n      });\n      this.errorNotifications.push(notification);\n      if (notification && notification.afterHide) {\n        let notificationAfterHideSubscription = notification.afterHide.subscribe(() => {\n          this.httpErrorStatusSet.delete(mergedNotification.content);\n          notificationAfterHideSubscription.unsubscribe();\n        });\n      }\n    } else {\n      this.notificationService.show({\n        content: mergedNotification.content,\n        cssClass: mergedNotification.cssClass,\n        animation: mergedNotification.animation,\n        position: mergedNotification.position,\n        type: mergedNotification.type,\n        closable: mergedNotification.closable,\n        hideAfter: mergedNotification.hideAfter,\n      });\n    }\n  }\n\n  public hideErrorToastNotifications() {\n    this.errorNotifications.forEach((notification) => {\n      notification.hide();\n    });\n    this.errorNotifications = [];\n  }\n  \n  ngOnDestroy() {\n    this.allSubscriptions.forEach((subs) => subs.unsubscribe())\n  }\n}\n"]}
|
|
@@ -66,6 +66,9 @@ class ToastNotificationService {
|
|
|
66
66
|
constructor(notificationService) {
|
|
67
67
|
this.notificationService = notificationService;
|
|
68
68
|
this.httpStatusHandledInHttpInterceptor = new Set([0, 202, 207, 401, 402, 403, 405, 500, 502, 503, 504]);
|
|
69
|
+
this.httpErrorStatusSet = new Set();
|
|
70
|
+
this.allSubscriptions = [];
|
|
71
|
+
this.errorNotifications = [];
|
|
69
72
|
}
|
|
70
73
|
/**
|
|
71
74
|
* @param notification
|
|
@@ -89,15 +92,48 @@ class ToastNotificationService {
|
|
|
89
92
|
if (this.httpStatusHandledInHttpInterceptor.has(mergedNotification?.action?.payload?.error?.status || mergedNotification?.action?.payload?.response?.code)) {
|
|
90
93
|
return;
|
|
91
94
|
}
|
|
92
|
-
this.
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
95
|
+
if (mergedNotification.type.style === 'error' && this.httpErrorStatusSet.has(mergedNotification.content)) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
if (mergedNotification.type.style === 'error') {
|
|
99
|
+
this.httpErrorStatusSet.add(mergedNotification.content);
|
|
100
|
+
const notification = this.notificationService.show({
|
|
101
|
+
content: mergedNotification.content,
|
|
102
|
+
cssClass: mergedNotification.cssClass,
|
|
103
|
+
animation: mergedNotification.animation,
|
|
104
|
+
position: mergedNotification.position,
|
|
105
|
+
type: mergedNotification.type,
|
|
106
|
+
closable: mergedNotification.closable,
|
|
107
|
+
hideAfter: mergedNotification.hideAfter,
|
|
108
|
+
});
|
|
109
|
+
this.errorNotifications.push(notification);
|
|
110
|
+
if (notification && notification.afterHide) {
|
|
111
|
+
let notificationAfterHideSubscription = notification.afterHide.subscribe(() => {
|
|
112
|
+
this.httpErrorStatusSet.delete(mergedNotification.content);
|
|
113
|
+
notificationAfterHideSubscription.unsubscribe();
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
this.notificationService.show({
|
|
119
|
+
content: mergedNotification.content,
|
|
120
|
+
cssClass: mergedNotification.cssClass,
|
|
121
|
+
animation: mergedNotification.animation,
|
|
122
|
+
position: mergedNotification.position,
|
|
123
|
+
type: mergedNotification.type,
|
|
124
|
+
closable: mergedNotification.closable,
|
|
125
|
+
hideAfter: mergedNotification.hideAfter,
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
hideErrorToastNotifications() {
|
|
130
|
+
this.errorNotifications.forEach((notification) => {
|
|
131
|
+
notification.hide();
|
|
100
132
|
});
|
|
133
|
+
this.errorNotifications = [];
|
|
134
|
+
}
|
|
135
|
+
ngOnDestroy() {
|
|
136
|
+
this.allSubscriptions.forEach((subs) => subs.unsubscribe());
|
|
101
137
|
}
|
|
102
138
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ToastNotificationService, deps: [{ token: i1.NotificationService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
103
139
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ToastNotificationService, providedIn: 'root' }); }
|