@provoly/dashboard 1.4.55 → 1.4.57

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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2suaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9zbmFja2Jhci9zbmFjay5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUHJ5U25hY2tNZXNzYWdlIHtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBpZD86IHN0cmluZztcbiAgYWN0aW9uPzogc3RyaW5nO1xuICB0eXBlOiAnc3VjY2VzcycgfCAnaW5mbycgfCAnd2FybmluZycgfCAnZXJyb3InIHwgJ25vdGlmJztcbiAgdGltZW91dD86IG51bWJlcjtcbiAgbGluaz86IHN0cmluZztcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2suaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9zbmFja2Jhci9zbmFjay5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUHJ5U25hY2tNZXNzYWdlIHtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICBhY3Rpb24/OiBzdHJpbmc7XG4gIHR5cGU6ICdzdWNjZXNzJyB8ICdpbmZvJyB8ICd3YXJuaW5nJyB8ICdlcnJvcic7XG4gIHRpbWVvdXQ/OiBudW1iZXI7XG59XG4iXX0=
@@ -1,10 +1,8 @@
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 "../snackbar.service";
5
- import * as i2 from "@angular/router";
6
- import * as i3 from "@angular/common";
7
- import * as i4 from "../../icon/icon.component";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "../../icon/icon.component";
8
6
  const showAnimation = animation([style({ transform: '{{transform}}', opacity: 0 }), animate('{{transition}}')]);
9
7
  const hideAnimation = animation([animate('{{transition}}'), style({ transform: '{{transform}}', opacity: 0 })]);
10
8
  export class PrySnackbarComponent {
@@ -12,25 +10,13 @@ export class PrySnackbarComponent {
12
10
  this._data = message;
13
11
  this.cdRef.detectChanges();
14
12
  }
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) {
13
+ constructor(cdRef) {
25
14
  this.cdRef = cdRef;
26
- this.snackService = snackService;
27
- this.router = router;
28
15
  this._data = { message: '', action: undefined, type: 'info', timeout: 3000 };
16
+ this.listIndex = 0;
29
17
  this.transformOptions = 'translate3d(-50%, 100%, 0px)';
30
18
  this.transitionOptions = '150ms cubic-bezier(0, 0, 0.2, 1)';
31
19
  this.hiddenFromAction = false;
32
- this._listIndex = 0;
33
- this.snackStyle = { top: '' };
34
20
  }
35
21
  get data() {
36
22
  return this._data;
@@ -38,25 +24,12 @@ export class PrySnackbarComponent {
38
24
  get typeClass() {
39
25
  return { ['-' + this.data.type]: true };
40
26
  }
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
- }
53
27
  get icon() {
54
28
  const iconsDefs = {
55
29
  info: 'information-point',
56
30
  success: 'check',
57
31
  warning: 'warning',
58
- error: 'close',
59
- notif: 'information-point'
32
+ error: 'close'
60
33
  };
61
34
  return iconsDefs[this.data.type];
62
35
  }
@@ -66,15 +39,8 @@ export class PrySnackbarComponent {
66
39
  hide() {
67
40
  this.hiddenFromAction = true;
68
41
  }
69
- openEvenement(data) {
70
- this.snackService.closeNotif(data);
71
- window.open(data.link, '_blank');
72
- }
73
- closeNotif(data) {
74
- this.snackService.closeNotif(data);
75
- }
76
- 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 }); }
77
- 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: [
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: [
78
44
  trigger('panelState', [
79
45
  transition('void => visible', [useAnimation(showAnimation)]),
80
46
  transition('visible => void', [useAnimation(hideAnimation)])
@@ -88,12 +54,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
88
54
  transition('void => visible', [useAnimation(showAnimation)]),
89
55
  transition('visible => void', [useAnimation(hideAnimation)])
90
56
  ])
91
- ], 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" }]
92
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.PrySnackbarService }, { type: i2.Router }], propDecorators: { data: [{
93
- type: Input
94
- }], actionClicked: [{
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: [{
95
59
  type: Input
96
60
  }], listIndex: [{
97
61
  type: Input
62
+ }], actionClicked: [{
63
+ type: Input
98
64
  }] } });
99
- //# 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":"AAAA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnG,OAAO,EAAqB,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;;;;;;AAMpE,MAAM,aAAa,GAAG,SAAS,CAAC,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;AAChH,MAAM,aAAa,GAAG,SAAS,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,KAAK,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAYhH,MAAM,OAAO,oBAAoB;IAG/B,IAAa,IAAI,CAAC,OAAwB;QACxC,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC;QACrB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAQD,IAAa,SAAS,CAAC,SAAiB;QACtC,IAAI,CAAC,CAAC,SAAS,IAAI,SAAS,KAAK,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC9B,CAAC;QACD,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,YACU,KAAwB,EACxB,YAAgC,EAChC,MAAc;QAFd,UAAK,GAAL,KAAK,CAAmB;QACxB,iBAAY,GAAZ,YAAY,CAAoB;QAChC,WAAM,GAAN,MAAM,CAAQ;QA1BxB,UAAK,GAAG,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAqB,CAAC;QAO3F,qBAAgB,GAAG,8BAA8B,CAAC;QAClD,sBAAiB,GAAG,kCAAkC,CAAC;QACvD,qBAAgB,GAAG,KAAK,CAAC;QACjB,eAAU,GAAG,CAAC,CAAC;QACvB,eAAU,GAAsC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC;IAgBzD,CAAC;IAEJ,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,SAAS;QACX,OAAO,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC;IAC1C,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YAC/B,IAAI,CAAC,UAAU,GAAG;gBAChB,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,IAAI;aACnE,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,GAAG;gBAChB,MAAM,EAAE,IAAI,CAAC,SAAS,GAAG,EAAE,GAAG,IAAI;aACnC,CAAC;QACJ,CAAC;IACH,CAAC;IAED,IAAI,IAAI;QACN,MAAM,SAAS,GAAG;YAChB,IAAI,EAAE,mBAAmB;YACzB,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,SAAS;YAClB,KAAK,EAAE,OAAO;YACd,KAAK,EAAE,mBAAmB;SAC3B,CAAC;QACF,OAAO,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI;QACF,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAC/B,CAAC;IAED,aAAa,CAAC,IAAqB;QACjC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACnC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAc,EAAE,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAED,UAAU,CAAC,IAAqB;QAC9B,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;8GA7EU,oBAAoB;kGAApB,oBAAoB,sICpBjC,qmCA8BA,iSDjBc;YACV,OAAO,CAAC,YAAY,EAAE;gBACpB,UAAU,CAAC,iBAAiB,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC;gBAC5D,UAAU,CAAC,iBAAiB,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC;aAC7D,CAAC;SACH;;2FAEU,oBAAoB;kBAVhC,SAAS;+BACE,cAAc,cAEZ;wBACV,OAAO,CAAC,YAAY,EAAE;4BACpB,UAAU,CAAC,iBAAiB,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC;4BAC5D,UAAU,CAAC,iBAAiB,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC;yBAC7D,CAAC;qBACH;4IAKY,IAAI;sBAAhB,KAAK;gBAKG,aAAa;sBAArB,KAAK;gBAMO,SAAS;sBAArB,KAAK","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.snackService.closeNotif(data);\n    window.open(data.link as string, '_blank');\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"]}
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2tiYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9zbmFja2Jhci9zbmFja2Jhci9zbmFja2Jhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9jb21wb25lbnRzL3NuYWNrYmFyL3NuYWNrYmFyL3NuYWNrYmFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25HLE9BQU8sRUFBcUIsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQUlwRSxNQUFNLGFBQWEsR0FBRyxTQUFTLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUVoSCxNQUFNLGFBQWEsR0FBRyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxLQUFLLENBQUMsRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQVloSCxNQUFNLE9BQU8sb0JBQW9CO0lBRy9CLElBQWEsSUFBSSxDQUFDLE9BQXdCO1FBQ3hDLElBQUksQ0FBQyxLQUFLLEdBQUcsT0FBTyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQVFELFlBQW9CLEtBQXdCO1FBQXhCLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBWjVDLFVBQUssR0FBRyxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQXFCLENBQUM7UUFNbEYsY0FBUyxHQUFHLENBQUMsQ0FBQztRQUV2QixxQkFBZ0IsR0FBRyw4QkFBOEIsQ0FBQztRQUNsRCxzQkFBaUIsR0FBRyxrQ0FBa0MsQ0FBQztRQUN2RCxxQkFBZ0IsR0FBRyxLQUFLLENBQUM7SUFFc0IsQ0FBQztJQUVoRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVELElBQUksU0FBUztRQUNYLE9BQU8sRUFBRSxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDO0lBQzFDLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixNQUFNLFNBQVMsR0FBRztZQUNoQixJQUFJLEVBQUUsbUJBQW1CO1lBQ3pCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLE9BQU8sRUFBRSxTQUFTO1lBQ2xCLEtBQUssRUFBRSxPQUFPO1NBQ2YsQ0FBQztRQUNGLE9BQU8sU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUFJO1FBQ0YsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQztJQUMvQixDQUFDOzhHQXhDVSxvQkFBb0I7a0dBQXBCLG9CQUFvQixzSUNuQmpDLG1qQkFnQkEsaVNESmM7WUFDVixPQUFPLENBQUMsWUFBWSxFQUFFO2dCQUNwQixVQUFVLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztnQkFDNUQsVUFBVSxDQUFDLGlCQUFpQixFQUFFLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7YUFDN0QsQ0FBQztTQUNIOzsyRkFFVSxvQkFBb0I7a0JBVmhDLFNBQVM7K0JBQ0UsY0FBYyxjQUVaO3dCQUNWLE9BQU8sQ0FBQyxZQUFZLEVBQUU7NEJBQ3BCLFVBQVUsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDOzRCQUM1RCxVQUFVLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQzt5QkFDN0QsQ0FBQztxQkFDSDtzRkFLWSxJQUFJO3NCQUFoQixLQUFLO2dCQUtHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFuaW1hdGUsIGFuaW1hdGlvbiwgc3R5bGUsIHRyYW5zaXRpb24sIHRyaWdnZXIsIHVzZUFuaW1hdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFByeVNuYWNrTWVzc2FnZSB9IGZyb20gJy4uL3NuYWNrLmludGVyZmFjZSc7XG5cbmNvbnN0IHNob3dBbmltYXRpb24gPSBhbmltYXRpb24oW3N0eWxlKHsgdHJhbnNmb3JtOiAne3t0cmFuc2Zvcm19fScsIG9wYWNpdHk6IDAgfSksIGFuaW1hdGUoJ3t7dHJhbnNpdGlvbn19JyldKTtcblxuY29uc3QgaGlkZUFuaW1hdGlvbiA9IGFuaW1hdGlvbihbYW5pbWF0ZSgne3t0cmFuc2l0aW9ufX0nKSwgc3R5bGUoeyB0cmFuc2Zvcm06ICd7e3RyYW5zZm9ybX19Jywgb3BhY2l0eTogMCB9KV0pO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcnktc25hY2tiYXInLFxuICB0ZW1wbGF0ZVVybDogJy4vc25hY2tiYXIuY29tcG9uZW50Lmh0bWwnLFxuICBhbmltYXRpb25zOiBbXG4gICAgdHJpZ2dlcigncGFuZWxTdGF0ZScsIFtcbiAgICAgIHRyYW5zaXRpb24oJ3ZvaWQgPT4gdmlzaWJsZScsIFt1c2VBbmltYXRpb24oc2hvd0FuaW1hdGlvbildKSxcbiAgICAgIHRyYW5zaXRpb24oJ3Zpc2libGUgPT4gdm9pZCcsIFt1c2VBbmltYXRpb24oaGlkZUFuaW1hdGlvbildKVxuICAgIF0pXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgUHJ5U25hY2tiYXJDb21wb25lbnQge1xuICBjb250YWluZXI6IGFueTtcbiAgX2RhdGEgPSB7IG1lc3NhZ2U6ICcnLCBhY3Rpb246IHVuZGVmaW5lZCwgdHlwZTogJ2luZm8nLCB0aW1lb3V0OiAzMDAwIH0gYXMgUHJ5U25hY2tNZXNzYWdlO1xuICBASW5wdXQoKSBzZXQgZGF0YShtZXNzYWdlOiBQcnlTbmFja01lc3NhZ2UpIHtcbiAgICB0aGlzLl9kYXRhID0gbWVzc2FnZTtcbiAgICB0aGlzLmNkUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIEBJbnB1dCgpIGxpc3RJbmRleCA9IDA7XG4gIEBJbnB1dCgpIGFjdGlvbkNsaWNrZWQhOiBTdWJqZWN0PHZvaWQ+O1xuICB0cmFuc2Zvcm1PcHRpb25zID0gJ3RyYW5zbGF0ZTNkKC01MCUsIDEwMCUsIDBweCknO1xuICB0cmFuc2l0aW9uT3B0aW9ucyA9ICcxNTBtcyBjdWJpYy1iZXppZXIoMCwgMCwgMC4yLCAxKSc7XG4gIGhpZGRlbkZyb21BY3Rpb24gPSBmYWxzZTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNkUmVmOiBDaGFuZ2VEZXRlY3RvclJlZikge31cblxuICBnZXQgZGF0YSgpIHtcbiAgICByZXR1cm4gdGhpcy5fZGF0YTtcbiAgfVxuXG4gIGdldCB0eXBlQ2xhc3MoKSB7XG4gICAgcmV0dXJuIHsgWyctJyArIHRoaXMuZGF0YS50eXBlXTogdHJ1ZSB9O1xuICB9XG5cbiAgZ2V0IGljb24oKTogc3RyaW5nIHtcbiAgICBjb25zdCBpY29uc0RlZnMgPSB7XG4gICAgICBpbmZvOiAnaW5mb3JtYXRpb24tcG9pbnQnLFxuICAgICAgc3VjY2VzczogJ2NoZWNrJyxcbiAgICAgIHdhcm5pbmc6ICd3YXJuaW5nJyxcbiAgICAgIGVycm9yOiAnY2xvc2UnXG4gICAgfTtcbiAgICByZXR1cm4gaWNvbnNEZWZzW3RoaXMuZGF0YS50eXBlXTtcbiAgfVxuXG4gIGFjdGlvbkNsaWNrKCkge1xuICAgIHRoaXMuYWN0aW9uQ2xpY2tlZC5uZXh0KCk7XG4gIH1cblxuICBoaWRlKCkge1xuICAgIHRoaXMuaGlkZGVuRnJvbUFjdGlvbiA9IHRydWU7XG4gIH1cbn1cbiIsIkBpZiAoIWhpZGRlbkZyb21BY3Rpb24pIHtcbiAgPGRpdlxuICAgIGNsYXNzPVwibS1zbmFja2JhciAtYm90dG9tXCJcbiAgICBbbmdDbGFzc109XCJ0eXBlQ2xhc3NcIlxuICAgIFtAcGFuZWxTdGF0ZV09XCJ7IHZhbHVlOiAndmlzaWJsZScsIHBhcmFtczogeyB0cmFuc2Zvcm06IHRyYW5zZm9ybU9wdGlvbnMsIHRyYW5zaXRpb246IHRyYW5zaXRpb25PcHRpb25zIH0gfVwiXG4gICAgW3N0eWxlLmJvdHRvbS5weF09XCJsaXN0SW5kZXggKiA2MFwiXG4gICAgPlxuICAgIDxkaXYgY2xhc3M9XCJtLXNuYWNrYmFyX19jb250ZW50XCI+XG4gICAgICA8cHJ5LWljb24gW2ljb25TdmddPVwiaWNvblwiPjwvcHJ5LWljb24+XG4gICAgICA8cCBjbGFzcz1cImEtcFwiPnt7IGRhdGEubWVzc2FnZSB9fTwvcD5cbiAgICAgIEBpZiAoISFkYXRhLmFjdGlvbikge1xuICAgICAgICA8YnV0dG9uIGNsYXNzPVwibS1zbmFja2Jhcl9fYWN0aW9uXCIgKGNsaWNrKT1cImFjdGlvbkNsaWNrKClcIj57eyBkYXRhLmFjdGlvbiB9fTwvYnV0dG9uPlxuICAgICAgfVxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbn1cbiJdfQ==
@@ -17,7 +17,6 @@ export class PrySnackbarService {
17
17
  this.overlay = overlay;
18
18
  this.translate = translate;
19
19
  this.messageEvents$ = new Subject();
20
- this.notifRef = [];
21
20
  // Allows to access snackbar from javascript, for example to manage Vega errors
22
21
  document.addEventListener(PRY_CUSTOMEVENT_TYPE, (e) => {
23
22
  const pryMessage = e.detail;
@@ -35,63 +34,26 @@ export class PrySnackbarService {
35
34
  dispatchOpenEvent(message) {
36
35
  document.dispatchEvent(new CustomEvent(PRY_CUSTOMEVENT_TYPE, { detail: message }));
37
36
  }
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
- }
49
37
  notMitigatedOpen(message) {
50
- const overlayRef = this.overlay.create(new OverlayConfig({
38
+ this.overlayRef = this.overlay.create(new OverlayConfig({
51
39
  hasBackdrop: false
52
40
  }));
53
41
  const componentPortal = new ComponentPortal(PrySnackbarComponent, this.rootViewContainer);
54
- const component = overlayRef.attach(componentPortal);
42
+ const component = this.overlayRef.attach(componentPortal);
55
43
  component.instance.data = message;
44
+ component.instance.listIndex = PrySnackbarService.count++;
56
45
  component.instance.actionClicked = new Subject();
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
- }
46
+ setTimeout(() => {
47
+ /* First hide component so it uses animation */
48
+ component.instance.hiddenFromAction = true;
49
+ PrySnackbarService.count--;
75
50
  setTimeout(() => {
51
+ /* then clean by removing it */
76
52
  component.instance.actionClicked.complete();
77
- overlayRef?.dispose();
53
+ this.overlayRef?.dispose();
78
54
  component.destroy();
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
- }
55
+ }, DELAY_FOR_HIDE);
56
+ }, message.timeout ?? DEFAULT_MSG_TIMEOUT);
95
57
  return component.instance.actionClicked;
96
58
  }
97
59
  open(message) {
@@ -106,4 +68,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
106
68
  providedIn: 'root'
107
69
  }]
108
70
  }], ctorParameters: () => [{ type: i1.Overlay }, { type: i2.PryI18nService }] });
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"]}
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hY2tiYXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9jb3JlL2NvbXBvbmVudHMvc25hY2tiYXIvc25hY2tiYXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVcsYUFBYSxFQUFjLE1BQU0sc0JBQXNCLENBQUM7QUFDMUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxVQUFVLEVBQW9CLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sS0FBSyxNQUFNLHFCQUFxQixDQUFDO0FBQ3hDLE9BQU8sRUFBYyxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNsRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFHNUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sK0JBQStCLENBQUM7Ozs7QUFFckUsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsSUFBSSxDQUFDO0FBQ3hDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxHQUFHLENBQUM7QUFFbEMsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsWUFBWSxDQUFDO0FBS2pELE1BQU0sT0FBTyxrQkFBa0I7YUFFdEIsVUFBSyxHQUFHLENBQUMsQUFBSixDQUFLO0lBTWpCLFlBQ1UsT0FBZ0IsRUFDaEIsU0FBeUI7UUFEekIsWUFBTyxHQUFQLE9BQU8sQ0FBUztRQUNoQixjQUFTLEdBQVQsU0FBUyxDQUFnQjtRQUozQixtQkFBYyxHQUFHLElBQUksT0FBTyxFQUFtQixDQUFDO1FBTXRELCtFQUErRTtRQUMvRSxRQUFRLENBQUMsZ0JBQWdCLENBQ3ZCLG9CQUFvQixFQUNwQixDQUFDLENBQVEsRUFBRSxFQUFFO1lBQ1gsTUFBTSxVQUFVLEdB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QWxCLGtCQUFrQixjQUZqQixNQUFNOzsyRkFFUCxrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3ZlcmxheSwgT3ZlcmxheUNvbmZpZywgT3ZlcmxheVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IENvbXBvbmVudFBvcnRhbCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IGVxdWFsIGZyb20gJ2Zhc3QtZGVlcC1lcXVhbC9lczYnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCwgc3dpdGNoTWFwLCB3aW5kb3dUaW1lIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBkaXN0aW5jdFVudGlsQ2hhbmdlZCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgUHJ5STE4blNlcnZpY2UgfSBmcm9tICcuLi8uLi9pMThuL2kxOG4uc2VydmljZSc7XG5pbXBvcnQgeyBQcnlTbmFja01lc3NhZ2UgfSBmcm9tICcuL3NuYWNrLmludGVyZmFjZSc7XG5pbXBvcnQgeyBQcnlTbmFja2JhckNvbXBvbmVudCB9IGZyb20gJy4vc25hY2tiYXIvc25hY2tiYXIuY29tcG9uZW50JztcblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfTVNHX1RJTUVPVVQgPSAzMDAwO1xuZXhwb3J0IGNvbnN0IERFTEFZX0ZPUl9ISURFID0gMjAwO1xuXG5leHBvcnQgY29uc3QgUFJZX0NVU1RPTUVWRU5UX1RZUEUgPSAnQHByeS5zbmFjayc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFByeVNuYWNrYmFyU2VydmljZSB7XG4gIHJvb3RWaWV3Q29udGFpbmVyPzogVmlld0NvbnRhaW5lclJlZjtcbiAgc3RhdGljIGNvdW50ID0gMDtcblxuICBwcml2YXRlIG92ZXJsYXlSZWY/OiBPdmVybGF5UmVmO1xuXG4gIHByaXZhdGUgbWVzc2FnZUV2ZW50cyQgPSBuZXcgU3ViamVjdDxQcnlTbmFja01lc3NhZ2U+KCk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBvdmVybGF5OiBPdmVybGF5LFxuICAgIHByaXZhdGUgdHJhbnNsYXRlOiBQcnlJMThuU2VydmljZVxuICApIHtcbiAgICAvLyBBbGxvd3MgdG8gYWNjZXNzIHNuYWNrYmFyIGZyb20gamF2YXNjcmlwdCwgZm9yIGV4YW1wbGUgdG8gbWFuYWdlIFZlZ2EgZXJyb3JzXG4gICAgZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcihcbiAgICAgIFBSWV9DVVNUT01FVkVOVF9UWVBFLFxuICAgICAgKGU6IEV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IHByeU1lc3NhZ2UgPSAoZSBhcyBDdXN0b21FdmVudDxQcnlTbmFja01lc3NhZ2U+KS5kZXRhaWw7XG4gICAgICAgIHByeU1lc3NhZ2UubWVzc2FnZSA9IHRoaXMudHJhbnNsYXRlLmluc3RhbnQocHJ5TWVzc2FnZS5tZXNzYWdlKTtcbiAgICAgICAgcHJ5TWVzc2FnZS5hY3Rpb24gPSAhIXByeU1lc3NhZ2UuYWN0aW9uID8gdGhpcy50cmFuc2xhdGUuaW5zdGFudChwcnlNZXNzYWdlLmFjdGlvbikgOiB1bmRlZmluZWQ7XG4gICAgICAgIHRoaXMubWVzc2FnZUV2ZW50cyQubmV4dChwcnlNZXNzYWdlKTtcbiAgICAgIH0sXG4gICAgICBmYWxzZVxuICAgICk7XG5cbiAgICB0aGlzLm1lc3NhZ2VFdmVudHMkXG4gICAgICAucGlwZShcbiAgICAgICAgd2luZG93VGltZSgxMDAwKSxcbiAgICAgICAgc3dpdGNoTWFwKChzb3VyY2UpID0+IHNvdXJjZS5waXBlKGRpc3RpbmN0VW50aWxDaGFuZ2VkKChwLCB2KSA9PiBlcXVhbChwLCB2KSkpKVxuICAgICAgKVxuICAgICAgLnN1YnNjcmliZSgobWVzc2FnZSkgPT4gdGhpcy5ub3RNaXRpZ2F0ZWRPcGVuKG1lc3NhZ2UpKTtcbiAgfVxuXG4gIHNldFJvb3RWaWV3Q29udGFpbmVyUmVmKHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHtcbiAgICB0aGlzLnJvb3RWaWV3Q29udGFpbmVyID0gdmlld0NvbnRhaW5lclJlZjtcbiAgfVxuXG4gIGRpc3BhdGNoT3BlbkV2ZW50KG1lc3NhZ2U6IFByeVNuYWNrTWVzc2FnZSkge1xuICAgIGRvY3VtZW50LmRpc3BhdGNoRXZlbnQobmV3IEN1c3RvbUV2ZW50KFBSWV9DVVNUT01FVkVOVF9UWVBFLCB7IGRldGFpbDogbWVzc2FnZSB9KSk7XG4gIH1cblxuICBub3RNaXRpZ2F0ZWRPcGVuKG1lc3NhZ2U6IFByeVNuYWNrTWVzc2FnZSk6IE9ic2VydmFibGU8dm9pZD4gfCBudWxsIHtcbiAgICB0aGlzLm92ZXJsYXlSZWYgPSB0aGlzLm92ZXJsYXkuY3JlYXRlKFxuICAgICAgbmV3IE92ZXJsYXlDb25maWcoe1xuICAgICAgICBoYXNCYWNrZHJvcDogZmFsc2VcbiAgICAgIH0pXG4gICAgKTtcbiAgICBjb25zdCBjb21wb25lbnRQb3J0YWwgPSBuZXcgQ29tcG9uZW50UG9ydGFsKFByeVNuYWNrYmFyQ29tcG9uZW50LCB0aGlzLnJvb3RWaWV3Q29udGFpbmVyKTtcbiAgICBjb25zdCBjb21wb25lbnQgPSB0aGlzLm92ZXJsYXlSZWYuYXR0YWNoKGNvbXBvbmVudFBvcnRhbCk7XG5cbiAgICBjb21wb25lbnQuaW5zdGFuY2UuZGF0YSA9IG1lc3NhZ2U7XG4gICAgY29tcG9uZW50Lmluc3RhbmNlLmxpc3RJbmRleCA9IFByeVNuYWNrYmFyU2VydmljZS5jb3VudCsrO1xuICAgIGNvbXBvbmVudC5pbnN0YW5jZS5hY3Rpb25DbGlja2VkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgLyogRmlyc3QgaGlkZSBjb21wb25lbnQgc28gaXQgdXNlcyBhbmltYXRpb24gKi9cbiAgICAgIGNvbXBvbmVudC5pbnN0YW5jZS5oaWRkZW5Gcm9tQWN0aW9uID0gdHJ1ZTtcbiAgICAgIFByeVNuYWNrYmFyU2VydmljZS5jb3VudC0tO1xuXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgLyogdGhlbiBjbGVhbiBieSByZW1vdmluZyBpdCAqL1xuICAgICAgICBjb21wb25lbnQuaW5zdGFuY2UuYWN0aW9uQ2xpY2tlZC5jb21wbGV0ZSgpO1xuICAgICAgICB0aGlzLm92ZXJsYXlSZWY/LmRpc3Bvc2UoKTtcbiAgICAgICAgY29tcG9uZW50LmRlc3Ryb3koKTtcbiAgICAgIH0sIERFTEFZX0ZPUl9ISURFKTtcbiAgICB9LCBtZXNzYWdlLnRpbWVvdXQgPz8gREVGQVVMVF9NU0dfVElNRU9VVCk7XG5cbiAgICByZXR1cm4gY29tcG9uZW50Lmluc3RhbmNlLmFjdGlvbkNsaWNrZWQ7XG4gIH1cblxuICBvcGVuKG1lc3NhZ2U6IFByeVNuYWNrTWVzc2FnZSkge1xuICAgIHRoaXMubWVzc2FnZUV2ZW50cyQubmV4dChtZXNzYWdlKTtcbiAgfVxufVxuIl19
@@ -2705,25 +2705,13 @@ class PrySnackbarComponent {
2705
2705
  this._data = message;
2706
2706
  this.cdRef.detectChanges();
2707
2707
  }
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) {
2708
+ constructor(cdRef) {
2718
2709
  this.cdRef = cdRef;
2719
- this.snackService = snackService;
2720
- this.router = router;
2721
2710
  this._data = { message: '', action: undefined, type: 'info', timeout: 3000 };
2711
+ this.listIndex = 0;
2722
2712
  this.transformOptions = 'translate3d(-50%, 100%, 0px)';
2723
2713
  this.transitionOptions = '150ms cubic-bezier(0, 0, 0.2, 1)';
2724
2714
  this.hiddenFromAction = false;
2725
- this._listIndex = 0;
2726
- this.snackStyle = { top: '' };
2727
2715
  }
2728
2716
  get data() {
2729
2717
  return this._data;
@@ -2731,25 +2719,12 @@ class PrySnackbarComponent {
2731
2719
  get typeClass() {
2732
2720
  return { ['-' + this.data.type]: true };
2733
2721
  }
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
- }
2746
2722
  get icon() {
2747
2723
  const iconsDefs = {
2748
2724
  info: 'information-point',
2749
2725
  success: 'check',
2750
2726
  warning: 'warning',
2751
- error: 'close',
2752
- notif: 'information-point'
2727
+ error: 'close'
2753
2728
  };
2754
2729
  return iconsDefs[this.data.type];
2755
2730
  }
@@ -2759,15 +2734,8 @@ class PrySnackbarComponent {
2759
2734
  hide() {
2760
2735
  this.hiddenFromAction = true;
2761
2736
  }
2762
- openEvenement(data) {
2763
- this.snackService.closeNotif(data);
2764
- window.open(data.link, '_blank');
2765
- }
2766
- closeNotif(data) {
2767
- this.snackService.closeNotif(data);
2768
- }
2769
- 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 }); }
2770
- 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: [
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: [
2771
2739
  trigger('panelState', [
2772
2740
  transition('void => visible', [useAnimation(showAnimation)]),
2773
2741
  transition('visible => void', [useAnimation(hideAnimation)])
@@ -2781,13 +2749,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
2781
2749
  transition('void => visible', [useAnimation(showAnimation)]),
2782
2750
  transition('visible => void', [useAnimation(hideAnimation)])
2783
2751
  ])
2784
- ], 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" }]
2785
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: PrySnackbarService }, { type: i2.Router }], propDecorators: { data: [{
2786
- type: Input
2787
- }], actionClicked: [{
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: [{
2788
2754
  type: Input
2789
2755
  }], listIndex: [{
2790
2756
  type: Input
2757
+ }], actionClicked: [{
2758
+ type: Input
2791
2759
  }] } });
2792
2760
 
2793
2761
  const DEFAULT_MSG_TIMEOUT = 3000;
@@ -2799,7 +2767,6 @@ class PrySnackbarService {
2799
2767
  this.overlay = overlay;
2800
2768
  this.translate = translate;
2801
2769
  this.messageEvents$ = new Subject();
2802
- this.notifRef = [];
2803
2770
  // Allows to access snackbar from javascript, for example to manage Vega errors
2804
2771
  document.addEventListener(PRY_CUSTOMEVENT_TYPE, (e) => {
2805
2772
  const pryMessage = e.detail;
@@ -2817,63 +2784,26 @@ class PrySnackbarService {
2817
2784
  dispatchOpenEvent(message) {
2818
2785
  document.dispatchEvent(new CustomEvent(PRY_CUSTOMEVENT_TYPE, { detail: message }));
2819
2786
  }
2820
- closeNotif(message) {
2821
- const notifIndex = this.notifRef.findIndex((notif) => notif.componentRef.instance.data.id === message.id);
2822
- const elementToRemove = this.notifRef.splice(notifIndex, 1).shift();
2823
- elementToRemove.componentRef.instance.hiddenFromAction = true;
2824
- elementToRemove.componentRef.instance.actionClicked.complete();
2825
- elementToRemove.overlayRef.dispose();
2826
- elementToRemove.componentRef.destroy();
2827
- this.notifRef.forEach((notifRef, index) => {
2828
- notifRef.componentRef.instance.listIndex = index;
2829
- });
2830
- }
2831
2787
  notMitigatedOpen(message) {
2832
- const overlayRef = this.overlay.create(new OverlayConfig({
2788
+ this.overlayRef = this.overlay.create(new OverlayConfig({
2833
2789
  hasBackdrop: false
2834
2790
  }));
2835
2791
  const componentPortal = new ComponentPortal(PrySnackbarComponent, this.rootViewContainer);
2836
- const component = overlayRef.attach(componentPortal);
2792
+ const component = this.overlayRef.attach(componentPortal);
2837
2793
  component.instance.data = message;
2794
+ component.instance.listIndex = PrySnackbarService.count++;
2838
2795
  component.instance.actionClicked = new Subject();
2839
- if (message.type === 'notif') {
2840
- if (this.notifRef.length < 5) {
2841
- this.notifRef.unshift({ componentRef: component, overlayRef });
2842
- this.notifRef.forEach((notifRef, index) => {
2843
- notifRef.componentRef.instance.listIndex = index;
2844
- });
2845
- }
2846
- else if (this.notifRef.length === 5) {
2847
- const olderComponent = this.notifRef.pop();
2848
- olderComponent.componentRef.instance.hiddenFromAction = true;
2849
- olderComponent.componentRef.instance.actionClicked.complete();
2850
- olderComponent.overlayRef.dispose();
2851
- olderComponent.componentRef.destroy();
2852
- this.notifRef.unshift({ componentRef: component, overlayRef });
2853
- this.notifRef.forEach((notifRef, index) => {
2854
- notifRef.componentRef.instance.listIndex = index;
2855
- });
2856
- }
2796
+ setTimeout(() => {
2797
+ /* First hide component so it uses animation */
2798
+ component.instance.hiddenFromAction = true;
2799
+ PrySnackbarService.count--;
2857
2800
  setTimeout(() => {
2801
+ /* then clean by removing it */
2858
2802
  component.instance.actionClicked.complete();
2859
- overlayRef?.dispose();
2803
+ this.overlayRef?.dispose();
2860
2804
  component.destroy();
2861
- }, 10000);
2862
- }
2863
- else {
2864
- component.instance.listIndex = PrySnackbarService.count++;
2865
- setTimeout(() => {
2866
- /* First hide component so it uses animation */
2867
- component.instance.hiddenFromAction = true;
2868
- PrySnackbarService.count--;
2869
- setTimeout(() => {
2870
- /* then clean by removing it */
2871
- component.instance.actionClicked.complete();
2872
- overlayRef?.dispose();
2873
- component.destroy();
2874
- }, DELAY_FOR_HIDE);
2875
- }, message.timeout ?? DEFAULT_MSG_TIMEOUT);
2876
- }
2805
+ }, DELAY_FOR_HIDE);
2806
+ }, message.timeout ?? DEFAULT_MSG_TIMEOUT);
2877
2807
  return component.instance.actionClicked;
2878
2808
  }
2879
2809
  open(message) {