@firestitch/filter 18.2.116 → 18.2.117

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.
@@ -7,12 +7,12 @@ import * as i0 from "@angular/core";
7
7
  export declare class DateRangeComponent extends BaseItemComponent<DateRangeItem | DateTimeRangeItem> implements OnInit, OnDestroy {
8
8
  autofocusName: string;
9
9
  floatLabel: 'auto' | 'always';
10
- private _fromPicker;
11
- private _toPicker;
12
10
  viewType: PickerViewType;
13
11
  from: Date;
14
12
  to: Date;
15
13
  initialized: boolean;
14
+ private _fromPicker;
15
+ private _toPicker;
16
16
  ngOnInit(): void;
17
17
  ngOnDestroy(): void;
18
18
  change(): void;
@@ -12,4 +12,4 @@ import { RangeItem } from '../models/items/range-item';
12
12
  import { SelectItem } from '../models/items/select-item';
13
13
  import { TextItem } from '../models/items/text-item';
14
14
  import { WeekItem } from '../models/items/week-item';
15
- export declare function createFilterItem(item: IFilterConfigItem, filter: FilterComponent): SelectItem | ChipsItem | RangeItem | DateRangeItem | DateTimeRangeItem | DateItem | WeekItem | DateTimeItem | AutocompleteItem | AutocompleteChipsItem | CheckboxItem | TextItem;
15
+ export declare function createFilterItem(item: IFilterConfigItem, filter: FilterComponent): DateRangeItem | DateTimeRangeItem | TextItem | SelectItem | ChipsItem | RangeItem | AutocompleteItem | AutocompleteChipsItem | DateItem | DateTimeItem | WeekItem | CheckboxItem;
@@ -16,12 +16,12 @@ import * as i3 from "@firestitch/form";
16
16
  export class DateRangeComponent extends BaseItemComponent {
17
17
  autofocusName;
18
18
  floatLabel = 'auto';
19
- _fromPicker;
20
- _toPicker;
21
19
  viewType = PickerViewType.Date;
22
20
  from;
23
21
  to;
24
22
  initialized = false;
23
+ _fromPicker;
24
+ _toPicker;
25
25
  ngOnInit() {
26
26
  super.ngOnInit();
27
27
  console.log('[DateRangeComponent] ngOnInit', this.item.name);
@@ -34,12 +34,7 @@ export class DateRangeComponent extends BaseItemComponent {
34
34
  this.to = value?.to;
35
35
  if (!this.initialized) {
36
36
  this.initialized = true;
37
- if (this.item.primary) {
38
- this.autofocusName = null;
39
- }
40
- else {
41
- this.autofocusName = this.from ? 'to' : 'from';
42
- }
37
+ this.autofocusName = this.item.primary ? null : 'from';
43
38
  console.log('[DateRangeComponent] initialized, autofocusName:', this.autofocusName);
44
39
  }
45
40
  this._cdRef.markForCheck();
@@ -96,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
96
91
  type: ViewChild,
97
92
  args: [DateRangePickerToComponent]
98
93
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../../src/app/components/filters-item/date-range/date-range.component.ts","../../../../../../src/app/components/filters-item/date-range/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\n\nimport { MatFormField, MatLabel } from '@angular/material/form-field';\nimport { MatInput } from '@angular/material/input';\n\nimport {\n  DateRangePickerFromComponent,\n  DateRangePickerToComponent,\n  FsDatePickerModule,\n} from '@firestitch/datepicker';\nimport { FsFormModule } from '@firestitch/form';\n\n\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { FocusToItemDirective } from '../../../directives/focus-to-item.directive';\nimport { ItemType } from '../../../enums/item-type.enum';\nimport { PickerViewType } from '../../../enums/picker-view-type.enum';\nimport { DateRangeItem } from '../../../models/items/date-range-item';\nimport { DateTimeRangeItem } from '../../../models/items/date-time-range-item';\nimport { BaseItemComponent } from '../base-item/base-item.component';\n\n\n@Component({\n  selector: 'filter-item-date-range',\n  templateUrl: './date-range.component.html',\n  styleUrls: ['./date-range.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    MatFormField,\n    MatLabel,\n    MatInput,\n    FormsModule,\n    FocusToItemDirective,\n    FsDatePickerModule,\n    FsFormModule,\n  ],\n})\nexport class  DateRangeComponent \n  extends BaseItemComponent<DateRangeItem | DateTimeRangeItem> implements OnInit, OnDestroy {\n\n  @Input() public autofocusName: string;\n  @Input() public floatLabel: 'auto' | 'always' = 'auto';\n\n  @ViewChild(DateRangePickerFromComponent)\n  private _fromPicker: DateRangePickerFromComponent;\n\n  @ViewChild(DateRangePickerToComponent)\n  private _toPicker: DateRangePickerToComponent;\n\n  public viewType = PickerViewType.Date;\n  public from: Date;\n  public to: Date;\n  public initialized = false;\n\n  public ngOnInit() {\n    super.ngOnInit();\n    console.log('[DateRangeComponent] ngOnInit', this.item.name);\n\n    this.viewType = this.item.type === ItemType.DateTimeRange ? \n      PickerViewType.DateTime : PickerViewType.Date;\n\n    this.item.value$\n      .pipe(\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe((value: { from?: Date; to?: Date }) => {\n        this.from = value?.from;\n        this.to = value?.to;\n\n        if(!this.initialized) {\n          this.initialized = true;\n          if(this.item.primary) {\n            this.autofocusName = null;\n          } else {\n            this.autofocusName = this.from ? 'to' : 'from';\n          }\n          console.log('[DateRangeComponent] initialized, autofocusName:', this.autofocusName);\n        }\n\n        this._cdRef.markForCheck();\n      });\n  }\n  \n  public ngOnDestroy(): void {\n    console.log('[DateRangeComponent] ngOnDestroy', this.item.name, {\n      fromDialogOpen: !!this._fromPicker?.dateDialogRef,\n      toDialogOpen: !!this._toPicker?.dateDialogRef,\n    });\n    \n    // Close any open datepicker dialogs to prevent overlay leaks.\n    // RangePickerComponent.ngOnDestroy() does not call close() (unlike\n    // FsDatePickerBaseComponent), so the calendar overlay stays in the DOM\n    // if we don't clean it up here.\n    this._fromPicker?.dateDialogRef?.close();\n    this._toPicker?.dateDialogRef?.close();\n\n    if(this.triggerChangeOn === 'close') {\n      this.item.value = this.getValue;\n    }\n  }\n\n  public change() {\n    if(this.triggerChangeOn === 'change') {\n      this.item.value = this.getValue;\n    }\n  }\n\n  public get getValue() {\n    return {\n      from: this.from,\n      to: this.to,\n    };\n  }\n}\n","@if (initialized) {\n  <div class=\"row\">\n    <mat-form-field\n        [floatLabel]=\"floatLabel\"\n        class=\"form-field-padless\">\n      <mat-label>\n        {{ item.fromLabel }}\n      </mat-label>\n      <input\n        matInput\n        [fsFilterFocusTrigger]=\"autofocusName === 'from'\"\n        [fsDateRangeFrom]=\"item.name\"\n        [(ngModel)]=\"from\"\n        (ngModelChange)=\"change()\"\n        [clear]=\"item.clearable\"\n        [view]=\"viewType\"\n        name=\"dateFrom\">\n    </mat-form-field>\n    <div class=\"to\">\n      to\n    </div>\n    <mat-form-field\n        [floatLabel]=\"floatLabel\"\n        class=\"form-field-padless\">\n      <mat-label>\n        {{ item.toLabel }}\n      </mat-label>\n      <input\n        matInput\n        [fsFilterFocusTrigger]=\"autofocusName === 'to'\"\n        [fsDateRangeTo]=\"item.name\"\n        [(ngModel)]=\"to\"\n        (ngModelChange)=\"change()\"\n        [clear]=\"item.clearable\"\n        [view]=\"viewType\"\n        name=\"dateTo\">\n    </mat-form-field>\n  </div>\n}\n"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../../src/app/components/filters-item/date-range/date-range.component.ts","../../../../../../src/app/components/filters-item/date-range/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\n\nimport { MatFormField, MatLabel } from '@angular/material/form-field';\nimport { MatInput } from '@angular/material/input';\n\nimport {\n  DateRangePickerFromComponent,\n  DateRangePickerToComponent,\n  FsDatePickerModule,\n} from '@firestitch/datepicker';\nimport { FsFormModule } from '@firestitch/form';\n\n\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { FocusToItemDirective } from '../../../directives/focus-to-item.directive';\nimport { ItemType } from '../../../enums/item-type.enum';\nimport { PickerViewType } from '../../../enums/picker-view-type.enum';\nimport { DateRangeItem } from '../../../models/items/date-range-item';\nimport { DateTimeRangeItem } from '../../../models/items/date-time-range-item';\nimport { BaseItemComponent } from '../base-item/base-item.component';\n\n\n@Component({\n  selector: 'filter-item-date-range',\n  templateUrl: './date-range.component.html',\n  styleUrls: ['./date-range.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    MatFormField,\n    MatLabel,\n    MatInput,\n    FormsModule,\n    FocusToItemDirective,\n    FsDatePickerModule,\n    FsFormModule,\n  ],\n})\nexport class  DateRangeComponent \n  extends BaseItemComponent<DateRangeItem | DateTimeRangeItem> implements OnInit, OnDestroy {\n\n  @Input() public autofocusName: string;\n  @Input() public floatLabel: 'auto' | 'always' = 'auto';\n  \n  public viewType = PickerViewType.Date;\n  public from: Date;\n  public to: Date;\n  public initialized = false;\n\n\n  @ViewChild(DateRangePickerFromComponent)\n  private _fromPicker: DateRangePickerFromComponent;\n\n  @ViewChild(DateRangePickerToComponent)\n  private _toPicker: DateRangePickerToComponent;\n\n  public ngOnInit() {\n    super.ngOnInit();\n    console.log('[DateRangeComponent] ngOnInit', this.item.name);\n\n    this.viewType = this.item.type === ItemType.DateTimeRange ? \n      PickerViewType.DateTime : PickerViewType.Date;\n\n    this.item.value$\n      .pipe(\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe((value: { from?: Date; to?: Date }) => {\n        this.from = value?.from;\n        this.to = value?.to;\n\n        if(!this.initialized) {\n          this.initialized = true;\n          this.autofocusName = this.item.primary ? null : 'from';\n          console.log('[DateRangeComponent] initialized, autofocusName:', this.autofocusName);\n        }\n\n        this._cdRef.markForCheck();\n      });\n  }\n  \n  public ngOnDestroy(): void {\n    console.log('[DateRangeComponent] ngOnDestroy', this.item.name, {\n      fromDialogOpen: !!this._fromPicker?.dateDialogRef,\n      toDialogOpen: !!this._toPicker?.dateDialogRef,\n    });\n    \n    // Close any open datepicker dialogs to prevent overlay leaks.\n    // RangePickerComponent.ngOnDestroy() does not call close() (unlike\n    // FsDatePickerBaseComponent), so the calendar overlay stays in the DOM\n    // if we don't clean it up here.\n    this._fromPicker?.dateDialogRef?.close();\n    this._toPicker?.dateDialogRef?.close();\n\n    if(this.triggerChangeOn === 'close') {\n      this.item.value = this.getValue;\n    }\n  }\n\n  public change() {\n    if(this.triggerChangeOn === 'change') {\n      this.item.value = this.getValue;\n    }\n  }\n\n  public get getValue() {\n    return {\n      from: this.from,\n      to: this.to,\n    };\n  }\n}\n","@if (initialized) {\n  <div class=\"row\">\n    <mat-form-field\n        [floatLabel]=\"floatLabel\"\n        class=\"form-field-padless\">\n      <mat-label>\n        {{ item.fromLabel }}\n      </mat-label>\n      <input\n        matInput\n        [fsFilterFocusTrigger]=\"autofocusName === 'from'\"\n        [fsDateRangeFrom]=\"item.name\"\n        [(ngModel)]=\"from\"\n        (ngModelChange)=\"change()\"\n        [clear]=\"item.clearable\"\n        [view]=\"viewType\"\n        name=\"dateFrom\">\n    </mat-form-field>\n    <div class=\"to\">\n      to\n    </div>\n    <mat-form-field\n        [floatLabel]=\"floatLabel\"\n        class=\"form-field-padless\">\n      <mat-label>\n        {{ item.toLabel }}\n      </mat-label>\n      <input\n        matInput\n        [fsFilterFocusTrigger]=\"autofocusName === 'to'\"\n        [fsDateRangeTo]=\"item.name\"\n        [(ngModel)]=\"to\"\n        (ngModelChange)=\"change()\"\n        [clear]=\"item.clearable\"\n        [view]=\"viewType\"\n        name=\"dateTo\">\n    </mat-form-field>\n  </div>\n}\n"]}
@@ -2894,12 +2894,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
2894
2894
  class DateRangeComponent extends BaseItemComponent {
2895
2895
  autofocusName;
2896
2896
  floatLabel = 'auto';
2897
- _fromPicker;
2898
- _toPicker;
2899
2897
  viewType = PickerViewType.Date;
2900
2898
  from;
2901
2899
  to;
2902
2900
  initialized = false;
2901
+ _fromPicker;
2902
+ _toPicker;
2903
2903
  ngOnInit() {
2904
2904
  super.ngOnInit();
2905
2905
  console.log('[DateRangeComponent] ngOnInit', this.item.name);
@@ -2912,12 +2912,7 @@ class DateRangeComponent extends BaseItemComponent {
2912
2912
  this.to = value?.to;
2913
2913
  if (!this.initialized) {
2914
2914
  this.initialized = true;
2915
- if (this.item.primary) {
2916
- this.autofocusName = null;
2917
- }
2918
- else {
2919
- this.autofocusName = this.from ? 'to' : 'from';
2920
- }
2915
+ this.autofocusName = this.item.primary ? null : 'from';
2921
2916
  console.log('[DateRangeComponent] initialized, autofocusName:', this.autofocusName);
2922
2917
  }
2923
2918
  this._cdRef.markForCheck();