@firestitch/filter 18.2.70 → 18.2.72
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/app/components/filter-chips/filter-chips.component.d.ts +14 -3
- package/app/components/filters-item/autocomplete/autocomplete.component.d.ts +2 -1
- package/app/components/filters-item/autocompletechips/autocompletechips.component.d.ts +2 -1
- package/app/components/filters-item/date/date.component.d.ts +2 -1
- package/app/components/filters-item/date-range/date-range.component.d.ts +2 -1
- package/app/components/filters-item/filter-item.component.d.ts +2 -1
- package/app/components/filters-item/range/range.component.d.ts +2 -1
- package/app/components/filters-item/select/select.component.d.ts +2 -1
- package/app/components/filters-item/text/text.component.d.ts +2 -1
- package/app/components/filters-item/week/week.component.d.ts +2 -1
- package/app/helpers/create-filter-item.d.ts +1 -1
- package/app/interfaces/config.interface.d.ts +1 -0
- package/app/interfaces/items/base.interface.d.ts +1 -0
- package/app/models/filter-config.d.ts +1 -0
- package/app/models/items/base-item.d.ts +7 -0
- package/app/services/filter-controller.service.d.ts +1 -2
- package/esm2022/app/components/filter/filter.component.mjs +2 -2
- package/esm2022/app/components/filter-chips/filter-chips.component.mjs +62 -25
- package/esm2022/app/components/filter-item-dialog/filter-item-dialog.component.mjs +3 -3
- package/esm2022/app/components/filters-item/autocomplete/autocomplete.component.mjs +5 -2
- package/esm2022/app/components/filters-item/autocompletechips/autocompletechips.component.mjs +6 -3
- package/esm2022/app/components/filters-item/date/date.component.mjs +6 -3
- package/esm2022/app/components/filters-item/date-range/date-range.component.mjs +6 -3
- package/esm2022/app/components/filters-item/filter-item.component.mjs +6 -3
- package/esm2022/app/components/filters-item/range/range.component.mjs +6 -3
- package/esm2022/app/components/filters-item/select/select.component.mjs +7 -5
- package/esm2022/app/components/filters-item/text/text.component.mjs +6 -3
- package/esm2022/app/components/filters-item/week/week.component.mjs +6 -3
- package/esm2022/app/interfaces/config.interface.mjs +1 -1
- package/esm2022/app/interfaces/items/base.interface.mjs +1 -1
- package/esm2022/app/models/filter-config.mjs +3 -1
- package/esm2022/app/models/items/base-item.mjs +29 -4
- package/esm2022/app/services/filter-controller.service.mjs +31 -10
- package/fesm2022/firestitch-filter.mjs +167 -57
- package/fesm2022/firestitch-filter.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import { OnInit } from '@angular/core';
|
|
2
|
+
import { MatSelectChange } from '@angular/material/select';
|
|
3
|
+
import { Observable } from 'rxjs';
|
|
2
4
|
import { ItemType } from '../../enums';
|
|
3
5
|
import { IFilterConfigItem } from '../../interfaces';
|
|
4
6
|
import { BaseItem } from '../../models/items/base-item';
|
|
@@ -6,6 +8,7 @@ import { SavedFilterController } from '../../services';
|
|
|
6
8
|
import * as i0 from "@angular/core";
|
|
7
9
|
export declare class FsFilterChipsComponent implements OnInit {
|
|
8
10
|
ItemType: typeof ItemType;
|
|
11
|
+
secondaryItems: BaseItem<IFilterConfigItem>[];
|
|
9
12
|
private _filterController;
|
|
10
13
|
private _dialog;
|
|
11
14
|
private _message;
|
|
@@ -13,25 +16,33 @@ export declare class FsFilterChipsComponent implements OnInit {
|
|
|
13
16
|
private _injector;
|
|
14
17
|
private _overlay;
|
|
15
18
|
private _overlayRef;
|
|
19
|
+
private _destroyRef;
|
|
20
|
+
private _elementRef;
|
|
21
|
+
private _hasSecondaryValue$;
|
|
16
22
|
get items(): BaseItem<IFilterConfigItem>[];
|
|
17
|
-
|
|
23
|
+
addFilter(event: MatSelectChange): void;
|
|
24
|
+
get disabledItems(): BaseItem<IFilterConfigItem>[];
|
|
25
|
+
get hasSecondaryValue$(): Observable<boolean>;
|
|
18
26
|
get savedFilterController(): SavedFilterController;
|
|
27
|
+
get hasSecondaryValue(): boolean;
|
|
19
28
|
ngOnInit(): void;
|
|
20
29
|
clear(): void;
|
|
21
|
-
|
|
30
|
+
openChip(item: BaseItem<IFilterConfigItem>, name?: string): void;
|
|
22
31
|
getNestedElement(el: any, className: string): any;
|
|
23
32
|
saveActiveFilter(): void;
|
|
24
33
|
createSavedFilter(): void;
|
|
25
34
|
saveAs(): void;
|
|
26
35
|
manageSavedFilters(): void;
|
|
27
36
|
_destroyOverlay(): void;
|
|
28
|
-
|
|
37
|
+
removeChip(item: BaseItem<IFilterConfigItem>, chip: {
|
|
29
38
|
name?: string;
|
|
30
39
|
value: string;
|
|
31
40
|
label: string;
|
|
32
41
|
}): void;
|
|
33
42
|
private _attachContainer;
|
|
34
43
|
private _createInjector;
|
|
44
|
+
private _initChipClick;
|
|
45
|
+
private _initHasSecondaryValue;
|
|
35
46
|
static ɵfac: i0.ɵɵFactoryDeclaration<FsFilterChipsComponent, never>;
|
|
36
47
|
static ɵcmp: i0.ɵɵComponentDeclaration<FsFilterChipsComponent, "fs-filter-chips", never, {}, {}, never, never, true, never>;
|
|
37
48
|
}
|
|
@@ -4,8 +4,9 @@ import { BaseItemComponent } from '../base-item/base-item.component';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class AutocompleteComponent extends BaseItemComponent<AutocompleteItem> {
|
|
6
6
|
autofocus: boolean;
|
|
7
|
+
floatLabel: 'auto' | 'always';
|
|
7
8
|
displayWith: (data: any) => any;
|
|
8
9
|
fetch: (keyword: any) => Observable<any>;
|
|
9
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<AutocompleteComponent, never>;
|
|
10
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<AutocompleteComponent, "filter-item-autocomplete", never, { "autofocus": { "alias": "autofocus"; "required": false; }; }, {}, never, never, true, never>;
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AutocompleteComponent, "filter-item-autocomplete", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; }, {}, never, never, true, never>;
|
|
11
12
|
}
|
|
@@ -4,6 +4,7 @@ import { BaseItemComponent } from '../base-item/base-item.component';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class AutocompletechipsComponent extends BaseItemComponent<AutocompleteChipsItem> implements OnInit {
|
|
6
6
|
autofocus: boolean;
|
|
7
|
+
floatLabel: 'auto' | 'always';
|
|
7
8
|
value: any[];
|
|
8
9
|
private _injector;
|
|
9
10
|
private _cdRef;
|
|
@@ -15,5 +16,5 @@ export declare class AutocompletechipsComponent extends BaseItemComponent<Autoco
|
|
|
15
16
|
compareItems(item1: any, item2: any): boolean;
|
|
16
17
|
actionClick(action: any): void;
|
|
17
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<AutocompletechipsComponent, never>;
|
|
18
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<AutocompletechipsComponent, "filter-item-autocompletechips", never, { "autofocus": { "alias": "autofocus"; "required": false; }; }, {}, never, never, true, never>;
|
|
19
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AutocompletechipsComponent, "filter-item-autocompletechips", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; }, {}, never, never, true, never>;
|
|
19
20
|
}
|
|
@@ -7,6 +7,7 @@ import { BaseItemComponent } from '../base-item/base-item.component';
|
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare class DateComponent extends BaseItemComponent<DateItem | DateTimeItem> implements OnInit {
|
|
9
9
|
autofocus: boolean;
|
|
10
|
+
floatLabel: 'auto' | 'always';
|
|
10
11
|
viewType: PickerViewType;
|
|
11
12
|
itemDateMode: typeof ItemDateMode;
|
|
12
13
|
showYear: boolean;
|
|
@@ -17,5 +18,5 @@ export declare class DateComponent extends BaseItemComponent<DateItem | DateTime
|
|
|
17
18
|
private _cdRef;
|
|
18
19
|
ngOnInit(): void;
|
|
19
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<DateComponent, never>;
|
|
20
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DateComponent, "filter-item-date", never, { "autofocus": { "alias": "autofocus"; "required": false; }; }, {}, never, never, true, never>;
|
|
21
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DateComponent, "filter-item-date", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; }, {}, never, never, true, never>;
|
|
21
22
|
}
|
|
@@ -6,6 +6,7 @@ import { BaseItemComponent } from '../base-item/base-item.component';
|
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export declare class DateRangeComponent extends BaseItemComponent<DateRangeItem | DateTimeRangeItem> implements OnInit {
|
|
8
8
|
autofocusName: string;
|
|
9
|
+
floatLabel: 'auto' | 'always';
|
|
9
10
|
viewType: PickerViewType;
|
|
10
11
|
from: Date;
|
|
11
12
|
to: Date;
|
|
@@ -13,5 +14,5 @@ export declare class DateRangeComponent extends BaseItemComponent<DateRangeItem
|
|
|
13
14
|
ngOnInit(): void;
|
|
14
15
|
change(): void;
|
|
15
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<DateRangeComponent, never>;
|
|
16
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DateRangeComponent, "filter-item-date-range", never, { "autofocusName": { "alias": "autofocusName"; "required": false; }; }, {}, never, never, true, never>;
|
|
17
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DateRangeComponent, "filter-item-date-range", never, { "autofocusName": { "alias": "autofocusName"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; }, {}, never, never, true, never>;
|
|
17
18
|
}
|
|
@@ -16,6 +16,7 @@ import type { WeekItem } from '../../models/items/week-item';
|
|
|
16
16
|
import * as i0 from "@angular/core";
|
|
17
17
|
export declare class FilterItemComponent implements OnInit, OnDestroy {
|
|
18
18
|
autofocus: boolean;
|
|
19
|
+
floatLabel: 'auto' | 'always';
|
|
19
20
|
autofocusName: string;
|
|
20
21
|
item: BaseItem<any>;
|
|
21
22
|
name: string;
|
|
@@ -37,5 +38,5 @@ export declare class FilterItemComponent implements OnInit, OnDestroy {
|
|
|
37
38
|
ngOnInit(): void;
|
|
38
39
|
ngOnDestroy(): void;
|
|
39
40
|
static ɵfac: i0.ɵɵFactoryDeclaration<FilterItemComponent, never>;
|
|
40
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<FilterItemComponent, "filter-item", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "autofocusName": { "alias": "autofocusName"; "required": false; }; "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
|
|
41
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FilterItemComponent, "filter-item", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; "autofocusName": { "alias": "autofocusName"; "required": false; }; "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
|
|
41
42
|
}
|
|
@@ -4,6 +4,7 @@ import { BaseItemComponent } from '../base-item/base-item.component';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class RangeComponent extends BaseItemComponent<RangeItem> implements OnInit {
|
|
6
6
|
autofocusName: string;
|
|
7
|
+
floatLabel: 'auto' | 'always';
|
|
7
8
|
min: number;
|
|
8
9
|
max: number;
|
|
9
10
|
private _change$;
|
|
@@ -11,5 +12,5 @@ export declare class RangeComponent extends BaseItemComponent<RangeItem> impleme
|
|
|
11
12
|
ngOnInit(): void;
|
|
12
13
|
change(): void;
|
|
13
14
|
static ɵfac: i0.ɵɵFactoryDeclaration<RangeComponent, never>;
|
|
14
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<RangeComponent, "filter-item-range", never, { "autofocusName": { "alias": "autofocusName"; "required": false; }; }, {}, never, never, true, never>;
|
|
15
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<RangeComponent, "filter-item-range", never, { "autofocusName": { "alias": "autofocusName"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; }, {}, never, never, true, never>;
|
|
15
16
|
}
|
|
@@ -5,6 +5,7 @@ import { SelectItem } from '../../../models/items/select-item';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class SelectComponent implements OnInit {
|
|
7
7
|
autofocus: boolean;
|
|
8
|
+
floatLabel: 'auto' | 'always';
|
|
8
9
|
item: SelectItem;
|
|
9
10
|
select: MatSelect;
|
|
10
11
|
value: any;
|
|
@@ -16,5 +17,5 @@ export declare class SelectComponent implements OnInit {
|
|
|
16
17
|
markForCheck(): void;
|
|
17
18
|
isolateChange(event: MatCheckboxChange): void;
|
|
18
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<SelectComponent, never>;
|
|
19
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<SelectComponent, "filter-item-select", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "item": { "alias": "item"; "required": false; }; }, {}, never, never, true, never>;
|
|
20
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SelectComponent, "filter-item-select", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; "item": { "alias": "item"; "required": false; }; }, {}, never, never, true, never>;
|
|
20
21
|
}
|
|
@@ -4,6 +4,7 @@ import { BaseItemComponent } from '../base-item/base-item.component';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class TextComponent extends BaseItemComponent<TextItem> implements OnInit {
|
|
6
6
|
autofocus: boolean;
|
|
7
|
+
floatLabel: 'auto' | 'always';
|
|
7
8
|
value: string;
|
|
8
9
|
private _change$;
|
|
9
10
|
private _cdRef;
|
|
@@ -12,5 +13,5 @@ export declare class TextComponent extends BaseItemComponent<TextItem> implement
|
|
|
12
13
|
private _listenControlValueChanges;
|
|
13
14
|
private _listenValueChanges;
|
|
14
15
|
static ɵfac: i0.ɵɵFactoryDeclaration<TextComponent, never>;
|
|
15
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TextComponent, "filter-item-text", never, { "autofocus": { "alias": "autofocus"; "required": false; }; }, {}, never, never, true, never>;
|
|
16
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TextComponent, "filter-item-text", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; }, {}, never, never, true, never>;
|
|
16
17
|
}
|
|
@@ -4,9 +4,10 @@ import { BaseItemComponent } from '../base-item/base-item.component';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class WeekComponent extends BaseItemComponent<WeekItem> implements OnInit {
|
|
6
6
|
autofocus: boolean;
|
|
7
|
+
floatLabel: 'auto' | 'always';
|
|
7
8
|
value: Date;
|
|
8
9
|
private _cdRef;
|
|
9
10
|
ngOnInit(): void;
|
|
10
11
|
static ɵfac: i0.ɵɵFactoryDeclaration<WeekComponent, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<WeekComponent, "filter-item-week", never, { "autofocus": { "alias": "autofocus"; "required": false; }; }, {}, never, never, true, never>;
|
|
12
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<WeekComponent, "filter-item-week", never, { "autofocus": { "alias": "autofocus"; "required": false; }; "floatLabel": { "alias": "floatLabel"; "required": false; }; }, {}, never, never, true, never>;
|
|
12
13
|
}
|
|
@@ -12,4 +12,4 @@ import { RangeItem } from '../models/items/range-item';
|
|
|
12
12
|
import { SelectItem } from '../models/items/select-item';
|
|
13
13
|
import { TextItem } from '../models/items/text-item';
|
|
14
14
|
import { WeekItem } from '../models/items/week-item';
|
|
15
|
-
export declare function createFilterItem(item: IFilterConfigItem, filter: FilterComponent):
|
|
15
|
+
export declare function createFilterItem(item: IFilterConfigItem, filter: FilterComponent): SelectItem | ChipsItem | RangeItem | DateRangeItem | DateTimeRangeItem | DateItem | WeekItem | DateTimeItem | AutocompleteItem | AutocompleteChipsItem | CheckboxItem | TextItem;
|
|
@@ -19,6 +19,7 @@ export interface IFilterConfigBaseItem<T = DefaultItemType, U = string> {
|
|
|
19
19
|
show?: boolean;
|
|
20
20
|
values?: any;
|
|
21
21
|
primary?: boolean;
|
|
22
|
+
secondary?: boolean;
|
|
22
23
|
default?: unknown;
|
|
23
24
|
change?: (item: BaseItem<any>, filter: FilterComponent) => void;
|
|
24
25
|
init?: (item: BaseItem<any>, filter?: FilterComponent) => void;
|
|
@@ -14,6 +14,7 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
14
14
|
persistanceDisabled: boolean;
|
|
15
15
|
queryParamsDisabled: boolean;
|
|
16
16
|
primary: boolean;
|
|
17
|
+
secondary: boolean;
|
|
17
18
|
changeCallback: (item: BaseItem<T>, filter: FilterComponent) => void;
|
|
18
19
|
initCallback: (item: BaseItem<T>, filter?: any) => void;
|
|
19
20
|
protected readonly _type: T['type'];
|
|
@@ -21,8 +22,13 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
21
22
|
private _hidden$;
|
|
22
23
|
private _value$;
|
|
23
24
|
private _values$;
|
|
25
|
+
private _secondaryVisible$;
|
|
24
26
|
private _destroy$;
|
|
25
27
|
constructor(itemConfig: T, _filter: FilterComponent);
|
|
28
|
+
secondaryShow(): void;
|
|
29
|
+
secondaryHide(): void;
|
|
30
|
+
get secondaryVisible$(): Observable<boolean>;
|
|
31
|
+
get secondaryVisible(): boolean;
|
|
26
32
|
get filter(): FilterComponent;
|
|
27
33
|
get hidden$(): Observable<boolean>;
|
|
28
34
|
get mergedLabel(): string;
|
|
@@ -44,6 +50,7 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
44
50
|
get destroy$(): Observable<void>;
|
|
45
51
|
get type(): T['type'];
|
|
46
52
|
get hasValue(): boolean;
|
|
53
|
+
get notValue$(): Observable<boolean>;
|
|
47
54
|
get hasValue$(): Observable<boolean>;
|
|
48
55
|
get chips$(): Observable<{
|
|
49
56
|
name?: string;
|
|
@@ -11,7 +11,6 @@ export declare class FilterController implements OnDestroy {
|
|
|
11
11
|
private _ready$;
|
|
12
12
|
private _items;
|
|
13
13
|
private _config;
|
|
14
|
-
private _add$;
|
|
15
14
|
private _init$;
|
|
16
15
|
private _change$;
|
|
17
16
|
private _destroy$;
|
|
@@ -24,7 +23,6 @@ export declare class FilterController implements OnDestroy {
|
|
|
24
23
|
get itemNames(): string[];
|
|
25
24
|
get config(): FsFilterConfig;
|
|
26
25
|
get init$(): Observable<void>;
|
|
27
|
-
get add$(): Observable<void>;
|
|
28
26
|
get change$(): Observable<BaseItem<IFilterConfigItem>[]>;
|
|
29
27
|
change(): void;
|
|
30
28
|
get ready$(): Observable<boolean>;
|
|
@@ -38,6 +36,7 @@ export declare class FilterController implements OnDestroy {
|
|
|
38
36
|
get values(): Record<string, unknown>;
|
|
39
37
|
private _getInitValues;
|
|
40
38
|
private _initItems;
|
|
39
|
+
private _initEnabledItems;
|
|
41
40
|
private _addItems;
|
|
42
41
|
private _initChanges;
|
|
43
42
|
static ɵfac: i0.ɵɵFactoryDeclaration<FilterController, never>;
|
|
@@ -360,7 +360,7 @@ export class FilterComponent {
|
|
|
360
360
|
ActionsController,
|
|
361
361
|
KeywordController,
|
|
362
362
|
SortController,
|
|
363
|
-
], queries: [{ propertyName: "statusBar", first: true, predicate: FilterStatusBarDirective, descendants: true }, { propertyName: "headingTemplate", first: true, predicate: FilterHeadingDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "keywordInput", first: true, predicate: KeywordInputComponent, descendants: true }, { propertyName: "reloadEl", first: true, predicate: ["reloadEl"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div\n class=\"filter-container\"\n [ngClass]=\"{ 'has-primary-filter': primaryFilterVisible$ | async }\"\n [ngClass]=\"{ 'keyword-full-width': keywordFullWidth$ | async }\">\n @if (primaryFilterVisible$ | async) {\n <ng-container *ngTemplateOutlet=\"headingTmpl\"></ng-container>\n }\n <div class=\"filter-bar-container\">\n @if (primaryFilterVisible$ | async) {\n <div class=\"filter-input-container\">\n @if (keywordVisible$ | async) {\n <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n }\n @for (item of primaryItems; track item.name) {\n @if (item.visible$ | async) {\n <filter-item [item]=\"item\"></filter-item>\n }\n }\n </div>\n } @else if (hasHeading) {\n <div class=\"filter-heading-container\">\n <ng-container *ngTemplateOutlet=\"headingTmpl\"></ng-container>\n </div>\n } @else {\n <ng-container *ngTemplateOutlet=\"chipsTmpl\"></ng-container>\n }\n <ng-container [ngTemplateOutlet]=\"filterActionsTmpl\"></ng-container>\n </div>\n @if ((primaryFilterVisible$ | async) === true || hasHeading) {\n <ng-container\n [ngTemplateOutlet]=\"chipsTmpl\"\n [ngTemplateOutletContext]=\"{ topMargin: true }\">\n </ng-container>\n }\n <ng-container *ngTemplateOutlet=\"statusBarTmpl\"></ng-container>\n</div>\n<ng-template\n #chipsTmpl\n let-topMargin=\"topMargin\">\n <fs-filter-chips\n class=\"filter-chips\"\n [ngClass]=\"{ 'top-margin': topMargin }\">\n </fs-filter-chips>\n</ng-template>\n<ng-template #statusBarTmpl>\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</ng-template>\n<ng-template #filterActionsTmpl>\n @if ((actionsVisible$ | async)) {\n <div class=\"filter-actions\">\n <ng-container [ngTemplateOutlet]=\"filterToolbarTmpl\"></ng-container>\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 #filterToolbarTmpl>\n @if (config.reload || config.autoReload || (filtersVisible$ | async)) {\n <div class=\"filter-toolbar\">\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 <mat-slide-toggle\n name=\"autoReload\"\n class=\"auto-reload\"\n [ngModel]=\"config.autoReload.enabled\"\n (ngModelChange)=\"config.autoReload.enabled = $event\">\n <span>\n Auto refresh\n </span>\n </mat-slide-toggle>\n </div>\n }\n </div>\n }\n</ng-template>\n<ng-template #headingTmpl>\n @if (headingTemplate) {\n <ng-container *ngTemplateOutlet=\"headingTemplate\"></ng-container>\n } @else 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;margin-top:4px}.filter-status-container .filter-status{overflow:hidden;text-overflow:ellipsis}.filter-container{width:100%}.filter-container.has-primary-filter .heading{margin-bottom:10px}.filter-container.has-primary-filter .filter-bar-container{margin-bottom:4px}.filter-container.keyword-full-width .filter-input-container{flex:1}.filter-container.keyword-full-width .filter-input-container fs-keyword-input{flex:1}.filter-container.keyword-full-width .filter-input-container fs-keyword-input ::ng-deep mat-form-field{width:100%}.filter-container .filter-bar-container{flex-direction:row;box-sizing:border-box;display:flex;position:relative;align-items:flex-start}.filter-container .filter-bar-container .filter-input-container{flex-direction:row;box-sizing:border-box;display:flex;align-items:center;min-width:0;gap:5px;flex-wrap:wrap}.filter-container .filter-bar-container .filter-heading-container{flex-direction:row;box-sizing:border-box;display:flex;align-items:center;min-width:0}.filter-container .filter-bar-container .filter-heading-container fs-keyword-input+fs-saved-filter-autocomplete-chips{margin-left: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;--mdc-icon-button-state-layer-size: 40px;padding:8px}.filter-toolbar .button-filters ::ng-deep svg,.filter-toolbar .button-reload ::ng-deep svg{display:flex}.filter-toolbar .button-reload{display:flex;align-items:center}.filter-toolbar .button-reload .auto-reload{margin-right:5px}.filter-toolbar .button-reload .auto-reload span{font-size:80%}.heading{margin-right:8px}.heading h2{margin:0}.heading h2+.subheading{margin:0}@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: FilterItemComponent, selector: "filter-item", inputs: ["autofocus", "autofocusName", "item", "name"] }, { 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 });
|
|
363
|
+
], queries: [{ propertyName: "statusBar", first: true, predicate: FilterStatusBarDirective, descendants: true }, { propertyName: "headingTemplate", first: true, predicate: FilterHeadingDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "keywordInput", first: true, predicate: KeywordInputComponent, descendants: true }, { propertyName: "reloadEl", first: true, predicate: ["reloadEl"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div\n class=\"filter-container\"\n [ngClass]=\"{ 'has-primary-filter': primaryFilterVisible$ | async }\"\n [ngClass]=\"{ 'keyword-full-width': keywordFullWidth$ | async }\">\n @if (primaryFilterVisible$ | async) {\n <ng-container *ngTemplateOutlet=\"headingTmpl\"></ng-container>\n }\n <div class=\"filter-bar-container\">\n @if (primaryFilterVisible$ | async) {\n <div class=\"filter-input-container\">\n @if (keywordVisible$ | async) {\n <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n }\n @for (item of primaryItems; track item.name) {\n @if (item.visible$ | async) {\n <filter-item [item]=\"item\"></filter-item>\n }\n }\n </div>\n } @else if (hasHeading) {\n <div class=\"filter-heading-container\">\n <ng-container *ngTemplateOutlet=\"headingTmpl\"></ng-container>\n </div>\n } @else {\n <ng-container *ngTemplateOutlet=\"chipsTmpl\"></ng-container>\n }\n <ng-container [ngTemplateOutlet]=\"filterActionsTmpl\"></ng-container>\n </div>\n @if ((primaryFilterVisible$ | async) === true || hasHeading) {\n <ng-container\n [ngTemplateOutlet]=\"chipsTmpl\"\n [ngTemplateOutletContext]=\"{ topMargin: true }\">\n </ng-container>\n }\n <ng-container *ngTemplateOutlet=\"statusBarTmpl\"></ng-container>\n</div>\n<ng-template\n #chipsTmpl\n let-topMargin=\"topMargin\">\n <fs-filter-chips\n class=\"filter-chips\"\n [ngClass]=\"{ 'top-margin': topMargin }\">\n </fs-filter-chips>\n</ng-template>\n<ng-template #statusBarTmpl>\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</ng-template>\n<ng-template #filterActionsTmpl>\n @if ((actionsVisible$ | async)) {\n <div class=\"filter-actions\">\n <ng-container [ngTemplateOutlet]=\"filterToolbarTmpl\"></ng-container>\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 #filterToolbarTmpl>\n @if (config.reload || config.autoReload || (filtersVisible$ | async)) {\n <div class=\"filter-toolbar\">\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 <mat-slide-toggle\n name=\"autoReload\"\n class=\"auto-reload\"\n [ngModel]=\"config.autoReload.enabled\"\n (ngModelChange)=\"config.autoReload.enabled = $event\">\n <span>\n Auto refresh\n </span>\n </mat-slide-toggle>\n </div>\n }\n </div>\n }\n</ng-template>\n<ng-template #headingTmpl>\n @if (headingTemplate) {\n <ng-container *ngTemplateOutlet=\"headingTemplate\"></ng-container>\n } @else 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;margin-top:4px}.filter-status-container .filter-status{overflow:hidden;text-overflow:ellipsis}.filter-container{width:100%}.filter-container.has-primary-filter .heading{margin-bottom:10px}.filter-container.has-primary-filter .filter-bar-container{margin-bottom:4px}.filter-container.keyword-full-width .filter-input-container{flex:1}.filter-container.keyword-full-width .filter-input-container fs-keyword-input{flex:1}.filter-container.keyword-full-width .filter-input-container fs-keyword-input ::ng-deep mat-form-field{width:100%}.filter-container .filter-bar-container{flex-direction:row;box-sizing:border-box;display:flex;position:relative;align-items:flex-start}.filter-container .filter-bar-container .filter-input-container{flex-direction:row;box-sizing:border-box;display:flex;align-items:center;min-width:0;gap:5px;flex-wrap:wrap}.filter-container .filter-bar-container .filter-heading-container{flex-direction:row;box-sizing:border-box;display:flex;align-items:center;min-width:0}.filter-container .filter-bar-container .filter-heading-container fs-keyword-input+fs-saved-filter-autocomplete-chips{margin-left: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;--mdc-icon-button-state-layer-size: 40px;padding:8px}.filter-toolbar .button-filters ::ng-deep svg,.filter-toolbar .button-reload ::ng-deep svg{display:flex}.filter-toolbar .button-reload{display:flex;align-items:center}.filter-toolbar .button-reload .auto-reload{margin-right:5px}.filter-toolbar .button-reload .auto-reload span{font-size:80%}.heading{margin-right:8px}.heading h2{margin:0}.heading h2+.subheading{margin:0}@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: FilterItemComponent, selector: "filter-item", inputs: ["autofocus", "floatLabel", "autofocusName", "item", "name"] }, { 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 });
|
|
364
364
|
}
|
|
365
365
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterComponent, decorators: [{
|
|
366
366
|
type: Component,
|
|
@@ -419,4 +419,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
419
419
|
type: HostBinding,
|
|
420
420
|
args: ['class.fs-filter']
|
|
421
421
|
}] } });
|
|
422
|
-
//# 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  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\n\nimport { MatIconAnchor } from '@angular/material/button';\nimport { MatIcon } 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 { FilterHeadingDirective } from '../../directives';\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 { 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 { FilterItemComponent } from '../filters-item';\nimport { KeywordInputComponent } from '../keyword-input/keyword-input.component';\n\nimport { FilterStatusBarDirective } from './../../directives/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    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    FilterItemComponent,\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  @Input('config') public set setFilterConfig(value: FilterConfig) {\n    this._filterConfig = value;\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  @ContentChild(FilterHeadingDirective, { read: TemplateRef })\n  public headingTemplate: TemplateRef<any>;\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 _filterConfig: FilterConfig;\n  private _filtersVisible$ = 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 _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  }\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 config(): FsFilterConfig {\n    return this._config;\n  }\n\n  public get items(): BaseItem<IFilterConfigItem>[] {\n    return this._filterController.items;\n  }\n\n  public get primaryItems(): BaseItem<IFilterConfigItem>[] {\n    return this.items.filter((item) => item.primary);\n  }\n\n  public change() {\n    this._filterController.change();\n  }\n\n  public get hasHeading(): boolean {\n    return !!this.headingTemplate || !!this.config.heading;\n  }\n\n  public get hasFilterChips$(): Observable<boolean> {\n    return this._hasFilterChips$.asObservable();\n  }\n\n  public get filtersVisible$(): Observable<boolean> {\n    return combineLatest({\n      filtersVisible: this._filtersVisible$.asObservable(),\n      hasVisibleItems: of(\n        this.items\n          .some((item) => item.visible && !item.isTypeKeyword),\n      ),\n    })\n      .pipe(\n        map(({ filtersVisible, hasVisibleItems }) => {\n          return filtersVisible && hasVisibleItems;\n        }),\n      );\n  }\n\n  public get keywordVisible$(): Observable<boolean> {\n    return this._keywordController.keywordVisible$;\n  }\n\n  public get keywordFullWidth$(): Observable<boolean> {\n    return this._keywordController.keywordFullWidth$;\n  }\n\n  public get primaryFilterVisible$(): Observable<boolean> {\n    return combineLatest({\n      keywordVisible: this.keywordVisible$,\n      savedFilterVisible: of(this.items.some((item) => item.visible && item.primary)),\n    })\n      .pipe(\n        map(({ keywordVisible, savedFilterVisible }) => {\n          return keywordVisible || savedFilterVisible;\n        }),\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 get sortController(): SortController {\n    return this._sortController;\n  }\n\n  public ngOnInit() {\n    const config = {\n      ...(this._defaultConfig || {}),\n      ...this._filterConfig,\n    };\n\n    this._config = new FsFilterConfig(config);\n    this._actionsController.setConfig(this.config);\n\n    this._initItems();\n    this._initAutoReload();\n  }\n\n  public ngOnDestroy() {\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, emitChange: boolean = true) {\n    this._sortController.updateSort(sort, emitChange);\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    this.change();\n  }\n\n  public getItem(name): BaseItem<any> {\n    return this.items\n      .find((item) => item.name === name);\n  }\n\n  /**\n   * @deprecated Use item(name).value$ instead\n   */\n  public getItemValueChange$(name: string) {\n    return this.getItem(name).value$;\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 showFilters(): void {\n    this._filtersVisible$.next(true);\n  }\n\n  /**\n   * Hide \"Filters\" button\n   */\n  public hideFilters(): void {\n    this._filtersVisible$.next(false);\n  }\n\n  /**\n   * Show \"Keyword\" field if it present\n   */\n  public showKeywordField(): void {\n    this._keywordController.show();\n  }\n\n  /**\n   * Hide \"Keyword\" field if it present\n   */\n  public hideKeywordField(): void {\n    this._keywordController.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 _updateWindowWidth() {\n    this.windowDesktop = window.innerWidth > 1200;\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.config.autoReload.enabled),\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this.reload(null);\n        });\n    }\n  }\n}\n","<div\n    class=\"filter-container\"\n    [ngClass]=\"{ 'has-primary-filter': primaryFilterVisible$ | async }\"\n    [ngClass]=\"{ 'keyword-full-width': keywordFullWidth$ | async }\">\n  @if (primaryFilterVisible$ | async) {\n    <ng-container *ngTemplateOutlet=\"headingTmpl\"></ng-container>\n  }\n  <div class=\"filter-bar-container\">\n    @if (primaryFilterVisible$ | async) {\n      <div class=\"filter-input-container\">\n        @if (keywordVisible$ | async) {\n          <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n        }\n        @for (item of primaryItems; track item.name) {\n          @if (item.visible$ | async) {\n            <filter-item [item]=\"item\"></filter-item>\n          }\n        }\n      </div>\n    } @else if (hasHeading) {\n      <div class=\"filter-heading-container\">\n        <ng-container *ngTemplateOutlet=\"headingTmpl\"></ng-container>\n      </div>\n    } @else {\n      <ng-container *ngTemplateOutlet=\"chipsTmpl\"></ng-container>\n    }\n    <ng-container [ngTemplateOutlet]=\"filterActionsTmpl\"></ng-container>\n  </div>\n  @if ((primaryFilterVisible$ | async) === true || hasHeading) {\n    <ng-container\n      [ngTemplateOutlet]=\"chipsTmpl\"\n      [ngTemplateOutletContext]=\"{ topMargin: true }\">\n    </ng-container>\n  }\n  <ng-container *ngTemplateOutlet=\"statusBarTmpl\"></ng-container>\n</div>\n<ng-template\n    #chipsTmpl\n    let-topMargin=\"topMargin\">\n  <fs-filter-chips\n    class=\"filter-chips\"\n    [ngClass]=\"{ 'top-margin': topMargin }\">\n  </fs-filter-chips>\n</ng-template>\n<ng-template #statusBarTmpl>\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</ng-template>\n<ng-template #filterActionsTmpl>\n  @if ((actionsVisible$ | async)) {\n    <div class=\"filter-actions\">\n      <ng-container [ngTemplateOutlet]=\"filterToolbarTmpl\"></ng-container>\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 #filterToolbarTmpl>\n  @if (config.reload || config.autoReload || (filtersVisible$ | async)) {\n    <div class=\"filter-toolbar\">\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          <mat-slide-toggle\n              name=\"autoReload\"\n              class=\"auto-reload\"\n              [ngModel]=\"config.autoReload.enabled\"\n              (ngModelChange)=\"config.autoReload.enabled = $event\">\n            <span>\n              Auto refresh\n            </span>\n          </mat-slide-toggle>\n        </div>\n      }\n    </div>\n  }\n</ng-template>\n<ng-template #headingTmpl>\n  @if (headingTemplate) {\n    <ng-container *ngTemplateOutlet=\"headingTemplate\"></ng-container>\n  } @else 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>"]}
|
|
422
|
+
//# 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  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\n\nimport { MatIconAnchor } from '@angular/material/button';\nimport { MatIcon } 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 { FilterHeadingDirective } from '../../directives';\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 { 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 { FilterItemComponent } from '../filters-item';\nimport { KeywordInputComponent } from '../keyword-input/keyword-input.component';\n\nimport { FilterStatusBarDirective } from './../../directives/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    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    FilterItemComponent,\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  @Input('config') public set setFilterConfig(value: FilterConfig) {\n    this._filterConfig = value;\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  @ContentChild(FilterHeadingDirective, { read: TemplateRef })\n  public headingTemplate: TemplateRef<any>;\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 _filterConfig: FilterConfig;\n  private _filtersVisible$ = 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 _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  }\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 config(): FsFilterConfig {\n    return this._config;\n  }\n\n  public get items(): BaseItem<IFilterConfigItem>[] {\n    return this._filterController.items;\n  }\n\n  public get primaryItems(): BaseItem<IFilterConfigItem>[] {\n    return this.items.filter((item) => item.primary);\n  }\n\n  public change() {\n    this._filterController.change();\n  }\n\n  public get hasHeading(): boolean {\n    return !!this.headingTemplate || !!this.config.heading;\n  }\n\n  public get hasFilterChips$(): Observable<boolean> {\n    return this._hasFilterChips$.asObservable();\n  }\n\n  public get filtersVisible$(): Observable<boolean> {\n    return combineLatest({\n      filtersVisible: this._filtersVisible$.asObservable(),\n      hasVisibleItems: of(\n        this.items\n          .some((item) => item.visible && !item.isTypeKeyword),\n      ),\n    })\n      .pipe(\n        map(({ filtersVisible, hasVisibleItems }) => {\n          return filtersVisible && hasVisibleItems;\n        }),\n      );\n  }\n\n  public get keywordVisible$(): Observable<boolean> {\n    return this._keywordController.keywordVisible$;\n  }\n\n  public get keywordFullWidth$(): Observable<boolean> {\n    return this._keywordController.keywordFullWidth$;\n  }\n\n  public get primaryFilterVisible$(): Observable<boolean> {\n    return combineLatest({\n      keywordVisible: this.keywordVisible$,\n      savedFilterVisible: of(this.items.some((item) => item.visible && item.primary)),\n    })\n      .pipe(\n        map(({ keywordVisible, savedFilterVisible }) => {\n          return keywordVisible || savedFilterVisible;\n        }),\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 get sortController(): SortController {\n    return this._sortController;\n  }\n\n  public ngOnInit() {\n    const config = {\n      ...(this._defaultConfig || {}),\n      ...this._filterConfig,\n    };\n\n    this._config = new FsFilterConfig(config);\n    this._actionsController.setConfig(this.config);\n\n    this._initItems();\n    this._initAutoReload();\n  }\n\n  public ngOnDestroy() {\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, emitChange: boolean = true) {\n    this._sortController.updateSort(sort, emitChange);\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    this.change();\n  }\n\n  public getItem(name): BaseItem<any> {\n    return this.items\n      .find((item) => item.name === name);\n  }\n\n  /**\n   * @deprecated Use item(name).value$ instead\n   */\n  public getItemValueChange$(name: string) {\n    return this.getItem(name).value$;\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 showFilters(): void {\n    this._filtersVisible$.next(true);\n  }\n\n  /**\n   * Hide \"Filters\" button\n   */\n  public hideFilters(): void {\n    this._filtersVisible$.next(false);\n  }\n\n  /**\n   * Show \"Keyword\" field if it present\n   */\n  public showKeywordField(): void {\n    this._keywordController.show();\n  }\n\n  /**\n   * Hide \"Keyword\" field if it present\n   */\n  public hideKeywordField(): void {\n    this._keywordController.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 _updateWindowWidth() {\n    this.windowDesktop = window.innerWidth > 1200;\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.config.autoReload.enabled),\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this.reload(null);\n        });\n    }\n  }\n}\n","<div\n    class=\"filter-container\"\n    [ngClass]=\"{ 'has-primary-filter': primaryFilterVisible$ | async }\"\n    [ngClass]=\"{ 'keyword-full-width': keywordFullWidth$ | async }\">\n  @if (primaryFilterVisible$ | async) {\n    <ng-container *ngTemplateOutlet=\"headingTmpl\"></ng-container>\n  }\n  <div class=\"filter-bar-container\">\n    @if (primaryFilterVisible$ | async) {\n      <div class=\"filter-input-container\">\n        @if (keywordVisible$ | async) {\n          <fs-keyword-input [autofocus]=\"config.autofocus\"></fs-keyword-input>\n        }\n        @for (item of primaryItems; track item.name) {\n          @if (item.visible$ | async) {\n            <filter-item [item]=\"item\"></filter-item>\n          }\n        }\n      </div>\n    } @else if (hasHeading) {\n      <div class=\"filter-heading-container\">\n        <ng-container *ngTemplateOutlet=\"headingTmpl\"></ng-container>\n      </div>\n    } @else {\n      <ng-container *ngTemplateOutlet=\"chipsTmpl\"></ng-container>\n    }\n    <ng-container [ngTemplateOutlet]=\"filterActionsTmpl\"></ng-container>\n  </div>\n  @if ((primaryFilterVisible$ | async) === true || hasHeading) {\n    <ng-container\n      [ngTemplateOutlet]=\"chipsTmpl\"\n      [ngTemplateOutletContext]=\"{ topMargin: true }\">\n    </ng-container>\n  }\n  <ng-container *ngTemplateOutlet=\"statusBarTmpl\"></ng-container>\n</div>\n<ng-template\n    #chipsTmpl\n    let-topMargin=\"topMargin\">\n  <fs-filter-chips\n    class=\"filter-chips\"\n    [ngClass]=\"{ 'top-margin': topMargin }\">\n  </fs-filter-chips>\n</ng-template>\n<ng-template #statusBarTmpl>\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</ng-template>\n<ng-template #filterActionsTmpl>\n  @if ((actionsVisible$ | async)) {\n    <div class=\"filter-actions\">\n      <ng-container [ngTemplateOutlet]=\"filterToolbarTmpl\"></ng-container>\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 #filterToolbarTmpl>\n  @if (config.reload || config.autoReload || (filtersVisible$ | async)) {\n    <div class=\"filter-toolbar\">\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          <mat-slide-toggle\n              name=\"autoReload\"\n              class=\"auto-reload\"\n              [ngModel]=\"config.autoReload.enabled\"\n              (ngModelChange)=\"config.autoReload.enabled = $event\">\n            <span>\n              Auto refresh\n            </span>\n          </mat-slide-toggle>\n        </div>\n      }\n    </div>\n  }\n</ng-template>\n<ng-template #headingTmpl>\n  @if (headingTemplate) {\n    <ng-container *ngTemplateOutlet=\"headingTemplate\"></ng-container>\n  } @else 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>"]}
|