@firestitch/filter 18.2.9 → 18.2.11
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/classes/actions-controller.d.ts +1 -1
- package/app/components/filter/filter.component.d.ts +3 -4
- package/app/components/filters-item/autocompletechips/autocompletechips.component.d.ts +2 -0
- package/app/helpers/create-filter-item.d.ts +1 -1
- package/app/interfaces/items/autocomplete-chips.interface.d.ts +1 -1
- package/app/models/items/autocomplete-chips-item.d.ts +1 -1
- package/app/models/items/base-item.d.ts +6 -1
- package/app/services/filter-overlay.service.d.ts +1 -0
- package/app/services/item-store.service.d.ts +2 -9
- package/esm2022/app/classes/actions-controller.mjs +2 -2
- package/esm2022/app/components/filter/filter.component.mjs +27 -42
- package/esm2022/app/components/filter-drawer/filter-drawer.component.mjs +3 -3
- package/esm2022/app/components/filters-item/autocompletechips/autocompletechips.component.mjs +10 -4
- package/esm2022/app/components/filters-item/filter-item.component.mjs +11 -9
- package/esm2022/app/components/filters-item/select/select.component.mjs +5 -5
- package/esm2022/app/interfaces/items/autocomplete-chips.interface.mjs +1 -1
- package/esm2022/app/models/items/autocomplete-chips-item.mjs +1 -1
- package/esm2022/app/models/items/base-item.mjs +24 -8
- package/esm2022/app/services/filter-overlay.service.mjs +4 -1
- package/esm2022/app/services/item-store.service.mjs +3 -26
- package/fesm2022/firestitch-filter.mjs +1416 -1429
- package/fesm2022/firestitch-filter.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { BreakpointObserver } from '@angular/cdk/layout';
|
|
2
1
|
import { OnDestroy } from '@angular/core';
|
|
2
|
+
import { BreakpointObserver } from '@angular/cdk/layout';
|
|
3
3
|
import { Observable } from 'rxjs';
|
|
4
4
|
import { FsFilterAction } from '../interfaces/action.interface';
|
|
5
5
|
import { Action } from '../models/action.model';
|
|
@@ -128,9 +128,9 @@ export declare class FilterComponent implements OnInit, OnDestroy {
|
|
|
128
128
|
*
|
|
129
129
|
*/
|
|
130
130
|
updateValues(values: any): void;
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
131
|
+
hideDrawer(): void;
|
|
132
|
+
showDrawer(): void;
|
|
133
|
+
filterButtonClick(event?: any): void;
|
|
134
134
|
get itemValues(): any[];
|
|
135
135
|
get nonEmptyItemValues(): any[];
|
|
136
136
|
get hasItemValues(): boolean;
|
|
@@ -140,7 +140,6 @@ export declare class FilterComponent implements OnInit, OnDestroy {
|
|
|
140
140
|
clearItem(name: string): void;
|
|
141
141
|
updateItemConfig(name: string, params: IUpdateFilterItemConfig): void;
|
|
142
142
|
getItemValueChange$(name: string): Observable<any> | null;
|
|
143
|
-
changeVisibility(state: boolean): void;
|
|
144
143
|
init(): void;
|
|
145
144
|
clear(event?: any): void;
|
|
146
145
|
reload(event?: any): void;
|
|
@@ -5,12 +5,14 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
export declare class AutocompletechipsComponent extends BaseItemComponent<AutocompleteChipsItem> {
|
|
6
6
|
protected _kvDiffers: KeyValueDiffers;
|
|
7
7
|
protected _cd: ChangeDetectorRef;
|
|
8
|
+
private _injector;
|
|
8
9
|
constructor(_kvDiffers: KeyValueDiffers, _cd: ChangeDetectorRef);
|
|
9
10
|
addAutocompleteChipItem(event: any): void;
|
|
10
11
|
removeAutocompleteChipItem(event: any): void;
|
|
11
12
|
clearAutocompleteChipItem(): void;
|
|
12
13
|
fetch: (keyword: any) => any[] | import("rxjs").Observable<any>;
|
|
13
14
|
compareItems(item1: any, item2: any): boolean;
|
|
15
|
+
actionClick(action: any): void;
|
|
14
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<AutocompletechipsComponent, never>;
|
|
15
17
|
static ɵcmp: i0.ɵɵComponentDeclaration<AutocompletechipsComponent, "filter-item-autocompletechips", never, {}, {}, never, never, true, never>;
|
|
16
18
|
}
|
|
@@ -11,4 +11,4 @@ import { DateTimeRangeItem } from '../models/items/date-time-range-item';
|
|
|
11
11
|
import { RangeItem } from '../models/items/range-item';
|
|
12
12
|
import { TextItem } from '../models/items/text-item';
|
|
13
13
|
import { WeekItem } from '../models/items/week-item';
|
|
14
|
-
export declare function createFilterItem(item: IFilterConfigItem, config: any, filter: FilterComponent):
|
|
14
|
+
export declare function createFilterItem(item: IFilterConfigItem, config: any, filter: FilterComponent): TextItem | ChipsItem | WeekItem | RangeItem | AutocompleteItem | AutocompleteChipsItem | DateItem | DateTimeItem | DateRangeItem | DateTimeRangeItem | CheckboxItem | import("../models/items").SimpleSelectItem | import("../models/items").MultipleSelectItem;
|
|
@@ -14,6 +14,6 @@ export interface IFilterConfigAutocompleteChipsItem extends IFilterConfigBaseIte
|
|
|
14
14
|
values?: (keyword?: string, filter?: FilterComponent) => Observable<any[]>;
|
|
15
15
|
panelActions?: {
|
|
16
16
|
label: string;
|
|
17
|
-
click: () => void;
|
|
17
|
+
click: (filter: FilterComponent) => void;
|
|
18
18
|
}[];
|
|
19
19
|
}
|
|
@@ -12,7 +12,7 @@ export declare class AutocompleteChipsItem extends BaseAutocompleteItem<IFilterC
|
|
|
12
12
|
chipClass: string;
|
|
13
13
|
panelActions: {
|
|
14
14
|
label: string;
|
|
15
|
-
click: () => void;
|
|
15
|
+
click: (filter: FilterComponent) => void;
|
|
16
16
|
}[];
|
|
17
17
|
constructor(itemConfig: IFilterConfigAutocompleteChipsItem, _additionalConfig: unknown, _filter: FilterComponent);
|
|
18
18
|
static create(config: IFilterConfigAutocompleteChipsItem, filter: FilterComponent): AutocompleteChipsItem;
|
|
@@ -8,7 +8,6 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
8
8
|
name: string;
|
|
9
9
|
label: any;
|
|
10
10
|
chipLabel: string | string[];
|
|
11
|
-
hide: boolean;
|
|
12
11
|
defaultValue: any;
|
|
13
12
|
defaultValueFn: IFilterDefaultFn;
|
|
14
13
|
persistedValue: unknown;
|
|
@@ -23,6 +22,7 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
23
22
|
protected _pendingDefaultValue: boolean;
|
|
24
23
|
protected _initializedValues: boolean;
|
|
25
24
|
protected _valuesFn: (keyword?: string, filter?: FilterComponent) => Observable<any> | any[];
|
|
25
|
+
private _hidden$;
|
|
26
26
|
private _loading$;
|
|
27
27
|
private _value$;
|
|
28
28
|
private _valueChange$;
|
|
@@ -31,6 +31,9 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
31
31
|
private _clear$;
|
|
32
32
|
constructor(itemConfig: T, _additionalConfig: unknown, _filter: FilterComponent);
|
|
33
33
|
get filter(): FilterComponent;
|
|
34
|
+
get hidden$(): Observable<boolean>;
|
|
35
|
+
get visible$(): Observable<boolean>;
|
|
36
|
+
get hidden(): boolean;
|
|
34
37
|
get isTypeAutocomplete(): boolean;
|
|
35
38
|
get isTypeAutocompleteChips(): boolean;
|
|
36
39
|
get isTypeChips(): boolean;
|
|
@@ -61,6 +64,8 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
61
64
|
get loading(): boolean;
|
|
62
65
|
set loading(value: boolean);
|
|
63
66
|
get isQueryParamVisible(): boolean;
|
|
67
|
+
hide(): void;
|
|
68
|
+
show(): void;
|
|
64
69
|
get queryObject(): Record<string, unknown>;
|
|
65
70
|
get persistanceObject(): Record<string, unknown>;
|
|
66
71
|
loadDefaultValue(): Observable<any>;
|
|
@@ -21,6 +21,7 @@ export declare class FsFilterOverlayService implements OnDestroy {
|
|
|
21
21
|
setClearFn(fn: () => void): void;
|
|
22
22
|
setDoneFn(fn: () => void): void;
|
|
23
23
|
close(): void;
|
|
24
|
+
opened(): boolean;
|
|
24
25
|
open(): FilterDrawerComponent;
|
|
25
26
|
ngOnDestroy(): void;
|
|
26
27
|
private _createOverlay;
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { OnDestroy } from '@angular/core';
|
|
2
|
-
import { Observable } from 'rxjs';
|
|
3
2
|
import type { FilterComponent } from '../components/filter/filter.component';
|
|
4
3
|
import { FilterSort, IFilterConfigItem, SortItem } from '../interfaces/config.interface';
|
|
5
4
|
import { KeyValue } from '../interfaces/external-params.interface';
|
|
@@ -25,15 +24,11 @@ export declare class ItemStore implements OnDestroy {
|
|
|
25
24
|
private _config;
|
|
26
25
|
private _itemsChange$;
|
|
27
26
|
private _destroy$;
|
|
28
|
-
constructor();
|
|
29
27
|
get items(): BaseItem<IFilterConfigItem>[];
|
|
30
28
|
get itemNames(): string[];
|
|
31
|
-
get visibleItems(): BaseItem<IFilterConfigItem>[];
|
|
32
|
-
set visibleItems(items: BaseItem<IFilterConfigItem>[]);
|
|
33
|
-
get visibleItems$(): Observable<BaseItem<IFilterConfigItem>[]>;
|
|
34
29
|
get hasKeyword(): boolean;
|
|
35
|
-
get itemsChange$(): Observable<unknown>;
|
|
36
|
-
get ready$(): Observable<boolean>;
|
|
30
|
+
get itemsChange$(): import("rxjs").Observable<unknown>;
|
|
31
|
+
get ready$(): import("rxjs").Observable<boolean>;
|
|
37
32
|
ngOnDestroy(): void;
|
|
38
33
|
setConfig(config: any): void;
|
|
39
34
|
getItemByName(name: string): BaseItem<IFilterConfigItem>;
|
|
@@ -57,10 +52,8 @@ export declare class ItemStore implements OnDestroy {
|
|
|
57
52
|
* Some items might need to load async values before they will be shown
|
|
58
53
|
*/
|
|
59
54
|
prepareItems(): void;
|
|
60
|
-
updateItemsVisiblity(): void;
|
|
61
55
|
private _createItems;
|
|
62
56
|
private _subscribeToItemsChanges;
|
|
63
|
-
private _lazyInit;
|
|
64
57
|
private _initSortingItems;
|
|
65
58
|
private _createSortingItems;
|
|
66
59
|
private _setKeywordItem;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { BreakpointObserver } from '@angular/cdk/layout';
|
|
2
1
|
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BreakpointObserver } from '@angular/cdk/layout';
|
|
3
3
|
import { BehaviorSubject, Subject } from 'rxjs';
|
|
4
4
|
import { skip, takeUntil } from 'rxjs/operators';
|
|
5
5
|
import { Action } from '../models/action.model';
|
|
@@ -127,4 +127,4 @@ export class ActionsController {
|
|
|
127
127
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionsController, decorators: [{
|
|
128
128
|
type: Injectable
|
|
129
129
|
}], ctorParameters: () => [{ type: i1.BreakpointObserver }] });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions-controller.js","sourceRoot":"","sources":["../../../../src/app/classes/actions-controller.ts"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver } from '@angular/cdk/layout';\nimport { Injectable, OnDestroy } from '@angular/core';\n\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { skip, takeUntil } from 'rxjs/operators';\n\nimport { FsFilterAction } from '../interfaces/action.interface';\nimport { Action } from '../models/action.model';\nimport { FsFilterConfig } from '../models/filter-config';\n\n\n@Injectable()\nexport class ActionsController implements OnDestroy {\n\n  private _visible$ = new BehaviorSubject(false);\n  private _actions$ = new BehaviorSubject<Action[]>([]);\n  private _menuActions$ = new BehaviorSubject<Action[]>([]);\n  private _destroy$ = new Subject<void>();\n  private _config: FsFilterConfig;\n\n  private readonly _mobileMedia = '(max-width: 799px)';\n  private _allActions: Action[] = [];\n  private _reorderAction: Action;\n\n  constructor(\n    private _breakpointObserver: BreakpointObserver,\n  ) {\n    this._listenMobileMedia();\n  }\n\n  public get menuActions(): Action[] {\n    return this._menuActions$.value;\n  }\n\n  public get actions(): Action[] {\n    return this._actions$.value;\n  }\n\n  public get actions$(): Observable<Action[]> {\n    return this._actions$.asObservable();\n  }\n\n  public get menuActions$(): Observable<Action[]> {\n    return this._menuActions$.asObservable();\n  }\n\n  public get visible$(): Observable<boolean> {\n    return this._visible$.asObservable();\n  }\n\n  public get mobileMode(): boolean {\n    return this._breakpointObserver.isMatched(this._mobileMedia);\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n  public setConfig(config: FsFilterConfig) {\n    this._config = config;\n    this.initActions(config.actions);\n  }\n\n  public initActions(rawActions: FsFilterAction[]) {\n    if (!rawActions || !Array.isArray(rawActions)) {\n      return;\n    }\n\n    this.show();\n\n    this._allActions = rawActions\n      .map((action) => new Action(this._config, action));\n\n    if (this._reorderAction) {\n      this._allActions.unshift(this._reorderAction);\n    }\n\n    this._classifyActions();\n  }\n\n  public show() {\n    this._visible$.next(true);\n  }\n\n  public hide() {\n    this._visible$.next(false);\n  }\n\n  public addReorderAction(action: Action) {\n    this._allActions.unshift(action);\n\n    action.isReorderAction = true;\n\n    this._classifyAction(action);\n    this._reorderAction = action;\n  }\n\n  public clearActions() {\n    this._allActions = [];\n    this._setActions([]);\n    this._setKebabActions([]);\n  }\n\n  public updateActionsVisibility() {\n    this._allActions.forEach((action) => action.updateVisibility());\n    this._classifyActions();\n  }\n\n  public updateDisabledState() {\n    this.actions.forEach((action) => action.updateDisabledState())\n  }\n\n  private _setKebabActions(actions: Action[]) {\n    this._menuActions$.next(actions);\n  }\n\n  private _setActions(actions: Action[]) {\n    this._actions$.next(actions);\n  }\n\n  private _classifyActions() {\n    const kebabActions = [];\n    const actions = [];\n    const mobileMode = this.mobileMode;\n\n    this._allActions\n      .filter((action) => {\n        return action.visible;\n      })\n      .forEach((action) => {\n        if (action.menu !== false && (action.menu || mobileMode)) {\n          kebabActions.push(action);\n        } else {\n          actions.push(action);\n        }\n      });\n\n    this._setKebabActions(kebabActions);\n    this._setActions(actions);\n  }\n\n  private _classifyAction(action: Action) {\n    if (action.menu) {\n      this._setKebabActions([...this.menuActions, action]);\n    } else {\n      this._setActions([...this.actions, action]);\n    }\n  }\n\n  private _listenMobileMedia() {\n    this._breakpointObserver.observe(this._mobileMedia)\n      .pipe(\n        skip(1),\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this._classifyActions();\n      })\n  }\n}\n"]}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions-controller.js","sourceRoot":"","sources":["../../../../src/app/classes/actions-controller.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\n\nimport { BreakpointObserver } from '@angular/cdk/layout';\n\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { skip, takeUntil } from 'rxjs/operators';\n\nimport { FsFilterAction } from '../interfaces/action.interface';\nimport { Action } from '../models/action.model';\nimport { FsFilterConfig } from '../models/filter-config';\n\n\n@Injectable()\nexport class ActionsController implements OnDestroy {\n\n  private _visible$ = new BehaviorSubject(false);\n  private _actions$ = new BehaviorSubject<Action[]>([]);\n  private _menuActions$ = new BehaviorSubject<Action[]>([]);\n  private _destroy$ = new Subject<void>();\n  private _config: FsFilterConfig;\n\n  private readonly _mobileMedia = '(max-width: 799px)';\n  private _allActions: Action[] = [];\n  private _reorderAction: Action;\n\n  constructor(\n    private _breakpointObserver: BreakpointObserver,\n  ) {\n    this._listenMobileMedia();\n  }\n\n  public get menuActions(): Action[] {\n    return this._menuActions$.value;\n  }\n\n  public get actions(): Action[] {\n    return this._actions$.value;\n  }\n\n  public get actions$(): Observable<Action[]> {\n    return this._actions$.asObservable();\n  }\n\n  public get menuActions$(): Observable<Action[]> {\n    return this._menuActions$.asObservable();\n  }\n\n  public get visible$(): Observable<boolean> {\n    return this._visible$.asObservable();\n  }\n\n  public get mobileMode(): boolean {\n    return this._breakpointObserver.isMatched(this._mobileMedia);\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n  public setConfig(config: FsFilterConfig) {\n    this._config = config;\n    this.initActions(config.actions);\n  }\n\n  public initActions(rawActions: FsFilterAction[]) {\n    if (!rawActions || !Array.isArray(rawActions)) {\n      return;\n    }\n\n    this.show();\n\n    this._allActions = rawActions\n      .map((action) => new Action(this._config, action));\n\n    if (this._reorderAction) {\n      this._allActions.unshift(this._reorderAction);\n    }\n\n    this._classifyActions();\n  }\n\n  public show() {\n    this._visible$.next(true);\n  }\n\n  public hide() {\n    this._visible$.next(false);\n  }\n\n  public addReorderAction(action: Action) {\n    this._allActions.unshift(action);\n\n    action.isReorderAction = true;\n\n    this._classifyAction(action);\n    this._reorderAction = action;\n  }\n\n  public clearActions() {\n    this._allActions = [];\n    this._setActions([]);\n    this._setKebabActions([]);\n  }\n\n  public updateActionsVisibility() {\n    this._allActions.forEach((action) => action.updateVisibility());\n    this._classifyActions();\n  }\n\n  public updateDisabledState() {\n    this.actions.forEach((action) => action.updateDisabledState());\n  }\n\n  private _setKebabActions(actions: Action[]) {\n    this._menuActions$.next(actions);\n  }\n\n  private _setActions(actions: Action[]) {\n    this._actions$.next(actions);\n  }\n\n  private _classifyActions() {\n    const kebabActions = [];\n    const actions = [];\n    const mobileMode = this.mobileMode;\n\n    this._allActions\n      .filter((action) => {\n        return action.visible;\n      })\n      .forEach((action) => {\n        if (action.menu !== false && (action.menu || mobileMode)) {\n          kebabActions.push(action);\n        } else {\n          actions.push(action);\n        }\n      });\n\n    this._setKebabActions(kebabActions);\n    this._setActions(actions);\n  }\n\n  private _classifyAction(action: Action) {\n    if (action.menu) {\n      this._setKebabActions([...this.menuActions, action]);\n    } else {\n      this._setActions([...this.actions, action]);\n    }\n  }\n\n  private _listenMobileMedia() {\n    this._breakpointObserver.observe(this._mobileMedia)\n      .pipe(\n        skip(1),\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this._classifyActions();\n      });\n  }\n}\n"]}
|