@provoly/hypervisor 1.8.4 → 1.8.5
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.
|
@@ -59,11 +59,13 @@ export class ChoiceFilterComponent extends HvyUnitFilterComponent {
|
|
|
59
59
|
if (!this.overlayRef) {
|
|
60
60
|
this.triggerInhibate();
|
|
61
61
|
this.overlayRef = this.overlay.create(new OverlayConfig({
|
|
62
|
-
hasBackdrop:
|
|
62
|
+
hasBackdrop: false,
|
|
63
63
|
backdropClass: 'backdrop',
|
|
64
64
|
panelClass: ['m-context-menu-wrapper', 'o-choice-filter-popup']
|
|
65
65
|
}));
|
|
66
|
-
this.overlayRef.
|
|
66
|
+
this.overlayRef.outsidePointerEvents().subscribe(() => {
|
|
67
|
+
this.toggleModal();
|
|
68
|
+
});
|
|
67
69
|
this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));
|
|
68
70
|
const contextMenu = document.querySelector('.o-choice-filter-popup');
|
|
69
71
|
if (!!contextMenu) {
|
|
@@ -152,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
152
154
|
type: ViewChild,
|
|
153
155
|
args: ['template', { read: TemplateRef }]
|
|
154
156
|
}] } });
|
|
155
|
-
//# 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() allLabel: string = '@hvy.event.filter.choice.all';\n  @Input() label: string = 'no-label-defined';\n  @Input() i18nPrefix: string = '';\n  @Input() addNonLeaves: boolean = false;\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(this.allLabel);\n    }\n    if (this.value().length === 1) {\n      return this.i18nService.instant(this.i18nPrefix + this.value()[0]);\n    }\n    if (this.value().length >= 0) {\n      return `(${this.value().length})`;\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  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.minWidth = rect.right - 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    const branches = this.choices.filter((choice) => choice.children).map((choice) => choice.key);\n    return this.choices\n      .map((choice) =>\n        !choice.children\n          ? [choice.key]\n          : [...choice.children.map((child) => child.key), ...(this.addNonLeaves ? branches : [])]\n      )\n      .reduce((p, c) => [...p, ...c], []);\n  }\n\n  assignValue(values: string[]) {\n    if (!this.inhibate || this.inhibate !== this.filterSet) {\n      this.triggerInhibate();\n\n      // Add or removes tree branches, according to children statuses\n      const branches = this.choices.filter((choice) => choice.children).map((choice) => choice.key);\n      const withoutBranches = values.filter((value) => !branches.includes(value));\n      const addedBranchValues = this.choices\n        .filter((choice) => choice.children && !choice.children.find((child) => !values.includes(child.key)))\n        .map((choice) => choice.key);\n      this.value.set([...withoutBranches, ...(this.addNonLeaves ? addedBranchValues : [])]);\n\n      this.changed.next();\n    }\n  }\n\n  private triggerInhibate() {\n    this.inhibate = this.filterSet;\n    setTimeout(() => (this.inhibate = undefined), 50);\n  }\n}\n","<button\n  (click)=\"toggleModal()\"\n  #button\n  class=\"o-hvy-choice-filter -horizontal\"\n  [class.-highlight]=\"displayValue() !== (allLabel | i18n)\"\n  [class.-no-value]=\"displayValue()==='(0)'\"\n  [class.-focus]=\"overlayRef\"\n>\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>{{ allLabel | 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\n            [ngModel]=\"isSelected(child)\"\n            (ngModelChange)=\"toggle(child)\"\n            class=\"o-hvy-choice-filter__child\"\n          >\n            <span>{{ i18nPrefix + child.key | i18n }}</span>\n          </pry-checkbox>\n        }\n      }\n    }\n  </div>\n</ng-template>\n"]}
|
|
157
|
+
//# 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() allLabel: string = '@hvy.event.filter.choice.all';\n  @Input() label: string = 'no-label-defined';\n  @Input() i18nPrefix: string = '';\n  @Input() addNonLeaves: boolean = false;\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(this.allLabel);\n    }\n    if (this.value().length === 1) {\n      return this.i18nService.instant(this.i18nPrefix + this.value()[0]);\n    }\n    if (this.value().length >= 0) {\n      return `(${this.value().length})`;\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  toggleModal() {\n    if (!this.overlayRef) {\n      this.triggerInhibate();\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: false,\n          backdropClass: 'backdrop',\n          panelClass: ['m-context-menu-wrapper', 'o-choice-filter-popup']\n        })\n      );\n      this.overlayRef.outsidePointerEvents().subscribe(() => {\n        this.toggleModal();\n      })\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.minWidth = rect.right - 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    const branches = this.choices.filter((choice) => choice.children).map((choice) => choice.key);\n    return this.choices\n      .map((choice) =>\n        !choice.children\n          ? [choice.key]\n          : [...choice.children.map((child) => child.key), ...(this.addNonLeaves ? branches : [])]\n      )\n      .reduce((p, c) => [...p, ...c], []);\n  }\n\n  assignValue(values: string[]) {\n    if (!this.inhibate || this.inhibate !== this.filterSet) {\n      this.triggerInhibate();\n\n      // Add or removes tree branches, according to children statuses\n      const branches = this.choices.filter((choice) => choice.children).map((choice) => choice.key);\n      const withoutBranches = values.filter((value) => !branches.includes(value));\n      const addedBranchValues = this.choices\n        .filter((choice) => choice.children && !choice.children.find((child) => !values.includes(child.key)))\n        .map((choice) => choice.key);\n      this.value.set([...withoutBranches, ...(this.addNonLeaves ? addedBranchValues : [])]);\n\n      this.changed.next();\n    }\n  }\n\n  private triggerInhibate() {\n    this.inhibate = this.filterSet;\n    setTimeout(() => (this.inhibate = undefined), 50);\n  }\n}\n","<button\n  (click)=\"toggleModal()\"\n  #button\n  class=\"o-hvy-choice-filter -horizontal\"\n  [class.-highlight]=\"displayValue() !== (allLabel | i18n)\"\n  [class.-no-value]=\"displayValue()==='(0)'\"\n  [class.-focus]=\"overlayRef\"\n>\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>{{ allLabel | 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\n            [ngModel]=\"isSelected(child)\"\n            (ngModelChange)=\"toggle(child)\"\n            class=\"o-hvy-choice-filter__child\"\n          >\n            <span>{{ i18nPrefix + child.key | i18n }}</span>\n          </pry-checkbox>\n        }\n      }\n    }\n  </div>\n</ng-template>\n"]}
|
|
@@ -2856,11 +2856,13 @@ class ChoiceFilterComponent extends HvyUnitFilterComponent {
|
|
|
2856
2856
|
if (!this.overlayRef) {
|
|
2857
2857
|
this.triggerInhibate();
|
|
2858
2858
|
this.overlayRef = this.overlay.create(new OverlayConfig({
|
|
2859
|
-
hasBackdrop:
|
|
2859
|
+
hasBackdrop: false,
|
|
2860
2860
|
backdropClass: 'backdrop',
|
|
2861
2861
|
panelClass: ['m-context-menu-wrapper', 'o-choice-filter-popup']
|
|
2862
2862
|
}));
|
|
2863
|
-
this.overlayRef.
|
|
2863
|
+
this.overlayRef.outsidePointerEvents().subscribe(() => {
|
|
2864
|
+
this.toggleModal();
|
|
2865
|
+
});
|
|
2864
2866
|
this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));
|
|
2865
2867
|
const contextMenu = document.querySelector('.o-choice-filter-popup');
|
|
2866
2868
|
if (!!contextMenu) {
|