@firestitch/filter 18.2.19 → 18.2.21
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/filter.component.d.ts +4 -6
- package/esm2022/app/components/filter/filter.component.mjs +20 -22
- package/esm2022/app/models/items/base-item.mjs +2 -4
- package/esm2022/app/models/items/chips-item.mjs +14 -12
- package/esm2022/app/services/filter-controller.service.mjs +5 -2
- package/esm2022/app/services/keyword-controller.service.mjs +4 -4
- package/fesm2022/firestitch-filter.mjs +39 -38
- package/fesm2022/firestitch-filter.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -151,7 +151,10 @@ export class FilterController {
|
|
|
151
151
|
return forkJoin(this.items
|
|
152
152
|
.map((item) => {
|
|
153
153
|
return item.init(values[item.name]);
|
|
154
|
-
}))
|
|
154
|
+
}))
|
|
155
|
+
.pipe(tap(() => this.items.forEach((item) => {
|
|
156
|
+
item.initCallback(item, this.filter);
|
|
157
|
+
})));
|
|
155
158
|
}
|
|
156
159
|
_addItems(items) {
|
|
157
160
|
this._add$.next();
|
|
@@ -196,4 +199,4 @@ export class FilterController {
|
|
|
196
199
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterController, decorators: [{
|
|
197
200
|
type: Injectable
|
|
198
201
|
}] });
|
|
199
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-controller.service.js","sourceRoot":"","sources":["../../../../src/app/services/filter-controller.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, OnDestroy } from '@angular/core';\n\nimport { BehaviorSubject, forkJoin, merge, Observable, of, Subject } from 'rxjs';\nimport { debounceTime, filter, finalize, map, switchMap, takeUntil, tap } from 'rxjs/operators';\n\n\nimport type { FilterComponent } from '../components/filter/filter.component';\nimport { ItemType } from '../enums/item-type.enum';\nimport { createFilterItem } from '../helpers/create-filter-item';\nimport {\n  IFilterConfigItem,\n} from '../interfaces/config.interface';\nimport { KeyValue } from '../interfaces/external-params.interface';\nimport { FsFilterConfig } from '../models/filter-config';\nimport { BaseItem } from '../models/items/base-item';\n\nimport { KeywordController } from './keyword-controller.service';\nimport { PersistanceController } from './persistance-controller.service';\nimport { QueryParamController } from './query-param-controller.service';\nimport { SavedFilterController } from './saved-filter-controller.service';\nimport { SortController } from './sort-controller.service';\n\n\n@Injectable()\nexport class FilterController implements OnDestroy {\n\n  public filter: FilterComponent;\n\n  private _ready$ = new BehaviorSubject(false);\n  private _items = new Map<string, BaseItem<IFilterConfigItem>>();\n  private _config: FsFilterConfig;\n  private _add$ = new Subject<void>();\n  private _init$ = new Subject<void>();\n  private _change$ = new Subject<BaseItem<IFilterConfigItem>[]>();\n  private _destroy$ = new Subject<void>();\n  private _persistanceController = inject(PersistanceController);\n  private _savedFilterController = inject(SavedFilterController);\n  private _queryParamController = inject(QueryParamController);\n  private _keywordController = inject(KeywordController);\n  private _sortController = inject(SortController);\n\n  public get items(): BaseItem<IFilterConfigItem>[] {\n    return Array.from(this._items.values());\n  }\n\n  public get itemNames(): string[] {\n    return this.items.map((item) => item.name);\n  }\n\n  public get config(): FsFilterConfig {\n    return this._config;\n  }\n\n  public get init$() {\n    return this._init$.asObservable();\n  }\n\n  public get add$() {\n    return this._add$.asObservable();\n  }\n\n  public get change$() {\n    return this._change$\n      .pipe(\n        debounceTime(30),\n      );\n  }\n\n  public change() {\n    this._change$.next(null);\n  }\n\n  public get ready$() {\n    return this._ready$.asObservable();\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n  public init(config: FsFilterConfig) {\n    this._config = config;\n    of(null)\n      .pipe(\n        tap(() => this._addItems(this._config.items || [])),\n        tap(() => this._keywordController.init(this)),\n        tap(() => this._sortController.init(this)),\n        switchMap(() => forkJoin({\n          savedFilters: this._savedFilterController.init(this),\n          persistance: this._persistanceController.init(this),\n          queryParams: this._queryParamController.init(this),\n        })),\n        switchMap(() => this._initItems()),\n        tap(() => this._initChanges()),\n        tap(() => {\n          this._init$.next();\n          if (this._config.init) {\n            this._config.init(this.query, this._sortController.getSort(), this.filter);\n          }\n        }),\n        finalize(() => this._ready$.next(true)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  public getItem(name: string): BaseItem<IFilterConfigItem> {\n    return this._items.get(name);\n  }\n\n  public filtersClear() {\n    this.items.forEach((item) => {\n      item.clear();\n    });\n\n    this._keywordController.clear();\n    this._sortController.clear();\n  }\n\n  public get queryParam(): Record<string, unknown> {\n    return this.items\n      .reduce((accum, item) => {\n        return {\n          ...accum,\n          ...item.queryParam,\n        };\n      }, {});\n  }\n\n  public get query(): KeyValue {\n    return {\n      ...this.items\n        .reduce((accum, item) => {\n          return {\n            ...accum,\n            ...item.query,\n          };\n        }, {}),\n      ...this._sortController.query(),\n    };\n  }\n\n  public set values(values: Record<string, unknown>) {\n    this.items.forEach((item) => {\n      item.setValue(values[item.name], false);\n    });\n\n    this.change();\n  }\n\n  public get values(): Record<string, unknown> {\n    return this.items\n      .reduce((acc, item) => {\n        const value = item.value;\n\n        if (value !== null) {\n          acc[item.name] = value;\n        }\n\n        return acc;\n      }, {});\n  }\n  \n  private _getInitValues(): KeyValue {\n    let result: KeyValue = {};\n\n    if (this._savedFilterController.enabled && this._savedFilterController.activeFilter) {\n      const query = Object.keys(result)\n        .filter((key) => !this.itemNames.includes(key))\n        .reduce((acc, key) => {\n          return {\n            ...acc,\n            [key]: result[key],\n          };\n        }, {});\n\n      result = {\n        ...query, \n        ...this._savedFilterController.activeFilterData,\n      };\n\n    } else {\n      if (this._persistanceController.enabled) {\n        result = {\n          ...result, \n          ...this._persistanceController.getQuery(),\n        };\n      }\n      \n      if (this._config.queryParam) {\n        result = {\n          ...result, \n          ...this._queryParamController.params,\n        };\n      }\n    }\n\n    return result;\n  }\n\n  private _initItems(): Observable<any> {\n    const values = this._getInitValues();\n\n    return forkJoin(\n      this.items\n        .map((item) => {\n          return item.init(values[item.name]);\n        }),\n    );\n  }\n\n  private _addItems(items: IFilterConfigItem[]) {\n    this._add$.next();\n\n    this._items = new Map(\n      items      \n        .filter((item) => {\n          if (this._items.has(item.name)) {\n            throw Error('Filter init error. Items name must be unique.');\n          }\n\n          return true;\n        })\n        .map((item) => {\n          const filterItem = createFilterItem(item, { }, this.filter);\n\n          if (filterItem.type === ItemType.Keyword) {\n            this._keywordController.keywordItem = filterItem;\n          }\n\n          this._items.set(item.name, filterItem);\n\n          return [item.name, filterItem];\n        }),\n    );\n  }\n\n  private _initChanges() {\n    merge(\n      ...this.items\n        .map((item) => item.valueEvent$\n          .pipe(\n            filter((event) => event.emitChange),\n            map(() => item),\n          )),\n    )\n      .pipe(\n        tap((item) => this._change$.next([item])),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._change$\n      .pipe(\n        tap((items: BaseItem<IFilterConfigItem>[]) => {\n          if (this._config.change) {\n            this._config.change(this.query, this._sortController.getSort());\n          }\n\n          items?.forEach((item) => {\n            if (item.changeCallback) {\n              item.changeCallback(item, this.filter);\n            }\n          });\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n}\n"]}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-controller.service.js","sourceRoot":"","sources":["../../../../src/app/services/filter-controller.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, OnDestroy } from '@angular/core';\n\nimport { BehaviorSubject, forkJoin, merge, Observable, of, Subject } from 'rxjs';\nimport { debounceTime, filter, finalize, map, switchMap, takeUntil, tap } from 'rxjs/operators';\n\n\nimport type { FilterComponent } from '../components/filter/filter.component';\nimport { ItemType } from '../enums/item-type.enum';\nimport { createFilterItem } from '../helpers/create-filter-item';\nimport {\n  IFilterConfigItem,\n} from '../interfaces/config.interface';\nimport { KeyValue } from '../interfaces/external-params.interface';\nimport { FsFilterConfig } from '../models/filter-config';\nimport { BaseItem } from '../models/items/base-item';\n\nimport { KeywordController } from './keyword-controller.service';\nimport { PersistanceController } from './persistance-controller.service';\nimport { QueryParamController } from './query-param-controller.service';\nimport { SavedFilterController } from './saved-filter-controller.service';\nimport { SortController } from './sort-controller.service';\n\n\n@Injectable()\nexport class FilterController implements OnDestroy {\n\n  public filter: FilterComponent;\n\n  private _ready$ = new BehaviorSubject(false);\n  private _items = new Map<string, BaseItem<IFilterConfigItem>>();\n  private _config: FsFilterConfig;\n  private _add$ = new Subject<void>();\n  private _init$ = new Subject<void>();\n  private _change$ = new Subject<BaseItem<IFilterConfigItem>[]>();\n  private _destroy$ = new Subject<void>();\n  private _persistanceController = inject(PersistanceController);\n  private _savedFilterController = inject(SavedFilterController);\n  private _queryParamController = inject(QueryParamController);\n  private _keywordController = inject(KeywordController);\n  private _sortController = inject(SortController);\n\n  public get items(): BaseItem<IFilterConfigItem>[] {\n    return Array.from(this._items.values());\n  }\n\n  public get itemNames(): string[] {\n    return this.items.map((item) => item.name);\n  }\n\n  public get config(): FsFilterConfig {\n    return this._config;\n  }\n\n  public get init$() {\n    return this._init$.asObservable();\n  }\n\n  public get add$() {\n    return this._add$.asObservable();\n  }\n\n  public get change$() {\n    return this._change$\n      .pipe(\n        debounceTime(30),\n      );\n  }\n\n  public change() {\n    this._change$.next(null);\n  }\n\n  public get ready$() {\n    return this._ready$.asObservable();\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n  public init(config: FsFilterConfig) {\n    this._config = config;\n    of(null)\n      .pipe(\n        tap(() => this._addItems(this._config.items || [])),\n        tap(() => this._keywordController.init(this)),\n        tap(() => this._sortController.init(this)),\n        switchMap(() => forkJoin({\n          savedFilters: this._savedFilterController.init(this),\n          persistance: this._persistanceController.init(this),\n          queryParams: this._queryParamController.init(this),\n        })),\n        switchMap(() => this._initItems()),        \n        tap(() => this._initChanges()),\n        tap(() => {\n          this._init$.next();\n          if (this._config.init) {\n            this._config.init(this.query, this._sortController.getSort(), this.filter);\n          }\n        }),\n        finalize(() => this._ready$.next(true)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  public getItem(name: string): BaseItem<IFilterConfigItem> {\n    return this._items.get(name);\n  }\n\n  public filtersClear() {\n    this.items.forEach((item) => {\n      item.clear();\n    });\n\n    this._keywordController.clear();\n    this._sortController.clear();\n  }\n\n  public get queryParam(): Record<string, unknown> {\n    return this.items\n      .reduce((accum, item) => {\n        return {\n          ...accum,\n          ...item.queryParam,\n        };\n      }, {});\n  }\n\n  public get query(): KeyValue {\n    return {\n      ...this.items\n        .reduce((accum, item) => {\n          return {\n            ...accum,\n            ...item.query,\n          };\n        }, {}),\n      ...this._sortController.query(),\n    };\n  }\n\n  public set values(values: Record<string, unknown>) {\n    this.items.forEach((item) => {\n      item.setValue(values[item.name], false);\n    });\n\n    this.change();\n  }\n\n  public get values(): Record<string, unknown> {\n    return this.items\n      .reduce((acc, item) => {\n        const value = item.value;\n\n        if (value !== null) {\n          acc[item.name] = value;\n        }\n\n        return acc;\n      }, {});\n  }\n  \n  private _getInitValues(): KeyValue {\n    let result: KeyValue = {};\n\n    if (this._savedFilterController.enabled && this._savedFilterController.activeFilter) {\n      const query = Object.keys(result)\n        .filter((key) => !this.itemNames.includes(key))\n        .reduce((acc, key) => {\n          return {\n            ...acc,\n            [key]: result[key],\n          };\n        }, {});\n\n      result = {\n        ...query, \n        ...this._savedFilterController.activeFilterData,\n      };\n\n    } else {\n      if (this._persistanceController.enabled) {\n        result = {\n          ...result, \n          ...this._persistanceController.getQuery(),\n        };\n      }\n      \n      if (this._config.queryParam) {\n        result = {\n          ...result, \n          ...this._queryParamController.params,\n        };\n      }\n    }\n\n    return result;\n  }\n\n  private _initItems(): Observable<any> {\n    const values = this._getInitValues();\n\n    return forkJoin(\n      this.items\n        .map((item) => {\n          return item.init(values[item.name]);\n        }),\n    )\n      .pipe(\n        tap(() => this.items.forEach((item) => {\n          item.initCallback(item, this.filter);\n        })),\n      );\n  }\n\n  private _addItems(items: IFilterConfigItem[]) {\n    this._add$.next();\n\n    this._items = new Map(\n      items      \n        .filter((item) => {\n          if (this._items.has(item.name)) {\n            throw Error('Filter init error. Items name must be unique.');\n          }\n\n          return true;\n        })\n        .map((item) => {\n          const filterItem = createFilterItem(item, { }, this.filter);\n\n          if (filterItem.type === ItemType.Keyword) {\n            this._keywordController.keywordItem = filterItem;\n          }\n\n          this._items.set(item.name, filterItem);\n\n          return [item.name, filterItem];\n        }),\n    );\n  }\n\n  private _initChanges() {\n    merge(\n      ...this.items\n        .map((item) => item.valueEvent$\n          .pipe(\n            filter((event) => event.emitChange),\n            map(() => item),\n          )),\n    )\n      .pipe(\n        tap((item) => this._change$.next([item])),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._change$\n      .pipe(\n        tap((items: BaseItem<IFilterConfigItem>[]) => {\n          if (this._config.change) {\n            this._config.change(this.query, this._sortController.getSort());\n          }\n\n          items?.forEach((item) => {\n            if (item.changeCallback) {\n              item.changeCallback(item, this.filter);\n            }\n          });\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { DestroyRef, inject, Injectable } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, distinctUntilChanged,
|
|
2
|
+
import { BehaviorSubject, distinctUntilChanged, switchMap } from 'rxjs';
|
|
3
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class KeywordController {
|
|
@@ -12,12 +12,12 @@ export class KeywordController {
|
|
|
12
12
|
this._keywordItem$
|
|
13
13
|
.pipe(
|
|
14
14
|
// when item changes, unsubscribe from the previous visible$
|
|
15
|
-
switchMap((item) => item
|
|
15
|
+
switchMap((item) => item.visible$),
|
|
16
16
|
// avoid redundant writes
|
|
17
17
|
distinctUntilChanged(),
|
|
18
18
|
// clean up on destroy,
|
|
19
19
|
takeUntilDestroyed(this._destroyRef))
|
|
20
|
-
.subscribe((
|
|
20
|
+
.subscribe((visible) => this._keywordVisible$.next(visible));
|
|
21
21
|
}
|
|
22
22
|
get keywordItem$() {
|
|
23
23
|
return this._keywordItem$.asObservable();
|
|
@@ -46,4 +46,4 @@ export class KeywordController {
|
|
|
46
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KeywordController, decorators: [{
|
|
47
47
|
type: Injectable
|
|
48
48
|
}] });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5d29yZC1jb250cm9sbGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL3NlcnZpY2VzL2tleXdvcmQtY29udHJvbGxlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLG9CQUFvQixFQUFjLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVwRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFRaEUsTUFBTSxPQUFPLGlCQUFpQjtJQUVwQixhQUFhLEdBQUcsSUFBSSxlQUFlLENBQVcsSUFBSSxDQUFDLENBQUM7SUFDcEQsZ0JBQWdCLEdBQUcsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDOUMsV0FBVyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNqQyxpQkFBaUIsQ0FBbUI7SUFFckMsSUFBSSxDQUFDLGdCQUFrQztRQUM1QyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsZ0JBQWdCLENBQUM7UUFDMUMsSUFBSSxDQUFDLGFBQWE7YUFDZixJQUFJO1FBQ0gsNERBQTREO1FBQzVELFNBQVMsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUNsQyx5QkFBeUI7UUFDekIsb0JBQW9CLEVBQUU7UUFDdEIsdUJBQXVCO1FBQ3ZCLGtCQUFrQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FDckM7YUFDQSxTQUFTLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRUQsSUFBVyxZQUFZO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUMzQyxDQUFDO0lBRUQsSUFBVyxXQUFXO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUM7SUFDbEMsQ0FBQztJQUVELElBQVcsV0FBVyxDQUFDLElBQWM7UUFDbkMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVNLEtBQUs7UUFDVixJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssR0FBRyxFQUFFLENBQUM7SUFDOUIsQ0FBQztJQUVNLElBQUk7UUFDVCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFTSxJQUFJO1FBQ1QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFBVyxlQUFlO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzlDLENBQUM7d0dBL0NVLGlCQUFpQjs0R0FBakIsaUJBQWlCOzs0RkFBakIsaUJBQWlCO2tCQUQ3QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgaW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgZGlzdGluY3RVbnRpbENoYW5nZWQsIE9ic2VydmFibGUsIHN3aXRjaE1hcCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyB0YWtlVW50aWxEZXN0cm95ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5cbmltcG9ydCB7IFRleHRJdGVtIH0gZnJvbSAnLi4vbW9kZWxzL2l0ZW1zL3RleHQtaXRlbSc7XG5cbmltcG9ydCB7IEZpbHRlckNvbnRyb2xsZXIgfSBmcm9tICcuL2ZpbHRlci1jb250cm9sbGVyLnNlcnZpY2UnO1xuXG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBLZXl3b3JkQ29udHJvbGxlciB7XG5cbiAgcHJpdmF0ZSBfa2V5d29yZEl0ZW0kID0gbmV3IEJlaGF2aW9yU3ViamVjdDxUZXh0SXRlbT4obnVsbCk7XG4gIHByaXZhdGUgX2tleXdvcmRWaXNpYmxlJCA9IG5ldyBCZWhhdmlvclN1YmplY3QoZmFsc2UpO1xuICBwcml2YXRlIF9kZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpO1xuICBwcml2YXRlIF9maWx0ZXJDb250cm9sbGVyOiBGaWx0ZXJDb250cm9sbGVyO1xuXG4gIHB1YmxpYyBpbml0KGZpbHRlckNvbnRyb2xsZXI6IEZpbHRlckNvbnRyb2xsZXIpIHtcbiAgICB0aGlzLl9maWx0ZXJDb250cm9sbGVyID0gZmlsdGVyQ29udHJvbGxlcjtcbiAgICB0aGlzLl9rZXl3b3JkSXRlbSRcbiAgICAgIC5waXBlKFxuICAgICAgICAvLyB3aGVuIGl0ZW0gY2hhbmdlcywgdW5zdWJzY3JpYmUgZnJvbSB0aGUgcHJldmlvdXMgdmlzaWJsZSRcbiAgICAgICAgc3dpdGNoTWFwKChpdGVtKSA9PiBpdGVtLnZpc2libGUkKSxcbiAgICAgICAgLy8gYXZvaWQgcmVkdW5kYW50IHdyaXRlc1xuICAgICAgICBkaXN0aW5jdFVudGlsQ2hhbmdlZCgpLFxuICAgICAgICAvLyBjbGVhbiB1cCBvbiBkZXN0cm95LFxuICAgICAgICB0YWtlVW50aWxEZXN0cm95ZWQodGhpcy5fZGVzdHJveVJlZiksXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKCh2aXNpYmxlKSA9PiB0aGlzLl9rZXl3b3JkVmlzaWJsZSQubmV4dCh2aXNpYmxlKSk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGtleXdvcmRJdGVtJCgpOiBPYnNlcnZhYmxlPFRleHRJdGVtPiB7XG4gICAgcmV0dXJuIHRoaXMuX2tleXdvcmRJdGVtJC5hc09ic2VydmFibGUoKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQga2V5d29yZEl0ZW0oKTogVGV4dEl0ZW0ge1xuICAgIHJldHVybiB0aGlzLl9rZXl3b3JkSXRlbSQudmFsdWU7XG4gIH1cblxuICBwdWJsaWMgc2V0IGtleXdvcmRJdGVtKGl0ZW06IFRleHRJdGVtKSB7XG4gICAgdGhpcy5fa2V5d29yZEl0ZW0kLm5leHQoaXRlbSk7XG4gIH1cblxuICBwdWJsaWMgY2xlYXIoKSB7XG4gICAgdGhpcy5rZXl3b3JkSXRlbS52YWx1ZSA9ICcnO1xuICB9XG5cbiAgcHVibGljIHNob3coKSB7XG4gICAgdGhpcy5rZXl3b3JkSXRlbS5zaG93KCk7XG4gIH1cblxuICBwdWJsaWMgaGlkZSgpIHtcbiAgICB0aGlzLmtleXdvcmRJdGVtLmhpZGUoKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQga2V5d29yZFZpc2libGUkKCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgIHJldHVybiB0aGlzLl9rZXl3b3JkVmlzaWJsZSQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxufVxuXG4iXX0=
|
|
@@ -784,9 +784,7 @@ class BaseItem {
|
|
|
784
784
|
this.loadDefault(),
|
|
785
785
|
this.loadValues(),
|
|
786
786
|
])
|
|
787
|
-
.pipe(tap(() =>
|
|
788
|
-
this.initValue(value);
|
|
789
|
-
}));
|
|
787
|
+
.pipe(tap(() => this.initValue(value)));
|
|
790
788
|
}
|
|
791
789
|
loadDefault() {
|
|
792
790
|
return this.defaultValueFn()
|
|
@@ -1047,7 +1045,7 @@ class ChipsItem extends BaseItem {
|
|
|
1047
1045
|
};
|
|
1048
1046
|
}
|
|
1049
1047
|
get query() {
|
|
1050
|
-
if (!this.
|
|
1048
|
+
if (!this.hasValue) {
|
|
1051
1049
|
return {};
|
|
1052
1050
|
}
|
|
1053
1051
|
return {
|
|
@@ -1057,17 +1055,19 @@ class ChipsItem extends BaseItem {
|
|
|
1057
1055
|
};
|
|
1058
1056
|
}
|
|
1059
1057
|
get chips() {
|
|
1060
|
-
|
|
1061
|
-
|
|
1062
|
-
|
|
1063
|
-
|
|
1064
|
-
|
|
1065
|
-
|
|
1066
|
-
|
|
1067
|
-
|
|
1058
|
+
if (!this.hasValue) {
|
|
1059
|
+
return [];
|
|
1060
|
+
}
|
|
1061
|
+
const chips = this.value
|
|
1062
|
+
.reduce((acc, i) => {
|
|
1063
|
+
acc.push((`${i.name}`).trim());
|
|
1064
|
+
return acc;
|
|
1065
|
+
}, [])
|
|
1066
|
+
.join(', ');
|
|
1067
|
+
return [{
|
|
1068
|
+
value: chips,
|
|
1068
1069
|
label: this.label,
|
|
1069
|
-
}
|
|
1070
|
-
] : [];
|
|
1070
|
+
}];
|
|
1071
1071
|
}
|
|
1072
1072
|
setValue(value, emitChange = true) {
|
|
1073
1073
|
super.setValue(Array.isArray(value) ? value : [], emitChange);
|
|
@@ -1560,12 +1560,12 @@ class KeywordController {
|
|
|
1560
1560
|
this._keywordItem$
|
|
1561
1561
|
.pipe(
|
|
1562
1562
|
// when item changes, unsubscribe from the previous visible$
|
|
1563
|
-
switchMap$1((item) => item
|
|
1563
|
+
switchMap$1((item) => item.visible$),
|
|
1564
1564
|
// avoid redundant writes
|
|
1565
1565
|
distinctUntilChanged$1(),
|
|
1566
1566
|
// clean up on destroy,
|
|
1567
1567
|
takeUntilDestroyed(this._destroyRef))
|
|
1568
|
-
.subscribe((
|
|
1568
|
+
.subscribe((visible) => this._keywordVisible$.next(visible));
|
|
1569
1569
|
}
|
|
1570
1570
|
get keywordItem$() {
|
|
1571
1571
|
return this._keywordItem$.asObservable();
|
|
@@ -2061,7 +2061,10 @@ class FilterController {
|
|
|
2061
2061
|
return forkJoin(this.items
|
|
2062
2062
|
.map((item) => {
|
|
2063
2063
|
return item.init(values[item.name]);
|
|
2064
|
-
}))
|
|
2064
|
+
}))
|
|
2065
|
+
.pipe(tap(() => this.items.forEach((item) => {
|
|
2066
|
+
item.initCallback(item, this.filter);
|
|
2067
|
+
})));
|
|
2065
2068
|
}
|
|
2066
2069
|
_addItems(items) {
|
|
2067
2070
|
this._add$.next();
|
|
@@ -3045,7 +3048,7 @@ class FilterComponent {
|
|
|
3045
3048
|
windowDesktop = false;
|
|
3046
3049
|
fsFilterClass = true;
|
|
3047
3050
|
_config;
|
|
3048
|
-
|
|
3051
|
+
_filtersVisible$ = new BehaviorSubject(true);
|
|
3049
3052
|
_hasFilterChips$ = new BehaviorSubject(false);
|
|
3050
3053
|
_destroy$ = new Subject();
|
|
3051
3054
|
_defaultConfig = inject(FS_FILTER_CONFIG, { optional: true });
|
|
@@ -3137,18 +3140,19 @@ class FilterComponent {
|
|
|
3137
3140
|
change() {
|
|
3138
3141
|
this._filterController.change();
|
|
3139
3142
|
}
|
|
3140
|
-
get visibleItems() {
|
|
3141
|
-
return this._filterController.items
|
|
3142
|
-
.filter((item) => !item.hidden);
|
|
3143
|
-
}
|
|
3144
3143
|
get hasFilterChips$() {
|
|
3145
3144
|
return this._hasFilterChips$.asObservable();
|
|
3146
3145
|
}
|
|
3147
|
-
get
|
|
3148
|
-
return
|
|
3149
|
-
|
|
3150
|
-
|
|
3151
|
-
|
|
3146
|
+
get filtersVisible$() {
|
|
3147
|
+
return combineLatest({
|
|
3148
|
+
filtersVisible: this._filtersVisible$.asObservable(),
|
|
3149
|
+
hasVisibleItems: of(this.items
|
|
3150
|
+
.filter((item) => !item.hidden && !item.isTypeKeyword)
|
|
3151
|
+
.length > 0),
|
|
3152
|
+
})
|
|
3153
|
+
.pipe(map(({ filtersVisible, hasVisibleItems }) => {
|
|
3154
|
+
return filtersVisible && hasVisibleItems;
|
|
3155
|
+
}));
|
|
3152
3156
|
}
|
|
3153
3157
|
get keywordVisible$() {
|
|
3154
3158
|
return this._keywordController.keywordVisible$;
|
|
@@ -3205,9 +3209,6 @@ class FilterComponent {
|
|
|
3205
3209
|
this._destroyFilterDrawer();
|
|
3206
3210
|
}
|
|
3207
3211
|
showDrawer() {
|
|
3208
|
-
if (!this.hasVisibleItemOrSorting) {
|
|
3209
|
-
return;
|
|
3210
|
-
}
|
|
3211
3212
|
this._listenEscButton();
|
|
3212
3213
|
this.opened.emit();
|
|
3213
3214
|
this._filterOverlay.open();
|
|
@@ -3309,26 +3310,26 @@ class FilterComponent {
|
|
|
3309
3310
|
/**
|
|
3310
3311
|
* Show "Filters" button
|
|
3311
3312
|
*/
|
|
3312
|
-
|
|
3313
|
-
this.
|
|
3313
|
+
showFilters() {
|
|
3314
|
+
this._filtersVisible$.next(true);
|
|
3314
3315
|
}
|
|
3315
3316
|
/**
|
|
3316
3317
|
* Hide "Filters" button
|
|
3317
3318
|
*/
|
|
3318
|
-
|
|
3319
|
-
this.
|
|
3319
|
+
hideFilters() {
|
|
3320
|
+
this._filtersVisible$.next(false);
|
|
3320
3321
|
}
|
|
3321
3322
|
/**
|
|
3322
3323
|
* Show "Keyword" field if it present
|
|
3323
3324
|
*/
|
|
3324
3325
|
showKeywordField() {
|
|
3325
|
-
this.
|
|
3326
|
+
this._keywordController.show();
|
|
3326
3327
|
}
|
|
3327
3328
|
/**
|
|
3328
3329
|
* Hide "Keyword" field if it present
|
|
3329
3330
|
*/
|
|
3330
3331
|
hideKeywordField() {
|
|
3331
|
-
this.
|
|
3332
|
+
this._keywordController.hide();
|
|
3332
3333
|
}
|
|
3333
3334
|
/**
|
|
3334
3335
|
* Go through actions and check show() callback and update visible actions
|
|
@@ -3412,7 +3413,7 @@ class FilterComponent {
|
|
|
3412
3413
|
ActionsController,
|
|
3413
3414
|
KeywordController,
|
|
3414
3415
|
SortController,
|
|
3415
|
-
], 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 || (
|
|
3416
|
+
], 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 || (filtersVisible$ | async)) {\n <div class=\"filter-toolbar\">\n @if ((filtersVisible$ | async)) {\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 <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 #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;margin:3px 0}.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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: FsFormModule }, { kind: "directive", type: i3.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 });
|
|
3416
3417
|
}
|
|
3417
3418
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterComponent, decorators: [{
|
|
3418
3419
|
type: Component,
|
|
@@ -3440,7 +3441,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
3440
3441
|
MatSlideToggle,
|
|
3441
3442
|
AsyncPipe,
|
|
3442
3443
|
KeywordInputComponent,
|
|
3443
|
-
], 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 || (
|
|
3444
|
+
], 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 || (filtersVisible$ | async)) {\n <div class=\"filter-toolbar\">\n @if ((filtersVisible$ | async)) {\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 <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 #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;margin:3px 0}.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"] }]
|
|
3444
3445
|
}], ctorParameters: () => [], propDecorators: { keywordInput: [{
|
|
3445
3446
|
type: ViewChild,
|
|
3446
3447
|
args: [KeywordInputComponent]
|