@provoly/dashboard 1.4.49 → 1.4.51

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.
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2suaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9zbmFja2Jhci9zbmFjay5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUHJ5U25hY2tNZXNzYWdlIHtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBhY3Rpb24/OiBzdHJpbmc7XG4gIHR5cGU6ICdzdWNjZXNzJyB8ICdpbmZvJyB8ICd3YXJuaW5nJyB8ICdlcnJvcic7XG4gIHRpbWVvdXQ/OiBudW1iZXI7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2suaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9zbmFja2Jhci9zbmFjay5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUHJ5U25hY2tNZXNzYWdlIHtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBpZD86IHN0cmluZztcbiAgYWN0aW9uPzogc3RyaW5nO1xuICB0eXBlOiAnc3VjY2VzcycgfCAnaW5mbycgfCAnd2FybmluZycgfCAnZXJyb3InIHwgJ25vdGlmJztcbiAgdGltZW91dD86IG51bWJlcjtcbiAgbGluaz86IHN0cmluZztcbn1cbiJdfQ==
@@ -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 "@angular/common";
5
- import * as i2 from "../../icon/icon.component";
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
- constructor(cdRef) {
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
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PrySnackbarComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
43
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PrySnackbarComponent, selector: "pry-snackbar", inputs: { data: "data", listIndex: "listIndex", actionClicked: "actionClicked" }, ngImport: i0, template: "@if (!hiddenFromAction) {\n <div\n class=\"m-snackbar -bottom\"\n [ngClass]=\"typeClass\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style.bottom.px]=\"listIndex * 60\"\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", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }], animations: [
69
+ openEvenement(data) {
70
+ this.router.navigate([]).then(() => {
71
+ const url = this.router.serializeUrl(this.router.createUrlTree(['', data.link]));
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 [ngClass]=\"typeClass\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style.bottom.px]=\"listIndex * 60\"\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" }]
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2tiYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9zbmFja2Jhci9zbmFja2Jhci9zbmFja2Jhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9jb21wb25lbnRzL3NuYWNrYmFyL3NuYWNrYmFyL3NuYWNrYmFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25HLE9BQU8sRUFBcUIsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQUlwRSxNQUFNLGFBQWEsR0FBRyxTQUFTLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUVoSCxNQUFNLGFBQWEsR0FBRyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQVloSCxNQUFNLE9BQU8sb0JBQW9CO0lBRy9CLElBQWEsSUFBSSxDQUFDLE9BQXdCO1FBQ3hDLElBQUksQ0FBQyxLQUFLLEdBQUcsT0FBTyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQVFELFlBQW9CLEtBQXdCO1FBQXhCLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBWjVDLFVBQUssR0FBRyxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQXFCLENBQUM7UUFNbEYsY0FBUyxHQUFHLENBQUMsQ0FBQztRQUV2QixxQkFBZ0IsR0FBRyw4QkFBOEIsQ0FBQztRQUNsRCxzQkFBaUIsR0FBRyxrQ0FBa0MsQ0FBQztRQUN2RCxxQkFBZ0IsR0FBRyxLQUFLLENBQUM7SUFFc0IsQ0FBQztJQUVoRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVELElBQUksU0FBUztRQUNYLE9BQU8sRUFBRSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDO0lBQzFDLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixNQUFNLFNBQVMsR0FBRztZQUNoQixJQUFJLEVBQUUsbUJBQW1CO1lBQ3pCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLE9BQU8sRUFBRSxTQUFTO1lBQ2xCLEtBQUssRUFBRSxPQUFPO1NBQ2YsQ0FBQztRQUNGLE9BQU8sU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUFJO1FBQ0YsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQztJQUMvQixDQUFDOzhHQXhDVSxvQkFBb0I7a0dBQXBCLG9CQUFvQixzSUNuQmpDLG1qQkFnQkEsaVNESmM7WUFDVixPQUFPLENBQUMsWUFBWSxFQUFFO2dCQUNwQixVQUFVLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztnQkFDNUQsVUFBVSxDQUFDLGlCQUFpQixFQUFFLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7YUFDN0QsQ0FBQztTQUNIOzsyRkFFVSxvQkFBb0I7a0JBVmhDLFNBQVM7K0JBQ0UsY0FBYyxjQUVaO3dCQUNWLE9BQU8sQ0FBQyxZQUFZLEVBQUU7NEJBQ3BCLFVBQVUsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDOzRCQUM1RCxVQUFVLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQzt5QkFDN0QsQ0FBQztxQkFDSDtzRkFLWSxJQUFJO3NCQUFoQixLQUFLO2dCQUtHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFuaW1hdGUsIGFuaW1hdGlvbiwgc3R5bGUsIHRyYW5zaXRpb24sIHRyaWdnZXIsIHVzZUFuaW1hdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFByeVNuYWNrTWVzc2FnZSB9IGZyb20gJy4uL3NuYWNrLmludGVyZmFjZSc7XG5cbmNvbnN0IHNob3dBbmltYXRpb24gPSBhbmltYXRpb24oW3N0eWxlKHsgdHJhbnNmb3JtOiAne3t0cmFuc2Zvcm19fScsIG9wYWNpdHk6IDAgfSksIGFuaW1hdGUoJ3t7dHJhbnNpdGlvbn19JyldKTtcblxuY29uc3QgaGlkZUFuaW1hdGlvbiA9IGFuaW1hdGlvbihbYW5pbWF0ZSgne3t0cmFuc2l0aW9ufX0nKSwgc3R5bGUoeyB0cmFuc2Zvcm06ICd7e3RyYW5zZm9ybX19Jywgb3BhY2l0eTogMCB9KV0pO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcnktc25hY2tiYXInLFxuICB0ZW1wbGF0ZVVybDogJy4vc25hY2tiYXIuY29tcG9uZW50Lmh0bWwnLFxuICBhbmltYXRpb25zOiBbXG4gICAgdHJpZ2dlcigncGFuZWxTdGF0ZScsIFtcbiAgICAgIHRyYW5zaXRpb24oJ3ZvaWQgPT4gdmlzaWJsZScsIFt1c2VBbmltYXRpb24oc2hvd0FuaW1hdGlvbildKSxcbiAgICAgIHRyYW5zaXRpb24oJ3Zpc2libGUgPT4gdm9pZCcsIFt1c2VBbmltYXRpb24oaGlkZUFuaW1hdGlvbildKVxuICAgIF0pXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgUHJ5U25hY2tiYXJDb21wb25lbnQge1xuICBjb250YWluZXI6IGFueTtcbiAgX2RhdGEgPSB7IG1lc3NhZ2U6ICcnLCBhY3Rpb246IHVuZGVmaW5lZCwgdHlwZTogJ2luZm8nLCB0aW1lb3V0OiAzMDAwIH0gYXMgUHJ5U25hY2tNZXNzYWdlO1xuICBASW5wdXQoKSBzZXQgZGF0YShtZXNzYWdlOiBQcnlTbmFja01lc3NhZ2UpIHtcbiAgICB0aGlzLl9kYXRhID0gbWVzc2FnZTtcbiAgICB0aGlzLmNkUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIEBJbnB1dCgpIGxpc3RJbmRleCA9IDA7XG4gIEBJbnB1dCgpIGFjdGlvbkNsaWNrZWQhOiBTdWJqZWN0PHZvaWQ+O1xuICB0cmFuc2Zvcm1PcHRpb25zID0gJ3RyYW5zbGF0ZTNkKC01MCUsIDEwMCUsIDBweCknO1xuICB0cmFuc2l0aW9uT3B0aW9ucyA9ICcxNTBtcyBjdWJpYy1iZXppZXIoMCwgMCwgMC4yLCAxKSc7XG4gIGhpZGRlbkZyb21BY3Rpb24gPSBmYWxzZTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNkUmVmOiBDaGFuZ2VEZXRlY3RvclJlZikge31cblxuICBnZXQgZGF0YSgpIHtcbiAgICByZXR1cm4gdGhpcy5fZGF0YTtcbiAgfVxuXG4gIGdldCB0eXBlQ2xhc3MoKSB7XG4gICAgcmV0dXJuIHsgWyctJyArIHRoaXMuZGF0YS50eXBlXTogdHJ1ZSB9O1xuICB9XG5cbiAgZ2V0IGljb24oKTogc3RyaW5nIHtcbiAgICBjb25zdCBpY29uc0RlZnMgPSB7XG4gICAgICBpbmZvOiAnaW5mb3JtYXRpb24tcG9pbnQnLFxuICAgICAgc3VjY2VzczogJ2NoZWNrJyxcbiAgICAgIHdhcm5pbmc6ICd3YXJuaW5nJyxcbiAgICAgIGVycm9yOiAnY2xvc2UnXG4gICAgfTtcbiAgICByZXR1cm4gaWNvbnNEZWZzW3RoaXMuZGF0YS50eXBlXTtcbiAgfVxuXG4gIGFjdGlvbkNsaWNrKCkge1xuICAgIHRoaXMuYWN0aW9uQ2xpY2tlZC5uZXh0KCk7XG4gIH1cblxuICBoaWRlKCkge1xuICAgIHRoaXMuaGlkZGVuRnJvbUFjdGlvbiA9IHRydWU7XG4gIH1cbn1cbiIsIkBpZiAoIWhpZGRlbkZyb21BY3Rpb24pIHtcbiAgPGRpdlxuICAgIGNsYXNzPVwibS1zbmFja2JhciAtYm90dG9tXCJcbiAgICBbbmdDbGFzc109XCJ0eXBlQ2xhc3NcIlxuICAgIFtAcGFuZWxTdGF0ZV09XCJ7IHZhbHVlOiAndmlzaWJsZScsIHBhcmFtczogeyB0cmFuc2Zvcm06IHRyYW5zZm9ybU9wdGlvbnMsIHRyYW5zaXRpb246IHRyYW5zaXRpb25PcHRpb25zIH0gfVwiXG4gICAgW3N0eWxlLmJvdHRvbS5weF09XCJsaXN0SW5kZXggKiA2MFwiXG4gICAgPlxuICAgIDxkaXYgY2xhc3M9XCJtLXNuYWNrYmFyX19jb250ZW50XCI+XG4gICAgICA8cHJ5LWljb24gW2ljb25TdmddPVwiaWNvblwiPjwvcHJ5LWljb24+XG4gICAgICA8cCBjbGFzcz1cImEtcFwiPnt7IGRhdGEubWVzc2FnZSB9fTwvcD5cbiAgICAgIEBpZiAoISFkYXRhLmFjdGlvbikge1xuICAgICAgICA8YnV0dG9uIGNsYXNzPVwibS1zbmFja2Jhcl9fYWN0aW9uXCIgKGNsaWNrKT1cImFjdGlvbkNsaWNrKClcIj57eyBkYXRhLmFjdGlvbiB9fTwvYnV0dG9uPlxuICAgICAgfVxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbn1cbiJdfQ==
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(['', data.link]));\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
- this.overlayRef = this.overlay.create(new OverlayConfig({
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 = this.overlayRef.attach(componentPortal);
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
- setTimeout(() => {
47
- /* First hide component so it uses animation */
48
- component.instance.hiddenFromAction = true;
49
- PrySnackbarService.count--;
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
- this.overlayRef?.dispose();
77
+ overlayRef?.dispose();
54
78
  component.destroy();
55
- }, DELAY_FOR_HIDE);
56
- }, message.timeout ?? DEFAULT_MSG_TIMEOUT);
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
- constructor(cdRef) {
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
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PrySnackbarComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
2738
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PrySnackbarComponent, selector: "pry-snackbar", inputs: { data: "data", listIndex: "listIndex", actionClicked: "actionClicked" }, ngImport: i0, template: "@if (!hiddenFromAction) {\n <div\n class=\"m-snackbar -bottom\"\n [ngClass]=\"typeClass\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style.bottom.px]=\"listIndex * 60\"\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", 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: [
2762
+ openEvenement(data) {
2763
+ this.router.navigate([]).then(() => {
2764
+ const url = this.router.serializeUrl(this.router.createUrlTree(['', data.link]));
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 [ngClass]=\"typeClass\"\n [@panelState]=\"{ value: 'visible', params: { transform: transformOptions, transition: transitionOptions } }\"\n [style.bottom.px]=\"listIndex * 60\"\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" }]
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
- this.overlayRef = this.overlay.create(new OverlayConfig({
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 = this.overlayRef.attach(componentPortal);
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
- setTimeout(() => {
2797
- /* First hide component so it uses animation */
2798
- component.instance.hiddenFromAction = true;
2799
- PrySnackbarService.count--;
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
- this.overlayRef?.dispose();
2861
+ overlayRef?.dispose();
2804
2862
  component.destroy();
2805
- }, DELAY_FOR_HIDE);
2806
- }, message.timeout ?? DEFAULT_MSG_TIMEOUT);
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) {