@firestitch/filter 18.0.22 → 18.0.24
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/filters-item/date/date.component.d.ts +2 -2
- package/app/components/filters-item/filter-item.component.d.ts +13 -13
- package/app/helpers/create-filter-item.d.ts +1 -1
- package/app/models/items/autocomplete/base-autocomplete-item.d.ts +5 -2
- package/app/models/items/autocomplete-chips-item.d.ts +3 -1
- package/app/models/items/base-item.d.ts +1 -1
- package/app/models/items/checkbox-item.d.ts +5 -2
- package/app/models/items/chips-item.d.ts +3 -1
- package/app/models/items/date/base-date-item.d.ts +4 -1
- package/app/models/items/date-item.d.ts +1 -1
- package/app/models/items/date-range/base-date-range-item.d.ts +0 -1
- package/app/models/items/range-item.d.ts +3 -1
- package/app/models/items/select/base-select-item.d.ts +4 -1
- package/app/models/items/text-item.d.ts +3 -1
- package/app/models/items/week-item.d.ts +3 -1
- package/esm2022/app/components/filter-drawer/filter-drawer.component.mjs +2 -2
- package/esm2022/app/components/filter-drawer-actions/filter-drawer-actions.component.mjs +2 -2
- package/esm2022/app/components/filters-item/checkbox/checkbox.component.mjs +1 -1
- package/esm2022/app/components/filters-item/chips/chips.component.mjs +1 -1
- package/esm2022/app/components/filters-item/date/date.component.mjs +9 -10
- package/esm2022/app/components/filters-item/filter-item.component.mjs +1 -2
- package/esm2022/app/models/items/autocomplete/base-autocomplete-item.mjs +9 -5
- package/esm2022/app/models/items/autocomplete-chips-item.mjs +14 -10
- package/esm2022/app/models/items/base-item.mjs +4 -4
- package/esm2022/app/models/items/checkbox-item.mjs +12 -8
- package/esm2022/app/models/items/chips-item.mjs +10 -11
- package/esm2022/app/models/items/date/base-date-item.mjs +11 -6
- package/esm2022/app/models/items/date-item.mjs +2 -2
- package/esm2022/app/models/items/date-range/base-date-range-item.mjs +1 -4
- package/esm2022/app/models/items/range-item.mjs +11 -7
- package/esm2022/app/models/items/select/base-select-item.mjs +7 -3
- package/esm2022/app/models/items/text-item.mjs +11 -7
- package/esm2022/app/models/items/week-item.mjs +9 -5
- package/fesm2022/firestitch-filter.mjs +134 -105
- package/fesm2022/firestitch-filter.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { ChangeDetectorRef, KeyValueDiffers, OnInit } from '@angular/core';
|
|
2
2
|
import { ItemDateMode } from '../../../enums/item-date-mode.enum';
|
|
3
3
|
import { PickerViewType } from '../../../enums/picker-view-type.enum';
|
|
4
|
-
import { DateItem } from '../../../models/items/date-item';
|
|
5
|
-
import { DateTimeItem } from '../../../models/items/date-time-item';
|
|
4
|
+
import type { DateItem } from '../../../models/items/date-item';
|
|
5
|
+
import type { DateTimeItem } from '../../../models/items/date-time-item';
|
|
6
6
|
import { BaseItemComponent } from '../base-item/base-item.component';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare class DateComponent extends BaseItemComponent<DateItem | DateTimeItem> implements OnInit {
|
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { ItemType } from '../../enums/item-type.enum';
|
|
3
|
-
import { AutocompleteChipsItem } from '../../models/items/autocomplete-chips-item';
|
|
4
|
-
import { AutocompleteItem } from '../../models/items/autocomplete-item';
|
|
5
|
-
import { BaseItem } from '../../models/items/base-item';
|
|
6
|
-
import { CheckboxItem } from '../../models/items/checkbox-item';
|
|
7
|
-
import { ChipsItem } from '../../models/items/chips-item';
|
|
8
|
-
import { DateItem } from '../../models/items/date-item';
|
|
9
|
-
import { DateRangeItem } from '../../models/items/date-range-item';
|
|
10
|
-
import { DateTimeItem } from '../../models/items/date-time-item';
|
|
11
|
-
import { DateTimeRangeItem } from '../../models/items/date-time-range-item';
|
|
12
|
-
import { RangeItem } from '../../models/items/range-item';
|
|
13
|
-
import { BaseSelectItem } from '../../models/items/select/base-select-item';
|
|
14
|
-
import { TextItem } from '../../models/items/text-item';
|
|
15
|
-
import { WeekItem } from '../../models/items/week-item';
|
|
3
|
+
import type { AutocompleteChipsItem } from '../../models/items/autocomplete-chips-item';
|
|
4
|
+
import type { AutocompleteItem } from '../../models/items/autocomplete-item';
|
|
5
|
+
import type { BaseItem } from '../../models/items/base-item';
|
|
6
|
+
import type { CheckboxItem } from '../../models/items/checkbox-item';
|
|
7
|
+
import type { ChipsItem } from '../../models/items/chips-item';
|
|
8
|
+
import type { DateItem } from '../../models/items/date-item';
|
|
9
|
+
import type { DateRangeItem } from '../../models/items/date-range-item';
|
|
10
|
+
import type { DateTimeItem } from '../../models/items/date-time-item';
|
|
11
|
+
import type { DateTimeRangeItem } from '../../models/items/date-time-range-item';
|
|
12
|
+
import type { RangeItem } from '../../models/items/range-item';
|
|
13
|
+
import type { BaseSelectItem } from '../../models/items/select/base-select-item';
|
|
14
|
+
import type { TextItem } from '../../models/items/text-item';
|
|
15
|
+
import type { WeekItem } from '../../models/items/week-item';
|
|
16
16
|
import * as i0 from "@angular/core";
|
|
17
17
|
export declare class FilterItemComponent implements OnInit, OnDestroy {
|
|
18
18
|
private _cdRef;
|
|
@@ -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): TextItem |
|
|
14
|
+
export declare function createFilterItem(item: IFilterConfigItem, config: any, filter: FilterComponent): TextItem | ChipsItem | RangeItem | AutocompleteItem | AutocompleteChipsItem | DateItem | DateRangeItem | DateTimeItem | DateTimeRangeItem | WeekItem | CheckboxItem | import("../models/items/select/simple-select-item").SimpleSelectItem | import("../models/items/select/multiple-select-item").MultipleSelectItem;
|
|
@@ -1,12 +1,15 @@
|
|
|
1
|
+
import type { FilterComponent } from '../../../components/filter/filter.component';
|
|
1
2
|
import { IFilterConfigAutocompleteChipsItem } from '../../../interfaces/items/autocomplete-chips.interface';
|
|
2
3
|
import { IFilterConfigAutocompleteItem } from '../../../interfaces/items/autocomplete.interface';
|
|
3
4
|
import { BaseItem } from '../base-item';
|
|
4
5
|
type AutoCompleteItem = IFilterConfigAutocompleteItem | IFilterConfigAutocompleteChipsItem;
|
|
5
6
|
export declare abstract class BaseAutocompleteItem<T extends AutoCompleteItem> extends BaseItem<T> {
|
|
7
|
+
protected _additionalConfig: unknown;
|
|
8
|
+
protected _filter: FilterComponent;
|
|
6
9
|
search: string;
|
|
7
10
|
fetchOnFocus: boolean;
|
|
8
|
-
get valuesFn(): (keyword?: string, filter?:
|
|
11
|
+
get valuesFn(): (keyword?: string, filter?: FilterComponent) => any[] | import("rxjs").Observable<any>;
|
|
12
|
+
constructor(itemConfig: T, _additionalConfig: unknown, _filter: FilterComponent);
|
|
9
13
|
protected _validateModel(): void;
|
|
10
|
-
protected _parseConfig(item: T): void;
|
|
11
14
|
}
|
|
12
15
|
export {};
|
|
@@ -2,19 +2,21 @@ import type { FilterComponent } from '../../components/filter/filter.component';
|
|
|
2
2
|
import { IFilterConfigAutocompleteChipsItem } from '../../interfaces/items/autocomplete-chips.interface';
|
|
3
3
|
import { BaseAutocompleteItem } from './autocomplete/base-autocomplete-item';
|
|
4
4
|
export declare class AutocompleteChipsItem extends BaseAutocompleteItem<IFilterConfigAutocompleteChipsItem> {
|
|
5
|
+
protected _additionalConfig: unknown;
|
|
6
|
+
protected _filter: FilterComponent;
|
|
5
7
|
chipImage: string;
|
|
6
8
|
chipIcon: string;
|
|
7
9
|
chipColor: string;
|
|
8
10
|
chipIconColor: string;
|
|
9
11
|
chipBackground: string;
|
|
10
12
|
chipClass: string;
|
|
13
|
+
constructor(itemConfig: IFilterConfigAutocompleteChipsItem, _additionalConfig: unknown, _filter: FilterComponent);
|
|
11
14
|
static create(config: IFilterConfigAutocompleteChipsItem, filter: FilterComponent): AutocompleteChipsItem;
|
|
12
15
|
get value(): any;
|
|
13
16
|
get queryObject(): Record<string, unknown>;
|
|
14
17
|
get isChipVisible(): boolean;
|
|
15
18
|
getChipsContent(): any;
|
|
16
19
|
protected _init(): void;
|
|
17
|
-
protected _parseConfig(item: IFilterConfigAutocompleteChipsItem): void;
|
|
18
20
|
protected _clearValue(defaultValue?: unknown): void;
|
|
19
21
|
protected _setModel(value: any): void;
|
|
20
22
|
}
|
|
@@ -68,7 +68,7 @@ export declare abstract class BaseItem<T extends IFilterConfigItem> {
|
|
|
68
68
|
clear(defaultValue?: unknown): void;
|
|
69
69
|
destroy(): void;
|
|
70
70
|
protected _setModel(value: any): void;
|
|
71
|
-
|
|
71
|
+
private _initConfig;
|
|
72
72
|
protected _initDefaultModel(): void;
|
|
73
73
|
protected _clearValue(defaultValue?: unknown): void;
|
|
74
74
|
protected get _initialized(): boolean;
|
|
@@ -1,15 +1,18 @@
|
|
|
1
|
+
import type { FilterComponent } from '../../components/filter/filter.component';
|
|
1
2
|
import { IFilterConfigCheckboxItem } from '../../interfaces/items/checkbox.interface';
|
|
2
3
|
import { BaseItem } from './base-item';
|
|
3
4
|
export declare class CheckboxItem extends BaseItem<IFilterConfigCheckboxItem> {
|
|
5
|
+
protected _additionalConfig: unknown;
|
|
6
|
+
protected _filter: FilterComponent;
|
|
4
7
|
private _checked;
|
|
5
8
|
private _unchecked;
|
|
9
|
+
constructor(itemConfig: IFilterConfigCheckboxItem, _additionalConfig: unknown, _filter: FilterComponent);
|
|
6
10
|
get isTypeCheckbox(): boolean;
|
|
7
11
|
get isChipVisible(): boolean;
|
|
8
12
|
get value(): any;
|
|
9
13
|
get queryObject(): Record<string, unknown>;
|
|
10
|
-
getChipsContent(
|
|
14
|
+
getChipsContent(): string;
|
|
11
15
|
protected _validateModel(): void;
|
|
12
|
-
protected _parseConfig(item: IFilterConfigCheckboxItem): void;
|
|
13
16
|
protected _init(): void;
|
|
14
17
|
protected _clearValue(defaultValue?: unknown): void;
|
|
15
18
|
}
|
|
@@ -2,7 +2,10 @@ import type { FilterComponent } from '../../components/filter/filter.component';
|
|
|
2
2
|
import { IFilterConfigChipsItem } from '../../interfaces/items/chips.interface';
|
|
3
3
|
import { BaseItem } from './base-item';
|
|
4
4
|
export declare class ChipsItem extends BaseItem<IFilterConfigChipsItem> {
|
|
5
|
+
protected _additionalConfig: unknown;
|
|
6
|
+
protected _filter: FilterComponent;
|
|
5
7
|
multiple: boolean;
|
|
8
|
+
constructor(itemConfig: IFilterConfigChipsItem, _additionalConfig: unknown, _filter: FilterComponent);
|
|
6
9
|
static create(config: IFilterConfigChipsItem, filter: FilterComponent): ChipsItem;
|
|
7
10
|
get isTypeChips(): boolean;
|
|
8
11
|
get value(): any;
|
|
@@ -12,7 +15,6 @@ export declare class ChipsItem extends BaseItem<IFilterConfigChipsItem> {
|
|
|
12
15
|
getChipsContent(): any;
|
|
13
16
|
protected _validateModel(): void;
|
|
14
17
|
protected _setModel(value: any): void;
|
|
15
|
-
protected _parseConfig(item: IFilterConfigChipsItem): void;
|
|
16
18
|
protected _init(): void;
|
|
17
19
|
protected _clearValue(defaultValue?: unknown): void;
|
|
18
20
|
}
|
|
@@ -1,14 +1,17 @@
|
|
|
1
|
+
import { FilterComponent } from '../../../components/filter/filter.component';
|
|
1
2
|
import { ItemDateMode } from '../../../enums/item-date-mode.enum';
|
|
2
3
|
import { IFilterConfigDateItem } from '../../../interfaces/items/date.interface';
|
|
3
4
|
import { BaseItem } from '../base-item';
|
|
4
5
|
export declare abstract class BaseDateItem extends BaseItem<IFilterConfigDateItem> {
|
|
6
|
+
protected _additionalConfig: unknown;
|
|
7
|
+
protected _filter: FilterComponent;
|
|
5
8
|
maxYear: number;
|
|
6
9
|
mode: ItemDateMode;
|
|
10
|
+
constructor(itemConfig: any, _additionalConfig: unknown, _filter: FilterComponent);
|
|
7
11
|
get value(): Date;
|
|
8
12
|
get queryObject(): Record<string, Date>;
|
|
9
13
|
get persistanceObject(): Record<string, string>;
|
|
10
14
|
protected _validateModel(): void;
|
|
11
15
|
protected _setModel(value: any): void;
|
|
12
|
-
protected _parseConfig(item: IFilterConfigDateItem): void;
|
|
13
16
|
protected _init(): void;
|
|
14
17
|
}
|
|
@@ -3,6 +3,6 @@ import { IFilterConfigDateItem } from '../../interfaces/items/date.interface';
|
|
|
3
3
|
import { BaseDateItem } from './date/base-date-item';
|
|
4
4
|
export declare class DateItem extends BaseDateItem {
|
|
5
5
|
static create(config: IFilterConfigDateItem, filter: FilterComponent): DateItem;
|
|
6
|
-
getChipsContent(
|
|
6
|
+
getChipsContent(): string;
|
|
7
7
|
protected _clearValue(defaultValue?: unknown): void;
|
|
8
8
|
}
|
|
@@ -11,7 +11,6 @@ export declare abstract class BaseDateRangeItem extends BaseItem<IFilterConfigDa
|
|
|
11
11
|
clearDateRange(type?: 'from' | 'to', defaultValue?: IFilterItemDefaultDateRange): void;
|
|
12
12
|
protected _validateModel(): void;
|
|
13
13
|
protected _setModel(value: any): void;
|
|
14
|
-
protected _parseConfig(item: IFilterConfigDateRangeItem): void;
|
|
15
14
|
protected _init(): void;
|
|
16
15
|
protected _clearValue(defaultValue?: unknown): void;
|
|
17
16
|
}
|
|
@@ -2,11 +2,14 @@ import type { FilterComponent } from '../../components/filter/filter.component';
|
|
|
2
2
|
import { IFilterConfigRangeItem, IFilterItemDefaultRange } from '../../interfaces/items/range.interface';
|
|
3
3
|
import { BaseItem } from './base-item';
|
|
4
4
|
export declare class RangeItem extends BaseItem<IFilterConfigRangeItem> {
|
|
5
|
+
protected _additionalConfig: unknown;
|
|
6
|
+
protected _filter: FilterComponent;
|
|
5
7
|
options: {
|
|
6
8
|
scale?: number;
|
|
7
9
|
};
|
|
8
10
|
prefix: string;
|
|
9
11
|
suffix: string;
|
|
12
|
+
constructor(itemConfig: IFilterConfigRangeItem, _additionalConfig: unknown, _filter: FilterComponent);
|
|
10
13
|
static create(config: IFilterConfigRangeItem, additionalConfig: unknown, filter: FilterComponent): RangeItem;
|
|
11
14
|
get value(): any;
|
|
12
15
|
get queryObject(): {};
|
|
@@ -14,6 +17,5 @@ export declare class RangeItem extends BaseItem<IFilterConfigRangeItem> {
|
|
|
14
17
|
getChipsContent(type: any): string;
|
|
15
18
|
clearRange(type?: 'from' | 'to', defaultValue?: IFilterItemDefaultRange): void;
|
|
16
19
|
protected _validateModel(): void;
|
|
17
|
-
protected _parseConfig(item: IFilterConfigRangeItem): void;
|
|
18
20
|
protected _init(): void;
|
|
19
21
|
}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
|
+
import type { FilterComponent } from '../../../components/filter/filter.component';
|
|
1
2
|
import { IFilterConfigSelectIsolate, IFilterConfigSelectItem } from '../../../interfaces/items/select.interface';
|
|
2
3
|
import { BaseItem } from '../base-item';
|
|
3
4
|
export interface IFilterIsolate extends IFilterConfigSelectIsolate {
|
|
4
5
|
enabled: boolean;
|
|
5
6
|
}
|
|
6
7
|
export declare abstract class BaseSelectItem extends BaseItem<IFilterConfigSelectItem> {
|
|
8
|
+
protected _additionalConfig: unknown;
|
|
9
|
+
protected _filter: FilterComponent;
|
|
7
10
|
children: string;
|
|
8
11
|
multiple: boolean;
|
|
9
12
|
isolate: IFilterIsolate;
|
|
10
|
-
|
|
13
|
+
constructor(itemConfig: IFilterConfigSelectItem, _additionalConfig: unknown, _filter: FilterComponent);
|
|
11
14
|
protected _init(): void;
|
|
12
15
|
protected _clearValue(defaultValue?: unknown): void;
|
|
13
16
|
}
|
|
@@ -2,14 +2,16 @@ import type { FilterComponent } from '../../components/filter/filter.component';
|
|
|
2
2
|
import { IFilterConfigTextItem } from '../../interfaces/items/text.interface';
|
|
3
3
|
import { BaseItem } from './base-item';
|
|
4
4
|
export declare class TextItem extends BaseItem<IFilterConfigTextItem> {
|
|
5
|
+
protected _additionalConfig: unknown;
|
|
6
|
+
protected _filter: FilterComponent;
|
|
5
7
|
prefix: string;
|
|
6
8
|
suffix: string;
|
|
9
|
+
constructor(itemConfig: IFilterConfigTextItem, _additionalConfig: unknown, _filter: FilterComponent);
|
|
7
10
|
static create(config: IFilterConfigTextItem, filter: FilterComponent): TextItem;
|
|
8
11
|
get value(): any;
|
|
9
12
|
get queryObject(): {};
|
|
10
13
|
getChipsContent(): any;
|
|
11
14
|
protected _validateModel(): void;
|
|
12
|
-
protected _parseConfig(item: IFilterConfigTextItem): void;
|
|
13
15
|
protected _init(): void;
|
|
14
16
|
protected _clearValue(defaultValue?: unknown): void;
|
|
15
17
|
}
|
|
@@ -2,7 +2,10 @@ import type { FilterComponent } from '../../components/filter/filter.component';
|
|
|
2
2
|
import { IFilterConfigWeekItem } from '../../interfaces/items/week.interface';
|
|
3
3
|
import { BaseItem } from './base-item';
|
|
4
4
|
export declare class WeekItem extends BaseItem<IFilterConfigWeekItem> {
|
|
5
|
+
protected _additionalConfig: unknown;
|
|
6
|
+
protected _filter: FilterComponent;
|
|
5
7
|
seedDate: Date;
|
|
8
|
+
constructor(itemConfig: IFilterConfigWeekItem, _additionalConfig: unknown, _filter: FilterComponent);
|
|
6
9
|
static create(config: IFilterConfigWeekItem, filter: FilterComponent): WeekItem;
|
|
7
10
|
get value(): any;
|
|
8
11
|
get queryObject(): {
|
|
@@ -12,7 +15,6 @@ export declare class WeekItem extends BaseItem<IFilterConfigWeekItem> {
|
|
|
12
15
|
getChipsContent(type?: any): string;
|
|
13
16
|
protected _validateModel(): void;
|
|
14
17
|
protected _setModel(value: any): void;
|
|
15
|
-
protected _parseConfig(item: IFilterConfigWeekItem): void;
|
|
16
18
|
protected _init(): void;
|
|
17
19
|
protected _clearValue(defaultValue?: unknown): void;
|
|
18
20
|
}
|
|
@@ -58,11 +58,11 @@ export class FilterDrawerComponent {
|
|
|
58
58
|
this.done();
|
|
59
59
|
}
|
|
60
60
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterDrawerComponent, deps: [{ token: FILTER_DRAWER_OVERLAY }, { token: FILTER_DRAWER_DATA }, { token: i1.ExternalParamsController }, { token: i0.ChangeDetectorRef }, { token: i2.FsFilterItemsStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
61
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FilterDrawerComponent, selector: "ng-component", inputs: { inline: "inline" }, host: { listeners: { "window:resize": "updateWindowWidth()" } }, ngImport: i0, template: "<div class=\"filters\">\n <div class=\"filters-wrap\">\n\n <div class=\"filter-by\">\n <mat-icon svgIcon=\"filterOutline\"></mat-icon>\n <span class=\"text\">Filters</span>\n </div>\n\n <div class=\"overflow-shadow filter-items\">\n <div class=\"overflow-shadow-content\">\n <ng-container *fsSkeleton=\"(externalParams.pending$ | async) !== true\">\n <filter-item \n *ngFor=\"let filterItem of items$ | async\"\n class=\"filter-group\"\n [item]=\"filterItem\">\n </filter-item>\n\n <ng-container *ngIf=\"sortItem && sortItem.values && sortItem.values.length > 0\">\n <filter-item \n class=\"filter-group sort\"\n [item]=\"sortItem\">\n </filter-item>\n <filter-item \n class=\"filter-group sort\"\n [item]=\"sortDirectionItem\">\n </filter-item>\n </ng-container>\n </ng-container>\n </div>\n </div>\n\n <fs-filter-drawer-actions \n class=\"filter-actions\"\n *ngIf=\"(externalParams.pending$ | async) !== true\"\n (clear)=\"clear()\"\n (done)=\"done()\">\n </fs-filter-drawer-actions>\n </div>\n</div>\n<div class=\"backdrop\" *ngIf=\"!windowDesktop\" (click)=\"backdropClick()\"></div>\n", styles: ["@charset \"UTF-8\";@media (max-width: 599px){h1[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"]{margin-top:0}}@media (max-width: 1023px){h1[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"]{margin-top:0}}@media (max-width: 1439px){h1[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"]{margin-top:0}}.fs-delimit>*:not(:last-child):after{content:\",\\a0\"}:host ::ng-deep mat-form-field{width:100%}.filter-by{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;padding:20px 25px}.filter-by mat-icon{margin-right:8px}.filter-by .text{font-weight:400;font-size:19px}.filter-actions{display:block;box-sizing:border-box;padding:13px}.filter-actions button{margin-right:6px}.filter-actions button:last-child{margin-right:0}.filters{position:fixed;display:block;top:0;right:0;z-index:1002;bottom:0}.filters .filters-wrap{background:#fff;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;width:100vw;max-width:350px;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);box-sizing:border-box;height:100%}.filters .filters-wrap .filter-items{padding-top:5px;overflow-y:auto;height:auto}.filters .filters-wrap .filter-items .overflow-shadow-content{padding:0 25px;box-sizing:border-box}.filters .filter-group{margin:10px 0 0}.filters .filter-group:first-child{margin:0}.filters .filter label{white-space:nowrap;color:#0000008a}.filters .filter .interface.interface-range input,.filters .filter .interface.interface-range .mat-input-wrapper,.filters .filter .interface.interface-range{text-align:center}.filters .filter .interface.interface-datetime fs-datetime.has-time .md-input{width:100%}.filters .filter .interface fs-datetime-range input{text-align:center}.filters .filter .filter-label{width:1%;white-space:nowrap;vertical-align:middle;padding-right:15px}.filters md-autocomplete-container md-input-container{margin:0}.filters .isolate{margin-top:-12px}.filters .isolate .interface{line-height:20px;padding-bottom:1.25em}.filters .isolate md-checkbox{margin:0 0 0 2px}.backdrop{position:fixed;inset:0;z-index:900;outline:none}@media (max-width: 599px){.filters .filters-wrap{max-width:none}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.FsSkeletonContentDirective, selector: "[fsSkeleton]", inputs: ["fsSkeleton", "fsSkeletonPattern"] }, { kind: "component", type: i6.FilterItemComponent, selector: "filter-item", inputs: ["item"] }, { kind: "component", type: i7.FsFilterDrawerActionsComponent, selector: "fs-filter-drawer-actions", outputs: ["clear", "done"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
61
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FilterDrawerComponent, selector: "ng-component", inputs: { inline: "inline" }, host: { listeners: { "window:resize": "updateWindowWidth()" } }, ngImport: i0, template: "<div class=\"filters\">\n <div class=\"filters-wrap\">\n\n <div class=\"filter-by\">\n <mat-icon svgIcon=\"filterOutline\"></mat-icon>\n <span class=\"text\">Filters</span>\n </div>\n\n <div class=\"overflow-shadow filter-items\">\n <div class=\"overflow-shadow-content\">\n <ng-container *fsSkeleton=\"(externalParams.pending$ | async) !== true\">\n <filter-item \n *ngFor=\"let filterItem of items$ | async\"\n class=\"filter-group\"\n [item]=\"filterItem\">\n </filter-item>\n\n <ng-container *ngIf=\"sortItem && sortItem.values && sortItem.values.length > 0\">\n <filter-item \n class=\"filter-group sort\"\n [item]=\"sortItem\">\n </filter-item>\n <filter-item \n class=\"filter-group sort\"\n [item]=\"sortDirectionItem\">\n </filter-item>\n </ng-container>\n </ng-container>\n </div>\n </div>\n\n <fs-filter-drawer-actions \n class=\"filter-actions\"\n *ngIf=\"(externalParams.pending$ | async) !== true\"\n (clear)=\"clear()\"\n (done)=\"done()\">\n </fs-filter-drawer-actions>\n </div>\n</div>\n<div class=\"backdrop\" *ngIf=\"!windowDesktop\" (click)=\"backdropClick()\"></div>\n", styles: ["@charset \"UTF-8\";@media (max-width: 599px){h1[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"]{margin-top:0}}@media (max-width: 1023px){h1[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"]{margin-top:0}}@media (max-width: 1439px){h1[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"]{margin-top:0}}.fs-delimit>*{display:inline-flex}.fs-delimit>*:not(:last-child):after{content:\",\\a0\"}:host ::ng-deep mat-form-field{width:100%}.filter-by{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;padding:20px 25px}.filter-by mat-icon{margin-right:8px}.filter-by .text{font-weight:400;font-size:19px}.filter-actions{display:block;box-sizing:border-box;padding:13px}.filter-actions button{margin-right:6px}.filter-actions button:last-child{margin-right:0}.filters{position:fixed;display:block;top:0;right:0;z-index:1002;bottom:0}.filters .filters-wrap{background:#fff;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;width:100vw;max-width:350px;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);box-sizing:border-box;height:100%}.filters .filters-wrap .filter-items{padding-top:5px;overflow-y:auto;height:auto}.filters .filters-wrap .filter-items .overflow-shadow-content{padding:0 25px;box-sizing:border-box}.filters .filter-group{margin:10px 0 0}.filters .filter-group:first-child{margin:0}.filters .filter label{white-space:nowrap;color:#0000008a}.filters .filter .interface.interface-range input,.filters .filter .interface.interface-range .mat-input-wrapper,.filters .filter .interface.interface-range{text-align:center}.filters .filter .interface.interface-datetime fs-datetime.has-time .md-input{width:100%}.filters .filter .interface fs-datetime-range input{text-align:center}.filters .filter .filter-label{width:1%;white-space:nowrap;vertical-align:middle;padding-right:15px}.filters md-autocomplete-container md-input-container{margin:0}.filters .isolate{margin-top:-12px}.filters .isolate .interface{line-height:20px;padding-bottom:1.25em}.filters .isolate md-checkbox{margin:0 0 0 2px}.backdrop{position:fixed;inset:0;z-index:900;outline:none}@media (max-width: 599px){.filters .filters-wrap{max-width:none}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.FsSkeletonContentDirective, selector: "[fsSkeleton]", inputs: ["fsSkeleton", "fsSkeletonPattern"] }, { kind: "component", type: i6.FilterItemComponent, selector: "filter-item", inputs: ["item"] }, { kind: "component", type: i7.FsFilterDrawerActionsComponent, selector: "fs-filter-drawer-actions", outputs: ["clear", "done"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
62
62
|
}
|
|
63
63
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterDrawerComponent, decorators: [{
|
|
64
64
|
type: Component,
|
|
65
|
-
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"filters\">\n <div class=\"filters-wrap\">\n\n <div class=\"filter-by\">\n <mat-icon svgIcon=\"filterOutline\"></mat-icon>\n <span class=\"text\">Filters</span>\n </div>\n\n <div class=\"overflow-shadow filter-items\">\n <div class=\"overflow-shadow-content\">\n <ng-container *fsSkeleton=\"(externalParams.pending$ | async) !== true\">\n <filter-item \n *ngFor=\"let filterItem of items$ | async\"\n class=\"filter-group\"\n [item]=\"filterItem\">\n </filter-item>\n\n <ng-container *ngIf=\"sortItem && sortItem.values && sortItem.values.length > 0\">\n <filter-item \n class=\"filter-group sort\"\n [item]=\"sortItem\">\n </filter-item>\n <filter-item \n class=\"filter-group sort\"\n [item]=\"sortDirectionItem\">\n </filter-item>\n </ng-container>\n </ng-container>\n </div>\n </div>\n\n <fs-filter-drawer-actions \n class=\"filter-actions\"\n *ngIf=\"(externalParams.pending$ | async) !== true\"\n (clear)=\"clear()\"\n (done)=\"done()\">\n </fs-filter-drawer-actions>\n </div>\n</div>\n<div class=\"backdrop\" *ngIf=\"!windowDesktop\" (click)=\"backdropClick()\"></div>\n", styles: ["@charset \"UTF-8\";@media (max-width: 599px){h1[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"]{margin-top:0}}@media (max-width: 1023px){h1[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"]{margin-top:0}}@media (max-width: 1439px){h1[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"]{margin-top:0}}.fs-delimit>*:not(:last-child):after{content:\",\\a0\"}:host ::ng-deep mat-form-field{width:100%}.filter-by{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;padding:20px 25px}.filter-by mat-icon{margin-right:8px}.filter-by .text{font-weight:400;font-size:19px}.filter-actions{display:block;box-sizing:border-box;padding:13px}.filter-actions button{margin-right:6px}.filter-actions button:last-child{margin-right:0}.filters{position:fixed;display:block;top:0;right:0;z-index:1002;bottom:0}.filters .filters-wrap{background:#fff;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;width:100vw;max-width:350px;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);box-sizing:border-box;height:100%}.filters .filters-wrap .filter-items{padding-top:5px;overflow-y:auto;height:auto}.filters .filters-wrap .filter-items .overflow-shadow-content{padding:0 25px;box-sizing:border-box}.filters .filter-group{margin:10px 0 0}.filters .filter-group:first-child{margin:0}.filters .filter label{white-space:nowrap;color:#0000008a}.filters .filter .interface.interface-range input,.filters .filter .interface.interface-range .mat-input-wrapper,.filters .filter .interface.interface-range{text-align:center}.filters .filter .interface.interface-datetime fs-datetime.has-time .md-input{width:100%}.filters .filter .interface fs-datetime-range input{text-align:center}.filters .filter .filter-label{width:1%;white-space:nowrap;vertical-align:middle;padding-right:15px}.filters md-autocomplete-container md-input-container{margin:0}.filters .isolate{margin-top:-12px}.filters .isolate .interface{line-height:20px;padding-bottom:1.25em}.filters .isolate md-checkbox{margin:0 0 0 2px}.backdrop{position:fixed;inset:0;z-index:900;outline:none}@media (max-width: 599px){.filters .filters-wrap{max-width:none}}\n"] }]
|
|
65
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"filters\">\n <div class=\"filters-wrap\">\n\n <div class=\"filter-by\">\n <mat-icon svgIcon=\"filterOutline\"></mat-icon>\n <span class=\"text\">Filters</span>\n </div>\n\n <div class=\"overflow-shadow filter-items\">\n <div class=\"overflow-shadow-content\">\n <ng-container *fsSkeleton=\"(externalParams.pending$ | async) !== true\">\n <filter-item \n *ngFor=\"let filterItem of items$ | async\"\n class=\"filter-group\"\n [item]=\"filterItem\">\n </filter-item>\n\n <ng-container *ngIf=\"sortItem && sortItem.values && sortItem.values.length > 0\">\n <filter-item \n class=\"filter-group sort\"\n [item]=\"sortItem\">\n </filter-item>\n <filter-item \n class=\"filter-group sort\"\n [item]=\"sortDirectionItem\">\n </filter-item>\n </ng-container>\n </ng-container>\n </div>\n </div>\n\n <fs-filter-drawer-actions \n class=\"filter-actions\"\n *ngIf=\"(externalParams.pending$ | async) !== true\"\n (clear)=\"clear()\"\n (done)=\"done()\">\n </fs-filter-drawer-actions>\n </div>\n</div>\n<div class=\"backdrop\" *ngIf=\"!windowDesktop\" (click)=\"backdropClick()\"></div>\n", styles: ["@charset \"UTF-8\";@media (max-width: 599px){h1[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"]{margin-top:0}}@media (max-width: 1023px){h1[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"]{margin-top:0}}@media (max-width: 1439px){h1[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"]{margin-top:0}}.fs-delimit>*{display:inline-flex}.fs-delimit>*:not(:last-child):after{content:\",\\a0\"}:host ::ng-deep mat-form-field{width:100%}.filter-by{display:flex;flex-direction:row;align-items:center;box-sizing:border-box;padding:20px 25px}.filter-by mat-icon{margin-right:8px}.filter-by .text{font-weight:400;font-size:19px}.filter-actions{display:block;box-sizing:border-box;padding:13px}.filter-actions button{margin-right:6px}.filter-actions button:last-child{margin-right:0}.filters{position:fixed;display:block;top:0;right:0;z-index:1002;bottom:0}.filters .filters-wrap{background:#fff;box-shadow:0 2px 4px -1px #0003,0 4px 5px #00000024,0 1px 10px #0000001f;width:100vw;max-width:350px;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);box-sizing:border-box;height:100%}.filters .filters-wrap .filter-items{padding-top:5px;overflow-y:auto;height:auto}.filters .filters-wrap .filter-items .overflow-shadow-content{padding:0 25px;box-sizing:border-box}.filters .filter-group{margin:10px 0 0}.filters .filter-group:first-child{margin:0}.filters .filter label{white-space:nowrap;color:#0000008a}.filters .filter .interface.interface-range input,.filters .filter .interface.interface-range .mat-input-wrapper,.filters .filter .interface.interface-range{text-align:center}.filters .filter .interface.interface-datetime fs-datetime.has-time .md-input{width:100%}.filters .filter .interface fs-datetime-range input{text-align:center}.filters .filter .filter-label{width:1%;white-space:nowrap;vertical-align:middle;padding-right:15px}.filters md-autocomplete-container md-input-container{margin:0}.filters .isolate{margin-top:-12px}.filters .isolate .interface{line-height:20px;padding-bottom:1.25em}.filters .isolate md-checkbox{margin:0 0 0 2px}.backdrop{position:fixed;inset:0;z-index:900;outline:none}@media (max-width: 599px){.filters .filters-wrap{max-width:none}}\n"] }]
|
|
66
66
|
}], ctorParameters: () => [{ type: i8.OverlayRef, decorators: [{
|
|
67
67
|
type: Inject,
|
|
68
68
|
args: [FILTER_DRAWER_OVERLAY]
|
|
@@ -12,11 +12,11 @@ export class FsFilterDrawerActionsComponent {
|
|
|
12
12
|
this._clear.emit();
|
|
13
13
|
}
|
|
14
14
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterDrawerActionsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FsFilterDrawerActionsComponent, selector: "fs-filter-drawer-actions", outputs: { _clear: "clear", _done: "done" }, ngImport: i0, template: "<a mat-button color=\"primary\" (click)=\"done()\">Done</a>\n<a mat-button (click)=\"clear()\">Clear</a>\n\n\n", styles: ["@charset \"UTF-8\";@media (max-width: 599px){h1[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"]{margin-top:0}}@media (max-width: 1023px){h1[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"]{margin-top:0}}@media (max-width: 1439px){h1[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"]{margin-top:0}}.fs-delimit>*:not(:last-child):after{content:\",\\a0\"}@media (max-width: 599px){a{width:100%}}\n"], dependencies: [{ kind: "component", type: i1.MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-flat-button], a[mat-stroked-button]", exportAs: ["matButton", "matAnchor"] }, { kind: "directive", type: i2.FsButtonDirective, selector: "[mat-raised-button]:not([fsFormButtonStandalone]),[mat-button]:not([fsFormButtonStandalone]),[mat-flat-button]:not([fsFormButtonStandalone]),[mat-stroked-button]:not([fsFormButtonStandalone])", inputs: ["name", "dirtySubmit", "form"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
15
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FsFilterDrawerActionsComponent, selector: "fs-filter-drawer-actions", outputs: { _clear: "clear", _done: "done" }, ngImport: i0, template: "<a mat-button color=\"primary\" (click)=\"done()\">Done</a>\n<a mat-button (click)=\"clear()\">Clear</a>\n\n\n", styles: ["@charset \"UTF-8\";@media (max-width: 599px){h1[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"]{margin-top:0}}@media (max-width: 1023px){h1[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"]{margin-top:0}}@media (max-width: 1439px){h1[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"]{margin-top:0}}.fs-delimit>*{display:inline-flex}.fs-delimit>*:not(:last-child):after{content:\",\\a0\"}@media (max-width: 599px){a{width:100%}}\n"], dependencies: [{ kind: "component", type: i1.MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-flat-button], a[mat-stroked-button]", exportAs: ["matButton", "matAnchor"] }, { kind: "directive", type: i2.FsButtonDirective, selector: "[mat-raised-button]:not([fsFormButtonStandalone]),[mat-button]:not([fsFormButtonStandalone]),[mat-flat-button]:not([fsFormButtonStandalone]),[mat-stroked-button]:not([fsFormButtonStandalone])", inputs: ["name", "dirtySubmit", "form"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
16
16
|
}
|
|
17
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FsFilterDrawerActionsComponent, decorators: [{
|
|
18
18
|
type: Component,
|
|
19
|
-
args: [{ selector: 'fs-filter-drawer-actions', changeDetection: ChangeDetectionStrategy.OnPush, template: "<a mat-button color=\"primary\" (click)=\"done()\">Done</a>\n<a mat-button (click)=\"clear()\">Clear</a>\n\n\n", styles: ["@charset \"UTF-8\";@media (max-width: 599px){h1[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"]{margin-top:0}}@media (max-width: 1023px){h1[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"]{margin-top:0}}@media (max-width: 1439px){h1[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"]{margin-top:0}}.fs-delimit>*:not(:last-child):after{content:\",\\a0\"}@media (max-width: 599px){a{width:100%}}\n"] }]
|
|
19
|
+
args: [{ selector: 'fs-filter-drawer-actions', changeDetection: ChangeDetectionStrategy.OnPush, template: "<a mat-button color=\"primary\" (click)=\"done()\">Done</a>\n<a mat-button (click)=\"clear()\">Clear</a>\n\n\n", styles: ["@charset \"UTF-8\";@media (max-width: 599px){h1[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-xs*=fs-heading][fs\\.lt-xs*=\".top-none\"]{margin-top:0}}@media (max-width: 1023px){h1[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-sm*=fs-heading][fs\\.lt-sm*=\".top-none\"]{margin-top:0}}@media (max-width: 1439px){h1[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h2[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"],h3[class*=\".top\"][fs\\.lt-md*=fs-heading][fs\\.lt-md*=\".top-none\"]{margin-top:0}}.fs-delimit>*{display:inline-flex}.fs-delimit>*:not(:last-child):after{content:\",\\a0\"}@media (max-width: 599px){a{width:100%}}\n"] }]
|
|
20
20
|
}], propDecorators: { _clear: [{
|
|
21
21
|
type: Output,
|
|
22
22
|
args: ['clear']
|
|
@@ -14,7 +14,7 @@ export class CheckboxComponent extends BaseItemComponent {
|
|
|
14
14
|
this._cd = _cd;
|
|
15
15
|
}
|
|
16
16
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CheckboxComponent, deps: [{ token: i0.KeyValueDiffers }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
17
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CheckboxComponent, selector: "filter-item-checkbox", usesInheritance: true, ngImport: i0, template: "<fs-label-field>\n <mat-checkbox \n [(ngModel)]=\"item.model\" \n [name]=\"item.name\">\n {{ item.label }}\n </mat-checkbox>\n</fs-label-field>", styles: ["fs-label-field{margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "component", type: i3.FsLabelFieldComponent, selector: "fs-label-field", inputs: ["appearance", "showOutline", "disabled", "focused", "hoverable", "
|
|
17
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CheckboxComponent, selector: "filter-item-checkbox", usesInheritance: true, ngImport: i0, template: "<fs-label-field>\n <mat-checkbox \n [(ngModel)]=\"item.model\" \n [name]=\"item.name\">\n {{ item.label }}\n </mat-checkbox>\n</fs-label-field>", styles: ["fs-label-field{margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "component", type: i3.FsLabelFieldComponent, selector: "fs-label-field", inputs: ["appearance", "showOutline", "disabled", "focused", "hoverable", "padless"] }, { kind: "directive", type: i4.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])" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
18
18
|
}
|
|
19
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CheckboxComponent, decorators: [{
|
|
20
20
|
type: Component,
|
|
@@ -21,7 +21,7 @@ export class ChipsComponent extends BaseItemComponent {
|
|
|
21
21
|
return String(modelValue.value) === String(chipValue.value);
|
|
22
22
|
}
|
|
23
23
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChipsComponent, deps: [{ token: i0.KeyValueDiffers }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
24
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ChipsComponent, selector: "filter-item-chips", usesInheritance: true, ngImport: i0, template: "<ng-template [ngIf]=\"item.values?.length\">\n <fs-label-field>\n <fs-label>{{item.label}}</fs-label>\n <fs-chips \n [(ngModel)]=\"item.model\"\n [compare]=\"compareFn\"\n [multiple]=\"item.multiple\">\n <fs-chip \n *ngFor=\"let value of item.values\"\n [value]=\"value\"\n [selectable]=\"true\">\n {{ value.name }}\n </fs-chip>\n </fs-chips>\n </fs-label-field>\n</ng-template>\n\n<ng-template [ngIf]=\"item.loading\">{{ item.label }} loading...</ng-template>\n", styles: ["fs-chip{line-height:40px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.FsChipsComponent, selector: "fs-chips", inputs: ["compare", "multiple", "sortable", "selected"], outputs: ["selectedChange"] }, { kind: "component", type: i3.FsChipComponent, selector: "fs-chip", inputs: ["selectable", "removable", "value", "maxWidth", "width", "backgroundColor", "borderColor", "color", "outlined", "icon", "image", "selected", "size"], outputs: ["selectedToggled", "removed"] }, { kind: "component", type: i4.FsLabelComponent, selector: "fs-label" }, { kind: "component", type: i4.FsLabelFieldComponent, selector: "fs-label-field", inputs: ["appearance", "showOutline", "disabled", "focused", "hoverable", "
|
|
24
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ChipsComponent, selector: "filter-item-chips", usesInheritance: true, ngImport: i0, template: "<ng-template [ngIf]=\"item.values?.length\">\n <fs-label-field>\n <fs-label>{{item.label}}</fs-label>\n <fs-chips \n [(ngModel)]=\"item.model\"\n [compare]=\"compareFn\"\n [multiple]=\"item.multiple\">\n <fs-chip \n *ngFor=\"let value of item.values\"\n [value]=\"value\"\n [selectable]=\"true\">\n {{ value.name }}\n </fs-chip>\n </fs-chips>\n </fs-label-field>\n</ng-template>\n\n<ng-template [ngIf]=\"item.loading\">{{ item.label }} loading...</ng-template>\n", styles: ["fs-chip{line-height:40px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.FsChipsComponent, selector: "fs-chips", inputs: ["compare", "multiple", "sortable", "selected"], outputs: ["selectedChange"] }, { kind: "component", type: i3.FsChipComponent, selector: "fs-chip", inputs: ["selectable", "removable", "value", "maxWidth", "width", "backgroundColor", "borderColor", "color", "outlined", "icon", "image", "selected", "size"], outputs: ["selectedToggled", "removed"] }, { kind: "component", type: i4.FsLabelComponent, selector: "fs-label" }, { kind: "component", type: i4.FsLabelFieldComponent, selector: "fs-label-field", inputs: ["appearance", "showOutline", "disabled", "focused", "hoverable", "padless"] }, { kind: "directive", type: i5.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])" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
25
25
|
}
|
|
26
26
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChipsComponent, decorators: [{
|
|
27
27
|
type: Component,
|
|
@@ -4,13 +4,12 @@ import { ItemType } from '../../../enums/item-type.enum';
|
|
|
4
4
|
import { PickerViewType } from '../../../enums/picker-view-type.enum';
|
|
5
5
|
import { BaseItemComponent } from '../base-item/base-item.component';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/
|
|
8
|
-
import * as i2 from "@angular/
|
|
9
|
-
import * as i3 from "@angular/material/
|
|
10
|
-
import * as i4 from "@
|
|
11
|
-
import * as i5 from "@firestitch/
|
|
12
|
-
import * as i6 from "
|
|
13
|
-
import * as i7 from "../../../directives/focus-to-item/focus-to-item.directive";
|
|
7
|
+
import * as i1 from "@angular/forms";
|
|
8
|
+
import * as i2 from "@angular/material/input";
|
|
9
|
+
import * as i3 from "@angular/material/form-field";
|
|
10
|
+
import * as i4 from "@firestitch/datepicker";
|
|
11
|
+
import * as i5 from "@firestitch/form";
|
|
12
|
+
import * as i6 from "../../../directives/focus-to-item/focus-to-item.directive";
|
|
14
13
|
export class DateComponent extends BaseItemComponent {
|
|
15
14
|
_kvDiffers;
|
|
16
15
|
_cd;
|
|
@@ -31,10 +30,10 @@ export class DateComponent extends BaseItemComponent {
|
|
|
31
30
|
}
|
|
32
31
|
}
|
|
33
32
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateComponent, deps: [{ token: i0.KeyValueDiffers }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
34
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
33
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DateComponent, selector: "filter-item-date", usesInheritance: true, ngImport: i0, template: "@if (item.mode === itemDateMode.ScrollMonthDayYear || item.mode === itemDateMode.ScrollMonthYear) {\n <mat-form-field>\n <mat-label>\n {{ item.label }}\n </mat-label>\n <input\n matInput\n fsDateScrollPicker\n [placeholder]=\"item.label\"\n [fsFilterFocusTrigger]=\"item\"\n [(ngModel)]=\"item.model\"\n [maxYear]=\"item.maxYear\"\n [showMonth]=\"showMonth\"\n [showDay]=\"showDay\"\n [showYear]=\"showYear\"\n [clear]=\"item.showClear\"\n [name]=\"item.name\">\n </mat-form-field>\n} @else if (item.mode === itemDateMode.Calendar) {\n <mat-form-field>\n <mat-label>\n {{ item.label }}\n </mat-label>\n <input\n matInput\n fsDatePicker\n [fsFilterFocusTrigger]=\"item\"\n [(ngModel)]=\"item.model\"\n [maxYear]=\"item.maxYear\"\n [view]=\"viewType\"\n [placeholder]=\"item.label\"\n [clear]=\"item.showClear\"\n [name]=\"item.name\">\n </mat-form-field>\n}", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "component", type: i4.FsDatePickerComponent, selector: "[fsDatePicker]", inputs: ["minYear", "maxYear", "minDate", "maxDate", "startOfDay", "view", "format", "minutes"], outputs: ["change"] }, { kind: "component", type: i4.FsDateScrollPickerComponent, selector: "[fsDateScrollPicker]", inputs: ["minYear", "maxYear", "minDate", "maxDate", "showMonth", "showYear", "showDay"] }, { kind: "directive", type: i5.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: "directive", type: i6.FocusToItemDirective, selector: "[fsFilterFocusTrigger]", inputs: ["fsFilterFocusTrigger", "focusTargetType"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
35
34
|
}
|
|
36
35
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateComponent, decorators: [{
|
|
37
36
|
type: Component,
|
|
38
|
-
args: [{ selector: 'filter-item-date', changeDetection: ChangeDetectionStrategy.OnPush, template: "
|
|
37
|
+
args: [{ selector: 'filter-item-date', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (item.mode === itemDateMode.ScrollMonthDayYear || item.mode === itemDateMode.ScrollMonthYear) {\n <mat-form-field>\n <mat-label>\n {{ item.label }}\n </mat-label>\n <input\n matInput\n fsDateScrollPicker\n [placeholder]=\"item.label\"\n [fsFilterFocusTrigger]=\"item\"\n [(ngModel)]=\"item.model\"\n [maxYear]=\"item.maxYear\"\n [showMonth]=\"showMonth\"\n [showDay]=\"showDay\"\n [showYear]=\"showYear\"\n [clear]=\"item.showClear\"\n [name]=\"item.name\">\n </mat-form-field>\n} @else if (item.mode === itemDateMode.Calendar) {\n <mat-form-field>\n <mat-label>\n {{ item.label }}\n </mat-label>\n <input\n matInput\n fsDatePicker\n [fsFilterFocusTrigger]=\"item\"\n [(ngModel)]=\"item.model\"\n [maxYear]=\"item.maxYear\"\n [view]=\"viewType\"\n [placeholder]=\"item.label\"\n [clear]=\"item.showClear\"\n [name]=\"item.name\">\n </mat-form-field>\n}" }]
|
|
39
38
|
}], ctorParameters: () => [{ type: i0.KeyValueDiffers }, { type: i0.ChangeDetectorRef }] });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvZmlsdGVycy1pdGVtL2RhdGUvZGF0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvZmlsdGVycy1pdGVtL2RhdGUvZGF0ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLGlCQUFpQixFQUNqQixTQUFTLEVBQ1QsZUFBZSxHQUVoQixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDbEUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUl0RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7Ozs7Ozs7QUFRckUsTUFBTSxPQUFPLGFBQWMsU0FBUSxpQkFBMEM7SUFVL0Q7SUFDQTtJQVRMLFFBQVEsR0FBRyxjQUFjLENBQUMsSUFBSSxDQUFDO0lBRS9CLFlBQVksR0FBRyxZQUFZLENBQUM7SUFDNUIsUUFBUSxHQUFHLElBQUksQ0FBQztJQUNoQixTQUFTLEdBQUcsSUFBSSxDQUFDO0lBQ2pCLE9BQU8sR0FBRyxJQUFJLENBQUM7SUFFdEIsWUFDWSxVQUEyQixFQUMzQixHQUFzQjtRQUVoQyxLQUFLLENBQUMsVUFBVSxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBSGIsZUFBVSxHQUFWLFVBQVUsQ0FBaUI7UUFDM0IsUUFBRyxHQUFILEdBQUcsQ0FBbUI7SUFHbEMsQ0FBQztJQUVNLFFBQVE7UUFDYixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUM7UUFFckcsSUFBSyxJQUFJLENBQUMsSUFBcUIsQ0FBQyxJQUFJLEtBQUssWUFBWSxDQUFDLGVBQWUsRUFBRSxDQUFDO1lBQ3RFLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLENBQUM7SUFDSCxDQUFDO3dHQXRCVSxhQUFhOzRGQUFiLGFBQWEsK0VDdEIxQiw4OUJBa0NDOzs0RkRaWSxhQUFhO2tCQUx6QixTQUFTOytCQUNFLGtCQUFrQixtQkFFWCx1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIEtleVZhbHVlRGlmZmVycyxcbiAgT25Jbml0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgSXRlbURhdGVNb2RlIH0gZnJvbSAnLi4vLi4vLi4vZW51bXMvaXRlbS1kYXRlLW1vZGUuZW51bSc7XG5pbXBvcnQgeyBJdGVtVHlwZSB9IGZyb20gJy4uLy4uLy4uL2VudW1zL2l0ZW0tdHlwZS5lbnVtJztcbmltcG9ydCB7IFBpY2tlclZpZXdUeXBlIH0gZnJvbSAnLi4vLi4vLi4vZW51bXMvcGlja2VyLXZpZXctdHlwZS5lbnVtJztcbmltcG9ydCB0eXBlIHsgRGF0ZUl0ZW0gfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvaXRlbXMvZGF0ZS1pdGVtJztcbmltcG9ydCB0eXBlIHsgRGF0ZVRpbWVJdGVtIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL2l0ZW1zL2RhdGUtdGltZS1pdGVtJztcbmltcG9ydCB0eXBlIHsgQmFzZURhdGVJdGVtIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL2l0ZW1zL2RhdGUvYmFzZS1kYXRlLWl0ZW0nO1xuaW1wb3J0IHsgQmFzZUl0ZW1Db21wb25lbnQgfSBmcm9tICcuLi9iYXNlLWl0ZW0vYmFzZS1pdGVtLmNvbXBvbmVudCc7XG5cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZmlsdGVyLWl0ZW0tZGF0ZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9kYXRlLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIERhdGVDb21wb25lbnQgZXh0ZW5kcyBCYXNlSXRlbUNvbXBvbmVudDxEYXRlSXRlbSB8IERhdGVUaW1lSXRlbT4gaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIHB1YmxpYyB2aWV3VHlwZSA9IFBpY2tlclZpZXdUeXBlLkRhdGU7XG5cbiAgcHVibGljIGl0ZW1EYXRlTW9kZSA9IEl0ZW1EYXRlTW9kZTtcbiAgcHVibGljIHNob3dZZWFyID0gdHJ1ZTtcbiAgcHVibGljIHNob3dNb250aCA9IHRydWU7XG4gIHB1YmxpYyBzaG93RGF5ID0gdHJ1ZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcm90ZWN0ZWQgX2t2RGlmZmVyczogS2V5VmFsdWVEaWZmZXJzLFxuICAgIHByb3RlY3RlZCBfY2Q6IENoYW5nZURldGVjdG9yUmVmLFxuICApIHtcbiAgICBzdXBlcihfa3ZEaWZmZXJzLCBfY2QpO1xuICB9XG5cbiAgcHVibGljIG5nT25Jbml0KCkge1xuICAgIHRoaXMudmlld1R5cGUgPSB0aGlzLml0ZW0udHlwZSA9PT0gSXRlbVR5cGUuRGF0ZVRpbWUgPyBQaWNrZXJWaWV3VHlwZS5EYXRlVGltZSA6IFBpY2tlclZpZXdUeXBlLkRhdGU7XG5cbiAgICBpZiAoKHRoaXMuaXRlbSBhcyBCYXNlRGF0ZUl0ZW0pLm1vZGUgPT09IEl0ZW1EYXRlTW9kZS5TY3JvbGxNb250aFllYXIpIHtcbiAgICAgIHRoaXMuc2hvd0RheSA9IGZhbHNlO1xuICAgIH1cbiAgfVxufVxuIiwiQGlmIChpdGVtLm1vZGUgPT09IGl0ZW1EYXRlTW9kZS5TY3JvbGxNb250aERheVllYXIgfHwgaXRlbS5tb2RlID09PSBpdGVtRGF0ZU1vZGUuU2Nyb2xsTW9udGhZZWFyKSB7XG4gIDxtYXQtZm9ybS1maWVsZD5cbiAgICA8bWF0LWxhYmVsPlxuICAgICAge3sgaXRlbS5sYWJlbCB9fVxuICAgIDwvbWF0LWxhYmVsPlxuICAgIDxpbnB1dFxuICAgICAgbWF0SW5wdXRcbiAgICAgIGZzRGF0ZVNjcm9sbFBpY2tlclxuICAgICAgW3BsYWNlaG9sZGVyXT1cIml0ZW0ubGFiZWxcIlxuICAgICAgW2ZzRmlsdGVyRm9jdXNUcmlnZ2VyXT1cIml0ZW1cIlxuICAgICAgWyhuZ01vZGVsKV09XCJpdGVtLm1vZGVsXCJcbiAgICAgIFttYXhZZWFyXT1cIml0ZW0ubWF4WWVhclwiXG4gICAgICBbc2hvd01vbnRoXT1cInNob3dNb250aFwiXG4gICAgICBbc2hvd0RheV09XCJzaG93RGF5XCJcbiAgICAgIFtzaG93WWVhcl09XCJzaG93WWVhclwiXG4gICAgICBbY2xlYXJdPVwiaXRlbS5zaG93Q2xlYXJcIlxuICAgICAgW25hbWVdPVwiaXRlbS5uYW1lXCI+XG4gIDwvbWF0LWZvcm0tZmllbGQ+XG59IEBlbHNlIGlmIChpdGVtLm1vZGUgPT09IGl0ZW1EYXRlTW9kZS5DYWxlbmRhcikge1xuICA8bWF0LWZvcm0tZmllbGQ+XG4gICAgPG1hdC1sYWJlbD5cbiAgICAgIHt7IGl0ZW0ubGFiZWwgfX1cbiAgICA8L21hdC1sYWJlbD5cbiAgICA8aW5wdXRcbiAgICAgIG1hdElucHV0XG4gICAgICBmc0RhdGVQaWNrZXJcbiAgICAgIFtmc0ZpbHRlckZvY3VzVHJpZ2dlcl09XCJpdGVtXCJcbiAgICAgIFsobmdNb2RlbCldPVwiaXRlbS5tb2RlbFwiXG4gICAgICBbbWF4WWVhcl09XCJpdGVtLm1heFllYXJcIlxuICAgICAgW3ZpZXddPVwidmlld1R5cGVcIlxuICAgICAgW3BsYWNlaG9sZGVyXT1cIml0ZW0ubGFiZWxcIlxuICAgICAgW2NsZWFyXT1cIml0ZW0uc2hvd0NsZWFyXCJcbiAgICAgIFtuYW1lXT1cIml0ZW0ubmFtZVwiPlxuICA8L21hdC1mb3JtLWZpZWxkPlxufSJdfQ==
|
|
@@ -2,7 +2,6 @@ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@
|
|
|
2
2
|
import { Subject } from 'rxjs';
|
|
3
3
|
import { takeUntil } from 'rxjs/operators';
|
|
4
4
|
import { ItemType } from '../../enums/item-type.enum';
|
|
5
|
-
import { BaseItem } from '../../models/items/base-item';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "@angular/common";
|
|
8
7
|
import * as i2 from "./select/select.component";
|
|
@@ -79,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
79
78
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { item: [{
|
|
80
79
|
type: Input
|
|
81
80
|
}] } });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-item.component.js","sourceRoot":"","sources":["../../../../../src/app/components/filters-item/filter-item.component.ts","../../../../../src/app/components/filters-item/filter-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,KAAK,GAGN,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;;;;;;AAsBtD,MAAM,OAAO,mBAAmB;IAwDV;IAtDJ,IAAI,CAAgB;IAE7B,QAAQ,GAAG,QAAQ,CAAC;IAE3B,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,IAAgB,CAAC;IAC/B,CAAC;IAED,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,IAAiB,CAAC;IAChC,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,IAAsB,CAAC;IACrC,CAAC;IAED,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,IAAiB,CAAC;IAChC,CAAC;IAED,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,IAAwB,CAAC;IACvC,CAAC;IAED,IAAW,qBAAqB;QAC9B,OAAO,IAAI,CAAC,IAA6B,CAAC;IAC5C,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,IAAgB,CAAC;IAC/B,CAAC;IAED,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,IAAqB,CAAC;IACpC,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,IAAoB,CAAC;IACnC,CAAC;IAED,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,IAAyB,CAAC;IACxC,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,IAAgB,CAAC;IAC/B,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,IAAoB,CAAC;IACnC,CAAC;IAEO,SAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAExC,YAAoB,MAAyB;QAAzB,WAAM,GAAN,MAAM,CAAmB;IAAI,CAAC;IAE3C,QAAQ;QACb,IAAI,CAAC,IAAI,CAAC,MAAM;aACb,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;wGAvEU,mBAAmB;4FAAnB,mBAAmB,6EClChC,wlEA6EA;;4FD3Ca,mBAAmB;kBAN/B,SAAS;+BACE,aAAa,mBAGN,uBAAuB,CAAC,MAAM;sFAI/B,IAAI;sBAAnB,KAAK","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { ItemType } from '../../enums/item-type.enum';\nimport type { AutocompleteChipsItem } from '../../models/items/autocomplete-chips-item';\nimport type { AutocompleteItem } from '../../models/items/autocomplete-item';\nimport type { BaseItem } from '../../models/items/base-item';\nimport type { CheckboxItem } from '../../models/items/checkbox-item';\nimport type { ChipsItem } from '../../models/items/chips-item';\nimport type { DateItem } from '../../models/items/date-item';\nimport type { DateRangeItem } from '../../models/items/date-range-item';\nimport type { DateTimeItem } from '../../models/items/date-time-item';\nimport type { DateTimeRangeItem } from '../../models/items/date-time-range-item';\nimport type { RangeItem } from '../../models/items/range-item';\nimport type { BaseSelectItem } from '../../models/items/select/base-select-item';\nimport type { TextItem } from '../../models/items/text-item';\nimport type { WeekItem } from '../../models/items/week-item';\n\n\n@Component({\n  selector: 'filter-item',\n  templateUrl: './filter-item.component.html',\n  styleUrls: ['./filter-item.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FilterItemComponent implements OnInit, OnDestroy {\n\n  @Input() public item: BaseItem<any>;\n\n  public itemType = ItemType;\n\n  public get textItem(): TextItem {\n    return this.item as TextItem;\n  }\n\n  public get chipsItem(): ChipsItem {\n    return this.item as ChipsItem;\n  }\n\n  public get baseSelectItem(): BaseSelectItem {\n    return this.item as BaseSelectItem;\n  }\n\n  public get rangeItem(): RangeItem {\n    return this.item as RangeItem;\n  }\n\n  public get autocompleteItem(): AutocompleteItem {\n    return this.item as AutocompleteItem;\n  }\n\n  public get autocompleteChipsItem(): AutocompleteChipsItem {\n    return this.item as AutocompleteChipsItem;\n  }\n\n  public get dateItem(): DateItem {\n    return this.item as DateItem;\n  }\n\n  public get dateRangeItem(): DateRangeItem {\n    return this.item as DateRangeItem;\n  }\n\n  public get dateTimeItem(): DateTimeItem {\n    return this.item as DateTimeItem;\n  }\n\n  public get dateTimeRangeItem(): DateTimeRangeItem {\n    return this.item as DateTimeRangeItem;\n  }\n\n  public get weekItem(): WeekItem {\n    return this.item as WeekItem;\n  }\n\n  public get checkboxItem(): CheckboxItem {\n    return this.item as CheckboxItem;\n  }\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(private _cdRef: ChangeDetectorRef) { }\n\n  public ngOnInit(): void {\n    this.item.value$\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this._cdRef.markForCheck();\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n}\n","<div class=\"filter filter-{{ item.type }}\">\n\n  <ng-container [ngSwitch]=\"item.type\">\n    <filter-item-text \n      class=\"interface\"\n      *ngSwitchCase=\"itemType.Text\"\n      [item]=\"textItem\">\n    </filter-item-text>\n\n    <filter-item-select \n      class=\"interface\"\n      *ngSwitchCase=\"itemType.Select\"\n      [item]=\"baseSelectItem\">\n    </filter-item-select>\n\n    <filter-item-chips \n      class=\"interface\"\n      *ngSwitchCase=\"itemType.Chips\"\n      [item]=\"chipsItem\">\n    </filter-item-chips>\n\n    <filter-item-range \n      class=\"interface interface-range\"\n      *ngSwitchCase=\"itemType.Range\"\n      [item]=\"rangeItem\">\n    </filter-item-range>\n\n    <filter-item-autocomplete \n      class=\"interface\"\n      *ngSwitchCase=\"itemType.AutoComplete\"\n      [item]=\"autocompleteItem\">\n    </filter-item-autocomplete>\n\n    <filter-item-autocompletechips \n      class=\"interface\"\n      *ngSwitchCase=\"itemType.AutoCompleteChips\"\n      [item]=\"autocompleteChipsItem\">\n    </filter-item-autocompletechips>\n\n    <filter-item-date \n      class=\"interface interface-date\"\n      *ngSwitchCase=\"itemType.Date\"\n      [item]=\"dateItem\">\n    </filter-item-date>\n\n    <filter-item-date \n      class=\"interface interface-date\"\n      *ngSwitchCase=\"itemType.DateTime\"\n      [item]=\"dateTimeItem\">\n    </filter-item-date>\n\n    <filter-item-date-range \n      class=\"interface interface-date\"\n      *ngSwitchCase=\"itemType.DateRange\"\n      [item]=\"dateRangeItem\">\n    </filter-item-date-range>\n\n    <filter-item-date-range \n      class=\"interface interface-date\"\n      *ngSwitchCase=\"itemType.DateTimeRange\"\n      [item]=\"dateTimeRangeItem\">\n    </filter-item-date-range>\n\n    <filter-item-week \n      class=\"interface\"\n      *ngSwitchCase=\"itemType.Week\"\n      [item]=\"weekItem\">\n    </filter-item-week>\n\n    <filter-item-checkbox \n      class=\"interface interface-checkbox\"\n      *ngSwitchCase=\"itemType.Checkbox\"\n      [item]=\"checkboxItem\">\n    </filter-item-checkbox>\n  </ng-container>\n\n</div>\n"]}
|
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
import { BaseItem } from '../base-item';
|
|
2
2
|
export class BaseAutocompleteItem extends BaseItem {
|
|
3
|
+
_additionalConfig;
|
|
4
|
+
_filter;
|
|
3
5
|
search;
|
|
4
6
|
get valuesFn() {
|
|
5
7
|
return this._valuesFn;
|
|
6
8
|
}
|
|
9
|
+
constructor(itemConfig, _additionalConfig, _filter) {
|
|
10
|
+
super(itemConfig, _additionalConfig, _filter);
|
|
11
|
+
this._additionalConfig = _additionalConfig;
|
|
12
|
+
this._filter = _filter;
|
|
13
|
+
this.fetchOnFocus = itemConfig.fetchOnFocus ?? true;
|
|
14
|
+
}
|
|
7
15
|
_validateModel() {
|
|
8
16
|
//
|
|
9
17
|
}
|
|
10
|
-
_parseConfig(item) {
|
|
11
|
-
this.fetchOnFocus = item.fetchOnFocus ?? true;
|
|
12
|
-
super._parseConfig(item);
|
|
13
|
-
}
|
|
14
18
|
}
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1hdXRvY29tcGxldGUtaXRlbS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kZWxzL2l0ZW1zL2F1dG9jb21wbGV0ZS9iYXNlLWF1dG9jb21wbGV0ZS1pdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFJeEMsTUFBTSxPQUFnQixvQkFBaUQsU0FBUSxRQUFXO0lBWTVFO0lBQ0E7SUFYTCxNQUFNLENBQVM7SUFJdEIsSUFBVyxRQUFRO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsWUFDRSxVQUFhLEVBQ0gsaUJBQTBCLEVBQzFCLE9BQXdCO1FBRWxDLEtBQUssQ0FBQyxVQUFVLEVBQUUsaUJBQWlCLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFIcEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFTO1FBQzFCLFlBQU8sR0FBUCxPQUFPLENBQWlCO1FBR2xDLElBQUksQ0FBQyxZQUFZLEdBQUcsVUFBVSxDQUFDLFlBQVksSUFBSSxJQUFJLENBQUM7SUFDdEQsQ0FBQztJQUVTLGNBQWM7UUFDdEIsRUFBRTtJQUNKLENBQUM7Q0FFRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cy9maWx0ZXIvZmlsdGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJRmlsdGVyQ29uZmlnQXV0b2NvbXBsZXRlQ2hpcHNJdGVtIH0gZnJvbSAnLi4vLi4vLi4vaW50ZXJmYWNlcy9pdGVtcy9hdXRvY29tcGxldGUtY2hpcHMuaW50ZXJmYWNlJztcbmltcG9ydCB7IElGaWx0ZXJDb25maWdBdXRvY29tcGxldGVJdGVtIH0gZnJvbSAnLi4vLi4vLi4vaW50ZXJmYWNlcy9pdGVtcy9hdXRvY29tcGxldGUuaW50ZXJmYWNlJztcbmltcG9ydCB7IEJhc2VJdGVtIH0gZnJvbSAnLi4vYmFzZS1pdGVtJztcblxudHlwZSBBdXRvQ29tcGxldGVJdGVtID0gSUZpbHRlckNvbmZpZ0F1dG9jb21wbGV0ZUl0ZW0gfCBJRmlsdGVyQ29uZmlnQXV0b2NvbXBsZXRlQ2hpcHNJdGVtO1xuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUF1dG9jb21wbGV0ZUl0ZW08VCBleHRlbmRzIEF1dG9Db21wbGV0ZUl0ZW0+IGV4dGVuZHMgQmFzZUl0ZW08VD4ge1xuXG4gIHB1YmxpYyBzZWFyY2g6IHN0cmluZztcblxuICBwdWJsaWMgZGVjbGFyZSBmZXRjaE9uRm9jdXM6IGJvb2xlYW47XG5cbiAgcHVibGljIGdldCB2YWx1ZXNGbigpIHtcbiAgICByZXR1cm4gdGhpcy5fdmFsdWVzRm47XG4gIH1cbiAgXG4gIGNvbnN0cnVjdG9yKFxuICAgIGl0ZW1Db25maWc6IFQsXG4gICAgcHJvdGVjdGVkIF9hZGRpdGlvbmFsQ29uZmlnOiB1bmtub3duLFxuICAgIHByb3RlY3RlZCBfZmlsdGVyOiBGaWx0ZXJDb21wb25lbnQsXG4gICkge1xuICAgIHN1cGVyKGl0ZW1Db25maWcsIF9hZGRpdGlvbmFsQ29uZmlnLCBfZmlsdGVyKTtcbiAgICB0aGlzLmZldGNoT25Gb2N1cyA9IGl0ZW1Db25maWcuZmV0Y2hPbkZvY3VzID8/IHRydWU7XG4gIH1cblxuICBwcm90ZWN0ZWQgX3ZhbGlkYXRlTW9kZWwoKSB7XG4gICAgLy9cbiAgfVxuXG59XG4iXX0=
|