@firestitch/filter 13.0.1 → 13.0.3
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/helpers/build-query-params.d.ts +1 -1
- package/app/helpers/create-filter-item.d.ts +1 -1
- package/app/models/items/base-item.d.ts +1 -0
- package/app/services/external-params/query-params-controller.service.d.ts +2 -1
- package/esm2020/app/helpers/build-query-params.mjs +4 -3
- package/esm2020/app/models/items/base-item.mjs +7 -9
- package/esm2020/app/services/external-params/query-params-controller.service.mjs +14 -19
- package/fesm2015/firestitch-filter.mjs +29 -35
- package/fesm2015/firestitch-filter.mjs.map +1 -1
- package/fesm2020/firestitch-filter.mjs +29 -35
- package/fesm2020/firestitch-filter.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { BaseItem } from '../models/items/base-item';
|
|
2
1
|
import { IFilterConfigItem } from '../interfaces/config.interface';
|
|
2
|
+
import { BaseItem } from '../models/items/base-item';
|
|
3
3
|
export declare function buildQueryParams(flattenedParams: Record<string, unknown>, items: BaseItem<IFilterConfigItem>[]): Record<string, unknown>;
|
|
@@ -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): RangeItem | DateRangeItem | DateTimeRangeItem | WeekItem | AutocompleteChipsItem | AutocompleteItem | CheckboxItem | ChipsItem | DateItem | DateTimeItem | import("../models/items/select/
|
|
14
|
+
export declare function createFilterItem(item: IFilterConfigItem, config: any, filter: FilterComponent): RangeItem | DateRangeItem | DateTimeRangeItem | WeekItem | AutocompleteChipsItem | AutocompleteItem | CheckboxItem | ChipsItem | DateItem | DateTimeItem | import("../models/items/select/multiple-select-item").MultipleSelectItem | import("../models/items/select/simple-select-item").SimpleSelectItem | TextItem;
|
|
@@ -22,6 +22,7 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
22
22
|
protected _model: any;
|
|
23
23
|
protected _pendingValues: boolean;
|
|
24
24
|
protected _pendingDefaultValue: boolean;
|
|
25
|
+
protected _initializedValues: boolean;
|
|
25
26
|
protected _loading$: BehaviorSubject<boolean>;
|
|
26
27
|
protected _value$: BehaviorSubject<any>;
|
|
27
28
|
protected _valueChange$: Subject<void>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ActivatedRoute, Router } from '@angular/router';
|
|
2
|
-
import { FsFilterItemsStore } from '../items-store.service';
|
|
3
2
|
import { Location } from '@angular/common';
|
|
3
|
+
import { FsFilterItemsStore } from '../items-store.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class QueryParamsController {
|
|
6
6
|
private _router;
|
|
@@ -19,6 +19,7 @@ export declare class QueryParamsController {
|
|
|
19
19
|
* Parse query and update filter values
|
|
20
20
|
*/
|
|
21
21
|
fetchFromQueryParams(): void;
|
|
22
|
+
private _replaceState;
|
|
22
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<QueryParamsController, never>;
|
|
23
24
|
static ɵprov: i0.ɵɵInjectableDeclaration<QueryParamsController>;
|
|
24
25
|
}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { list as arrayList } from '@firestitch/common';
|
|
2
2
|
import { isObject } from 'lodash-es';
|
|
3
|
-
import { filterToQueryParam } from './query-param-transformers';
|
|
4
3
|
import { MultipleSelectItem } from '../models/items/select/multiple-select-item';
|
|
5
4
|
import { arraysAreEquals } from './compare';
|
|
5
|
+
import { filterToQueryParam } from './query-param-transformers';
|
|
6
6
|
export function buildQueryParams(flattenedParams, items) {
|
|
7
|
-
items
|
|
7
|
+
items
|
|
8
|
+
.forEach((filterItem) => {
|
|
8
9
|
if (filterItem instanceof MultipleSelectItem && filterItem.isolate) {
|
|
9
10
|
if (filterItem.multiple && filterItem.value) {
|
|
10
11
|
const isolated = arrayList(filterItem.values, 'value').sort();
|
|
@@ -29,4 +30,4 @@ export function buildQueryParams(flattenedParams, items) {
|
|
|
29
30
|
});
|
|
30
31
|
return flattenedParams;
|
|
31
32
|
}
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtcXVlcnktcGFyYW1zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwcC9oZWxwZXJzL2J1aWxkLXF1ZXJ5LXBhcmFtcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxJQUFJLFNBQVMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXZELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFJckMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDakYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUM1QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUdoRSxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsZUFBd0MsRUFBRSxLQUFvQztJQUM3RyxLQUFLO1NBQ0gsT0FBTyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUU7UUFDdkIsSUFBSSxVQUFVLFlBQVksa0JBQWtCLElBQUksVUFBVSxDQUFDLE9BQU8sRUFBRTtZQUNsRSxJQUFJLFVBQVUsQ0FBQyxRQUFRLElBQUksVUFBVSxDQUFDLEtBQUssRUFBRTtnQkFDM0MsTUFBTSxRQUFRLEdBQUcsU0FBUyxDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQzlELE1BQU0sS0FBSyxHQUFHLFVBQVUsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBRXRDLElBQUksZUFBZSxDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsRUFBRTtvQkFDcEMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUM7aUJBQ3pDO2FBQ0Y7U0FDRjtRQUVELElBQUksVUFBVSxDQUFDLGtCQUFrQixFQUFFO1lBQ2pDLElBQUksUUFBUSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDOUIsZUFBZSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEtBQUssRUFBRSxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ3RHO1NBQ0Y7YUFBTSxJQUFJLFVBQVUsQ0FBQyx1QkFBdUIsSUFBSSxVQUFVLENBQUMsV0FBVyxFQUFFO1lBQ3ZFLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksVUFBVSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7Z0JBQzlELGVBQWUsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtvQkFDL0QsT0FBTyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDbkQsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2FBQ2Q7U0FDRjtJQUNILENBQUMsQ0FBQyxDQUFDO0lBRUgsT0FBTyxlQUFlLENBQUM7QUFDekIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGxpc3QgYXMgYXJyYXlMaXN0IH0gZnJvbSAnQGZpcmVzdGl0Y2gvY29tbW9uJztcblxuaW1wb3J0IHsgaXNPYmplY3QgfSBmcm9tICdsb2Rhc2gtZXMnO1xuXG5pbXBvcnQgeyBJRmlsdGVyQ29uZmlnSXRlbSB9IGZyb20gJy4uL2ludGVyZmFjZXMvY29uZmlnLmludGVyZmFjZSc7XG5pbXBvcnQgeyBCYXNlSXRlbSB9IGZyb20gJy4uL21vZGVscy9pdGVtcy9iYXNlLWl0ZW0nO1xuaW1wb3J0IHsgTXVsdGlwbGVTZWxlY3RJdGVtIH0gZnJvbSAnLi4vbW9kZWxzL2l0ZW1zL3NlbGVjdC9tdWx0aXBsZS1zZWxlY3QtaXRlbSc7XG5pbXBvcnQgeyBhcnJheXNBcmVFcXVhbHMgfSBmcm9tICcuL2NvbXBhcmUnO1xuaW1wb3J0IHsgZmlsdGVyVG9RdWVyeVBhcmFtIH0gZnJvbSAnLi9xdWVyeS1wYXJhbS10cmFuc2Zvcm1lcnMnO1xuXG5cbmV4cG9ydCBmdW5jdGlvbiBidWlsZFF1ZXJ5UGFyYW1zKGZsYXR0ZW5lZFBhcmFtczogUmVjb3JkPHN0cmluZywgdW5rbm93bj4sIGl0ZW1zOiBCYXNlSXRlbTxJRmlsdGVyQ29uZmlnSXRlbT5bXSkge1xuICBpdGVtc1xuICAgLmZvckVhY2goKGZpbHRlckl0ZW0pID0+IHtcbiAgICBpZiAoZmlsdGVySXRlbSBpbnN0YW5jZW9mIE11bHRpcGxlU2VsZWN0SXRlbSAmJiBmaWx0ZXJJdGVtLmlzb2xhdGUpIHtcbiAgICAgIGlmIChmaWx0ZXJJdGVtLm11bHRpcGxlICYmIGZpbHRlckl0ZW0udmFsdWUpIHtcbiAgICAgICAgY29uc3QgaXNvbGF0ZWQgPSBhcnJheUxpc3QoZmlsdGVySXRlbS52YWx1ZXMsICd2YWx1ZScpLnNvcnQoKTtcbiAgICAgICAgY29uc3QgdmFsdWUgPSBmaWx0ZXJJdGVtLnZhbHVlLnNvcnQoKTtcblxuICAgICAgICBpZiAoYXJyYXlzQXJlRXF1YWxzKHZhbHVlLCBpc29sYXRlZCkpIHtcbiAgICAgICAgICBmbGF0dGVuZWRQYXJhbXNbZmlsdGVySXRlbS5uYW1lXSA9IG51bGw7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoZmlsdGVySXRlbS5pc1R5cGVBdXRvY29tcGxldGUpIHtcbiAgICAgIGlmIChpc09iamVjdChmaWx0ZXJJdGVtLm1vZGVsKSkge1xuICAgICAgICBmbGF0dGVuZWRQYXJhbXNbZmlsdGVySXRlbS5uYW1lXSA9IGZpbHRlclRvUXVlcnlQYXJhbShmaWx0ZXJJdGVtLm1vZGVsLnZhbHVlLCBmaWx0ZXJJdGVtLm1vZGVsLm5hbWUpO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAoZmlsdGVySXRlbS5pc1R5cGVBdXRvY29tcGxldGVDaGlwcyB8fCBmaWx0ZXJJdGVtLmlzVHlwZUNoaXBzKSB7XG4gICAgICBpZiAoQXJyYXkuaXNBcnJheShmaWx0ZXJJdGVtLm1vZGVsKSAmJiBmaWx0ZXJJdGVtLm1vZGVsLmxlbmd0aCkge1xuICAgICAgICBmbGF0dGVuZWRQYXJhbXNbZmlsdGVySXRlbS5uYW1lXSA9IGZpbHRlckl0ZW0ubW9kZWwubWFwKChpdGVtKSA9PiB7XG4gICAgICAgICAgcmV0dXJuIGZpbHRlclRvUXVlcnlQYXJhbShpdGVtLnZhbHVlLCBpdGVtLm5hbWUpO1xuICAgICAgICB9KS5qb2luKCcsJyk7XG4gICAgICB9XG4gICAgfVxuICB9KTtcblxuICByZXR1cm4gZmxhdHRlbmVkUGFyYW1zO1xufVxuIl19
|
|
@@ -8,6 +8,7 @@ export class BaseItem {
|
|
|
8
8
|
this._filter = _filter;
|
|
9
9
|
this._pendingValues = false;
|
|
10
10
|
this._pendingDefaultValue = false;
|
|
11
|
+
this._initializedValues = false;
|
|
11
12
|
this._loading$ = new BehaviorSubject(false);
|
|
12
13
|
this._value$ = new BehaviorSubject(null);
|
|
13
14
|
this._valueChange$ = new Subject();
|
|
@@ -20,7 +21,6 @@ export class BaseItem {
|
|
|
20
21
|
get filter() {
|
|
21
22
|
return this._filter;
|
|
22
23
|
}
|
|
23
|
-
///
|
|
24
24
|
get isTypeAutocomplete() {
|
|
25
25
|
return this.type === ItemType.AutoComplete;
|
|
26
26
|
}
|
|
@@ -54,7 +54,6 @@ export class BaseItem {
|
|
|
54
54
|
get isTypeKeyword() {
|
|
55
55
|
return this.type === ItemType.Keyword;
|
|
56
56
|
}
|
|
57
|
-
////
|
|
58
57
|
get isChipVisible() {
|
|
59
58
|
return !!this.model;
|
|
60
59
|
}
|
|
@@ -108,7 +107,7 @@ export class BaseItem {
|
|
|
108
107
|
this._loading$.next(value);
|
|
109
108
|
}
|
|
110
109
|
get _initialized() {
|
|
111
|
-
return !this._pendingDefaultValue && !this._pendingValues;
|
|
110
|
+
return !this._pendingDefaultValue && !this._pendingValues && this._initializedValues;
|
|
112
111
|
}
|
|
113
112
|
valueChanged() {
|
|
114
113
|
this._value$.next(this.value);
|
|
@@ -145,7 +144,7 @@ export class BaseItem {
|
|
|
145
144
|
}));
|
|
146
145
|
}
|
|
147
146
|
initValues(persistedValue) {
|
|
148
|
-
|
|
147
|
+
this._initializedValues = false;
|
|
149
148
|
this.persistedValue = persistedValue;
|
|
150
149
|
this._initDefaultModel();
|
|
151
150
|
const isAutocomplete = this.type === ItemType.AutoComplete || this.type === ItemType.AutoCompleteChips;
|
|
@@ -156,14 +155,13 @@ export class BaseItem {
|
|
|
156
155
|
}
|
|
157
156
|
else {
|
|
158
157
|
this.values = valuesResult;
|
|
159
|
-
// Move to some other place
|
|
160
158
|
this._init();
|
|
161
|
-
|
|
159
|
+
this._initializedValues = true;
|
|
162
160
|
}
|
|
163
161
|
}
|
|
164
162
|
else {
|
|
165
163
|
this._init();
|
|
166
|
-
|
|
164
|
+
this._initializedValues = true;
|
|
167
165
|
}
|
|
168
166
|
}
|
|
169
167
|
loadAsyncValues(reload = true) {
|
|
@@ -177,7 +175,7 @@ export class BaseItem {
|
|
|
177
175
|
this.loading = false;
|
|
178
176
|
this._init();
|
|
179
177
|
this._validateModel();
|
|
180
|
-
|
|
178
|
+
this._initializedValues = true;
|
|
181
179
|
});
|
|
182
180
|
}
|
|
183
181
|
}
|
|
@@ -236,4 +234,4 @@ export class BaseItem {
|
|
|
236
234
|
this.model = defaultValue ?? undefined;
|
|
237
235
|
}
|
|
238
236
|
}
|
|
239
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-item.js","sourceRoot":"","sources":["../../../../../src/app/models/items/base-item.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { BehaviorSubject, isObservable, Observable, Subject } from 'rxjs';\nimport {\n  finalize,\n  take,\n  takeUntil,\n  tap,\n} from 'rxjs/operators';\n\nimport { isFunction } from 'lodash-es';\n\nimport type { FilterComponent } from '../../components/filter/filter.component';\nimport { ItemType } from '../../enums/item-type.enum';\nimport { IFilterConfigItem } from '../../interfaces/config.interface';\nimport { IFilterDefaultFn } from '../../interfaces/items/base.interface';\nimport { IFilterItemDefaultRange } from '../../interfaces/items/range.interface';\n\n\nexport abstract class BaseItem<T extends IFilterConfigItem> {\n\n  public name: string;\n  public label: string | string[];\n  public chipLabel: string | string[];\n  public hide: boolean;\n  public defaultValue: any | IFilterItemDefaultRange;\n  public defaultValueFn: IFilterDefaultFn;\n  public persistedValue: unknown;\n  public showClear: boolean;\n  public persistanceDisabled: boolean;\n  public queryParamsDisabled: boolean;\n  public change: (item: BaseItem<T>, filter: FilterComponent) => void;\n  public init: (item: BaseItem<T>, filter?) => void;\n\n  protected readonly _type: T['type'];\n\n  protected _model: any;\n  protected _pendingValues = false;\n  protected _pendingDefaultValue = false;\n  protected _loading$ = new BehaviorSubject(false);\n  protected _value$ = new BehaviorSubject(null);\n  protected _valueChange$ = new Subject<void>();\n  protected _values$ = new BehaviorSubject(null);\n  protected _valuesFn: (keyword?: string, filter?: FilterComponent) => Observable<any> | any;\n\n  protected _destroy$ = new Subject<void>();\n\n  private _clear$ = new Subject<unknown>();\n\n  constructor(\n    itemConfig: T,\n    protected _additionalConfig: unknown,\n    protected _filter: FilterComponent,\n  ) {\n    this._type = itemConfig.type;\n    this._parseConfig(itemConfig);\n  }\n\n  public abstract get value();\n\n  public get filter(): FilterComponent {\n    return this._filter;\n  }\n\n  ///\n  public get isTypeAutocomplete() {\n    return this.type === ItemType.AutoComplete;\n  }\n\n  public get isTypeAutocompleteChips() {\n    return this.type === ItemType.AutoCompleteChips;\n  }\n\n  public get isTypeChips() {\n    return this.type === ItemType.Chips;\n  }\n\n  public get isTypeCheckbox() {\n    return this.type === ItemType.Checkbox;\n  }\n\n  public get isTypeSelect() {\n    return this.type === ItemType.Select;\n  }\n\n  public get isTypeDate() {\n    return this.type === ItemType.Date;\n  }\n\n  public get isTypeDateRange() {\n    return this.type === ItemType.DateRange;\n  }\n\n  public get isTypeRange() {\n    return this.type === ItemType.Range;\n  }\n\n  public get isTypeDateTimeRange() {\n    return this.type === ItemType.DateTimeRange;\n  }\n\n  public get isTypeDateTime() {\n    return this.type === ItemType.DateTime;\n  }\n\n  public get isTypeKeyword() {\n    return this.type === ItemType.Keyword;\n  }\n  ////\n\n  public get isChipVisible(): boolean {\n    return !!this.model;\n  }\n\n  public get destroy$() {\n    return this._destroy$.asObservable();\n  }\n\n  public get type(): T['type'] {\n    return this._type;\n  }\n\n  public get hasPendingValues(): boolean {\n    return this._pendingValues;\n  }\n\n  public get hasPendingDefaultValue(): boolean {\n    return this._pendingDefaultValue;\n  }\n\n  public get model() {\n    return this._model;\n  }\n\n  public set model(value) {\n    this._setModel(value);\n    this.valueChanged();\n  }\n\n  public set values(values) {\n    this._values$.next(values);\n  }\n\n  public get values() {\n    return this._values$.getValue();\n  }\n\n  public get values$(): Observable<unknown> {\n    return this._values$.asObservable();\n  }\n\n  public get valueChange$() {\n    return this._valueChange$.asObservable();\n  }\n\n  public get value$() {\n    return this._value$.asObservable();\n  }\n\n  public get clear$() {\n    return this._clear$.asObservable();\n  }\n\n  public get initialized() {\n    return this._initialized;\n  }\n\n  public get loading$(): Observable<boolean> {\n    return this._loading$.asObservable();\n  }\n\n  public get loading(): boolean {\n    return this._loading$.getValue();\n  }\n\n  public set loading(value: boolean) {\n    this._loading$.next(value);\n  }\n\n  protected get _initialized(): boolean {\n    return !this._pendingDefaultValue && !this._pendingValues;\n  }\n\n  public valueChanged() {\n    this._value$.next(this.value);\n\n    if (this.change) {\n      this.change(this, this._filter);\n    }\n\n    if (this.initialized) {\n      this._valueChange$.next();\n    }\n  }\n\n  public get queryObject(): Record<string, unknown> {\n    const value = this.value;\n    const name = this.name;\n    const params = {};\n\n    if (Array.isArray(value)) {\n      params[this.name] = value.join(',');\n    } else {\n      params[name] = value;\n    }\n\n    return params;\n  }\n\n  public get persistanceObject(): Record<string, unknown> {\n    return this.queryObject;\n  }\n\n  public loadDefaultValue(): Observable<any> {\n    this._pendingDefaultValue = true;\n\n    return this.defaultValueFn()\n      .pipe(\n        tap((value) => {\n          this.defaultValue = value;\n\n          this._initDefaultModel();\n        }),\n        finalize(() => {\n          this._pendingDefaultValue = false;\n        }),\n      );\n  }\n\n  public initValues(persistedValue: unknown) {\n    // this._initialized = false;\n    this.persistedValue = persistedValue;\n    this._initDefaultModel();\n\n    const isAutocomplete = this.type === ItemType.AutoComplete || this.type === ItemType.AutoCompleteChips;\n\n    if (this._valuesFn && !isAutocomplete) {\n      const valuesResult = this._valuesFn(null, this._filter);\n\n      if (isObservable(valuesResult)) {\n        this._pendingValues = true;\n      } else {\n        this.values = valuesResult;\n\n        // Move to some other place\n        this._init();\n        // this._initialized = true;\n      }\n\n    } else {\n      this._init();\n      // this._initialized = true;\n    }\n  }\n\n  public loadAsyncValues(reload = true) {\n    if (reload || (!this.loading && this.hasPendingValues)) {\n      this.loading = true;\n\n      (this._valuesFn(null, this._filter) as Observable<unknown>)\n        .pipe(\n          take(1),\n          takeUntil(this._destroy$),\n        )\n        .subscribe((values) => {\n          this.values = values;\n          this._pendingValues = false;\n          this.loading = false;\n          this._init();\n          this._validateModel();\n          // this._initialized = true;\n        });\n\n    }\n  }\n\n  public clear(defaultValue: unknown = undefined) {\n    if (this.isTypeRange || this.isTypeDateRange || this.isTypeDateTimeRange) {\n      console.warn(`\n        Filter ${this.name} can not be cleared with .clear() method!\n        Use special .clearRange() or clearDateRange() instead.\n      `);\n    }\n\n    this._clear$.next(defaultValue);\n    this._clearValue(defaultValue);\n  }\n\n  public getChipsContent(type): string {\n    return '';\n  }\n\n\n  public destroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  protected _setModel(value) {\n    this._model = value;\n  }\n\n  protected _parseConfig(item: T) {\n    this.name = item.name;\n    this.label = item.label;\n    this.chipLabel = item.chipLabel;\n\n    if (typeof item.default === 'function') {\n      this.defaultValueFn = item.default as IFilterDefaultFn;\n    } else {\n      this.defaultValue = item.default;\n    }\n\n    this.change = item.change;\n    this.init = item.init || ((_) => {\n      //\n    });\n    this.hide = item.hide;\n    this.showClear = item.clear ?? true;\n    this.persistanceDisabled = item.disablePersist ?? false;\n    this.queryParamsDisabled = item.disableQueryParams ?? false;\n\n    if (isFunction(item.values)) {\n      this._valuesFn = item.values;\n    } else {\n      this.values = item.values;\n    }\n  }\n\n  protected _initDefaultModel() {\n    const model = this.persistedValue ?? this.defaultValue;\n\n    if (model !== undefined) {\n      this._setModel(model);\n    }\n  }\n\n  protected _clearValue(defaultValue: unknown = undefined) {\n    this.model = defaultValue ?? undefined;\n  }\n\n  protected abstract _init();\n  protected abstract _validateModel();\n}\n"]}
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-item.js","sourceRoot":"","sources":["../../../../../src/app/models/items/base-item.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport { BehaviorSubject, isObservable, Observable, Subject } from 'rxjs';\nimport {\n  finalize,\n  take,\n  takeUntil,\n  tap,\n} from 'rxjs/operators';\n\nimport { isFunction } from 'lodash-es';\n\nimport type { FilterComponent } from '../../components/filter/filter.component';\nimport { ItemType } from '../../enums/item-type.enum';\nimport { IFilterConfigItem } from '../../interfaces/config.interface';\nimport { IFilterDefaultFn } from '../../interfaces/items/base.interface';\nimport { IFilterItemDefaultRange } from '../../interfaces/items/range.interface';\n\n\nexport abstract class BaseItem<T extends IFilterConfigItem> {\n\n  public name: string;\n  public label: string | string[];\n  public chipLabel: string | string[];\n  public hide: boolean;\n  public defaultValue: any | IFilterItemDefaultRange;\n  public defaultValueFn: IFilterDefaultFn;\n  public persistedValue: unknown;\n  public showClear: boolean;\n  public persistanceDisabled: boolean;\n  public queryParamsDisabled: boolean;\n  public change: (item: BaseItem<T>, filter: FilterComponent) => void;\n  public init: (item: BaseItem<T>, filter?) => void;\n\n  protected readonly _type: T['type'];\n\n  protected _model: any;\n  protected _pendingValues = false;\n  protected _pendingDefaultValue = false;\n  protected _initializedValues = false;\n  protected _loading$ = new BehaviorSubject(false);\n  protected _value$ = new BehaviorSubject(null);\n  protected _valueChange$ = new Subject<void>();\n  protected _values$ = new BehaviorSubject(null);\n  protected _valuesFn: (keyword?: string, filter?: FilterComponent) => Observable<any> | any;\n\n  protected _destroy$ = new Subject<void>();\n\n  private _clear$ = new Subject<unknown>();\n\n  constructor(\n    itemConfig: T,\n    protected _additionalConfig: unknown,\n    protected _filter: FilterComponent,\n  ) {\n    this._type = itemConfig.type;\n    this._parseConfig(itemConfig);\n  }\n\n  public abstract get value();\n\n  public get filter(): FilterComponent {\n    return this._filter;\n  }\n\n  public get isTypeAutocomplete() {\n    return this.type === ItemType.AutoComplete;\n  }\n\n  public get isTypeAutocompleteChips() {\n    return this.type === ItemType.AutoCompleteChips;\n  }\n\n  public get isTypeChips() {\n    return this.type === ItemType.Chips;\n  }\n\n  public get isTypeCheckbox() {\n    return this.type === ItemType.Checkbox;\n  }\n\n  public get isTypeSelect() {\n    return this.type === ItemType.Select;\n  }\n\n  public get isTypeDate() {\n    return this.type === ItemType.Date;\n  }\n\n  public get isTypeDateRange() {\n    return this.type === ItemType.DateRange;\n  }\n\n  public get isTypeRange() {\n    return this.type === ItemType.Range;\n  }\n\n  public get isTypeDateTimeRange() {\n    return this.type === ItemType.DateTimeRange;\n  }\n\n  public get isTypeDateTime() {\n    return this.type === ItemType.DateTime;\n  }\n\n  public get isTypeKeyword() {\n    return this.type === ItemType.Keyword;\n  }\n\n  public get isChipVisible(): boolean {\n    return !!this.model;\n  }\n\n  public get destroy$() {\n    return this._destroy$.asObservable();\n  }\n\n  public get type(): T['type'] {\n    return this._type;\n  }\n\n  public get hasPendingValues(): boolean {\n    return this._pendingValues;\n  }\n\n  public get hasPendingDefaultValue(): boolean {\n    return this._pendingDefaultValue;\n  }\n\n  public get model() {\n    return this._model;\n  }\n\n  public set model(value) {\n    this._setModel(value);\n    this.valueChanged();\n  }\n\n  public set values(values) {\n    this._values$.next(values);\n  }\n\n  public get values() {\n    return this._values$.getValue();\n  }\n\n  public get values$(): Observable<unknown> {\n    return this._values$.asObservable();\n  }\n\n  public get valueChange$() {\n    return this._valueChange$.asObservable();\n  }\n\n  public get value$() {\n    return this._value$.asObservable();\n  }\n\n  public get clear$() {\n    return this._clear$.asObservable();\n  }\n\n  public get initialized() {\n    return this._initialized;\n  }\n\n  public get loading$(): Observable<boolean> {\n    return this._loading$.asObservable();\n  }\n\n  public get loading(): boolean {\n    return this._loading$.getValue();\n  }\n\n  public set loading(value: boolean) {\n    this._loading$.next(value);\n  }\n\n  protected get _initialized(): boolean {\n    return !this._pendingDefaultValue && !this._pendingValues && this._initializedValues;\n  }\n\n  public valueChanged() {\n    this._value$.next(this.value);\n\n    if (this.change) {\n      this.change(this, this._filter);\n    }\n\n    if (this.initialized) {\n      this._valueChange$.next();\n    }\n  }\n\n  public get queryObject(): Record<string, unknown> {\n    const value = this.value;\n    const name = this.name;\n    const params = {};\n\n    if (Array.isArray(value)) {\n      params[this.name] = value.join(',');\n    } else {\n      params[name] = value;\n    }\n\n    return params;\n  }\n\n  public get persistanceObject(): Record<string, unknown> {\n    return this.queryObject;\n  }\n\n  public loadDefaultValue(): Observable<any> {\n    this._pendingDefaultValue = true;\n\n    return this.defaultValueFn()\n      .pipe(\n        tap((value) => {\n          this.defaultValue = value;\n\n          this._initDefaultModel();\n        }),\n        finalize(() => {\n          this._pendingDefaultValue = false;\n        }),\n      );\n  }\n\n  public initValues(persistedValue: unknown) {\n    this._initializedValues = false;\n    this.persistedValue = persistedValue;\n    this._initDefaultModel();\n\n    const isAutocomplete = this.type === ItemType.AutoComplete || this.type === ItemType.AutoCompleteChips;\n\n    if (this._valuesFn && !isAutocomplete) {\n      const valuesResult = this._valuesFn(null, this._filter);\n\n      if (isObservable(valuesResult)) {\n        this._pendingValues = true;\n      } else {\n        this.values = valuesResult;\n        this._init();\n        this._initializedValues = true;\n      }\n\n    } else {\n      this._init();\n      this._initializedValues = true;\n    }\n  }\n\n  public loadAsyncValues(reload = true) {\n    if (reload || (!this.loading && this.hasPendingValues)) {\n      this.loading = true;\n\n      (this._valuesFn(null, this._filter) as Observable<unknown>)\n        .pipe(\n          take(1),\n          takeUntil(this._destroy$),\n        )\n        .subscribe((values) => {\n          this.values = values;\n          this._pendingValues = false;\n          this.loading = false;\n          this._init();\n          this._validateModel();\n          this._initializedValues = true;\n        });\n\n    }\n  }\n\n  public clear(defaultValue: unknown = undefined) {\n    if (this.isTypeRange || this.isTypeDateRange || this.isTypeDateTimeRange) {\n      console.warn(`\n        Filter ${this.name} can not be cleared with .clear() method!\n        Use special .clearRange() or clearDateRange() instead.\n      `);\n    }\n\n    this._clear$.next(defaultValue);\n    this._clearValue(defaultValue);\n  }\n\n  public getChipsContent(type): string {\n    return '';\n  }\n\n\n  public destroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  protected _setModel(value) {\n    this._model = value;\n  }\n\n  protected _parseConfig(item: T) {\n    this.name = item.name;\n    this.label = item.label;\n    this.chipLabel = item.chipLabel;\n\n    if (typeof item.default === 'function') {\n      this.defaultValueFn = item.default as IFilterDefaultFn;\n    } else {\n      this.defaultValue = item.default;\n    }\n\n    this.change = item.change;\n    this.init = item.init || ((_) => {\n      //\n    });\n    this.hide = item.hide;\n    this.showClear = item.clear ?? true;\n    this.persistanceDisabled = item.disablePersist ?? false;\n    this.queryParamsDisabled = item.disableQueryParams ?? false;\n\n    if (isFunction(item.values)) {\n      this._valuesFn = item.values;\n    } else {\n      this.values = item.values;\n    }\n  }\n\n  protected _initDefaultModel() {\n    const model = this.persistedValue ?? this.defaultValue;\n\n    if (model !== undefined) {\n      this._setModel(model);\n    }\n  }\n\n  protected _clearValue(defaultValue: unknown = undefined) {\n    this.model = defaultValue ?? undefined;\n  }\n\n  protected abstract _init();\n  protected abstract _validateModel();\n}\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { ActivatedRoute, Router } from '@angular/router';
|
|
3
|
-
import { FsFilterItemsStore } from '../items-store.service';
|
|
4
|
-
import { restoreItems } from '../../helpers/restore-items';
|
|
5
3
|
import { Location } from '@angular/common';
|
|
4
|
+
import { restoreItems } from '../../helpers/restore-items';
|
|
5
|
+
import { FsFilterItemsStore } from '../items-store.service';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@angular/router";
|
|
8
8
|
import * as i2 from "@angular/common";
|
|
@@ -29,23 +29,9 @@ export class QueryParamsController {
|
|
|
29
29
|
}
|
|
30
30
|
}
|
|
31
31
|
writeStateToQueryParams(params) {
|
|
32
|
-
if (
|
|
33
|
-
|
|
32
|
+
if (this._enabled) {
|
|
33
|
+
this._replaceState(params);
|
|
34
34
|
}
|
|
35
|
-
this._location.replaceState(this._router.createUrlTree([], {
|
|
36
|
-
relativeTo: this._route,
|
|
37
|
-
queryParams: params,
|
|
38
|
-
queryParamsHandling: 'merge',
|
|
39
|
-
preserveFragment: true,
|
|
40
|
-
}).toString());
|
|
41
|
-
// Trying replacing the URL without triggering an Angular navigation change
|
|
42
|
-
// // Update query
|
|
43
|
-
// this._router.navigate([], {
|
|
44
|
-
// replaceUrl: true,
|
|
45
|
-
// relativeTo: this._route,
|
|
46
|
-
// queryParams: params,
|
|
47
|
-
// queryParamsHandling: 'merge',
|
|
48
|
-
// }).then(() => {});
|
|
49
35
|
}
|
|
50
36
|
/**
|
|
51
37
|
* Parse query and update filter values
|
|
@@ -58,10 +44,19 @@ export class QueryParamsController {
|
|
|
58
44
|
].filter((item) => !!item);
|
|
59
45
|
this._fetchedParams = restoreItems(this._route.snapshot.queryParams, items, this._paramsCase);
|
|
60
46
|
}
|
|
47
|
+
_replaceState(data) {
|
|
48
|
+
const url = new URL(window.location.href);
|
|
49
|
+
Object.keys(data)
|
|
50
|
+
.filter((name) => data[name] !== undefined && data[name] !== null)
|
|
51
|
+
.forEach((name) => {
|
|
52
|
+
url.searchParams.set(name, data[name]);
|
|
53
|
+
});
|
|
54
|
+
history.replaceState({}, null, url.search);
|
|
55
|
+
}
|
|
61
56
|
}
|
|
62
57
|
QueryParamsController.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: QueryParamsController, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.Location }, { token: i3.FsFilterItemsStore }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
63
58
|
QueryParamsController.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: QueryParamsController });
|
|
64
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: QueryParamsController, decorators: [{
|
|
65
60
|
type: Injectable
|
|
66
61
|
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.Location }, { type: i3.FsFilterItemsStore }]; } });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktcGFyYW1zLWNvbnRyb2xsZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvc2VydmljZXMvZXh0ZXJuYWwtcGFyYW1zL3F1ZXJ5LXBhcmFtcy1jb250cm9sbGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRXpELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0FBSTVELE1BQU0sT0FBTyxxQkFBcUI7SUFNaEMsWUFDVSxPQUFlLEVBQ2YsTUFBc0IsRUFDdEIsU0FBbUIsRUFDbkIsV0FBK0I7UUFIL0IsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQUNmLFdBQU0sR0FBTixNQUFNLENBQWdCO1FBQ3RCLGNBQVMsR0FBVCxTQUFTLENBQVU7UUFDbkIsZ0JBQVcsR0FBWCxXQUFXLENBQW9CO1FBUmpDLGFBQVEsR0FBRyxLQUFLLENBQUM7SUFTdEIsQ0FBQztJQUVKLElBQVcsT0FBTztRQUNoQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQVcsYUFBYTtRQUN0QixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDN0IsQ0FBQztJQUVNLElBQUksQ0FBQyxPQUFnQixFQUFFLFVBQTZCO1FBQ3pELElBQUksQ0FBQyxRQUFRLEdBQUcsT0FBTyxDQUFDO1FBQ3hCLElBQUksQ0FBQyxXQUFXLEdBQUcsVUFBVSxDQUFDO1FBRTlCLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNoQixJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztTQUM3QjtJQUNILENBQUM7SUFFTSx1QkFBdUIsQ0FBQyxNQUFNO1FBQ25DLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQzVCO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0ksb0JBQW9CO1FBQ3pCLE1BQU0sS0FBSyxHQUFHO1lBQ1osR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUs7WUFDekIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxVQUFVO1lBQzNCLElBQUksQ0FBQyxXQUFXLENBQUMsaUJBQWlCO1NBQ25DLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFM0IsSUFBSSxDQUFDLGNBQWMsR0FBRyxZQUFZLENBQ2hDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFDaEMsS0FBSyxFQUNMLElBQUksQ0FBQyxXQUFXLENBQ2pCLENBQUM7SUFDSixDQUFDO0lBRU8sYUFBYSxDQUFDLElBQUk7UUFDeEIsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUUxQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQzthQUNkLE1BQU0sQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLFNBQVMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDO2FBQ2pFLE9BQU8sQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ2hCLEdBQUcsQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLElBQUksRUFBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUN4QyxDQUFDLENBQUMsQ0FBQztRQUVMLE9BQU8sQ0FBQyxZQUFZLENBQUMsRUFBRSxFQUFFLElBQUksRUFBRSxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDN0MsQ0FBQzs7a0hBL0RVLHFCQUFxQjtzSEFBckIscUJBQXFCOzJGQUFyQixxQkFBcUI7a0JBRGpDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZSwgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcblxuaW1wb3J0IHsgTG9jYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgcmVzdG9yZUl0ZW1zIH0gZnJvbSAnLi4vLi4vaGVscGVycy9yZXN0b3JlLWl0ZW1zJztcbmltcG9ydCB7IEZzRmlsdGVySXRlbXNTdG9yZSB9IGZyb20gJy4uL2l0ZW1zLXN0b3JlLnNlcnZpY2UnO1xuXG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBRdWVyeVBhcmFtc0NvbnRyb2xsZXIge1xuXG4gIHByaXZhdGUgX2VuYWJsZWQgPSBmYWxzZTtcbiAgcHJpdmF0ZSBfcGFyYW1zQ2FzZTogJ3NuYWtlJyB8ICdjYW1lbCc7XG4gIHByaXZhdGUgX2ZldGNoZWRQYXJhbXM6IFJlY29yZDxzdHJpbmcsIGFueT47XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBfcm91dGVyOiBSb3V0ZXIsXG4gICAgcHJpdmF0ZSBfcm91dGU6IEFjdGl2YXRlZFJvdXRlLFxuICAgIHByaXZhdGUgX2xvY2F0aW9uOiBMb2NhdGlvbixcbiAgICBwcml2YXRlIF9pdGVtc1N0b3JlOiBGc0ZpbHRlckl0ZW1zU3RvcmVcbiAgKSB7fVxuXG4gIHB1YmxpYyBnZXQgZW5hYmxlZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fZW5hYmxlZDtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgZmV0Y2hlZFBhcmFtcygpIHtcbiAgICByZXR1cm4gdGhpcy5fZmV0Y2hlZFBhcmFtcztcbiAgfVxuXG4gIHB1YmxpYyBpbml0KGVuYWJsZWQ6IGJvb2xlYW4sIHBhcmFtc0Nhc2U6ICdzbmFrZScgfCAnY2FtZWwnKSB7XG4gICAgdGhpcy5fZW5hYmxlZCA9IGVuYWJsZWQ7XG4gICAgdGhpcy5fcGFyYW1zQ2FzZSA9IHBhcmFtc0Nhc2U7XG5cbiAgICBpZiAodGhpcy5lbmFibGVkKSB7XG4gICAgICB0aGlzLmZldGNoRnJvbVF1ZXJ5UGFyYW1zKCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHdyaXRlU3RhdGVUb1F1ZXJ5UGFyYW1zKHBhcmFtcykge1xuICAgIGlmICh0aGlzLl9lbmFibGVkKSB7IFxuICAgICAgdGhpcy5fcmVwbGFjZVN0YXRlKHBhcmFtcyk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFBhcnNlIHF1ZXJ5IGFuZCB1cGRhdGUgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcHVibGljIGZldGNoRnJvbVF1ZXJ5UGFyYW1zKCkge1xuICAgIGNvbnN0IGl0ZW1zID0gW1xuICAgICAgLi4udGhpcy5faXRlbXNTdG9yZS5pdGVtcyxcbiAgICAgIHRoaXMuX2l0ZW1zU3RvcmUuc29ydEJ5SXRlbSxcbiAgICAgIHRoaXMuX2l0ZW1zU3RvcmUuc29ydERpcmVjdGlvbkl0ZW0sXG4gICAgXS5maWx0ZXIoKGl0ZW0pID0+ICEhaXRlbSk7XG5cbiAgICB0aGlzLl9mZXRjaGVkUGFyYW1zID0gcmVzdG9yZUl0ZW1zKFxuICAgICAgdGhpcy5fcm91dGUuc25hcHNob3QucXVlcnlQYXJhbXMsXG4gICAgICBpdGVtcyxcbiAgICAgIHRoaXMuX3BhcmFtc0Nhc2VcbiAgICApO1xuICB9XG5cbiAgcHJpdmF0ZSBfcmVwbGFjZVN0YXRlKGRhdGEpIHtcbiAgICBjb25zdCB1cmwgPSBuZXcgVVJMKHdpbmRvdy5sb2NhdGlvbi5ocmVmKTtcblxuICAgIE9iamVjdC5rZXlzKGRhdGEpXG4gICAgICAuZmlsdGVyKChuYW1lKSA9PiBkYXRhW25hbWVdICE9PSB1bmRlZmluZWQgJiYgZGF0YVtuYW1lXSAhPT0gbnVsbClcbiAgICAgIC5mb3JFYWNoKChuYW1lKSA9PiB7XG4gICAgICAgIHVybC5zZWFyY2hQYXJhbXMuc2V0KG5hbWUsZGF0YVtuYW1lXSk7XG4gICAgICB9KTtcblxuICAgIGhpc3RvcnkucmVwbGFjZVN0YXRlKHt9LCBudWxsLCB1cmwuc2VhcmNoKTtcbiAgfVxufVxuIl19
|
|
@@ -59,16 +59,6 @@ import * as i1$6 from '@angular/cdk/overlay';
|
|
|
59
59
|
import { OverlayConfig } from '@angular/cdk/overlay';
|
|
60
60
|
import * as i1$7 from '@angular/cdk/layout';
|
|
61
61
|
|
|
62
|
-
const QUERY_PARAM_DELIMITER = ':';
|
|
63
|
-
|
|
64
|
-
function filterToQueryParam(value, name) {
|
|
65
|
-
return `${encodeURIComponent(value)}${QUERY_PARAM_DELIMITER}${encodeURIComponent(name)}`;
|
|
66
|
-
}
|
|
67
|
-
function filterFromQueryParam(param) {
|
|
68
|
-
const parts = param.split(QUERY_PARAM_DELIMITER);
|
|
69
|
-
return [decodeURIComponent(parts[0]), decodeURIComponent(parts[1])];
|
|
70
|
-
}
|
|
71
|
-
|
|
72
62
|
function objectsAreEquals(obj1, obj2) {
|
|
73
63
|
const oldKeys = Object.keys(obj1);
|
|
74
64
|
const currKeys = Object.keys(obj2);
|
|
@@ -129,6 +119,7 @@ class BaseItem {
|
|
|
129
119
|
this._filter = _filter;
|
|
130
120
|
this._pendingValues = false;
|
|
131
121
|
this._pendingDefaultValue = false;
|
|
122
|
+
this._initializedValues = false;
|
|
132
123
|
this._loading$ = new BehaviorSubject(false);
|
|
133
124
|
this._value$ = new BehaviorSubject(null);
|
|
134
125
|
this._valueChange$ = new Subject();
|
|
@@ -141,7 +132,6 @@ class BaseItem {
|
|
|
141
132
|
get filter() {
|
|
142
133
|
return this._filter;
|
|
143
134
|
}
|
|
144
|
-
///
|
|
145
135
|
get isTypeAutocomplete() {
|
|
146
136
|
return this.type === ItemType.AutoComplete;
|
|
147
137
|
}
|
|
@@ -175,7 +165,6 @@ class BaseItem {
|
|
|
175
165
|
get isTypeKeyword() {
|
|
176
166
|
return this.type === ItemType.Keyword;
|
|
177
167
|
}
|
|
178
|
-
////
|
|
179
168
|
get isChipVisible() {
|
|
180
169
|
return !!this.model;
|
|
181
170
|
}
|
|
@@ -229,7 +218,7 @@ class BaseItem {
|
|
|
229
218
|
this._loading$.next(value);
|
|
230
219
|
}
|
|
231
220
|
get _initialized() {
|
|
232
|
-
return !this._pendingDefaultValue && !this._pendingValues;
|
|
221
|
+
return !this._pendingDefaultValue && !this._pendingValues && this._initializedValues;
|
|
233
222
|
}
|
|
234
223
|
valueChanged() {
|
|
235
224
|
this._value$.next(this.value);
|
|
@@ -266,7 +255,7 @@ class BaseItem {
|
|
|
266
255
|
}));
|
|
267
256
|
}
|
|
268
257
|
initValues(persistedValue) {
|
|
269
|
-
|
|
258
|
+
this._initializedValues = false;
|
|
270
259
|
this.persistedValue = persistedValue;
|
|
271
260
|
this._initDefaultModel();
|
|
272
261
|
const isAutocomplete = this.type === ItemType.AutoComplete || this.type === ItemType.AutoCompleteChips;
|
|
@@ -277,14 +266,13 @@ class BaseItem {
|
|
|
277
266
|
}
|
|
278
267
|
else {
|
|
279
268
|
this.values = valuesResult;
|
|
280
|
-
// Move to some other place
|
|
281
269
|
this._init();
|
|
282
|
-
|
|
270
|
+
this._initializedValues = true;
|
|
283
271
|
}
|
|
284
272
|
}
|
|
285
273
|
else {
|
|
286
274
|
this._init();
|
|
287
|
-
|
|
275
|
+
this._initializedValues = true;
|
|
288
276
|
}
|
|
289
277
|
}
|
|
290
278
|
loadAsyncValues(reload = true) {
|
|
@@ -298,7 +286,7 @@ class BaseItem {
|
|
|
298
286
|
this.loading = false;
|
|
299
287
|
this._init();
|
|
300
288
|
this._validateModel();
|
|
301
|
-
|
|
289
|
+
this._initializedValues = true;
|
|
302
290
|
});
|
|
303
291
|
}
|
|
304
292
|
}
|
|
@@ -478,8 +466,19 @@ class MultipleSelectItem extends BaseSelectItem {
|
|
|
478
466
|
}
|
|
479
467
|
}
|
|
480
468
|
|
|
469
|
+
const QUERY_PARAM_DELIMITER = ':';
|
|
470
|
+
|
|
471
|
+
function filterToQueryParam(value, name) {
|
|
472
|
+
return `${encodeURIComponent(value)}${QUERY_PARAM_DELIMITER}${encodeURIComponent(name)}`;
|
|
473
|
+
}
|
|
474
|
+
function filterFromQueryParam(param) {
|
|
475
|
+
const parts = param.split(QUERY_PARAM_DELIMITER);
|
|
476
|
+
return [decodeURIComponent(parts[0]), decodeURIComponent(parts[1])];
|
|
477
|
+
}
|
|
478
|
+
|
|
481
479
|
function buildQueryParams(flattenedParams, items) {
|
|
482
|
-
items
|
|
480
|
+
items
|
|
481
|
+
.forEach((filterItem) => {
|
|
483
482
|
if (filterItem instanceof MultipleSelectItem && filterItem.isolate) {
|
|
484
483
|
if (filterItem.multiple && filterItem.value) {
|
|
485
484
|
const isolated = list(filterItem.values, 'value').sort();
|
|
@@ -1925,23 +1924,9 @@ class QueryParamsController {
|
|
|
1925
1924
|
}
|
|
1926
1925
|
}
|
|
1927
1926
|
writeStateToQueryParams(params) {
|
|
1928
|
-
if (
|
|
1929
|
-
|
|
1927
|
+
if (this._enabled) {
|
|
1928
|
+
this._replaceState(params);
|
|
1930
1929
|
}
|
|
1931
|
-
this._location.replaceState(this._router.createUrlTree([], {
|
|
1932
|
-
relativeTo: this._route,
|
|
1933
|
-
queryParams: params,
|
|
1934
|
-
queryParamsHandling: 'merge',
|
|
1935
|
-
preserveFragment: true,
|
|
1936
|
-
}).toString());
|
|
1937
|
-
// Trying replacing the URL without triggering an Angular navigation change
|
|
1938
|
-
// // Update query
|
|
1939
|
-
// this._router.navigate([], {
|
|
1940
|
-
// replaceUrl: true,
|
|
1941
|
-
// relativeTo: this._route,
|
|
1942
|
-
// queryParams: params,
|
|
1943
|
-
// queryParamsHandling: 'merge',
|
|
1944
|
-
// }).then(() => {});
|
|
1945
1930
|
}
|
|
1946
1931
|
/**
|
|
1947
1932
|
* Parse query and update filter values
|
|
@@ -1954,6 +1939,15 @@ class QueryParamsController {
|
|
|
1954
1939
|
].filter((item) => !!item);
|
|
1955
1940
|
this._fetchedParams = restoreItems(this._route.snapshot.queryParams, items, this._paramsCase);
|
|
1956
1941
|
}
|
|
1942
|
+
_replaceState(data) {
|
|
1943
|
+
const url = new URL(window.location.href);
|
|
1944
|
+
Object.keys(data)
|
|
1945
|
+
.filter((name) => data[name] !== undefined && data[name] !== null)
|
|
1946
|
+
.forEach((name) => {
|
|
1947
|
+
url.searchParams.set(name, data[name]);
|
|
1948
|
+
});
|
|
1949
|
+
history.replaceState({}, null, url.search);
|
|
1950
|
+
}
|
|
1957
1951
|
}
|
|
1958
1952
|
QueryParamsController.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: QueryParamsController, deps: [{ token: i1$1.Router }, { token: i1$1.ActivatedRoute }, { token: i3.Location }, { token: FsFilterItemsStore }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1959
1953
|
QueryParamsController.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: QueryParamsController });
|