@firestitch/filter 18.2.13 → 18.2.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (23) hide show
  1. package/app/components/filter/filter.component.d.ts +2 -5
  2. package/app/components/filter-chips/filter-chips.component.d.ts +1 -0
  3. package/app/components/saved-filter/saved-filter-manage/saved-filter-manage.component.d.ts +1 -1
  4. package/app/fs-filter.module.d.ts +8 -10
  5. package/app/models/items/base-item.d.ts +5 -2
  6. package/app/models/items/chips-item.d.ts +0 -2
  7. package/app/services/focus-controller.service.d.ts +0 -1
  8. package/esm2022/app/components/filter/filter.component.mjs +5 -14
  9. package/esm2022/app/components/filter-chips/filter-chips.component.mjs +7 -7
  10. package/esm2022/app/components/saved-filter/saved-filter-manage/components/saved-filter-chips/saved-filter-chips.component.mjs +9 -7
  11. package/esm2022/app/components/saved-filter/saved-filter-manage/saved-filter-manage.component.mjs +3 -3
  12. package/esm2022/app/fs-filter.module.mjs +1 -8
  13. package/esm2022/app/models/items/base-item.mjs +21 -12
  14. package/esm2022/app/models/items/chips-item.mjs +1 -20
  15. package/esm2022/app/services/filter-controller.service.mjs +2 -2
  16. package/esm2022/app/services/focus-controller.service.mjs +2 -3
  17. package/fesm2022/firestitch-filter.mjs +64 -227
  18. package/fesm2022/firestitch-filter.mjs.map +1 -1
  19. package/package.json +1 -1
  20. package/app/components/filter-chip/filter-chip.component.d.ts +0 -37
  21. package/app/components/filter-chip-content/filter-chip-content.component.d.ts +0 -18
  22. package/esm2022/app/components/filter-chip/filter-chip.component.mjs +0 -84
  23. package/esm2022/app/components/filter-chip-content/filter-chip-content.component.mjs +0 -71
@@ -1,6 +1,6 @@
1
1
  import { ElementRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
2
  import { Observable } from 'rxjs';
3
- import { IFilterSavedFilter, ISortingChangeEvent, KeyValue } from '../../interfaces';
3
+ import { ISortingChangeEvent, KeyValue } from '../../interfaces';
4
4
  import { FsFilterAction } from '../../interfaces/action.interface';
5
5
  import { FilterConfig, IFilterConfigItem } from '../../interfaces/config.interface';
6
6
  import { IUpdateFilterItemConfig } from '../../interfaces/update-filter-item.interface';
@@ -112,10 +112,7 @@ export declare class FilterComponent implements OnInit, OnDestroy {
112
112
  get actionsVisible$(): Observable<boolean>;
113
113
  get actions$(): Observable<import("../../models/action.model").Action[]>;
114
114
  get menuActions$(): Observable<import("../../models/action.model").Action[]>;
115
- set activeSavedFilter(savedFilter: IFilterSavedFilter);
116
- get activeSavedFilter(): IFilterSavedFilter;
117
- get savedFilters(): IFilterSavedFilter[];
118
- get savedFiltersController(): SavedFilterController;
115
+ get savedFilterController(): SavedFilterController;
119
116
  ngOnInit(): void;
120
117
  ngOnDestroy(): void;
121
118
  focus(): void;
@@ -5,6 +5,7 @@ import * as i0 from "@angular/core";
5
5
  export declare class FsFilterChipsComponent {
6
6
  ItemType: typeof ItemType;
7
7
  private _filterController;
8
+ private _injector;
8
9
  get items(): BaseItem<IFilterConfigItem>[];
9
10
  click(item: BaseItem<IFilterConfigItem>, chip: {
10
11
  name?: string;
@@ -7,7 +7,7 @@ export declare class FsFilterSavedFilterManageComponent implements OnInit {
7
7
  savedFilters: IFilterSavedFilter[];
8
8
  private _savedFilterController;
9
9
  private _cdRef;
10
- private filterController;
10
+ private _filterController;
11
11
  private _dialogRef;
12
12
  private _filterOverlayService;
13
13
  ngOnInit(): void;
@@ -17,18 +17,16 @@ import * as i13 from "./components/filters-item/date/date.component";
17
17
  import * as i14 from "./components/filters-item/date-range/date-range.component";
18
18
  import * as i15 from "./components/filters-item/checkbox/checkbox.component";
19
19
  import * as i16 from "./components/filter-drawer/filter-drawer.component";
20
- import * as i17 from "./components/filter-chip/filter-chip.component";
21
- import * as i18 from "./components/filter-chip-content/filter-chip-content.component";
22
- import * as i19 from "./components/filter-drawer-actions/filter-drawer-actions.component";
23
- import * as i20 from "./components/actions/actions.component";
24
- import * as i21 from "./components/action-button/action-button.component";
25
- import * as i22 from "./components/action-kebab-actions/action-kebab-actions.component";
26
- import * as i23 from "./directives/status-bar/status-bar.directive";
27
- import * as i24 from "./directives/focus-to-item/focus-to-item.directive";
28
- import * as i25 from "./pipes/remove-isolate-value.pipe";
20
+ import * as i17 from "./components/filter-drawer-actions/filter-drawer-actions.component";
21
+ import * as i18 from "./components/actions/actions.component";
22
+ import * as i19 from "./components/action-button/action-button.component";
23
+ import * as i20 from "./components/action-kebab-actions/action-kebab-actions.component";
24
+ import * as i21 from "./directives/status-bar/status-bar.directive";
25
+ import * as i22 from "./directives/focus-to-item/focus-to-item.directive";
26
+ import * as i23 from "./pipes/remove-isolate-value.pipe";
29
27
  export declare class FsFilterModule {
30
28
  static forRoot(config?: FilterConfig): ModuleWithProviders<FsFilterModule>;
31
29
  static ɵfac: i0.ɵɵFactoryDeclaration<FsFilterModule, never>;
32
- static ɵmod: i0.ɵɵNgModuleDeclaration<FsFilterModule, never, [typeof i1.FsSavedFilterAutocompleteChipsComponent, typeof i2.BaseItemComponent, typeof i3.FilterComponent, typeof i4.FilterItemComponent, typeof i5.FsFilterChipsComponent, typeof i6.SelectComponent, typeof i7.ChipsComponent, typeof i8.TextComponent, typeof i9.WeekComponent, typeof i10.RangeComponent, typeof i11.AutocompleteComponent, typeof i12.AutocompletechipsComponent, typeof i13.DateComponent, typeof i14.DateRangeComponent, typeof i15.CheckboxComponent, typeof i16.FilterDrawerComponent, typeof i17.FsFilterChipComponent, typeof i18.FsFilterChipContentComponent, typeof i19.FsFilterDrawerActionsComponent, typeof i20.FsFilterActionsComponent, typeof i21.FsFilterActionButtonComponent, typeof i22.FsFilterActionKebabActionsComponent, typeof i23.FilterStatusBarDirective, typeof i24.FocusToItemDirective, typeof i25.FsFilterIsolateValues], [typeof i3.FilterComponent, typeof i23.FilterStatusBarDirective]>;
30
+ static ɵmod: i0.ɵɵNgModuleDeclaration<FsFilterModule, never, [typeof i1.FsSavedFilterAutocompleteChipsComponent, typeof i2.BaseItemComponent, typeof i3.FilterComponent, typeof i4.FilterItemComponent, typeof i5.FsFilterChipsComponent, typeof i6.SelectComponent, typeof i7.ChipsComponent, typeof i8.TextComponent, typeof i9.WeekComponent, typeof i10.RangeComponent, typeof i11.AutocompleteComponent, typeof i12.AutocompletechipsComponent, typeof i13.DateComponent, typeof i14.DateRangeComponent, typeof i15.CheckboxComponent, typeof i16.FilterDrawerComponent, typeof i17.FsFilterDrawerActionsComponent, typeof i18.FsFilterActionsComponent, typeof i19.FsFilterActionButtonComponent, typeof i20.FsFilterActionKebabActionsComponent, typeof i21.FilterStatusBarDirective, typeof i22.FocusToItemDirective, typeof i23.FsFilterIsolateValues], [typeof i3.FilterComponent, typeof i21.FilterStatusBarDirective]>;
33
31
  static ɵinj: i0.ɵɵInjectorDeclaration<FsFilterModule>;
34
32
  }
@@ -21,6 +21,7 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
21
21
  private _value$;
22
22
  private _values$;
23
23
  private _destroy$;
24
+ private _emitChange;
24
25
  constructor(itemConfig: T, _additionalConfig: unknown, _filter: FilterComponent);
25
26
  get filter(): FilterComponent;
26
27
  get hidden$(): Observable<boolean>;
@@ -51,6 +52,9 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
51
52
  get values(): any[];
52
53
  get values$(): Observable<any>;
53
54
  get value$(): Observable<any>;
55
+ get value(): any;
56
+ set value(value: any);
57
+ setValue(value: unknown, emitChange?: boolean): void;
54
58
  get queryParam(): Record<string, unknown>;
55
59
  hide(): void;
56
60
  show(): void;
@@ -61,8 +65,7 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
61
65
  initValue(value: unknown): void;
62
66
  clear(name?: string): void;
63
67
  destroy(): void;
64
- get value(): any;
65
- set value(value: any);
68
+ clone(): BaseItem<T>;
66
69
  private _initConfig;
67
70
  abstract get chips(): {
68
71
  name?: string;
@@ -1,4 +1,3 @@
1
- import { Observable } from 'rxjs';
2
1
  import type { FilterComponent } from '../../components/filter/filter.component';
3
2
  import { IFilterConfigChipsItem } from '../../interfaces/items/chips.interface';
4
3
  import { BaseItem } from './base-item';
@@ -19,5 +18,4 @@ export declare class ChipsItem extends BaseItem<IFilterConfigChipsItem> {
19
18
  set value(value: any);
20
19
  get value(): any;
21
20
  clear(): void;
22
- init(value: unknown): Observable<unknown>;
23
21
  }
@@ -2,7 +2,6 @@ import { BaseItem } from '../models/items/base-item';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class FocusControllerService {
4
4
  private _focusOn;
5
- constructor();
6
5
  get focusOn$(): import("rxjs").Observable<{
7
6
  item: BaseItem<any>;
8
7
  type: string;
@@ -163,7 +163,7 @@ export class FilterComponent {
163
163
  get inlineToolbar$() {
164
164
  return combineLatest({
165
165
  keywordVisible: this.keywordVisible$,
166
- activeFilter: of(this.savedFiltersController.enabled),
166
+ activeFilter: of(this.savedFilterController.enabled),
167
167
  })
168
168
  .pipe(map(({ keywordVisible, activeFilter }) => {
169
169
  return !keywordVisible && !activeFilter;
@@ -182,16 +182,7 @@ export class FilterComponent {
182
182
  get menuActions$() {
183
183
  return this._actionsController.menuActions$;
184
184
  }
185
- set activeSavedFilter(savedFilter) {
186
- this._savedFilterController.setActiveFilter(savedFilter);
187
- }
188
- get activeSavedFilter() {
189
- return this._savedFilterController.activeFilter;
190
- }
191
- get savedFilters() {
192
- return this._savedFilterController.savedFilters;
193
- }
194
- get savedFiltersController() {
185
+ get savedFilterController() {
195
186
  return this._savedFilterController;
196
187
  }
197
188
  ngOnInit() {
@@ -422,7 +413,7 @@ export class FilterComponent {
422
413
  ActionsController,
423
414
  KeywordController,
424
415
  SortController,
425
- ], queries: [{ propertyName: "statusBar", first: true, predicate: FilterStatusBarDirective, descendants: true }], viewQueries: [{ propertyName: "keywordInput", first: true, predicate: KeywordInputComponent, descendants: true }, { propertyName: "reloadEl", first: true, predicate: ["reloadEl"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"filter-container\">\n @if (notInlineToolbar$ | async) {\n <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n }\n <div class=\"filter-inner-container\">\n @if (notInlineToolbar$ | async) {\n <div class=\"filter-inner-inputs\">\n @if (keywordVisible$ | async) {\n <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n }\n @if (savedFiltersController.enabled) {\n <fs-saved-filter-autocomplete-chips [savedFiltersController]=\"savedFiltersController\"></fs-saved-filter-autocomplete-chips>\n }\n </div>\n } @else {\n <div>\n <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n </div>\n }\n <ng-container [ngTemplateOutlet]=\"filterToolbar\"></ng-container>\n <ng-container [ngTemplateOutlet]=\"filterActions\"></ng-container>\n </div>\n @if (notInlineToolbar$ | async) {\n <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n }\n</div>\n<ng-template #filterStatusBarChips>\n @if (statusBar) {\n <div\n class=\"filter-status-container\"\n [ngClass]=\"{ 'has-status': !!filterStatus.textContent }\">\n <div\n class=\"filter-status\"\n #filterStatus>\n <ng-container *ngTemplateOutlet=\"statusBar.templateRef\"></ng-container>\n </div>\n </div>\n }\n @if (config.chips) {\n <fs-filter-chips class=\"filter-chips\"></fs-filter-chips>\n }\n</ng-template>\n<ng-template #filterActions>\n @if (actionsVisible$ | async) {\n <div class=\"filter-actions\">\n <fs-filter-actions\n [actions]=\"actions$ | async\"\n [kebabActions]=\"menuActions$ | async\">\n </fs-filter-actions>\n </div>\n }\n</ng-template>\n<ng-template #filterToolbar>\n @if (config.reload || config.autoReload || ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting)) {\n <div class=\"filter-toolbar\">\n @if ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting) {\n <a\n mat-icon-button\n class=\"button-filters\"\n (click)=\"filterButtonClick($event)\"\n [color]=\"config.button.color\">\n @if (config.button.icon) {\n <mat-icon [svgIcon]=\"'filterOutline'\"></mat-icon>\n }\n </a>\n }\n @if (config.reload) {\n <a\n mat-icon-button\n (click)=\"reload($event)\"\n class=\"button-reload\">\n <mat-icon #reloadEl>\n refresh\n </mat-icon>\n </a>\n }\n @if (config.autoReload) {\n <div class=\"filter-reload\">\n @if (config.autoReload) {\n <mat-slide-toggle\n name=\"autoReload\"\n class=\"auto-reload\"\n [(ngModel)]=\"autoReload\">\n <span>\n Auto refresh\n </span>\n </mat-slide-toggle>\n }\n </div>\n }\n </div>\n }\n</ng-template>\n<ng-template #heading>\n @if (config.heading) {\n <div class=\"heading\">\n <h2>\n {{ config.heading }}\n </h2>\n <div class=\"subheading\">\n {{ config.subheading }}\n </div>\n </div>\n }\n</ng-template>", styles: [":host{margin-bottom:20px;display:block}.filter-status-container{flex-grow:1;display:flex;justify-content:center;flex-direction:column;align-self:flex-end}.filter-status-container .filter-status{overflow:hidden;text-overflow:ellipsis;line-height:18px}.filter-container{width:100%}.filter-inner-container{flex-direction:row;box-sizing:border-box;display:flex;position:relative;align-items:center}.filter-inner-container .filter-inner-inputs{flex-direction:row;box-sizing:border-box;display:flex;align-items:center;min-width:0;gap:5px}.filter-actions{display:flex;align-items:center;flex:1;justify-content:flex-end}.filter-toolbar{white-space:nowrap;display:flex;align-items:center}.filter-toolbar .button-filters,.filter-toolbar .button-reload{display:flex;width:40px;padding:8px;height:40px;overflow:hidden}.filter-toolbar .button-filters ::ng-deep svg,.filter-toolbar .button-reload ::ng-deep svg{display:flex}.filter-toolbar .filter-reload{margin-left:10px;display:flex;align-items:center}.filter-toolbar .filter-reload .auto-reload{margin-right:5px}.filter-toolbar .filter-reload .auto-reload span{font-size:80%}.heading{margin-right:10px}.heading h2{margin:0}.heading h2+.subheading{margin:0}.results{min-height:90px;position:relative;overflow-x:auto;overflow-y:hidden}fs-filter-chips{margin:4px 0;display:flex;flex-wrap:wrap;gap:5px}@media screen and (min-width: 1200px){html.fs-filter-open body{margin-right:350px}}html.fs-filter-open{scrollbar-width:none}:host ::ng-deep .auto-reload.mat-checked .mat-slide-toggle-thumb-container{transform:translate3d(12px,0,0)}:host ::ng-deep .auto-reload:not(.mat-checked) .mat-slide-toggle-content{color:#ccc}:host ::ng-deep .auto-reload .mat-slide-toggle-thumb,:host ::ng-deep .auto-reload .mat-slide-toggle-thumb-container{height:15px;width:15px}:host ::ng-deep .auto-reload .mat-slide-toggle-content{font-size:90%}:host ::ng-deep .auto-reload .mat-slide-toggle-bar{width:26px;height:10px;border-radius:10px}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: FsSavedFilterAutocompleteChipsComponent, selector: "fs-saved-filter-autocomplete-chips", inputs: ["savedFiltersController"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: FsFormModule }, { kind: "directive", type: i2.FsFormNoFsValidatorsDirective, selector: "[ngModel]:not([required]):not([fsFormRequired]):not([fsFormCompare]):not([fsFormDateRange]):not([fsFormEmail]):not([fsFormEmails]):not([fsFormFunction]):not([fsFormGreater]):not([fsFormGreaterEqual]):not([fsFormInteger]):not([fsFormLesser]):not([fsFormMax]):not([fsFormMaxLength]):not([fsFormMin]):not([fsFormMinLength]):not([fsFormNumeric]):not([fsFormPattern]):not([fsFormPhone]):not([fsFormUrl]):not([validate])" }, { kind: "ngmodule", type: FsClearModule }, { kind: "component", type: FsFilterChipsComponent, selector: "fs-filter-chips" }, { kind: "component", type: FsFilterActionsComponent, selector: "fs-filter-actions", inputs: ["kebabActions", "actions"] }, { kind: "component", type: MatIconAnchor, selector: "a[mat-icon-button]", exportAs: ["matButton", "matAnchor"] }, { kind: "component", type: MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: KeywordInputComponent, selector: "fs-keyword-input", inputs: ["autofocus"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
416
+ ], queries: [{ propertyName: "statusBar", first: true, predicate: FilterStatusBarDirective, descendants: true }], viewQueries: [{ propertyName: "keywordInput", first: true, predicate: KeywordInputComponent, descendants: true }, { propertyName: "reloadEl", first: true, predicate: ["reloadEl"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"filter-container\">\n @if (notInlineToolbar$ | async) {\n <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n }\n <div class=\"filter-inner-container\">\n @if (notInlineToolbar$ | async) {\n <div class=\"filter-inner-inputs\">\n @if (keywordVisible$ | async) {\n <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n }\n @if (savedFilterController.enabled) {\n <fs-saved-filter-autocomplete-chips [savedFiltersController]=\"savedFilterController\"></fs-saved-filter-autocomplete-chips>\n }\n </div>\n } @else {\n <div>\n <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n </div>\n }\n <ng-container [ngTemplateOutlet]=\"filterToolbar\"></ng-container>\n <ng-container [ngTemplateOutlet]=\"filterActions\"></ng-container>\n </div>\n @if (notInlineToolbar$ | async) {\n <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n }\n</div>\n<ng-template #filterStatusBarChips>\n @if (statusBar) {\n <div\n class=\"filter-status-container\"\n [ngClass]=\"{ 'has-status': !!filterStatus.textContent }\">\n <div\n class=\"filter-status\"\n #filterStatus>\n <ng-container *ngTemplateOutlet=\"statusBar.templateRef\"></ng-container>\n </div>\n </div>\n }\n @if (config.chips) {\n <fs-filter-chips class=\"filter-chips\"></fs-filter-chips>\n }\n</ng-template>\n<ng-template #filterActions>\n @if (actionsVisible$ | async) {\n <div class=\"filter-actions\">\n <fs-filter-actions\n [actions]=\"actions$ | async\"\n [kebabActions]=\"menuActions$ | async\">\n </fs-filter-actions>\n </div>\n }\n</ng-template>\n<ng-template #filterToolbar>\n @if (config.reload || config.autoReload || ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting)) {\n <div class=\"filter-toolbar\">\n @if ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting) {\n <a\n mat-icon-button\n class=\"button-filters\"\n (click)=\"filterButtonClick($event)\"\n [color]=\"config.button.color\">\n @if (config.button.icon) {\n <mat-icon [svgIcon]=\"'filterOutline'\"></mat-icon>\n }\n </a>\n }\n @if (config.reload) {\n <a\n mat-icon-button\n (click)=\"reload($event)\"\n class=\"button-reload\">\n <mat-icon #reloadEl>\n refresh\n </mat-icon>\n </a>\n }\n @if (config.autoReload) {\n <div class=\"filter-reload\">\n @if (config.autoReload) {\n <mat-slide-toggle\n name=\"autoReload\"\n class=\"auto-reload\"\n [(ngModel)]=\"autoReload\">\n <span>\n Auto refresh\n </span>\n </mat-slide-toggle>\n }\n </div>\n }\n </div>\n }\n</ng-template>\n<ng-template #heading>\n @if (config.heading) {\n <div class=\"heading\">\n <h2>\n {{ config.heading }}\n </h2>\n <div class=\"subheading\">\n {{ config.subheading }}\n </div>\n </div>\n }\n</ng-template>", styles: [":host{margin-bottom:20px;display:block}.filter-status-container{flex-grow:1;display:flex;justify-content:center;flex-direction:column;align-self:flex-end}.filter-status-container .filter-status{overflow:hidden;text-overflow:ellipsis;line-height:18px}.filter-container{width:100%}.filter-inner-container{flex-direction:row;box-sizing:border-box;display:flex;position:relative;align-items:center}.filter-inner-container .filter-inner-inputs{flex-direction:row;box-sizing:border-box;display:flex;align-items:center;min-width:0;gap:5px}.filter-actions{display:flex;align-items:center;flex:1;justify-content:flex-end}.filter-toolbar{white-space:nowrap;display:flex;align-items:center}.filter-toolbar .button-filters,.filter-toolbar .button-reload{display:flex;width:40px;padding:8px;height:40px;overflow:hidden}.filter-toolbar .button-filters ::ng-deep svg,.filter-toolbar .button-reload ::ng-deep svg{display:flex}.filter-toolbar .filter-reload{margin-left:10px;display:flex;align-items:center}.filter-toolbar .filter-reload .auto-reload{margin-right:5px}.filter-toolbar .filter-reload .auto-reload span{font-size:80%}.heading{margin-right:10px}.heading h2{margin:0}.heading h2+.subheading{margin:0}.results{min-height:90px;position:relative;overflow-x:auto;overflow-y:hidden}fs-filter-chips{margin:4px 0;display:flex;flex-wrap:wrap;gap:5px}@media screen and (min-width: 1200px){html.fs-filter-open body{margin-right:350px}}html.fs-filter-open{scrollbar-width:none}:host ::ng-deep .auto-reload.mat-checked .mat-slide-toggle-thumb-container{transform:translate3d(12px,0,0)}:host ::ng-deep .auto-reload:not(.mat-checked) .mat-slide-toggle-content{color:#ccc}:host ::ng-deep .auto-reload .mat-slide-toggle-thumb,:host ::ng-deep .auto-reload .mat-slide-toggle-thumb-container{height:15px;width:15px}:host ::ng-deep .auto-reload .mat-slide-toggle-content{font-size:90%}:host ::ng-deep .auto-reload .mat-slide-toggle-bar{width:26px;height:10px;border-radius:10px}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: FsSavedFilterAutocompleteChipsComponent, selector: "fs-saved-filter-autocomplete-chips", inputs: ["savedFiltersController"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: FsFormModule }, { kind: "directive", type: i2.FsFormNoFsValidatorsDirective, selector: "[ngModel]:not([required]):not([fsFormRequired]):not([fsFormCompare]):not([fsFormDateRange]):not([fsFormEmail]):not([fsFormEmails]):not([fsFormFunction]):not([fsFormGreater]):not([fsFormGreaterEqual]):not([fsFormInteger]):not([fsFormLesser]):not([fsFormMax]):not([fsFormMaxLength]):not([fsFormMin]):not([fsFormMinLength]):not([fsFormNumeric]):not([fsFormPattern]):not([fsFormPhone]):not([fsFormUrl]):not([validate])" }, { kind: "ngmodule", type: FsClearModule }, { kind: "component", type: FsFilterChipsComponent, selector: "fs-filter-chips" }, { kind: "component", type: FsFilterActionsComponent, selector: "fs-filter-actions", inputs: ["kebabActions", "actions"] }, { kind: "component", type: MatIconAnchor, selector: "a[mat-icon-button]", exportAs: ["matButton", "matAnchor"] }, { kind: "component", type: MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: KeywordInputComponent, selector: "fs-keyword-input", inputs: ["autofocus"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
426
417
  }
427
418
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterComponent, decorators: [{
428
419
  type: Component,
@@ -450,7 +441,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
450
441
  MatSlideToggle,
451
442
  AsyncPipe,
452
443
  KeywordInputComponent,
453
- ], template: "<div class=\"filter-container\">\n @if (notInlineToolbar$ | async) {\n <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n }\n <div class=\"filter-inner-container\">\n @if (notInlineToolbar$ | async) {\n <div class=\"filter-inner-inputs\">\n @if (keywordVisible$ | async) {\n <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n }\n @if (savedFiltersController.enabled) {\n <fs-saved-filter-autocomplete-chips [savedFiltersController]=\"savedFiltersController\"></fs-saved-filter-autocomplete-chips>\n }\n </div>\n } @else {\n <div>\n <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n </div>\n }\n <ng-container [ngTemplateOutlet]=\"filterToolbar\"></ng-container>\n <ng-container [ngTemplateOutlet]=\"filterActions\"></ng-container>\n </div>\n @if (notInlineToolbar$ | async) {\n <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n }\n</div>\n<ng-template #filterStatusBarChips>\n @if (statusBar) {\n <div\n class=\"filter-status-container\"\n [ngClass]=\"{ 'has-status': !!filterStatus.textContent }\">\n <div\n class=\"filter-status\"\n #filterStatus>\n <ng-container *ngTemplateOutlet=\"statusBar.templateRef\"></ng-container>\n </div>\n </div>\n }\n @if (config.chips) {\n <fs-filter-chips class=\"filter-chips\"></fs-filter-chips>\n }\n</ng-template>\n<ng-template #filterActions>\n @if (actionsVisible$ | async) {\n <div class=\"filter-actions\">\n <fs-filter-actions\n [actions]=\"actions$ | async\"\n [kebabActions]=\"menuActions$ | async\">\n </fs-filter-actions>\n </div>\n }\n</ng-template>\n<ng-template #filterToolbar>\n @if (config.reload || config.autoReload || ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting)) {\n <div class=\"filter-toolbar\">\n @if ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting) {\n <a\n mat-icon-button\n class=\"button-filters\"\n (click)=\"filterButtonClick($event)\"\n [color]=\"config.button.color\">\n @if (config.button.icon) {\n <mat-icon [svgIcon]=\"'filterOutline'\"></mat-icon>\n }\n </a>\n }\n @if (config.reload) {\n <a\n mat-icon-button\n (click)=\"reload($event)\"\n class=\"button-reload\">\n <mat-icon #reloadEl>\n refresh\n </mat-icon>\n </a>\n }\n @if (config.autoReload) {\n <div class=\"filter-reload\">\n @if (config.autoReload) {\n <mat-slide-toggle\n name=\"autoReload\"\n class=\"auto-reload\"\n [(ngModel)]=\"autoReload\">\n <span>\n Auto refresh\n </span>\n </mat-slide-toggle>\n }\n </div>\n }\n </div>\n }\n</ng-template>\n<ng-template #heading>\n @if (config.heading) {\n <div class=\"heading\">\n <h2>\n {{ config.heading }}\n </h2>\n <div class=\"subheading\">\n {{ config.subheading }}\n </div>\n </div>\n }\n</ng-template>", styles: [":host{margin-bottom:20px;display:block}.filter-status-container{flex-grow:1;display:flex;justify-content:center;flex-direction:column;align-self:flex-end}.filter-status-container .filter-status{overflow:hidden;text-overflow:ellipsis;line-height:18px}.filter-container{width:100%}.filter-inner-container{flex-direction:row;box-sizing:border-box;display:flex;position:relative;align-items:center}.filter-inner-container .filter-inner-inputs{flex-direction:row;box-sizing:border-box;display:flex;align-items:center;min-width:0;gap:5px}.filter-actions{display:flex;align-items:center;flex:1;justify-content:flex-end}.filter-toolbar{white-space:nowrap;display:flex;align-items:center}.filter-toolbar .button-filters,.filter-toolbar .button-reload{display:flex;width:40px;padding:8px;height:40px;overflow:hidden}.filter-toolbar .button-filters ::ng-deep svg,.filter-toolbar .button-reload ::ng-deep svg{display:flex}.filter-toolbar .filter-reload{margin-left:10px;display:flex;align-items:center}.filter-toolbar .filter-reload .auto-reload{margin-right:5px}.filter-toolbar .filter-reload .auto-reload span{font-size:80%}.heading{margin-right:10px}.heading h2{margin:0}.heading h2+.subheading{margin:0}.results{min-height:90px;position:relative;overflow-x:auto;overflow-y:hidden}fs-filter-chips{margin:4px 0;display:flex;flex-wrap:wrap;gap:5px}@media screen and (min-width: 1200px){html.fs-filter-open body{margin-right:350px}}html.fs-filter-open{scrollbar-width:none}:host ::ng-deep .auto-reload.mat-checked .mat-slide-toggle-thumb-container{transform:translate3d(12px,0,0)}:host ::ng-deep .auto-reload:not(.mat-checked) .mat-slide-toggle-content{color:#ccc}:host ::ng-deep .auto-reload .mat-slide-toggle-thumb,:host ::ng-deep .auto-reload .mat-slide-toggle-thumb-container{height:15px;width:15px}:host ::ng-deep .auto-reload .mat-slide-toggle-content{font-size:90%}:host ::ng-deep .auto-reload .mat-slide-toggle-bar{width:26px;height:10px;border-radius:10px}\n"] }]
444
+ ], template: "<div class=\"filter-container\">\n @if (notInlineToolbar$ | async) {\n <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n }\n <div class=\"filter-inner-container\">\n @if (notInlineToolbar$ | async) {\n <div class=\"filter-inner-inputs\">\n @if (keywordVisible$ | async) {\n <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n }\n @if (savedFilterController.enabled) {\n <fs-saved-filter-autocomplete-chips [savedFiltersController]=\"savedFilterController\"></fs-saved-filter-autocomplete-chips>\n }\n </div>\n } @else {\n <div>\n <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n </div>\n }\n <ng-container [ngTemplateOutlet]=\"filterToolbar\"></ng-container>\n <ng-container [ngTemplateOutlet]=\"filterActions\"></ng-container>\n </div>\n @if (notInlineToolbar$ | async) {\n <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n }\n</div>\n<ng-template #filterStatusBarChips>\n @if (statusBar) {\n <div\n class=\"filter-status-container\"\n [ngClass]=\"{ 'has-status': !!filterStatus.textContent }\">\n <div\n class=\"filter-status\"\n #filterStatus>\n <ng-container *ngTemplateOutlet=\"statusBar.templateRef\"></ng-container>\n </div>\n </div>\n }\n @if (config.chips) {\n <fs-filter-chips class=\"filter-chips\"></fs-filter-chips>\n }\n</ng-template>\n<ng-template #filterActions>\n @if (actionsVisible$ | async) {\n <div class=\"filter-actions\">\n <fs-filter-actions\n [actions]=\"actions$ | async\"\n [kebabActions]=\"menuActions$ | async\">\n </fs-filter-actions>\n </div>\n }\n</ng-template>\n<ng-template #filterToolbar>\n @if (config.reload || config.autoReload || ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting)) {\n <div class=\"filter-toolbar\">\n @if ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting) {\n <a\n mat-icon-button\n class=\"button-filters\"\n (click)=\"filterButtonClick($event)\"\n [color]=\"config.button.color\">\n @if (config.button.icon) {\n <mat-icon [svgIcon]=\"'filterOutline'\"></mat-icon>\n }\n </a>\n }\n @if (config.reload) {\n <a\n mat-icon-button\n (click)=\"reload($event)\"\n class=\"button-reload\">\n <mat-icon #reloadEl>\n refresh\n </mat-icon>\n </a>\n }\n @if (config.autoReload) {\n <div class=\"filter-reload\">\n @if (config.autoReload) {\n <mat-slide-toggle\n name=\"autoReload\"\n class=\"auto-reload\"\n [(ngModel)]=\"autoReload\">\n <span>\n Auto refresh\n </span>\n </mat-slide-toggle>\n }\n </div>\n }\n </div>\n }\n</ng-template>\n<ng-template #heading>\n @if (config.heading) {\n <div class=\"heading\">\n <h2>\n {{ config.heading }}\n </h2>\n <div class=\"subheading\">\n {{ config.subheading }}\n </div>\n </div>\n }\n</ng-template>", styles: [":host{margin-bottom:20px;display:block}.filter-status-container{flex-grow:1;display:flex;justify-content:center;flex-direction:column;align-self:flex-end}.filter-status-container .filter-status{overflow:hidden;text-overflow:ellipsis;line-height:18px}.filter-container{width:100%}.filter-inner-container{flex-direction:row;box-sizing:border-box;display:flex;position:relative;align-items:center}.filter-inner-container .filter-inner-inputs{flex-direction:row;box-sizing:border-box;display:flex;align-items:center;min-width:0;gap:5px}.filter-actions{display:flex;align-items:center;flex:1;justify-content:flex-end}.filter-toolbar{white-space:nowrap;display:flex;align-items:center}.filter-toolbar .button-filters,.filter-toolbar .button-reload{display:flex;width:40px;padding:8px;height:40px;overflow:hidden}.filter-toolbar .button-filters ::ng-deep svg,.filter-toolbar .button-reload ::ng-deep svg{display:flex}.filter-toolbar .filter-reload{margin-left:10px;display:flex;align-items:center}.filter-toolbar .filter-reload .auto-reload{margin-right:5px}.filter-toolbar .filter-reload .auto-reload span{font-size:80%}.heading{margin-right:10px}.heading h2{margin:0}.heading h2+.subheading{margin:0}.results{min-height:90px;position:relative;overflow-x:auto;overflow-y:hidden}fs-filter-chips{margin:4px 0;display:flex;flex-wrap:wrap;gap:5px}@media screen and (min-width: 1200px){html.fs-filter-open body{margin-right:350px}}html.fs-filter-open{scrollbar-width:none}:host ::ng-deep .auto-reload.mat-checked .mat-slide-toggle-thumb-container{transform:translate3d(12px,0,0)}:host ::ng-deep .auto-reload:not(.mat-checked) .mat-slide-toggle-content{color:#ccc}:host ::ng-deep .auto-reload .mat-slide-toggle-thumb,:host ::ng-deep .auto-reload .mat-slide-toggle-thumb-container{height:15px;width:15px}:host ::ng-deep .auto-reload .mat-slide-toggle-content{font-size:90%}:host ::ng-deep .auto-reload .mat-slide-toggle-bar{width:26px;height:10px;border-radius:10px}\n"] }]
454
445
  }], ctorParameters: () => [], propDecorators: { keywordInput: [{
455
446
  type: ViewChild,
456
447
  args: [KeywordInputComponent]
@@ -482,4 +473,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
482
473
  type: HostBinding,
483
474
  args: ['class.fs-filter']
484
475
  }] } });
485
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.component.js","sourceRoot":"","sources":["../../../../../src/app/components/filter/filter.component.ts","../../../../../src/app/components/filter/filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgClass, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { MatIconAnchor } from '@angular/material/button';\nimport { MatIcon, MatIconRegistry } from '@angular/material/icon';\nimport { MatSlideToggle } from '@angular/material/slide-toggle';\n\nimport { FsClearModule } from '@firestitch/clear';\nimport { FsFormModule } from '@firestitch/form';\n\nimport { BehaviorSubject, combineLatest, fromEvent, interval, Observable, of, Subject } from 'rxjs';\nimport { debounceTime, filter, map, takeUntil } from 'rxjs/operators';\n\nimport { ActionsController } from '../../classes/actions-controller';\nimport { FilterIcon } from '../../consts';\nimport { IFilterSavedFilter, ISortingChangeEvent, KeyValue } from '../../interfaces';\nimport { FsFilterAction } from '../../interfaces/action.interface';\nimport {\n  FilterConfig,\n  IFilterConfigItem,\n} from '../../interfaces/config.interface';\nimport { IUpdateFilterItemConfig } from '../../interfaces/update-filter-item.interface';\nimport { FsFilterConfig } from '../../models/filter-config';\nimport { BaseItem } from '../../models/items/base-item';\nimport { SortController } from '../../services';\nimport { FilterController } from '../../services/filter-controller.service';\nimport { FsFilterOverlayService } from '../../services/filter-overlay.service';\nimport { FocusControllerService } from '../../services/focus-controller.service';\nimport { KeywordController } from '../../services/keyword-controller.service';\nimport { PersistanceController } from '../../services/persistance-controller.service';\nimport { QueryParamController } from '../../services/query-param-controller.service';\nimport { SavedFilterController } from '../../services/saved-filter-controller.service';\nimport { FsFilterActionsComponent } from '../actions/actions.component';\nimport { FsFilterChipsComponent } from '../filter-chips/filter-chips.component';\nimport { KeywordInputComponent } from '../keyword-input/keyword-input.component';\nimport { FsSavedFilterAutocompleteChipsComponent } from '../saved-filter/saved-filter-autocomplete-chips/saved-filter-autocomplete-chips.component';\n\nimport { FilterStatusBarDirective } from './../../directives/status-bar/status-bar.directive';\nimport { FS_FILTER_CONFIG } from './../../injectors/filter-config';\n\n\n@Component({\n  selector: 'fs-filter',\n  styleUrls: ['./filter.component.scss'],\n  templateUrl: './filter.component.html',\n  providers: [\n    FsFilterOverlayService,\n    PersistanceController,\n    QueryParamController,\n    FocusControllerService,\n    FilterController,\n    SavedFilterController,\n    ActionsController,\n    KeywordController,\n    SortController,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgTemplateOutlet,\n    FsSavedFilterAutocompleteChipsComponent,\n    NgClass,\n    MatIcon,\n    FormsModule,\n    FsFormModule,\n    FsClearModule,\n    FsFilterChipsComponent,\n    FsFilterActionsComponent,\n    MatIconAnchor,\n    MatSlideToggle,\n    AsyncPipe,\n    KeywordInputComponent,\n  ],\n})\nexport class FilterComponent implements OnInit, OnDestroy {\n\n  @ViewChild(KeywordInputComponent)\n  public keywordInput: KeywordInputComponent;\n\n  /**\n   * @deprecated Use set config instead\n   */\n  @Input('filterConfig') public set filterConfig(value: FilterConfig) {\n    this.config = value;\n  }\n  \n  @Input('config') public set config(value: FilterConfig) {\n    this._config = new FsFilterConfig(value);\n  }\n  \n  public get config(): FsFilterConfig {\n    return this._config;\n  }\n\n  @Output() public closed = new EventEmitter<any>();\n  @Output() public opened = new EventEmitter<any>();\n  @Output() public ready = new EventEmitter<void>();\n\n  @ContentChild(FilterStatusBarDirective)\n  public statusBar: FilterStatusBarDirective;\n\n  @ViewChild('reloadEl', { read: ElementRef })\n  public reloadEl: ElementRef;\n\n  @HostBinding('class.filters-open')\n  public showFilterMenu = false;\n\n  @HostBinding('class.window-desktop')\n  public windowDesktop = false;\n\n  @HostBinding('class.fs-filter')\n  public fsFilterClass = true;\n\n  private _config: FsFilterConfig;\n  private _filtersBtnVisible$ = new BehaviorSubject(true);\n  private _hasFilterChips$ = new BehaviorSubject(false);\n  private _destroy$ = new Subject<void>();\n  private _defaultConfig = inject(FS_FILTER_CONFIG, { optional: true });\n  private _filterOverlay = inject(FsFilterOverlayService);\n  private _zone = inject(NgZone);\n  private _actionsController = inject(ActionsController);\n  private _filterController = inject(FilterController);\n  private _sortController = inject(SortController);\n  private _savedFilterController = inject(SavedFilterController);\n  private _keywordController = inject(KeywordController);\n\n  constructor(\n  ) {\n    this._filterController.filter = this;\n    this._updateWindowWidth();\n    this._listenWindowResize();\n    this._initIcon();\n  }\n\n  public get queryParams(): KeyValue {\n    return this._filterController.queryParam;\n  }\n\n  public get query(): KeyValue {\n    return this._filterController.query;\n  }\n\n  public get values(): KeyValue {\n    return this._filterController.values;\n  }\n\n  /**\n   *\n   * Do update value of some field\n   *\n   * @param values - values for update\n   *\n   * To update text value just pass new text value\n   *\n   * public updateSelectValue(val) {\n   *   this.filterEl.updateValues({ keyword: val });\n   * }\n   *\n   * To update select or observable select you could pass suitable value\n   *\n   * public updateSelectValue(val: number) {\n   *   this.filterEl.updateValues({ simple_select: val }, { observable_select: val });\n   * }\n   *\n   * To update checkbox value just pass true/false as value\n   *\n   * public updateCheckox(val: boolean) {\n   *   this.filterEl.updateValues({ checkbox: val });\n   * }\n   *\n   * To update range value just pass object with min&max object or just with one of targets\n   *\n   * Ex.: { min: 10, max 15 }, { min: 5 }, { max 5 }\n   *\n   * public updateRange(val) {\n   *   this.filterEl.updateValues({ range: val });\n   * }\n   *\n   * To update autocomplete just pass object with name/value fields\n   *\n   * Ex.: { name: 'John Doe', value: 1 }\n   *\n   * public updateAutocomplete(val) {\n   *   this.filterEl.updateValues({ autocomplete_user_id: val });\n   * }\n   *\n   * To update autocompletechips just pass:\n   *\n   * 1) object with name/value fields - will be appended to existing set of values\n   *\n   * { name: 'John Doe', value: 1 }\n   *\n   * 2) array of objects - will be appended to existing set of values\n   *\n   * [{ name: 'John Doe', value: 1 }, { name: 'Darya Filipova', value: 2 }]\n   *\n   * 3) null - clear existing set of values\n   *\n   * public updateAutocomplete(val) {\n   *   this.filterEl.updateValues({ autocompletechips_user_id: val });\n   * }\n   *\n   */\n  public set values(values) {\n    this._filterController.values = values;\n  }\n\n  public get items(): BaseItem<IFilterConfigItem>[] {\n    return this._filterController.items;\n  }\n\n  public get visibleItems() {\n    return this._filterController.items\n      .filter((item) => !item.hidden);\n  }\n\n  public get autoReload(): boolean {\n    return !!this.config.autoReload;\n  }\n\n  public get hasFilterChips$(): Observable<boolean> {\n    return this._hasFilterChips$.asObservable();\n  }\n\n  public get hasVisibleItemOrSorting(): boolean {\n    return this.visibleItems.length > 0;\n  }\n\n  public get filtersBtnVisible$(): Observable<boolean> {\n    return this._filtersBtnVisible$.asObservable();\n  }\n\n  public get keywordVisible$(): Observable<boolean> {\n    return this._keywordController.keywordVisible$;\n  }\n\n  public get inlineToolbar$(): Observable<boolean> {\n    return combineLatest({\n      keywordVisible: this.keywordVisible$,\n      activeFilter: of(this.savedFiltersController.enabled),\n    })\n      .pipe(\n        map(({ keywordVisible, activeFilter }) => {\n          return !keywordVisible && !activeFilter;\n        }),\n      );\n  }\n\n  public get notInlineToolbar$(): Observable<boolean> {\n    return this.inlineToolbar$\n      .pipe(\n        map((inline) => !inline),\n      );\n  }\n\n  public get actionsVisible$() {\n    return this._actionsController.visible$;\n  }\n\n  public get actions$() {\n    return this._actionsController.actions$;\n  }\n\n  public get menuActions$() {\n    return this._actionsController.menuActions$;\n  }\n\n  public set activeSavedFilter(savedFilter: IFilterSavedFilter) {\n    this._savedFilterController.setActiveFilter(savedFilter);\n  }\n\n  public get activeSavedFilter(): IFilterSavedFilter {\n    return this._savedFilterController.activeFilter;\n  }\n\n  public get savedFilters(): IFilterSavedFilter[] {\n    return this._savedFilterController.savedFilters;\n  }\n\n  public get savedFiltersController(): SavedFilterController {\n    return this._savedFilterController;\n  }\n\n  public ngOnInit() {\n    const config = {\n      ...(this._defaultConfig || {}),\n      ...this.config,\n    };\n\n    this._config = new FsFilterConfig(config);\n    this._actionsController.setConfig(this._config);\n\n    this._initItems();\n    this._initAutoReload();\n    this._initOverlay();\n  }\n\n  public ngOnDestroy() {\n    this._destroyFilterDrawer();\n\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n  public focus() {\n    this.keywordInput?.focus();\n  }\n\n  public updateSort(sort: ISortingChangeEvent) {\n    this._sortController.updateSort(sort);\n  }\n\n  public hideDrawer() {\n    this.closed.emit();\n    this._destroyFilterDrawer();\n  }\n\n  public showDrawer() {\n    if (!this.hasVisibleItemOrSorting) {\n      return;\n    }\n\n    this._listenEscButton();\n\n    this.opened.emit();\n\n    this._filterOverlay.open();\n  }\n\n  public filterButtonClick(event = null) {\n    event.stopPropagation();\n\n    if (this._filterOverlay.opened()) {\n      this.hideDrawer();\n    } else {\n      this.showDrawer();\n    }\n  }\n\n  public get itemValues(): any[] {\n    return this.items\n      .map((item) => item.value);\n  }\n\n  public get nonEmptyItemValues(): any[] {\n    return this.items\n      .filter((item) => item.value !== undefined)\n      .map((item) => item.value);\n  }\n\n  public get hasItemValues(): boolean {\n    return this.items\n      .some((item) => item.value !== undefined);\n  }\n\n  public getItemValue(name: string) {\n    const item = this.items\n      .find((_item) => _item.name === name);\n\n    return item?.value;\n  }\n\n  public showItem(name: string) {\n    this.getItem(name)?.show();\n  }\n\n  public hideItem(name: string) {\n    this.getItem(name)?.hide();\n  }\n\n  public clearItem(name: string) {\n    const item = this.getItem(name);\n\n    if (!item) {\n      return;\n    }\n\n    item.clear();\n  }\n\n  public updateItemConfig(\n    name: string,\n    params: IUpdateFilterItemConfig,\n  ): void {\n    const item = this.getItem(name);\n\n    if (!item) {\n      return;\n    }\n\n    item.label = params.label ?? item.label;\n    item.chipLabel = params.chipLabel ?? item.chipLabel;\n  }\n\n  public clear(event = null) {\n    if (event) {\n      event.stopPropagation();\n    }\n\n    this._filterController.filtersClear();\n\n    if (this.config.clear) {\n      this.config.clear();\n    }\n\n    this.keywordInput.clear();\n  }\n\n  public reload(event = null) {\n    if (event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n\n    const el = this.reloadEl?.nativeElement;\n\n    if(el) {\n      el.style.transition = 'all 0.75s 0.0s';\n      el.style.transform = 'rotate(360deg)';\n\n      setTimeout(() => {\n        el.style.transition = null;\n        el.style.transform = null;\n      }, 1000);\n    }\n\n    if (this.config.reload) {\n      this.config.reload(this._filterController.query, this._sortController.getSort());\n    }\n  }\n\n  public getItem(name): BaseItem<any> {\n    return this.items\n      .find((item) => item.name === name);\n  }\n\n  /**\n   * Update filter actions config\n   *\n   * @param actions\n   */\n  public updateActions(actions: FsFilterAction[]): void {\n    this._actionsController.initActions(actions);\n  }\n\n  /**\n   * Show \"Filters\" button\n   */\n  public showFiltersBtn(): void {\n    this._filtersBtnVisible$.next(true);\n  }\n\n  /**\n   * Hide \"Filters\" button\n   */\n  public hideFiltersBtn(): void {\n    this._filtersBtnVisible$.next(false);\n  }\n\n  /**\n   * Show \"Keyword\" field if it present\n   */\n  public showKeywordField(): void {\n    this.keywordInput.show();\n  }\n\n  /**\n   * Hide \"Keyword\" field if it present\n   */\n  public hideKeywordField(): void {\n    this.keywordInput.hide();\n  }\n\n  /**\n   * Go through actions and check show() callback and update visible actions\n   */\n  public updateActionsVisibility(): void {\n    this._actionsController.updateActionsVisibility();\n  }\n\n  /**\n   * Go through actions and check disabled() callback and update disabled state\n   */\n  public updateDisabledState(): void {\n    this._actionsController.updateDisabledState();\n  }\n\n  private _destroyFilterDrawer() {\n    this._filterOverlay.close();\n  }\n\n  private _updateWindowWidth() {\n    this.windowDesktop = window.innerWidth > 1200;\n  }\n\n  private _listenEscButton() {\n    this._zone.runOutsideAngular(() => {\n      fromEvent(window, 'keyup')\n        .pipe(\n          filter((event: KeyboardEvent) => event.code === 'Escape'),\n          takeUntil(this.closed),\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this._zone.run(() => {\n            this.hideDrawer();\n          });\n        });\n    });\n  }\n\n  private _initIcon() {\n    const iconRegistry = inject(MatIconRegistry);\n    const sanitizer = inject(DomSanitizer);\n\n    iconRegistry.addSvgIconLiteral('filterOutline', sanitizer.bypassSecurityTrustHtml(FilterIcon));\n  }\n\n  private _listenWindowResize() {\n    this._zone.runOutsideAngular(() => {\n      fromEvent(window, 'resize')\n        .pipe(\n          debounceTime(100),\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this._zone.run(() => {\n            this._updateWindowWidth();\n          });\n        });\n    });\n  }\n\n  private _initItems() {\n    this._filterController.init(this._config);\n  }\n\n  private _initAutoReload() {\n    if(this.config.autoReload) {\n      interval(this.config.autoReload.seconds * 1000)\n        .pipe(\n          filter(() => this.autoReload),\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this.reload(null);\n        });\n    }\n  }\n\n  private _initOverlay() {\n    this._filterOverlay.attach$\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this.showFilterMenu = true;\n      });\n\n    this._filterOverlay.detach$\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this.showFilterMenu = false;\n      });\n\n    this._filterOverlay.setClearFn(this.clear.bind(this));\n    this._filterOverlay.setDoneFn(this.hideDrawer.bind(this));\n  }\n}\n","<div class=\"filter-container\">\n  @if (notInlineToolbar$ | async) {\n    <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n  }\n  <div class=\"filter-inner-container\">\n    @if (notInlineToolbar$ | async) {\n      <div class=\"filter-inner-inputs\">\n        @if (keywordVisible$ | async) {\n          <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n        }\n        @if (savedFiltersController.enabled) {\n          <fs-saved-filter-autocomplete-chips [savedFiltersController]=\"savedFiltersController\"></fs-saved-filter-autocomplete-chips>\n        }\n      </div>\n    } @else {\n      <div>\n        <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n        <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n      </div>\n    }\n    <ng-container [ngTemplateOutlet]=\"filterToolbar\"></ng-container>\n    <ng-container [ngTemplateOutlet]=\"filterActions\"></ng-container>\n  </div>\n  @if (notInlineToolbar$ | async) {\n    <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n  }\n</div>\n<ng-template #filterStatusBarChips>\n  @if (statusBar) {\n    <div\n        class=\"filter-status-container\"\n        [ngClass]=\"{ 'has-status': !!filterStatus.textContent }\">\n      <div\n          class=\"filter-status\"\n          #filterStatus>\n        <ng-container *ngTemplateOutlet=\"statusBar.templateRef\"></ng-container>\n      </div>\n    </div>\n  }\n  @if (config.chips) {\n    <fs-filter-chips class=\"filter-chips\"></fs-filter-chips>\n  }\n</ng-template>\n<ng-template #filterActions>\n  @if (actionsVisible$ | async) {\n    <div class=\"filter-actions\">\n      <fs-filter-actions\n        [actions]=\"actions$ | async\"\n        [kebabActions]=\"menuActions$ | async\">\n      </fs-filter-actions>\n    </div>\n  }\n</ng-template>\n<ng-template #filterToolbar>\n  @if (config.reload || config.autoReload || ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting)) {\n    <div class=\"filter-toolbar\">\n      @if ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting) {\n        <a\n            mat-icon-button\n            class=\"button-filters\"\n            (click)=\"filterButtonClick($event)\"\n            [color]=\"config.button.color\">\n          @if (config.button.icon) {\n            <mat-icon [svgIcon]=\"'filterOutline'\"></mat-icon>\n          }\n        </a>\n      }\n      @if (config.reload) {\n        <a\n            mat-icon-button\n            (click)=\"reload($event)\"\n            class=\"button-reload\">\n          <mat-icon #reloadEl>\n            refresh\n          </mat-icon>\n        </a>\n      }\n      @if (config.autoReload) {\n        <div class=\"filter-reload\">\n          @if (config.autoReload) {\n            <mat-slide-toggle\n                name=\"autoReload\"\n                class=\"auto-reload\"\n                [(ngModel)]=\"autoReload\">\n              <span>\n                Auto refresh\n              </span>\n            </mat-slide-toggle>\n          }\n        </div>\n      }\n    </div>\n  }\n</ng-template>\n<ng-template #heading>\n  @if (config.heading) {\n    <div class=\"heading\">\n      <h2>\n        {{ config.heading }}\n      </h2>\n      <div class=\"subheading\">\n        {{ config.subheading }}\n      </div>\n    </div>\n  }\n</ng-template>"]}
476
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.component.js","sourceRoot":"","sources":["../../../../../src/app/components/filter/filter.component.ts","../../../../../src/app/components/filter/filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgClass, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { MatIconAnchor } from '@angular/material/button';\nimport { MatIcon, MatIconRegistry } from '@angular/material/icon';\nimport { MatSlideToggle } from '@angular/material/slide-toggle';\n\nimport { FsClearModule } from '@firestitch/clear';\nimport { FsFormModule } from '@firestitch/form';\n\nimport { BehaviorSubject, combineLatest, fromEvent, interval, Observable, of, Subject } from 'rxjs';\nimport { debounceTime, filter, map, takeUntil } from 'rxjs/operators';\n\nimport { ActionsController } from '../../classes/actions-controller';\nimport { FilterIcon } from '../../consts';\nimport { ISortingChangeEvent, KeyValue } from '../../interfaces';\nimport { FsFilterAction } from '../../interfaces/action.interface';\nimport {\n  FilterConfig,\n  IFilterConfigItem,\n} from '../../interfaces/config.interface';\nimport { IUpdateFilterItemConfig } from '../../interfaces/update-filter-item.interface';\nimport { FsFilterConfig } from '../../models/filter-config';\nimport { BaseItem } from '../../models/items/base-item';\nimport { SortController } from '../../services';\nimport { FilterController } from '../../services/filter-controller.service';\nimport { FsFilterOverlayService } from '../../services/filter-overlay.service';\nimport { FocusControllerService } from '../../services/focus-controller.service';\nimport { KeywordController } from '../../services/keyword-controller.service';\nimport { PersistanceController } from '../../services/persistance-controller.service';\nimport { QueryParamController } from '../../services/query-param-controller.service';\nimport { SavedFilterController } from '../../services/saved-filter-controller.service';\nimport { FsFilterActionsComponent } from '../actions/actions.component';\nimport { FsFilterChipsComponent } from '../filter-chips/filter-chips.component';\nimport { KeywordInputComponent } from '../keyword-input/keyword-input.component';\nimport { FsSavedFilterAutocompleteChipsComponent } from '../saved-filter/saved-filter-autocomplete-chips/saved-filter-autocomplete-chips.component';\n\nimport { FilterStatusBarDirective } from './../../directives/status-bar/status-bar.directive';\nimport { FS_FILTER_CONFIG } from './../../injectors/filter-config';\n\n\n@Component({\n  selector: 'fs-filter',\n  styleUrls: ['./filter.component.scss'],\n  templateUrl: './filter.component.html',\n  providers: [\n    FsFilterOverlayService,\n    PersistanceController,\n    QueryParamController,\n    FocusControllerService,\n    FilterController,\n    SavedFilterController,\n    ActionsController,\n    KeywordController,\n    SortController,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgTemplateOutlet,\n    FsSavedFilterAutocompleteChipsComponent,\n    NgClass,\n    MatIcon,\n    FormsModule,\n    FsFormModule,\n    FsClearModule,\n    FsFilterChipsComponent,\n    FsFilterActionsComponent,\n    MatIconAnchor,\n    MatSlideToggle,\n    AsyncPipe,\n    KeywordInputComponent,\n  ],\n})\nexport class FilterComponent implements OnInit, OnDestroy {\n\n  @ViewChild(KeywordInputComponent)\n  public keywordInput: KeywordInputComponent;\n\n  /**\n   * @deprecated Use set config instead\n   */\n  @Input('filterConfig') public set filterConfig(value: FilterConfig) {\n    this.config = value;\n  }\n  \n  @Input('config') public set config(value: FilterConfig) {\n    this._config = new FsFilterConfig(value);\n  }\n  \n  public get config(): FsFilterConfig {\n    return this._config;\n  }\n\n  @Output() public closed = new EventEmitter<any>();\n  @Output() public opened = new EventEmitter<any>();\n  @Output() public ready = new EventEmitter<void>();\n\n  @ContentChild(FilterStatusBarDirective)\n  public statusBar: FilterStatusBarDirective;\n\n  @ViewChild('reloadEl', { read: ElementRef })\n  public reloadEl: ElementRef;\n\n  @HostBinding('class.filters-open')\n  public showFilterMenu = false;\n\n  @HostBinding('class.window-desktop')\n  public windowDesktop = false;\n\n  @HostBinding('class.fs-filter')\n  public fsFilterClass = true;\n\n  private _config: FsFilterConfig;\n  private _filtersBtnVisible$ = new BehaviorSubject(true);\n  private _hasFilterChips$ = new BehaviorSubject(false);\n  private _destroy$ = new Subject<void>();\n  private _defaultConfig = inject(FS_FILTER_CONFIG, { optional: true });\n  private _filterOverlay = inject(FsFilterOverlayService);\n  private _zone = inject(NgZone);\n  private _actionsController = inject(ActionsController);\n  private _filterController = inject(FilterController);\n  private _sortController = inject(SortController);\n  private _savedFilterController = inject(SavedFilterController);\n  private _keywordController = inject(KeywordController);\n\n  constructor(\n  ) {\n    this._filterController.filter = this;\n    this._updateWindowWidth();\n    this._listenWindowResize();\n    this._initIcon();\n  }\n\n  public get queryParams(): KeyValue {\n    return this._filterController.queryParam;\n  }\n\n  public get query(): KeyValue {\n    return this._filterController.query;\n  }\n\n  public get values(): KeyValue {\n    return this._filterController.values;\n  }\n\n  /**\n   *\n   * Do update value of some field\n   *\n   * @param values - values for update\n   *\n   * To update text value just pass new text value\n   *\n   * public updateSelectValue(val) {\n   *   this.filterEl.updateValues({ keyword: val });\n   * }\n   *\n   * To update select or observable select you could pass suitable value\n   *\n   * public updateSelectValue(val: number) {\n   *   this.filterEl.updateValues({ simple_select: val }, { observable_select: val });\n   * }\n   *\n   * To update checkbox value just pass true/false as value\n   *\n   * public updateCheckox(val: boolean) {\n   *   this.filterEl.updateValues({ checkbox: val });\n   * }\n   *\n   * To update range value just pass object with min&max object or just with one of targets\n   *\n   * Ex.: { min: 10, max 15 }, { min: 5 }, { max 5 }\n   *\n   * public updateRange(val) {\n   *   this.filterEl.updateValues({ range: val });\n   * }\n   *\n   * To update autocomplete just pass object with name/value fields\n   *\n   * Ex.: { name: 'John Doe', value: 1 }\n   *\n   * public updateAutocomplete(val) {\n   *   this.filterEl.updateValues({ autocomplete_user_id: val });\n   * }\n   *\n   * To update autocompletechips just pass:\n   *\n   * 1) object with name/value fields - will be appended to existing set of values\n   *\n   * { name: 'John Doe', value: 1 }\n   *\n   * 2) array of objects - will be appended to existing set of values\n   *\n   * [{ name: 'John Doe', value: 1 }, { name: 'Darya Filipova', value: 2 }]\n   *\n   * 3) null - clear existing set of values\n   *\n   * public updateAutocomplete(val) {\n   *   this.filterEl.updateValues({ autocompletechips_user_id: val });\n   * }\n   *\n   */\n  public set values(values) {\n    this._filterController.values = values;\n  }\n\n  public get items(): BaseItem<IFilterConfigItem>[] {\n    return this._filterController.items;\n  }\n\n  public get visibleItems() {\n    return this._filterController.items\n      .filter((item) => !item.hidden);\n  }\n\n  public get autoReload(): boolean {\n    return !!this.config.autoReload;\n  }\n\n  public get hasFilterChips$(): Observable<boolean> {\n    return this._hasFilterChips$.asObservable();\n  }\n\n  public get hasVisibleItemOrSorting(): boolean {\n    return this.visibleItems.length > 0;\n  }\n\n  public get filtersBtnVisible$(): Observable<boolean> {\n    return this._filtersBtnVisible$.asObservable();\n  }\n\n  public get keywordVisible$(): Observable<boolean> {\n    return this._keywordController.keywordVisible$;\n  }\n\n  public get inlineToolbar$(): Observable<boolean> {\n    return combineLatest({\n      keywordVisible: this.keywordVisible$,\n      activeFilter: of(this.savedFilterController.enabled),\n    })\n      .pipe(\n        map(({ keywordVisible, activeFilter }) => {\n          return !keywordVisible && !activeFilter;\n        }),\n      );\n  }\n\n  public get notInlineToolbar$(): Observable<boolean> {\n    return this.inlineToolbar$\n      .pipe(\n        map((inline) => !inline),\n      );\n  }\n\n  public get actionsVisible$() {\n    return this._actionsController.visible$;\n  }\n\n  public get actions$() {\n    return this._actionsController.actions$;\n  }\n\n  public get menuActions$() {\n    return this._actionsController.menuActions$;\n  }\n\n  public get savedFilterController(): SavedFilterController {\n    return this._savedFilterController;\n  }\n\n  public ngOnInit() {\n    const config = {\n      ...(this._defaultConfig || {}),\n      ...this.config,\n    };\n\n    this._config = new FsFilterConfig(config);\n    this._actionsController.setConfig(this._config);\n\n    this._initItems();\n    this._initAutoReload();\n    this._initOverlay();\n  }\n\n  public ngOnDestroy() {\n    this._destroyFilterDrawer();\n\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n  public focus() {\n    this.keywordInput?.focus();\n  }\n\n  public updateSort(sort: ISortingChangeEvent) {\n    this._sortController.updateSort(sort);\n  }\n\n  public hideDrawer() {\n    this.closed.emit();\n    this._destroyFilterDrawer();\n  }\n\n  public showDrawer() {\n    if (!this.hasVisibleItemOrSorting) {\n      return;\n    }\n\n    this._listenEscButton();\n\n    this.opened.emit();\n\n    this._filterOverlay.open();\n  }\n\n  public filterButtonClick(event = null) {\n    event.stopPropagation();\n\n    if (this._filterOverlay.opened()) {\n      this.hideDrawer();\n    } else {\n      this.showDrawer();\n    }\n  }\n\n  public get itemValues(): any[] {\n    return this.items\n      .map((item) => item.value);\n  }\n\n  public get nonEmptyItemValues(): any[] {\n    return this.items\n      .filter((item) => item.value !== undefined)\n      .map((item) => item.value);\n  }\n\n  public get hasItemValues(): boolean {\n    return this.items\n      .some((item) => item.value !== undefined);\n  }\n\n  public getItemValue(name: string) {\n    const item = this.items\n      .find((_item) => _item.name === name);\n\n    return item?.value;\n  }\n\n  public showItem(name: string) {\n    this.getItem(name)?.show();\n  }\n\n  public hideItem(name: string) {\n    this.getItem(name)?.hide();\n  }\n\n  public clearItem(name: string) {\n    const item = this.getItem(name);\n\n    if (!item) {\n      return;\n    }\n\n    item.clear();\n  }\n\n  public updateItemConfig(\n    name: string,\n    params: IUpdateFilterItemConfig,\n  ): void {\n    const item = this.getItem(name);\n\n    if (!item) {\n      return;\n    }\n\n    item.label = params.label ?? item.label;\n    item.chipLabel = params.chipLabel ?? item.chipLabel;\n  }\n\n  public clear(event = null) {\n    if (event) {\n      event.stopPropagation();\n    }\n\n    this._filterController.filtersClear();\n\n    if (this.config.clear) {\n      this.config.clear();\n    }\n\n    this.keywordInput.clear();\n  }\n\n  public reload(event = null) {\n    if (event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n\n    const el = this.reloadEl?.nativeElement;\n\n    if(el) {\n      el.style.transition = 'all 0.75s 0.0s';\n      el.style.transform = 'rotate(360deg)';\n\n      setTimeout(() => {\n        el.style.transition = null;\n        el.style.transform = null;\n      }, 1000);\n    }\n\n    if (this.config.reload) {\n      this.config.reload(this._filterController.query, this._sortController.getSort());\n    }\n  }\n\n  public getItem(name): BaseItem<any> {\n    return this.items\n      .find((item) => item.name === name);\n  }\n\n  /**\n   * Update filter actions config\n   *\n   * @param actions\n   */\n  public updateActions(actions: FsFilterAction[]): void {\n    this._actionsController.initActions(actions);\n  }\n\n  /**\n   * Show \"Filters\" button\n   */\n  public showFiltersBtn(): void {\n    this._filtersBtnVisible$.next(true);\n  }\n\n  /**\n   * Hide \"Filters\" button\n   */\n  public hideFiltersBtn(): void {\n    this._filtersBtnVisible$.next(false);\n  }\n\n  /**\n   * Show \"Keyword\" field if it present\n   */\n  public showKeywordField(): void {\n    this.keywordInput.show();\n  }\n\n  /**\n   * Hide \"Keyword\" field if it present\n   */\n  public hideKeywordField(): void {\n    this.keywordInput.hide();\n  }\n\n  /**\n   * Go through actions and check show() callback and update visible actions\n   */\n  public updateActionsVisibility(): void {\n    this._actionsController.updateActionsVisibility();\n  }\n\n  /**\n   * Go through actions and check disabled() callback and update disabled state\n   */\n  public updateDisabledState(): void {\n    this._actionsController.updateDisabledState();\n  }\n\n  private _destroyFilterDrawer() {\n    this._filterOverlay.close();\n  }\n\n  private _updateWindowWidth() {\n    this.windowDesktop = window.innerWidth > 1200;\n  }\n\n  private _listenEscButton() {\n    this._zone.runOutsideAngular(() => {\n      fromEvent(window, 'keyup')\n        .pipe(\n          filter((event: KeyboardEvent) => event.code === 'Escape'),\n          takeUntil(this.closed),\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this._zone.run(() => {\n            this.hideDrawer();\n          });\n        });\n    });\n  }\n\n  private _initIcon() {\n    const iconRegistry = inject(MatIconRegistry);\n    const sanitizer = inject(DomSanitizer);\n\n    iconRegistry.addSvgIconLiteral('filterOutline', sanitizer.bypassSecurityTrustHtml(FilterIcon));\n  }\n\n  private _listenWindowResize() {\n    this._zone.runOutsideAngular(() => {\n      fromEvent(window, 'resize')\n        .pipe(\n          debounceTime(100),\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this._zone.run(() => {\n            this._updateWindowWidth();\n          });\n        });\n    });\n  }\n\n  private _initItems() {\n    this._filterController.init(this._config);\n  }\n\n  private _initAutoReload() {\n    if(this.config.autoReload) {\n      interval(this.config.autoReload.seconds * 1000)\n        .pipe(\n          filter(() => this.autoReload),\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this.reload(null);\n        });\n    }\n  }\n\n  private _initOverlay() {\n    this._filterOverlay.attach$\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this.showFilterMenu = true;\n      });\n\n    this._filterOverlay.detach$\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this.showFilterMenu = false;\n      });\n\n    this._filterOverlay.setClearFn(this.clear.bind(this));\n    this._filterOverlay.setDoneFn(this.hideDrawer.bind(this));\n  }\n}\n","<div class=\"filter-container\">\n  @if (notInlineToolbar$ | async) {\n    <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n  }\n  <div class=\"filter-inner-container\">\n    @if (notInlineToolbar$ | async) {\n      <div class=\"filter-inner-inputs\">\n        @if (keywordVisible$ | async) {\n          <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n        }\n        @if (savedFilterController.enabled) {\n          <fs-saved-filter-autocomplete-chips [savedFiltersController]=\"savedFilterController\"></fs-saved-filter-autocomplete-chips>\n        }\n      </div>\n    } @else {\n      <div>\n        <ng-container *ngTemplateOutlet=\"heading\"></ng-container>\n        <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n      </div>\n    }\n    <ng-container [ngTemplateOutlet]=\"filterToolbar\"></ng-container>\n    <ng-container [ngTemplateOutlet]=\"filterActions\"></ng-container>\n  </div>\n  @if (notInlineToolbar$ | async) {\n    <ng-container *ngTemplateOutlet=\"filterStatusBarChips\"></ng-container>\n  }\n</div>\n<ng-template #filterStatusBarChips>\n  @if (statusBar) {\n    <div\n        class=\"filter-status-container\"\n        [ngClass]=\"{ 'has-status': !!filterStatus.textContent }\">\n      <div\n          class=\"filter-status\"\n          #filterStatus>\n        <ng-container *ngTemplateOutlet=\"statusBar.templateRef\"></ng-container>\n      </div>\n    </div>\n  }\n  @if (config.chips) {\n    <fs-filter-chips class=\"filter-chips\"></fs-filter-chips>\n  }\n</ng-template>\n<ng-template #filterActions>\n  @if (actionsVisible$ | async) {\n    <div class=\"filter-actions\">\n      <fs-filter-actions\n        [actions]=\"actions$ | async\"\n        [kebabActions]=\"menuActions$ | async\">\n      </fs-filter-actions>\n    </div>\n  }\n</ng-template>\n<ng-template #filterToolbar>\n  @if (config.reload || config.autoReload || ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting)) {\n    <div class=\"filter-toolbar\">\n      @if ((filtersBtnVisible$ | async) && hasVisibleItemOrSorting) {\n        <a\n            mat-icon-button\n            class=\"button-filters\"\n            (click)=\"filterButtonClick($event)\"\n            [color]=\"config.button.color\">\n          @if (config.button.icon) {\n            <mat-icon [svgIcon]=\"'filterOutline'\"></mat-icon>\n          }\n        </a>\n      }\n      @if (config.reload) {\n        <a\n            mat-icon-button\n            (click)=\"reload($event)\"\n            class=\"button-reload\">\n          <mat-icon #reloadEl>\n            refresh\n          </mat-icon>\n        </a>\n      }\n      @if (config.autoReload) {\n        <div class=\"filter-reload\">\n          @if (config.autoReload) {\n            <mat-slide-toggle\n                name=\"autoReload\"\n                class=\"auto-reload\"\n                [(ngModel)]=\"autoReload\">\n              <span>\n                Auto refresh\n              </span>\n            </mat-slide-toggle>\n          }\n        </div>\n      }\n    </div>\n  }\n</ng-template>\n<ng-template #heading>\n  @if (config.heading) {\n    <div class=\"heading\">\n      <h2>\n        {{ config.heading }}\n      </h2>\n      <div class=\"subheading\">\n        {{ config.subheading }}\n      </div>\n    </div>\n  }\n</ng-template>"]}
@@ -1,32 +1,32 @@
1
1
  import { AsyncPipe } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, inject } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, inject, Injector } from '@angular/core';
3
3
  import { FsChipModule } from '@firestitch/chip';
4
4
  import { ItemType } from '../../enums';
5
5
  import { FilterController } from '../../services/filter-controller.service';
6
- import { FsFilterChipComponent } from '../filter-chip/filter-chip.component';
6
+ import { FocusControllerService } from '../../services/focus-controller.service';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@firestitch/chip";
9
9
  export class FsFilterChipsComponent {
10
10
  ItemType = ItemType;
11
11
  _filterController = inject(FilterController);
12
+ _injector = inject(Injector);
12
13
  get items() {
13
14
  return this._filterController.items;
14
15
  }
15
16
  click(item, chip) {
16
- //this._focusController.click(this.item, chip.name);
17
+ this._injector.get(FocusControllerService).click(item, chip.name);
17
18
  }
18
19
  remove(item, chip) {
19
20
  item.clear(chip.name);
20
21
  }
21
22
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterChipsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
22
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FsFilterChipsComponent, isStandalone: true, selector: "fs-filter-chips", ngImport: i0, template: "@for (item of items; track item.name) {\n @let chips = item.chips$ | async;\n @if (chips.length > 0) {\n @for (chip of chips; track chip.label) {\n <fs-chip\n [removable]=\"item.showClear\"\n size=\"small\"\n (click)=\"click(item, chip)\"\n (removed)=\"remove(item, chip)\">\n {{ chip.label }}: {{ chip.value }}\n </fs-chip>\n }\n <!-- <fs-filter-chip\n [chips]=\"chips\"\n [clickable]=\"true\"\n [removable]=\"true\">\n </fs-filter-chip> -->\n }\n}", styles: [""], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: FsChipModule }, { kind: "component", type: i1.FsChipComponent, selector: "fs-chip", inputs: ["selectable", "removable", "value", "maxWidth", "width", "backgroundColor", "borderColor", "color", "shape", "outlined", "icon", "image", "selected", "padding", "contrastColor", "size"], outputs: ["selectedToggled", "removed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
23
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FsFilterChipsComponent, isStandalone: true, selector: "fs-filter-chips", ngImport: i0, template: "@for (item of items; track item.name) {\n @let chips = item.chips$ | async;\n @if (chips.length > 0) {\n @for (chip of chips; track chip.label) {\n <fs-chip\n [removable]=\"item.showClear\"\n size=\"small\"\n (click)=\"click(item, chip)\"\n (removed)=\"remove(item, chip)\">\n {{ chip.value ? chip.label + ': ' + chip.value : chip.label }}\n </fs-chip>\n }\n }\n}", styles: [""], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: FsChipModule }, { kind: "component", type: i1.FsChipComponent, selector: "fs-chip", inputs: ["selectable", "removable", "value", "maxWidth", "width", "backgroundColor", "borderColor", "color", "shape", "outlined", "icon", "image", "selected", "padding", "contrastColor", "size"], outputs: ["selectedToggled", "removed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
23
24
  }
24
25
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterChipsComponent, decorators: [{
25
26
  type: Component,
26
27
  args: [{ selector: 'fs-filter-chips', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
27
- FsFilterChipComponent,
28
28
  AsyncPipe,
29
29
  FsChipModule,
30
- ], template: "@for (item of items; track item.name) {\n @let chips = item.chips$ | async;\n @if (chips.length > 0) {\n @for (chip of chips; track chip.label) {\n <fs-chip\n [removable]=\"item.showClear\"\n size=\"small\"\n (click)=\"click(item, chip)\"\n (removed)=\"remove(item, chip)\">\n {{ chip.label }}: {{ chip.value }}\n </fs-chip>\n }\n <!-- <fs-filter-chip\n [chips]=\"chips\"\n [clickable]=\"true\"\n [removable]=\"true\">\n </fs-filter-chip> -->\n }\n}" }]
30
+ ], template: "@for (item of items; track item.name) {\n @let chips = item.chips$ | async;\n @if (chips.length > 0) {\n @for (chip of chips; track chip.label) {\n <fs-chip\n [removable]=\"item.showClear\"\n size=\"small\"\n (click)=\"click(item, chip)\"\n (removed)=\"remove(item, chip)\">\n {{ chip.value ? chip.label + ': ' + chip.value : chip.label }}\n </fs-chip>\n }\n }\n}" }]
31
31
  }] });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWNoaXBzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9maWx0ZXItY2hpcHMvZmlsdGVyLWNoaXBzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9maWx0ZXItY2hpcHMvZmlsdGVyLWNoaXBzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM1QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFaEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUd2QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUM1RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7O0FBZTdFLE1BQU0sT0FBTyxzQkFBc0I7SUFFMUIsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUVuQixpQkFBaUIsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUVyRCxJQUFXLEtBQUs7UUFDZCxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUM7SUFDdEMsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFpQyxFQUFFLElBQXFEO1FBQ25HLG9EQUFvRDtJQUN0RCxDQUFDO0lBRU0sTUFBTSxDQUFDLElBQWlDLEVBQUUsSUFBcUQ7UUFDcEcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEIsQ0FBQzt3R0FoQlUsc0JBQXNCOzRGQUF0QixzQkFBc0IsMkVDeEJuQyxzaEJBa0JDLHFEREVHLFNBQVMsNkNBQ1QsWUFBWTs7NEZBR0gsc0JBQXNCO2tCQVpsQyxTQUFTOytCQUNFLGlCQUFpQixtQkFHVix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUDt3QkFDUCxxQkFBcUI7d0JBQ3JCLFNBQVM7d0JBQ1QsWUFBWTtxQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzeW5jUGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRnNDaGlwTW9kdWxlIH0gZnJvbSAnQGZpcmVzdGl0Y2gvY2hpcCc7XG5cbmltcG9ydCB7IEl0ZW1UeXBlIH0gZnJvbSAnLi4vLi4vZW51bXMnO1xuaW1wb3J0IHsgSUZpbHRlckNvbmZpZ0l0ZW0gfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL2NvbmZpZy5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQmFzZUl0ZW0gfSBmcm9tICcuLi8uLi9tb2RlbHMvaXRlbXMvYmFzZS1pdGVtJztcbmltcG9ydCB7IEZpbHRlckNvbnRyb2xsZXIgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9maWx0ZXItY29udHJvbGxlci5zZXJ2aWNlJztcbmltcG9ydCB7IEZzRmlsdGVyQ2hpcENvbXBvbmVudCB9IGZyb20gJy4uL2ZpbHRlci1jaGlwL2ZpbHRlci1jaGlwLmNvbXBvbmVudCc7XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZnMtZmlsdGVyLWNoaXBzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpbHRlci1jaGlwcy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2ZpbHRlci1jaGlwcy5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIEZzRmlsdGVyQ2hpcENvbXBvbmVudCxcbiAgICBBc3luY1BpcGUsXG4gICAgRnNDaGlwTW9kdWxlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBGc0ZpbHRlckNoaXBzQ29tcG9uZW50IHtcblxuICBwdWJsaWMgSXRlbVR5cGUgPSBJdGVtVHlwZTtcblxuICBwcml2YXRlIF9maWx0ZXJDb250cm9sbGVyID0gaW5qZWN0KEZpbHRlckNvbnRyb2xsZXIpO1xuXG4gIHB1YmxpYyBnZXQgaXRlbXMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2ZpbHRlckNvbnRyb2xsZXIuaXRlbXM7XG4gIH1cblxuICBwdWJsaWMgY2xpY2soaXRlbTogQmFzZUl0ZW08SUZpbHRlckNvbmZpZ0l0ZW0+LCBjaGlwOiB7IG5hbWU/OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcsIGxhYmVsOiBzdHJpbmcgfSkge1xuICAgIC8vdGhpcy5fZm9jdXNDb250cm9sbGVyLmNsaWNrKHRoaXMuaXRlbSwgY2hpcC5uYW1lKTtcbiAgfVxuXG4gIHB1YmxpYyByZW1vdmUoaXRlbTogQmFzZUl0ZW08SUZpbHRlckNvbmZpZ0l0ZW0+LCBjaGlwOiB7IG5hbWU/OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcsIGxhYmVsOiBzdHJpbmcgfSkge1xuICAgIGl0ZW0uY2xlYXIoY2hpcC5uYW1lKTtcbiAgfVxuXG59XG4iLCJAZm9yIChpdGVtIG9mIGl0ZW1zOyB0cmFjayBpdGVtLm5hbWUpIHtcbiAgQGxldCBjaGlwcyA9IGl0ZW0uY2hpcHMkIHwgYXN5bmM7XG4gIEBpZiAoY2hpcHMubGVuZ3RoID4gMCkge1xuICAgIEBmb3IgKGNoaXAgb2YgY2hpcHM7IHRyYWNrIGNoaXAubGFiZWwpIHtcbiAgICAgIDxmcy1jaGlwXG4gICAgICAgICAgW3JlbW92YWJsZV09XCJpdGVtLnNob3dDbGVhclwiXG4gICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAoY2xpY2spPVwiY2xpY2soaXRlbSwgY2hpcClcIlxuICAgICAgICAgIChyZW1vdmVkKT1cInJlbW92ZShpdGVtLCBjaGlwKVwiPlxuICAgICAgICB7eyBjaGlwLmxhYmVsIH19OiB7eyBjaGlwLnZhbHVlIH19XG4gICAgICA8L2ZzLWNoaXA+XG4gICAgfVxuICAgIDwhLS0gPGZzLWZpbHRlci1jaGlwXG4gICAgICBbY2hpcHNdPVwiY2hpcHNcIlxuICAgICAgW2NsaWNrYWJsZV09XCJ0cnVlXCJcbiAgICAgIFtyZW1vdmFibGVdPVwidHJ1ZVwiPlxuICAgIDwvZnMtZmlsdGVyLWNoaXA+IC0tPlxuICB9XG59Il19
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWNoaXBzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9maWx0ZXItY2hpcHMvZmlsdGVyLWNoaXBzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9maWx0ZXItY2hpcHMvZmlsdGVyLWNoaXBzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM1QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRWhELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFHdkMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDNUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUNBQXlDLENBQUM7OztBQWNqRixNQUFNLE9BQU8sc0JBQXNCO0lBRTFCLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFFbkIsaUJBQWlCLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDN0MsU0FBUyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUVyQyxJQUFXLEtBQUs7UUFDZCxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUM7SUFDdEMsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFpQyxFQUFFLElBQXFEO1FBQ25HLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLHNCQUFzQixDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEUsQ0FBQztJQUVNLE1BQU0sQ0FBQyxJQUFpQyxFQUFFLElBQXFEO1FBQ3BHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hCLENBQUM7d0dBakJVLHNCQUFzQjs0RkFBdEIsc0JBQXNCLDJFQ3ZCbkMsMmFBYUMscURETUcsU0FBUyw2Q0FDVCxZQUFZOzs0RkFHSCxzQkFBc0I7a0JBWGxDLFNBQVM7K0JBQ0UsaUJBQWlCLG1CQUdWLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQO3dCQUNQLFNBQVM7d0JBQ1QsWUFBWTtxQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzeW5jUGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEZzQ2hpcE1vZHVsZSB9IGZyb20gJ0BmaXJlc3RpdGNoL2NoaXAnO1xuXG5pbXBvcnQgeyBJdGVtVHlwZSB9IGZyb20gJy4uLy4uL2VudW1zJztcbmltcG9ydCB7IElGaWx0ZXJDb25maWdJdGVtIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9jb25maWcuaW50ZXJmYWNlJztcbmltcG9ydCB7IEJhc2VJdGVtIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2l0ZW1zL2Jhc2UtaXRlbSc7XG5pbXBvcnQgeyBGaWx0ZXJDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZmlsdGVyLWNvbnRyb2xsZXIuc2VydmljZSc7XG5pbXBvcnQgeyBGb2N1c0NvbnRyb2xsZXJTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZm9jdXMtY29udHJvbGxlci5zZXJ2aWNlJztcblxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdmcy1maWx0ZXItY2hpcHMnLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLWNoaXBzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyLWNoaXBzLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgQXN5bmNQaXBlLFxuICAgIEZzQ2hpcE1vZHVsZSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRnNGaWx0ZXJDaGlwc0NvbXBvbmVudCB7XG5cbiAgcHVibGljIEl0ZW1UeXBlID0gSXRlbVR5cGU7XG5cbiAgcHJpdmF0ZSBfZmlsdGVyQ29udHJvbGxlciA9IGluamVjdChGaWx0ZXJDb250cm9sbGVyKTtcbiAgcHJpdmF0ZSBfaW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IpO1xuXG4gIHB1YmxpYyBnZXQgaXRlbXMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2ZpbHRlckNvbnRyb2xsZXIuaXRlbXM7XG4gIH1cblxuICBwdWJsaWMgY2xpY2soaXRlbTogQmFzZUl0ZW08SUZpbHRlckNvbmZpZ0l0ZW0+LCBjaGlwOiB7IG5hbWU/OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcsIGxhYmVsOiBzdHJpbmcgfSkge1xuICAgIHRoaXMuX2luamVjdG9yLmdldChGb2N1c0NvbnRyb2xsZXJTZXJ2aWNlKS5jbGljayhpdGVtLCBjaGlwLm5hbWUpO1xuICB9XG5cbiAgcHVibGljIHJlbW92ZShpdGVtOiBCYXNlSXRlbTxJRmlsdGVyQ29uZmlnSXRlbT4sIGNoaXA6IHsgbmFtZT86IHN0cmluZywgdmFsdWU6IHN0cmluZywgbGFiZWw6IHN0cmluZyB9KSB7XG4gICAgaXRlbS5jbGVhcihjaGlwLm5hbWUpO1xuICB9XG5cbn1cbiIsIkBmb3IgKGl0ZW0gb2YgaXRlbXM7IHRyYWNrIGl0ZW0ubmFtZSkge1xuICBAbGV0IGNoaXBzID0gaXRlbS5jaGlwcyQgfCBhc3luYztcbiAgQGlmIChjaGlwcy5sZW5ndGggPiAwKSB7XG4gICAgQGZvciAoY2hpcCBvZiBjaGlwczsgdHJhY2sgY2hpcC5sYWJlbCkge1xuICAgICAgPGZzLWNoaXBcbiAgICAgICAgICBbcmVtb3ZhYmxlXT1cIml0ZW0uc2hvd0NsZWFyXCJcbiAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgIChjbGljayk9XCJjbGljayhpdGVtLCBjaGlwKVwiXG4gICAgICAgICAgKHJlbW92ZWQpPVwicmVtb3ZlKGl0ZW0sIGNoaXApXCI+XG4gICAgICAgIHt7IGNoaXAudmFsdWUgPyBjaGlwLmxhYmVsICsgJzogJyArIGNoaXAudmFsdWUgOiBjaGlwLmxhYmVsIH19XG4gICAgICA8L2ZzLWNoaXA+XG4gICAgfVxuICB9XG59Il19
@@ -1,7 +1,8 @@
1
1
  import { ChangeDetectionStrategy, Component, inject, Input, } from '@angular/core';
2
+ import { FsChipModule } from '@firestitch/chip';
2
3
  import { FilterController } from '../../../../../services';
3
- import { FsFilterChipComponent } from '../../../../filter-chip/filter-chip.component';
4
4
  import * as i0 from "@angular/core";
5
+ import * as i1 from "@firestitch/chip";
5
6
  export class FsFilterSavedFilterChipsComponent {
6
7
  savedFilter;
7
8
  items = [];
@@ -10,19 +11,20 @@ export class FsFilterSavedFilterChipsComponent {
10
11
  this.items = [...this._filterController.items]
11
12
  .filter((item) => !!this.savedFilter.filters[item.name])
12
13
  .map((item) => {
13
- item.value = this.savedFilter.filters[item.name];
14
- return item;
14
+ const object = item.clone();
15
+ object.setValue(this.savedFilter.filters[item.name], false);
16
+ return object;
15
17
  });
16
18
  }
17
19
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterSavedFilterChipsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
18
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FsFilterSavedFilterChipsComponent, isStandalone: true, selector: "fs-saved-filter-chips", inputs: { savedFilter: "savedFilter" }, ngImport: i0, template: "<div class=\"filter-chips\">\n @for (item of items; track item.name) {\n <fs-filter-chip [item]=\"item\"></fs-filter-chip>\n }\n</div>", styles: [".filter-chips{display:flex;flex-wrap:wrap;gap:4px}\n"], dependencies: [{ kind: "component", type: FsFilterChipComponent, selector: "fs-filter-chip", inputs: ["item", "removable", "chips", "clickable"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
20
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FsFilterSavedFilterChipsComponent, isStandalone: true, selector: "fs-saved-filter-chips", inputs: { savedFilter: "savedFilter" }, ngImport: i0, template: "<div class=\"filter-chips\">\n @for (item of items; track item.name) {\n @for (chip of item.chips; track chip.label) {\n <fs-chip size=\"small\">\n {{ chip.value ? chip.label + ': ' + chip.value : chip.label }}\n </fs-chip>\n }\n }\n</div>", styles: [".filter-chips{display:flex;flex-wrap:wrap;gap:4px}\n"], dependencies: [{ kind: "ngmodule", type: FsChipModule }, { kind: "component", type: i1.FsChipComponent, selector: "fs-chip", inputs: ["selectable", "removable", "value", "maxWidth", "width", "backgroundColor", "borderColor", "color", "shape", "outlined", "icon", "image", "selected", "padding", "contrastColor", "size"], outputs: ["selectedToggled", "removed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
19
21
  }
20
22
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterSavedFilterChipsComponent, decorators: [{
21
23
  type: Component,
22
24
  args: [{ selector: 'fs-saved-filter-chips', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
23
- FsFilterChipComponent,
24
- ], template: "<div class=\"filter-chips\">\n @for (item of items; track item.name) {\n <fs-filter-chip [item]=\"item\"></fs-filter-chip>\n }\n</div>", styles: [".filter-chips{display:flex;flex-wrap:wrap;gap:4px}\n"] }]
25
+ FsChipModule,
26
+ ], template: "<div class=\"filter-chips\">\n @for (item of items; track item.name) {\n @for (chip of item.chips; track chip.label) {\n <fs-chip size=\"small\">\n {{ chip.value ? chip.label + ': ' + chip.value : chip.label }}\n </fs-chip>\n }\n }\n</div>", styles: [".filter-chips{display:flex;flex-wrap:wrap;gap:4px}\n"] }]
25
27
  }], propDecorators: { savedFilter: [{
26
28
  type: Input
27
29
  }] } });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2F2ZWQtZmlsdGVyLWNoaXBzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9zYXZlZC1maWx0ZXIvc2F2ZWQtZmlsdGVyLW1hbmFnZS9jb21wb25lbnRzL3NhdmVkLWZpbHRlci1jaGlwcy9zYXZlZC1maWx0ZXItY2hpcHMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9jb21wb25lbnRzL3NhdmVkLWZpbHRlci9zYXZlZC1maWx0ZXItbWFuYWdlL2NvbXBvbmVudHMvc2F2ZWQtZmlsdGVyLWNoaXBzL3NhdmVkLWZpbHRlci1jaGlwcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEVBQ04sS0FBSyxHQUVOLE1BQU0sZUFBZSxDQUFDO0FBS3ZCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDOztBQWF0RixNQUFNLE9BQU8saUNBQWlDO0lBRTVCLFdBQVcsQ0FBcUI7SUFFekMsS0FBSyxHQUFrQyxFQUFFLENBQUM7SUFFekMsaUJBQWlCLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFFOUMsUUFBUTtRQUNiLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUM7YUFDM0MsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ3ZELEdBQUcsQ0FBQyxDQUFDLElBQWlDLEVBQStCLEVBQUU7WUFDdEUsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7WUFFakQsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7d0dBaEJVLGlDQUFpQzs0RkFBakMsaUNBQWlDLHlIQ3pCOUMsNklBSU0sOEdEa0JGLHFCQUFxQjs7NEZBR1osaUNBQWlDO2tCQVY3QyxTQUFTOytCQUNFLHVCQUF1QixtQkFHaEIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1A7d0JBQ1AscUJBQXFCO3FCQUN0Qjs4QkFJZSxXQUFXO3NCQUExQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgaW5qZWN0LFxuICBJbnB1dCxcbiAgT25Jbml0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgSUZpbHRlckNvbmZpZ0l0ZW0gfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IElGaWx0ZXJTYXZlZEZpbHRlciB9IGZyb20gJy4uLy4uLy4uLy4uLy4uL2ludGVyZmFjZXMvc2F2ZWQtZmlsdGVycy5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQmFzZUl0ZW0gfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9tb2RlbHMvaXRlbXMnO1xuaW1wb3J0IHsgRmlsdGVyQ29udHJvbGxlciB9IGZyb20gJy4uLy4uLy4uLy4uLy4uL3NlcnZpY2VzJztcbmltcG9ydCB7IEZzRmlsdGVyQ2hpcENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uLy4uL2ZpbHRlci1jaGlwL2ZpbHRlci1jaGlwLmNvbXBvbmVudCc7XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZnMtc2F2ZWQtZmlsdGVyLWNoaXBzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3NhdmVkLWZpbHRlci1jaGlwcy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3NhdmVkLWZpbHRlci1jaGlwcy5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIEZzRmlsdGVyQ2hpcENvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRnNGaWx0ZXJTYXZlZEZpbHRlckNoaXBzQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBASW5wdXQoKSBwdWJsaWMgc2F2ZWRGaWx0ZXI6IElGaWx0ZXJTYXZlZEZpbHRlcjtcblxuICBwdWJsaWMgaXRlbXM6IEJhc2VJdGVtPElGaWx0ZXJDb25maWdJdGVtPltdID0gW107XG5cbiAgcHJpdmF0ZSBfZmlsdGVyQ29udHJvbGxlciA9IGluamVjdChGaWx0ZXJDb250cm9sbGVyKTtcblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5pdGVtcyA9IFsuLi50aGlzLl9maWx0ZXJDb250cm9sbGVyLml0ZW1zXVxuICAgICAgLmZpbHRlcigoaXRlbSkgPT4gISF0aGlzLnNhdmVkRmlsdGVyLmZpbHRlcnNbaXRlbS5uYW1lXSlcbiAgICAgIC5tYXAoKGl0ZW06IEJhc2VJdGVtPElGaWx0ZXJDb25maWdJdGVtPik6IEJhc2VJdGVtPElGaWx0ZXJDb25maWdJdGVtPiA9PiB7XG4gICAgICAgIGl0ZW0udmFsdWUgPSB0aGlzLnNhdmVkRmlsdGVyLmZpbHRlcnNbaXRlbS5uYW1lXTtcblxuICAgICAgICByZXR1cm4gaXRlbTtcbiAgICAgIH0pO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZmlsdGVyLWNoaXBzXCI+XG4gIEBmb3IgKGl0ZW0gb2YgaXRlbXM7IHRyYWNrIGl0ZW0ubmFtZSkge1xuICAgIDxmcy1maWx0ZXItY2hpcCBbaXRlbV09XCJpdGVtXCI+PC9mcy1maWx0ZXItY2hpcD5cbiAgfVxuPC9kaXY+Il19
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2F2ZWQtZmlsdGVyLWNoaXBzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9zYXZlZC1maWx0ZXIvc2F2ZWQtZmlsdGVyLW1hbmFnZS9jb21wb25lbnRzL3NhdmVkLWZpbHRlci1jaGlwcy9zYXZlZC1maWx0ZXItY2hpcHMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9jb21wb25lbnRzL3NhdmVkLWZpbHRlci9zYXZlZC1maWx0ZXItbWFuYWdlL2NvbXBvbmVudHMvc2F2ZWQtZmlsdGVyLWNoaXBzL3NhdmVkLWZpbHRlci1jaGlwcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEVBQ04sS0FBSyxHQUVOLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUtoRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7O0FBYTNELE1BQU0sT0FBTyxpQ0FBaUM7SUFFNUIsV0FBVyxDQUFxQjtJQUV6QyxLQUFLLEdBQWtDLEVBQUUsQ0FBQztJQUV6QyxpQkFBaUIsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUU5QyxRQUFRO1FBQ2IsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQzthQUMzQyxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7YUFDdkQsR0FBRyxDQUFDLENBQUMsSUFBaUMsRUFBK0IsRUFBRTtZQUN0RSxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDNUIsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFFNUQsT0FBTyxNQUFNLENBQUM7UUFDaEIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO3dHQWpCVSxpQ0FBaUM7NEZBQWpDLGlDQUFpQyx5SEMxQjlDLDBRQVFNLDZHRGVGLFlBQVk7OzRGQUdILGlDQUFpQztrQkFWN0MsU0FBUzsrQkFDRSx1QkFBdUIsbUJBR2hCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQO3dCQUNQLFlBQVk7cUJBQ2I7OEJBSWUsV0FBVztzQkFBMUIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIGluamVjdCxcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEZzQ2hpcE1vZHVsZSB9IGZyb20gJ0BmaXJlc3RpdGNoL2NoaXAnO1xuXG5pbXBvcnQgeyBJRmlsdGVyQ29uZmlnSXRlbSB9IGZyb20gJy4uLy4uLy4uLy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgSUZpbHRlclNhdmVkRmlsdGVyIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vaW50ZXJmYWNlcy9zYXZlZC1maWx0ZXJzLmludGVyZmFjZSc7XG5pbXBvcnQgeyBCYXNlSXRlbSB9IGZyb20gJy4uLy4uLy4uLy4uLy4uL21vZGVscy9pdGVtcyc7XG5pbXBvcnQgeyBGaWx0ZXJDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vc2VydmljZXMnO1xuXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2ZzLXNhdmVkLWZpbHRlci1jaGlwcycsXG4gIHRlbXBsYXRlVXJsOiAnLi9zYXZlZC1maWx0ZXItY2hpcHMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zYXZlZC1maWx0ZXItY2hpcHMuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtcbiAgICBGc0NoaXBNb2R1bGUsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZzRmlsdGVyU2F2ZWRGaWx0ZXJDaGlwc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgQElucHV0KCkgcHVibGljIHNhdmVkRmlsdGVyOiBJRmlsdGVyU2F2ZWRGaWx0ZXI7XG5cbiAgcHVibGljIGl0ZW1zOiBCYXNlSXRlbTxJRmlsdGVyQ29uZmlnSXRlbT5bXSA9IFtdO1xuXG4gIHByaXZhdGUgX2ZpbHRlckNvbnRyb2xsZXIgPSBpbmplY3QoRmlsdGVyQ29udHJvbGxlcik7XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuaXRlbXMgPSBbLi4udGhpcy5fZmlsdGVyQ29udHJvbGxlci5pdGVtc11cbiAgICAgIC5maWx0ZXIoKGl0ZW0pID0+ICEhdGhpcy5zYXZlZEZpbHRlci5maWx0ZXJzW2l0ZW0ubmFtZV0pXG4gICAgICAubWFwKChpdGVtOiBCYXNlSXRlbTxJRmlsdGVyQ29uZmlnSXRlbT4pOiBCYXNlSXRlbTxJRmlsdGVyQ29uZmlnSXRlbT4gPT4ge1xuICAgICAgICBjb25zdCBvYmplY3QgPSBpdGVtLmNsb25lKCk7XG4gICAgICAgIG9iamVjdC5zZXRWYWx1ZSh0aGlzLnNhdmVkRmlsdGVyLmZpbHRlcnNbaXRlbS5uYW1lXSwgZmFsc2UpO1xuXG4gICAgICAgIHJldHVybiBvYmplY3Q7ICBcbiAgICAgIH0pO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZmlsdGVyLWNoaXBzXCI+XG4gIEBmb3IgKGl0ZW0gb2YgaXRlbXM7IHRyYWNrIGl0ZW0ubmFtZSkge1xuICAgIEBmb3IgKGNoaXAgb2YgaXRlbS5jaGlwczsgdHJhY2sgY2hpcC5sYWJlbCkge1xuICAgICAgPGZzLWNoaXAgc2l6ZT1cInNtYWxsXCI+XG4gICAgICAgIHt7IGNoaXAudmFsdWUgPyBjaGlwLmxhYmVsICsgJzogJyArIGNoaXAudmFsdWUgOiBjaGlwLmxhYmVsIH19XG4gICAgICA8L2ZzLWNoaXA+XG4gICAgfVxuICB9XG48L2Rpdj4iXX0=