@firestitch/filter 18.2.63 → 18.2.64
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/app/classes/actions-controller.d.ts +1 -2
- package/app/components/filters-item/autocomplete/autocomplete.component.d.ts +0 -4
- package/app/components/filters-item/base-item/base-item.component.d.ts +2 -3
- package/app/components/filters-item/filter-item.component.d.ts +1 -2
- package/app/directives/focus-to-item.directive.d.ts +2 -8
- package/app/directives/heading.directive.d.ts +0 -1
- package/app/directives/status-bar.directive.d.ts +0 -1
- package/app/helpers/create-filter-item.d.ts +1 -1
- package/app/interfaces/config.interface.d.ts +1 -1
- package/app/models/filter-config.d.ts +1 -1
- package/esm2022/app/classes/actions-controller.mjs +6 -8
- package/esm2022/app/components/filter/filter.component.mjs +2 -4
- package/esm2022/app/components/filters-item/autocomplete/autocomplete.component.mjs +4 -11
- package/esm2022/app/components/filters-item/base-item/base-item.component.mjs +6 -10
- package/esm2022/app/components/filters-item/filter-item.component.mjs +5 -8
- package/esm2022/app/directives/focus-to-item.directive.mjs +13 -57
- package/esm2022/app/directives/heading.directive.mjs +5 -8
- package/esm2022/app/directives/status-bar.directive.mjs +5 -8
- package/esm2022/app/interfaces/config.interface.mjs +1 -1
- package/esm2022/app/models/filter-config.mjs +2 -2
- package/fesm2022/firestitch-filter.mjs +50 -113
- package/fesm2022/firestitch-filter.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { AsyncPipe } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, inject } from '@angular/core';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
4
|
import { takeUntil } from 'rxjs/operators';
|
|
5
5
|
import { ItemType } from '../../enums/item-type.enum';
|
|
@@ -15,7 +15,7 @@ import { TextComponent } from './text/text.component';
|
|
|
15
15
|
import { WeekComponent } from './week/week.component';
|
|
16
16
|
import * as i0 from "@angular/core";
|
|
17
17
|
export class FilterItemComponent {
|
|
18
|
-
_cdRef;
|
|
18
|
+
_cdRef = inject(ChangeDetectorRef);
|
|
19
19
|
item;
|
|
20
20
|
itemType = ItemType;
|
|
21
21
|
get textItem() {
|
|
@@ -55,9 +55,6 @@ export class FilterItemComponent {
|
|
|
55
55
|
return this.item;
|
|
56
56
|
}
|
|
57
57
|
_destroy$ = new Subject();
|
|
58
|
-
constructor(_cdRef) {
|
|
59
|
-
this._cdRef = _cdRef;
|
|
60
|
-
}
|
|
61
58
|
ngOnInit() {
|
|
62
59
|
this.item.value$
|
|
63
60
|
.pipe(takeUntil(this._destroy$))
|
|
@@ -69,7 +66,7 @@ export class FilterItemComponent {
|
|
|
69
66
|
this._destroy$.next(null);
|
|
70
67
|
this._destroy$.complete();
|
|
71
68
|
}
|
|
72
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterItemComponent, deps: [
|
|
69
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
73
70
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FilterItemComponent, isStandalone: true, selector: "filter-item", inputs: { item: "item" }, ngImport: i0, template: "@if (item.visible$ | async) {\n <div class=\"filter filter-{{ item.type }}\">\n @switch (item.type) {\n @case (itemType.Text) {\n <filter-item-text\n class=\"interface\"\n [item]=\"textItem\">\n </filter-item-text>\n }\n @case (itemType.Select) {\n <filter-item-select\n class=\"interface\"\n [item]=\"selectItem\">\n </filter-item-select>\n }\n @case (itemType.Chips) {\n <filter-item-chips\n class=\"interface\"\n [item]=\"chipsItem\">\n </filter-item-chips>\n }\n @case (itemType.Range) {\n <filter-item-range\n class=\"interface interface-range\"\n [item]=\"rangeItem\">\n </filter-item-range>\n }\n @case (itemType.AutoComplete) {\n <filter-item-autocomplete\n class=\"interface\"\n [item]=\"autocompleteItem\">\n </filter-item-autocomplete>\n }\n @case (itemType.AutoCompleteChips) {\n <filter-item-autocompletechips\n class=\"interface\"\n [item]=\"autocompleteChipsItem\">\n </filter-item-autocompletechips>\n }\n @case (itemType.Date) {\n <filter-item-date\n class=\"interface interface-date\"\n [item]=\"dateItem\">\n </filter-item-date>\n }\n @case (itemType.DateTime) {\n <filter-item-date\n class=\"interface interface-date\"\n [item]=\"dateTimeItem\">\n </filter-item-date>\n }\n @case (itemType.DateRange) {\n <filter-item-date-range\n class=\"interface interface-date\"\n [item]=\"dateRangeItem\">\n </filter-item-date-range>\n }\n @case (itemType.DateTimeRange) {\n <filter-item-date-range\n class=\"interface interface-date\"\n [item]=\"dateTimeRangeItem\">\n </filter-item-date-range>\n }\n @case (itemType.Week) {\n <filter-item-week\n class=\"interface\"\n [item]=\"weekItem\">\n </filter-item-week>\n }\n @case (itemType.Checkbox) {\n <filter-item-checkbox\n class=\"interface interface-checkbox\"\n [item]=\"checkboxItem\">\n </filter-item-checkbox>\n }\n }\n </div>\n}", styles: [":host ::ng-deep mat-form-field .mat-form-field-prefix .text-prefix,:host ::ng-deep mat-form-field .mat-form-field-prefix .text-suffix,:host ::ng-deep mat-form-field .mat-form-field-suffix .text-prefix,:host ::ng-deep mat-form-field .mat-form-field-suffix .text-suffix{top:-.25em;position:relative}:host ::ng-deep mat-form-field:not(.mat-form-field-should-float) .mat-form-field-prefix .text-prefix,:host ::ng-deep mat-form-field:not(.mat-form-field-should-float) .mat-form-field-suffix .text-suffix{display:none}\n"], dependencies: [{ kind: "component", type: TextComponent, selector: "filter-item-text" }, { kind: "component", type: SelectComponent, selector: "filter-item-select", inputs: ["item"] }, { kind: "component", type: ChipsComponent, selector: "filter-item-chips" }, { kind: "component", type: RangeComponent, selector: "filter-item-range" }, { kind: "component", type: AutocompleteComponent, selector: "filter-item-autocomplete" }, { kind: "component", type: AutocompletechipsComponent, selector: "filter-item-autocompletechips" }, { kind: "component", type: DateComponent, selector: "filter-item-date" }, { kind: "component", type: DateRangeComponent, selector: "filter-item-date-range" }, { kind: "component", type: WeekComponent, selector: "filter-item-week" }, { kind: "component", type: CheckboxComponent, selector: "filter-item-checkbox" }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
74
71
|
}
|
|
75
72
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterItemComponent, decorators: [{
|
|
@@ -87,7 +84,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
87
84
|
CheckboxComponent,
|
|
88
85
|
AsyncPipe,
|
|
89
86
|
], template: "@if (item.visible$ | async) {\n <div class=\"filter filter-{{ item.type }}\">\n @switch (item.type) {\n @case (itemType.Text) {\n <filter-item-text\n class=\"interface\"\n [item]=\"textItem\">\n </filter-item-text>\n }\n @case (itemType.Select) {\n <filter-item-select\n class=\"interface\"\n [item]=\"selectItem\">\n </filter-item-select>\n }\n @case (itemType.Chips) {\n <filter-item-chips\n class=\"interface\"\n [item]=\"chipsItem\">\n </filter-item-chips>\n }\n @case (itemType.Range) {\n <filter-item-range\n class=\"interface interface-range\"\n [item]=\"rangeItem\">\n </filter-item-range>\n }\n @case (itemType.AutoComplete) {\n <filter-item-autocomplete\n class=\"interface\"\n [item]=\"autocompleteItem\">\n </filter-item-autocomplete>\n }\n @case (itemType.AutoCompleteChips) {\n <filter-item-autocompletechips\n class=\"interface\"\n [item]=\"autocompleteChipsItem\">\n </filter-item-autocompletechips>\n }\n @case (itemType.Date) {\n <filter-item-date\n class=\"interface interface-date\"\n [item]=\"dateItem\">\n </filter-item-date>\n }\n @case (itemType.DateTime) {\n <filter-item-date\n class=\"interface interface-date\"\n [item]=\"dateTimeItem\">\n </filter-item-date>\n }\n @case (itemType.DateRange) {\n <filter-item-date-range\n class=\"interface interface-date\"\n [item]=\"dateRangeItem\">\n </filter-item-date-range>\n }\n @case (itemType.DateTimeRange) {\n <filter-item-date-range\n class=\"interface interface-date\"\n [item]=\"dateTimeRangeItem\">\n </filter-item-date-range>\n }\n @case (itemType.Week) {\n <filter-item-week\n class=\"interface\"\n [item]=\"weekItem\">\n </filter-item-week>\n }\n @case (itemType.Checkbox) {\n <filter-item-checkbox\n class=\"interface interface-checkbox\"\n [item]=\"checkboxItem\">\n </filter-item-checkbox>\n }\n }\n </div>\n}", styles: [":host ::ng-deep mat-form-field .mat-form-field-prefix .text-prefix,:host ::ng-deep mat-form-field .mat-form-field-prefix .text-suffix,:host ::ng-deep mat-form-field .mat-form-field-suffix .text-prefix,:host ::ng-deep mat-form-field .mat-form-field-suffix .text-suffix{top:-.25em;position:relative}:host ::ng-deep mat-form-field:not(.mat-form-field-should-float) .mat-form-field-prefix .text-prefix,:host ::ng-deep mat-form-field:not(.mat-form-field-should-float) .mat-form-field-suffix .text-suffix{display:none}\n"] }]
|
|
90
|
-
}],
|
|
87
|
+
}], propDecorators: { item: [{
|
|
91
88
|
type: Input
|
|
92
89
|
}] } });
|
|
93
|
-
//# 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":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport {\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 { SelectItem } from '../../models/items/select-item';\nimport type { TextItem } from '../../models/items/text-item';\nimport type { WeekItem } from '../../models/items/week-item';\n\nimport { AutocompleteComponent } from './autocomplete/autocomplete.component';\nimport { AutocompletechipsComponent } from './autocompletechips/autocompletechips.component';\nimport { CheckboxComponent } from './checkbox/checkbox.component';\nimport { ChipsComponent } from './chips/chips.component';\nimport { DateRangeComponent } from './date-range/date-range.component';\nimport { DateComponent } from './date/date.component';\nimport { RangeComponent } from './range/range.component';\nimport { SelectComponent } from './select/select.component';\nimport { TextComponent } from './text/text.component';\nimport { WeekComponent } from './week/week.component';\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  standalone: true,\n  imports: [\n    TextComponent,\n    SelectComponent,\n    ChipsComponent,\n    RangeComponent,\n    AutocompleteComponent,\n    AutocompletechipsComponent,\n    DateComponent,\n    DateRangeComponent,\n    WeekComponent,\n    CheckboxComponent,\n    AsyncPipe,\n  ],\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 selectItem(): SelectItem {\n    return this.item as SelectItem;\n  }\n\n  public get chipsItem(): ChipsItem {\n    return this.item as ChipsItem;\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","@if (item.visible$ | async) {\n  <div class=\"filter filter-{{ item.type }}\">\n    @switch (item.type) {\n      @case (itemType.Text) {\n        <filter-item-text\n          class=\"interface\"\n          [item]=\"textItem\">\n        </filter-item-text>\n      }\n      @case (itemType.Select) {\n        <filter-item-select\n          class=\"interface\"\n          [item]=\"selectItem\">\n        </filter-item-select>\n      }\n      @case (itemType.Chips) {\n        <filter-item-chips\n          class=\"interface\"\n          [item]=\"chipsItem\">\n        </filter-item-chips>\n      }\n      @case (itemType.Range) {\n        <filter-item-range\n          class=\"interface interface-range\"\n          [item]=\"rangeItem\">\n        </filter-item-range>\n      }\n      @case (itemType.AutoComplete) {\n        <filter-item-autocomplete\n          class=\"interface\"\n          [item]=\"autocompleteItem\">\n        </filter-item-autocomplete>\n      }\n      @case (itemType.AutoCompleteChips) {\n        <filter-item-autocompletechips\n          class=\"interface\"\n          [item]=\"autocompleteChipsItem\">\n        </filter-item-autocompletechips>\n      }\n      @case (itemType.Date) {\n        <filter-item-date\n          class=\"interface interface-date\"\n          [item]=\"dateItem\">\n        </filter-item-date>\n      }\n      @case (itemType.DateTime) {\n        <filter-item-date\n          class=\"interface interface-date\"\n          [item]=\"dateTimeItem\">\n        </filter-item-date>\n      }\n      @case (itemType.DateRange) {\n        <filter-item-date-range\n          class=\"interface interface-date\"\n          [item]=\"dateRangeItem\">\n        </filter-item-date-range>\n      }\n      @case (itemType.DateTimeRange) {\n        <filter-item-date-range\n          class=\"interface interface-date\"\n          [item]=\"dateTimeRangeItem\">\n        </filter-item-date-range>\n      }\n      @case (itemType.Week) {\n        <filter-item-week\n          class=\"interface\"\n          [item]=\"weekItem\">\n        </filter-item-week>\n      }\n      @case (itemType.Checkbox) {\n        <filter-item-checkbox\n          class=\"interface interface-checkbox\"\n          [item]=\"checkboxItem\">\n        </filter-item-checkbox>\n      }\n    }\n  </div>\n}"]}
|
|
90
|
+
//# 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":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnDestroy, OnInit, inject } 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 { SelectItem } from '../../models/items/select-item';\nimport type { TextItem } from '../../models/items/text-item';\nimport type { WeekItem } from '../../models/items/week-item';\n\nimport { AutocompleteComponent } from './autocomplete/autocomplete.component';\nimport { AutocompletechipsComponent } from './autocompletechips/autocompletechips.component';\nimport { CheckboxComponent } from './checkbox/checkbox.component';\nimport { ChipsComponent } from './chips/chips.component';\nimport { DateRangeComponent } from './date-range/date-range.component';\nimport { DateComponent } from './date/date.component';\nimport { RangeComponent } from './range/range.component';\nimport { SelectComponent } from './select/select.component';\nimport { TextComponent } from './text/text.component';\nimport { WeekComponent } from './week/week.component';\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  standalone: true,\n  imports: [\n    TextComponent,\n    SelectComponent,\n    ChipsComponent,\n    RangeComponent,\n    AutocompleteComponent,\n    AutocompletechipsComponent,\n    DateComponent,\n    DateRangeComponent,\n    WeekComponent,\n    CheckboxComponent,\n    AsyncPipe,\n  ],\n})\nexport class FilterItemComponent implements OnInit, OnDestroy {\n  private _cdRef = inject(ChangeDetectorRef);\n\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 selectItem(): SelectItem {\n    return this.item as SelectItem;\n  }\n\n  public get chipsItem(): ChipsItem {\n    return this.item as ChipsItem;\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  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","@if (item.visible$ | async) {\n  <div class=\"filter filter-{{ item.type }}\">\n    @switch (item.type) {\n      @case (itemType.Text) {\n        <filter-item-text\n          class=\"interface\"\n          [item]=\"textItem\">\n        </filter-item-text>\n      }\n      @case (itemType.Select) {\n        <filter-item-select\n          class=\"interface\"\n          [item]=\"selectItem\">\n        </filter-item-select>\n      }\n      @case (itemType.Chips) {\n        <filter-item-chips\n          class=\"interface\"\n          [item]=\"chipsItem\">\n        </filter-item-chips>\n      }\n      @case (itemType.Range) {\n        <filter-item-range\n          class=\"interface interface-range\"\n          [item]=\"rangeItem\">\n        </filter-item-range>\n      }\n      @case (itemType.AutoComplete) {\n        <filter-item-autocomplete\n          class=\"interface\"\n          [item]=\"autocompleteItem\">\n        </filter-item-autocomplete>\n      }\n      @case (itemType.AutoCompleteChips) {\n        <filter-item-autocompletechips\n          class=\"interface\"\n          [item]=\"autocompleteChipsItem\">\n        </filter-item-autocompletechips>\n      }\n      @case (itemType.Date) {\n        <filter-item-date\n          class=\"interface interface-date\"\n          [item]=\"dateItem\">\n        </filter-item-date>\n      }\n      @case (itemType.DateTime) {\n        <filter-item-date\n          class=\"interface interface-date\"\n          [item]=\"dateTimeItem\">\n        </filter-item-date>\n      }\n      @case (itemType.DateRange) {\n        <filter-item-date-range\n          class=\"interface interface-date\"\n          [item]=\"dateRangeItem\">\n        </filter-item-date-range>\n      }\n      @case (itemType.DateTimeRange) {\n        <filter-item-date-range\n          class=\"interface interface-date\"\n          [item]=\"dateTimeRangeItem\">\n        </filter-item-date-range>\n      }\n      @case (itemType.Week) {\n        <filter-item-week\n          class=\"interface\"\n          [item]=\"weekItem\">\n        </filter-item-week>\n      }\n      @case (itemType.Checkbox) {\n        <filter-item-checkbox\n          class=\"interface interface-checkbox\"\n          [item]=\"checkboxItem\">\n        </filter-item-checkbox>\n      }\n    }\n  </div>\n}"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Directive, ElementRef, Input,
|
|
1
|
+
import { Directive, ElementRef, Input, inject } from '@angular/core';
|
|
2
2
|
import { MatSelect } from '@angular/material/select';
|
|
3
3
|
import { FsAutocompleteComponent } from '@firestitch/autocomplete';
|
|
4
4
|
import { FsAutocompleteChipsComponent } from '@firestitch/autocomplete-chips';
|
|
@@ -9,35 +9,19 @@ import { ItemDateMode } from '../enums/item-date-mode.enum';
|
|
|
9
9
|
import { ItemType } from '../enums/item-type.enum';
|
|
10
10
|
import { FocusControllerService } from '../services/focus-controller.service';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "../services/focus-controller.service";
|
|
13
|
-
import * as i2 from "@angular/material/select";
|
|
14
|
-
import * as i3 from "@firestitch/datepicker";
|
|
15
|
-
import * as i4 from "@firestitch/autocomplete";
|
|
16
|
-
import * as i5 from "@firestitch/autocomplete-chips";
|
|
17
12
|
export class FocusToItemDirective {
|
|
18
|
-
_el;
|
|
19
|
-
_focusController;
|
|
20
|
-
_targetSelect;
|
|
21
|
-
_targetDate;
|
|
22
|
-
_targetDateScroll;
|
|
23
|
-
_targetDateRangeFrom;
|
|
24
|
-
_targetDateRangeTo;
|
|
25
|
-
_targetAutocomplete;
|
|
26
|
-
_targetAutocompleteChips;
|
|
13
|
+
_el = inject(ElementRef);
|
|
14
|
+
_focusController = inject(FocusControllerService);
|
|
15
|
+
_targetSelect = inject(MatSelect, { optional: true, self: true });
|
|
16
|
+
_targetDate = inject(FsDatePickerComponent, { optional: true, self: true });
|
|
17
|
+
_targetDateScroll = inject(FsDateScrollPickerComponent, { optional: true, self: true });
|
|
18
|
+
_targetDateRangeFrom = inject(DateRangePickerFromComponent, { optional: true, self: true });
|
|
19
|
+
_targetDateRangeTo = inject(DateRangePickerToComponent, { optional: true, self: true });
|
|
20
|
+
_targetAutocomplete = inject(FsAutocompleteComponent, { optional: true, self: true });
|
|
21
|
+
_targetAutocompleteChips = inject(FsAutocompleteChipsComponent, { optional: true, self: true });
|
|
27
22
|
_item;
|
|
28
23
|
_focusTargetType;
|
|
29
24
|
_destroy$ = new Subject();
|
|
30
|
-
constructor(_el, _focusController, _targetSelect, _targetDate, _targetDateScroll, _targetDateRangeFrom, _targetDateRangeTo, _targetAutocomplete, _targetAutocompleteChips) {
|
|
31
|
-
this._el = _el;
|
|
32
|
-
this._focusController = _focusController;
|
|
33
|
-
this._targetSelect = _targetSelect;
|
|
34
|
-
this._targetDate = _targetDate;
|
|
35
|
-
this._targetDateScroll = _targetDateScroll;
|
|
36
|
-
this._targetDateRangeFrom = _targetDateRangeFrom;
|
|
37
|
-
this._targetDateRangeTo = _targetDateRangeTo;
|
|
38
|
-
this._targetAutocomplete = _targetAutocomplete;
|
|
39
|
-
this._targetAutocompleteChips = _targetAutocompleteChips;
|
|
40
|
-
}
|
|
41
25
|
ngOnInit() {
|
|
42
26
|
this._focusController
|
|
43
27
|
.listenFocusFor$(this._item, this._focusTargetType)
|
|
@@ -95,7 +79,7 @@ export class FocusToItemDirective {
|
|
|
95
79
|
break;
|
|
96
80
|
}
|
|
97
81
|
}
|
|
98
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FocusToItemDirective, deps: [
|
|
82
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FocusToItemDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
99
83
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: FocusToItemDirective, isStandalone: true, selector: "[fsFilterFocusTrigger]", inputs: { _item: ["fsFilterFocusTrigger", "_item"], _focusTargetType: ["focusTargetType", "_focusTargetType"] }, ngImport: i0 });
|
|
100
84
|
}
|
|
101
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FocusToItemDirective, decorators: [{
|
|
@@ -104,39 +88,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
104
88
|
selector: '[fsFilterFocusTrigger]',
|
|
105
89
|
standalone: true,
|
|
106
90
|
}]
|
|
107
|
-
}],
|
|
108
|
-
type: Optional
|
|
109
|
-
}, {
|
|
110
|
-
type: Self
|
|
111
|
-
}] }, { type: i3.FsDatePickerComponent, decorators: [{
|
|
112
|
-
type: Optional
|
|
113
|
-
}, {
|
|
114
|
-
type: Self
|
|
115
|
-
}] }, { type: i3.FsDateScrollPickerComponent, decorators: [{
|
|
116
|
-
type: Optional
|
|
117
|
-
}, {
|
|
118
|
-
type: Self
|
|
119
|
-
}] }, { type: i3.DateRangePickerFromComponent, decorators: [{
|
|
120
|
-
type: Optional
|
|
121
|
-
}, {
|
|
122
|
-
type: Self
|
|
123
|
-
}] }, { type: i3.DateRangePickerToComponent, decorators: [{
|
|
124
|
-
type: Optional
|
|
125
|
-
}, {
|
|
126
|
-
type: Self
|
|
127
|
-
}] }, { type: i4.FsAutocompleteComponent, decorators: [{
|
|
128
|
-
type: Optional
|
|
129
|
-
}, {
|
|
130
|
-
type: Self
|
|
131
|
-
}] }, { type: i5.FsAutocompleteChipsComponent, decorators: [{
|
|
132
|
-
type: Optional
|
|
133
|
-
}, {
|
|
134
|
-
type: Self
|
|
135
|
-
}] }], propDecorators: { _item: [{
|
|
91
|
+
}], propDecorators: { _item: [{
|
|
136
92
|
type: Input,
|
|
137
93
|
args: ['fsFilterFocusTrigger']
|
|
138
94
|
}], _focusTargetType: [{
|
|
139
95
|
type: Input,
|
|
140
96
|
args: ['focusTargetType']
|
|
141
97
|
}] } });
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"focus-to-item.directive.js","sourceRoot":"","sources":["../../../../src/app/directives/focus-to-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnDestroy, OnInit, inject } from '@angular/core';\n\nimport { MatSelect } from '@angular/material/select';\n\nimport { FsAutocompleteComponent } from '@firestitch/autocomplete';\nimport { FsAutocompleteChipsComponent } from '@firestitch/autocomplete-chips';\nimport {\n  DateRangePickerFromComponent, DateRangePickerToComponent,\n  FsDatePickerComponent,\n  FsDateScrollPickerComponent,\n} from '@firestitch/datepicker';\n\nimport { Subject } from 'rxjs';\nimport { delay, takeUntil } from 'rxjs/operators';\n\nimport { ItemDateMode } from '../enums/item-date-mode.enum';\nimport { ItemType } from '../enums/item-type.enum';\nimport { FocusControllerService } from '../services/focus-controller.service';\n\n\n@Directive({\n  selector: '[fsFilterFocusTrigger]',\n  standalone: true,\n})\nexport class FocusToItemDirective implements OnInit, OnDestroy {\n  private _el = inject(ElementRef);\n  private _focusController = inject(FocusControllerService);\n  private _targetSelect = inject(MatSelect, { optional: true, self: true });\n  private _targetDate = inject(FsDatePickerComponent, { optional: true, self: true });\n  private _targetDateScroll = inject(FsDateScrollPickerComponent, { optional: true, self: true });\n  private _targetDateRangeFrom = inject(DateRangePickerFromComponent, { optional: true, self: true });\n  private _targetDateRangeTo = inject(DateRangePickerToComponent, { optional: true, self: true });\n  private _targetAutocomplete = inject(FsAutocompleteComponent, { optional: true, self: true });\n  private _targetAutocompleteChips = inject(FsAutocompleteChipsComponent, { optional: true, self: true });\n\n\n  @Input('fsFilterFocusTrigger')\n  private _item;\n\n  @Input('focusTargetType')\n  private _focusTargetType;\n\n  private _destroy$ = new Subject<void>();\n\n  public ngOnInit(): void {\n    this._focusController\n      .listenFocusFor$(this._item, this._focusTargetType)\n      .pipe(\n        delay(500),\n        takeUntil(this._destroy$),\n      )\n      .subscribe(() => {\n        this._focus();\n      });\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n\n  private _focus() {\n    switch (this._item.type) {\n      case ItemType.Select: {\n        this._targetSelect.open();\n      } break;\n\n      case ItemType.Text: case ItemType.Range: {\n        this._el.nativeElement.focus();\n      } break;\n\n      case ItemType.Date: {\n        if (this._item.mode === ItemDateMode.Calendar) {\n          this._targetDate.open();\n        } else {\n          this._targetDateScroll.open();\n        }\n      } break;\n      case ItemType.DateRange: {\n        if (this._focusTargetType === 'from') {\n          this._targetDateRangeFrom.open();\n        } else {\n          this._targetDateRangeTo.open();\n        }\n      } break;\n\n      case ItemType.AutoComplete: {\n        this._targetAutocomplete.focus();\n      } break;\n\n      case ItemType.AutoCompleteChips: {\n        this._targetAutocompleteChips.focus();\n      } break;\n    }\n  }\n}\n"]}
|
|
@@ -1,11 +1,8 @@
|
|
|
1
|
-
import { Directive, TemplateRef } from '@angular/core';
|
|
1
|
+
import { Directive, TemplateRef, inject } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class FilterHeadingDirective {
|
|
4
|
-
templateRef;
|
|
5
|
-
|
|
6
|
-
this.templateRef = templateRef;
|
|
7
|
-
}
|
|
8
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterHeadingDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
4
|
+
templateRef = inject(TemplateRef);
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterHeadingDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
6
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: FilterHeadingDirective, isStandalone: true, selector: "[fsFilterHeading]", ngImport: i0 });
|
|
10
7
|
}
|
|
11
8
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterHeadingDirective, decorators: [{
|
|
@@ -14,5 +11,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
14
11
|
selector: '[fsFilterHeading]',
|
|
15
12
|
standalone: true,
|
|
16
13
|
}]
|
|
17
|
-
}]
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
}] });
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGluZy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2RpcmVjdGl2ZXMvaGVhZGluZy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU8vRCxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLFdBQVcsR0FBRyxNQUFNLENBQW1CLFdBQVcsQ0FBQyxDQUFDO3dHQUR6QyxzQkFBc0I7NEZBQXRCLHNCQUFzQjs7NEZBQXRCLHNCQUFzQjtrQkFKbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFRlbXBsYXRlUmVmLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZnNGaWx0ZXJIZWFkaW5nXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEZpbHRlckhlYWRpbmdEaXJlY3RpdmUge1xuICB0ZW1wbGF0ZVJlZiA9IGluamVjdDxUZW1wbGF0ZVJlZjxhbnk+PihUZW1wbGF0ZVJlZik7XG5cbn1cbiJdfQ==
|
|
@@ -1,11 +1,8 @@
|
|
|
1
|
-
import { Directive, TemplateRef } from '@angular/core';
|
|
1
|
+
import { Directive, TemplateRef, inject } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class FilterStatusBarDirective {
|
|
4
|
-
templateRef;
|
|
5
|
-
|
|
6
|
-
this.templateRef = templateRef;
|
|
7
|
-
}
|
|
8
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterStatusBarDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
4
|
+
templateRef = inject(TemplateRef);
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterStatusBarDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
6
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: FilterStatusBarDirective, isStandalone: true, selector: "[fsFilterStatusBar]", ngImport: i0 });
|
|
10
7
|
}
|
|
11
8
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterStatusBarDirective, decorators: [{
|
|
@@ -14,5 +11,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
14
11
|
selector: '[fsFilterStatusBar]',
|
|
15
12
|
standalone: true,
|
|
16
13
|
}]
|
|
17
|
-
}]
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
}] });
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzLWJhci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2RpcmVjdGl2ZXMvc3RhdHVzLWJhci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU8vRCxNQUFNLE9BQU8sd0JBQXdCO0lBQ25DLFdBQVcsR0FBRyxNQUFNLENBQW1CLFdBQVcsQ0FBQyxDQUFDO3dHQUR6Qyx3QkFBd0I7NEZBQXhCLHdCQUF3Qjs7NEZBQXhCLHdCQUF3QjtrQkFKcEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFRlbXBsYXRlUmVmLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZnNGaWx0ZXJTdGF0dXNCYXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRmlsdGVyU3RhdHVzQmFyRGlyZWN0aXZlIHtcbiAgdGVtcGxhdGVSZWYgPSBpbmplY3Q8VGVtcGxhdGVSZWY8YW55Pj4oVGVtcGxhdGVSZWYpO1xuXG59XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hcHAvaW50ZXJmYWNlcy9jb25maWcuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCdXR0b25TdHlsZSB9IGZyb20gJy4uL2VudW1zJztcblxuaW1wb3J0IHsgRnNGaWx0ZXJBY3Rpb24gfSBmcm9tICcuL2FjdGlvbi5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUZpbHRlckNvbmZpZ0tleXdvcmRJdGVtIH0gZnJvbSAnLi9pdGVtcyc7XG5pbXBvcnQgeyBJRmlsdGVyQ29uZmlnQXV0b2NvbXBsZXRlQ2hpcHNJdGVtIH0gZnJvbSAnLi9pdGVtcy9hdXRvY29tcGxldGUtY2hpcHMuaW50ZXJmYWNlJztcbmltcG9ydCB7IElGaWx0ZXJDb25maWdBdXRvY29tcGxldGVJdGVtIH0gZnJvbSAnLi9pdGVtcy9hdXRvY29tcGxldGUuaW50ZXJmYWNlJztcbmltcG9ydCB7IElGaWx0ZXJDb25maWdCYXNlSXRlbSB9IGZyb20gJy4vaXRlbXMvYmFzZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUZpbHRlckNvbmZpZ0NoZWNrYm94SXRlbSB9IGZyb20gJy4vaXRlbXMvY2hlY2tib3guaW50ZXJmYWNlJztcbmltcG9ydCB7IElGaWx0ZXJDb25maWdDaGlwc0l0ZW0gfSBmcm9tICcuL2l0ZW1zL2NoaXBzLmludGVyZmFjZSc7XG5pbXBvcnQgeyBJRmlsdGVyQ29uZmlnRGF0ZVJhbmdlSXRlbSB9IGZyb20gJy4vaXRlbXMvZGF0ZS1yYW5nZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUZpbHRlckNvbmZpZ0RhdGVJdGVtIH0gZnJvbSAnLi9pdGVtcy9kYXRlLmludGVyZmFjZSc7XG5pbXBvcnQgeyBJRmlsdGVyQ29uZmlnUmFuZ2VJdGVtIH0gZnJvbSAnLi9pdGVtcy9yYW5nZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUZpbHRlckNvbmZpZ1NlbGVjdEl0ZW0gfSBmcm9tICcuL2l0ZW1zL3NlbGVjdC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgSUZpbHRlckNvbmZpZ1RleHRJdGVtIH0gZnJvbSAnLi9pdGVtcy90ZXh0LmludGVyZmFjZSc7XG5pbXBvcnQgeyBJRmlsdGVyU2F2ZWRGaWx0ZXJzQ29uZmlnIH0gZnJvbSAnLi9zYXZlZC1maWx0ZXJzLmludGVyZmFjZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmlsdGVyQ29uZmlnIHtcbiAgbG9hZD86IGJvb2xlYW47XG4gIGNoaXBzPzogYm9vbGVhbjtcbiAgYXV0b2ZvY3VzPzogYm9vbGVhbjtcbiAgcXVlcnlQYXJhbT86IGJvb2xlYW47XG4gIG5hbWVzcGFjZT86IHN0cmluZztcbiAgcGVyc2lzdD86IEZzRmlsdGVyUGVyc2lzdGFuY2U7XG4gIHJlbG9hZD86IGJvb2xlYW47XG4gIGNsZWFyPzogQ2hhbmdlRm47XG4gIGl0ZW1zPzogSUZpbHRlckNvbmZpZ0l0ZW1bXTtcbiAgaW5pdD86IENoYW5nZUZuO1xuICBjaGFuZ2U/OiBDaGFuZ2VGbjtcbiAgc29ydD86IFNvcnQ7XG4gIHNvcnRDaGFuZ2U/OiBDaGFuZ2VGbjtcbiAgcmVsb2FkV2hlbkNvbmZpZ0NoYW5nZWQ/OiBib29sZWFuO1xuICBjYXNlPzogJ3NuYWtlJyB8ICdjYW1lbCc7XG4gIGJ1dHRvbj86IEZpbHRlckJ1dHRvbjtcbiAgYnV0dG9uU3R5bGU/OiBCdXR0b25TdHlsZTtcbiAgc2F2ZWRGaWx0ZXJzPzogSUZpbHRlclNhdmVkRmlsdGVyc0NvbmZpZztcbiAgYWN0aW9ucz86IEZzRmlsdGVyQWN0aW9uW107XG4gIGF1dG9SZWxvYWQ/OiBGc0ZpbHRlckF1dG9SZWxvYWQ7ICBcbiAgaGVhZGluZz86IHN0cmluZztcbiAgc3ViaGVhZGluZz86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGc0ZpbHRlckF1dG9SZWxvYWQge1xuICBlbmFibGVkPzogYm9vbGVhbjtcbiAgc2Vjb25kcz86IG51bWJlcjtcbn1cblxuZXhwb3J0IHR5cGUgSUZpbHRlckNvbmZpZ0l0ZW0gPVxuICAoXG4gICAgSUZpbHRlckNvbmZpZ0Jhc2VJdGVtXG4gICAgfCBJRmlsdGVyQ29uZmlnQ2hlY2tib3hJdGVtXG4gICAgfCBJRmlsdGVyQ29uZmlnU2VsZWN0SXRlbVxuICAgIHwgSUZpbHRlckNvbmZpZ0NoaXBzSXRlbVxuICAgIHwgSUZpbHRlckNvbmZpZ1RleHRJdGVtXG4gICAgfCBJRmlsdGVyQ29uZmlnS2V5d29yZEl0ZW1cbiAgICB8IElGaWx0ZXJDb25maWdEYXRlSXRlbVxuICAgIHwgSUZpbHRlckNvbmZpZ0F1dG9jb21wbGV0ZUl0ZW1cbiAgICB8IElGaWx0ZXJDb25maWdBdXRvY29tcGxldGVDaGlwc0l0ZW1cbiAgICB8IElGaWx0ZXJDb25maWdSYW5nZUl0ZW1cbiAgICB8IElGaWx0ZXJDb25maWdEYXRlUmFuZ2VJdGVtXG4gICk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU29ydEl0ZW0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU29ydCB7XG4gIGRpcmVjdGlvbj86IHN0cmluZztcbiAgdmFsdWU/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmlsdGVyQnV0dG9uIHtcbiAgc3R5bGU/OiBCdXR0b25TdHlsZTtcbiAgY29sb3I/OiAncHJpbWFyeScgfCAnZGVmYXVsdCcsXG4gIGljb24/OiBzdHJpbmcsXG4gIGxhYmVsPzogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2hhbmdlRm4ge1xuICAocXVlcnk/OiBhbnksIHNvcnQ/OiBGaWx0ZXJTb3J0IHwgbnVsbCk6IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmlsdGVyU29ydCB7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIGRpcmVjdGlvbjogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZzRmlsdGVyUGVyc2lzdGFuY2VDb25maWcge1xuICBuYW1lPzogc3RyaW5nO1xuICB0aW1lb3V0PzogbnVtYmVyO1xufVxuXG5leHBvcnQgdHlwZSBGc0ZpbHRlclBlcnNpc3RhbmNlID0gYm9vbGVhbiB8IEZzRmlsdGVyUGVyc2lzdGFuY2VDb25maWc7XG4iXX0=
|
|
@@ -14,7 +14,7 @@ export class FsFilterConfig {
|
|
|
14
14
|
queryParam = false;
|
|
15
15
|
init;
|
|
16
16
|
change;
|
|
17
|
-
reload;
|
|
17
|
+
reload = true;
|
|
18
18
|
autoReload;
|
|
19
19
|
clear;
|
|
20
20
|
sortChange;
|
|
@@ -86,4 +86,4 @@ export class FsFilterConfig {
|
|
|
86
86
|
}
|
|
87
87
|
}
|
|
88
88
|
}
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-config.js","sourceRoot":"","sources":["../../../../src/app/models/filter-config.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAYvC,MAAM,CAAC,MAAM,WAAW,GAAG,UAAU,CAAC;AACtC,MAAM,CAAC,MAAM,kBAAkB,GAAG,eAAe,CAAC;AAGlD,MAAM,OAAO,cAAc;IAElB,IAAI,GAAG,IAAI,CAAC;IACZ,OAAO,GAAwB,KAAK,CAAC;IACrC,YAAY,CAA4B;IACxC,MAAM,GAAG,KAAK,CAAC;IACf,SAAS,GAAG,KAAK,CAAC;IAClB,KAAK,GAAG,KAAK,CAAC;IACd,WAAW,CAAc;IACzB,UAAU,GAAU,IAAI,CAAC;IACzB,IAAI,GAAS,IAAI,CAAC;IAClB,UAAU,GAAG,KAAK,CAAC;IACnB,IAAI,CAA4E;IAChF,MAAM,CAAW;IACjB,MAAM,GAAY,IAAI,CAAC;IACvB,UAAU,CAAqB;IAC/B,KAAK,CAAW;IAChB,UAAU,CAAW;IACrB,MAAM,CAAe;IACrB,KAAK,CAAsB;IAC3B,OAAO,CAAmB;IAC1B,SAAS,CAAS,CAAC,kBAAkB;IACrC,OAAO,CAAS;IAChB,UAAU,CAAS;IAE1B,YAAY,OAAqB,EAAE;QACjC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,CAAC;IAEO,KAAK,CAAC,OAAqB,EAAE;QACnC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE;YAClB,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,IAAI;YACvB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,KAAK;YAClC,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,KAAK;YAC1B,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,UAAU,EAAE,IAAI,CAAC,UAAU,IAAI,KAAK;YACpC,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;gBAC5B,GAAG,IAAI,CAAC,UAAU;gBAClB,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK;aACnE,CAAC,CAAC,CAAC,IAAI;YACR,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,OAAO;YAC1B,uBAAuB,EAAE,IAAI,CAAC,uBAAuB;YACrD,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,IAAI;YACjD,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU;SAC5B,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;gBACrC,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;oBACtB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;gBACrC,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,GAAG,EAAE;gBAChB,EAAE;YACJ,CAAC,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAEO,WAAW,CAAC,IAAkB;QACpC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACnB,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YACpC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,SAAS,CAAC;QAChC,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YACnC,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,eAAe,CAAC;QACrC,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YACpC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM,CAAC;QACzC,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YACpC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,SAAS,CAAC;QAChC,CAAC;IACH,CAAC;CACF","sourcesContent":["import type { FilterComponent } from '../components/filter/filter.component';\nimport { ButtonStyle } from '../enums';\nimport { FsFilterAction } from '../interfaces/action.interface';\nimport { ChangeFn, FilterSort, FsFilterAutoReload, Sort } from '../interfaces/config.interface';\nimport { IFilterSavedFiltersConfig } from '../interfaces/saved-filters.interface';\n\nimport {\n  FilterButton,\n  FilterConfig,\n  FsFilterPersistance,\n  IFilterConfigItem,\n} from './../interfaces/config.interface';\n\nexport const SortByField = 'sortName';\nexport const SortDirectionField = 'sortDirection';\n\n\nexport class FsFilterConfig {\n\n  public load = true;\n  public persist: FsFilterPersistance = false;\n  public savedFilters: IFilterSavedFiltersConfig;\n  public inline = false;\n  public autofocus = false;\n  public chips = false;\n  public buttonStyle: ButtonStyle;\n  public sortValues: any[] = null;\n  public sort: Sort = null;\n  public queryParam = false;\n  public init: (query?: any, sort?: FilterSort | null, filter?: FilterComponent) => void;\n  public change: ChangeFn;\n  public reload: boolean = true;\n  public autoReload: FsFilterAutoReload;\n  public clear: ChangeFn;\n  public sortChange: ChangeFn;\n  public button: FilterButton;\n  public items: IFilterConfigItem[];\n  public actions: FsFilterAction[];\n  public namespace: string; // for persistance\n  public heading: string;\n  public subheading: string;\n\n  constructor(data: FilterConfig = {}) {\n    this._init(data);\n  }\n\n  private _init(data: FilterConfig = {}) {\n    Object.assign(this, {\n      load: data.load ?? true,\n      persist: data.persist,\n      savedFilters: data.savedFilters,\n      autofocus: data.autofocus ?? false,\n      chips: data.chips ?? false,\n      sort: data.sort,\n      queryParam: data.queryParam ?? false,\n      init: data.init,\n      change: data.change,\n      reload: data.reload,\n      autoReload: data.autoReload ? {\n        ...data.autoReload,\n        enabled: data.autoReload ? data.autoReload.enabled ?? true : false,\n      } : null,\n      clear: data.clear,\n      sortChange: data.sortChange,\n      case: data.case ?? 'camel',\n      reloadWhenConfigChanged: data.reloadWhenConfigChanged,\n      items: data.items,\n      actions: data.actions,\n      buttonStyle: data.buttonStyle || ButtonStyle.Flat,\n      heading: data.heading,\n      subheading: data.subheading,\n    });\n\n    if (this.persist) {\n      if (typeof this.persist === 'object') {\n        if (this.persist.name) {\n          this.namespace = this.persist.name;\n        }\n      }\n    }\n\n    if (this.clear === undefined) {\n      this.clear = () => { \n        //\n      };\n    }\n\n    this._initButton(data);\n  }\n\n  private _initButton(data: FilterConfig): void {\n    this.button = data.button;\n    if (!this.button) {\n      this.button = {};\n    }\n\n    if (this.button.label === undefined) {\n      this.button.label = 'Filters';\n    }\n\n    if (this.button.icon === undefined) {\n      this.button.icon = 'filterOutline';\n    }\n\n    if (this.button.style === undefined) {\n      this.button.style = ButtonStyle.Raised;\n    }\n\n    if (this.button.color === undefined) {\n      this.button.color = 'default';\n    }\n  }\n}\n"]}
|