@provoly/hypervisor 0.0.21 → 0.0.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/svgs/i.svg +18 -0
- package/esm2022/src/lib/event/detail/event-detail.component.mjs +92 -32
- package/esm2022/src/lib/event/filters/choice/choice-filter.component.mjs +21 -21
- package/esm2022/src/lib/event/filters/date/date-filter.component.mjs +7 -9
- package/esm2022/src/lib/event/filters/event-filters.component.mjs +14 -9
- package/esm2022/src/lib/event/filters/hvy-unit-filter.class.mjs +21 -1
- package/esm2022/src/lib/event/list/event-list.component.mjs +10 -8
- package/esm2022/src/lib/event-summary/list/event-summary-list.component.mjs +4 -3
- package/esm2022/src/lib/event-summary/page/event-summary-page.component.mjs +12 -5
- package/esm2022/src/lib/general/i18n/en.translations.mjs +25 -18
- package/esm2022/src/lib/general/i18n/fr.translations.mjs +33 -24
- package/esm2022/src/lib/general/status-display/status-display.component.mjs +3 -3
- package/esm2022/src/lib/model/event/hyp-event-detail.interface.mjs +1 -1
- package/esm2022/src/lib/model/event/hyp-event-summary.interface.mjs +1 -1
- package/esm2022/src/lib/model/event/hyp-event.interface.mjs +1 -1
- package/esm2022/src/lib/store/event/event.actions.mjs +2 -2
- package/esm2022/src/lib/store/event/event.effects.mjs +3 -3
- package/esm2022/src/lib/store/event/event.reducer.mjs +15 -13
- package/esm2022/src/lib/store/event/event.service.mjs +21 -31
- package/esm2022/src/lib/store/event-summary/event-summary.service.mjs +5 -5
- package/fesm2022/provoly-hypervisor.mjs +316 -226
- package/fesm2022/provoly-hypervisor.mjs.map +1 -1
- package/package.json +1 -1
- package/src/lib/event/detail/event-detail.component.d.ts +16 -2
- package/src/lib/event/filters/choice/choice-filter.component.d.ts +6 -5
- package/src/lib/event/filters/date/date-filter.component.d.ts +5 -4
- package/src/lib/event/filters/event-filters.component.d.ts +5 -3
- package/src/lib/event/filters/hvy-unit-filter.class.d.ts +14 -2
- package/src/lib/event/list/event-list.component.d.ts +3 -0
- package/src/lib/general/i18n/en.translations.d.ts +7 -0
- package/src/lib/general/i18n/fr.translations.d.ts +9 -0
- package/src/lib/model/event/hyp-event-detail.interface.d.ts +1 -2
- package/src/lib/model/event/hyp-event-summary.interface.d.ts +0 -1
- package/src/lib/model/event/hyp-event.interface.d.ts +1 -0
- package/src/lib/model/hyp-procedure.interface.d.ts +1 -1
- package/src/lib/store/event/event.actions.d.ts +4 -0
- package/src/lib/store/event/event.service.d.ts +9 -3
- package/styles/components/_m-hvy-event-summary-item.scss +37 -7
- package/styles/components/_o-hvy-event-detail.scss +41 -0
- package/styles/components/_o-hvy-event-filters.scss +3 -0
- package/styles/components/_o-hvy-events-table.scss +2 -1
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { Component, computed, forwardRef, Input, signal, TemplateRef, ViewChild
|
|
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
4
|
import { OverlayConfig } from '@angular/cdk/overlay';
|
|
5
5
|
import { TemplatePortal } from '@angular/cdk/portal';
|
|
6
|
+
import { combineLatest } from 'rxjs';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@ngrx/store";
|
|
8
9
|
import * as i2 from "@angular/cdk/overlay";
|
|
@@ -19,12 +20,10 @@ export class ChoiceFilterComponent extends HvyUnitFilterComponent {
|
|
|
19
20
|
this.i18nService = i18nService;
|
|
20
21
|
this.ref = ref;
|
|
21
22
|
this.id = -1;
|
|
22
|
-
this.prop = 'no-prop-defined';
|
|
23
23
|
this.label = 'no-label-defined';
|
|
24
24
|
this.i18nPrefix = '';
|
|
25
25
|
this.value = signal([]);
|
|
26
26
|
this.choices = [];
|
|
27
|
-
this.inhibate = false;
|
|
28
27
|
this.displayValue = computed(() => {
|
|
29
28
|
if (this.allSelected()) {
|
|
30
29
|
return this.i18nService.instant('@hvy.event.filter.choice.all');
|
|
@@ -40,9 +39,12 @@ export class ChoiceFilterComponent extends HvyUnitFilterComponent {
|
|
|
40
39
|
this.id = ChoiceFilterComponent.idCounter++;
|
|
41
40
|
}
|
|
42
41
|
ngAfterViewInit() {
|
|
43
|
-
this.subscriptions.add(this.store.select(EventSelectors.filters).subscribe(filters => {
|
|
44
|
-
this.assignValue(filters.hasOwnProperty(this.prop)
|
|
45
|
-
filters[this.prop].length === 1 && filters[this.prop][0] === ''
|
|
42
|
+
this.subscriptions.add(combineLatest([this.store.select(EventSelectors.filters), this._filterSet$]).subscribe(([filters, filterSet]) => {
|
|
43
|
+
this.assignValue((filters[filterSet] ?? {}).hasOwnProperty(this.prop)
|
|
44
|
+
? filters[filterSet][this.prop].length === 1 && filters[filterSet][this.prop][0] === ''
|
|
45
|
+
? []
|
|
46
|
+
: filters[filterSet][this.prop]
|
|
47
|
+
: this.allValues());
|
|
46
48
|
}));
|
|
47
49
|
}
|
|
48
50
|
getParams() {
|
|
@@ -60,7 +62,7 @@ export class ChoiceFilterComponent extends HvyUnitFilterComponent {
|
|
|
60
62
|
this.overlayRef = this.overlay.create(new OverlayConfig({
|
|
61
63
|
hasBackdrop: true,
|
|
62
64
|
backdropClass: 'backdrop',
|
|
63
|
-
panelClass: ['m-context-menu-wrapper', 'o-choice-filter-popup']
|
|
65
|
+
panelClass: ['m-context-menu-wrapper', 'o-choice-filter-popup']
|
|
64
66
|
}));
|
|
65
67
|
this.overlayRef.backdropClick().subscribe(() => this.toggleModal());
|
|
66
68
|
this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));
|
|
@@ -86,49 +88,47 @@ export class ChoiceFilterComponent extends HvyUnitFilterComponent {
|
|
|
86
88
|
}
|
|
87
89
|
toggle(elt) {
|
|
88
90
|
const isSelected = this.isSelected(elt);
|
|
89
|
-
const eltSubKeys = !elt.children ? [elt.key] : elt.children.map(ch => ch.key);
|
|
91
|
+
const eltSubKeys = !elt.children ? [elt.key] : elt.children.map((ch) => ch.key);
|
|
90
92
|
if (!isSelected) {
|
|
91
93
|
this.assignValue([...new Set([...this.value(), ...eltSubKeys])]);
|
|
92
94
|
}
|
|
93
95
|
else {
|
|
94
|
-
this.assignValue(this.value().filter(v => !eltSubKeys.includes(v)));
|
|
96
|
+
this.assignValue(this.value().filter((v) => !eltSubKeys.includes(v)));
|
|
95
97
|
}
|
|
96
98
|
}
|
|
97
99
|
allSelected() {
|
|
98
|
-
return this.choices.map(choice => this.isSelected(choice)).reduce((p, c) => p && c, true);
|
|
100
|
+
return this.choices.map((choice) => this.isSelected(choice)).reduce((p, c) => p && c, true);
|
|
99
101
|
}
|
|
100
102
|
isSelected(choice) {
|
|
101
103
|
if (!choice.children) {
|
|
102
104
|
return this.value().includes(choice.key);
|
|
103
105
|
}
|
|
104
106
|
else {
|
|
105
|
-
return choice.children.map(child => this.isSelected(child)).reduce((p, c) => p && c, true);
|
|
107
|
+
return choice.children.map((child) => this.isSelected(child)).reduce((p, c) => p && c, true);
|
|
106
108
|
}
|
|
107
109
|
}
|
|
108
110
|
allValues() {
|
|
109
111
|
return this.choices
|
|
110
|
-
.map(choice => !choice.children ? [choice.key] : choice.children.map(child => child.key))
|
|
112
|
+
.map((choice) => (!choice.children ? [choice.key] : choice.children.map((child) => child.key)))
|
|
111
113
|
.reduce((p, c) => [...p, ...c], []);
|
|
112
114
|
}
|
|
113
115
|
assignValue(value) {
|
|
114
|
-
if (!this.inhibate) {
|
|
116
|
+
if (!this.inhibate || this.inhibate !== this.filterSet) {
|
|
115
117
|
this.triggerInhibate();
|
|
116
118
|
this.value.set(value);
|
|
117
119
|
}
|
|
118
120
|
}
|
|
119
121
|
triggerInhibate() {
|
|
120
|
-
this.inhibate =
|
|
121
|
-
setTimeout(() => this.inhibate =
|
|
122
|
+
this.inhibate = this.filterSet;
|
|
123
|
+
setTimeout(() => (this.inhibate = undefined), 50);
|
|
122
124
|
}
|
|
123
125
|
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: {
|
|
126
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: ChoiceFilterComponent, selector: "hvy-choice-filter", inputs: { 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 <div class=\"o-hvy-choice-filter__choice-value\">\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 </div>\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=\"choice\"\n tabindex=\"-1\"\n id=\"choice\"\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" }] }); }
|
|
125
127
|
}
|
|
126
128
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: ChoiceFilterComponent, decorators: [{
|
|
127
129
|
type: Component,
|
|
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 <div class=\"o-hvy-choice-filter__choice-value\">\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 </div>\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=\"
|
|
129
|
-
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i3.PryI18nService }, { type: i0.ElementRef }], propDecorators: {
|
|
130
|
-
type: Input
|
|
131
|
-
}], label: [{
|
|
130
|
+
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 <div class=\"o-hvy-choice-filter__choice-value\">\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 </div>\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=\"choice\"\n tabindex=\"-1\"\n id=\"choice\"\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" }]
|
|
131
|
+
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i3.PryI18nService }, { type: i0.ElementRef }], propDecorators: { label: [{
|
|
132
132
|
type: Input
|
|
133
133
|
}], i18nPrefix: [{
|
|
134
134
|
type: Input
|
|
@@ -138,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
138
138
|
type: ViewChild,
|
|
139
139
|
args: ['template', { read: TemplateRef }]
|
|
140
140
|
}] } });
|
|
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 = '';\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  <div class=\"o-hvy-choice-filter__choice-value\">\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  </div>\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"]}
|
|
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 { 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';\nimport { combineLatest } from 'rxjs';\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\n  @Input() label: string = 'no-label-defined';\n  @Input() i18nPrefix: string = '';\n  value: WritableSignal<string[]> = signal([]);\n  @Input() choices: HvyChoiceFilter = [];\n  overlayRef?: OverlayRef;\n  @ViewChild('template', { read: TemplateRef }) template!: TemplateRef<any>;\n  inhibate?: string;\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(\n    private store: Store,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private i18nService: PryI18nService,\n    private ref: ElementRef\n  ) {\n    super();\n    this.id = ChoiceFilterComponent.idCounter++;\n  }\n\n  ngAfterViewInit(): void {\n    this.subscriptions.add(\n      combineLatest([this.store.select(EventSelectors.filters), this._filterSet$]).subscribe(([filters, filterSet]) => {\n        this.assignValue(\n          (filters[filterSet] ?? {}).hasOwnProperty(this.prop)\n            ? filters[filterSet][this.prop].length === 1 && filters[filterSet][this.prop][0] === ''\n              ? []\n              : filters[filterSet][this.prop]\n            : this.allValues()\n        );\n      })\n    );\n  }\n\n  override getParams(): { [key: string]: string[] } {\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 || this.inhibate !== this.filterSet) {\n      this.triggerInhibate();\n      this.value.set(value);\n    }\n  }\n\n  private triggerInhibate() {\n    this.inhibate = this.filterSet;\n    setTimeout(() => (this.inhibate = undefined), 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  <div class=\"o-hvy-choice-filter__choice-value\">\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  </div>\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=\"choice\"\n    tabindex=\"-1\"\n    id=\"choice\"\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"]}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { Component, forwardRef
|
|
1
|
+
import { Component, forwardRef } from '@angular/core';
|
|
2
2
|
import { HvyUnitFilterComponent } from '../hvy-unit-filter.class';
|
|
3
3
|
import { EventSelectors } from '../../../store/event/event.selectors';
|
|
4
|
+
import { combineLatest } from 'rxjs';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@ngrx/store";
|
|
6
7
|
export class DateFilterComponent extends HvyUnitFilterComponent {
|
|
7
8
|
constructor(store) {
|
|
8
9
|
super();
|
|
9
10
|
this.store = store;
|
|
10
|
-
this.prop = 'no-prop-defined';
|
|
11
11
|
this.value = '';
|
|
12
|
-
this.subscriptions.add(this.store.select(EventSelectors.filters).subscribe(filters => {
|
|
13
|
-
this.value = filters[this.prop] ? (filters[this.prop][0] ?? ''
|
|
12
|
+
this.subscriptions.add(combineLatest([this.store.select(EventSelectors.filters), this._filterSet$]).subscribe(([filters, filterSet]) => {
|
|
13
|
+
this.value = (filters[filterSet] ?? {})[this.prop] ? (filters[filterSet] ?? {})[this.prop][0] ?? '' : '';
|
|
14
14
|
}));
|
|
15
15
|
}
|
|
16
16
|
getParams() {
|
|
@@ -27,12 +27,10 @@ export class DateFilterComponent extends HvyUnitFilterComponent {
|
|
|
27
27
|
this.value = $event instanceof Event ? $event.target?.value : $event;
|
|
28
28
|
}
|
|
29
29
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DateFilterComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
30
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: DateFilterComponent, selector: "hvy-date-filter",
|
|
30
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: DateFilterComponent, selector: "hvy-date-filter", providers: [{ provide: HvyUnitFilterComponent, useExisting: forwardRef(() => DateFilterComponent) }], usesInheritance: true, ngImport: i0, template: "<div class=\"o-hvy-date-filters\">\n <input type=\"date\" class=\"a-form-field\"\n [value]=\"value\"\n (change)=\"triggerChange($event)\">\n</div>\n" }); }
|
|
31
31
|
}
|
|
32
32
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DateFilterComponent, decorators: [{
|
|
33
33
|
type: Component,
|
|
34
34
|
args: [{ selector: 'hvy-date-filter', providers: [{ provide: HvyUnitFilterComponent, useExisting: forwardRef(() => DateFilterComponent) }], template: "<div class=\"o-hvy-date-filters\">\n <input type=\"date\" class=\"a-form-field\"\n [value]=\"value\"\n (change)=\"triggerChange($event)\">\n</div>\n" }]
|
|
35
|
-
}], ctorParameters: () => [{ type: i1.Store }]
|
|
36
|
-
|
|
37
|
-
}] } });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQvZmlsdGVycy9kYXRlL2RhdGUtZmlsdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvaHlwZXJ2aXNvci9zcmMvbGliL2V2ZW50L2ZpbHRlcnMvZGF0ZS9kYXRlLWZpbHRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0QsT0FBTyxFQUFtQixzQkFBc0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRW5GLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7O0FBT3RFLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxzQkFBc0I7SUFJN0QsWUFBb0IsS0FBWTtRQUM5QixLQUFLLEVBQUUsQ0FBQztRQURVLFVBQUssR0FBTCxLQUFLLENBQU87UUFIdkIsU0FBSSxHQUFXLGlCQUFpQixDQUFDO1FBQzFDLFVBQUssR0FBVyxFQUFFLENBQUM7UUFJakIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUNuRixJQUFJLENBQUMsS0FBSyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ3ZFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDTixDQUFDO0lBRVEsU0FBUztRQUNoQixJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssRUFBRSxFQUFFLENBQUM7WUFDdEIsT0FBTyxFQUFFLENBQUM7UUFDWixDQUFDO1FBQ0QsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLEVBQUUsQ0FBQztJQUMvRCxDQUFDO0lBRVEsS0FBSztRQUNaLElBQUksQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDO0lBQ2xCLENBQUM7SUFFRCxhQUFhLENBQUMsTUFBYTtRQUN6QixhQUFhO1FBQ2IsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLFlBQVksS0FBSyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ3ZFLENBQUM7OEdBekJVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLG9FQUZuQixDQUFDLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsbUJBQW1CLENBQUMsRUFBRSxDQUFDLGlEQ1J0Ryx1S0FLQTs7MkZES2EsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGlCQUFpQixhQUVoQixDQUFDLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLG9CQUFvQixDQUFDLEVBQUUsQ0FBQzswRUFHM0YsSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBmb3J3YXJkUmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSHZ5RmlsdGVyUGFyYW1zLCBIdnlVbml0RmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vaHZ5LXVuaXQtZmlsdGVyLmNsYXNzJztcbmltcG9ydCB7IFN0b3JlIH0gZnJvbSAnQG5ncngvc3RvcmUnO1xuaW1wb3J0IHsgRXZlbnRTZWxlY3RvcnMgfSBmcm9tICcuLi8uLi8uLi9zdG9yZS9ldmVudC9ldmVudC5zZWxlY3RvcnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdodnktZGF0ZS1maWx0ZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZGF0ZS1maWx0ZXIuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFt7IHByb3ZpZGU6IEh2eVVuaXRGaWx0ZXJDb21wb25lbnQsIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IERhdGVGaWx0ZXJDb21wb25lbnQpIH1dLFxufSlcbmV4cG9ydCBjbGFzcyBEYXRlRmlsdGVyQ29tcG9uZW50IGV4dGVuZHMgSHZ5VW5pdEZpbHRlckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHByb3A6IHN0cmluZyA9ICduby1wcm9wLWRlZmluZWQnO1xuICB2YWx1ZTogc3RyaW5nID0gJyc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmUpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5hZGQodGhpcy5zdG9yZS5zZWxlY3QoRXZlbnRTZWxlY3RvcnMuZmlsdGVycykuc3Vic2NyaWJlKGZpbHRlcnMgPT4ge1xuICAgICAgdGhpcy52YWx1ZSA9IGZpbHRlcnNbdGhpcy5wcm9wXSA/IChmaWx0ZXJzW3RoaXMucHJvcF1bMF0gPz8gJycpIDogJyc7XG4gICAgfSkpO1xuICB9XG5cbiAgb3ZlcnJpZGUgZ2V0UGFyYW1zKCk6IEh2eUZpbHRlclBhcmFtcyB7XG4gICAgaWYgKHRoaXMudmFsdWUgPT09ICcnKSB7XG4gICAgICByZXR1cm4ge307XG4gICAgfVxuICAgIHJldHVybiB7IFt0aGlzLnByb3BdOiBbbmV3IERhdGUodGhpcy52YWx1ZSkudG9JU09TdHJpbmcoKV0gfTtcbiAgfVxuXG4gIG92ZXJyaWRlIHJlc2V0KCk6IHZvaWQge1xuICAgIHRoaXMudmFsdWUgPSAnJztcbiAgfVxuXG4gIHRyaWdnZXJDaGFuZ2UoJGV2ZW50OiBFdmVudCkge1xuICAgIC8vIEB0cy1pZ25vcmVcbiAgICB0aGlzLnZhbHVlID0gJGV2ZW50IGluc3RhbmNlb2YgRXZlbnQgPyAkZXZlbnQudGFyZ2V0Py52YWx1ZSA6ICRldmVudDtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm8taHZ5LWRhdGUtZmlsdGVyc1wiPlxuICA8aW5wdXQgdHlwZT1cImRhdGVcIiBjbGFzcz1cImEtZm9ybS1maWVsZFwiXG4gICAgICAgICBbdmFsdWVdPVwidmFsdWVcIlxuICAgICAgICAgKGNoYW5nZSk9XCJ0cmlnZ2VyQ2hhbmdlKCRldmVudClcIj5cbjwvZGl2PlxuIl19
|
|
35
|
+
}], ctorParameters: () => [{ type: i1.Store }] });
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQvZmlsdGVycy9kYXRlL2RhdGUtZmlsdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvaHlwZXJ2aXNvci9zcmMvbGliL2V2ZW50L2ZpbHRlcnMvZGF0ZS9kYXRlLWZpbHRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUVsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7O0FBT3JDLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxzQkFBc0I7SUFHN0QsWUFBb0IsS0FBWTtRQUM5QixLQUFLLEVBQUUsQ0FBQztRQURVLFVBQUssR0FBTCxLQUFLLENBQU87UUFGaEMsVUFBSyxHQUFXLEVBQUUsQ0FBQztRQUlqQixJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FDcEIsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxFQUFFLEVBQUU7WUFDOUcsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUMzRyxDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQztJQUVRLFNBQVM7UUFDaEIsSUFBSSxJQUFJLENBQUMsS0FBSyxLQUFLLEVBQUUsRUFBRSxDQUFDO1lBQ3RCLE9BQU8sRUFBRSxDQUFDO1FBQ1osQ0FBQztRQUNELE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxFQUFFLENBQUM7SUFDL0QsQ0FBQztJQUVRLEtBQUs7UUFDWixJQUFJLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQztJQUNsQixDQUFDO0lBRUQsYUFBYSxDQUFDLE1BQWE7UUFDekIsYUFBYTtRQUNiLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTSxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUN2RSxDQUFDOzhHQTFCVSxtQkFBbUI7a0dBQW5CLG1CQUFtQiwwQ0FGbkIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLG1CQUFtQixDQUFDLEVBQUUsQ0FBQyxpRENUdEcsdUtBS0E7OzJGRE1hLG1CQUFtQjtrQkFML0IsU0FBUzsrQkFDRSxpQkFBaUIsYUFFaEIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxvQkFBb0IsQ0FBQyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGZvcndhcmRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEh2eVVuaXRGaWx0ZXJDb21wb25lbnQgfSBmcm9tICcuLi9odnktdW5pdC1maWx0ZXIuY2xhc3MnO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQgeyBFdmVudFNlbGVjdG9ycyB9IGZyb20gJy4uLy4uLy4uL3N0b3JlL2V2ZW50L2V2ZW50LnNlbGVjdG9ycyc7XG5pbXBvcnQgeyBjb21iaW5lTGF0ZXN0IH0gZnJvbSAncnhqcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2h2eS1kYXRlLWZpbHRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9kYXRlLWZpbHRlci5jb21wb25lbnQuaHRtbCcsXG4gIHByb3ZpZGVyczogW3sgcHJvdmlkZTogSHZ5VW5pdEZpbHRlckNvbXBvbmVudCwgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gRGF0ZUZpbHRlckNvbXBvbmVudCkgfV1cbn0pXG5leHBvcnQgY2xhc3MgRGF0ZUZpbHRlckNvbXBvbmVudCBleHRlbmRzIEh2eVVuaXRGaWx0ZXJDb21wb25lbnQge1xuICB2YWx1ZTogc3RyaW5nID0gJyc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmUpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5hZGQoXG4gICAgICBjb21iaW5lTGF0ZXN0KFt0aGlzLnN0b3JlLnNlbGVjdChFdmVudFNlbGVjdG9ycy5maWx0ZXJzKSwgdGhpcy5fZmlsdGVyU2V0JF0pLnN1YnNjcmliZSgoW2ZpbHRlcnMsIGZpbHRlclNldF0pID0+IHtcbiAgICAgICAgdGhpcy52YWx1ZSA9IChmaWx0ZXJzW2ZpbHRlclNldF0gPz8ge30pW3RoaXMucHJvcF0gPyAoZmlsdGVyc1tmaWx0ZXJTZXRdID8/IHt9KVt0aGlzLnByb3BdWzBdID8/ICcnIDogJyc7XG4gICAgICB9KVxuICAgICk7XG4gIH1cblxuICBvdmVycmlkZSBnZXRQYXJhbXMoKTogeyBba2V5OiBzdHJpbmddOiBzdHJpbmdbXSB9IHtcbiAgICBpZiAodGhpcy52YWx1ZSA9PT0gJycpIHtcbiAgICAgIHJldHVybiB7fTtcbiAgICB9XG4gICAgcmV0dXJuIHsgW3RoaXMucHJvcF06IFtuZXcgRGF0ZSh0aGlzLnZhbHVlKS50b0lTT1N0cmluZygpXSB9O1xuICB9XG5cbiAgb3ZlcnJpZGUgcmVzZXQoKTogdm9pZCB7XG4gICAgdGhpcy52YWx1ZSA9ICcnO1xuICB9XG5cbiAgdHJpZ2dlckNoYW5nZSgkZXZlbnQ6IEV2ZW50KSB7XG4gICAgLy8gQHRzLWlnbm9yZVxuICAgIHRoaXMudmFsdWUgPSAkZXZlbnQgaW5zdGFuY2VvZiBFdmVudCA/ICRldmVudC50YXJnZXQ/LnZhbHVlIDogJGV2ZW50O1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiby1odnktZGF0ZS1maWx0ZXJzXCI+XG4gIDxpbnB1dCB0eXBlPVwiZGF0ZVwiIGNsYXNzPVwiYS1mb3JtLWZpZWxkXCJcbiAgICAgICAgIFt2YWx1ZV09XCJ2YWx1ZVwiXG4gICAgICAgICAoY2hhbmdlKT1cInRyaWdnZXJDaGFuZ2UoJGV2ZW50KVwiPlxuPC9kaXY+XG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, ContentChildren } from '@angular/core';
|
|
1
|
+
import { Component, ContentChildren, Input } from '@angular/core';
|
|
2
2
|
import { SubscriptionnerDirective } from '@provoly/dashboard';
|
|
3
3
|
import { EventActions } from '../../store/event/event.actions';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -8,24 +8,29 @@ export class EventFiltersComponent extends SubscriptionnerDirective {
|
|
|
8
8
|
constructor(store) {
|
|
9
9
|
super();
|
|
10
10
|
this.store = store;
|
|
11
|
+
this.filterSet = 'global';
|
|
12
|
+
}
|
|
13
|
+
ngAfterViewInit() {
|
|
14
|
+
this.filters.forEach((filter) => (filter.filterSet = this.filterSet));
|
|
11
15
|
}
|
|
12
16
|
filter() {
|
|
13
|
-
const filters = this.filters.map(filter => filter.getParams())
|
|
14
|
-
|
|
15
|
-
this.store.dispatch(EventActions.filter({ filters }));
|
|
17
|
+
const filters = this.filters.map((filter) => filter.getParams()).reduce((p, c) => ({ ...p, ...c }), {});
|
|
18
|
+
this.store.dispatch(EventActions.filter({ filters, filterSet: this.filterSet }));
|
|
16
19
|
}
|
|
17
20
|
reset() {
|
|
18
|
-
this.filters.forEach(filter => filter.reset());
|
|
19
|
-
this.store.dispatch(EventActions.filter({ filters: {} }));
|
|
21
|
+
this.filters.forEach((filter) => filter.reset());
|
|
22
|
+
this.store.dispatch(EventActions.filter({ filters: {}, filterSet: this.filterSet }));
|
|
20
23
|
}
|
|
21
24
|
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"], 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" }] }); }
|
|
25
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: EventFiltersComponent, selector: "hvy-event-filters", inputs: { filterSet: "filterSet" }, 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
26
|
}
|
|
24
27
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: EventFiltersComponent, decorators: [{
|
|
25
28
|
type: Component,
|
|
26
29
|
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
|
-
}], ctorParameters: () => [{ type: i1.Store }], propDecorators: {
|
|
30
|
+
}], ctorParameters: () => [{ type: i1.Store }], propDecorators: { filterSet: [{
|
|
31
|
+
type: Input
|
|
32
|
+
}], filters: [{
|
|
28
33
|
type: ContentChildren,
|
|
29
34
|
args: ['filter', { descendants: true }]
|
|
30
35
|
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtZmlsdGVycy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2h5cGVydmlzb3Ivc3JjL2xpYi9ldmVudC9maWx0ZXJzL2V2ZW50LWZpbHRlcnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQvZmlsdGVycy9ldmVudC1maWx0ZXJzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsU0FBUyxFQUFFLGVBQWUsRUFBRSxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFDNUYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFHOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlDQUFpQyxDQUFDOzs7O0FBTS9ELE1BQU0sT0FBTyxxQkFBc0IsU0FBUSx3QkFBd0I7SUFJakUsWUFBb0IsS0FBWTtRQUM5QixLQUFLLEVBQUUsQ0FBQztRQURVLFVBQUssR0FBTCxLQUFLLENBQU87UUFIdkIsY0FBUyxHQUFHLFFBQVEsQ0FBQztJQUs5QixDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDeEUsQ0FBQztJQUVELE1BQU07UUFDSixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUN4RyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBQ2pELElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ3ZGLENBQUM7OEdBcEJVLHFCQUFxQjtrR0FBckIscUJBQXFCLHNNQ1ZsQyx3Y0FZQTs7MkZERmEscUJBQXFCO2tCQUpqQyxTQUFTOytCQUNFLG1CQUFtQjswRUFJcEIsU0FBUztzQkFBakIsS0FBSztnQkFDNEMsT0FBTztzQkFBeEQsZUFBZTt1QkFBQyxRQUFRLEVBQUUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ29tcG9uZW50LCBDb250ZW50Q2hpbGRyZW4sIElucHV0LCBRdWVyeUxpc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbm5lckRpcmVjdGl2ZSB9IGZyb20gJ0Bwcm92b2x5L2Rhc2hib2FyZCc7XG5pbXBvcnQgeyBIdnlVbml0RmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi9odnktdW5pdC1maWx0ZXIuY2xhc3MnO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQgeyBFdmVudEFjdGlvbnMgfSBmcm9tICcuLi8uLi9zdG9yZS9ldmVudC9ldmVudC5hY3Rpb25zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaHZ5LWV2ZW50LWZpbHRlcnMnLFxuICB0ZW1wbGF0ZVVybDogJy4vZXZlbnQtZmlsdGVycy5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgRXZlbnRGaWx0ZXJzQ29tcG9uZW50IGV4dGVuZHMgU3Vic2NyaXB0aW9ubmVyRGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCgpIGZpbHRlclNldCA9ICdnbG9iYWwnO1xuICBAQ29udGVudENoaWxkcmVuKCdmaWx0ZXInLCB7IGRlc2NlbmRhbnRzOiB0cnVlIH0pIGZpbHRlcnMhOiBRdWVyeUxpc3Q8SHZ5VW5pdEZpbHRlckNvbXBvbmVudD47XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmUpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIHRoaXMuZmlsdGVycy5mb3JFYWNoKChmaWx0ZXIpID0+IChmaWx0ZXIuZmlsdGVyU2V0ID0gdGhpcy5maWx0ZXJTZXQpKTtcbiAgfVxuXG4gIGZpbHRlcigpIHtcbiAgICBjb25zdCBmaWx0ZXJzID0gdGhpcy5maWx0ZXJzLm1hcCgoZmlsdGVyKSA9PiBmaWx0ZXIuZ2V0UGFyYW1zKCkpLnJlZHVjZSgocCwgYykgPT4gKHsgLi4ucCwgLi4uYyB9KSwge30pO1xuICAgIHRoaXMuc3RvcmUuZGlzcGF0Y2goRXZlbnRBY3Rpb25zLmZpbHRlcih7IGZpbHRlcnMsIGZpbHRlclNldDogdGhpcy5maWx0ZXJTZXQgfSkpO1xuICB9XG5cbiAgcmVzZXQoKSB7XG4gICAgdGhpcy5maWx0ZXJzLmZvckVhY2goKGZpbHRlcikgPT4gZmlsdGVyLnJlc2V0KCkpO1xuICAgIHRoaXMuc3RvcmUuZGlzcGF0Y2goRXZlbnRBY3Rpb25zLmZpbHRlcih7IGZpbHRlcnM6IHt9LCBmaWx0ZXJTZXQ6IHRoaXMuZmlsdGVyU2V0IH0pKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LWZpbHRlcnNcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8ZGl2IGNsYXNzPVwiby1odnktZXZlbnQtZmlsdGVyc19fYnV0dG9uc1wiPlxuICAgIDxidXR0b24gKGNsaWNrKT1cInJlc2V0KClcIiBjbGFzcz1cImEtYnRuIGEtYnRuLS1zZWNvbmRhcnlcIj5cbiAgICAgIDxwcnktaWNvbiBpY29uU3ZnPVwicmVzZXRfZmlsdGVyX2V2ZW50XCI+PC9wcnktaWNvbj5cbiAgICA8L2J1dHRvbj5cbiAgICA8YnV0dG9uIChjbGljayk9XCJmaWx0ZXIoKVwiIGNsYXNzPVwiYS1idG4gYS1idG4tLXByaW1hcnlcIj5cbiAgICAgIHt7ICdAaHZ5LmV2ZW50LmZpbHRlci5uYW1lJyB8IGkxOG4gfX1cbiAgICAgIDxwcnktaWNvbiBpY29uU3ZnPVwiZXZlbnRfZmlsdGVyXCI+PC9wcnktaWNvbj5cbiAgICA8L2J1dHRvbj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -1,7 +1,18 @@
|
|
|
1
1
|
import { SubscriptionnerDirective } from '@provoly/dashboard';
|
|
2
|
+
import { Directive, Input } from '@angular/core';
|
|
3
|
+
import { BehaviorSubject } from 'rxjs';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
2
5
|
export class HvyUnitFilterComponent extends SubscriptionnerDirective {
|
|
6
|
+
set filterSet(filterSet) {
|
|
7
|
+
this._filterSet$.next(filterSet);
|
|
8
|
+
}
|
|
9
|
+
get filterSet() {
|
|
10
|
+
return this._filterSet$.value;
|
|
11
|
+
}
|
|
3
12
|
constructor() {
|
|
4
13
|
super();
|
|
14
|
+
this.prop = 'no-prop-defined';
|
|
15
|
+
this._filterSet$ = new BehaviorSubject('global');
|
|
5
16
|
}
|
|
6
17
|
getParams() {
|
|
7
18
|
throw new Error('Must use sub implementation');
|
|
@@ -9,5 +20,14 @@ export class HvyUnitFilterComponent extends SubscriptionnerDirective {
|
|
|
9
20
|
reset() {
|
|
10
21
|
throw new Error('Must use sub implementation');
|
|
11
22
|
}
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: HvyUnitFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
24
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.3", type: HvyUnitFilterComponent, inputs: { prop: "prop", filterSet: "filterSet" }, usesInheritance: true, ngImport: i0 }); }
|
|
12
25
|
}
|
|
13
|
-
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: HvyUnitFilterComponent, decorators: [{
|
|
27
|
+
type: Directive
|
|
28
|
+
}], ctorParameters: () => [], propDecorators: { prop: [{
|
|
29
|
+
type: Input
|
|
30
|
+
}], filterSet: [{
|
|
31
|
+
type: Input
|
|
32
|
+
}] } });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHZ5LXVuaXQtZmlsdGVyLmNsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQvZmlsdGVycy9odnktdW5pdC1maWx0ZXIuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDOUQsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFLdkMsTUFBTSxPQUFPLHNCQUF1QixTQUFRLHdCQUF3QjtJQUlsRSxJQUFhLFNBQVMsQ0FBQyxTQUFpQjtRQUN0QyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQztJQUNoQyxDQUFDO0lBRUQ7UUFDRSxLQUFLLEVBQUUsQ0FBQztRQVpELFNBQUksR0FBVyxpQkFBaUIsQ0FBQztRQUNoQyxnQkFBVyxHQUFHLElBQUksZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBWXRELENBQUM7SUFFRCxTQUFTO1FBQ1AsTUFBTSxJQUFJLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFRCxLQUFLO1FBQ0gsTUFBTSxJQUFJLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0lBQ2pELENBQUM7OEdBdEJVLHNCQUFzQjtrR0FBdEIsc0JBQXNCOzsyRkFBdEIsc0JBQXNCO2tCQURsQyxTQUFTO3dEQUVDLElBQUk7c0JBQVosS0FBSztnQkFHTyxTQUFTO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3Vic2NyaXB0aW9ubmVyRGlyZWN0aXZlIH0gZnJvbSAnQHByb3ZvbHkvZGFzaGJvYXJkJztcbmltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgdHlwZSBIdnlGaWx0ZXJQYXJhbXMgPSB7IFtmaWx0ZXJTZXQ6IHN0cmluZ106IHsgW2tleTogc3RyaW5nXTogc3RyaW5nW10gfSB9O1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBjbGFzcyBIdnlVbml0RmlsdGVyQ29tcG9uZW50IGV4dGVuZHMgU3Vic2NyaXB0aW9ubmVyRGlyZWN0aXZlIHtcbiAgQElucHV0KCkgcHJvcDogc3RyaW5nID0gJ25vLXByb3AtZGVmaW5lZCc7XG4gIHByb3RlY3RlZCBfZmlsdGVyU2V0JCA9IG5ldyBCZWhhdmlvclN1YmplY3QoJ2dsb2JhbCcpO1xuXG4gIEBJbnB1dCgpIHNldCBmaWx0ZXJTZXQoZmlsdGVyU2V0OiBzdHJpbmcpIHtcbiAgICB0aGlzLl9maWx0ZXJTZXQkLm5leHQoZmlsdGVyU2V0KTtcbiAgfVxuXG4gIGdldCBmaWx0ZXJTZXQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2ZpbHRlclNldCQudmFsdWU7XG4gIH1cblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgZ2V0UGFyYW1zKCk6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nW10gfSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNdXN0IHVzZSBzdWIgaW1wbGVtZW50YXRpb24nKTtcbiAgfVxuXG4gIHJlc2V0KCk6IHZvaWQge1xuICAgIHRocm93IG5ldyBFcnJvcignTXVzdCB1c2Ugc3ViIGltcGxlbWVudGF0aW9uJyk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -15,8 +15,9 @@ import * as i8 from "@angular/common";
|
|
|
15
15
|
import * as i9 from "@provoly/dashboard";
|
|
16
16
|
import * as i10 from "@provoly/dashboard/components/sinceDate";
|
|
17
17
|
export const EVENT_LINK = {
|
|
18
|
-
fn: (event, store) => ['./', event.id]
|
|
18
|
+
fn: (event, store) => ['./', event.id]
|
|
19
19
|
};
|
|
20
|
+
export const SCROLL_PX_TO_TRIGGER_FETCH_PAGE = { value: 200 };
|
|
20
21
|
export class EventListComponent extends SubscriptionnerDirective {
|
|
21
22
|
constructor(store, el) {
|
|
22
23
|
super();
|
|
@@ -24,11 +25,11 @@ export class EventListComponent extends SubscriptionnerDirective {
|
|
|
24
25
|
this.el = el;
|
|
25
26
|
this.EVENT_LINK = EVENT_LINK;
|
|
26
27
|
this._store = this.store;
|
|
27
|
-
this._inhibate =
|
|
28
|
+
this._inhibate = true;
|
|
28
29
|
this.store.dispatch(EventActions.load({}));
|
|
29
30
|
this.events$ = this.store.select(EventSelectors.events);
|
|
30
31
|
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));
|
|
32
|
+
this.allSelected$ = combineLatest([this.events$, this.selectedIds$]).pipe(map(([events, selectedIds]) => events.filter((ev) => !selectedIds.includes(ev.id)).length === 0));
|
|
32
33
|
}
|
|
33
34
|
ngAfterViewInit() {
|
|
34
35
|
this.subscriptions.add(fromEvent(this.el.nativeElement, 'scroll')
|
|
@@ -37,7 +38,8 @@ export class EventListComponent extends SubscriptionnerDirective {
|
|
|
37
38
|
map((e) => {
|
|
38
39
|
const target = e.currentTarget;
|
|
39
40
|
return target.scrollHeight - target.offsetHeight - target.scrollTop;
|
|
40
|
-
}), withLatestFrom(this.store.select(EventSelectors.noMoreEvents)), filter(([remaningScroll, noMore]) => !noMore && remaningScroll <
|
|
41
|
+
}), withLatestFrom(this.store.select(EventSelectors.noMoreEvents)), filter(([remaningScroll, noMore]) => !noMore && remaningScroll < SCROLL_PX_TO_TRIGGER_FETCH_PAGE.value), auditTime(200))
|
|
42
|
+
.subscribe(() => {
|
|
41
43
|
this.store.dispatch(EventActions.load({ next: true }));
|
|
42
44
|
}));
|
|
43
45
|
}
|
|
@@ -50,15 +52,15 @@ export class EventListComponent extends SubscriptionnerDirective {
|
|
|
50
52
|
selectAll($event) {
|
|
51
53
|
if (!this._inhibate) {
|
|
52
54
|
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
|
+
const tmpSub = this.events$.subscribe((events) => {
|
|
56
|
+
this.store.dispatch(EventActions.select({ ids: $event ? events.map((ev) => ev.id) : [], cumulative: false }));
|
|
55
57
|
setTimeout(() => tmpSub.unsubscribe(), 10);
|
|
56
58
|
});
|
|
57
59
|
}
|
|
58
60
|
}
|
|
59
61
|
inhibate() {
|
|
60
62
|
this._inhibate = true;
|
|
61
|
-
setTimeout(() => this._inhibate = false, 100);
|
|
63
|
+
setTimeout(() => (this._inhibate = false), 100);
|
|
62
64
|
}
|
|
63
65
|
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 }); }
|
|
64
66
|
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=\"status\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"procedureProgress\">{{ '@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" }] }); }
|
|
@@ -67,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
67
69
|
type: Component,
|
|
68
70
|
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=\"status\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n </th>\n <th>\n <hvy-column-order field=\"procedureProgress\">{{ '@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" }]
|
|
69
71
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i0.ElementRef }] });
|
|
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":"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,aAAa,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,EAAc,cAAc,EAAE,MAAM,MAAM,CAAC;AACpG,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;IAQ9D,YAAoB,KAAiB,EAAU,EAAc;QAC3D,KAAK,EAAE,CAAC;QADU,UAAK,GAAL,KAAK,CAAY;QAAU,OAAE,GAAF,EAAE,CAAY;QAL7D,eAAU,GAAG,UAAU,CAAC;QACxB,WAAM,GAAG,IAAI,CAAC,KAAK,CAAC;QAEpB,cAAS,GAAG,KAAK,CAAC;QAIhB,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;QAClE,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;IAC5K,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,QAAQ,EAAE,CAAC;QAChB,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;IAED,SAAS,CAAC,MAAW;QACnB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;gBAC7C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,UAAU,EAAE,KAAK,EAAC,CAAC,CAAC,CAAC;gBAC3G,UAAU,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,EAAE,EAAE,CAAC,CAAC;YAC7C,CAAC,CAAC,CAAC;QAEL,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC;IAChD,CAAC;8GAtDU,kBAAkB;kGAAlB,kBAAkB,6ECjB/B,2/FAuEA;;2FDtDa,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, 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=\"status\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n    </th>\n    <th>\n      <hvy-column-order field=\"procedureProgress\">{{ '@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"]}
|
|
72
|
+
//# 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\nexport const SCROLL_PX_TO_TRIGGER_FETCH_PAGE = { value: 200 };\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 = true;\n\n  constructor(\n    private store: Store<any>,\n    private el: ElementRef\n  ) {\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(\n      map(([events, selectedIds]) => events.filter((ev) => !selectedIds.includes(ev.id)).length === 0)\n    );\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 < SCROLL_PX_TO_TRIGGER_FETCH_PAGE.value),\n          auditTime(200)\n        )\n        .subscribe(() => {\n          this.store.dispatch(EventActions.load({ next: true }));\n        })\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  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=\"status\">{{ '@hvy.event.status.name' | i18n }}</hvy-column-order>\n    </th>\n    <th>\n      <hvy-column-order field=\"procedureProgress\">{{ '@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"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import { EventActions } from '../../store/event/event.actions';
|
|
3
|
+
import { KNOWN_FILTER_SETS } from '../../store/event/event.service';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@ngrx/store";
|
|
5
6
|
import * as i2 from "@angular/router";
|
|
@@ -20,8 +21,8 @@ export class EventSummaryListComponent {
|
|
|
20
21
|
this.itemLinkBase = this.itemLinkBase.length > 0 ? this.itemLinkBase : ['events'];
|
|
21
22
|
}
|
|
22
23
|
filterAndRoute(status) {
|
|
23
|
-
this.router.navigate([...this.consultLink]);
|
|
24
|
-
this.store.dispatch(EventActions.filter({ filters: { status: [status] } }));
|
|
24
|
+
this.router.navigate([...this.consultLink], { queryParams: { status: this.status } });
|
|
25
|
+
this.store.dispatch(EventActions.filter({ filters: { status: [status] }, filterSet: KNOWN_FILTER_SETS.EVENTS }));
|
|
25
26
|
}
|
|
26
27
|
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
28
|
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 <a class=\"o-hvy-event-summary-list__footer-button\" (click)=\"filterAndRoute(status)\">\n > {{ '@hvy.action.consult' | i18n }}\n <pry-icon iconSvg=\"arrow\"></pry-icon>\n </a>\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" }] }); }
|
|
@@ -40,4 +41,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
40
41
|
}], itemLinkBase: [{
|
|
41
42
|
type: Input
|
|
42
43
|
}] } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtc3VtbWFyeS1saXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvaHlwZXJ2aXNvci9zcmMvbGliL2V2ZW50LXN1bW1hcnkvbGlzdC9ldmVudC1zdW1tYXJ5LWxpc3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9oeXBlcnZpc29yL3NyYy9saWIvZXZlbnQtc3VtbWFyeS9saXN0L2V2ZW50LXN1bW1hcnktbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUd6RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFL0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7Ozs7OztBQU1wRSxNQUFNLE9BQU8seUJBQXlCO0lBT3BDLFlBQ1UsS0FBaUIsRUFDakIsTUFBYztRQURkLFVBQUssR0FBTCxLQUFLLENBQVk7UUFDakIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQVJmLFdBQU0sR0FBc0IsRUFBRSxDQUFDO1FBQy9CLG9CQUFlLEdBQUcsQ0FBQyxDQUFDO1FBQ3BCLFdBQU0sR0FBVyxFQUFFLENBQUM7UUFDcEIsZ0JBQVcsR0FBYSxFQUFFLENBQUM7UUFDM0IsaUJBQVksR0FBYSxFQUFFLENBQUM7SUFLbEMsQ0FBQztJQUVKLFFBQVE7UUFDTixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvRSxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNwRixDQUFDO0lBRUQsY0FBYyxDQUFDLE1BQWM7UUFDM0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsRUFBRSxFQUFFLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ3RGLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRSxPQUFPLEVBQUUsRUFBRSxNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDbkgsQ0FBQzs4R0FwQlUseUJBQXlCO2tHQUF6Qix5QkFBeUIsNE1DWHRDLHEvQkE0QkE7OzJGRGpCYSx5QkFBeUI7a0JBSnJDLFNBQVM7K0JBQ0Usd0JBQXdCOytGQUl6QixNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQgeyBFdmVudEFjdGlvbnMgfSBmcm9tICcuLi8uLi9zdG9yZS9ldmVudC9ldmVudC5hY3Rpb25zJztcbmltcG9ydCB7IEh5cEV2ZW50U3VtbWFyeSB9IGZyb20gJy4uLy4uL21vZGVsL2V2ZW50L2h5cC1ldmVudC1zdW1tYXJ5LmludGVyZmFjZSc7XG5pbXBvcnQgeyBLTk9XTl9GSUxURVJfU0VUUyB9IGZyb20gJy4uLy4uL3N0b3JlL2V2ZW50L2V2ZW50LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdodnktZXZlbnQtc3VtbWFyeS1saXN0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2V2ZW50LXN1bW1hcnktbGlzdC5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgRXZlbnRTdW1tYXJ5TGlzdENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIGV2ZW50czogSHlwRXZlbnRTdW1tYXJ5W10gPSBbXTtcbiAgQElucHV0KCkgdG90YWxFdmVudENvdW50ID0gMDtcbiAgQElucHV0KCkgc3RhdHVzOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgY29uc3VsdExpbms6IHN0cmluZ1tdID0gW107XG4gIEBJbnB1dCgpIGl0ZW1MaW5rQmFzZTogc3RyaW5nW10gPSBbXTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHN0b3JlOiBTdG9yZTxhbnk+LFxuICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXJcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuY29uc3VsdExpbmsgPSB0aGlzLmNvbnN1bHRMaW5rLmxlbmd0aCA+IDAgPyB0aGlzLmNvbnN1bHRMaW5rIDogWydldmVudHMnXTtcbiAgICB0aGlzLml0ZW1MaW5rQmFzZSA9IHRoaXMuaXRlbUxpbmtCYXNlLmxlbmd0aCA+IDAgPyB0aGlzLml0ZW1MaW5rQmFzZSA6IFsnZXZlbnRzJ107XG4gIH1cblxuICBmaWx0ZXJBbmRSb3V0ZShzdGF0dXM6IHN0cmluZykge1xuICAgIHRoaXMucm91dGVyLm5hdmlnYXRlKFsuLi50aGlzLmNvbnN1bHRMaW5rXSwgeyBxdWVyeVBhcmFtczogeyBzdGF0dXM6IHRoaXMuc3RhdHVzIH0gfSk7XG4gICAgdGhpcy5zdG9yZS5kaXNwYXRjaChFdmVudEFjdGlvbnMuZmlsdGVyKHsgZmlsdGVyczogeyBzdGF0dXM6IFtzdGF0dXNdIH0sIGZpbHRlclNldDogS05PV05fRklMVEVSX1NFVFMuRVZFTlRTIH0pKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdCAtaHZ5LXt7c3RhdHVzLnRvTG93ZXJDYXNlKCl9fVwiPlxuICA8ZGl2IGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1saXN0X19oZWFkZXJcIj5cbiAgICA8aDMgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3RfX3RpdGxlXCI+XG4gICAgICB7eyAnQGh2eS5ldmVudFN1bW1hcnkuc3RhdHVzTGFiZWxzLicgKyBzdGF0dXMgfCBpMThuIH19XG4gICAgPC9oMz5cbiAgICA8c3BhbiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdF9fY291bnRlclwiPlxuICAgICAge3sgdG90YWxFdmVudENvdW50IH19XG4gICAgPC9zcGFuPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm8taHZ5LWV2ZW50LXN1bW1hcnktbGlzdF9fY29udGVudFwiPlxuICAgIEBmb3IgKGV2ZW50IG9mIGV2ZW50czt0cmFjayBldmVudC5pZCkge1xuICAgICAgPGh2eS1ldmVudC1zdW1tYXJ5LWl0ZW1cbiAgICAgICAgW2V2ZW50XT1cImV2ZW50XCJcbiAgICAgICAgW2xpbmtCYXNlXT1cIml0ZW1MaW5rQmFzZVwiPlxuICAgICAgPC9odnktZXZlbnQtc3VtbWFyeS1pdGVtPlxuICAgIH0gQGVtcHR5IHtcbiAgICAgIDxzcGFuIGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1saXN0X19uby1jb250ZW50XCI+XG4gICAgICAgIHt7ICdAaHZ5LmV2ZW50U3VtbWFyeS5ub0NvbnRlbnQnIHwgaTE4biB9fVxuICAgICAgPC9zcGFuPlxuICAgIH1cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJvLWh2eS1ldmVudC1zdW1tYXJ5LWxpc3RfX2Zvb3RlclwiPlxuICAgIDxhIGNsYXNzPVwiby1odnktZXZlbnQtc3VtbWFyeS1saXN0X19mb290ZXItYnV0dG9uXCIgKGNsaWNrKT1cImZpbHRlckFuZFJvdXRlKHN0YXR1cylcIj5cbiAgICAgID4ge3sgJ0BodnkuYWN0aW9uLmNvbnN1bHQnIHwgaTE4biB9fVxuICAgICAgPHByeS1pY29uIGljb25Tdmc9XCJhcnJvd1wiPjwvcHJ5LWljb24+XG4gICAgPC9hPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|