@firestitch/filter 18.2.106 → 18.2.107

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.
@@ -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): WeekItem | TextItem | SelectItem | RangeItem | DateItem | DateTimeItem | DateRangeItem | DateTimeRangeItem | ChipsItem | AutocompleteItem | AutocompleteChipsItem | CheckboxItem;
15
+ export declare function createFilterItem(item: IFilterConfigItem, filter: FilterComponent): AutocompleteItem | CheckboxItem | ChipsItem | DateItem | DateRangeItem | DateTimeItem | DateTimeRangeItem | TextItem | RangeItem | SelectItem | WeekItem | AutocompleteChipsItem;
@@ -89,6 +89,7 @@ export class FsFilterChipsComponent {
89
89
  this.openChip(item, name);
90
90
  }
91
91
  openChip(item, name = null) {
92
+ console.log('[FilterChips] openChip', item.name, 'type:', item.type, 'existingOverlay:', !!this._overlayRef);
92
93
  this._destroyOverlay();
93
94
  const el = this._elementRef.nativeElement
94
95
  .querySelector(`[data-filter-item="${item.name}"]`);
@@ -171,6 +172,7 @@ export class FsFilterChipsComponent {
171
172
  }
172
173
  _destroyOverlay() {
173
174
  if (this._overlayRef) {
175
+ console.log('[FilterChips] _destroyOverlay - disposing existing overlay');
174
176
  try {
175
177
  this._overlayRef.detachBackdrop();
176
178
  this._overlayRef.detach();
@@ -314,4 +316,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
314
316
  type: ViewChildren,
315
317
  args: [FsChipComponent]
316
318
  }] } });
317
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-chips.component.js","sourceRoot":"","sources":["../../../../../src/app/components/filter-chips/filter-chips.component.ts","../../../../../src/app/components/filter-chips/filter-chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, Injector, OnInit, QueryList, StaticProvider, ViewChildren, inject, signal } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\n\nimport { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialog } from '@angular/material/dialog';\n\nimport { FsChipComponent, FsChipModule, FsChipSelectTriggerDirective } from '@firestitch/chip';\nimport { FsMessage } from '@firestitch/message';\nimport { FsSelectButtonModule } from '@firestitch/selectbutton';\n\nimport { BehaviorSubject, Observable, delay, merge, skip, take, tap } from 'rxjs';\n\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { ItemType } from '../../enums';\nimport { FILTER_DRAWER_DATA } from '../../injectors';\nimport { IFilterConfigItem } from '../../interfaces';\nimport { BaseItem } from '../../models/items/base-item';\nimport { SavedFilterController } from '../../services';\nimport { FilterController } from '../../services/filter-controller.service';\nimport { FilterItemDialogComponent } from '../filter-item-dialog';\nimport { FsFilterSavedFilterManageComponent } from '../saved-filter/saved-filter-manage/saved-filter-manage.component';\n\n\n@Component({\n  selector: 'fs-filter-chips',\n  templateUrl: './filter-chips.component.html',\n  styleUrls: ['./filter-chips.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    FsChipModule,\n    FsSelectButtonModule,\n    MatButtonModule,\n    FormsModule,\n    FsChipSelectTriggerDirective,\n  ],\n})\nexport class FsFilterChipsComponent implements OnInit {\n\n  @ViewChildren(FsChipComponent) \n  public chips: QueryList<FsChipComponent>;\n\n  public ItemType = ItemType;\n  public secondaryItems: BaseItem<IFilterConfigItem>[] = [];\n  public moreFilterItems = signal<BaseItem<IFilterConfigItem>[]>([]);\n  public clearFiltersVisible = signal<boolean>(false);\n\n  private _filterController = inject(FilterController);\n  private _dialog = inject(MatDialog);\n  private _message = inject(FsMessage);\n  private _savedFilterController = inject(SavedFilterController);\n  private _injector = inject(Injector);\n  private _overlay = inject(Overlay);\n  private _overlayRef: OverlayRef;\n  private _destroyRef = inject(DestroyRef);\n  private _elementRef = inject(ElementRef);\n  private _hasSecondaryValue$ = new BehaviorSubject(false);\n\n  public get items(): BaseItem<IFilterConfigItem>[] {\n    return this._filterController.items;\n  }\n\n  public addFilter(item: BaseItem<IFilterConfigItem>) {\n    // For checkbox items, set to checked when adding from \"More filters\"\n    if (item.isTypeCheckbox && !item.hasValue) {\n      item.setValue(true);\n    }\n    \n    item.secondaryShow();\n\n    // Don't open overlay for secondary checkbox items\n    if (item.isTypeCheckbox && !item.primary) {\n      return;\n    }\n\n    this.chips.changes\n      .pipe(\n        take(1),\n        delay(100),\n        tap(() => {\n          this.openChip(item);\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n  }\n\n  public get hasSecondaryValue$(): Observable<boolean> {\n    return this._hasSecondaryValue$.asObservable();\n  }\n\n  public get savedFilterController(): SavedFilterController {\n    return this._savedFilterController;\n  }\n\n  public get hasSecondaryValue(): boolean {\n    return this._filterController.items\n      .some((item) => item.hasValue && item.visible && !item.primary);\n  }\n\n  public ngOnInit(): void {\n    this._initSecondaryItems();\n    this._initHasSecondaryValue();\n    this._initMoreFilterItems();\n    this._initClearFiltersVisible();\n  }\n\n  public clear() {\n    this._filterController.items\n      .filter((item) => item.clearable)\n      .forEach((item) => {\n        if(!item.secondary) {\n          item.secondaryHide();\n        }\n        item.clear(false);\n      });\n\n    this._filterController.change();\n    this._savedFilterController.setActiveFilter(null);\n  }\n\n  public handleChipClick(item: BaseItem<IFilterConfigItem>, name: string = null) {\n    // For secondary checkbox items, don't open overlay - clearing is done via remove button\n    if (item.isTypeCheckbox && !item.primary) {\n      return;\n    }\n\n    this.openChip(item, name);\n  }\n\n  public openChip(item: BaseItem<IFilterConfigItem>, name: string = null) {\n    this._destroyOverlay();\n    const el = this._elementRef.nativeElement\n      .querySelector(`[data-filter-item=\"${item.name}\"]`);\n\n    const positions: ConnectedPosition[] = [\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'top',\n        offsetX: 0,\n        offsetY: el.offsetHeight + 2,\n      },\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'bottom',\n      },\n    ];\n\n    const strategy = this._overlay\n      .position()\n      .flexibleConnectedTo(el)\n      .withPositions(positions);\n    \n    const overlayConfig = new OverlayConfig({\n      positionStrategy: strategy,\n      scrollStrategy: this._overlay.scrollStrategies.block(),\n      disposeOnNavigation: true,\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      panelClass: 'fs-sidenav-menu-overlay-pane',\n    });\n\n    this._overlayRef = this._overlay.create(overlayConfig);\n\n    this._overlayRef.backdropClick().pipe(\n      take(1),\n      tap(() => {\n        this._destroyOverlay();\n      }),\n      takeUntilDestroyed(this._destroyRef),\n    ).subscribe();\n\n    this._overlayRef.detachments().pipe(\n      take(1),\n      tap(() => {\n        this._overlayRef = null;\n      }),\n      takeUntilDestroyed(this._destroyRef),\n    ).subscribe();\n\n    this._attachContainer(this._overlayRef, item, name);\n  }\n\n  public getNestedElement(el: any, className: string) {\n    if(el) {\n      if(el.classList.contains(className)) {\n        return el;\n      }\n\n      return this.getNestedElement(el.parentElement, className);\n    }\n\n    return null;\n  }\n  \n  public saveActiveFilter(): void {\n    this._savedFilterController\n      .save(this._savedFilterController.activeFilter)\n      .pipe(\n        tap(() => {\n          this._message.success(`Saved ${this._savedFilterController.singularLabel}`);\n        }),\n      )\n      .subscribe();\n  }\n\n  public createSavedFilter(): void {\n    this._savedFilterController.create()\n      .pipe(\n        tap(() => {\n          this._message\n            .success(`Created ${this._savedFilterController.singularLabel}`,\n            );\n        }),\n      )\n      .subscribe();\n  }\n\n  public saveAs(): void {\n    this._savedFilterController\n      .saveAs()\n      .pipe(\n        tap(() => {\n          this._message.success(`Saved ${this._savedFilterController.singularLabel}`);\n        }),\n      )\n      .subscribe();\n  } \n\n  public manageSavedFilters(): void {\n    this._dialog\n      .open(FsFilterSavedFilterManageComponent, {\n        injector: this._injector,\n        restoreFocus: false,\n      });\n  }\n\n  public _destroyOverlay() {\n    if(this._overlayRef) {\n      try {\n        this._overlayRef.detachBackdrop();\n        this._overlayRef.detach();\n        this._overlayRef.dispose();\n      } catch {\n        // overlay may already be disposed by BaseItemComponent.close()\n      }\n      this._overlayRef = null;\n    }\n  }\n\n  public removeChip(\n    item: BaseItem<IFilterConfigItem>, \n    chip: { name?: string, value: string, label: string },\n    event?: { event: MouseEvent; data: any } | Event,\n  ) {\n    if (event) {\n      const mouseEvent = 'event' in event ? event.event : event;\n      mouseEvent.stopPropagation();\n    }\n\n    if(!item.secondary) {\n      item.secondaryHide();\n    }\n\n    if(chip.name) {\n      item.clearByName(chip.name);\n    } else {\n      item.clear();\n    }\n  }\n\n  public removeItem(item: BaseItem<IFilterConfigItem>) {\n    item.secondaryHide();\n  }\n\n  private _initSecondaryItems() {\n    this._updateSecondaryItems();\n\n    merge(\n      ...this.items\n        .reduce((accum, item) => {\n          return [\n            ...accum, \n            item.hasValue$\n              .pipe(skip(1)),\n            item.visible$\n              .pipe(skip(1)),\n          ];\n        }, []),\n    )\n      .pipe(\n        tap(() => {\n          this._updateSecondaryItems();\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n  }\n\n  private _updateSecondaryItems() {\n    this.secondaryItems = this.items\n      .filter((item) => {\n        if (!item.allowSecondary) {\n          return false;\n        }\n        // Exclude checkbox items without values from secondary filters\n        if (item.isTypeCheckbox && !item.hasValue) {\n          return false;\n        }\n\n        return true;\n      });\n  }\n\n  private _attachContainer(overlayRef: OverlayRef, item: BaseItem<IFilterConfigItem>, name: string) {\n    const injector = this._createInjector(item, name);\n    const containerPortal = new ComponentPortal(FilterItemDialogComponent, undefined, injector);\n    const containerRef = overlayRef.attach<FilterItemDialogComponent>(containerPortal);\n\n    return containerRef.instance;\n  }\n\n  private _createInjector(item: BaseItem<IFilterConfigItem>, autofocusName: string): Injector {\n    const providers: StaticProvider[] = [\n      { provide: FILTER_DRAWER_DATA, useValue: { item, autofocusName, overlayRef: this._overlayRef } },\n    ];\n  \n    return Injector.create({\n      providers,\n      parent: this._injector,\n    });\n  }\n\n  private _initMoreFilterItems() {\n    merge(\n      ...this.items\n        .reduce((accum, item) => {\n          return [\n            ...accum, \n            item.visible$\n              .pipe(skip(1)),\n            item.secondaryVisible$\n              .pipe(skip(1)),\n          ];\n        }, []),\n    )\n      .pipe(\n        tap(() => {\n          this._updateMoreFilterItems();\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n\n    this._updateMoreFilterItems();\n  }\n\n  private _initClearFiltersVisible() {\n    merge(\n      ...this.items\n        .reduce((accum, item) => {\n          return [\n            ...accum, \n            item.visible$\n              .pipe(skip(1)),\n            item.hasValue$\n              .pipe(skip(1)),\n          ];\n        }, []),\n    )\n      .pipe(\n        tap(() => {\n          this._updateClearItems();\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n\n    this._updateClearItems();\n  }\n\n  private _updateMoreFilterItems() {\n    this.moreFilterItems\n      .set(this.items\n        .filter((item) => !item.primary && item.visible && !item.secondaryVisible));\n  }\n\n  private _updateClearItems() {\n    this.clearFiltersVisible\n      .set(this.items\n        .some((item) => item.clearable && item.hasValue && item.visible));\n  }\n\n  private _initHasSecondaryValue() {\n    this._hasSecondaryValue$.next(this.hasSecondaryValue);\n\n    this._filterController.change$\n      .pipe(\n        tap(() => {\n          this._hasSecondaryValue$.next(this.hasSecondaryValue);\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n  }\n\n}\n","@if (items.length !== 0) {\n  @for (item of secondaryItems; track item.name) {\n    @if ((item.visible$ | async)) {\n      @if ((item.hasValue$ | async)) {\n        @for (chip of item.chips$ | async; track chip.label) {\n          <fs-chip\n              class=\"filter-chip selected\"\n              [size]=\"'medium'\"\n              [borderColor]=\"'#ddd'\"\n              [attr.data-filter-item]=\"item.name\"\n              [outlined]=\"true\"\n              (click)=\"handleChipClick(item, chip.name)\">\n            @if (chip.value) {\n              {{ chip.label }}:\n              <a>\n                {{ chip.value }}\n              </a>\n            } @else {\n              {{ chip.label }}\n            }\n            <ng-template\n              fsChipSuffix\n              [icon]=\"'cancel_circle_outline'\"\n              (click)=\"removeChip(item, chip, $event)\">\n            </ng-template>\n          </fs-chip>\n        }\n      }\n      @if ((item.notValue$ | async) && (item.secondaryVisible$ | async)) {\n        <fs-chip\n            class=\"filter-chip\"\n            [attr.data-filter-item]=\"item.name\"\n            [size]=\"'medium'\"\n            [borderColor]=\"'#ddd'\"\n            (click)=\"handleChipClick(item)\"\n            [outlined]=\"true\"\n            [outlineDash]=\"true\">\n          {{ item.mergedLabel }}\n          <ng-template\n            fsChipSuffix\n            [icon]=\"'add_circle_outline'\">\n          </ng-template>\n        </fs-chip>\n      }\n    }\n  }\n  @if (moreFilterItems().length > 0) {\n    <fs-chip-select\n        [outlined]=\"true\"\n        (select)=\"addFilter($event)\">\n      <fs-chip-select-trigger>\n        More filters\n      </fs-chip-select-trigger>\n      @for (item of moreFilterItems(); track item.name) {\n        <fs-chip-select-option [value]=\"item\">\n          {{ item.mergedLabel }}\n        </fs-chip-select-option>\n      }\n    </fs-chip-select>\n  }\n  @if (savedFilterController.enabled) {\n    <fs-chip-select [outlined]=\"true\">\n      <fs-chip-select-trigger>\n        {{ (savedFilterController.activeFilter$ | async) ? savedFilterController.singularLabel + ': ' + (savedFilterController.activeFilter$ | async).name : savedFilterController.pluralLabel }}\n      </fs-chip-select-trigger>\n      @if (savedFilterController.activeFilter$ | async) {\n        <fs-chip-select-option (click)=\"saveActiveFilter()\">\n          Update filters\n        </fs-chip-select-option>\n        <fs-chip-select-option (click)=\"saveAs()\">\n          Save as new\n        </fs-chip-select-option>\n      } @else {\n        <fs-chip-select-option (click)=\"createSavedFilter()\">\n          Create new\n        </fs-chip-select-option>\n      }\n      <fs-chip-select-option (click)=\"manageSavedFilters()\">\n        View all\n      </fs-chip-select-option>\n    </fs-chip-select>\n  }\n  @if (clearFiltersVisible()) {\n    <fs-chip\n        [outlined]=\"true\"\n        (click)=\"clear()\">\n      Clear filters\n      <ng-template\n        fsChipSuffix\n        [icon]=\"'cancel_circle_outline'\">\n      </ng-template>\n    </fs-chip>\n  }\n}"]}
319
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-chips.component.js","sourceRoot":"","sources":["../../../../../src/app/components/filter-chips/filter-chips.component.ts","../../../../../src/app/components/filter-chips/filter-chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, Injector, OnInit, QueryList, StaticProvider, ViewChildren, inject, signal } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\n\nimport { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialog } from '@angular/material/dialog';\n\nimport { FsChipComponent, FsChipModule, FsChipSelectTriggerDirective } from '@firestitch/chip';\nimport { FsMessage } from '@firestitch/message';\nimport { FsSelectButtonModule } from '@firestitch/selectbutton';\n\nimport { BehaviorSubject, Observable, delay, merge, skip, take, tap } from 'rxjs';\n\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { ItemType } from '../../enums';\nimport { FILTER_DRAWER_DATA } from '../../injectors';\nimport { IFilterConfigItem } from '../../interfaces';\nimport { BaseItem } from '../../models/items/base-item';\nimport { SavedFilterController } from '../../services';\nimport { FilterController } from '../../services/filter-controller.service';\nimport { FilterItemDialogComponent } from '../filter-item-dialog';\nimport { FsFilterSavedFilterManageComponent } from '../saved-filter/saved-filter-manage/saved-filter-manage.component';\n\n\n@Component({\n  selector: 'fs-filter-chips',\n  templateUrl: './filter-chips.component.html',\n  styleUrls: ['./filter-chips.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    FsChipModule,\n    FsSelectButtonModule,\n    MatButtonModule,\n    FormsModule,\n    FsChipSelectTriggerDirective,\n  ],\n})\nexport class FsFilterChipsComponent implements OnInit {\n\n  @ViewChildren(FsChipComponent) \n  public chips: QueryList<FsChipComponent>;\n\n  public ItemType = ItemType;\n  public secondaryItems: BaseItem<IFilterConfigItem>[] = [];\n  public moreFilterItems = signal<BaseItem<IFilterConfigItem>[]>([]);\n  public clearFiltersVisible = signal<boolean>(false);\n\n  private _filterController = inject(FilterController);\n  private _dialog = inject(MatDialog);\n  private _message = inject(FsMessage);\n  private _savedFilterController = inject(SavedFilterController);\n  private _injector = inject(Injector);\n  private _overlay = inject(Overlay);\n  private _overlayRef: OverlayRef;\n  private _destroyRef = inject(DestroyRef);\n  private _elementRef = inject(ElementRef);\n  private _hasSecondaryValue$ = new BehaviorSubject(false);\n\n  public get items(): BaseItem<IFilterConfigItem>[] {\n    return this._filterController.items;\n  }\n\n  public addFilter(item: BaseItem<IFilterConfigItem>) {\n    // For checkbox items, set to checked when adding from \"More filters\"\n    if (item.isTypeCheckbox && !item.hasValue) {\n      item.setValue(true);\n    }\n    \n    item.secondaryShow();\n\n    // Don't open overlay for secondary checkbox items\n    if (item.isTypeCheckbox && !item.primary) {\n      return;\n    }\n\n    this.chips.changes\n      .pipe(\n        take(1),\n        delay(100),\n        tap(() => {\n          this.openChip(item);\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n  }\n\n  public get hasSecondaryValue$(): Observable<boolean> {\n    return this._hasSecondaryValue$.asObservable();\n  }\n\n  public get savedFilterController(): SavedFilterController {\n    return this._savedFilterController;\n  }\n\n  public get hasSecondaryValue(): boolean {\n    return this._filterController.items\n      .some((item) => item.hasValue && item.visible && !item.primary);\n  }\n\n  public ngOnInit(): void {\n    this._initSecondaryItems();\n    this._initHasSecondaryValue();\n    this._initMoreFilterItems();\n    this._initClearFiltersVisible();\n  }\n\n  public clear() {\n    this._filterController.items\n      .filter((item) => item.clearable)\n      .forEach((item) => {\n        if(!item.secondary) {\n          item.secondaryHide();\n        }\n        item.clear(false);\n      });\n\n    this._filterController.change();\n    this._savedFilterController.setActiveFilter(null);\n  }\n\n  public handleChipClick(item: BaseItem<IFilterConfigItem>, name: string = null) {\n    // For secondary checkbox items, don't open overlay - clearing is done via remove button\n    if (item.isTypeCheckbox && !item.primary) {\n      return;\n    }\n\n    this.openChip(item, name);\n  }\n\n  public openChip(item: BaseItem<IFilterConfigItem>, name: string = null) {\n    console.log('[FilterChips] openChip', item.name, 'type:', item.type, 'existingOverlay:', !!this._overlayRef);\n    this._destroyOverlay();\n    const el = this._elementRef.nativeElement\n      .querySelector(`[data-filter-item=\"${item.name}\"]`);\n\n    const positions: ConnectedPosition[] = [\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'top',\n        offsetX: 0,\n        offsetY: el.offsetHeight + 2,\n      },\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'bottom',\n      },\n    ];\n\n    const strategy = this._overlay\n      .position()\n      .flexibleConnectedTo(el)\n      .withPositions(positions);\n    \n    const overlayConfig = new OverlayConfig({\n      positionStrategy: strategy,\n      scrollStrategy: this._overlay.scrollStrategies.block(),\n      disposeOnNavigation: true,\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      panelClass: 'fs-sidenav-menu-overlay-pane',\n    });\n\n    this._overlayRef = this._overlay.create(overlayConfig);\n\n    this._overlayRef.backdropClick().pipe(\n      take(1),\n      tap(() => {\n        this._destroyOverlay();\n      }),\n      takeUntilDestroyed(this._destroyRef),\n    ).subscribe();\n\n    this._overlayRef.detachments().pipe(\n      take(1),\n      tap(() => {\n        this._overlayRef = null;\n      }),\n      takeUntilDestroyed(this._destroyRef),\n    ).subscribe();\n\n    this._attachContainer(this._overlayRef, item, name);\n  }\n\n  public getNestedElement(el: any, className: string) {\n    if(el) {\n      if(el.classList.contains(className)) {\n        return el;\n      }\n\n      return this.getNestedElement(el.parentElement, className);\n    }\n\n    return null;\n  }\n  \n  public saveActiveFilter(): void {\n    this._savedFilterController\n      .save(this._savedFilterController.activeFilter)\n      .pipe(\n        tap(() => {\n          this._message.success(`Saved ${this._savedFilterController.singularLabel}`);\n        }),\n      )\n      .subscribe();\n  }\n\n  public createSavedFilter(): void {\n    this._savedFilterController.create()\n      .pipe(\n        tap(() => {\n          this._message\n            .success(`Created ${this._savedFilterController.singularLabel}`,\n            );\n        }),\n      )\n      .subscribe();\n  }\n\n  public saveAs(): void {\n    this._savedFilterController\n      .saveAs()\n      .pipe(\n        tap(() => {\n          this._message.success(`Saved ${this._savedFilterController.singularLabel}`);\n        }),\n      )\n      .subscribe();\n  } \n\n  public manageSavedFilters(): void {\n    this._dialog\n      .open(FsFilterSavedFilterManageComponent, {\n        injector: this._injector,\n        restoreFocus: false,\n      });\n  }\n\n  public _destroyOverlay() {\n    if(this._overlayRef) {\n      console.log('[FilterChips] _destroyOverlay - disposing existing overlay');\n      try {\n        this._overlayRef.detachBackdrop();\n        this._overlayRef.detach();\n        this._overlayRef.dispose();\n      } catch {\n        // overlay may already be disposed by BaseItemComponent.close()\n      }\n      this._overlayRef = null;\n    }\n  }\n\n  public removeChip(\n    item: BaseItem<IFilterConfigItem>, \n    chip: { name?: string, value: string, label: string },\n    event?: { event: MouseEvent; data: any } | Event,\n  ) {\n    if (event) {\n      const mouseEvent = 'event' in event ? event.event : event;\n      mouseEvent.stopPropagation();\n    }\n\n    if(!item.secondary) {\n      item.secondaryHide();\n    }\n\n    if(chip.name) {\n      item.clearByName(chip.name);\n    } else {\n      item.clear();\n    }\n  }\n\n  public removeItem(item: BaseItem<IFilterConfigItem>) {\n    item.secondaryHide();\n  }\n\n  private _initSecondaryItems() {\n    this._updateSecondaryItems();\n\n    merge(\n      ...this.items\n        .reduce((accum, item) => {\n          return [\n            ...accum, \n            item.hasValue$\n              .pipe(skip(1)),\n            item.visible$\n              .pipe(skip(1)),\n          ];\n        }, []),\n    )\n      .pipe(\n        tap(() => {\n          this._updateSecondaryItems();\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n  }\n\n  private _updateSecondaryItems() {\n    this.secondaryItems = this.items\n      .filter((item) => {\n        if (!item.allowSecondary) {\n          return false;\n        }\n        // Exclude checkbox items without values from secondary filters\n        if (item.isTypeCheckbox && !item.hasValue) {\n          return false;\n        }\n\n        return true;\n      });\n  }\n\n  private _attachContainer(overlayRef: OverlayRef, item: BaseItem<IFilterConfigItem>, name: string) {\n    const injector = this._createInjector(item, name);\n    const containerPortal = new ComponentPortal(FilterItemDialogComponent, undefined, injector);\n    const containerRef = overlayRef.attach<FilterItemDialogComponent>(containerPortal);\n\n    return containerRef.instance;\n  }\n\n  private _createInjector(item: BaseItem<IFilterConfigItem>, autofocusName: string): Injector {\n    const providers: StaticProvider[] = [\n      { provide: FILTER_DRAWER_DATA, useValue: { item, autofocusName, overlayRef: this._overlayRef } },\n    ];\n  \n    return Injector.create({\n      providers,\n      parent: this._injector,\n    });\n  }\n\n  private _initMoreFilterItems() {\n    merge(\n      ...this.items\n        .reduce((accum, item) => {\n          return [\n            ...accum, \n            item.visible$\n              .pipe(skip(1)),\n            item.secondaryVisible$\n              .pipe(skip(1)),\n          ];\n        }, []),\n    )\n      .pipe(\n        tap(() => {\n          this._updateMoreFilterItems();\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n\n    this._updateMoreFilterItems();\n  }\n\n  private _initClearFiltersVisible() {\n    merge(\n      ...this.items\n        .reduce((accum, item) => {\n          return [\n            ...accum, \n            item.visible$\n              .pipe(skip(1)),\n            item.hasValue$\n              .pipe(skip(1)),\n          ];\n        }, []),\n    )\n      .pipe(\n        tap(() => {\n          this._updateClearItems();\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n\n    this._updateClearItems();\n  }\n\n  private _updateMoreFilterItems() {\n    this.moreFilterItems\n      .set(this.items\n        .filter((item) => !item.primary && item.visible && !item.secondaryVisible));\n  }\n\n  private _updateClearItems() {\n    this.clearFiltersVisible\n      .set(this.items\n        .some((item) => item.clearable && item.hasValue && item.visible));\n  }\n\n  private _initHasSecondaryValue() {\n    this._hasSecondaryValue$.next(this.hasSecondaryValue);\n\n    this._filterController.change$\n      .pipe(\n        tap(() => {\n          this._hasSecondaryValue$.next(this.hasSecondaryValue);\n        }),\n        takeUntilDestroyed(this._destroyRef),\n      )\n      .subscribe();\n  }\n\n}\n","@if (items.length !== 0) {\n  @for (item of secondaryItems; track item.name) {\n    @if ((item.visible$ | async)) {\n      @if ((item.hasValue$ | async)) {\n        @for (chip of item.chips$ | async; track chip.label) {\n          <fs-chip\n              class=\"filter-chip selected\"\n              [size]=\"'medium'\"\n              [borderColor]=\"'#ddd'\"\n              [attr.data-filter-item]=\"item.name\"\n              [outlined]=\"true\"\n              (click)=\"handleChipClick(item, chip.name)\">\n            @if (chip.value) {\n              {{ chip.label }}:\n              <a>\n                {{ chip.value }}\n              </a>\n            } @else {\n              {{ chip.label }}\n            }\n            <ng-template\n              fsChipSuffix\n              [icon]=\"'cancel_circle_outline'\"\n              (click)=\"removeChip(item, chip, $event)\">\n            </ng-template>\n          </fs-chip>\n        }\n      }\n      @if ((item.notValue$ | async) && (item.secondaryVisible$ | async)) {\n        <fs-chip\n            class=\"filter-chip\"\n            [attr.data-filter-item]=\"item.name\"\n            [size]=\"'medium'\"\n            [borderColor]=\"'#ddd'\"\n            (click)=\"handleChipClick(item)\"\n            [outlined]=\"true\"\n            [outlineDash]=\"true\">\n          {{ item.mergedLabel }}\n          <ng-template\n            fsChipSuffix\n            [icon]=\"'add_circle_outline'\">\n          </ng-template>\n        </fs-chip>\n      }\n    }\n  }\n  @if (moreFilterItems().length > 0) {\n    <fs-chip-select\n        [outlined]=\"true\"\n        (select)=\"addFilter($event)\">\n      <fs-chip-select-trigger>\n        More filters\n      </fs-chip-select-trigger>\n      @for (item of moreFilterItems(); track item.name) {\n        <fs-chip-select-option [value]=\"item\">\n          {{ item.mergedLabel }}\n        </fs-chip-select-option>\n      }\n    </fs-chip-select>\n  }\n  @if (savedFilterController.enabled) {\n    <fs-chip-select [outlined]=\"true\">\n      <fs-chip-select-trigger>\n        {{ (savedFilterController.activeFilter$ | async) ? savedFilterController.singularLabel + ': ' + (savedFilterController.activeFilter$ | async).name : savedFilterController.pluralLabel }}\n      </fs-chip-select-trigger>\n      @if (savedFilterController.activeFilter$ | async) {\n        <fs-chip-select-option (click)=\"saveActiveFilter()\">\n          Update filters\n        </fs-chip-select-option>\n        <fs-chip-select-option (click)=\"saveAs()\">\n          Save as new\n        </fs-chip-select-option>\n      } @else {\n        <fs-chip-select-option (click)=\"createSavedFilter()\">\n          Create new\n        </fs-chip-select-option>\n      }\n      <fs-chip-select-option (click)=\"manageSavedFilters()\">\n        View all\n      </fs-chip-select-option>\n    </fs-chip-select>\n  }\n  @if (clearFiltersVisible()) {\n    <fs-chip\n        [outlined]=\"true\"\n        (click)=\"clear()\">\n      Clear filters\n      <ng-template\n        fsChipSuffix\n        [icon]=\"'cancel_circle_outline'\">\n      </ng-template>\n    </fs-chip>\n  }\n}"]}
@@ -24,6 +24,7 @@ export class DateRangeComponent extends BaseItemComponent {
24
24
  initialized = false;
25
25
  ngOnInit() {
26
26
  super.ngOnInit();
27
+ console.log('[DateRangeComponent] ngOnInit', this.item.name);
27
28
  this.viewType = this.item.type === ItemType.DateTimeRange ?
28
29
  PickerViewType.DateTime : PickerViewType.Date;
29
30
  this.item.value$
@@ -39,11 +40,16 @@ export class DateRangeComponent extends BaseItemComponent {
39
40
  else {
40
41
  this.autofocusName = this.from ? 'to' : 'from';
41
42
  }
43
+ console.log('[DateRangeComponent] initialized, autofocusName:', this.autofocusName);
42
44
  }
43
45
  this._cdRef.markForCheck();
44
46
  });
45
47
  }
46
48
  ngOnDestroy() {
49
+ console.log('[DateRangeComponent] ngOnDestroy', this.item.name, {
50
+ fromDialogOpen: !!this._fromPicker?.dateDialogRef,
51
+ toDialogOpen: !!this._toPicker?.dateDialogRef,
52
+ });
47
53
  // Close any open datepicker dialogs to prevent overlay leaks.
48
54
  // RangePickerComponent.ngOnDestroy() does not call close() (unlike
49
55
  // FsDatePickerBaseComponent), so the calendar overlay stays in the DOM
@@ -90,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
90
96
  type: ViewChild,
91
97
  args: [DateRangePickerToComponent]
92
98
  }] } });
93
- //# 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\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        }\n\n        this._cdRef.markForCheck();\n      });\n  }\n  \n  public ngOnDestroy(): void {\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"]}
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"]}
@@ -18,6 +18,16 @@ export class FocusToItemDirective {
18
18
  ngAfterViewInit() {
19
19
  if (this.focusEnabled) {
20
20
  setTimeout(() => {
21
+ console.log('[FocusToItemDirective] _focus() called', {
22
+ hasSelect: !!this._targetSelect,
23
+ hasText: !!this._targetText,
24
+ hasDate: !!this._targetDate,
25
+ hasDateScroll: !!this._targetDateScroll,
26
+ hasDateRangeFrom: !!this._targetDateRangeFrom,
27
+ hasDateRangeTo: !!this._targetDateRangeTo,
28
+ hasAutocomplete: !!this._targetAutocomplete,
29
+ hasAutocompleteChips: !!this._targetAutocompleteChips,
30
+ });
21
31
  this._focus();
22
32
  });
23
33
  }
@@ -26,14 +36,12 @@ export class FocusToItemDirective {
26
36
  if (this._targetSelect) {
27
37
  this._targetSelect.open();
28
38
  }
29
- else if (this._targetDateRangeFrom) {
30
- this._targetDateRangeFrom.open();
31
- }
32
- else if (this._targetDateRangeTo) {
33
- this._targetDateRangeTo.open();
34
- }
35
- else if (this._targetDate) {
36
- this._targetDate.open();
39
+ else if (this._targetDateRangeFrom || this._targetDateRangeTo || this._targetDate) {
40
+ // Don't call open() directly on date pickers.
41
+ // Date picker directives bind @HostListener('focus') → open(), so focusing
42
+ // the input is enough. Calling open() directly creates a dual-trigger:
43
+ // open() → _doFocus() → focus event → @HostListener('focus') → open() again.
44
+ this._targetText?.focus();
37
45
  }
38
46
  else if (this._targetDateScroll) {
39
47
  this._targetDateScroll.open();
@@ -61,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
61
69
  type: Input,
62
70
  args: ['fsFilterFocusTrigger']
63
71
  }] } });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXMtdG8taXRlbS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2RpcmVjdGl2ZXMvZm9jdXMtdG8taXRlbS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV4RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRXJELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ25FLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlFLE9BQU8sRUFDTCw0QkFBNEIsRUFBRSwwQkFBMEIsRUFDeEQscUJBQXFCLEVBQ3JCLDJCQUEyQixHQUM1QixNQUFNLHdCQUF3QixDQUFDOztBQU9oQyxNQUFNLE9BQU8sb0JBQW9CO0lBR3hCLFlBQVksR0FBRyxJQUFJLENBQUM7SUFFbkIsYUFBYSxHQUFHLE1BQU0sQ0FBQyxTQUFTLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ2xFLFdBQVcsR0FBRyxNQUFNLENBQUMsUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMvRCxXQUFXLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUM1RSxpQkFBaUIsR0FBRyxNQUFNLENBQUMsMkJBQTJCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3hGLG9CQUFvQixHQUFHLE1BQU0sQ0FBQyw0QkFBNEIsRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDNUYsa0JBQWtCLEdBQUcsTUFBTSxDQUFDLDBCQUEwQixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN4RixtQkFBbUIsR0FBRyxNQUFNLENBQUMsdUJBQXVCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3RGLHdCQUF3QixHQUFHLE1BQU0sQ0FBQyw0QkFBNEIsRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFHakcsZUFBZTtRQUNwQixJQUFHLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNyQixVQUFVLENBQUMsR0FBRyxFQUFFO2dCQUNkLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNoQixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7SUFDSCxDQUFDO0lBRU8sTUFBTTtRQUNaLElBQUcsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDNUIsQ0FBQzthQUFNLElBQUcsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7WUFDcEMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLElBQUksRUFBRSxDQUFDO1FBQ25DLENBQUM7YUFBTSxJQUFHLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1lBQ2xDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNqQyxDQUFDO2FBQU0sSUFBRyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUMxQixDQUFDO2FBQU0sSUFBRyxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztZQUNqQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDaEMsQ0FBQzthQUFNLElBQUcsSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7WUFDbkMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ25DLENBQUM7YUFBTSxJQUFHLElBQUksQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1lBQ3hDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN4QyxDQUFDO2FBQU0sSUFBRyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUMzQixDQUFDO0lBQ0gsQ0FBQzt3R0F6Q1Usb0JBQW9COzRGQUFwQixvQkFBb0I7OzRGQUFwQixvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQUlRLFlBQVk7c0JBRGxCLEtBQUs7dUJBQUMsc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgRGlyZWN0aXZlLCBJbnB1dCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE1hdElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHsgTWF0U2VsZWN0IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2VsZWN0JztcblxuaW1wb3J0IHsgRnNBdXRvY29tcGxldGVDb21wb25lbnQgfSBmcm9tICdAZmlyZXN0aXRjaC9hdXRvY29tcGxldGUnO1xuaW1wb3J0IHsgRnNBdXRvY29tcGxldGVDaGlwc0NvbXBvbmVudCB9IGZyb20gJ0BmaXJlc3RpdGNoL2F1dG9jb21wbGV0ZS1jaGlwcyc7XG5pbXBvcnQge1xuICBEYXRlUmFuZ2VQaWNrZXJGcm9tQ29tcG9uZW50LCBEYXRlUmFuZ2VQaWNrZXJUb0NvbXBvbmVudCxcbiAgRnNEYXRlUGlja2VyQ29tcG9uZW50LFxuICBGc0RhdGVTY3JvbGxQaWNrZXJDb21wb25lbnQsXG59IGZyb20gJ0BmaXJlc3RpdGNoL2RhdGVwaWNrZXInO1xuXG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tmc0ZpbHRlckZvY3VzVHJpZ2dlcl0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBGb2N1c1RvSXRlbURpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuXG4gIEBJbnB1dCgnZnNGaWx0ZXJGb2N1c1RyaWdnZXInKVxuICBwdWJsaWMgZm9jdXNFbmFibGVkID0gdHJ1ZTtcblxuICBwcml2YXRlIF90YXJnZXRTZWxlY3QgPSBpbmplY3QoTWF0U2VsZWN0LCB7IG9wdGlvbmFsOiB0cnVlLCBzZWxmOiB0cnVlIH0pO1xuICBwcml2YXRlIF90YXJnZXRUZXh0ID0gaW5qZWN0KE1hdElucHV0LCB7IG9wdGlvbmFsOiB0cnVlLCBzZWxmOiB0cnVlIH0pO1xuICBwcml2YXRlIF90YXJnZXREYXRlID0gaW5qZWN0KEZzRGF0ZVBpY2tlckNvbXBvbmVudCwgeyBvcHRpb25hbDogdHJ1ZSwgc2VsZjogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSBfdGFyZ2V0RGF0ZVNjcm9sbCA9IGluamVjdChGc0RhdGVTY3JvbGxQaWNrZXJDb21wb25lbnQsIHsgb3B0aW9uYWw6IHRydWUsIHNlbGY6IHRydWUgfSk7XG4gIHByaXZhdGUgX3RhcmdldERhdGVSYW5nZUZyb20gPSBpbmplY3QoRGF0ZVJhbmdlUGlja2VyRnJvbUNvbXBvbmVudCwgeyBvcHRpb25hbDogdHJ1ZSwgc2VsZjogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSBfdGFyZ2V0RGF0ZVJhbmdlVG8gPSBpbmplY3QoRGF0ZVJhbmdlUGlja2VyVG9Db21wb25lbnQsIHsgb3B0aW9uYWw6IHRydWUsIHNlbGY6IHRydWUgfSk7XG4gIHByaXZhdGUgX3RhcmdldEF1dG9jb21wbGV0ZSA9IGluamVjdChGc0F1dG9jb21wbGV0ZUNvbXBvbmVudCwgeyBvcHRpb25hbDogdHJ1ZSwgc2VsZjogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSBfdGFyZ2V0QXV0b2NvbXBsZXRlQ2hpcHMgPSBpbmplY3QoRnNBdXRvY29tcGxldGVDaGlwc0NvbXBvbmVudCwgeyBvcHRpb25hbDogdHJ1ZSwgc2VsZjogdHJ1ZSB9KTtcblxuXG4gIHB1YmxpYyBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgaWYodGhpcy5mb2N1c0VuYWJsZWQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICB0aGlzLl9mb2N1cygpO1xuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfZm9jdXMoKSB7XG4gICAgaWYodGhpcy5fdGFyZ2V0U2VsZWN0KSB7XG4gICAgICB0aGlzLl90YXJnZXRTZWxlY3Qub3BlbigpO1xuICAgIH0gZWxzZSBpZih0aGlzLl90YXJnZXREYXRlUmFuZ2VGcm9tKSB7XG4gICAgICB0aGlzLl90YXJnZXREYXRlUmFuZ2VGcm9tLm9wZW4oKTtcbiAgICB9IGVsc2UgaWYodGhpcy5fdGFyZ2V0RGF0ZVJhbmdlVG8pIHtcbiAgICAgIHRoaXMuX3RhcmdldERhdGVSYW5nZVRvLm9wZW4oKTtcbiAgICB9IGVsc2UgaWYodGhpcy5fdGFyZ2V0RGF0ZSkge1xuICAgICAgdGhpcy5fdGFyZ2V0RGF0ZS5vcGVuKCk7XG4gICAgfSBlbHNlIGlmKHRoaXMuX3RhcmdldERhdGVTY3JvbGwpIHtcbiAgICAgIHRoaXMuX3RhcmdldERhdGVTY3JvbGwub3BlbigpO1xuICAgIH0gZWxzZSBpZih0aGlzLl90YXJnZXRBdXRvY29tcGxldGUpIHtcbiAgICAgIHRoaXMuX3RhcmdldEF1dG9jb21wbGV0ZS5mb2N1cygpO1xuICAgIH0gZWxzZSBpZih0aGlzLl90YXJnZXRBdXRvY29tcGxldGVDaGlwcykge1xuICAgICAgdGhpcy5fdGFyZ2V0QXV0b2NvbXBsZXRlQ2hpcHMuZm9jdXMoKTtcbiAgICB9IGVsc2UgaWYodGhpcy5fdGFyZ2V0VGV4dCkge1xuICAgICAgdGhpcy5fdGFyZ2V0VGV4dC5mb2N1cygpO1xuICAgIH1cbiAgfVxufVxuIl19
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXMtdG8taXRlbS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2RpcmVjdGl2ZXMvZm9jdXMtdG8taXRlbS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV4RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRXJELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ25FLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlFLE9BQU8sRUFDTCw0QkFBNEIsRUFBRSwwQkFBMEIsRUFDeEQscUJBQXFCLEVBQ3JCLDJCQUEyQixHQUM1QixNQUFNLHdCQUF3QixDQUFDOztBQU9oQyxNQUFNLE9BQU8sb0JBQW9CO0lBR3hCLFlBQVksR0FBRyxJQUFJLENBQUM7SUFFbkIsYUFBYSxHQUFHLE1BQU0sQ0FBQyxTQUFTLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ2xFLFdBQVcsR0FBRyxNQUFNLENBQUMsUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMvRCxXQUFXLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUM1RSxpQkFBaUIsR0FBRyxNQUFNLENBQUMsMkJBQTJCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFD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IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBNYXRJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IE1hdFNlbGVjdCB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XG5cbmltcG9ydCB7IEZzQXV0b2NvbXBsZXRlQ29tcG9uZW50IH0gZnJvbSAnQGZpcmVzdGl0Y2gvYXV0b2NvbXBsZXRlJztcbmltcG9ydCB7IEZzQXV0b2NvbXBsZXRlQ2hpcHNDb21wb25lbnQgfSBmcm9tICdAZmlyZXN0aXRjaC9hdXRvY29tcGxldGUtY2hpcHMnO1xuaW1wb3J0IHtcbiAgRGF0ZVJhbmdlUGlja2VyRnJvbUNvbXBvbmVudCwgRGF0ZVJhbmdlUGlja2VyVG9Db21wb25lbnQsXG4gIEZzRGF0ZVBpY2tlckNvbXBvbmVudCxcbiAgRnNEYXRlU2Nyb2xsUGlja2VyQ29tcG9uZW50LFxufSBmcm9tICdAZmlyZXN0aXRjaC9kYXRlcGlja2VyJztcblxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZnNGaWx0ZXJGb2N1c1RyaWdnZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRm9jdXNUb0l0ZW1EaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcblxuICBASW5wdXQoJ2ZzRmlsdGVyRm9jdXNUcmlnZ2VyJylcbiAgcHVibGljIGZvY3VzRW5hYmxlZCA9IHRydWU7XG5cbiAgcHJpdmF0ZSBfdGFyZ2V0U2VsZWN0ID0gaW5qZWN0KE1hdFNlbGVjdCwgeyBvcHRpb25hbDogdHJ1ZSwgc2VsZjogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSBfdGFyZ2V0VGV4dCA9IGluamVjdChNYXRJbnB1dCwgeyBvcHRpb25hbDogdHJ1ZSwgc2VsZjogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSBfdGFyZ2V0RGF0ZSA9IGluamVjdChGc0RhdGVQaWNrZXJDb21wb25lbnQsIHsgb3B0aW9uYWw6IHRydWUsIHNlbGY6IHRydWUgfSk7XG4gIHByaXZhdGUgX3RhcmdldERhdGVTY3JvbGwgPSBpbmplY3QoRnNEYXRlU2Nyb2xsUGlja2VyQ29tcG9uZW50LCB7IG9wdGlvbmFsOiB0cnVlLCBzZWxmOiB0cnVlIH0pO1xuICBwcml2YXRlIF90YXJnZXREYXRlUmFuZ2VGcm9tID0gaW5qZWN0KERhdGVSYW5nZVBpY2tlckZyb21Db21wb25lbnQsIHsgb3B0aW9uYWw6IHRydWUsIHNlbGY6IHRydWUgfSk7XG4gIHByaXZhdGUgX3RhcmdldERhdGVSYW5nZVRvID0gaW5qZWN0KERhdGVSYW5nZVBpY2tlclRvQ29tcG9uZW50LCB7IG9wdGlvbmFsOiB0cnVlLCBzZWxmOiB0cnVlIH0pO1xuICBwcml2YXRlIF90YXJnZXRBdXRvY29tcGxldGUgPSBpbmplY3QoRnNBdXRvY29tcGxldGVDb21wb25lbnQsIHsgb3B0aW9uYWw6IHRydWUsIHNlbGY6IHRydWUgfSk7XG4gIHByaXZhdGUgX3RhcmdldEF1dG9jb21wbGV0ZUNoaXBzID0gaW5qZWN0KEZzQXV0b2NvbXBsZXRlQ2hpcHNDb21wb25lbnQsIHsgb3B0aW9uYWw6IHRydWUsIHNlbGY6IHRydWUgfSk7XG5cblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIGlmKHRoaXMuZm9jdXNFbmFibGVkKSB7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgY29uc29sZS5sb2coJ1tGb2N1c1RvSXRlbURpcmVjdGl2ZV0gX2ZvY3VzKCkgY2FsbGVkJywge1xuICAgICAgICAgIGhhc1NlbGVjdDogISF0aGlzLl90YXJnZXRTZWxlY3QsXG4gICAgICAgICAgaGFzVGV4dDogISF0aGlzLl90YXJnZXRUZXh0LFxuICAgICAgICAgIGhhc0RhdGU6ICEhdGhpcy5fdGFyZ2V0RGF0ZSxcbiAgICAgICAgICBoYXNEYXRlU2Nyb2xsOiAhIXRoaXMuX3RhcmdldERhdGVTY3JvbGwsXG4gICAgICAgICAgaGFzRGF0ZVJhbmdlRnJvbTogISF0aGlzLl90YXJnZXREYXRlUmFuZ2VGcm9tLFxuICAgICAgICAgIGhhc0RhdGVSYW5nZVRvOiAhIXRoaXMuX3RhcmdldERhdGVSYW5nZVRvLFxuICAgICAgICAgIGhhc0F1dG9jb21wbGV0ZTogISF0aGlzLl90YXJnZXRBdXRvY29tcGxldGUsXG4gICAgICAgICAgaGFzQXV0b2NvbXBsZXRlQ2hpcHM6ICEhdGhpcy5fdGFyZ2V0QXV0b2NvbXBsZXRlQ2hpcHMsXG4gICAgICAgIH0pO1xuICAgICAgICB0aGlzLl9mb2N1cygpO1xuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfZm9jdXMoKSB7XG4gICAgaWYodGhpcy5fdGFyZ2V0U2VsZWN0KSB7XG4gICAgICB0aGlzLl90YXJnZXRTZWxlY3Qub3BlbigpO1xuICAgIH0gZWxzZSBpZih0aGlzLl90YXJnZXREYXRlUmFuZ2VGcm9tIHx8IHRoaXMuX3RhcmdldERhdGVSYW5nZVRvIHx8IHRoaXMuX3RhcmdldERhdGUpIHtcbiAgICAgIC8vIERvbid0IGNhbGwgb3BlbigpIGRpcmVjdGx5IG9uIGRhdGUgcGlja2Vycy5cbiAgICAgIC8vIERhdGUgcGlja2VyIGRpcmVjdGl2ZXMgYmluZCBASG9zdExpc3RlbmVyKCdmb2N1cycpIOKGkiBvcGVuKCksIHNvIGZvY3VzaW5nXG4gICAgICAvLyB0aGUgaW5wdXQgaXMgZW5vdWdoLiAgQ2FsbGluZyBvcGVuKCkgZGlyZWN0bHkgY3JlYXRlcyBhIGR1YWwtdHJpZ2dlcjpcbiAgICAgIC8vIG9wZW4oKSDihpIgX2RvRm9jdXMoKSDihpIgZm9jdXMgZXZlbnQg4oaSIEBIb3N0TGlzdGVuZXIoJ2ZvY3VzJykg4oaSIG9wZW4oKSBhZ2Fpbi5cbiAgICAgIHRoaXMuX3RhcmdldFRleHQ/LmZvY3VzKCk7XG4gICAgfSBlbHNlIGlmKHRoaXMuX3RhcmdldERhdGVTY3JvbGwpIHtcbiAgICAgIHRoaXMuX3RhcmdldERhdGVTY3JvbGwub3BlbigpO1xuICAgIH0gZWxzZSBpZih0aGlzLl90YXJnZXRBdXRvY29tcGxldGUpIHtcbiAgICAgIHRoaXMuX3RhcmdldEF1dG9jb21wbGV0ZS5mb2N1cygpO1xuICAgIH0gZWxzZSBpZih0aGlzLl90YXJnZXRBdXRvY29tcGxldGVDaGlwcykge1xuICAgICAgdGhpcy5fdGFyZ2V0QXV0b2NvbXBsZXRlQ2hpcHMuZm9jdXMoKTtcbiAgICB9IGVsc2UgaWYodGhpcy5fdGFyZ2V0VGV4dCkge1xuICAgICAgdGhpcy5fdGFyZ2V0VGV4dC5mb2N1cygpO1xuICAgIH1cbiAgfVxufVxuIl19
@@ -698,6 +698,16 @@ class FocusToItemDirective {
698
698
  ngAfterViewInit() {
699
699
  if (this.focusEnabled) {
700
700
  setTimeout(() => {
701
+ console.log('[FocusToItemDirective] _focus() called', {
702
+ hasSelect: !!this._targetSelect,
703
+ hasText: !!this._targetText,
704
+ hasDate: !!this._targetDate,
705
+ hasDateScroll: !!this._targetDateScroll,
706
+ hasDateRangeFrom: !!this._targetDateRangeFrom,
707
+ hasDateRangeTo: !!this._targetDateRangeTo,
708
+ hasAutocomplete: !!this._targetAutocomplete,
709
+ hasAutocompleteChips: !!this._targetAutocompleteChips,
710
+ });
701
711
  this._focus();
702
712
  });
703
713
  }
@@ -706,14 +716,12 @@ class FocusToItemDirective {
706
716
  if (this._targetSelect) {
707
717
  this._targetSelect.open();
708
718
  }
709
- else if (this._targetDateRangeFrom) {
710
- this._targetDateRangeFrom.open();
711
- }
712
- else if (this._targetDateRangeTo) {
713
- this._targetDateRangeTo.open();
714
- }
715
- else if (this._targetDate) {
716
- this._targetDate.open();
719
+ else if (this._targetDateRangeFrom || this._targetDateRangeTo || this._targetDate) {
720
+ // Don't call open() directly on date pickers.
721
+ // Date picker directives bind @HostListener('focus') → open(), so focusing
722
+ // the input is enough. Calling open() directly creates a dual-trigger:
723
+ // open() → _doFocus() → focus event → @HostListener('focus') → open() again.
724
+ this._targetText?.focus();
717
725
  }
718
726
  else if (this._targetDateScroll) {
719
727
  this._targetDateScroll.open();
@@ -2868,6 +2876,7 @@ class DateRangeComponent extends BaseItemComponent {
2868
2876
  initialized = false;
2869
2877
  ngOnInit() {
2870
2878
  super.ngOnInit();
2879
+ console.log('[DateRangeComponent] ngOnInit', this.item.name);
2871
2880
  this.viewType = this.item.type === ItemType.DateTimeRange ?
2872
2881
  PickerViewType.DateTime : PickerViewType.Date;
2873
2882
  this.item.value$
@@ -2883,11 +2892,16 @@ class DateRangeComponent extends BaseItemComponent {
2883
2892
  else {
2884
2893
  this.autofocusName = this.from ? 'to' : 'from';
2885
2894
  }
2895
+ console.log('[DateRangeComponent] initialized, autofocusName:', this.autofocusName);
2886
2896
  }
2887
2897
  this._cdRef.markForCheck();
2888
2898
  });
2889
2899
  }
2890
2900
  ngOnDestroy() {
2901
+ console.log('[DateRangeComponent] ngOnDestroy', this.item.name, {
2902
+ fromDialogOpen: !!this._fromPicker?.dateDialogRef,
2903
+ toDialogOpen: !!this._toPicker?.dateDialogRef,
2904
+ });
2891
2905
  // Close any open datepicker dialogs to prevent overlay leaks.
2892
2906
  // RangePickerComponent.ngOnDestroy() does not call close() (unlike
2893
2907
  // FsDatePickerBaseComponent), so the calendar overlay stays in the DOM
@@ -3426,6 +3440,7 @@ class FsFilterChipsComponent {
3426
3440
  this.openChip(item, name);
3427
3441
  }
3428
3442
  openChip(item, name = null) {
3443
+ console.log('[FilterChips] openChip', item.name, 'type:', item.type, 'existingOverlay:', !!this._overlayRef);
3429
3444
  this._destroyOverlay();
3430
3445
  const el = this._elementRef.nativeElement
3431
3446
  .querySelector(`[data-filter-item="${item.name}"]`);
@@ -3508,6 +3523,7 @@ class FsFilterChipsComponent {
3508
3523
  }
3509
3524
  _destroyOverlay() {
3510
3525
  if (this._overlayRef) {
3526
+ console.log('[FilterChips] _destroyOverlay - disposing existing overlay');
3511
3527
  try {
3512
3528
  this._overlayRef.detachBackdrop();
3513
3529
  this._overlayRef.detach();