@arsedizioni/ars-utils 18.4.48 → 18.4.49
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.
|
@@ -65,7 +65,7 @@ export class FilterBarComponent {
|
|
|
65
65
|
initializeFilters() {
|
|
66
66
|
if (!this.filters())
|
|
67
67
|
return;
|
|
68
|
-
this.filters()
|
|
68
|
+
this.filters()?.forEach((n) => {
|
|
69
69
|
switch (n.group) {
|
|
70
70
|
case Filters.FLT_1:
|
|
71
71
|
this.flt1 = n;
|
|
@@ -266,7 +266,7 @@ export class FilterBarComponent {
|
|
|
266
266
|
* @param id : the filter id
|
|
267
267
|
*/
|
|
268
268
|
getFilterGroup(id) {
|
|
269
|
-
return this.filters()
|
|
269
|
+
return this.filters()?.find((n) => n.group === id);
|
|
270
270
|
}
|
|
271
271
|
/**
|
|
272
272
|
* Update filter bar using current search params
|
|
@@ -353,4 +353,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
353
353
|
}], ctorParameters: () => [], propDecorators: { changed: [{
|
|
354
354
|
type: Output
|
|
355
355
|
}] } });
|
|
356
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/filter-bar/filter-bar.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/filter-bar/filter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgStyle } from \"@angular/common\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, OnInit, Output, effect, inject, input, signal } from \"@angular/core\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { MatButtonModule } from \"@angular/material/button\";\r\nimport { MatDividerModule } from \"@angular/material/divider\";\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatIconModule } from \"@angular/material/icon\";\r\nimport { MatInputModule } from \"@angular/material/input\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\r\nimport { SafeHtmlPipe } from '@arsedizioni/ars-utils/core';\r\nimport { CurrentFilter, CurrentFilterChanged, FilterGroup, FilterItem, Filters } from '../../filters';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\n\r\n\r\n\r\n@Component({\r\n  selector: \"filter-bar\",\r\n  templateUrl: \"./filter-bar.component.html\",\r\n  styleUrls: [\"./filter-bar.component.scss\"],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [NgClass, NgStyle, FlexLayoutModule, MatFormFieldModule, MatInputModule, FormsModule,\r\n    MatTooltipModule, MatButtonModule, MatIconModule, MatMenuModule, MatDividerModule, SafeHtmlPipe]\r\n})\r\nexport class FilterBarComponent implements OnInit {\r\n  @Output() changed = new EventEmitter<CurrentFilterChanged>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n\r\n  filters = input<any>();\r\n  canFilterByFlt1 = signal<boolean>(false);\r\n  canFilterByFlt2 = signal<boolean>(false);\r\n  canFilterByFlt3 = signal<boolean>(false);\r\n  canFilterByFlt4 = signal<boolean>(false);\r\n  canFilterByFlt5 = signal<boolean>(false);\r\n  canFilterByText = input<boolean>(false);\r\n  canFilterByText2 = input<boolean>(false);\r\n  canFilterByText3 = input<boolean>(false);\r\n  initialText = input<string>(null);\r\n  initialText2 = input<string>(null);\r\n  initialText3 = input<string>(null);\r\n  textName = input<string>(\"testo\");\r\n  text2Name = input<string>(\"...\");\r\n  text3Name = input<string>(\"...\");\r\n  textLength = input<string>();\r\n  text2Length = input<string>();\r\n  text3Length = input<string>();\r\n  showTextSearchButton = input<boolean>(false);\r\n  appearance = input<'fill' | 'outline' | null>('outline');\r\n\r\n\r\n  protected text: string | null = null;\r\n  protected text2: string | null = null;\r\n  protected text3: string | null = null;\r\n  protected flt1: FilterGroup;\r\n  protected flt2: FilterGroup;\r\n  protected flt3: FilterGroup;\r\n  protected flt4: FilterGroup;\r\n  protected flt5: FilterGroup;\r\n\r\n  public readonly currentFilter: CurrentFilter = new CurrentFilter();\r\n\r\n  constructor() {\r\n    effect(() => {\r\n      this.text = this.initialText();\r\n      this.text2 = this.initialText2();\r\n      this.text3 = this.initialText3();\r\n    })\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.initializeFilters();\r\n  }\r\n\r\n\r\n  /**\r\n   * Initialize filters\r\n   */\r\n  initializeFilters() {\r\n    if (!this.filters()) return;\r\n    this.filters().forEach((n: any) => {\r\n      switch (n.group) {\r\n        case Filters.FLT_1:\r\n          this.flt1 = n;\r\n          this.canFilterByFlt1.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n        case Filters.FLT_2:\r\n          this.flt2 = n;\r\n          this.canFilterByFlt2.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n        case Filters.FLT_3:\r\n          this.flt3 = n;\r\n          this.canFilterByFlt3.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n        case Filters.FLT_4:\r\n          this.flt4 = n;\r\n          this.canFilterByFlt4.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n        case Filters.FLT_5:\r\n          this.flt5 = n;\r\n          this.canFilterByFlt5.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Apply a filter\r\n   * @param filter : the filter to apply\r\n   */\r\n  applyFilter(filter: FilterItem) {\r\n    let changed = false;\r\n    switch (filter.group) {\r\n      case Filters.FLT_1:\r\n        changed = this.currentFilter.flt1 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt1 = filter.value;\r\n          this.currentFilter.flt1Name = filter.titleSelected;\r\n        }\r\n        break;\r\n      case Filters.FLT_2:\r\n        changed = this.currentFilter.flt2 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt2 = filter.value;\r\n          this.currentFilter.flt2Name = filter.titleSelected;\r\n        }\r\n        break;\r\n      case Filters.FLT_3:\r\n        changed = this.currentFilter.flt3 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt3 = filter.value;\r\n          this.currentFilter.flt3Name = filter.titleSelected;\r\n        }\r\n        break;\r\n      case Filters.FLT_4:\r\n        changed = this.currentFilter.flt4 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt4 = filter.value;\r\n          this.currentFilter.flt4Name = filter.titleSelected;\r\n        }\r\n        break;\r\n      case Filters.FLT_5:\r\n        changed = this.currentFilter.flt5 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt5 = filter.value;\r\n          this.currentFilter.flt5Name = filter.titleSelected;\r\n        }\r\n        break;\r\n    }\r\n\r\n    if (changed) {\r\n      this.changed.emit({ filter: this.currentFilter, group: filter.group });\r\n    }\r\n\r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Apply a filter action\r\n   * @param filter : the filter to apply\r\n   * @param clear : true if the filter mus be removed\r\n   * @param event : the click event\r\n   */\r\n  applyFilterAction(group: number, clear: boolean = false, event: any = null) {\r\n    if (!clear) {\r\n      const g = this.getFilterGroup(group);\r\n      if (g.action) {\r\n        g.action(this, g, event);\r\n      }\r\n    } else {\r\n      this.clearFilter(group);\r\n    }\r\n    \r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Apply text filter\r\n   */\r\n  applyTextFilter() {\r\n    this.currentFilter.text = this.text;\r\n    this.currentFilter.text2 = this.text2;\r\n    this.currentFilter.text3 = this.text3;\r\n    this.changed.emit({\r\n      filter: this.currentFilter,\r\n      group: Filters.FLT_TEXT\r\n    });\r\n    \r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Clear a filter\r\n   * @param group : the filter group\r\n   */\r\n  clearFilter(group: number) {\r\n    let changed = false;\r\n    switch (group) {\r\n      case Filters.FLT_1:\r\n        changed = this.currentFilter.flt1 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt1 = null;\r\n          this.currentFilter.flt1Name = null;\r\n        }\r\n        break;\r\n      case Filters.FLT_2:\r\n        changed = this.currentFilter.flt2 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt2 = null;\r\n          this.currentFilter.flt2Name = null;\r\n        }\r\n        break;\r\n      case Filters.FLT_3:\r\n        changed = this.currentFilter.flt3 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt3 = null;\r\n          this.currentFilter.flt3Name = null;\r\n        }\r\n        break;\r\n      case Filters.FLT_4:\r\n        changed = this.currentFilter.flt4 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt4 = null;\r\n          this.currentFilter.flt4Name = null;\r\n        }\r\n        break;\r\n      case Filters.FLT_5:\r\n        changed = this.currentFilter.flt5 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt5 = null;\r\n          this.currentFilter.flt5Name = null;\r\n        }\r\n        break;\r\n    }\r\n    if (changed) {\r\n      this.changed.emit({ filter: this.currentFilter, group: group });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear all filters\r\n   */\r\n  clearAllFilters() {\r\n    this.currentFilter.flt1 = null;\r\n    this.currentFilter.flt1Name = null;\r\n    this.currentFilter.flt2 = null;\r\n    this.currentFilter.flt2Name = null;\r\n    this.currentFilter.flt3 = null;\r\n    this.currentFilter.flt3Name = null;\r\n    this.currentFilter.flt4 = null;\r\n    this.currentFilter.flt4Name = null;\r\n    this.currentFilter.flt5 = null;\r\n    this.currentFilter.flt5Name = null;\r\n    this.currentFilter.text = null;\r\n    this.currentFilter.text2 = null;\r\n    this.currentFilter.text3 = null;\r\n    this.text = null;\r\n    this.text2 = null;\r\n    this.text3 = null;\r\n    this.changed.emit({ filter: this.currentFilter, group: -1 });\r\n  }\r\n\r\n  /**\r\n   * Check if can clear all filters button cab be showed\r\n   */\r\n  canClearAllFilters(): boolean {\r\n    let count = 0;\r\n    if (this.canFilterByText) count++;\r\n    if (this.canFilterByText2) count++;\r\n    if (this.canFilterByText3) count++;\r\n    if (this.canFilterByFlt1) count++;\r\n    if (this.canFilterByFlt2) count++;\r\n    if (this.canFilterByFlt3) count++;\r\n    if (this.canFilterByFlt4) count++;\r\n    if (this.canFilterByFlt5) count++;\r\n    return count > 1;\r\n  }\r\n\r\n  /**\r\n   * Get the filter group\r\n   * @param id : the filter id\r\n   */\r\n  private getFilterGroup(id: number): FilterGroup {\r\n    return this.filters().find((n: any) => n.group === id);\r\n  }\r\n\r\n  /**\r\n   * Update filter bar using current search params\r\n   * @param params : search params\r\n   */\r\n  syncFilter() {\r\n    let g = this.getFilterGroup(Filters.FLT_1);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt1Name = null;\r\n        if (this.currentFilter.flt1) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt1);\r\n          if (gi) this.currentFilter.flt1Name = gi.titleSelected;\r\n          else this.currentFilter.flt1 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    g = this.getFilterGroup(Filters.FLT_2);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt2Name = null;\r\n        if (this.currentFilter.flt2) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt2);\r\n          if (gi) this.currentFilter.flt2Name = gi.titleSelected;\r\n          else this.currentFilter.flt2 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    g = this.getFilterGroup(Filters.FLT_3);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt3Name = null;\r\n        if (this.currentFilter.flt3) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt3);\r\n          if (gi) this.currentFilter.flt3Name = gi.titleSelected;\r\n          else this.currentFilter.flt3 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    g = this.getFilterGroup(Filters.FLT_4);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt4Name = null;\r\n        if (this.currentFilter.flt4) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt4);\r\n          if (gi) this.currentFilter.flt4Name = gi.titleSelected;\r\n          else this.currentFilter.flt4 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    g = this.getFilterGroup(Filters.FLT_5);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt5Name = null;\r\n        if (this.currentFilter.flt5) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt5);\r\n          if (gi) this.currentFilter.flt5Name = gi.titleSelected;\r\n          else this.currentFilter.flt5 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    this.text = this.currentFilter.text;\r\n    this.text2 = this.currentFilter.text2;\r\n    this.text3 = this.currentFilter.text3;\r\n\r\n    this.changeDetector.markForCheck();\r\n  }\r\n}\r\n","<div fxLayout=\"row\"  fxLayoutAlign=\"start center\"  class=\"filterbox\"\r\n[ngClass]=\"{'filterbox-filtered': currentFilter.filtered()}\">\r\n  <div fxFlex=\"100\" fxLayout=\"row wrap\" fxLayoutAlign=\"space-between\">\r\n    @if (canFilterByText() || canFilterByText2() || canFilterByText3()) {\r\n    <div fxFlex.lt-sm=\"100\" fxFlexAlign=\"center\">\r\n      <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill style=\"padding:4px;\">\r\n        @if (canFilterByText()) {\r\n        <mat-form-field [ngStyle]=\"{'width': textLength() ?? '100%'}\" [appearance]=\"appearance()\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Cerca per {{textName()}}...</mat-label>\r\n          <input matInput name=\"_text\" [(ngModel)]=\"text\" maxlength=\"100\" #_text=\"ngModel\"\r\n            (keyup.Enter)=\"applyTextFilter()\" matTooltip=\"Premi INVIO per avviare la ricerca\">\r\n          @if (text) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Pulisci\"\r\n            (click)=\"text = ''; applyTextFilter();\" matTooltip=\"Azzera\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n          @if (showTextSearchButton()) {\r\n          <button type=\"button\" matSuffix mat-icon-button aria-label=\"Trova\" (click)=\"applyTextFilter();\"\r\n            matTooltip=\"Trova\">\r\n            <mat-icon>search</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n        }\r\n        @if (canFilterByText2()) {\r\n        <mat-form-field [ngStyle]=\"{'width': text2Length() ?? '100%'}\" [appearance]=\"appearance()\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Cerca per {{text2Name()}}...</mat-label>\r\n          <input matInput name=\"_text2\" [(ngModel)]=\"text2\" maxlength=\"100\" #_text2=\"ngModel\"\r\n            (keyup.Enter)=\"applyTextFilter()\" matTooltip=\"Premi INVIO per avviare la ricerca\">\r\n          @if (text2) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Pulisci\"\r\n            (click)=\"text2 = ''; applyTextFilter();\" matTooltip=\"Azzera\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n        }\r\n        @if (canFilterByText3()) {\r\n        <mat-form-field [ngStyle]=\"{'width': text3Length() ?? '100%'}\" [appearance]=\"appearance()\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Cerca per {{text3Name()}}...</mat-label>\r\n          <input matInput name=\"_text3\" [(ngModel)]=\"text3\" maxlength=\"100\" #_text3=\"ngModel\"\r\n            (keyup.Enter)=\"applyTextFilter()\" matTooltip=\"Premi INVIO per avviare la ricerca\">\r\n          @if (text3) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Pulisci\"\r\n            (click)=\"text3 = ''; applyTextFilter();\" matTooltip=\"Azzera\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n        }\r\n      </div>\r\n    </div>\r\n    }\r\n    <div fxFlex.lt-sm=\"100\">\r\n      <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill >\r\n        @if (canFilterByFlt1() && flt1 && flt1.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt1.tooltip || 'Filtra per ' + flt1.title\"\r\n            [attr.aria-label]=\"flt1.tooltip || 'Filtra per ' + flt1.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(1, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt1) {\r\n            <span style=\"font-weight: 200 !important\">{{flt1.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt1Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt1) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(1, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        } @else if (canFilterByFlt1() && flt1 && flt1.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt1.tooltip || 'Filtra per ' + flt1.title\"\r\n          [attr.aria-label]=\"flt1.tooltip || 'Filtra per ' + flt1.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt1\"\r\n          color=\"primary\" style=\"height:56px;\" >\r\n          &nbsp;\r\n          @if (!currentFilter.flt1) {\r\n          <span style=\"font-weight: 200 !important\">{{flt1.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt1Name | safeHtml\"></span>\r\n          }          \r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt1=\"matMenu\">\r\n            @for (f of flt1.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt1.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n        @if (canFilterByFlt2() && flt2 && flt2.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt2.tooltip || 'Filtra per ' + flt2.title\"\r\n            [attr.aria-label]=\"flt2.tooltip || 'Filtra per ' + flt2.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(2, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt2) {\r\n            <span style=\"font-weight: 200 !important\">{{flt2.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt2Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt2) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(2, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        }\r\n        @if (canFilterByFlt2() && flt2 && flt2.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt2.tooltip || 'Filtra per ' + flt2.title\"\r\n          [attr.aria-label]=\"flt2.tooltip || 'Filtra per ' + flt2.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt2\"\r\n          color=\"primary\" style=\"height:56px;\">\r\n          &nbsp;\r\n          @if (!currentFilter.flt2) {\r\n          <span style=\"font-weight: 200 !important\">{{flt2.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt2Name | safeHtml\"></span>\r\n          }\r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt2=\"matMenu\">\r\n            @for (f of flt2.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt2.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n        @if (canFilterByFlt3() && flt3 && flt3.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt3.tooltip || 'Filtra per ' + flt3.title\"\r\n            [attr.aria-label]=\"flt3.tooltip || 'Filtra per ' + flt3.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(3, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt3) {\r\n            <span style=\"font-weight: 200 !important\">{{flt3.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt3Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt3) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(3, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        }\r\n        @if (canFilterByFlt3() && flt3 && flt3.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt3.tooltip || 'Filtra per ' + flt3.title\"\r\n          [attr.aria-label]=\"flt3.tooltip || 'Filtra per ' + flt3.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt3\"\r\n          color=\"primary\" style=\"height:56px;\">\r\n          &nbsp;\r\n          @if (!currentFilter.flt3) {\r\n          <span style=\"font-weight: 200 !important\">{{flt3.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt3Name | safeHtml\"></span>\r\n          }\r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt3=\"matMenu\">\r\n            @for (f of flt3.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt3.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n        @if (canFilterByFlt4() && flt4 && flt4.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt4.tooltip || 'Filtra per ' + flt4.title\"\r\n            [attr.aria-label]=\"flt4.tooltip || 'Filtra per ' + flt4.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(4, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt4) {\r\n            <span style=\"font-weight: 200 !important\">{{flt4.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt4Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt4) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(4, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        }\r\n        @if (canFilterByFlt4() && flt4 && flt4.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt4.tooltip || 'Filtra per ' + flt4.title\"\r\n          [attr.aria-label]=\"flt4.tooltip || 'Filtra per ' + flt4.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt4\"\r\n          color=\"primary\" style=\"height:56px;\">\r\n          &nbsp;\r\n          @if (!currentFilter.flt4) {\r\n          <span style=\"font-weight: 200 !important\">{{flt4.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt4Name | safeHtml\"></span>\r\n          }\r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt4=\"matMenu\">\r\n            @for (f of flt4.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt4.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n        @if (canFilterByFlt5() && flt5 && flt5.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt5.tooltip || 'Filtra per ' + flt5.title\"\r\n            [attr.aria-label]=\"flt5.tooltip || 'Filtra per ' + flt5.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(5, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt5) {\r\n            <span style=\"font-weight: 200 !important\">{{flt5.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt5Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt5) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(5, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        }\r\n        @if (canFilterByFlt5() && flt5 && flt5.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt5.tooltip || 'Filtra per ' + flt5.title\"\r\n          [attr.aria-label]=\"flt5.tooltip || 'Filtra per ' + flt5.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt5\"\r\n          color=\"primary\" style=\"height:56px;\">\r\n          &nbsp;\r\n          @if (!currentFilter.flt5) {\r\n          <span style=\"font-weight: 200 !important\">{{flt5.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt5Name | safeHtml\"></span>\r\n          }\r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt5=\"matMenu\">\r\n            @for (f of flt5.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt5.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div>\r\n    @if (currentFilter.filtered() && canClearAllFilters()) {\r\n    <button type=\"button\" mat-icon-button matTooltip=\"Azzera tutti i filtri\" attr.aria-label=\"Azzera tutti i filtri\"\r\n       (click)=\"clearAllFilters()\">\r\n      <mat-icon>clear</mat-icon>\r\n    </button>\r\n    }\r\n  </div>\r\n</div>"]}
|
|
356
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../../../projects/ars-utils/ui.application/ui/components/filter-bar/filter-bar.component.ts","../../../../../../../projects/ars-utils/ui.application/ui/components/filter-bar/filter-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,YAAY,EAAU,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnJ,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAiD,OAAO,EAAE,MAAM,eAAe,CAAC;AACtG,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;;;;;;;;;;;;AAazD,MAAM,OAAO,kBAAkB;IAqC7B;QApCU,YAAO,GAAG,IAAI,YAAY,EAAwB,CAAC;QACrD,mBAAc,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAEnD,YAAO,GAAG,KAAK,EAAO,CAAC;QACvB,oBAAe,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QACzC,oBAAe,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QACzC,oBAAe,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QACzC,oBAAe,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QACzC,oBAAe,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QACzC,oBAAe,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACxC,qBAAgB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACzC,qBAAgB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACzC,gBAAW,GAAG,KAAK,CAAS,IAAI,CAAC,CAAC;QAClC,iBAAY,GAAG,KAAK,CAAS,IAAI,CAAC,CAAC;QACnC,iBAAY,GAAG,KAAK,CAAS,IAAI,CAAC,CAAC;QACnC,aAAQ,GAAG,KAAK,CAAS,OAAO,CAAC,CAAC;QAClC,cAAS,GAAG,KAAK,CAAS,KAAK,CAAC,CAAC;QACjC,cAAS,GAAG,KAAK,CAAS,KAAK,CAAC,CAAC;QACjC,eAAU,GAAG,KAAK,EAAU,CAAC;QAC7B,gBAAW,GAAG,KAAK,EAAU,CAAC;QAC9B,gBAAW,GAAG,KAAK,EAAU,CAAC;QAC9B,yBAAoB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAC7C,eAAU,GAAG,KAAK,CAA4B,SAAS,CAAC,CAAC;QAG/C,SAAI,GAAkB,IAAI,CAAC;QAC3B,UAAK,GAAkB,IAAI,CAAC;QAC5B,UAAK,GAAkB,IAAI,CAAC;QAOtB,kBAAa,GAAkB,IAAI,aAAa,EAAE,CAAC;QAGjE,MAAM,CAAC,GAAG,EAAE;YACV,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YAC/B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACjC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACnC,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAGD;;OAEG;IACH,iBAAiB;QACf,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YAAE,OAAO;QAC5B,IAAI,CAAC,OAAO,EAAE,EAAE,OAAO,CAAC,CAAC,CAAM,EAAE,EAAE;YACjC,QAAQ,CAAC,CAAC,KAAK,EAAE,CAAC;gBAChB,KAAK,OAAO,CAAC,KAAK;oBAChB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;oBACd,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;oBACtE,MAAM;gBACR,KAAK,OAAO,CAAC,KAAK;oBAChB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;oBACd,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;oBACtE,MAAM;gBACR,KAAK,OAAO,CAAC,KAAK;oBAChB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;oBACd,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;oBACtE,MAAM;gBACR,KAAK,OAAO,CAAC,KAAK;oBAChB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;oBACd,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;oBACtE,MAAM;gBACR,KAAK,OAAO,CAAC,KAAK;oBAChB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;oBACd,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;oBACtE,MAAM;YACV,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,MAAkB;QAC5B,IAAI,OAAO,GAAG,KAAK,CAAC;QACpB,QAAQ,MAAM,CAAC,KAAK,EAAE,CAAC;YACrB,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC;gBAClD,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;oBACvC,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,MAAM,CAAC,aAAa,CAAC;gBACrD,CAAC;gBACD,MAAM;YACR,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC;gBAClD,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;oBACvC,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,MAAM,CAAC,aAAa,CAAC;gBACrD,CAAC;gBACD,MAAM;YACR,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC;gBAClD,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;oBACvC,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,MAAM,CAAC,aAAa,CAAC;gBACrD,CAAC;gBACD,MAAM;YACR,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC;gBAClD,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;oBACvC,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,MAAM,CAAC,aAAa,CAAC;gBACrD,CAAC;gBACD,MAAM;YACR,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC;gBAClD,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;oBACvC,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,MAAM,CAAC,aAAa,CAAC;gBACrD,CAAC;gBACD,MAAM;QACV,CAAC;QAED,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC;QACzE,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED;;;;;OAKG;IACH,iBAAiB,CAAC,KAAa,EAAE,QAAiB,KAAK,EAAE,QAAa,IAAI;QACxE,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,MAAM,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;gBACb,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;YAC3B,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACpC,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAChB,MAAM,EAAE,IAAI,CAAC,aAAa;YAC1B,KAAK,EAAE,OAAO,CAAC,QAAQ;SACxB,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,KAAa;QACvB,IAAI,OAAO,GAAG,KAAK,CAAC;QACpB,QAAQ,KAAK,EAAE,CAAC;YACd,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,IAAI,CAAC;gBAC1C,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;oBAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrC,CAAC;gBACD,MAAM;YACR,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,IAAI,CAAC;gBAC1C,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;oBAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrC,CAAC;gBACD,MAAM;YACR,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,IAAI,CAAC;gBAC1C,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;oBAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrC,CAAC;gBACD,MAAM;YACR,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,IAAI,CAAC;gBAC1C,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;oBAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrC,CAAC;gBACD,MAAM;YACR,KAAK,OAAO,CAAC,KAAK;gBAChB,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,IAAI,CAAC;gBAC1C,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;oBAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrC,CAAC;gBACD,MAAM;QACV,CAAC;QACD,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAClE,CAAC;IACH,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;IAC/D,CAAC;IAED;;OAEG;IACH,kBAAkB;QAChB,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,IAAI,CAAC,eAAe;YAAE,KAAK,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,gBAAgB;YAAE,KAAK,EAAE,CAAC;QACnC,IAAI,IAAI,CAAC,gBAAgB;YAAE,KAAK,EAAE,CAAC;QACnC,IAAI,IAAI,CAAC,eAAe;YAAE,KAAK,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,eAAe;YAAE,KAAK,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,eAAe;YAAE,KAAK,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,eAAe;YAAE,KAAK,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,eAAe;YAAE,KAAK,EAAE,CAAC;QAClC,OAAO,KAAK,GAAG,CAAC,CAAC;IACnB,CAAC;IAED;;;OAGG;IACK,cAAc,CAAC,EAAU;QAC/B,OAAO,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACH,UAAU;QACR,IAAI,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC3C,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACZ,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACnC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;oBAC5B,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAClE,IAAI,EAAE;wBAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,EAAE,CAAC,aAAa,CAAC;;wBAClD,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;gBACtC,CAAC;YACH,CAAC;QACH,CAAC;QAED,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACZ,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACnC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;oBAC5B,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAClE,IAAI,EAAE;wBAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,EAAE,CAAC,aAAa,CAAC;;wBAClD,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;gBACtC,CAAC;YACH,CAAC;QACH,CAAC;QAED,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACZ,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACnC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;oBAC5B,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAClE,IAAI,EAAE;wBAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,EAAE,CAAC,aAAa,CAAC;;wBAClD,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;gBACtC,CAAC;YACH,CAAC;QACH,CAAC;QAED,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACZ,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACnC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;oBAC5B,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAClE,IAAI,EAAE;wBAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,EAAE,CAAC,aAAa,CAAC;;wBAClD,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;gBACtC,CAAC;YACH,CAAC;QACH,CAAC;QAED,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACZ,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACnC,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;oBAC5B,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAClE,IAAI,EAAE;wBAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,EAAE,CAAC,aAAa,CAAC;;wBAClD,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;gBACtC,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;QACpC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;QAEtC,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;8GA3UU,kBAAkB;kGAAlB,kBAAkB,6qECzB/B,qziBA0VM,0hIDpUM,OAAO,oFAAE,OAAO,0EAAE,gBAAgB,siIAAE,kBAAkB,2aAAE,cAAc,0WAAE,WAAW,ixBAC3F,gBAAgB,4TAAE,eAAe,wUAAE,aAAa,mLAAE,aAAa,6vBAAE,gBAAgB,+HAAE,YAAY;;2FAEtF,kBAAkB;kBAT9B,SAAS;+BACE,YAAY,cAGV,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC,CAAC,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,cAAc,EAAE,WAAW;wBAC3F,gBAAgB,EAAE,eAAe,EAAE,aAAa,EAAE,aAAa,EAAE,gBAAgB,EAAE,YAAY,CAAC;wDAGxF,OAAO;sBAAhB,MAAM","sourcesContent":["import { NgClass, NgStyle } from \"@angular/common\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, OnInit, Output, effect, inject, input, signal } from \"@angular/core\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { MatButtonModule } from \"@angular/material/button\";\r\nimport { MatDividerModule } from \"@angular/material/divider\";\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatIconModule } from \"@angular/material/icon\";\r\nimport { MatInputModule } from \"@angular/material/input\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\r\nimport { SafeHtmlPipe } from '@arsedizioni/ars-utils/core';\r\nimport { CurrentFilter, CurrentFilterChanged, FilterGroup, FilterItem, Filters } from '../../filters';\r\nimport { FlexLayoutModule } from '@ngbracket/ngx-layout';\r\n\r\n\r\n\r\n@Component({\r\n  selector: \"filter-bar\",\r\n  templateUrl: \"./filter-bar.component.html\",\r\n  styleUrls: [\"./filter-bar.component.scss\"],\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [NgClass, NgStyle, FlexLayoutModule, MatFormFieldModule, MatInputModule, FormsModule,\r\n    MatTooltipModule, MatButtonModule, MatIconModule, MatMenuModule, MatDividerModule, SafeHtmlPipe]\r\n})\r\nexport class FilterBarComponent implements OnInit {\r\n  @Output() changed = new EventEmitter<CurrentFilterChanged>();\r\n  private changeDetector = inject(ChangeDetectorRef);\r\n\r\n  filters = input<any>();\r\n  canFilterByFlt1 = signal<boolean>(false);\r\n  canFilterByFlt2 = signal<boolean>(false);\r\n  canFilterByFlt3 = signal<boolean>(false);\r\n  canFilterByFlt4 = signal<boolean>(false);\r\n  canFilterByFlt5 = signal<boolean>(false);\r\n  canFilterByText = input<boolean>(false);\r\n  canFilterByText2 = input<boolean>(false);\r\n  canFilterByText3 = input<boolean>(false);\r\n  initialText = input<string>(null);\r\n  initialText2 = input<string>(null);\r\n  initialText3 = input<string>(null);\r\n  textName = input<string>(\"testo\");\r\n  text2Name = input<string>(\"...\");\r\n  text3Name = input<string>(\"...\");\r\n  textLength = input<string>();\r\n  text2Length = input<string>();\r\n  text3Length = input<string>();\r\n  showTextSearchButton = input<boolean>(false);\r\n  appearance = input<'fill' | 'outline' | null>('outline');\r\n\r\n\r\n  protected text: string | null = null;\r\n  protected text2: string | null = null;\r\n  protected text3: string | null = null;\r\n  protected flt1: FilterGroup;\r\n  protected flt2: FilterGroup;\r\n  protected flt3: FilterGroup;\r\n  protected flt4: FilterGroup;\r\n  protected flt5: FilterGroup;\r\n\r\n  public readonly currentFilter: CurrentFilter = new CurrentFilter();\r\n\r\n  constructor() {\r\n    effect(() => {\r\n      this.text = this.initialText();\r\n      this.text2 = this.initialText2();\r\n      this.text3 = this.initialText3();\r\n    })\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.initializeFilters();\r\n  }\r\n\r\n\r\n  /**\r\n   * Initialize filters\r\n   */\r\n  initializeFilters() {\r\n    if (!this.filters()) return;\r\n    this.filters()?.forEach((n: any) => {\r\n      switch (n.group) {\r\n        case Filters.FLT_1:\r\n          this.flt1 = n;\r\n          this.canFilterByFlt1.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n        case Filters.FLT_2:\r\n          this.flt2 = n;\r\n          this.canFilterByFlt2.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n        case Filters.FLT_3:\r\n          this.flt3 = n;\r\n          this.canFilterByFlt3.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n        case Filters.FLT_4:\r\n          this.flt4 = n;\r\n          this.canFilterByFlt4.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n        case Filters.FLT_5:\r\n          this.flt5 = n;\r\n          this.canFilterByFlt5.set(n.action || (n.items && n.items.length > 0));\r\n          break;\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Apply a filter\r\n   * @param filter : the filter to apply\r\n   */\r\n  applyFilter(filter: FilterItem) {\r\n    let changed = false;\r\n    switch (filter.group) {\r\n      case Filters.FLT_1:\r\n        changed = this.currentFilter.flt1 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt1 = filter.value;\r\n          this.currentFilter.flt1Name = filter.titleSelected;\r\n        }\r\n        break;\r\n      case Filters.FLT_2:\r\n        changed = this.currentFilter.flt2 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt2 = filter.value;\r\n          this.currentFilter.flt2Name = filter.titleSelected;\r\n        }\r\n        break;\r\n      case Filters.FLT_3:\r\n        changed = this.currentFilter.flt3 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt3 = filter.value;\r\n          this.currentFilter.flt3Name = filter.titleSelected;\r\n        }\r\n        break;\r\n      case Filters.FLT_4:\r\n        changed = this.currentFilter.flt4 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt4 = filter.value;\r\n          this.currentFilter.flt4Name = filter.titleSelected;\r\n        }\r\n        break;\r\n      case Filters.FLT_5:\r\n        changed = this.currentFilter.flt5 != filter.value;\r\n        if (changed) {\r\n          this.currentFilter.flt5 = filter.value;\r\n          this.currentFilter.flt5Name = filter.titleSelected;\r\n        }\r\n        break;\r\n    }\r\n\r\n    if (changed) {\r\n      this.changed.emit({ filter: this.currentFilter, group: filter.group });\r\n    }\r\n\r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Apply a filter action\r\n   * @param filter : the filter to apply\r\n   * @param clear : true if the filter mus be removed\r\n   * @param event : the click event\r\n   */\r\n  applyFilterAction(group: number, clear: boolean = false, event: any = null) {\r\n    if (!clear) {\r\n      const g = this.getFilterGroup(group);\r\n      if (g.action) {\r\n        g.action(this, g, event);\r\n      }\r\n    } else {\r\n      this.clearFilter(group);\r\n    }\r\n    \r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Apply text filter\r\n   */\r\n  applyTextFilter() {\r\n    this.currentFilter.text = this.text;\r\n    this.currentFilter.text2 = this.text2;\r\n    this.currentFilter.text3 = this.text3;\r\n    this.changed.emit({\r\n      filter: this.currentFilter,\r\n      group: Filters.FLT_TEXT\r\n    });\r\n    \r\n    this.changeDetector.markForCheck();\r\n  }\r\n\r\n  /**\r\n   * Clear a filter\r\n   * @param group : the filter group\r\n   */\r\n  clearFilter(group: number) {\r\n    let changed = false;\r\n    switch (group) {\r\n      case Filters.FLT_1:\r\n        changed = this.currentFilter.flt1 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt1 = null;\r\n          this.currentFilter.flt1Name = null;\r\n        }\r\n        break;\r\n      case Filters.FLT_2:\r\n        changed = this.currentFilter.flt2 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt2 = null;\r\n          this.currentFilter.flt2Name = null;\r\n        }\r\n        break;\r\n      case Filters.FLT_3:\r\n        changed = this.currentFilter.flt3 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt3 = null;\r\n          this.currentFilter.flt3Name = null;\r\n        }\r\n        break;\r\n      case Filters.FLT_4:\r\n        changed = this.currentFilter.flt4 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt4 = null;\r\n          this.currentFilter.flt4Name = null;\r\n        }\r\n        break;\r\n      case Filters.FLT_5:\r\n        changed = this.currentFilter.flt5 != null;\r\n        if (changed) {\r\n          this.currentFilter.flt5 = null;\r\n          this.currentFilter.flt5Name = null;\r\n        }\r\n        break;\r\n    }\r\n    if (changed) {\r\n      this.changed.emit({ filter: this.currentFilter, group: group });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Clear all filters\r\n   */\r\n  clearAllFilters() {\r\n    this.currentFilter.flt1 = null;\r\n    this.currentFilter.flt1Name = null;\r\n    this.currentFilter.flt2 = null;\r\n    this.currentFilter.flt2Name = null;\r\n    this.currentFilter.flt3 = null;\r\n    this.currentFilter.flt3Name = null;\r\n    this.currentFilter.flt4 = null;\r\n    this.currentFilter.flt4Name = null;\r\n    this.currentFilter.flt5 = null;\r\n    this.currentFilter.flt5Name = null;\r\n    this.currentFilter.text = null;\r\n    this.currentFilter.text2 = null;\r\n    this.currentFilter.text3 = null;\r\n    this.text = null;\r\n    this.text2 = null;\r\n    this.text3 = null;\r\n    this.changed.emit({ filter: this.currentFilter, group: -1 });\r\n  }\r\n\r\n  /**\r\n   * Check if can clear all filters button cab be showed\r\n   */\r\n  canClearAllFilters(): boolean {\r\n    let count = 0;\r\n    if (this.canFilterByText) count++;\r\n    if (this.canFilterByText2) count++;\r\n    if (this.canFilterByText3) count++;\r\n    if (this.canFilterByFlt1) count++;\r\n    if (this.canFilterByFlt2) count++;\r\n    if (this.canFilterByFlt3) count++;\r\n    if (this.canFilterByFlt4) count++;\r\n    if (this.canFilterByFlt5) count++;\r\n    return count > 1;\r\n  }\r\n\r\n  /**\r\n   * Get the filter group\r\n   * @param id : the filter id\r\n   */\r\n  private getFilterGroup(id: number): FilterGroup {\r\n    return this.filters()?.find((n: any) => n.group === id);\r\n  }\r\n\r\n  /**\r\n   * Update filter bar using current search params\r\n   * @param params : search params\r\n   */\r\n  syncFilter() {\r\n    let g = this.getFilterGroup(Filters.FLT_1);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt1Name = null;\r\n        if (this.currentFilter.flt1) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt1);\r\n          if (gi) this.currentFilter.flt1Name = gi.titleSelected;\r\n          else this.currentFilter.flt1 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    g = this.getFilterGroup(Filters.FLT_2);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt2Name = null;\r\n        if (this.currentFilter.flt2) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt2);\r\n          if (gi) this.currentFilter.flt2Name = gi.titleSelected;\r\n          else this.currentFilter.flt2 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    g = this.getFilterGroup(Filters.FLT_3);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt3Name = null;\r\n        if (this.currentFilter.flt3) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt3);\r\n          if (gi) this.currentFilter.flt3Name = gi.titleSelected;\r\n          else this.currentFilter.flt3 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    g = this.getFilterGroup(Filters.FLT_4);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt4Name = null;\r\n        if (this.currentFilter.flt4) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt4);\r\n          if (gi) this.currentFilter.flt4Name = gi.titleSelected;\r\n          else this.currentFilter.flt4 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    g = this.getFilterGroup(Filters.FLT_5);\r\n    if (g) {\r\n      if (g.items) {\r\n        this.currentFilter.flt5Name = null;\r\n        if (this.currentFilter.flt5) {\r\n          const gi = g.items.find(n => n.value === this.currentFilter.flt5);\r\n          if (gi) this.currentFilter.flt5Name = gi.titleSelected;\r\n          else this.currentFilter.flt5 = null;\r\n        }\r\n      }\r\n    }\r\n\r\n    this.text = this.currentFilter.text;\r\n    this.text2 = this.currentFilter.text2;\r\n    this.text3 = this.currentFilter.text3;\r\n\r\n    this.changeDetector.markForCheck();\r\n  }\r\n}\r\n","<div fxLayout=\"row\"  fxLayoutAlign=\"start center\"  class=\"filterbox\"\r\n[ngClass]=\"{'filterbox-filtered': currentFilter.filtered()}\">\r\n  <div fxFlex=\"100\" fxLayout=\"row wrap\" fxLayoutAlign=\"space-between\">\r\n    @if (canFilterByText() || canFilterByText2() || canFilterByText3()) {\r\n    <div fxFlex.lt-sm=\"100\" fxFlexAlign=\"center\">\r\n      <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill style=\"padding:4px;\">\r\n        @if (canFilterByText()) {\r\n        <mat-form-field [ngStyle]=\"{'width': textLength() ?? '100%'}\" [appearance]=\"appearance()\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Cerca per {{textName()}}...</mat-label>\r\n          <input matInput name=\"_text\" [(ngModel)]=\"text\" maxlength=\"100\" #_text=\"ngModel\"\r\n            (keyup.Enter)=\"applyTextFilter()\" matTooltip=\"Premi INVIO per avviare la ricerca\">\r\n          @if (text) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Pulisci\"\r\n            (click)=\"text = ''; applyTextFilter();\" matTooltip=\"Azzera\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n          @if (showTextSearchButton()) {\r\n          <button type=\"button\" matSuffix mat-icon-button aria-label=\"Trova\" (click)=\"applyTextFilter();\"\r\n            matTooltip=\"Trova\">\r\n            <mat-icon>search</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n        }\r\n        @if (canFilterByText2()) {\r\n        <mat-form-field [ngStyle]=\"{'width': text2Length() ?? '100%'}\" [appearance]=\"appearance()\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Cerca per {{text2Name()}}...</mat-label>\r\n          <input matInput name=\"_text2\" [(ngModel)]=\"text2\" maxlength=\"100\" #_text2=\"ngModel\"\r\n            (keyup.Enter)=\"applyTextFilter()\" matTooltip=\"Premi INVIO per avviare la ricerca\">\r\n          @if (text2) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Pulisci\"\r\n            (click)=\"text2 = ''; applyTextFilter();\" matTooltip=\"Azzera\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n        }\r\n        @if (canFilterByText3()) {\r\n        <mat-form-field [ngStyle]=\"{'width': text3Length() ?? '100%'}\" [appearance]=\"appearance()\" subscriptSizing=\"dynamic\">\r\n          <mat-label>Cerca per {{text3Name()}}...</mat-label>\r\n          <input matInput name=\"_text3\" [(ngModel)]=\"text3\" maxlength=\"100\" #_text3=\"ngModel\"\r\n            (keyup.Enter)=\"applyTextFilter()\" matTooltip=\"Premi INVIO per avviare la ricerca\">\r\n          @if (text3) {\r\n          <button type=\"button\" tabindex=\"-1\" matSuffix mat-icon-button aria-label=\"Pulisci\"\r\n            (click)=\"text3 = ''; applyTextFilter();\" matTooltip=\"Azzera\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n          }\r\n        </mat-form-field>\r\n        }\r\n      </div>\r\n    </div>\r\n    }\r\n    <div fxFlex.lt-sm=\"100\">\r\n      <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill >\r\n        @if (canFilterByFlt1() && flt1 && flt1.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt1.tooltip || 'Filtra per ' + flt1.title\"\r\n            [attr.aria-label]=\"flt1.tooltip || 'Filtra per ' + flt1.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(1, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt1) {\r\n            <span style=\"font-weight: 200 !important\">{{flt1.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt1Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt1) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(1, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        } @else if (canFilterByFlt1() && flt1 && flt1.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt1.tooltip || 'Filtra per ' + flt1.title\"\r\n          [attr.aria-label]=\"flt1.tooltip || 'Filtra per ' + flt1.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt1\"\r\n          color=\"primary\" style=\"height:56px;\" >\r\n          &nbsp;\r\n          @if (!currentFilter.flt1) {\r\n          <span style=\"font-weight: 200 !important\">{{flt1.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt1Name | safeHtml\"></span>\r\n          }          \r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt1=\"matMenu\">\r\n            @for (f of flt1.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt1.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n        @if (canFilterByFlt2() && flt2 && flt2.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt2.tooltip || 'Filtra per ' + flt2.title\"\r\n            [attr.aria-label]=\"flt2.tooltip || 'Filtra per ' + flt2.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(2, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt2) {\r\n            <span style=\"font-weight: 200 !important\">{{flt2.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt2Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt2) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(2, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        }\r\n        @if (canFilterByFlt2() && flt2 && flt2.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt2.tooltip || 'Filtra per ' + flt2.title\"\r\n          [attr.aria-label]=\"flt2.tooltip || 'Filtra per ' + flt2.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt2\"\r\n          color=\"primary\" style=\"height:56px;\">\r\n          &nbsp;\r\n          @if (!currentFilter.flt2) {\r\n          <span style=\"font-weight: 200 !important\">{{flt2.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt2Name | safeHtml\"></span>\r\n          }\r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt2=\"matMenu\">\r\n            @for (f of flt2.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt2.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n        @if (canFilterByFlt3() && flt3 && flt3.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt3.tooltip || 'Filtra per ' + flt3.title\"\r\n            [attr.aria-label]=\"flt3.tooltip || 'Filtra per ' + flt3.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(3, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt3) {\r\n            <span style=\"font-weight: 200 !important\">{{flt3.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt3Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt3) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(3, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        }\r\n        @if (canFilterByFlt3() && flt3 && flt3.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt3.tooltip || 'Filtra per ' + flt3.title\"\r\n          [attr.aria-label]=\"flt3.tooltip || 'Filtra per ' + flt3.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt3\"\r\n          color=\"primary\" style=\"height:56px;\">\r\n          &nbsp;\r\n          @if (!currentFilter.flt3) {\r\n          <span style=\"font-weight: 200 !important\">{{flt3.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt3Name | safeHtml\"></span>\r\n          }\r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt3=\"matMenu\">\r\n            @for (f of flt3.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt3.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n        @if (canFilterByFlt4() && flt4 && flt4.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt4.tooltip || 'Filtra per ' + flt4.title\"\r\n            [attr.aria-label]=\"flt4.tooltip || 'Filtra per ' + flt4.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(4, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt4) {\r\n            <span style=\"font-weight: 200 !important\">{{flt4.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt4Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt4) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(4, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        }\r\n        @if (canFilterByFlt4() && flt4 && flt4.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt4.tooltip || 'Filtra per ' + flt4.title\"\r\n          [attr.aria-label]=\"flt4.tooltip || 'Filtra per ' + flt4.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt4\"\r\n          color=\"primary\" style=\"height:56px;\">\r\n          &nbsp;\r\n          @if (!currentFilter.flt4) {\r\n          <span style=\"font-weight: 200 !important\">{{flt4.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt4Name | safeHtml\"></span>\r\n          }\r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt4=\"matMenu\">\r\n            @for (f of flt4.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt4.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n        @if (canFilterByFlt5() && flt5 && flt5.action) {\r\n        <div fxLayout=\"row\">\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-button\r\n            [matTooltip]=\"flt5.tooltip || 'Filtra per ' + flt5.title\"\r\n            [attr.aria-label]=\"flt5.tooltip || 'Filtra per ' + flt5.title\" color=\"primary\"\r\n            (click)=\"applyFilterAction(5, false)\" style=\"height:56px;\">\r\n            &nbsp;\r\n            @if (!currentFilter.flt5) {\r\n            <span style=\"font-weight: 200 !important\">{{flt5.title}}</span>\r\n            } @else {\r\n            <span [innerHtml]=\"currentFilter.flt5Name | safeHtml\"></span>\r\n            }\r\n          </button>\r\n          @if (currentFilter.flt5) {\r\n          <button fxFlexAlign=\"center\" type=\"button\" mat-icon-button  matTooltip=\"Azzera\"\r\n            aria-label=\"'Azzera'\" (click)=\"applyFilterAction(5, true);\" class=\"small-icon-button\">\r\n            <mat-icon>clear</mat-icon>\r\n          </button>\r\n          }\r\n        </div>\r\n        }\r\n        @if (canFilterByFlt5() && flt5 && flt5.items) {\r\n        <button fxFlexAlign=\"center\" type=\"button\" mat-button [matTooltip]=\"flt5.tooltip || 'Filtra per ' + flt5.title\"\r\n          [attr.aria-label]=\"flt5.tooltip || 'Filtra per ' + flt5.title\" [matMenuTriggerFor]=\"menuApplyFilterFlt5\"\r\n          color=\"primary\" style=\"height:56px;\">\r\n          &nbsp;\r\n          @if (!currentFilter.flt5) {\r\n          <span style=\"font-weight: 200 !important\">{{flt5.title}}</span>\r\n          } @else {\r\n          <span [innerHtml]=\"currentFilter.flt5Name | safeHtml\"></span>\r\n          }\r\n          <mat-icon class=\"icon-menu-drop-down\">expand_more</mat-icon>\r\n          <mat-menu #menuApplyFilterFlt5=\"matMenu\">\r\n            @for (f of flt5.items; track f) {\r\n\r\n            @if (f.divider) {\r\n            <mat-divider></mat-divider>\r\n            }\r\n            <button mat-menu-item (click)=\"applyFilter(f)\" [attr.aria-label]=\"f.description\" style=\"min-width: 200px\">\r\n              <span [innerHTML]=\"f.title | safeHtml\"></span>\r\n            </button>\r\n\r\n            }\r\n            <mat-divider></mat-divider>\r\n            <div fxLayout=\"row\" fxLayoutGap=\"10px\" fxFill>\r\n              <div fxLayoutAlign=\"end\" style=\"width: 100%; min-width: 200px; padding: 4px 4px 0 4px;\">\r\n                <button type=\"button\" mat-button color=\"primary\" (click)=\"clearFilter(flt5.items[0].group)\"\r\n                  attr.aria-label=\"Azzera\">\r\n                  <mat-icon style=\"font-size:18px; height: 18px; width:18px;\">clear</mat-icon> Azzera\r\n                </button>\r\n              </div>\r\n            </div>\r\n          </mat-menu>\r\n        </button>\r\n        }\r\n\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div>\r\n    @if (currentFilter.filtered() && canClearAllFilters()) {\r\n    <button type=\"button\" mat-icon-button matTooltip=\"Azzera tutti i filtri\" attr.aria-label=\"Azzera tutti i filtri\"\r\n       (click)=\"clearAllFilters()\">\r\n      <mat-icon>clear</mat-icon>\r\n    </button>\r\n    }\r\n  </div>\r\n</div>"]}
|
|
@@ -1722,7 +1722,7 @@ class FilterBarComponent {
|
|
|
1722
1722
|
initializeFilters() {
|
|
1723
1723
|
if (!this.filters())
|
|
1724
1724
|
return;
|
|
1725
|
-
this.filters()
|
|
1725
|
+
this.filters()?.forEach((n) => {
|
|
1726
1726
|
switch (n.group) {
|
|
1727
1727
|
case Filters.FLT_1:
|
|
1728
1728
|
this.flt1 = n;
|
|
@@ -1923,7 +1923,7 @@ class FilterBarComponent {
|
|
|
1923
1923
|
* @param id : the filter id
|
|
1924
1924
|
*/
|
|
1925
1925
|
getFilterGroup(id) {
|
|
1926
|
-
return this.filters()
|
|
1926
|
+
return this.filters()?.find((n) => n.group === id);
|
|
1927
1927
|
}
|
|
1928
1928
|
/**
|
|
1929
1929
|
* Update filter bar using current search params
|