@provoly/dashboard 1.4.49 → 1.4.50
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/core/components/snackbar/snack.interface.mjs +1 -1
- package/esm2022/lib/core/components/snackbar/snackbar/snackbar.component.mjs +48 -12
- package/esm2022/lib/core/components/snackbar/snackbar.service.mjs +50 -12
- package/fesm2022/provoly-dashboard.mjs +92 -20
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/components/snackbar/snack.interface.d.ts +2 -1
- package/lib/core/components/snackbar/snackbar/snackbar.component.d.ts +16 -3
- package/lib/core/components/snackbar/snackbar.service.d.ts +9 -3
- package/package.json +37 -37
- package/styles-theme/components-theme/_m-snackbar.theme.scss +5 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2suaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9zbmFja2Jhci9zbmFjay5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUHJ5U25hY2tNZXNzYWdlIHtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBpZD86IHN0cmluZztcbiAgYWN0aW9uPzogc3RyaW5nO1xuICB0eXBlOiAnc3VjY2VzcycgfCAnaW5mbycgfCAnd2FybmluZycgfCAnZXJyb3InIHwgJ25vdGlmJztcbiAgdGltZW91dD86IG51bWJlcjtcbn1cbiJdfQ==
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { animate, animation, style, transition, trigger, useAnimation } from '@angular/animations';
|
|
2
2
|
import { Component, Input } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
5
|
-
import * as i2 from "
|
|
4
|
+
import * as i1 from "../snackbar.service";
|
|
5
|
+
import * as i2 from "@angular/router";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "../../icon/icon.component";
|
|
6
8
|
const showAnimation = animation([style({ transform: '{{transform}}', opacity: 0 }), animate('{{transition}}')]);
|
|
7
9
|
const hideAnimation = animation([animate('{{transition}}'), style({ transform: '{{transform}}', opacity: 0 })]);
|
|
8
10
|
export class PrySnackbarComponent {
|
|
@@ -10,13 +12,25 @@ export class PrySnackbarComponent {
|
|
|
10
12
|
this._data = message;
|
|
11
13
|
this.cdRef.detectChanges();
|
|
12
14
|
}
|
|
13
|
-
|
|
15
|
+
set listIndex(listIndex) {
|
|
16
|
+
if (!!listIndex || listIndex === 0) {
|
|
17
|
+
this._listIndex = listIndex;
|
|
18
|
+
}
|
|
19
|
+
this.getStyle();
|
|
20
|
+
}
|
|
21
|
+
get listIndex() {
|
|
22
|
+
return this._listIndex;
|
|
23
|
+
}
|
|
24
|
+
constructor(cdRef, snackService, router) {
|
|
14
25
|
this.cdRef = cdRef;
|
|
26
|
+
this.snackService = snackService;
|
|
27
|
+
this.router = router;
|
|
15
28
|
this._data = { message: '', action: undefined, type: 'info', timeout: 3000 };
|
|
16
|
-
this.listIndex = 0;
|
|
17
29
|
this.transformOptions = 'translate3d(-50%, 100%, 0px)';
|
|
18
30
|
this.transitionOptions = '150ms cubic-bezier(0, 0, 0.2, 1)';
|
|
19
31
|
this.hiddenFromAction = false;
|
|
32
|
+
this._listIndex = 0;
|
|
33
|
+
this.snackStyle = { top: '' };
|
|
20
34
|
}
|
|
21
35
|
get data() {
|
|
22
36
|
return this._data;
|
|
@@ -24,12 +38,25 @@ export class PrySnackbarComponent {
|
|
|
24
38
|
get typeClass() {
|
|
25
39
|
return { ['-' + this.data.type]: true };
|
|
26
40
|
}
|
|
41
|
+
getStyle() {
|
|
42
|
+
if (this.data.type === 'notif') {
|
|
43
|
+
this.snackStyle = {
|
|
44
|
+
top: (this.listIndex === 0 ? 60 : this.listIndex * 60 + 60) + 'px'
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
this.snackStyle = {
|
|
49
|
+
bottom: this.listIndex * 60 + 'px'
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
}
|
|
27
53
|
get icon() {
|
|
28
54
|
const iconsDefs = {
|
|
29
55
|
info: 'information-point',
|
|
30
56
|
success: 'check',
|
|
31
57
|
warning: 'warning',
|
|
32
|
-
error: 'close'
|
|
58
|
+
error: 'close',
|
|
59
|
+
notif: 'information-point'
|
|
33
60
|
};
|
|
34
61
|
return iconsDefs[this.data.type];
|
|
35
62
|
}
|
|
@@ -39,8 +66,17 @@ export class PrySnackbarComponent {
|
|
|
39
66
|
hide() {
|
|
40
67
|
this.hiddenFromAction = true;
|
|
41
68
|
}
|
|
42
|
-
|
|
43
|
-
|
|
69
|
+
openEvenement(data) {
|
|
70
|
+
this.router.navigate([]).then(() => {
|
|
71
|
+
const url = this.router.serializeUrl(this.router.createUrlTree(['/', 'journal', data.message.padStart(6, '0')]));
|
|
72
|
+
window.open(url, '_blank');
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
closeNotif(data) {
|
|
76
|
+
this.snackService.closeNotif(data);
|
|
77
|
+
}
|
|
78
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PrySnackbarComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.PrySnackbarService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PrySnackbarComponent, selector: "pry-snackbar", inputs: { data: "data", actionClicked: "actionClicked", listIndex: "listIndex" }, ngImport: i0, template: "@if (!hiddenFromAction) {\n @if (data.type === 'notif') {\n <div\n (click)=\"openEvenement(data)\"\n class=\"m-snackbar m-snackbar-notif\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style]=\"snackStyle\"\n >\n <div class=\"m-snackbar__content\">\n <p class=\"a-p\">{{ data.message }}</p>\n <pry-icon (click)=\"closeNotif(data)\" class=\"notif-erase\" iconSvg=\"close\" [width]=\"18\" [height]=\"18\"> </pry-icon>\n </div>\n </div>\n } @else {\n <div\n class=\"m-snackbar -bottom\"\n [ngClass]=\"typeClass\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style]=\"snackStyle\"\n >\n <div class=\"m-snackbar__content\">\n <pry-icon [iconSvg]=\"icon\"></pry-icon>\n <p class=\"a-p\">{{ data.message }}</p>\n @if (!!data.action) {\n <button class=\"m-snackbar__action\" (click)=\"actionClick()\">{{ data.action }}</button>\n }\n </div>\n </div>\n }\n}\n", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }], animations: [
|
|
44
80
|
trigger('panelState', [
|
|
45
81
|
transition('void => visible', [useAnimation(showAnimation)]),
|
|
46
82
|
transition('visible => void', [useAnimation(hideAnimation)])
|
|
@@ -54,12 +90,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
54
90
|
transition('void => visible', [useAnimation(showAnimation)]),
|
|
55
91
|
transition('visible => void', [useAnimation(hideAnimation)])
|
|
56
92
|
])
|
|
57
|
-
], template: "@if (!hiddenFromAction) {\n <div\n class=\"m-snackbar -bottom\"\n
|
|
58
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { data: [{
|
|
59
|
-
type: Input
|
|
60
|
-
}], listIndex: [{
|
|
93
|
+
], template: "@if (!hiddenFromAction) {\n @if (data.type === 'notif') {\n <div\n (click)=\"openEvenement(data)\"\n class=\"m-snackbar m-snackbar-notif\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style]=\"snackStyle\"\n >\n <div class=\"m-snackbar__content\">\n <p class=\"a-p\">{{ data.message }}</p>\n <pry-icon (click)=\"closeNotif(data)\" class=\"notif-erase\" iconSvg=\"close\" [width]=\"18\" [height]=\"18\"> </pry-icon>\n </div>\n </div>\n } @else {\n <div\n class=\"m-snackbar -bottom\"\n [ngClass]=\"typeClass\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style]=\"snackStyle\"\n >\n <div class=\"m-snackbar__content\">\n <pry-icon [iconSvg]=\"icon\"></pry-icon>\n <p class=\"a-p\">{{ data.message }}</p>\n @if (!!data.action) {\n <button class=\"m-snackbar__action\" (click)=\"actionClick()\">{{ data.action }}</button>\n }\n </div>\n </div>\n }\n}\n" }]
|
|
94
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.PrySnackbarService }, { type: i2.Router }], propDecorators: { data: [{
|
|
61
95
|
type: Input
|
|
62
96
|
}], actionClicked: [{
|
|
63
97
|
type: Input
|
|
98
|
+
}], listIndex: [{
|
|
99
|
+
type: Input
|
|
64
100
|
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/core/components/snackbar/snackbar/snackbar.component.ts","../../../../../../../../../projects/provoly/dashboard/lib/core/components/snackbar/snackbar/snackbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, animation, style, transition, trigger, useAnimation } from '@angular/animations';\nimport { ChangeDetectorRef, Component, Input } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { PrySnackMessage } from '../snack.interface';\nimport { PrySnackbarService } from '../snackbar.service';\nimport { Router } from '@angular/router';\n\nconst showAnimation = animation([style({ transform: '{{transform}}', opacity: 0 }), animate('{{transition}}')]);\nconst hideAnimation = animation([animate('{{transition}}'), style({ transform: '{{transform}}', opacity: 0 })]);\n\n@Component({\n  selector: 'pry-snackbar',\n  templateUrl: './snackbar.component.html',\n  animations: [\n    trigger('panelState', [\n      transition('void => visible', [useAnimation(showAnimation)]),\n      transition('visible => void', [useAnimation(hideAnimation)])\n    ])\n  ]\n})\nexport class PrySnackbarComponent {\n  container: any;\n  _data = { message: '', action: undefined, type: 'info', timeout: 3000 } as PrySnackMessage;\n  @Input() set data(message: PrySnackMessage) {\n    this._data = message;\n    this.cdRef.detectChanges();\n  }\n\n  @Input() actionClicked!: Subject<void>;\n  transformOptions = 'translate3d(-50%, 100%, 0px)';\n  transitionOptions = '150ms cubic-bezier(0, 0, 0.2, 1)';\n  hiddenFromAction = false;\n  private _listIndex = 0;\n  snackStyle: { top?: string; bottom?: string } = { top: '' };\n  @Input() set listIndex(listIndex: number) {\n    if (!!listIndex || listIndex === 0) {\n      this._listIndex = listIndex;\n    }\n    this.getStyle();\n  }\n\n  get listIndex() {\n    return this._listIndex;\n  }\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private snackService: PrySnackbarService,\n    private router: Router\n  ) {}\n\n  get data() {\n    return this._data;\n  }\n\n  get typeClass() {\n    return { ['-' + this.data.type]: true };\n  }\n\n  getStyle() {\n    if (this.data.type === 'notif') {\n      this.snackStyle = {\n        top: (this.listIndex === 0 ? 60 : this.listIndex * 60 + 60) + 'px'\n      };\n    } else {\n      this.snackStyle = {\n        bottom: this.listIndex * 60 + 'px'\n      };\n    }\n  }\n\n  get icon(): string {\n    const iconsDefs = {\n      info: 'information-point',\n      success: 'check',\n      warning: 'warning',\n      error: 'close',\n      notif: 'information-point'\n    };\n    return iconsDefs[this.data.type];\n  }\n\n  actionClick() {\n    this.actionClicked.next();\n  }\n\n  hide() {\n    this.hiddenFromAction = true;\n  }\n\n  openEvenement(data: PrySnackMessage) {\n    this.router.navigate([]).then(() => {\n      const url = this.router.serializeUrl(this.router.createUrlTree(['/', 'journal', data.message.padStart(6, '0')]));\n      window.open(url, '_blank');\n    });\n  }\n\n  closeNotif(data: PrySnackMessage) {\n    this.snackService.closeNotif(data);\n  }\n}\n","@if (!hiddenFromAction) {\n  @if (data.type === 'notif') {\n    <div\n      (click)=\"openEvenement(data)\"\n      class=\"m-snackbar m-snackbar-notif\"\n      [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n      [style]=\"snackStyle\"\n    >\n      <div class=\"m-snackbar__content\">\n        <p class=\"a-p\">{{ data.message }}</p>\n        <pry-icon (click)=\"closeNotif(data)\" class=\"notif-erase\" iconSvg=\"close\" [width]=\"18\" [height]=\"18\"> </pry-icon>\n      </div>\n    </div>\n  } @else {\n    <div\n      class=\"m-snackbar -bottom\"\n      [ngClass]=\"typeClass\"\n      [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n      [style]=\"snackStyle\"\n    >\n      <div class=\"m-snackbar__content\">\n        <pry-icon [iconSvg]=\"icon\"></pry-icon>\n        <p class=\"a-p\">{{ data.message }}</p>\n        @if (!!data.action) {\n          <button class=\"m-snackbar__action\" (click)=\"actionClick()\">{{ data.action }}</button>\n        }\n      </div>\n    </div>\n  }\n}\n"]}
|
|
@@ -17,6 +17,7 @@ export class PrySnackbarService {
|
|
|
17
17
|
this.overlay = overlay;
|
|
18
18
|
this.translate = translate;
|
|
19
19
|
this.messageEvents$ = new Subject();
|
|
20
|
+
this.notifRef = [];
|
|
20
21
|
// Allows to access snackbar from javascript, for example to manage Vega errors
|
|
21
22
|
document.addEventListener(PRY_CUSTOMEVENT_TYPE, (e) => {
|
|
22
23
|
const pryMessage = e.detail;
|
|
@@ -34,26 +35,63 @@ export class PrySnackbarService {
|
|
|
34
35
|
dispatchOpenEvent(message) {
|
|
35
36
|
document.dispatchEvent(new CustomEvent(PRY_CUSTOMEVENT_TYPE, { detail: message }));
|
|
36
37
|
}
|
|
38
|
+
closeNotif(message) {
|
|
39
|
+
const notifIndex = this.notifRef.findIndex((notif) => notif.componentRef.instance.data.id === message.id);
|
|
40
|
+
const elementToRemove = this.notifRef.splice(notifIndex, 1).shift();
|
|
41
|
+
elementToRemove.componentRef.instance.hiddenFromAction = true;
|
|
42
|
+
elementToRemove.componentRef.instance.actionClicked.complete();
|
|
43
|
+
elementToRemove.overlayRef.dispose();
|
|
44
|
+
elementToRemove.componentRef.destroy();
|
|
45
|
+
this.notifRef.forEach((notifRef, index) => {
|
|
46
|
+
notifRef.componentRef.instance.listIndex = index;
|
|
47
|
+
});
|
|
48
|
+
}
|
|
37
49
|
notMitigatedOpen(message) {
|
|
38
|
-
|
|
50
|
+
const overlayRef = this.overlay.create(new OverlayConfig({
|
|
39
51
|
hasBackdrop: false
|
|
40
52
|
}));
|
|
41
53
|
const componentPortal = new ComponentPortal(PrySnackbarComponent, this.rootViewContainer);
|
|
42
|
-
const component =
|
|
54
|
+
const component = overlayRef.attach(componentPortal);
|
|
43
55
|
component.instance.data = message;
|
|
44
|
-
component.instance.listIndex = PrySnackbarService.count++;
|
|
45
56
|
component.instance.actionClicked = new Subject();
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
57
|
+
if (message.type === 'notif') {
|
|
58
|
+
if (this.notifRef.length < 5) {
|
|
59
|
+
this.notifRef.unshift({ componentRef: component, overlayRef });
|
|
60
|
+
this.notifRef.forEach((notifRef, index) => {
|
|
61
|
+
notifRef.componentRef.instance.listIndex = index;
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
else if (this.notifRef.length === 5) {
|
|
65
|
+
const olderComponent = this.notifRef.pop();
|
|
66
|
+
olderComponent.componentRef.instance.hiddenFromAction = true;
|
|
67
|
+
olderComponent.componentRef.instance.actionClicked.complete();
|
|
68
|
+
olderComponent.overlayRef.dispose();
|
|
69
|
+
olderComponent.componentRef.destroy();
|
|
70
|
+
this.notifRef.unshift({ componentRef: component, overlayRef });
|
|
71
|
+
this.notifRef.forEach((notifRef, index) => {
|
|
72
|
+
notifRef.componentRef.instance.listIndex = index;
|
|
73
|
+
});
|
|
74
|
+
}
|
|
50
75
|
setTimeout(() => {
|
|
51
|
-
/* then clean by removing it */
|
|
52
76
|
component.instance.actionClicked.complete();
|
|
53
|
-
|
|
77
|
+
overlayRef?.dispose();
|
|
54
78
|
component.destroy();
|
|
55
|
-
},
|
|
56
|
-
}
|
|
79
|
+
}, 10000);
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
component.instance.listIndex = PrySnackbarService.count++;
|
|
83
|
+
setTimeout(() => {
|
|
84
|
+
/* First hide component so it uses animation */
|
|
85
|
+
component.instance.hiddenFromAction = true;
|
|
86
|
+
PrySnackbarService.count--;
|
|
87
|
+
setTimeout(() => {
|
|
88
|
+
/* then clean by removing it */
|
|
89
|
+
component.instance.actionClicked.complete();
|
|
90
|
+
overlayRef?.dispose();
|
|
91
|
+
component.destroy();
|
|
92
|
+
}, DELAY_FOR_HIDE);
|
|
93
|
+
}, message.timeout ?? DEFAULT_MSG_TIMEOUT);
|
|
94
|
+
}
|
|
57
95
|
return component.instance.actionClicked;
|
|
58
96
|
}
|
|
59
97
|
open(message) {
|
|
@@ -68,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
68
106
|
providedIn: 'root'
|
|
69
107
|
}]
|
|
70
108
|
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i2.PryI18nService }] });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2tiYXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9jb3JlL2NvbXBvbmVudHMvc25hY2tiYXIvc25hY2tiYXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVcsYUFBYSxFQUFjLE1BQU0sc0JBQXNCLENBQUM7QUFDMUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxVQUFVLEVBQW9CLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sS0FBSyxNQUFNLHFCQUFxQixDQUFDO0FBQ3hDLE9BQU8sRUFBYyxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNsRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFHNUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sK0JBQStCLENBQUM7Ozs7QUFFckUsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsSUFBSSxDQUFDO0FBQ3hDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxHQUFHLENBQUM7QUFFbEMsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsWUFBWSxDQUFDO0FBS2pELE1BQU0sT0FBTyxrQkFBa0I7YUFFdEIsVUFBSyxHQUFHLENBQUMsQUFBSixDQUFLO0lBTWpCLFlBQ1UsT0FBZ0IsRUFDaEIsU0FBeUI7UUFEekIsWUFBTyxHQUFQLE9BQU8sQ0FBUztRQUNoQixjQUFTLEdBQVQsU0FBUyxDQUFnQjtRQUozQixtQkFBYyxHQUFHLElBQUksT0FBTyxFQUFtQixDQUFDO1FBTXRELCtFQUErRTtRQUMvRSxRQUFRLENBQUMsZ0JBQWdCLENBQ3ZCLG9CQUFvQixFQUNwQixDQUFDLENBQVEsRUFBRSxFQUFFO1lBQ1gsTUFBTSxVQUFVLEdB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QWxCLGtCQUFrQixjQUZqQixNQUFNOzsyRkFFUCxrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3ZlcmxheSwgT3ZlcmxheUNvbmZpZywgT3ZlcmxheVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IENvbXBvbmVudFBvcnRhbCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IGVxdWFsIGZyb20gJ2Zhc3QtZGVlcC1lcXVhbC9lczYnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCwgc3dpdGNoTWFwLCB3aW5kb3dUaW1lIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBkaXN0aW5jdFVudGlsQ2hhbmdlZCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgUHJ5STE4blNlcnZpY2UgfSBmcm9tICcuLi8uLi9pMThuL2kxOG4uc2VydmljZSc7XG5pbXBvcnQgeyBQcnlTbmFja01lc3NhZ2UgfSBmcm9tICcuL3NuYWNrLmludGVyZmFjZSc7XG5pbXBvcnQgeyBQcnlTbmFja2JhckNvbXBvbmVudCB9IGZyb20gJy4vc25hY2tiYXIvc25hY2tiYXIuY29tcG9uZW50JztcblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfTVNHX1RJTUVPVVQgPSAzMDAwO1xuZXhwb3J0IGNvbnN0IERFTEFZX0ZPUl9ISURFID0gMjAwO1xuXG5leHBvcnQgY29uc3QgUFJZX0NVU1RPTUVWRU5UX1RZUEUgPSAnQHByeS5zbmFjayc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFByeVNuYWNrYmFyU2VydmljZSB7XG4gIHJvb3RWaWV3Q29udGFpbmVyPzogVmlld0NvbnRhaW5lclJlZjtcbiAgc3RhdGljIGNvdW50ID0gMDtcblxuICBwcml2YXRlIG92ZXJsYXlSZWY/OiBPdmVybGF5UmVmO1xuXG4gIHByaXZhdGUgbWVzc2FnZUV2ZW50cyQgPSBuZXcgU3ViamVjdDxQcnlTbmFja01lc3NhZ2U+KCk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBvdmVybGF5OiBPdmVybGF5LFxuICAgIHByaXZhdGUgdHJhbnNsYXRlOiBQcnlJMThuU2VydmljZVxuICApIHtcbiAgICAvLyBBbGxvd3MgdG8gYWNjZXNzIHNuYWNrYmFyIGZyb20gamF2YXNjcmlwdCwgZm9yIGV4YW1wbGUgdG8gbWFuYWdlIFZlZ2EgZXJyb3JzXG4gICAgZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcihcbiAgICAgIFBSWV9DVVNUT01FVkVOVF9UWVBFLFxuICAgICAgKGU6IEV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IHByeU1lc3NhZ2UgPSAoZSBhcyBDdXN0b21FdmVudDxQcnlTbmFja01lc3NhZ2U+KS5kZXRhaWw7XG4gICAgICAgIHByeU1lc3NhZ2UubWVzc2FnZSA9IHRoaXMudHJhbnNsYXRlLmluc3RhbnQocHJ5TWVzc2FnZS5tZXNzYWdlKTtcbiAgICAgICAgcHJ5TWVzc2FnZS5hY3Rpb24gPSAhIXByeU1lc3NhZ2UuYWN0aW9uID8gdGhpcy50cmFuc2xhdGUuaW5zdGFudChwcnlNZXNzYWdlLmFjdGlvbikgOiB1bmRlZmluZWQ7XG4gICAgICAgIHRoaXMubWVzc2FnZUV2ZW50cyQubmV4dChwcnlNZXNzYWdlKTtcbiAgICAgIH0sXG4gICAgICBmYWxzZVxuICAgICk7XG5cbiAgICB0aGlzLm1lc3NhZ2VFdmVudHMkXG4gICAgICAucGlwZShcbiAgICAgICAgd2luZG93VGltZSgxMDAwKSxcbiAgICAgICAgc3dpdGNoTWFwKChzb3VyY2UpID0+IHNvdXJjZS5waXBlKGRpc3RpbmN0VW50aWxDaGFuZ2VkKChwLCB2KSA9PiBlcXVhbChwLCB2KSkpKVxuICAgICAgKVxuICAgICAgLnN1YnNjcmliZSgobWVzc2FnZSkgPT4gdGhpcy5ub3RNaXRpZ2F0ZWRPcGVuKG1lc3NhZ2UpKTtcbiAgfVxuXG4gIHNldFJvb3RWaWV3Q29udGFpbmVyUmVmKHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHtcbiAgICB0aGlzLnJvb3RWaWV3Q29udGFpbmVyID0gdmlld0NvbnRhaW5lclJlZjtcbiAgfVxuXG4gIGRpc3BhdGNoT3BlbkV2ZW50KG1lc3NhZ2U6IFByeVNuYWNrTWVzc2FnZSkge1xuICAgIGRvY3VtZW50LmRpc3BhdGNoRXZlbnQobmV3IEN1c3RvbUV2ZW50KFBSWV9DVVNUT01FVkVOVF9UWVBFLCB7IGRldGFpbDogbWVzc2FnZSB9KSk7XG4gIH1cblxuICBub3RNaXRpZ2F0ZWRPcGVuKG1lc3NhZ2U6IFByeVNuYWNrTWVzc2FnZSk6IE9ic2VydmFibGU8dm9pZD4gfCBudWxsIHtcbiAgICB0aGlzLm92ZXJsYXlSZWYgPSB0aGlzLm92ZXJsYXkuY3JlYXRlKFxuICAgICAgbmV3IE92ZXJsYXlDb25maWcoe1xuICAgICAgICBoYXNCYWNrZHJvcDogZmFsc2VcbiAgICAgIH0pXG4gICAgKTtcbiAgICBjb25zdCBjb21wb25lbnRQb3J0YWwgPSBuZXcgQ29tcG9uZW50UG9ydGFsKFByeVNuYWNrYmFyQ29tcG9uZW50LCB0aGlzLnJvb3RWaWV3Q29udGFpbmVyKTtcbiAgICBjb25zdCBjb21wb25lbnQgPSB0aGlzLm92ZXJsYXlSZWYuYXR0YWNoKGNvbXBvbmVudFBvcnRhbCk7XG5cbiAgICBjb21wb25lbnQuaW5zdGFuY2UuZGF0YSA9IG1lc3NhZ2U7XG4gICAgY29tcG9uZW50Lmluc3RhbmNlLmxpc3RJbmRleCA9IFByeVNuYWNrYmFyU2VydmljZS5jb3VudCsrO1xuICAgIGNvbXBvbmVudC5pbnN0YW5jZS5hY3Rpb25DbGlja2VkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgLyogRmlyc3QgaGlkZSBjb21wb25lbnQgc28gaXQgdXNlcyBhbmltYXRpb24gKi9cbiAgICAgIGNvbXBvbmVudC5pbnN0YW5jZS5oaWRkZW5Gcm9tQWN0aW9uID0gdHJ1ZTtcbiAgICAgIFByeVNuYWNrYmFyU2VydmljZS5jb3VudC0tO1xuXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgLyogdGhlbiBjbGVhbiBieSByZW1vdmluZyBpdCAqL1xuICAgICAgICBjb21wb25lbnQuaW5zdGFuY2UuYWN0aW9uQ2xpY2tlZC5jb21wbGV0ZSgpO1xuICAgICAgICB0aGlzLm92ZXJsYXlSZWY/LmRpc3Bvc2UoKTtcbiAgICAgICAgY29tcG9uZW50LmRlc3Ryb3koKTtcbiAgICAgIH0sIERFTEFZX0ZPUl9ISURFKTtcbiAgICB9LCBtZXNzYWdlLnRpbWVvdXQgPz8gREVGQVVMVF9NU0dfVElNRU9VVCk7XG5cbiAgICByZXR1cm4gY29tcG9uZW50Lmluc3RhbmNlLmFjdGlvbkNsaWNrZWQ7XG4gIH1cblxuICBvcGVuKG1lc3NhZ2U6IFByeVNuYWNrTWVzc2FnZSkge1xuICAgIHRoaXMubWVzc2FnZUV2ZW50cyQubmV4dChtZXNzYWdlKTtcbiAgfVxufVxuIl19
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snackbar.service.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/lib/core/components/snackbar/snackbar.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, Injectable, ViewContainerRef } from '@angular/core';\nimport equal from 'fast-deep-equal/es6';\nimport { Observable, Subject, switchMap, windowTime } from 'rxjs';\nimport { distinctUntilChanged } from 'rxjs';\nimport { PryI18nService } from '../../i18n/i18n.service';\nimport { PrySnackMessage } from './snack.interface';\nimport { PrySnackbarComponent } from './snackbar/snackbar.component';\n\nexport const DEFAULT_MSG_TIMEOUT = 3000;\nexport const DELAY_FOR_HIDE = 200;\n\nexport const PRY_CUSTOMEVENT_TYPE = '@pry.snack';\n\nexport interface notifSnack {\n  componentRef: ComponentRef<PrySnackbarComponent>;\n  overlayRef: OverlayRef;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class PrySnackbarService {\n  rootViewContainer?: ViewContainerRef;\n  static count = 0;\n\n  private messageEvents$ = new Subject<PrySnackMessage>();\n  private notifRef: notifSnack[] = [];\n\n  constructor(\n    private overlay: Overlay,\n    private translate: PryI18nService\n  ) {\n    // Allows to access snackbar from javascript, for example to manage Vega errors\n    document.addEventListener(\n      PRY_CUSTOMEVENT_TYPE,\n      (e: Event) => {\n        const pryMessage = (e as CustomEvent<PrySnackMessage>).detail;\n        pryMessage.message = this.translate.instant(pryMessage.message);\n        pryMessage.action = !!pryMessage.action ? this.translate.instant(pryMessage.action) : undefined;\n        this.messageEvents$.next(pryMessage);\n      },\n      false\n    );\n\n    this.messageEvents$\n      .pipe(\n        windowTime(1000),\n        switchMap((source) => source.pipe(distinctUntilChanged((p, v) => equal(p, v))))\n      )\n      .subscribe((message) => this.notMitigatedOpen(message));\n  }\n\n  setRootViewContainerRef(viewContainerRef: ViewContainerRef) {\n    this.rootViewContainer = viewContainerRef;\n  }\n\n  dispatchOpenEvent(message: PrySnackMessage) {\n    document.dispatchEvent(new CustomEvent(PRY_CUSTOMEVENT_TYPE, { detail: message }));\n  }\n\n  closeNotif(message: PrySnackMessage) {\n    const notifIndex = this.notifRef.findIndex((notif) => notif.componentRef.instance.data.id === message.id);\n    const elementToRemove = this.notifRef.splice(notifIndex, 1).shift();\n    elementToRemove!.componentRef.instance.hiddenFromAction = true;\n    elementToRemove!.componentRef.instance.actionClicked.complete();\n    elementToRemove!.overlayRef.dispose();\n    elementToRemove!.componentRef.destroy();\n    this.notifRef.forEach((notifRef, index) => {\n      notifRef.componentRef.instance.listIndex = index;\n    });\n  }\n\n  notMitigatedOpen(message: PrySnackMessage): Observable<void> | null {\n    const overlayRef = this.overlay.create(\n      new OverlayConfig({\n        hasBackdrop: false\n      })\n    );\n    const componentPortal = new ComponentPortal(PrySnackbarComponent, this.rootViewContainer);\n    const component = overlayRef.attach(componentPortal);\n    component.instance.data = message;\n    component.instance.actionClicked = new Subject<void>();\n    if (message.type === 'notif') {\n      if (this.notifRef.length < 5) {\n        this.notifRef.unshift({ componentRef: component, overlayRef });\n        this.notifRef.forEach((notifRef, index) => {\n          notifRef.componentRef.instance.listIndex = index;\n        });\n      } else if (this.notifRef.length === 5) {\n        const olderComponent = this.notifRef.pop();\n        olderComponent!.componentRef.instance.hiddenFromAction = true;\n        olderComponent!.componentRef.instance.actionClicked.complete();\n        olderComponent!.overlayRef.dispose();\n        olderComponent!.componentRef.destroy();\n        this.notifRef.unshift({ componentRef: component, overlayRef });\n        this.notifRef.forEach((notifRef, index) => {\n          notifRef.componentRef.instance.listIndex = index;\n        });\n      }\n      setTimeout(() => {\n        component.instance.actionClicked.complete();\n        overlayRef?.dispose();\n        component.destroy();\n      }, 10000);\n    } else {\n      component.instance.listIndex = PrySnackbarService.count++;\n      setTimeout(() => {\n        /* First hide component so it uses animation */\n        component.instance.hiddenFromAction = true;\n        PrySnackbarService.count--;\n        setTimeout(() => {\n          /* then clean by removing it */\n          component.instance.actionClicked.complete();\n          overlayRef?.dispose();\n          component.destroy();\n        }, DELAY_FOR_HIDE);\n      }, message.timeout ?? DEFAULT_MSG_TIMEOUT);\n    }\n\n    return component.instance.actionClicked;\n  }\n\n  open(message: PrySnackMessage) {\n    this.messageEvents$.next(message);\n  }\n}\n"]}
|
|
@@ -2705,13 +2705,25 @@ class PrySnackbarComponent {
|
|
|
2705
2705
|
this._data = message;
|
|
2706
2706
|
this.cdRef.detectChanges();
|
|
2707
2707
|
}
|
|
2708
|
-
|
|
2708
|
+
set listIndex(listIndex) {
|
|
2709
|
+
if (!!listIndex || listIndex === 0) {
|
|
2710
|
+
this._listIndex = listIndex;
|
|
2711
|
+
}
|
|
2712
|
+
this.getStyle();
|
|
2713
|
+
}
|
|
2714
|
+
get listIndex() {
|
|
2715
|
+
return this._listIndex;
|
|
2716
|
+
}
|
|
2717
|
+
constructor(cdRef, snackService, router) {
|
|
2709
2718
|
this.cdRef = cdRef;
|
|
2719
|
+
this.snackService = snackService;
|
|
2720
|
+
this.router = router;
|
|
2710
2721
|
this._data = { message: '', action: undefined, type: 'info', timeout: 3000 };
|
|
2711
|
-
this.listIndex = 0;
|
|
2712
2722
|
this.transformOptions = 'translate3d(-50%, 100%, 0px)';
|
|
2713
2723
|
this.transitionOptions = '150ms cubic-bezier(0, 0, 0.2, 1)';
|
|
2714
2724
|
this.hiddenFromAction = false;
|
|
2725
|
+
this._listIndex = 0;
|
|
2726
|
+
this.snackStyle = { top: '' };
|
|
2715
2727
|
}
|
|
2716
2728
|
get data() {
|
|
2717
2729
|
return this._data;
|
|
@@ -2719,12 +2731,25 @@ class PrySnackbarComponent {
|
|
|
2719
2731
|
get typeClass() {
|
|
2720
2732
|
return { ['-' + this.data.type]: true };
|
|
2721
2733
|
}
|
|
2734
|
+
getStyle() {
|
|
2735
|
+
if (this.data.type === 'notif') {
|
|
2736
|
+
this.snackStyle = {
|
|
2737
|
+
top: (this.listIndex === 0 ? 60 : this.listIndex * 60 + 60) + 'px'
|
|
2738
|
+
};
|
|
2739
|
+
}
|
|
2740
|
+
else {
|
|
2741
|
+
this.snackStyle = {
|
|
2742
|
+
bottom: this.listIndex * 60 + 'px'
|
|
2743
|
+
};
|
|
2744
|
+
}
|
|
2745
|
+
}
|
|
2722
2746
|
get icon() {
|
|
2723
2747
|
const iconsDefs = {
|
|
2724
2748
|
info: 'information-point',
|
|
2725
2749
|
success: 'check',
|
|
2726
2750
|
warning: 'warning',
|
|
2727
|
-
error: 'close'
|
|
2751
|
+
error: 'close',
|
|
2752
|
+
notif: 'information-point'
|
|
2728
2753
|
};
|
|
2729
2754
|
return iconsDefs[this.data.type];
|
|
2730
2755
|
}
|
|
@@ -2734,8 +2759,17 @@ class PrySnackbarComponent {
|
|
|
2734
2759
|
hide() {
|
|
2735
2760
|
this.hiddenFromAction = true;
|
|
2736
2761
|
}
|
|
2737
|
-
|
|
2738
|
-
|
|
2762
|
+
openEvenement(data) {
|
|
2763
|
+
this.router.navigate([]).then(() => {
|
|
2764
|
+
const url = this.router.serializeUrl(this.router.createUrlTree(['/', 'journal', data.message.padStart(6, '0')]));
|
|
2765
|
+
window.open(url, '_blank');
|
|
2766
|
+
});
|
|
2767
|
+
}
|
|
2768
|
+
closeNotif(data) {
|
|
2769
|
+
this.snackService.closeNotif(data);
|
|
2770
|
+
}
|
|
2771
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PrySnackbarComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: PrySnackbarService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2772
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PrySnackbarComponent, selector: "pry-snackbar", inputs: { data: "data", actionClicked: "actionClicked", listIndex: "listIndex" }, ngImport: i0, template: "@if (!hiddenFromAction) {\n @if (data.type === 'notif') {\n <div\n (click)=\"openEvenement(data)\"\n class=\"m-snackbar m-snackbar-notif\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style]=\"snackStyle\"\n >\n <div class=\"m-snackbar__content\">\n <p class=\"a-p\">{{ data.message }}</p>\n <pry-icon (click)=\"closeNotif(data)\" class=\"notif-erase\" iconSvg=\"close\" [width]=\"18\" [height]=\"18\"> </pry-icon>\n </div>\n </div>\n } @else {\n <div\n class=\"m-snackbar -bottom\"\n [ngClass]=\"typeClass\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style]=\"snackStyle\"\n >\n <div class=\"m-snackbar__content\">\n <pry-icon [iconSvg]=\"icon\"></pry-icon>\n <p class=\"a-p\">{{ data.message }}</p>\n @if (!!data.action) {\n <button class=\"m-snackbar__action\" (click)=\"actionClick()\">{{ data.action }}</button>\n }\n </div>\n </div>\n }\n}\n", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }], animations: [
|
|
2739
2773
|
trigger('panelState', [
|
|
2740
2774
|
transition('void => visible', [useAnimation(showAnimation)]),
|
|
2741
2775
|
transition('visible => void', [useAnimation(hideAnimation)])
|
|
@@ -2749,13 +2783,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
2749
2783
|
transition('void => visible', [useAnimation(showAnimation)]),
|
|
2750
2784
|
transition('visible => void', [useAnimation(hideAnimation)])
|
|
2751
2785
|
])
|
|
2752
|
-
], template: "@if (!hiddenFromAction) {\n <div\n class=\"m-snackbar -bottom\"\n
|
|
2753
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { data: [{
|
|
2754
|
-
type: Input
|
|
2755
|
-
}], listIndex: [{
|
|
2786
|
+
], template: "@if (!hiddenFromAction) {\n @if (data.type === 'notif') {\n <div\n (click)=\"openEvenement(data)\"\n class=\"m-snackbar m-snackbar-notif\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style]=\"snackStyle\"\n >\n <div class=\"m-snackbar__content\">\n <p class=\"a-p\">{{ data.message }}</p>\n <pry-icon (click)=\"closeNotif(data)\" class=\"notif-erase\" iconSvg=\"close\" [width]=\"18\" [height]=\"18\"> </pry-icon>\n </div>\n </div>\n } @else {\n <div\n class=\"m-snackbar -bottom\"\n [ngClass]=\"typeClass\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style]=\"snackStyle\"\n >\n <div class=\"m-snackbar__content\">\n <pry-icon [iconSvg]=\"icon\"></pry-icon>\n <p class=\"a-p\">{{ data.message }}</p>\n @if (!!data.action) {\n <button class=\"m-snackbar__action\" (click)=\"actionClick()\">{{ data.action }}</button>\n }\n </div>\n </div>\n }\n}\n" }]
|
|
2787
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: PrySnackbarService }, { type: i2.Router }], propDecorators: { data: [{
|
|
2756
2788
|
type: Input
|
|
2757
2789
|
}], actionClicked: [{
|
|
2758
2790
|
type: Input
|
|
2791
|
+
}], listIndex: [{
|
|
2792
|
+
type: Input
|
|
2759
2793
|
}] } });
|
|
2760
2794
|
|
|
2761
2795
|
const DEFAULT_MSG_TIMEOUT = 3000;
|
|
@@ -2767,6 +2801,7 @@ class PrySnackbarService {
|
|
|
2767
2801
|
this.overlay = overlay;
|
|
2768
2802
|
this.translate = translate;
|
|
2769
2803
|
this.messageEvents$ = new Subject();
|
|
2804
|
+
this.notifRef = [];
|
|
2770
2805
|
// Allows to access snackbar from javascript, for example to manage Vega errors
|
|
2771
2806
|
document.addEventListener(PRY_CUSTOMEVENT_TYPE, (e) => {
|
|
2772
2807
|
const pryMessage = e.detail;
|
|
@@ -2784,26 +2819,63 @@ class PrySnackbarService {
|
|
|
2784
2819
|
dispatchOpenEvent(message) {
|
|
2785
2820
|
document.dispatchEvent(new CustomEvent(PRY_CUSTOMEVENT_TYPE, { detail: message }));
|
|
2786
2821
|
}
|
|
2822
|
+
closeNotif(message) {
|
|
2823
|
+
const notifIndex = this.notifRef.findIndex((notif) => notif.componentRef.instance.data.id === message.id);
|
|
2824
|
+
const elementToRemove = this.notifRef.splice(notifIndex, 1).shift();
|
|
2825
|
+
elementToRemove.componentRef.instance.hiddenFromAction = true;
|
|
2826
|
+
elementToRemove.componentRef.instance.actionClicked.complete();
|
|
2827
|
+
elementToRemove.overlayRef.dispose();
|
|
2828
|
+
elementToRemove.componentRef.destroy();
|
|
2829
|
+
this.notifRef.forEach((notifRef, index) => {
|
|
2830
|
+
notifRef.componentRef.instance.listIndex = index;
|
|
2831
|
+
});
|
|
2832
|
+
}
|
|
2787
2833
|
notMitigatedOpen(message) {
|
|
2788
|
-
|
|
2834
|
+
const overlayRef = this.overlay.create(new OverlayConfig({
|
|
2789
2835
|
hasBackdrop: false
|
|
2790
2836
|
}));
|
|
2791
2837
|
const componentPortal = new ComponentPortal(PrySnackbarComponent, this.rootViewContainer);
|
|
2792
|
-
const component =
|
|
2838
|
+
const component = overlayRef.attach(componentPortal);
|
|
2793
2839
|
component.instance.data = message;
|
|
2794
|
-
component.instance.listIndex = PrySnackbarService.count++;
|
|
2795
2840
|
component.instance.actionClicked = new Subject();
|
|
2796
|
-
|
|
2797
|
-
|
|
2798
|
-
|
|
2799
|
-
|
|
2841
|
+
if (message.type === 'notif') {
|
|
2842
|
+
if (this.notifRef.length < 5) {
|
|
2843
|
+
this.notifRef.unshift({ componentRef: component, overlayRef });
|
|
2844
|
+
this.notifRef.forEach((notifRef, index) => {
|
|
2845
|
+
notifRef.componentRef.instance.listIndex = index;
|
|
2846
|
+
});
|
|
2847
|
+
}
|
|
2848
|
+
else if (this.notifRef.length === 5) {
|
|
2849
|
+
const olderComponent = this.notifRef.pop();
|
|
2850
|
+
olderComponent.componentRef.instance.hiddenFromAction = true;
|
|
2851
|
+
olderComponent.componentRef.instance.actionClicked.complete();
|
|
2852
|
+
olderComponent.overlayRef.dispose();
|
|
2853
|
+
olderComponent.componentRef.destroy();
|
|
2854
|
+
this.notifRef.unshift({ componentRef: component, overlayRef });
|
|
2855
|
+
this.notifRef.forEach((notifRef, index) => {
|
|
2856
|
+
notifRef.componentRef.instance.listIndex = index;
|
|
2857
|
+
});
|
|
2858
|
+
}
|
|
2800
2859
|
setTimeout(() => {
|
|
2801
|
-
/* then clean by removing it */
|
|
2802
2860
|
component.instance.actionClicked.complete();
|
|
2803
|
-
|
|
2861
|
+
overlayRef?.dispose();
|
|
2804
2862
|
component.destroy();
|
|
2805
|
-
},
|
|
2806
|
-
}
|
|
2863
|
+
}, 10000);
|
|
2864
|
+
}
|
|
2865
|
+
else {
|
|
2866
|
+
component.instance.listIndex = PrySnackbarService.count++;
|
|
2867
|
+
setTimeout(() => {
|
|
2868
|
+
/* First hide component so it uses animation */
|
|
2869
|
+
component.instance.hiddenFromAction = true;
|
|
2870
|
+
PrySnackbarService.count--;
|
|
2871
|
+
setTimeout(() => {
|
|
2872
|
+
/* then clean by removing it */
|
|
2873
|
+
component.instance.actionClicked.complete();
|
|
2874
|
+
overlayRef?.dispose();
|
|
2875
|
+
component.destroy();
|
|
2876
|
+
}, DELAY_FOR_HIDE);
|
|
2877
|
+
}, message.timeout ?? DEFAULT_MSG_TIMEOUT);
|
|
2878
|
+
}
|
|
2807
2879
|
return component.instance.actionClicked;
|
|
2808
2880
|
}
|
|
2809
2881
|
open(message) {
|