@provoly/hypervisor 0.0.15 → 0.0.17

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.
Files changed (34) hide show
  1. package/assets/svgs/event_filter.svg +5 -0
  2. package/assets/svgs/reset_filter_event.svg +13 -0
  3. package/esm2022/src/lib/event/detail/event-detail.component.mjs +49 -5
  4. package/esm2022/src/lib/event/filters/choice/choice-filter.component.mjs +118 -12
  5. package/esm2022/src/lib/event/filters/event-filters.component.mjs +6 -6
  6. package/esm2022/src/lib/event/list/event-list.component.mjs +20 -4
  7. package/esm2022/src/lib/event-summary/list/event-summary-list.component.mjs +3 -3
  8. package/esm2022/src/lib/event-summary/page/event-summary-page.component.mjs +11 -7
  9. package/esm2022/src/lib/general/i18n/en.translations.mjs +16 -3
  10. package/esm2022/src/lib/general/i18n/fr.translations.mjs +19 -12
  11. package/esm2022/src/lib/hypervisor.module.mjs +11 -3
  12. package/esm2022/src/lib/model/event/hyp-event-category.type.mjs +6 -4
  13. package/esm2022/src/lib/store/event/event.actions.mjs +1 -2
  14. package/esm2022/src/lib/store/event/event.effects.mjs +2 -2
  15. package/esm2022/src/lib/store/event/event.reducer.mjs +6 -4
  16. package/esm2022/src/lib/store/event/event.service.mjs +2 -2
  17. package/fesm2022/provoly-hypervisor.mjs +267 -69
  18. package/fesm2022/provoly-hypervisor.mjs.map +1 -1
  19. package/package.json +1 -1
  20. package/src/lib/event/detail/event-detail.component.d.ts +14 -0
  21. package/src/lib/event/filters/choice/choice-filter.component.d.ts +38 -4
  22. package/src/lib/event/list/event-list.component.d.ts +4 -0
  23. package/src/lib/event-summary/page/event-summary-page.component.d.ts +11 -3
  24. package/src/lib/general/i18n/en.translations.d.ts +15 -2
  25. package/src/lib/general/i18n/fr.translations.d.ts +7 -0
  26. package/src/lib/hypervisor.module.d.ts +1 -1
  27. package/src/lib/model/event/hyp-event-category.type.d.ts +3 -1
  28. package/src/lib/store/event/event.actions.d.ts +0 -6
  29. package/styles/components/_m-hvy-event-summary-item.scss +2 -0
  30. package/styles/components/_o-hvy-event-detail.scss +11 -4
  31. package/styles/components/_o-hvy-event-filters.scss +65 -0
  32. package/styles/components/_o-hvy-event-summary-list.scss +32 -19
  33. package/styles/components/_o-hvy-event-summary-page.scss +9 -5
  34. package/styles/components/_o-hvy-events-table.scss +17 -3
@@ -1,35 +1,141 @@
1
- import { Component, forwardRef, Input } from '@angular/core';
1
+ import { Component, computed, forwardRef, Input, signal, TemplateRef, ViewChild, } from '@angular/core';
2
2
  import { HvyUnitFilterComponent } from '../hvy-unit-filter.class';
3
3
  import { EventSelectors } from '../../../store/event/event.selectors';
4
+ import { OverlayConfig } from '@angular/cdk/overlay';
5
+ import { TemplatePortal } from '@angular/cdk/portal';
4
6
  import * as i0 from "@angular/core";
5
7
  import * as i1 from "@ngrx/store";
6
- import * as i2 from "@angular/common";
8
+ import * as i2 from "@angular/cdk/overlay";
9
+ import * as i3 from "@provoly/dashboard";
10
+ import * as i4 from "@provoly/dashboard/components/checkbox";
11
+ import * as i5 from "@angular/forms";
7
12
  export class ChoiceFilterComponent extends HvyUnitFilterComponent {
8
- constructor(store) {
13
+ static { this.idCounter = 0; }
14
+ constructor(store, overlay, viewContainerRef, i18nService, ref) {
9
15
  super();
10
16
  this.store = store;
17
+ this.overlay = overlay;
18
+ this.viewContainerRef = viewContainerRef;
19
+ this.i18nService = i18nService;
20
+ this.ref = ref;
21
+ this.id = -1;
11
22
  this.prop = 'no-prop-defined';
12
- this.value = [];
23
+ this.label = 'no-label-defined';
24
+ this.i18nPrefix = 'no-prefix-defined.';
25
+ this.value = signal([]);
13
26
  this.choices = [];
27
+ this.inhibate = false;
28
+ this.displayValue = computed(() => {
29
+ if (this.allSelected()) {
30
+ return this.i18nService.instant('@hvy.event.filter.choice.all');
31
+ }
32
+ if (this.value().length > 1) {
33
+ return `(${this.value().length})`;
34
+ }
35
+ if (this.value().length === 1) {
36
+ return this.i18nService.instant(this.i18nPrefix + this.value()[0]);
37
+ }
38
+ return '';
39
+ });
40
+ this.id = ChoiceFilterComponent.idCounter++;
41
+ }
42
+ ngAfterViewInit() {
14
43
  this.subscriptions.add(this.store.select(EventSelectors.filters).subscribe(filters => {
15
- this.value = filters[this.prop] ?? [];
44
+ this.assignValue(filters.hasOwnProperty(this.prop) ?
45
+ filters[this.prop].length === 1 && filters[this.prop][0] === '' ? [] : filters[this.prop] : this.allValues());
16
46
  }));
17
47
  }
18
48
  getParams() {
19
- return { [this.prop]: this.value };
49
+ if (this.value().length === this.allValues().length) {
50
+ return {};
51
+ }
52
+ return { [this.prop]: this.value().length === 0 ? [''] : this.value() };
20
53
  }
21
54
  reset() {
22
- this.value = [];
55
+ this.assignValue([]);
56
+ }
57
+ toggleModal() {
58
+ if (!this.overlayRef) {
59
+ this.triggerInhibate();
60
+ this.overlayRef = this.overlay.create(new OverlayConfig({
61
+ hasBackdrop: true,
62
+ backdropClass: 'backdrop',
63
+ panelClass: ['m-context-menu-wrapper', 'o-choice-filter-popup'],
64
+ }));
65
+ this.overlayRef.backdropClick().subscribe(() => this.toggleModal());
66
+ this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));
67
+ const contextMenu = document.querySelector('.o-choice-filter-popup');
68
+ if (!!contextMenu) {
69
+ const rect = this.ref.nativeElement.getBoundingClientRect();
70
+ contextMenu.style.left = rect.x + 'px';
71
+ contextMenu.style.top = rect.bottom + 'px';
72
+ }
73
+ }
74
+ else {
75
+ this.overlayRef.dispose();
76
+ this.overlayRef = undefined;
77
+ }
78
+ }
79
+ clickAll() {
80
+ if (this.allSelected()) {
81
+ this.assignValue([]);
82
+ }
83
+ else {
84
+ this.assignValue(this.allValues());
85
+ }
86
+ }
87
+ toggle(elt) {
88
+ const isSelected = this.isSelected(elt);
89
+ const eltSubKeys = !elt.children ? [elt.key] : elt.children.map(ch => ch.key);
90
+ if (!isSelected) {
91
+ this.assignValue([...new Set([...this.value(), ...eltSubKeys])]);
92
+ }
93
+ else {
94
+ this.assignValue(this.value().filter(v => !eltSubKeys.includes(v)));
95
+ }
96
+ }
97
+ allSelected() {
98
+ return this.choices.map(choice => this.isSelected(choice)).reduce((p, c) => p && c, true);
99
+ }
100
+ isSelected(choice) {
101
+ if (!choice.children) {
102
+ return this.value().includes(choice.key);
103
+ }
104
+ else {
105
+ return choice.children.map(child => this.isSelected(child)).reduce((p, c) => p && c, true);
106
+ }
23
107
  }
24
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: ChoiceFilterComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
25
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: ChoiceFilterComponent, selector: "hvy-choice-filter", inputs: { prop: "prop", choices: "choices" }, providers: [{ provide: HvyUnitFilterComponent, useExisting: forwardRef(() => ChoiceFilterComponent) }], usesInheritance: true, ngImport: i0, template: "<div class=\"o-hvy-choice-filters\">\n CHOICE: {{ value | json }}\n</div>\n", dependencies: [{ kind: "pipe", type: i2.JsonPipe, name: "json" }] }); }
108
+ allValues() {
109
+ return this.choices
110
+ .map(choice => !choice.children ? [choice.key] : choice.children.map(child => child.key))
111
+ .reduce((p, c) => [...p, ...c], []);
112
+ }
113
+ assignValue(value) {
114
+ if (!this.inhibate) {
115
+ this.triggerInhibate();
116
+ this.value.set(value);
117
+ }
118
+ }
119
+ triggerInhibate() {
120
+ this.inhibate = true;
121
+ setTimeout(() => this.inhibate = false, 50);
122
+ }
123
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: ChoiceFilterComponent, deps: [{ token: i1.Store }, { token: i2.Overlay }, { token: i0.ViewContainerRef }, { token: i3.PryI18nService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
124
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: ChoiceFilterComponent, selector: "hvy-choice-filter", inputs: { prop: "prop", label: "label", i18nPrefix: "i18nPrefix", choices: "choices" }, providers: [{ provide: HvyUnitFilterComponent, useExisting: forwardRef(() => ChoiceFilterComponent) }], viewQueries: [{ propertyName: "template", first: true, predicate: ["template"], descendants: true, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "<button (click)=\"toggleModal()\" #button class=\"o-hvy-choice-filter -horizontal\"\n [class.-highlight]=\"displayValue() !== ('@hvy.event.filter.choice.all' | i18n)\" [class.-focus]=\"overlayRef\">\n <span class=\"o-hvy-choice-filter__label\">{{ label | i18n }}:</span>\n <span class=\"o-hvy-choice-filter__value\" type=\"text\" id=\"select_{{id}}\">{{ displayValue() }}</span>\n <pry-icon [iconSvg]=\"!!overlayRef ? 'chevron_top' : 'chevron_bottom'\" [width]=\"10\" [height]=\"10\"></pry-icon>\n</button>\n\n<ng-template #template>\n <div\n class=\"m-context-menu o-hvy-choice-filter\"\n aria-labelledby=\"manage-account\"\n tabindex=\"-1\"\n id=\"account-menu\"\n role=\"menu\"\n aria-modal=\"true\"\n >\n <div class=\"o-hvy-choice-filter__all\">\n <pry-checkbox [ngModel]=\"allSelected()\" (ngModelChange)=\"clickAll()\">\n <span>{{ '@hvy.event.filter.choice.all' | i18n }}</span>\n </pry-checkbox>\n </div>\n @for (elt of choices;track elt.key) {\n @if (!elt.children) {\n <pry-checkbox [ngModel]=\"isSelected(elt)\" (ngModelChange)=\"toggle(elt)\" class=\"o-hvy-choice-filter__root\">\n <span>{{ i18nPrefix + elt.key | i18n }}</span>\n </pry-checkbox>\n } @else {\n <pry-checkbox [ngModel]=\"isSelected(elt)\" (ngModelChange)=\"toggle(elt)\" class=\"o-hvy-choice-filter__root\">\n <span>{{ i18nPrefix + elt.key | i18n }}</span>\n </pry-checkbox>\n @for (child of elt.children;track child.key) {\n <pry-checkbox [ngModel]=\"isSelected(child)\" (ngModelChange)=\"toggle(child)\"\n class=\"o-hvy-choice-filter__child\">\n <span>{{ i18nPrefix + child.key | i18n }}</span>\n </pry-checkbox>\n }\n }\n }\n </div>\n</ng-template>\n", dependencies: [{ kind: "component", type: i4.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }] }); }
26
125
  }
27
126
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: ChoiceFilterComponent, decorators: [{
28
127
  type: Component,
29
- args: [{ selector: 'hvy-choice-filter', providers: [{ provide: HvyUnitFilterComponent, useExisting: forwardRef(() => ChoiceFilterComponent) }], template: "<div class=\"o-hvy-choice-filters\">\n CHOICE: {{ value | json }}\n</div>\n" }]
30
- }], ctorParameters: () => [{ type: i1.Store }], propDecorators: { prop: [{
128
+ args: [{ selector: 'hvy-choice-filter', providers: [{ provide: HvyUnitFilterComponent, useExisting: forwardRef(() => ChoiceFilterComponent) }], template: "<button (click)=\"toggleModal()\" #button class=\"o-hvy-choice-filter -horizontal\"\n [class.-highlight]=\"displayValue() !== ('@hvy.event.filter.choice.all' | i18n)\" [class.-focus]=\"overlayRef\">\n <span class=\"o-hvy-choice-filter__label\">{{ label | i18n }}:</span>\n <span class=\"o-hvy-choice-filter__value\" type=\"text\" id=\"select_{{id}}\">{{ displayValue() }}</span>\n <pry-icon [iconSvg]=\"!!overlayRef ? 'chevron_top' : 'chevron_bottom'\" [width]=\"10\" [height]=\"10\"></pry-icon>\n</button>\n\n<ng-template #template>\n <div\n class=\"m-context-menu o-hvy-choice-filter\"\n aria-labelledby=\"manage-account\"\n tabindex=\"-1\"\n id=\"account-menu\"\n role=\"menu\"\n aria-modal=\"true\"\n >\n <div class=\"o-hvy-choice-filter__all\">\n <pry-checkbox [ngModel]=\"allSelected()\" (ngModelChange)=\"clickAll()\">\n <span>{{ '@hvy.event.filter.choice.all' | i18n }}</span>\n </pry-checkbox>\n </div>\n @for (elt of choices;track elt.key) {\n @if (!elt.children) {\n <pry-checkbox [ngModel]=\"isSelected(elt)\" (ngModelChange)=\"toggle(elt)\" class=\"o-hvy-choice-filter__root\">\n <span>{{ i18nPrefix + elt.key | i18n }}</span>\n </pry-checkbox>\n } @else {\n <pry-checkbox [ngModel]=\"isSelected(elt)\" (ngModelChange)=\"toggle(elt)\" class=\"o-hvy-choice-filter__root\">\n <span>{{ i18nPrefix + elt.key | i18n }}</span>\n </pry-checkbox>\n @for (child of elt.children;track child.key) {\n <pry-checkbox [ngModel]=\"isSelected(child)\" (ngModelChange)=\"toggle(child)\"\n class=\"o-hvy-choice-filter__child\">\n <span>{{ i18nPrefix + child.key | i18n }}</span>\n </pry-checkbox>\n }\n }\n }\n </div>\n</ng-template>\n" }]
129
+ }], ctorParameters: () => [{ type: i1.Store }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i3.PryI18nService }, { type: i0.ElementRef }], propDecorators: { prop: [{
130
+ type: Input
131
+ }], label: [{
132
+ type: Input
133
+ }], i18nPrefix: [{
31
134
  type: Input
32
135
  }], choices: [{
33
136
  type: Input
137
+ }], template: [{
138
+ type: ViewChild,
139
+ args: ['template', { read: TemplateRef }]
34
140
  }] } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvaWNlLWZpbHRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2h5cGVydmlzb3Ivc3JjL2xpYi9ldmVudC9maWx0ZXJzL2Nob2ljZS9jaG9pY2UtZmlsdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvaHlwZXJ2aXNvci9zcmMvbGliL2V2ZW50L2ZpbHRlcnMvY2hvaWNlL2Nob2ljZS1maWx0ZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBbUIsc0JBQXNCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUVuRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0NBQXNDLENBQUM7Ozs7QUFZdEUsTUFBTSxPQUFPLHFCQUFzQixTQUFRLHNCQUFzQjtJQUsvRCxZQUFvQixLQUFZO1FBQzlCLEtBQUssRUFBRSxDQUFDO1FBRFUsVUFBSyxHQUFMLEtBQUssQ0FBTztRQUp2QixTQUFJLEdBQVcsaUJBQWlCLENBQUM7UUFDMUMsVUFBSyxHQUFhLEVBQUUsQ0FBQztRQUNaLFlBQU8sR0FBb0IsRUFBRSxDQUFDO1FBSXJDLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDbkYsSUFBSSxDQUFDLEtBQUssR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN4QyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ04sQ0FBQztJQUVRLFNBQVM7UUFDaEIsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNyQyxDQUFDO0lBRVEsS0FBSztRQUNaLElBQUksQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDO0lBQ2xCLENBQUM7OEdBbEJVLHFCQUFxQjtrR0FBckIscUJBQXFCLDBGQUZyQixDQUFDLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMscUJBQXFCLENBQUMsRUFBRSxDQUFDLGlEQ2J4Ryw4RUFHQTs7MkZEWWEscUJBQXFCO2tCQUxqQyxTQUFTOytCQUNFLG1CQUFtQixhQUVsQixDQUFDLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLHNCQUFzQixDQUFDLEVBQUUsQ0FBQzswRUFHN0YsSUFBSTtzQkFBWixLQUFLO2dCQUVHLE9BQU87c0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEh2eUZpbHRlclBhcmFtcywgSHZ5VW5pdEZpbHRlckNvbXBvbmVudCB9IGZyb20gJy4uL2h2eS11bml0LWZpbHRlci5jbGFzcyc7XG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IEV2ZW50U2VsZWN0b3JzIH0gZnJvbSAnLi4vLi4vLi4vc3RvcmUvZXZlbnQvZXZlbnQuc2VsZWN0b3JzJztcblxuZXhwb3J0IHR5cGUgSHZ5Q2hvaWNlRmlsdGVyID0ge1xuICBrZXk6IHN0cmluZztcbiAgY2hpbGRyZW4/OiB7IGtleTogc3RyaW5nIH1bXVxufVtdO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdodnktY2hvaWNlLWZpbHRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9pY2UtZmlsdGVyLmNvbXBvbmVudC5odG1sJyxcbiAgcHJvdmlkZXJzOiBbeyBwcm92aWRlOiBIdnlVbml0RmlsdGVyQ29tcG9uZW50LCB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBDaG9pY2VGaWx0ZXJDb21wb25lbnQpIH1dLFxufSlcbmV4cG9ydCBjbGFzcyBDaG9pY2VGaWx0ZXJDb21wb25lbnQgZXh0ZW5kcyBIdnlVbml0RmlsdGVyQ29tcG9uZW50IHtcbiAgQElucHV0KCkgcHJvcDogc3RyaW5nID0gJ25vLXByb3AtZGVmaW5lZCc7XG4gIHZhbHVlOiBzdHJpbmdbXSA9IFtdO1xuICBASW5wdXQoKSBjaG9pY2VzOiBIdnlDaG9pY2VGaWx0ZXIgPSBbXTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHN0b3JlOiBTdG9yZSkge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5zdWJzY3JpcHRpb25zLmFkZCh0aGlzLnN0b3JlLnNlbGVjdChFdmVudFNlbGVjdG9ycy5maWx0ZXJzKS5zdWJzY3JpYmUoZmlsdGVycyA9PiB7XG4gICAgICB0aGlzLnZhbHVlID0gZmlsdGVyc1t0aGlzLnByb3BdID8/IFtdO1xuICAgIH0pKTtcbiAgfVxuXG4gIG92ZXJyaWRlIGdldFBhcmFtcygpOiBIdnlGaWx0ZXJQYXJhbXMge1xuICAgIHJldHVybiB7IFt0aGlzLnByb3BdOiB0aGlzLnZhbHVlIH07XG4gIH1cblxuICBvdmVycmlkZSByZXNldCgpOiB2b2lkIHtcbiAgICB0aGlzLnZhbHVlID0gW107XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJvLWh2eS1jaG9pY2UtZmlsdGVyc1wiPlxuICBDSE9JQ0U6IHt7IHZhbHVlIHwganNvbiB9fVxuPC9kaXY+XG4iXX0=
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"choice-filter.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/hypervisor/src/lib/event/filters/choice/choice-filter.component.ts","../../../../../../../../../projects/provoly/hypervisor/src/lib/event/filters/choice/choice-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  computed,\n  ElementRef,\n  forwardRef,\n  Input,\n  signal,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  WritableSignal,\n} from '@angular/core';\nimport { HvyFilterParams, HvyUnitFilterComponent } from '../hvy-unit-filter.class';\nimport { Store } from '@ngrx/store';\nimport { EventSelectors } from '../../../store/event/event.selectors';\nimport { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { PryI18nService } from '@provoly/dashboard';\n\nexport type HvyChoiceFilter = {\n  key: string;\n  children?: { key: string }[]\n}[];\n\n@Component({\n  selector: 'hvy-choice-filter',\n  templateUrl: './choice-filter.component.html',\n  providers: [{ provide: HvyUnitFilterComponent, useExisting: forwardRef(() => ChoiceFilterComponent) }],\n})\nexport class ChoiceFilterComponent extends HvyUnitFilterComponent implements AfterViewInit {\n  static idCounter = 0;\n  id = -1;\n  @Input() prop: string = 'no-prop-defined';\n  @Input() label: string = 'no-label-defined';\n  @Input() i18nPrefix: string = 'no-prefix-defined.';\n  value: WritableSignal<string[]> = signal([]);\n  @Input() choices: HvyChoiceFilter = [];\n  overlayRef?: OverlayRef;\n  @ViewChild('template', { read: TemplateRef }) template!: TemplateRef<any>;\n  inhibate = false;\n  displayValue = computed(() => {\n    if (this.allSelected()) {\n      return this.i18nService.instant('@hvy.event.filter.choice.all');\n    }\n    if (this.value().length > 1) {\n      return `(${this.value().length})`;\n    }\n    if (this.value().length === 1) {\n      return this.i18nService.instant(this.i18nPrefix + this.value()[0]);\n    }\n    return '';\n  });\n\n  constructor(private store: Store, private overlay: Overlay, private viewContainerRef: ViewContainerRef, private i18nService: PryI18nService, private ref: ElementRef) {\n    super();\n    this.id = ChoiceFilterComponent.idCounter++;\n  }\n\n  ngAfterViewInit(): void {\n    this.subscriptions.add(this.store.select(EventSelectors.filters).subscribe(filters => {\n      this.assignValue(filters.hasOwnProperty(this.prop) ?\n        filters[this.prop].length === 1 && filters[this.prop][0] === '' ? [] : filters[this.prop] : this.allValues());\n    }));\n  }\n\n  override getParams(): HvyFilterParams {\n    if (this.value().length === this.allValues().length) {\n      return {};\n    }\n    return { [this.prop]: this.value().length === 0 ? [''] : this.value() };\n  }\n\n  override reset(): void {\n    this.assignValue([]);\n  }\n\n  toggleModal() {\n    if (!this.overlayRef) {\n      this.triggerInhibate();\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          backdropClass: 'backdrop',\n          panelClass: ['m-context-menu-wrapper', 'o-choice-filter-popup'],\n        }),\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModal());\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      const contextMenu = document.querySelector('.o-choice-filter-popup') as HTMLDivElement;\n      if (!!contextMenu) {\n        const rect = this.ref.nativeElement.getBoundingClientRect();\n        contextMenu.style.left = rect.x + 'px';\n        contextMenu.style.top = rect.bottom + 'px';\n      }\n    } else {\n      this.overlayRef.dispose();\n      this.overlayRef = undefined;\n    }\n  }\n\n  clickAll() {\n    if (this.allSelected()) {\n      this.assignValue([]);\n    } else {\n      this.assignValue(this.allValues());\n    }\n  }\n\n  toggle(elt: { key: string; children?: { key: string }[] }) {\n    const isSelected = this.isSelected(elt);\n    const eltSubKeys = !elt.children ? [elt.key] : elt.children.map(ch => ch.key);\n    if (!isSelected) {\n      this.assignValue([...new Set([...this.value(), ...eltSubKeys])]);\n    } else {\n      this.assignValue(this.value().filter(v => !eltSubKeys.includes(v)));\n    }\n  }\n\n  allSelected() {\n    return this.choices.map(choice => this.isSelected(choice)).reduce((p, c) => p && c, true);\n  }\n\n  isSelected(choice: { key: string; children?: { key: string }[] }): boolean {\n    if (!choice.children) {\n      return this.value().includes(choice.key);\n    } else {\n      return choice.children.map(child => this.isSelected(child)).reduce((p, c) => p && c, true);\n    }\n  }\n\n  allValues() {\n    return this.choices\n      .map(choice => !choice.children ? [choice.key] : choice.children.map(child => child.key))\n      .reduce((p, c) => [...p, ...c], []);\n  }\n\n  assignValue(value: string[]) {\n    if (!this.inhibate) {\n      this.triggerInhibate();\n      this.value.set(value);\n    }\n  }\n\n  private triggerInhibate() {\n    this.inhibate = true;\n    setTimeout(() => this.inhibate = false, 50);\n  }\n}\n","<button (click)=\"toggleModal()\" #button class=\"o-hvy-choice-filter -horizontal\"\n        [class.-highlight]=\"displayValue() !== ('@hvy.event.filter.choice.all' | i18n)\" [class.-focus]=\"overlayRef\">\n  <span class=\"o-hvy-choice-filter__label\">{{ label | i18n }}:</span>\n  <span class=\"o-hvy-choice-filter__value\" type=\"text\" id=\"select_{{id}}\">{{ displayValue() }}</span>\n  <pry-icon [iconSvg]=\"!!overlayRef ? 'chevron_top' : 'chevron_bottom'\" [width]=\"10\" [height]=\"10\"></pry-icon>\n</button>\n\n<ng-template #template>\n  <div\n    class=\"m-context-menu o-hvy-choice-filter\"\n    aria-labelledby=\"manage-account\"\n    tabindex=\"-1\"\n    id=\"account-menu\"\n    role=\"menu\"\n    aria-modal=\"true\"\n  >\n    <div class=\"o-hvy-choice-filter__all\">\n      <pry-checkbox [ngModel]=\"allSelected()\" (ngModelChange)=\"clickAll()\">\n        <span>{{ '@hvy.event.filter.choice.all' | i18n }}</span>\n      </pry-checkbox>\n    </div>\n    @for (elt of choices;track elt.key) {\n      @if (!elt.children) {\n        <pry-checkbox [ngModel]=\"isSelected(elt)\" (ngModelChange)=\"toggle(elt)\" class=\"o-hvy-choice-filter__root\">\n          <span>{{ i18nPrefix + elt.key | i18n }}</span>\n        </pry-checkbox>\n      } @else {\n        <pry-checkbox [ngModel]=\"isSelected(elt)\" (ngModelChange)=\"toggle(elt)\" class=\"o-hvy-choice-filter__root\">\n          <span>{{ i18nPrefix + elt.key | i18n }}</span>\n        </pry-checkbox>\n        @for (child of elt.children;track child.key) {\n          <pry-checkbox [ngModel]=\"isSelected(child)\" (ngModelChange)=\"toggle(child)\"\n                        class=\"o-hvy-choice-filter__child\">\n            <span>{{ i18nPrefix + child.key | i18n }}</span>\n          </pry-checkbox>\n        }\n      }\n    }\n  </div>\n</ng-template>\n"]}
@@ -12,20 +12,20 @@ export class EventFiltersComponent extends SubscriptionnerDirective {
12
12
  filter() {
13
13
  const filters = this.filters.map(filter => filter.getParams())
14
14
  .reduce((p, c) => ({ ...p, ...c }), {});
15
- this.store.dispatch(EventActions.setFilters({ filters }));
15
+ this.store.dispatch(EventActions.filter({ filters }));
16
16
  }
17
17
  reset() {
18
18
  this.filters.forEach(filter => filter.reset());
19
- this.store.dispatch(EventActions.setFilters({ filters: {} }));
19
+ this.store.dispatch(EventActions.filter({ filters: {} }));
20
20
  }
21
21
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventFiltersComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
22
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: EventFiltersComponent, selector: "hvy-event-filters", queries: [{ propertyName: "filters", predicate: ["filter"] }], usesInheritance: true, ngImport: i0, template: "<div class=\"o-hvy-event-filters\">\n <ng-content></ng-content>\n <div class=\"o-hvy-event-filters__buttons\">\n <button (click)=\"reset()\">\n <pry-icon iconSvg=\"reset\"></pry-icon>\n RESET\n </button>\n <button (click)=\"filter()\">\n <pry-icon iconSvg=\"filter\"></pry-icon>\n FILTRER\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }] }); }
22
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: EventFiltersComponent, selector: "hvy-event-filters", queries: [{ propertyName: "filters", predicate: ["filter"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"o-hvy-event-filters\">\n <ng-content></ng-content>\n <div class=\"o-hvy-event-filters__buttons\">\n <button (click)=\"reset()\" class=\"a-btn a-btn--secondary\">\n <pry-icon iconSvg=\"reset_filter_event\"></pry-icon>\n </button>\n <button (click)=\"filter()\" class=\"a-btn a-btn--primary\">\n {{ '@hvy.event.filter.name' | i18n }}\n <pry-icon iconSvg=\"event_filter\"></pry-icon>\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i2.I18nPipe, name: "i18n" }] }); }
23
23
  }
24
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventFiltersComponent, decorators: [{
25
25
  type: Component,
26
- args: [{ selector: 'hvy-event-filters', template: "<div class=\"o-hvy-event-filters\">\n <ng-content></ng-content>\n <div class=\"o-hvy-event-filters__buttons\">\n <button (click)=\"reset()\">\n <pry-icon iconSvg=\"reset\"></pry-icon>\n RESET\n </button>\n <button (click)=\"filter()\">\n <pry-icon iconSvg=\"filter\"></pry-icon>\n FILTRER\n </button>\n </div>\n</div>\n" }]
26
+ args: [{ selector: 'hvy-event-filters', template: "<div class=\"o-hvy-event-filters\">\n <ng-content></ng-content>\n <div class=\"o-hvy-event-filters__buttons\">\n <button (click)=\"reset()\" class=\"a-btn a-btn--secondary\">\n <pry-icon iconSvg=\"reset_filter_event\"></pry-icon>\n </button>\n <button (click)=\"filter()\" class=\"a-btn a-btn--primary\">\n {{ '@hvy.event.filter.name' | i18n }}\n <pry-icon iconSvg=\"event_filter\"></pry-icon>\n </button>\n </div>\n</div>\n" }]
27
27
  }], ctorParameters: () => [{ type: i1.Store }], propDecorators: { filters: [{
28
28
  type: ContentChildren,
29
- args: ['filter']
29
+ args: ['filter', { descendants: true }]
30
30
  }] } });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtZmlsdGVycy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2h5cGVydmlzb3Ivc3JjL2xpYi9ldmVudC9maWx0ZXJzL2V2ZW50LWZpbHRlcnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQvZmlsdGVycy9ldmVudC1maWx0ZXJzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3RFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7OztBQU0vRCxNQUFNLE9BQU8scUJBQXNCLFNBQVEsd0JBQXdCO0lBSWpFLFlBQW9CLEtBQVk7UUFDOUIsS0FBSyxFQUFFLENBQUM7UUFEVSxVQUFLLEdBQUwsS0FBSyxDQUFPO0lBRWhDLENBQUM7SUFFRCxNQUFNO1FBQ0osTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7YUFDM0QsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUMvQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNoRSxDQUFDOzhHQWpCVSxxQkFBcUI7a0dBQXJCLHFCQUFxQiwrSUNWbEMsb1dBYUE7OzJGREhhLHFCQUFxQjtrQkFKakMsU0FBUzsrQkFDRSxtQkFBbUI7MEVBS0YsT0FBTztzQkFBakMsZUFBZTt1QkFBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDb250ZW50Q2hpbGRyZW4sIFF1ZXJ5TGlzdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9ubmVyRGlyZWN0aXZlIH0gZnJvbSAnQHByb3ZvbHkvZGFzaGJvYXJkJztcbmltcG9ydCB7IEh2eVVuaXRGaWx0ZXJDb21wb25lbnQgfSBmcm9tICcuL2h2eS11bml0LWZpbHRlci5jbGFzcyc7XG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IEV2ZW50QWN0aW9ucyB9IGZyb20gJy4uLy4uL3N0b3JlL2V2ZW50L2V2ZW50LmFjdGlvbnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdodnktZXZlbnQtZmlsdGVycycsXG4gIHRlbXBsYXRlVXJsOiAnLi9ldmVudC1maWx0ZXJzLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgRXZlbnRGaWx0ZXJzQ29tcG9uZW50IGV4dGVuZHMgU3Vic2NyaXB0aW9ubmVyRGlyZWN0aXZlIHtcblxuICBAQ29udGVudENoaWxkcmVuKCdmaWx0ZXInKSBmaWx0ZXJzITogUXVlcnlMaXN0PEh2eVVuaXRGaWx0ZXJDb21wb25lbnQ+O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc3RvcmU6IFN0b3JlKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuXG4gIGZpbHRlcigpIHtcbiAgICBjb25zdCBmaWx0ZXJzID0gdGhpcy5maWx0ZXJzLm1hcChmaWx0ZXIgPT4gZmlsdGVyLmdldFBhcmFtcygpKVxuICAgICAgLnJlZHVjZSgocCwgYykgPT4gKHsgLi4ucCwgLi4uYyB9KSwge30pO1xuICAgIHRoaXMuc3RvcmUuZGlzcGF0Y2goRXZlbnRBY3Rpb25zLnNldEZpbHRlcnMoeyBmaWx0ZXJzIH0pKTtcbiAgfVxuXG4gIHJlc2V0KCkge1xuICAgIHRoaXMuZmlsdGVycy5mb3JFYWNoKGZpbHRlciA9PiBmaWx0ZXIucmVzZXQoKSk7XG4gICAgdGhpcy5zdG9yZS5kaXNwYXRjaChFdmVudEFjdGlvbnMuc2V0RmlsdGVycyh7IGZpbHRlcnM6IHt9IH0pKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LWZpbHRlcnNcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8ZGl2IGNsYXNzPVwiby1odnktZXZlbnQtZmlsdGVyc19fYnV0dG9uc1wiPlxuICAgIDxidXR0b24gKGNsaWNrKT1cInJlc2V0KClcIj5cbiAgICAgIDxwcnktaWNvbiBpY29uU3ZnPVwicmVzZXRcIj48L3ByeS1pY29uPlxuICAgICAgUkVTRVRcbiAgICA8L2J1dHRvbj5cbiAgICA8YnV0dG9uIChjbGljayk9XCJmaWx0ZXIoKVwiPlxuICAgICAgPHByeS1pY29uIGljb25Tdmc9XCJmaWx0ZXJcIj48L3ByeS1pY29uPlxuICAgICAgRklMVFJFUlxuICAgIDwvYnV0dG9uPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtZmlsdGVycy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2h5cGVydmlzb3Ivc3JjL2xpYi9ldmVudC9maWx0ZXJzL2V2ZW50LWZpbHRlcnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQvZmlsdGVycy9ldmVudC1maWx0ZXJzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3RFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRzlELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7OztBQU0vRCxNQUFNLE9BQU8scUJBQXNCLFNBQVEsd0JBQXdCO0lBSWpFLFlBQW9CLEtBQVk7UUFDOUIsS0FBSyxFQUFFLENBQUM7UUFEVSxVQUFLLEdBQUwsS0FBSyxDQUFPO0lBRWhDLENBQUM7SUFFRCxNQUFNO1FBQ0osTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7YUFDM0QsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ3hELENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUMvQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM1RCxDQUFDOzhHQWpCVSxxQkFBcUI7a0dBQXJCLHFCQUFxQixrS0NWbEMsd2NBWUE7OzJGREZhLHFCQUFxQjtrQkFKakMsU0FBUzsrQkFDRSxtQkFBbUI7MEVBS3FCLE9BQU87c0JBQXhELGVBQWU7dUJBQUMsUUFBUSxFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkcmVuLCBRdWVyeUxpc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbm5lckRpcmVjdGl2ZSB9IGZyb20gJ0Bwcm92b2x5L2Rhc2hib2FyZCc7XG5pbXBvcnQgeyBIdnlVbml0RmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi9odnktdW5pdC1maWx0ZXIuY2xhc3MnO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQgeyBFdmVudEFjdGlvbnMgfSBmcm9tICcuLi8uLi9zdG9yZS9ldmVudC9ldmVudC5hY3Rpb25zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaHZ5LWV2ZW50LWZpbHRlcnMnLFxuICB0ZW1wbGF0ZVVybDogJy4vZXZlbnQtZmlsdGVycy5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIEV2ZW50RmlsdGVyc0NvbXBvbmVudCBleHRlbmRzIFN1YnNjcmlwdGlvbm5lckRpcmVjdGl2ZSB7XG5cbiAgQENvbnRlbnRDaGlsZHJlbignZmlsdGVyJywgeyBkZXNjZW5kYW50czogdHJ1ZSB9KSBmaWx0ZXJzITogUXVlcnlMaXN0PEh2eVVuaXRGaWx0ZXJDb21wb25lbnQ+O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc3RvcmU6IFN0b3JlKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuXG4gIGZpbHRlcigpIHtcbiAgICBjb25zdCBmaWx0ZXJzID0gdGhpcy5maWx0ZXJzLm1hcChmaWx0ZXIgPT4gZmlsdGVyLmdldFBhcmFtcygpKVxuICAgICAgLnJlZHVjZSgocCwgYykgPT4gKHsgLi4ucCwgLi4uYyB9KSwge30pO1xuICAgIHRoaXMuc3RvcmUuZGlzcGF0Y2goRXZlbnRBY3Rpb25zLmZpbHRlcih7IGZpbHRlcnMgfSkpO1xuICB9XG5cbiAgcmVzZXQoKSB7XG4gICAgdGhpcy5maWx0ZXJzLmZvckVhY2goZmlsdGVyID0+IGZpbHRlci5yZXNldCgpKTtcbiAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKEV2ZW50QWN0aW9ucy5maWx0ZXIoeyBmaWx0ZXJzOiB7fSB9KSk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1maWx0ZXJzXCI+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LWZpbHRlcnNfX2J1dHRvbnNcIj5cbiAgICA8YnV0dG9uIChjbGljayk9XCJyZXNldCgpXCIgY2xhc3M9XCJhLWJ0biBhLWJ0bi0tc2Vjb25kYXJ5XCI+XG4gICAgICA8cHJ5LWljb24gaWNvblN2Zz1cInJlc2V0X2ZpbHRlcl9ldmVudFwiPjwvcHJ5LWljb24+XG4gICAgPC9idXR0b24+XG4gICAgPGJ1dHRvbiAoY2xpY2spPVwiZmlsdGVyKClcIiBjbGFzcz1cImEtYnRuIGEtYnRuLS1wcmltYXJ5XCI+XG4gICAgICB7eyAnQGh2eS5ldmVudC5maWx0ZXIubmFtZScgfCBpMThuIH19XG4gICAgICA8cHJ5LWljb24gaWNvblN2Zz1cImV2ZW50X2ZpbHRlclwiPjwvcHJ5LWljb24+XG4gICAgPC9idXR0b24+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -1,7 +1,7 @@
1
1
  import { Component } from '@angular/core';
2
2
  import { EventActions } from '../../store/event/event.actions';
3
3
  import { EventSelectors } from '../../store/event/event.selectors';
4
- import { auditTime, filter, fromEvent, map, withLatestFrom } from 'rxjs';
4
+ import { auditTime, combineLatest, filter, fromEvent, map, withLatestFrom } from 'rxjs';
5
5
  import { SubscriptionnerDirective } from '@provoly/dashboard';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@ngrx/store";
@@ -24,9 +24,11 @@ export class EventListComponent extends SubscriptionnerDirective {
24
24
  this.el = el;
25
25
  this.EVENT_LINK = EVENT_LINK;
26
26
  this._store = this.store;
27
+ this._inhibate = false;
27
28
  this.store.dispatch(EventActions.load({}));
28
29
  this.events$ = this.store.select(EventSelectors.events);
29
30
  this.selectedIds$ = this.store.select(EventSelectors.selectedIds);
31
+ this.allSelected$ = combineLatest([this.events$, this.selectedIds$]).pipe(map(([events, selectedIds]) => events.filter(ev => !selectedIds.includes(ev.id)).length === 0));
30
32
  }
31
33
  ngAfterViewInit() {
32
34
  this.subscriptions.add(fromEvent(this.el.nativeElement, 'scroll')
@@ -40,15 +42,29 @@ export class EventListComponent extends SubscriptionnerDirective {
40
42
  }));
41
43
  }
42
44
  select(event, $event) {
45
+ this.inhibate();
43
46
  this.store.dispatch(EventActions.select({ ids: [event.id], cumulative: true }));
44
47
  $event.preventDefault();
45
48
  $event.stopPropagation();
46
49
  }
50
+ selectAll($event) {
51
+ if (!this._inhibate) {
52
+ this.inhibate();
53
+ const tmpSub = this.events$.subscribe(events => {
54
+ this.store.dispatch(EventActions.select({ ids: $event ? events.map(ev => ev.id) : [], cumulative: false }));
55
+ setTimeout(() => tmpSub.unsubscribe(), 10);
56
+ });
57
+ }
58
+ }
59
+ inhibate() {
60
+ this._inhibate = true;
61
+ setTimeout(() => this._inhibate = false, 100);
62
+ }
47
63
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventListComponent, deps: [{ token: i1.Store }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
48
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: EventListComponent, selector: "hvy-event-list", usesInheritance: true, ngImport: i0, template: "<table class=\"o-hvy-events-table\">\n <thead>\n <tr class=\"o-hvy-events-table__header\">\n <th></th>\n <th>{{ '@hvy.event.criticality.name' | i18n }}</th>\n <th>{{ '@hvy.event.name' | i18n }}</th>\n <th>{{ '@hvy.event.category.name' | i18n }}</th>\n <th>{{ '@hvy.event.address' | i18n }}</th>\n <th>\n <hvy-column-order field=\"creationDate\">{{ '@hvy.event.creationDate' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"lastModificationDate\">{{ '@hvy.event.lastModificationDate' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"name\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"progress\">{{ '@hvy.procedure.progress' | i18n }}</hvy-column-order>\n </th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (event of events$|async;track event.id) {\n <tr class=\"o-hvy-events-table__line\" (click)=\"select(event, $event)\">\n <td class=\"o-hvy-events-table__line__cell\">\n <pry-checkbox [ngModel]=\"(selectedIds$|async)!.includes(event.id)\"></pry-checkbox>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n <hvy-icon-display [event]=\"event\"></hvy-icon-display>\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <div class=\"o-hvy-events-table__line__cell__name__main\">{{ event.name }}</div>\n <div\n class=\"o-hvy-events-table__line__cell__name__sub\">{{ event.equipment?.name ? event.equipment?.name : '' }}\n </div>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">{{ '@hvy.event.category.' + event.category | i18n }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.address }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.creationDate| sinceDate: { onlyLocale: true } }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.lastModificationDate | sinceDate: { onlyLocale: true } }}\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n <hvy-status-display [event]=\"event\"></hvy-status-display>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n {{ event.procedureProgress }} %\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <a [routerLink]=\"EVENT_LINK.fn(event, _store)\">\n > {{ '@hvy.action.consult' | i18n }} @if (event.linkedEvents > 1) {\n ({{ event.linkedEvents }})\n }\n </a>\n </td>\n </tr>\n } @empty {\n <tr>\n <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n <div>{{ '@hvy.event.log.empty' | i18n }}</div>\n <div>\n <ng-content></ng-content>\n </div>\n </td>\n </tr>\n }\n </tbody>\n</table>\n", dependencies: [{ kind: "component", type: i2.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i5.IconDisplayComponent, selector: "hvy-icon-display", inputs: ["event"] }, { kind: "component", type: i6.StatusDisplayComponent, selector: "hvy-status-display", inputs: ["event", "modifiable"], outputs: ["modified"] }, { kind: "component", type: i7.ColumnOrderComponent, selector: "hvy-column-order", inputs: ["field"] }, { kind: "pipe", type: i8.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.I18nPipe, name: "i18n" }, { kind: "pipe", type: i10.PrySinceDatePipe, name: "sinceDate" }] }); }
64
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: EventListComponent, selector: "hvy-event-list", usesInheritance: true, ngImport: i0, template: "<table class=\"o-hvy-events-table\">\n <thead>\n <tr class=\"o-hvy-events-table__header\">\n <th>\n <pry-checkbox [ngModel]=\"allSelected$|async\" (ngModelChange)=\"selectAll($event)\"></pry-checkbox>\n </th>\n <th>{{ '@hvy.event.criticality.name' | i18n }}</th>\n <th>{{ '@hvy.event.name' | i18n }}</th>\n <th>{{ '@hvy.event.category.name' | i18n }}</th>\n <th>{{ '@hvy.event.address' | i18n }}</th>\n <th>\n <hvy-column-order field=\"creationDate\">{{ '@hvy.event.creationDate' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"lastModificationDate\">{{ '@hvy.event.lastModificationDate' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"name\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"progress\">{{ '@hvy.procedure.progress' | i18n }}</hvy-column-order>\n </th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (event of events$|async;track event.id) {\n <tr class=\"o-hvy-events-table__line\" (click)=\"select(event, $event)\">\n <td class=\"o-hvy-events-table__line__cell\">\n <pry-checkbox [ngModel]=\"(selectedIds$|async)!.includes(event.id)\"></pry-checkbox>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n <hvy-icon-display [event]=\"event\"></hvy-icon-display>\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <div class=\"o-hvy-events-table__line__cell__name__main\">{{ event.name }}</div>\n <div\n class=\"o-hvy-events-table__line__cell__name__sub\">{{ event.equipment?.name ? event.equipment?.name : '' }}\n </div>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">{{ '@hvy.event.category.' + event.category | i18n }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.address }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.creationDate| sinceDate: { onlyLocale: true } }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.lastModificationDate | sinceDate: { onlyLocale: true } }}\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n <hvy-status-display [event]=\"event\"></hvy-status-display>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n {{ event.procedureProgress }} %\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <a [routerLink]=\"EVENT_LINK.fn(event, _store)\">\n > {{ '@hvy.action.consult' | i18n }} @if (event.linkedEvents > 1) {\n ({{ event.linkedEvents }})\n }\n </a>\n </td>\n </tr>\n } @empty {\n <tr>\n <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n <div>{{ '@hvy.event.log.empty' | i18n }}</div>\n <div>\n <ng-content></ng-content>\n </div>\n </td>\n </tr>\n }\n </tbody>\n</table>\n", dependencies: [{ kind: "component", type: i2.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i5.IconDisplayComponent, selector: "hvy-icon-display", inputs: ["event"] }, { kind: "component", type: i6.StatusDisplayComponent, selector: "hvy-status-display", inputs: ["event", "modifiable"], outputs: ["modified"] }, { kind: "component", type: i7.ColumnOrderComponent, selector: "hvy-column-order", inputs: ["field"] }, { kind: "pipe", type: i8.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.I18nPipe, name: "i18n" }, { kind: "pipe", type: i10.PrySinceDatePipe, name: "sinceDate" }] }); }
49
65
  }
50
66
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventListComponent, decorators: [{
51
67
  type: Component,
52
- args: [{ selector: 'hvy-event-list', template: "<table class=\"o-hvy-events-table\">\n <thead>\n <tr class=\"o-hvy-events-table__header\">\n <th></th>\n <th>{{ '@hvy.event.criticality.name' | i18n }}</th>\n <th>{{ '@hvy.event.name' | i18n }}</th>\n <th>{{ '@hvy.event.category.name' | i18n }}</th>\n <th>{{ '@hvy.event.address' | i18n }}</th>\n <th>\n <hvy-column-order field=\"creationDate\">{{ '@hvy.event.creationDate' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"lastModificationDate\">{{ '@hvy.event.lastModificationDate' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"name\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"progress\">{{ '@hvy.procedure.progress' | i18n }}</hvy-column-order>\n </th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (event of events$|async;track event.id) {\n <tr class=\"o-hvy-events-table__line\" (click)=\"select(event, $event)\">\n <td class=\"o-hvy-events-table__line__cell\">\n <pry-checkbox [ngModel]=\"(selectedIds$|async)!.includes(event.id)\"></pry-checkbox>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n <hvy-icon-display [event]=\"event\"></hvy-icon-display>\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <div class=\"o-hvy-events-table__line__cell__name__main\">{{ event.name }}</div>\n <div\n class=\"o-hvy-events-table__line__cell__name__sub\">{{ event.equipment?.name ? event.equipment?.name : '' }}\n </div>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">{{ '@hvy.event.category.' + event.category | i18n }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.address }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.creationDate| sinceDate: { onlyLocale: true } }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.lastModificationDate | sinceDate: { onlyLocale: true } }}\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n <hvy-status-display [event]=\"event\"></hvy-status-display>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n {{ event.procedureProgress }} %\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <a [routerLink]=\"EVENT_LINK.fn(event, _store)\">\n > {{ '@hvy.action.consult' | i18n }} @if (event.linkedEvents > 1) {\n ({{ event.linkedEvents }})\n }\n </a>\n </td>\n </tr>\n } @empty {\n <tr>\n <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n <div>{{ '@hvy.event.log.empty' | i18n }}</div>\n <div>\n <ng-content></ng-content>\n </div>\n </td>\n </tr>\n }\n </tbody>\n</table>\n" }]
68
+ args: [{ selector: 'hvy-event-list', template: "<table class=\"o-hvy-events-table\">\n <thead>\n <tr class=\"o-hvy-events-table__header\">\n <th>\n <pry-checkbox [ngModel]=\"allSelected$|async\" (ngModelChange)=\"selectAll($event)\"></pry-checkbox>\n </th>\n <th>{{ '@hvy.event.criticality.name' | i18n }}</th>\n <th>{{ '@hvy.event.name' | i18n }}</th>\n <th>{{ '@hvy.event.category.name' | i18n }}</th>\n <th>{{ '@hvy.event.address' | i18n }}</th>\n <th>\n <hvy-column-order field=\"creationDate\">{{ '@hvy.event.creationDate' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"lastModificationDate\">{{ '@hvy.event.lastModificationDate' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"name\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"progress\">{{ '@hvy.procedure.progress' | i18n }}</hvy-column-order>\n </th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (event of events$|async;track event.id) {\n <tr class=\"o-hvy-events-table__line\" (click)=\"select(event, $event)\">\n <td class=\"o-hvy-events-table__line__cell\">\n <pry-checkbox [ngModel]=\"(selectedIds$|async)!.includes(event.id)\"></pry-checkbox>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n <hvy-icon-display [event]=\"event\"></hvy-icon-display>\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <div class=\"o-hvy-events-table__line__cell__name__main\">{{ event.name }}</div>\n <div\n class=\"o-hvy-events-table__line__cell__name__sub\">{{ event.equipment?.name ? event.equipment?.name : '' }}\n </div>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">{{ '@hvy.event.category.' + event.category | i18n }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.address }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.creationDate| sinceDate: { onlyLocale: true } }}</td>\n <td class=\"o-hvy-events-table__line__cell\">{{ event.lastModificationDate | sinceDate: { onlyLocale: true } }}\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n <hvy-status-display [event]=\"event\"></hvy-status-display>\n </td>\n <td class=\"o-hvy-events-table__line__cell -centered\">\n {{ event.procedureProgress }} %\n </td>\n <td class=\"o-hvy-events-table__line__cell\">\n <a [routerLink]=\"EVENT_LINK.fn(event, _store)\">\n > {{ '@hvy.action.consult' | i18n }} @if (event.linkedEvents > 1) {\n ({{ event.linkedEvents }})\n }\n </a>\n </td>\n </tr>\n } @empty {\n <tr>\n <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n <div>{{ '@hvy.event.log.empty' | i18n }}</div>\n <div>\n <ng-content></ng-content>\n </div>\n </td>\n </tr>\n }\n </tbody>\n</table>\n" }]
53
69
  }], ctorParameters: () => [{ type: i1.Store }, { type: i0.ElementRef }] });
54
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/event/list/event-list.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/event/list/event-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAc,MAAM,eAAe,CAAC;AAErE,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,EAAc,cAAc,EAAE,MAAM,MAAM,CAAC;AACrF,OAAO,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAC;;;;;;;;;;;;AAI9D,MAAM,CAAC,MAAM,UAAU,GAAG;IACxB,EAAE,EAAE,CAAC,KAAwC,EAAE,KAAiB,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC;CACtF,CAAC;AAMF,MAAM,OAAO,kBAAmB,SAAQ,wBAAwB;IAM9D,YAAoB,KAAiB,EAAU,EAAc;QAC3D,KAAK,EAAE,CAAC;QADU,UAAK,GAAL,KAAK,CAAY;QAAU,OAAE,GAAF,EAAE,CAAY;QAH7D,eAAU,GAAG,UAAU,CAAC;QACxB,WAAM,GAAG,IAAI,CAAC,KAAK,CAAC;QAIlB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QACxD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IACpE,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,QAAQ,CAAC;aACvC,IAAI;QACH,sBAAsB;QACtB,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE;YACb,MAAM,MAAM,GAAG,CAAC,CAAC,aAAa,CAAC;YAC/B,OAAO,MAAM,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,GAAG,MAAM,CAAC,SAAS,CAAC;QACtE,CAAC,CAAC,EACF,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,EAC9D,MAAM,CAAC,CAAC,CAAC,cAAc,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,IAAI,cAAc,GAAG,GAAG,CAAC,EACrE,SAAS,CAAC,GAAG,CAAC,CACf,CAAC,SAAS,CAAC,GAAG,EAAE;YACjB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC,CAAC;IACR,CAAC;IAED,MAAM,CAAC,KAAsB,EAAE,MAAkB;QAC/C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAChF,MAAM,CAAC,cAAc,EAAE,CAAC;QACxB,MAAM,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;8GAlCU,kBAAkB;kGAAlB,kBAAkB,6ECjB/B,63FAqEA;;2FDpDa,kBAAkB;kBAJ9B,SAAS;+BACE,gBAAgB","sourcesContent":["import { AfterViewInit, Component, ElementRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { EventActions } from '../../store/event/event.actions';\nimport { EventSelectors } from '../../store/event/event.selectors';\nimport { auditTime, filter, fromEvent, map, Observable, withLatestFrom } from 'rxjs';\nimport { SubscriptionnerDirective } from '@provoly/dashboard';\nimport { HypEventDetails } from '../../model/event/hyp-event-detail.interface';\nimport { HypEventSummary } from '../../model/event/hyp-event-summary.interface';\n\nexport const EVENT_LINK = {\n  fn: (event: HypEventDetails | HypEventSummary, store: Store<any>) => ['./', event.id],\n};\n\n@Component({\n  selector: 'hvy-event-list',\n  templateUrl: './event-list.component.html',\n})\nexport class EventListComponent extends SubscriptionnerDirective implements AfterViewInit {\n  events$: Observable<HypEventDetails[]>;\n  selectedIds$: Observable<string[]>;\n  EVENT_LINK = EVENT_LINK;\n  _store = this.store;\n\n  constructor(private store: Store<any>, private el: ElementRef) {\n    super();\n    this.store.dispatch(EventActions.load({}));\n    this.events$ = this.store.select(EventSelectors.events);\n    this.selectedIds$ = this.store.select(EventSelectors.selectedIds);\n  }\n\n  ngAfterViewInit(): void {\n    this.subscriptions.add(\n      fromEvent(this.el.nativeElement, 'scroll')\n        .pipe(\n          // Are we close to end\n          map((e: any) => {\n            const target = e.currentTarget;\n            return target.scrollHeight - target.offsetHeight - target.scrollTop;\n          }),\n          withLatestFrom(this.store.select(EventSelectors.noMoreEvents)),\n          filter(([remaningScroll, noMore]) => !noMore && remaningScroll < 200),\n          auditTime(200),\n        ).subscribe(() => {\n        this.store.dispatch(EventActions.load({ next: true }));\n      }));\n  }\n\n  select(event: HypEventDetails, $event: MouseEvent) {\n    this.store.dispatch(EventActions.select({ ids: [event.id], cumulative: true }));\n    $event.preventDefault();\n    $event.stopPropagation();\n  }\n}\n","<table class=\"o-hvy-events-table\">\n  <thead>\n  <tr class=\"o-hvy-events-table__header\">\n    <th></th>\n    <th>{{ '@hvy.event.criticality.name' | i18n }}</th>\n    <th>{{ '@hvy.event.name' | i18n }}</th>\n    <th>{{ '@hvy.event.category.name' | i18n }}</th>\n    <th>{{ '@hvy.event.address' | i18n }}</th>\n    <th>\n      <hvy-column-order field=\"creationDate\">{{ '@hvy.event.creationDate' | i18n }}</hvy-column-order>\n    </th>\n    <th>\n      <hvy-column-order field=\"lastModificationDate\">{{ '@hvy.event.lastModificationDate' | i18n }}</hvy-column-order>\n    </th>\n    <th>\n      <hvy-column-order field=\"name\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n    </th>\n    <th>\n      <hvy-column-order field=\"progress\">{{ '@hvy.procedure.progress' | i18n }}</hvy-column-order>\n    </th>\n    <th></th>\n  </tr>\n  </thead>\n  <tbody>\n    @for (event of events$|async;track event.id) {\n      <tr class=\"o-hvy-events-table__line\" (click)=\"select(event, $event)\">\n        <td class=\"o-hvy-events-table__line__cell\">\n          <pry-checkbox [ngModel]=\"(selectedIds$|async)!.includes(event.id)\"></pry-checkbox>\n        </td>\n        <td class=\"o-hvy-events-table__line__cell -centered\">\n          <hvy-icon-display [event]=\"event\"></hvy-icon-display>\n        </td>\n        <td class=\"o-hvy-events-table__line__cell\">\n          <div class=\"o-hvy-events-table__line__cell__name__main\">{{ event.name }}</div>\n          <div\n            class=\"o-hvy-events-table__line__cell__name__sub\">{{ event.equipment?.name ? event.equipment?.name : '' }}\n          </div>\n        </td>\n        <td class=\"o-hvy-events-table__line__cell -centered\">{{ '@hvy.event.category.' + event.category | i18n }}</td>\n        <td class=\"o-hvy-events-table__line__cell\">{{ event.address }}</td>\n        <td class=\"o-hvy-events-table__line__cell\">{{ event.creationDate| sinceDate: { onlyLocale: true } }}</td>\n        <td class=\"o-hvy-events-table__line__cell\">{{ event.lastModificationDate | sinceDate: { onlyLocale: true } }}\n        </td>\n        <td class=\"o-hvy-events-table__line__cell -centered\">\n          <hvy-status-display [event]=\"event\"></hvy-status-display>\n        </td>\n        <td class=\"o-hvy-events-table__line__cell -centered\">\n          {{ event.procedureProgress }} %\n        </td>\n        <td class=\"o-hvy-events-table__line__cell\">\n          <a [routerLink]=\"EVENT_LINK.fn(event, _store)\">\n            > {{ '@hvy.action.consult' | i18n }} @if (event.linkedEvents > 1) {\n            ({{ event.linkedEvents }})\n          }\n          </a>\n        </td>\n      </tr>\n    } @empty {\n      <tr>\n        <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n          <div>{{ '@hvy.event.log.empty' | i18n }}</div>\n          <div>\n            <ng-content></ng-content>\n          </div>\n        </td>\n      </tr>\n    }\n  </tbody>\n</table>\n"]}
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/hypervisor/src/lib/event/list/event-list.component.ts","../../../../../../../../projects/provoly/hypervisor/src/lib/event/list/event-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { EventActions } from '../../store/event/event.actions';\nimport { EventSelectors } from '../../store/event/event.selectors';\nimport { auditTime, combineLatest, filter, fromEvent, map, Observable, withLatestFrom } from 'rxjs';\nimport { SubscriptionnerDirective } from '@provoly/dashboard';\nimport { HypEventDetails } from '../../model/event/hyp-event-detail.interface';\nimport { HypEventSummary } from '../../model/event/hyp-event-summary.interface';\n\nexport const EVENT_LINK = {\n  fn: (event: HypEventDetails | HypEventSummary, store: Store<any>) => ['./', event.id],\n};\n\n@Component({\n  selector: 'hvy-event-list',\n  templateUrl: './event-list.component.html',\n})\nexport class EventListComponent extends SubscriptionnerDirective implements AfterViewInit {\n  events$: Observable<HypEventDetails[]>;\n  selectedIds$: Observable<string[]>;\n  EVENT_LINK = EVENT_LINK;\n  _store = this.store;\n  allSelected$: Observable<boolean>;\n  _inhibate = false;\n\n  constructor(private store: Store<any>, private el: ElementRef) {\n    super();\n    this.store.dispatch(EventActions.load({}));\n    this.events$ = this.store.select(EventSelectors.events);\n    this.selectedIds$ = this.store.select(EventSelectors.selectedIds);\n    this.allSelected$ = combineLatest([this.events$, this.selectedIds$]).pipe(map(([events, selectedIds]) => events.filter(ev => !selectedIds.includes(ev.id)).length === 0));\n  }\n\n  ngAfterViewInit(): void {\n    this.subscriptions.add(\n      fromEvent(this.el.nativeElement, 'scroll')\n        .pipe(\n          // Are we close to end\n          map((e: any) => {\n            const target = e.currentTarget;\n            return target.scrollHeight - target.offsetHeight - target.scrollTop;\n          }),\n          withLatestFrom(this.store.select(EventSelectors.noMoreEvents)),\n          filter(([remaningScroll, noMore]) => !noMore && remaningScroll < 200),\n          auditTime(200),\n        ).subscribe(() => {\n        this.store.dispatch(EventActions.load({ next: true }));\n      }));\n  }\n\n  select(event: HypEventDetails, $event: MouseEvent) {\n    this.inhibate();\n    this.store.dispatch(EventActions.select({ ids: [event.id], cumulative: true }));\n    $event.preventDefault();\n    $event.stopPropagation();\n  }\n\n  selectAll($event: any) {\n    if (!this._inhibate) {\n      this.inhibate();\n      const tmpSub = this.events$.subscribe(events => {\n        this.store.dispatch(EventActions.select({ ids: $event ? events.map(ev => ev.id) : [], cumulative: false}));\n        setTimeout(() => tmpSub.unsubscribe(), 10);\n      });\n\n    }\n  }\n\n  inhibate() {\n    this._inhibate = true;\n    setTimeout(() => this._inhibate = false, 100);\n  }\n}\n","<table class=\"o-hvy-events-table\">\n  <thead>\n  <tr class=\"o-hvy-events-table__header\">\n    <th>\n      <pry-checkbox [ngModel]=\"allSelected$|async\" (ngModelChange)=\"selectAll($event)\"></pry-checkbox>\n    </th>\n    <th>{{ '@hvy.event.criticality.name' | i18n }}</th>\n    <th>{{ '@hvy.event.name' | i18n }}</th>\n    <th>{{ '@hvy.event.category.name' | i18n }}</th>\n    <th>{{ '@hvy.event.address' | i18n }}</th>\n    <th>\n      <hvy-column-order field=\"creationDate\">{{ '@hvy.event.creationDate' | i18n }}</hvy-column-order>\n    </th>\n    <th>\n      <hvy-column-order field=\"lastModificationDate\">{{ '@hvy.event.lastModificationDate' | i18n }}</hvy-column-order>\n    </th>\n    <th>\n      <hvy-column-order field=\"name\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n    </th>\n    <th>\n      <hvy-column-order field=\"progress\">{{ '@hvy.procedure.progress' | i18n }}</hvy-column-order>\n    </th>\n    <th></th>\n  </tr>\n  </thead>\n  <tbody>\n    @for (event of events$|async;track event.id) {\n      <tr class=\"o-hvy-events-table__line\" (click)=\"select(event, $event)\">\n        <td class=\"o-hvy-events-table__line__cell\">\n          <pry-checkbox [ngModel]=\"(selectedIds$|async)!.includes(event.id)\"></pry-checkbox>\n        </td>\n        <td class=\"o-hvy-events-table__line__cell -centered\">\n          <hvy-icon-display [event]=\"event\"></hvy-icon-display>\n        </td>\n        <td class=\"o-hvy-events-table__line__cell\">\n          <div class=\"o-hvy-events-table__line__cell__name__main\">{{ event.name }}</div>\n          <div\n            class=\"o-hvy-events-table__line__cell__name__sub\">{{ event.equipment?.name ? event.equipment?.name : '' }}\n          </div>\n        </td>\n        <td class=\"o-hvy-events-table__line__cell -centered\">{{ '@hvy.event.category.' + event.category | i18n }}</td>\n        <td class=\"o-hvy-events-table__line__cell\">{{ event.address }}</td>\n        <td class=\"o-hvy-events-table__line__cell\">{{ event.creationDate| sinceDate: { onlyLocale: true } }}</td>\n        <td class=\"o-hvy-events-table__line__cell\">{{ event.lastModificationDate | sinceDate: { onlyLocale: true } }}\n        </td>\n        <td class=\"o-hvy-events-table__line__cell -centered\">\n          <hvy-status-display [event]=\"event\"></hvy-status-display>\n        </td>\n        <td class=\"o-hvy-events-table__line__cell -centered\">\n          {{ event.procedureProgress }} %\n        </td>\n        <td class=\"o-hvy-events-table__line__cell\">\n          <a [routerLink]=\"EVENT_LINK.fn(event, _store)\">\n            > {{ '@hvy.action.consult' | i18n }} @if (event.linkedEvents > 1) {\n            ({{ event.linkedEvents }})\n          }\n          </a>\n        </td>\n      </tr>\n    } @empty {\n      <tr>\n        <td class=\"o-hvy-events-table__empty\" colspan=\"50\">\n          <div>{{ '@hvy.event.log.empty' | i18n }}</div>\n          <div>\n            <ng-content></ng-content>\n          </div>\n        </td>\n      </tr>\n    }\n  </tbody>\n</table>\n"]}
@@ -24,11 +24,11 @@ export class EventSummaryListComponent {
24
24
  this.store.dispatch(EventActions.filter({ filters: { status: [status] } }));
25
25
  }
26
26
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventSummaryListComponent, deps: [{ token: i1.Store }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
27
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: EventSummaryListComponent, selector: "hvy-event-summary-list", inputs: { events: "events", totalEventCount: "totalEventCount", status: "status", consultLink: "consultLink", itemLinkBase: "itemLinkBase" }, ngImport: i0, template: "<div class=\"o-hvy-event-summary-list -hvy-{{status.toLowerCase()}}\">\n <div class=\"o-hvy-event-summary-list__header\">\n <h3 class=\"o-hvy-event-summary-list__title\">\n {{ '@hvy.eventSummary.statusLabels.' + status | i18n }}\n </h3>\n <span class=\"o-hvy-event-summary-list__counter\">\n {{ totalEventCount }}\n </span>\n </div>\n <div class=\"o-hvy-event-summary-list__content\">\n @for (event of events; track event.id) {\n <hvy-event-summary-item\n [event]=\"event\"\n [linkBase]=\"itemLinkBase\">\n </hvy-event-summary-item>\n } @empty {\n <span class=\"o-hvy-event-summary-list__no-content\">\n {{ '@hvy.eventSummary.noContent' | i18n }}\n </span>\n }\n </div>\n <div class=\"o-hvy-event-summary-list__footer\">\n <button class=\"o-hvy-event-summary-list__footer-button\" (click)=\"filterAndRoute(status)\">\n Consulter\n <pry-icon iconSvg=\"arrow\"></pry-icon>\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i4.EventSummaryItemComponent, selector: "hvy-event-summary-item", inputs: ["event", "linkBase"] }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }] }); }
27
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: EventSummaryListComponent, selector: "hvy-event-summary-list", inputs: { events: "events", totalEventCount: "totalEventCount", status: "status", consultLink: "consultLink", itemLinkBase: "itemLinkBase" }, ngImport: i0, template: "<div class=\"o-hvy-event-summary-list -hvy-{{status.toLowerCase()}}\">\n <div class=\"o-hvy-event-summary-list__header\">\n <h3 class=\"o-hvy-event-summary-list__title\">\n {{ '@hvy.eventSummary.statusLabels.' + status | i18n }}\n </h3>\n <span class=\"o-hvy-event-summary-list__counter\">\n {{ totalEventCount }}\n </span>\n </div>\n <div class=\"o-hvy-event-summary-list__content\">\n @for (event of events; track event.id) {\n <hvy-event-summary-item\n [event]=\"event\"\n [linkBase]=\"itemLinkBase\">\n </hvy-event-summary-item>\n } @empty {\n <span class=\"o-hvy-event-summary-list__no-content\">\n {{ '@hvy.eventSummary.noContent' | i18n }}\n </span>\n }\n </div>\n <div class=\"o-hvy-event-summary-list__footer\">\n <button class=\"o-hvy-event-summary-list__footer-button\" (click)=\"filterAndRoute(status)\">\n {{ '@hvy.action.consult' | i18n }}\n <pry-icon iconSvg=\"arrow\"></pry-icon>\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i4.EventSummaryItemComponent, selector: "hvy-event-summary-item", inputs: ["event", "linkBase"] }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }] }); }
28
28
  }
29
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventSummaryListComponent, decorators: [{
30
30
  type: Component,
31
- args: [{ selector: 'hvy-event-summary-list', template: "<div class=\"o-hvy-event-summary-list -hvy-{{status.toLowerCase()}}\">\n <div class=\"o-hvy-event-summary-list__header\">\n <h3 class=\"o-hvy-event-summary-list__title\">\n {{ '@hvy.eventSummary.statusLabels.' + status | i18n }}\n </h3>\n <span class=\"o-hvy-event-summary-list__counter\">\n {{ totalEventCount }}\n </span>\n </div>\n <div class=\"o-hvy-event-summary-list__content\">\n @for (event of events; track event.id) {\n <hvy-event-summary-item\n [event]=\"event\"\n [linkBase]=\"itemLinkBase\">\n </hvy-event-summary-item>\n } @empty {\n <span class=\"o-hvy-event-summary-list__no-content\">\n {{ '@hvy.eventSummary.noContent' | i18n }}\n </span>\n }\n </div>\n <div class=\"o-hvy-event-summary-list__footer\">\n <button class=\"o-hvy-event-summary-list__footer-button\" (click)=\"filterAndRoute(status)\">\n Consulter\n <pry-icon iconSvg=\"arrow\"></pry-icon>\n </button>\n </div>\n</div>\n" }]
31
+ args: [{ selector: 'hvy-event-summary-list', template: "<div class=\"o-hvy-event-summary-list -hvy-{{status.toLowerCase()}}\">\n <div class=\"o-hvy-event-summary-list__header\">\n <h3 class=\"o-hvy-event-summary-list__title\">\n {{ '@hvy.eventSummary.statusLabels.' + status | i18n }}\n </h3>\n <span class=\"o-hvy-event-summary-list__counter\">\n {{ totalEventCount }}\n </span>\n </div>\n <div class=\"o-hvy-event-summary-list__content\">\n @for (event of events; track event.id) {\n <hvy-event-summary-item\n [event]=\"event\"\n [linkBase]=\"itemLinkBase\">\n </hvy-event-summary-item>\n } @empty {\n <span class=\"o-hvy-event-summary-list__no-content\">\n {{ '@hvy.eventSummary.noContent' | i18n }}\n </span>\n }\n </div>\n <div class=\"o-hvy-event-summary-list__footer\">\n <button class=\"o-hvy-event-summary-list__footer-button\" (click)=\"filterAndRoute(status)\">\n {{ '@hvy.action.consult' | i18n }}\n <pry-icon iconSvg=\"arrow\"></pry-icon>\n </button>\n </div>\n</div>\n" }]
32
32
  }], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }], propDecorators: { events: [{
33
33
  type: Input
34
34
  }], totalEventCount: [{
@@ -40,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
40
40
  }], itemLinkBase: [{
41
41
  type: Input
42
42
  }] } });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc3VtbWFyeS1saXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvaHlwZXJ2aXNvci9zcmMvbGliL2V2ZW50LXN1bW1hcnkvbGlzdC9ldmVudC1zdW1tYXJ5LWxpc3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQtc3VtbWFyeS9saXN0L2V2ZW50LXN1bW1hcnktbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUd6RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUNBQWlDLENBQUM7Ozs7OztBQU8vRCxNQUFNLE9BQU8seUJBQXlCO0lBT3BDLFlBQW9CLEtBQWlCLEVBQVUsTUFBYztRQUF6QyxVQUFLLEdBQUwsS0FBSyxDQUFZO1FBQVUsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQU5wRCxXQUFNLEdBQXNCLEVBQUUsQ0FBQztRQUMvQixvQkFBZSxHQUFHLENBQUMsQ0FBQztRQUNwQixXQUFNLEdBQVcsRUFBRSxDQUFDO1FBQ3BCLGdCQUFXLEdBQWEsRUFBRSxDQUFDO1FBQzNCLGlCQUFZLEdBQWEsRUFBRSxDQUFDO0lBR3JDLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDL0UsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDcEYsQ0FBQztJQUVELGNBQWMsQ0FBQyxNQUFjO1FBQzNCLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUM1QyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM5RSxDQUFDOzhHQWxCVSx5QkFBeUI7a0dBQXpCLHlCQUF5Qiw0TUNWdEMscStCQTRCQTs7MkZEbEJhLHlCQUF5QjtrQkFKckMsU0FBUzsrQkFDRSx3QkFBd0I7K0ZBSXpCLE1BQU07c0JBQWQsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IEV2ZW50QWN0aW9ucyB9IGZyb20gJy4uLy4uL3N0b3JlL2V2ZW50L2V2ZW50LmFjdGlvbnMnO1xuaW1wb3J0IHsgSHlwRXZlbnRTdW1tYXJ5IH0gZnJvbSAnLi4vLi4vbW9kZWwvZXZlbnQvaHlwLWV2ZW50LXN1bW1hcnkuaW50ZXJmYWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaHZ5LWV2ZW50LXN1bW1hcnktbGlzdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9ldmVudC1zdW1tYXJ5LWxpc3QuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEV2ZW50U3VtbWFyeUxpc3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBldmVudHM6IEh5cEV2ZW50U3VtbWFyeVtdID0gW107XG4gIEBJbnB1dCgpIHRvdGFsRXZlbnRDb3VudCA9IDA7XG4gIEBJbnB1dCgpIHN0YXR1czogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIGNvbnN1bHRMaW5rOiBzdHJpbmdbXSA9IFtdO1xuICBASW5wdXQoKSBpdGVtTGlua0Jhc2U6IHN0cmluZ1tdID0gW107XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmU8YW55PiwgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlcikge1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5jb25zdWx0TGluayA9IHRoaXMuY29uc3VsdExpbmsubGVuZ3RoID4gMCA/IHRoaXMuY29uc3VsdExpbmsgOiBbJ2V2ZW50cyddO1xuICAgIHRoaXMuaXRlbUxpbmtCYXNlID0gdGhpcy5pdGVtTGlua0Jhc2UubGVuZ3RoID4gMCA/IHRoaXMuaXRlbUxpbmtCYXNlIDogWydldmVudHMnXTtcbiAgfVxuXG4gIGZpbHRlckFuZFJvdXRlKHN0YXR1czogc3RyaW5nKSB7XG4gICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoWy4uLnRoaXMuY29uc3VsdExpbmtdKTtcbiAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKEV2ZW50QWN0aW9ucy5maWx0ZXIoeyBmaWx0ZXJzOiB7IHN0YXR1czogW3N0YXR1c10gfSB9KSk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3QgLWh2eS17e3N0YXR1cy50b0xvd2VyQ2FzZSgpfX1cIj5cbiAgPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdF9faGVhZGVyXCI+XG4gICAgPGgzIGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1saXN0X190aXRsZVwiPlxuICAgICAge3sgJ0BodnkuZXZlbnRTdW1tYXJ5LnN0YXR1c0xhYmVscy4nICsgc3RhdHVzIHwgaTE4biB9fVxuICAgIDwvaDM+XG4gICAgPHNwYW4gY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3RfX2NvdW50ZXJcIj5cbiAgICAgIHt7IHRvdGFsRXZlbnRDb3VudCB9fVxuICAgIDwvc3Bhbj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3RfX2NvbnRlbnRcIj5cbiAgICBAZm9yIChldmVudCBvZiBldmVudHM7IHRyYWNrIGV2ZW50LmlkKSB7XG4gICAgICA8aHZ5LWV2ZW50LXN1bW1hcnktaXRlbVxuICAgICAgICBbZXZlbnRdPVwiZXZlbnRcIlxuICAgICAgICBbbGlua0Jhc2VdPVwiaXRlbUxpbmtCYXNlXCI+XG4gICAgICA8L2h2eS1ldmVudC1zdW1tYXJ5LWl0ZW0+XG4gICAgfSBAZW1wdHkge1xuICAgICAgPHNwYW4gY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3RfX25vLWNvbnRlbnRcIj5cbiAgICAgICAge3sgJ0BodnkuZXZlbnRTdW1tYXJ5Lm5vQ29udGVudCcgfCBpMThuIH19XG4gICAgICA8L3NwYW4+XG4gICAgfVxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdF9fZm9vdGVyXCI+XG4gICAgPGJ1dHRvbiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdF9fZm9vdGVyLWJ1dHRvblwiIChjbGljayk9XCJmaWx0ZXJBbmRSb3V0ZShzdGF0dXMpXCI+XG4gICAgICBDb25zdWx0ZXJcbiAgICAgIDxwcnktaWNvbiBpY29uU3ZnPVwiYXJyb3dcIj48L3ByeS1pY29uPlxuICAgIDwvYnV0dG9uPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc3VtbWFyeS1saXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvaHlwZXJ2aXNvci9zcmMvbGliL2V2ZW50LXN1bW1hcnkvbGlzdC9ldmVudC1zdW1tYXJ5LWxpc3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQtc3VtbWFyeS9saXN0L2V2ZW50LXN1bW1hcnktbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUd6RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUNBQWlDLENBQUM7Ozs7OztBQU8vRCxNQUFNLE9BQU8seUJBQXlCO0lBT3BDLFlBQW9CLEtBQWlCLEVBQVUsTUFBYztRQUF6QyxVQUFLLEdBQUwsS0FBSyxDQUFZO1FBQVUsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQU5wRCxXQUFNLEdBQXNCLEVBQUUsQ0FBQztRQUMvQixvQkFBZSxHQUFHLENBQUMsQ0FBQztRQUNwQixXQUFNLEdBQVcsRUFBRSxDQUFDO1FBQ3BCLGdCQUFXLEdBQWEsRUFBRSxDQUFDO1FBQzNCLGlCQUFZLEdBQWEsRUFBRSxDQUFDO0lBR3JDLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDL0UsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDcEYsQ0FBQztJQUVELGNBQWMsQ0FBQyxNQUFjO1FBQzNCLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUM1QyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM5RSxDQUFDOzhHQWxCVSx5QkFBeUI7a0dBQXpCLHlCQUF5Qiw0TUNWdEMsOC9CQTRCQTs7MkZEbEJhLHlCQUF5QjtrQkFKckMsU0FBUzsrQkFDRSx3QkFBd0I7K0ZBSXpCLE1BQU07c0JBQWQsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IEV2ZW50QWN0aW9ucyB9IGZyb20gJy4uLy4uL3N0b3JlL2V2ZW50L2V2ZW50LmFjdGlvbnMnO1xuaW1wb3J0IHsgSHlwRXZlbnRTdW1tYXJ5IH0gZnJvbSAnLi4vLi4vbW9kZWwvZXZlbnQvaHlwLWV2ZW50LXN1bW1hcnkuaW50ZXJmYWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaHZ5LWV2ZW50LXN1bW1hcnktbGlzdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9ldmVudC1zdW1tYXJ5LWxpc3QuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEV2ZW50U3VtbWFyeUxpc3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBldmVudHM6IEh5cEV2ZW50U3VtbWFyeVtdID0gW107XG4gIEBJbnB1dCgpIHRvdGFsRXZlbnRDb3VudCA9IDA7XG4gIEBJbnB1dCgpIHN0YXR1czogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIGNvbnN1bHRMaW5rOiBzdHJpbmdbXSA9IFtdO1xuICBASW5wdXQoKSBpdGVtTGlua0Jhc2U6IHN0cmluZ1tdID0gW107XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmU8YW55PiwgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlcikge1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5jb25zdWx0TGluayA9IHRoaXMuY29uc3VsdExpbmsubGVuZ3RoID4gMCA/IHRoaXMuY29uc3VsdExpbmsgOiBbJ2V2ZW50cyddO1xuICAgIHRoaXMuaXRlbUxpbmtCYXNlID0gdGhpcy5pdGVtTGlua0Jhc2UubGVuZ3RoID4gMCA/IHRoaXMuaXRlbUxpbmtCYXNlIDogWydldmVudHMnXTtcbiAgfVxuXG4gIGZpbHRlckFuZFJvdXRlKHN0YXR1czogc3RyaW5nKSB7XG4gICAgdGhpcy5yb3V0ZXIubmF2aWdhdGUoWy4uLnRoaXMuY29uc3VsdExpbmtdKTtcbiAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKEV2ZW50QWN0aW9ucy5maWx0ZXIoeyBmaWx0ZXJzOiB7IHN0YXR1czogW3N0YXR1c10gfSB9KSk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3QgLWh2eS17e3N0YXR1cy50b0xvd2VyQ2FzZSgpfX1cIj5cbiAgPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdF9faGVhZGVyXCI+XG4gICAgPGgzIGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1saXN0X190aXRsZVwiPlxuICAgICAge3sgJ0BodnkuZXZlbnRTdW1tYXJ5LnN0YXR1c0xhYmVscy4nICsgc3RhdHVzIHwgaTE4biB9fVxuICAgIDwvaDM+XG4gICAgPHNwYW4gY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3RfX2NvdW50ZXJcIj5cbiAgICAgIHt7IHRvdGFsRXZlbnRDb3VudCB9fVxuICAgIDwvc3Bhbj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3RfX2NvbnRlbnRcIj5cbiAgICBAZm9yIChldmVudCBvZiBldmVudHM7IHRyYWNrIGV2ZW50LmlkKSB7XG4gICAgICA8aHZ5LWV2ZW50LXN1bW1hcnktaXRlbVxuICAgICAgICBbZXZlbnRdPVwiZXZlbnRcIlxuICAgICAgICBbbGlua0Jhc2VdPVwiaXRlbUxpbmtCYXNlXCI+XG4gICAgICA8L2h2eS1ldmVudC1zdW1tYXJ5LWl0ZW0+XG4gICAgfSBAZW1wdHkge1xuICAgICAgPHNwYW4gY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3RfX25vLWNvbnRlbnRcIj5cbiAgICAgICAge3sgJ0BodnkuZXZlbnRTdW1tYXJ5Lm5vQ29udGVudCcgfCBpMThuIH19XG4gICAgICA8L3NwYW4+XG4gICAgfVxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdF9fZm9vdGVyXCI+XG4gICAgPGJ1dHRvbiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdF9fZm9vdGVyLWJ1dHRvblwiIChjbGljayk9XCJmaWx0ZXJBbmRSb3V0ZShzdGF0dXMpXCI+XG4gICAgICB7eyAnQGh2eS5hY3Rpb24uY29uc3VsdCcgfCBpMThuIH19XG4gICAgICA8cHJ5LWljb24gaWNvblN2Zz1cImFycm93XCI+PC9wcnktaWNvbj5cbiAgICA8L2J1dHRvbj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -5,6 +5,7 @@ import { EventSelectors } from '../../store/event/event.selectors';
5
5
  import { map } from 'rxjs/operators';
6
6
  import { EventSummarySelectors } from '../../store/event-summary/event-summary.selectors';
7
7
  import { SubscriptionnerDirective } from '@provoly/dashboard';
8
+ import { HypEventStatus } from '../../model/event/hyp-event-status.type';
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "@ngrx/store";
10
11
  import * as i2 from "@angular/forms";
@@ -16,12 +17,16 @@ export class EventSummaryPageComponent extends SubscriptionnerDirective {
16
17
  super();
17
18
  this.store = store;
18
19
  this.pageTitle = '';
20
+ this.consultLink = [];
19
21
  this.summaries = {
20
22
  NEW: { events: [], count: 0 },
21
23
  IN_PROGRESS: { events: [], count: 0 },
22
24
  DONE: { events: [], count: 0 },
23
25
  };
24
- this.criticalityList = ["LOW", "MEDIUM", "HIGH", "ALL"];
26
+ this.criticalityList = [...HypEventStatus.values, 'ALL'];
27
+ this.criticalityOrder = (a, b) => {
28
+ return this.criticalityList.indexOf(a.key) - this.criticalityList.indexOf(b.key);
29
+ };
25
30
  this.store.dispatch(EventSummaryActions.load());
26
31
  this.selectedCriticality$ = this.store.select(EventSelectors.filters).pipe(map((filters) => filters['criticality']?.[0] ?? 'ALL'));
27
32
  this.subscriptions.add(this.store.select(EventSummarySelectors.summaries).subscribe((summaries) => {
@@ -33,16 +38,15 @@ export class EventSummaryPageComponent extends SubscriptionnerDirective {
33
38
  this.store.dispatch(EventActions.filter({ filters: { criticality: [$event] } }));
34
39
  this.store.dispatch(EventSummaryActions.load());
35
40
  }
36
- asIsOrder() {
37
- return 0;
38
- }
39
41
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventSummaryPageComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
40
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: EventSummaryPageComponent, selector: "hvy-event-summary-page", inputs: { pageTitle: "pageTitle" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-hvy-event-summary-page\">\n <div class=\"o-hvy-event-summary-page__header\">\n @if (pageTitle) {\n <h3 class=\"o-hvy-event-summary-page__title\">{{ pageTitle }}</h3>\n }\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown\">\n <label class=\"a-label m-filter__label\" for=\"criticality-filter\">{{ '@hvy.event.criticality.name' | i18n }} :&nbsp;</label>\n <pry-select\n id=\"criticality-filter\"\n class=\"o-hvy-event-summary-page__filter\"\n [items]=\"criticalityList\"\n [ngModel]=\"selectedCriticality$ | async\"\n (ngModelChange)=\"filterByCriticality($event)\"\n [translate]=\"true\"\n i18nPrefix=\"@hvy.eventSummary.criticalityLabels.\"\n >\n </pry-select>\n </div>\n </div>\n <div class=\"o-hvy-event-summary-page__content\">\n @for (summaryList of summaries | keyvalue: asIsOrder; track summaryList.key) {\n <hvy-event-summary-list\n class=\"o-hvy-event-summary-page__summary-list\"\n [status]=\"summaryList.key\"\n [totalEventCount]=\"summaryList.value.count\"\n [events]=\"summaryList.value.events\">\n </hvy-event-summary-list>\n }\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared"] }, { kind: "component", type: i4.EventSummaryListComponent, selector: "hvy-event-summary-list", inputs: ["events", "totalEventCount", "status", "consultLink", "itemLinkBase"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }, { kind: "pipe", type: i5.KeyValuePipe, name: "keyvalue" }] }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: EventSummaryPageComponent, selector: "hvy-event-summary-page", inputs: { pageTitle: "pageTitle", consultLink: "consultLink" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-hvy-event-summary-page\">\n <div class=\"o-hvy-event-summary-page__header\">\n @if (pageTitle) {\n <h3 class=\"o-hvy-event-summary-page__title\">{{ pageTitle }}</h3>\n }\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown\">\n <label class=\"a-label m-filter__label\" for=\"criticality-filter\">{{ '@hvy.event.criticality.name' | i18n }}\n :&nbsp;</label>\n <pry-select\n id=\"criticality-filter\"\n class=\"o-hvy-event-summary-page__filter\"\n [items]=\"criticalityList\"\n [ngModel]=\"selectedCriticality$ | async\"\n (ngModelChange)=\"filterByCriticality($event)\"\n [translate]=\"true\"\n i18nPrefix=\"@hvy.eventSummary.criticalityLabels.\"\n >\n </pry-select>\n </div>\n </div>\n <div class=\"o-hvy-event-summary-page__content\">\n <div class=\"o-hvy-event-summary-page__content__sub\">\n @for (summaryList of summaries | keyvalue: criticalityOrder;track summaryList.key) {\n <hvy-event-summary-list\n class=\"o-hvy-event-summary-page__summary-list\"\n [status]=\"summaryList.key\"\n [totalEventCount]=\"summaryList.value.count\"\n [events]=\"summaryList.value.events\"\n [consultLink]=\"consultLink\">\n </hvy-event-summary-list>\n }\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared"] }, { kind: "component", type: i4.EventSummaryListComponent, selector: "hvy-event-summary-list", inputs: ["events", "totalEventCount", "status", "consultLink", "itemLinkBase"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }, { kind: "pipe", type: i5.KeyValuePipe, name: "keyvalue" }] }); }
41
43
  }
42
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventSummaryPageComponent, decorators: [{
43
45
  type: Component,
44
- args: [{ selector: 'hvy-event-summary-page', template: "<div class=\"o-hvy-event-summary-page\">\n <div class=\"o-hvy-event-summary-page__header\">\n @if (pageTitle) {\n <h3 class=\"o-hvy-event-summary-page__title\">{{ pageTitle }}</h3>\n }\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown\">\n <label class=\"a-label m-filter__label\" for=\"criticality-filter\">{{ '@hvy.event.criticality.name' | i18n }} :&nbsp;</label>\n <pry-select\n id=\"criticality-filter\"\n class=\"o-hvy-event-summary-page__filter\"\n [items]=\"criticalityList\"\n [ngModel]=\"selectedCriticality$ | async\"\n (ngModelChange)=\"filterByCriticality($event)\"\n [translate]=\"true\"\n i18nPrefix=\"@hvy.eventSummary.criticalityLabels.\"\n >\n </pry-select>\n </div>\n </div>\n <div class=\"o-hvy-event-summary-page__content\">\n @for (summaryList of summaries | keyvalue: asIsOrder; track summaryList.key) {\n <hvy-event-summary-list\n class=\"o-hvy-event-summary-page__summary-list\"\n [status]=\"summaryList.key\"\n [totalEventCount]=\"summaryList.value.count\"\n [events]=\"summaryList.value.events\">\n </hvy-event-summary-list>\n }\n </div>\n</div>\n" }]
46
+ args: [{ selector: 'hvy-event-summary-page', template: "<div class=\"o-hvy-event-summary-page\">\n <div class=\"o-hvy-event-summary-page__header\">\n @if (pageTitle) {\n <h3 class=\"o-hvy-event-summary-page__title\">{{ pageTitle }}</h3>\n }\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown\">\n <label class=\"a-label m-filter__label\" for=\"criticality-filter\">{{ '@hvy.event.criticality.name' | i18n }}\n :&nbsp;</label>\n <pry-select\n id=\"criticality-filter\"\n class=\"o-hvy-event-summary-page__filter\"\n [items]=\"criticalityList\"\n [ngModel]=\"selectedCriticality$ | async\"\n (ngModelChange)=\"filterByCriticality($event)\"\n [translate]=\"true\"\n i18nPrefix=\"@hvy.eventSummary.criticalityLabels.\"\n >\n </pry-select>\n </div>\n </div>\n <div class=\"o-hvy-event-summary-page__content\">\n <div class=\"o-hvy-event-summary-page__content__sub\">\n @for (summaryList of summaries | keyvalue: criticalityOrder;track summaryList.key) {\n <hvy-event-summary-list\n class=\"o-hvy-event-summary-page__summary-list\"\n [status]=\"summaryList.key\"\n [totalEventCount]=\"summaryList.value.count\"\n [events]=\"summaryList.value.events\"\n [consultLink]=\"consultLink\">\n </hvy-event-summary-list>\n }\n </div>\n </div>\n</div>\n" }]
45
47
  }], ctorParameters: () => [{ type: i1.Store }], propDecorators: { pageTitle: [{
46
48
  type: Input
49
+ }], consultLink: [{
50
+ type: Input
47
51
  }] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc3VtbWFyeS1wYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvaHlwZXJ2aXNvci9zcmMvbGliL2V2ZW50LXN1bW1hcnkvcGFnZS9ldmVudC1zdW1tYXJ5LXBhZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQtc3VtbWFyeS9wYWdlL2V2ZW50LXN1bW1hcnktcGFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFHL0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDdEYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUMxRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7OztBQU05RCxNQUFNLE9BQU8seUJBQTBCLFNBQVEsd0JBQXdCO0lBVXJFLFlBQW9CLEtBQWlCO1FBQ25DLEtBQUssRUFBRSxDQUFDO1FBRFUsVUFBSyxHQUFMLEtBQUssQ0FBWTtRQVQ1QixjQUFTLEdBQUcsRUFBRSxDQUFDO1FBQ3hCLGNBQVMsR0FBc0I7WUFDN0IsR0FBRyxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFO1lBQzdCLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRTtZQUNyQyxJQUFJLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUU7U0FDL0IsQ0FBQztRQUVGLG9CQUFlLEdBQUcsQ0FBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztRQUlsRCxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ2hELElBQUksQ0FBQyxvQkFBb0IsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUN4RSxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUN2RCxDQUFDO1FBQ0YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQ3BCLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFO1lBQ3pFLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1FBQzdCLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDO0lBRUQsbUJBQW1CLENBQUMsTUFBYztRQUNoQyxNQUFNLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsV0FBVyxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDN0YsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxFQUFFLE9BQU8sRUFBRSxFQUFFLFdBQVcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDbkYsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsU0FBUztRQUNQLE9BQU8sQ0FBQyxDQUFDO0lBQ1gsQ0FBQzs4R0EvQlUseUJBQXlCO2tHQUF6Qix5QkFBeUIseUhDZnRDLGl0Q0E4QkE7OzJGRGZhLHlCQUF5QjtrQkFKckMsU0FBUzsrQkFDRSx3QkFBd0I7MEVBSXpCLFNBQVM7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IEV2ZW50QWN0aW9ucyB9IGZyb20gJy4uLy4uL3N0b3JlL2V2ZW50L2V2ZW50LmFjdGlvbnMnO1xuaW1wb3J0IHsgSHlwRXZlbnRTdW1tYXJpZXMgfSBmcm9tICcuLi8uLi9tb2RlbC9ldmVudC9oeXAtZXZlbnQtc3VtbWFyeS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRXZlbnRTdW1tYXJ5QWN0aW9ucyB9IGZyb20gJy4uLy4uL3N0b3JlL2V2ZW50LXN1bW1hcnkvZXZlbnQtc3VtbWFyeS5hY3Rpb25zJztcbmltcG9ydCB7IEV2ZW50U2VsZWN0b3JzIH0gZnJvbSAnLi4vLi4vc3RvcmUvZXZlbnQvZXZlbnQuc2VsZWN0b3JzJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IEV2ZW50U3VtbWFyeVNlbGVjdG9ycyB9IGZyb20gJy4uLy4uL3N0b3JlL2V2ZW50LXN1bW1hcnkvZXZlbnQtc3VtbWFyeS5zZWxlY3RvcnMnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9ubmVyRGlyZWN0aXZlIH0gZnJvbSAnQHByb3ZvbHkvZGFzaGJvYXJkJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaHZ5LWV2ZW50LXN1bW1hcnktcGFnZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9ldmVudC1zdW1tYXJ5LXBhZ2UuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEV2ZW50U3VtbWFyeVBhZ2VDb21wb25lbnQgZXh0ZW5kcyBTdWJzY3JpcHRpb25uZXJEaXJlY3RpdmUge1xuICBASW5wdXQoKSBwYWdlVGl0bGUgPSAnJztcbiAgc3VtbWFyaWVzOiBIeXBFdmVudFN1bW1hcmllcyA9IHtcbiAgICBORVc6IHsgZXZlbnRzOiBbXSwgY291bnQ6IDAgfSxcbiAgICBJTl9QUk9HUkVTUzogeyBldmVudHM6IFtdLCBjb3VudDogMCB9LFxuICAgIERPTkU6IHsgZXZlbnRzOiBbXSwgY291bnQ6IDAgfSxcbiAgfTtcbiAgc2VsZWN0ZWRDcml0aWNhbGl0eSQ6IE9ic2VydmFibGU8c3RyaW5nIHwgdW5kZWZpbmVkPjtcbiAgY3JpdGljYWxpdHlMaXN0ID0gWyBcIkxPV1wiLCBcIk1FRElVTVwiLCBcIkhJR0hcIiwgXCJBTExcIl07XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmU8YW55Pikge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5zdG9yZS5kaXNwYXRjaChFdmVudFN1bW1hcnlBY3Rpb25zLmxvYWQoKSk7XG4gICAgdGhpcy5zZWxlY3RlZENyaXRpY2FsaXR5JCA9IHRoaXMuc3RvcmUuc2VsZWN0KEV2ZW50U2VsZWN0b3JzLmZpbHRlcnMpLnBpcGUoXG4gICAgICBtYXAoKGZpbHRlcnMpID0+IGZpbHRlcnNbJ2NyaXRpY2FsaXR5J10/LlswXSA/PyAnQUxMJyksXG4gICAgKTtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbnMuYWRkKFxuICAgICAgdGhpcy5zdG9yZS5zZWxlY3QoRXZlbnRTdW1tYXJ5U2VsZWN0b3JzLnN1bW1hcmllcykuc3Vic2NyaWJlKChzdW1tYXJpZXMpID0+IHtcbiAgICAgICAgdGhpcy5zdW1tYXJpZXMgPSBzdW1tYXJpZXM7XG4gICAgICB9KSxcbiAgICApO1xuICB9XG5cbiAgZmlsdGVyQnlDcml0aWNhbGl0eSgkZXZlbnQ6IHN0cmluZykge1xuICAgICRldmVudCA9PT0gJ0FMTCcgPyB0aGlzLnN0b3JlLmRpc3BhdGNoKEV2ZW50QWN0aW9ucy5maWx0ZXIoeyBmaWx0ZXJzOiB7IGNyaXRpY2FsaXR5OiBbXSB9IH0pKSA6XG4gICAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKEV2ZW50QWN0aW9ucy5maWx0ZXIoeyBmaWx0ZXJzOiB7IGNyaXRpY2FsaXR5OiBbJGV2ZW50XSB9IH0pKTtcbiAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKEV2ZW50U3VtbWFyeUFjdGlvbnMubG9hZCgpKTtcbiAgfVxuXG4gIGFzSXNPcmRlcigpIHtcbiAgICByZXR1cm4gMDtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktcGFnZVwiPlxuICA8ZGl2IGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1wYWdlX19oZWFkZXJcIj5cbiAgICBAaWYgKHBhZ2VUaXRsZSkge1xuICAgICAgPGgzIGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1wYWdlX190aXRsZVwiPnt7IHBhZ2VUaXRsZSB9fTwvaDM+XG4gICAgfVxuICAgIDxkaXYgY2xhc3M9XCJtLWZpbHRlcl9faW5wdXQtd3JhcHBlciBtLWZpbHRlcl9faW5wdXQtd3JhcHBlci0tZHJvcGRvd25cIj5cbiAgICAgIDxsYWJlbCBjbGFzcz1cImEtbGFiZWwgbS1maWx0ZXJfX2xhYmVsXCIgZm9yPVwiY3JpdGljYWxpdHktZmlsdGVyXCI+e3sgJ0BodnkuZXZlbnQuY3JpdGljYWxpdHkubmFtZScgfCBpMThuIH19IDombmJzcDs8L2xhYmVsPlxuICAgICAgPHByeS1zZWxlY3RcbiAgICAgICAgaWQ9XCJjcml0aWNhbGl0eS1maWx0ZXJcIlxuICAgICAgICBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktcGFnZV9fZmlsdGVyXCJcbiAgICAgICAgW2l0ZW1zXT1cImNyaXRpY2FsaXR5TGlzdFwiXG4gICAgICAgIFtuZ01vZGVsXT1cInNlbGVjdGVkQ3JpdGljYWxpdHkkIHwgYXN5bmNcIlxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJmaWx0ZXJCeUNyaXRpY2FsaXR5KCRldmVudClcIlxuICAgICAgICBbdHJhbnNsYXRlXT1cInRydWVcIlxuICAgICAgICBpMThuUHJlZml4PVwiQGh2eS5ldmVudFN1bW1hcnkuY3JpdGljYWxpdHlMYWJlbHMuXCJcbiAgICAgID5cbiAgICAgIDwvcHJ5LXNlbGVjdD5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LXBhZ2VfX2NvbnRlbnRcIj5cbiAgICBAZm9yIChzdW1tYXJ5TGlzdCBvZiBzdW1tYXJpZXMgfCBrZXl2YWx1ZTogYXNJc09yZGVyOyB0cmFjayBzdW1tYXJ5TGlzdC5rZXkpIHtcbiAgICAgIDxodnktZXZlbnQtc3VtbWFyeS1saXN0XG4gICAgICAgIGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1wYWdlX19zdW1tYXJ5LWxpc3RcIlxuICAgICAgICBbc3RhdHVzXT1cInN1bW1hcnlMaXN0LmtleVwiXG4gICAgICAgIFt0b3RhbEV2ZW50Q291bnRdPVwic3VtbWFyeUxpc3QudmFsdWUuY291bnRcIlxuICAgICAgICBbZXZlbnRzXT1cInN1bW1hcnlMaXN0LnZhbHVlLmV2ZW50c1wiPlxuICAgICAgPC9odnktZXZlbnQtc3VtbWFyeS1saXN0PlxuICAgIH1cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc3VtbWFyeS1wYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvaHlwZXJ2aXNvci9zcmMvbGliL2V2ZW50LXN1bW1hcnkvcGFnZS9ldmVudC1zdW1tYXJ5LXBhZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQtc3VtbWFyeS9wYWdlL2V2ZW50LXN1bW1hcnktcGFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFHL0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDdEYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUMxRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUNBQXlDLENBQUM7Ozs7Ozs7QUFPekUsTUFBTSxPQUFPLHlCQUEwQixTQUFRLHdCQUF3QjtJQVdyRSxZQUFvQixLQUFpQjtRQUNuQyxLQUFLLEVBQUUsQ0FBQztRQURVLFVBQUssR0FBTCxLQUFLLENBQVk7UUFWNUIsY0FBUyxHQUFHLEVBQUUsQ0FBQztRQUNmLGdCQUFXLEdBQWEsRUFBRSxDQUFDO1FBQ3BDLGNBQVMsR0FBc0I7WUFDN0IsR0FBRyxFQUFFLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFO1lBQzdCLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRTtZQUNyQyxJQUFJLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUU7U0FDL0IsQ0FBQztRQUVGLG9CQUFlLEdBQUcsQ0FBQyxHQUFHLGNBQWMsQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFxQnBELHFCQUFnQixHQUFHLENBQUMsQ0FBa0UsRUFBRSxDQUd0RixFQUFVLEVBQUU7WUFDWixPQUFPLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkYsQ0FBQyxDQUFDO1FBdEJBLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7UUFDaEQsSUFBSSxDQUFDLG9CQUFvQixHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQ3hFLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxDQUFDLENBQ3ZELENBQUM7UUFDRixJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FDcEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUU7WUFDekUsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDN0IsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxNQUFjO1FBQ2hDLE1BQU0sS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRSxPQUFPLEVBQUUsRUFBRSxXQUFXLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM3RixJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsV0FBVyxFQUFFLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNuRixJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ2xELENBQUM7OEdBNUJVLHlCQUF5QjtrR0FBekIseUJBQXlCLHFKQ2pCdEMsaTJDQWtDQTs7MkZEakJhLHlCQUF5QjtrQkFKckMsU0FBUzsrQkFDRSx3QkFBd0I7MEVBSXpCLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN0b3JlIH0gZnJvbSAnQG5ncngvc3RvcmUnO1xuaW1wb3J0IHsgRXZlbnRBY3Rpb25zIH0gZnJvbSAnLi4vLi4vc3RvcmUvZXZlbnQvZXZlbnQuYWN0aW9ucyc7XG5pbXBvcnQgeyBIeXBFdmVudFN1bW1hcmllcywgSHlwRXZlbnRTdW1tYXJ5IH0gZnJvbSAnLi4vLi4vbW9kZWwvZXZlbnQvaHlwLWV2ZW50LXN1bW1hcnkuaW50ZXJmYWNlJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEV2ZW50U3VtbWFyeUFjdGlvbnMgfSBmcm9tICcuLi8uLi9zdG9yZS9ldmVudC1zdW1tYXJ5L2V2ZW50LXN1bW1hcnkuYWN0aW9ucyc7XG5pbXBvcnQgeyBFdmVudFNlbGVjdG9ycyB9IGZyb20gJy4uLy4uL3N0b3JlL2V2ZW50L2V2ZW50LnNlbGVjdG9ycyc7XG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBFdmVudFN1bW1hcnlTZWxlY3RvcnMgfSBmcm9tICcuLi8uLi9zdG9yZS9ldmVudC1zdW1tYXJ5L2V2ZW50LXN1bW1hcnkuc2VsZWN0b3JzJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbm5lckRpcmVjdGl2ZSB9IGZyb20gJ0Bwcm92b2x5L2Rhc2hib2FyZCc7XG5pbXBvcnQgeyBIeXBFdmVudFN0YXR1cyB9IGZyb20gJy4uLy4uL21vZGVsL2V2ZW50L2h5cC1ldmVudC1zdGF0dXMudHlwZSc7XG5pbXBvcnQgeyBLZXlWYWx1ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2h2eS1ldmVudC1zdW1tYXJ5LXBhZ2UnLFxuICB0ZW1wbGF0ZVVybDogJy4vZXZlbnQtc3VtbWFyeS1wYWdlLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgRXZlbnRTdW1tYXJ5UGFnZUNvbXBvbmVudCBleHRlbmRzIFN1YnNjcmlwdGlvbm5lckRpcmVjdGl2ZSB7XG4gIEBJbnB1dCgpIHBhZ2VUaXRsZSA9ICcnO1xuICBASW5wdXQoKSBjb25zdWx0TGluazogc3RyaW5nW10gPSBbXTtcbiAgc3VtbWFyaWVzOiBIeXBFdmVudFN1bW1hcmllcyA9IHtcbiAgICBORVc6IHsgZXZlbnRzOiBbXSwgY291bnQ6IDAgfSxcbiAgICBJTl9QUk9HUkVTUzogeyBldmVudHM6IFtdLCBjb3VudDogMCB9LFxuICAgIERPTkU6IHsgZXZlbnRzOiBbXSwgY291bnQ6IDAgfSxcbiAgfTtcbiAgc2VsZWN0ZWRDcml0aWNhbGl0eSQ6IE9ic2VydmFibGU8c3RyaW5nIHwgdW5kZWZpbmVkPjtcbiAgY3JpdGljYWxpdHlMaXN0ID0gWy4uLkh5cEV2ZW50U3RhdHVzLnZhbHVlcywgJ0FMTCddO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc3RvcmU6IFN0b3JlPGFueT4pIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuc3RvcmUuZGlzcGF0Y2goRXZlbnRTdW1tYXJ5QWN0aW9ucy5sb2FkKCkpO1xuICAgIHRoaXMuc2VsZWN0ZWRDcml0aWNhbGl0eSQgPSB0aGlzLnN0b3JlLnNlbGVjdChFdmVudFNlbGVjdG9ycy5maWx0ZXJzKS5waXBlKFxuICAgICAgbWFwKChmaWx0ZXJzKSA9PiBmaWx0ZXJzWydjcml0aWNhbGl0eSddPy5bMF0gPz8gJ0FMTCcpLFxuICAgICk7XG4gICAgdGhpcy5zdWJzY3JpcHRpb25zLmFkZChcbiAgICAgIHRoaXMuc3RvcmUuc2VsZWN0KEV2ZW50U3VtbWFyeVNlbGVjdG9ycy5zdW1tYXJpZXMpLnN1YnNjcmliZSgoc3VtbWFyaWVzKSA9PiB7XG4gICAgICAgIHRoaXMuc3VtbWFyaWVzID0gc3VtbWFyaWVzO1xuICAgICAgfSksXG4gICAgKTtcbiAgfVxuXG4gIGZpbHRlckJ5Q3JpdGljYWxpdHkoJGV2ZW50OiBzdHJpbmcpIHtcbiAgICAkZXZlbnQgPT09ICdBTEwnID8gdGhpcy5zdG9yZS5kaXNwYXRjaChFdmVudEFjdGlvbnMuZmlsdGVyKHsgZmlsdGVyczogeyBjcml0aWNhbGl0eTogW10gfSB9KSkgOlxuICAgICAgdGhpcy5zdG9yZS5kaXNwYXRjaChFdmVudEFjdGlvbnMuZmlsdGVyKHsgZmlsdGVyczogeyBjcml0aWNhbGl0eTogWyRldmVudF0gfSB9KSk7XG4gICAgdGhpcy5zdG9yZS5kaXNwYXRjaChFdmVudFN1bW1hcnlBY3Rpb25zLmxvYWQoKSk7XG4gIH1cblxuICBjcml0aWNhbGl0eU9yZGVyID0gKGE6IEtleVZhbHVlPHN0cmluZywgeyBldmVudHM6IEh5cEV2ZW50U3VtbWFyeVtdOyBjb3VudDogbnVtYmVyOyB9PiwgYjogS2V5VmFsdWU8c3RyaW5nLCB7XG4gICAgZXZlbnRzOiBIeXBFdmVudFN1bW1hcnlbXTtcbiAgICBjb3VudDogbnVtYmVyO1xuICB9Pik6IG51bWJlciA9PiB7XG4gICAgcmV0dXJuIHRoaXMuY3JpdGljYWxpdHlMaXN0LmluZGV4T2YoYS5rZXkpIC0gdGhpcy5jcml0aWNhbGl0eUxpc3QuaW5kZXhPZihiLmtleSk7XG4gIH07XG59XG4iLCI8ZGl2IGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1wYWdlXCI+XG4gIDxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LXBhZ2VfX2hlYWRlclwiPlxuICAgIEBpZiAocGFnZVRpdGxlKSB7XG4gICAgICA8aDMgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LXBhZ2VfX3RpdGxlXCI+e3sgcGFnZVRpdGxlIH19PC9oMz5cbiAgICB9XG4gICAgPGRpdiBjbGFzcz1cIm0tZmlsdGVyX19pbnB1dC13cmFwcGVyIG0tZmlsdGVyX19pbnB1dC13cmFwcGVyLS1kcm9wZG93blwiPlxuICAgICAgPGxhYmVsIGNsYXNzPVwiYS1sYWJlbCBtLWZpbHRlcl9fbGFiZWxcIiBmb3I9XCJjcml0aWNhbGl0eS1maWx0ZXJcIj57eyAnQGh2eS5ldmVudC5jcml0aWNhbGl0eS5uYW1lJyB8IGkxOG4gfX1cbiAgICAgICAgOiZuYnNwOzwvbGFiZWw+XG4gICAgICA8cHJ5LXNlbGVjdFxuICAgICAgICBpZD1cImNyaXRpY2FsaXR5LWZpbHRlclwiXG4gICAgICAgIGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1wYWdlX19maWx0ZXJcIlxuICAgICAgICBbaXRlbXNdPVwiY3JpdGljYWxpdHlMaXN0XCJcbiAgICAgICAgW25nTW9kZWxdPVwic2VsZWN0ZWRDcml0aWNhbGl0eSQgfCBhc3luY1wiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cImZpbHRlckJ5Q3JpdGljYWxpdHkoJGV2ZW50KVwiXG4gICAgICAgIFt0cmFuc2xhdGVdPVwidHJ1ZVwiXG4gICAgICAgIGkxOG5QcmVmaXg9XCJAaHZ5LmV2ZW50U3VtbWFyeS5jcml0aWNhbGl0eUxhYmVscy5cIlxuICAgICAgPlxuICAgICAgPC9wcnktc2VsZWN0PlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktcGFnZV9fY29udGVudFwiPlxuICAgIDxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LXBhZ2VfX2NvbnRlbnRfX3N1YlwiPlxuICAgICAgQGZvciAoc3VtbWFyeUxpc3Qgb2Ygc3VtbWFyaWVzIHwga2V5dmFsdWU6IGNyaXRpY2FsaXR5T3JkZXI7dHJhY2sgc3VtbWFyeUxpc3Qua2V5KSB7XG4gICAgICAgIDxodnktZXZlbnQtc3VtbWFyeS1saXN0XG4gICAgICAgICAgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LXBhZ2VfX3N1bW1hcnktbGlzdFwiXG4gICAgICAgICAgW3N0YXR1c109XCJzdW1tYXJ5TGlzdC5rZXlcIlxuICAgICAgICAgIFt0b3RhbEV2ZW50Q291bnRdPVwic3VtbWFyeUxpc3QudmFsdWUuY291bnRcIlxuICAgICAgICAgIFtldmVudHNdPVwic3VtbWFyeUxpc3QudmFsdWUuZXZlbnRzXCJcbiAgICAgICAgICBbY29uc3VsdExpbmtdPVwiY29uc3VsdExpbmtcIj5cbiAgICAgICAgPC9odnktZXZlbnQtc3VtbWFyeS1saXN0PlxuICAgICAgfVxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19