@cqa-lib/cqa-ui 1.0.81 → 1.0.84

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.
@@ -44,6 +44,10 @@ export class DynamicSelectFieldComponent {
44
44
  this.loadingMore = false;
45
45
  }
46
46
  this.lastOptionsLength = len;
47
+ // If panel is open and hasMore is true, ensure the sentinel is being observed.
48
+ if (this.selectRef?.panelOpen && this.config?.hasMore) {
49
+ setTimeout(() => this.setupLoadMoreObserver(), 0);
50
+ }
47
51
  }
48
52
  if ('form' in changes && !changes['form'].firstChange) {
49
53
  this.applySelectedValueIfNeeded();
@@ -456,4 +460,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
456
460
  type: HostListener,
457
461
  args: ['document:click', ['$event']]
458
462
  }] } });
459
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-select-field.component.js","sourceRoot":"","sources":["../../../../../src/lib/dynamic-select/dynamic-select-field.component.ts","../../../../../src/lib/dynamic-select/dynamic-select-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit, OnChanges, SimpleChanges, ViewChild, ElementRef, HostListener, Output, EventEmitter } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { MatSelect, MatSelectChange } from '@angular/material/select';\n\n// Local option model (previously imported from removed cqa-select component)\nexport interface SelectOption {\n  id?: any;\n  value?: any;\n  name?: string;\n  label?: string;\n}\n\nexport interface DynamicSelectFieldConfig {\n  key: string;\n  label?: string;\n  placeholder?: string;\n  disabled?: boolean;\n  multiple?: boolean;\n  searchable?: boolean;\n  /** Controls how selection indicator is shown for multi-select options. */\n  optionStyle?: 'checkmark' | 'checkbox';\n  /** Show a 'Select All' option at the top (multi-select only). */\n  showSelectAll?: boolean;\n  /** Custom label for the 'Select All' option. Defaults to 'All'. */\n  selectAllLabel?: string;\n  /** If true, close the panel when an option is selected (useful for multi-select in headers). */\n  closeOnSelect?: boolean;\n  /** Provide a default selected value (or array for multi-select) if the control has no value yet. */\n  selectedValue?: any | any[];\n  /** Optional callback invoked whenever the selection changes. */\n  onChange?: (value: any, event?: MatSelectChange) => void;\n  /** Enable server-side search mode; component will emit search instead of local filtering. */\n  serverSearch?: boolean;\n  /** Indicates more results are available for infinite scroll. */\n  hasMore?: boolean;\n  /** Optional loading flag controlled by consumer to show loading state. */\n  isLoading?: boolean;\n  /** Optional callback for server-side search when query changes. */\n  onSearch?: (query: string) => void;\n  /** Optional callback when more data is requested (infinite scroll). */\n  onLoadMore?: (query?: string) => void;\n  options: SelectOption[];\n}\n\n@Component({\n  selector: 'cqa-dynamic-select',\n  templateUrl: './dynamic-select-field.component.html',\n  styleUrls: [],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DynamicSelectFieldComponent implements OnInit, OnChanges {\n  readonly SELECT_ALL_VALUE: string = '__select_all__';\n  @Input() form!: FormGroup;\n  @Input() config!: DynamicSelectFieldConfig;\n  @Output() selectionChange = new EventEmitter<{ key: string; value: any; event: MatSelectChange }>();\n  @Output() selectClick = new EventEmitter<void>();\n  /** Emits when user types in search box (useful for server search) */\n  @Output() searchChange = new EventEmitter<{ key: string; query: string }>();\n  /** Emits when the component requests more data for the current query */\n  @Output() loadMore = new EventEmitter<{ key: string; query: string }>();\n\n  @ViewChild('selectRef', { static: false }) selectRef?: MatSelect;\n  @ViewChild('host', { static: false, read: ElementRef }) hostEl?: ElementRef<HTMLElement>;\n\n  // Must be public for template access in Angular's strict template checking mode\n  searchTextByKey: Record<string, string> = {};\n  private outsideCleanup?: () => void;\n  private loadMoreObserver?: IntersectionObserver;\n  private lastOptionsLength = 0;\n  loadingMore = false;\n\n  ngOnInit(): void {\n    if (!this.config || !this.config.key) {\n      throw new Error('cqa-dynamic-select: input \"config.key\" is required.');\n    }\n    this.applySelectedValueIfNeeded();\n    this.lastOptionsLength = (this.config?.options || []).length;\n  }\n\n  get displayPlaceholder(): string | undefined {\n    const key = this.config?.key;\n    if (!key || !this.form) return this.config?.placeholder;\n    const controlValue = this.form.get(key)?.value;\n    return this.hasExistingValue(controlValue) ? undefined : this.config?.placeholder;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if ('config' in changes) {\n      // When config changes (including toggling multiple), ensure control value shape matches\n      this.syncControlValueForMultipleMode();\n      this.applySelectedValueIfNeeded();\n      // Reset loadingMore when new options arrive (options length increased)\n      const len = (this.config?.options || []).length;\n      if (len > this.lastOptionsLength) {\n        this.loadingMore = false;\n      }\n      this.lastOptionsLength = len;\n    }\n    if ('form' in changes && !changes['form'].firstChange) {\n      this.applySelectedValueIfNeeded();\n    }\n  }\n\n  get panelClass(): string {\n    return `ctc-select-panel ${this.isMultiple ? 'multiple' : ''}`.trim();\n  }\n\n  get isMultiple(): boolean {\n    return this.toBoolean(this.config?.multiple);\n  }\n\n  get isDisabled(): boolean {\n    return this.toBoolean(this.config?.disabled);\n  }\n  \n  get useCheckboxStyle(): boolean {\n    return this.isMultiple && (this.config?.optionStyle === 'checkbox');\n  }\n  \n  get allSelected(): boolean {\n    if (!this.isMultiple) return false;\n    const key = this.config?.key;\n    if (!key || !this.form) return false;\n    const control = this.form.get(key);\n    if (!control) return false;\n    const selected = control.value as any[];\n    const allIds = this.getAllOptionIds();\n    if (!Array.isArray(selected)) return false;\n    if (!allIds.length) return false;\n    return allIds.every(id => selected.includes(id));\n  }\n\n  private toBoolean(value: unknown): boolean {\n    if (typeof value === 'string') {\n      const v = value.trim().toLowerCase();\n      if (v === 'true' || v === '1') return true;\n      if (v === 'false' || v === '0' || v === '') return false;\n      return true; // any other non-empty string treated as truthy\n    }\n    if (typeof value === 'number') {\n      return value !== 0;\n    }\n    return !!value;\n  }\n\n  private syncControlValueForMultipleMode(): void {\n    const key = this.config?.key;\n    if (!key || !this.form) return;\n    const control = this.form.get(key);\n    if (!control) return;\n    const currentValue = control.value;\n    if (this.isMultiple) {\n      if (currentValue == null) return;\n      if (Array.isArray(currentValue)) return;\n      control.setValue([currentValue], { emitEvent: false });\n    } else {\n      if (!Array.isArray(currentValue)) return;\n      control.setValue(currentValue.length ? currentValue[0] : null, { emitEvent: false });\n    }\n  }\n\n  private applySelectedValueIfNeeded(): void {\n    const key = this.config?.key;\n    if (!key || !this.form) return;\n    const control = this.form.get(key);\n    if (!control) return;\n    const selectedValue = this.config?.selectedValue;\n    const currentValue = control.value;\n    if (this.hasExistingValue(currentValue)) {\n      return;\n    }\n    if (selectedValue === undefined || selectedValue === null) {\n      return;\n    }\n\n    if (this.isMultiple) {\n      const normalized = (Array.isArray(selectedValue) ? selectedValue : [selectedValue]).filter(\n        (val) => val !== undefined,\n      );\n      if (!normalized.length) return;\n      control.setValue(normalized, { emitEvent: false });\n    } else {\n      const normalized = Array.isArray(selectedValue)\n        ? (selectedValue.length ? selectedValue[0] : undefined)\n        : selectedValue;\n      if (normalized === undefined) return;\n      control.setValue(normalized, { emitEvent: false });\n    }\n  }\n\n  private hasExistingValue(value: any): boolean {\n    if (value === null || value === undefined) {\n      return false;\n    }\n    if (Array.isArray(value)) {\n      return value.some((val) => val !== null && val !== undefined && val !== '');\n    }\n    if (typeof value === 'string') {\n      return value.trim().length > 0;\n    }\n    return true;\n  }\n\n  isOptionSelected(opt: SelectOption): boolean {\n    const key = this.config?.key;\n    if (!key || !this.form) return false;\n    const control = this.form.get(key);\n    if (!control) return false;\n    const controlValue = control.value;\n    const optionId = opt.id ?? opt.value;\n    if (this.isMultiple) {\n      if (!Array.isArray(controlValue)) return false;\n      return controlValue.includes(optionId);\n    }\n    return controlValue === optionId;\n  }\n\n  private getAllOptionIds(): any[] {\n    const options = this.config?.options || [];\n    return options.map(o => (o.id ?? o.value)).filter(v => v !== undefined);\n  }\n\n  onToggleSelectAll(select: MatSelect): void {\n    const key = this.config?.key;\n    if (!key || !this.form) return;\n    const control = this.form.get(key);\n    if (!control) return;\n    const allIds = this.getAllOptionIds();\n    if (!allIds.length) return;\n    if (this.allSelected) {\n      control.setValue([], { emitEvent: true });\n    } else {\n      control.setValue(allIds, { emitEvent: true });\n    }\n    // Keep panel open for continued selections in multi-select\n    try { select.open(); } catch {}\n  }\n\n  onSelectOpenedChange(opened: boolean, _select: MatSelect): void {\n    if (opened) {\n      // Emit click event when select is opened (clicked)\n      this.selectClick.emit();\n    }\n    \n    if (!opened) {\n      // Reset search text on close so the next open shows full list\n      if (this.config?.key) {\n        this.searchTextByKey[this.config.key] = '';\n      }\n      // Ensure any previous custom listeners are cleared (legacy compatibility)\n      if (this.outsideCleanup) {\n        this.outsideCleanup();\n        this.outsideCleanup = undefined;\n      }\n      // Disconnect load-more observer if any\n      if (this.loadMoreObserver) {\n        try { this.loadMoreObserver.disconnect(); } catch {}\n        this.loadMoreObserver = undefined;\n      }\n      return;\n    }\n\n    // Focus the search box if enabled\n    if (this.config?.searchable) {\n      setTimeout(() => {\n        const input = document.querySelector<HTMLInputElement>('.ts-select-search-input');\n        input?.focus();\n      }, 0);\n    }\n\n    // In serverSearch mode, if no options yet, trigger initial fetch\n    if (this.config?.serverSearch) {\n      const key = this.config.key;\n      const q = this.searchTextByKey[key] || '';\n      try { this.config.onSearch?.(q); } catch {}\n      this.searchChange.emit({ key, query: q });\n    }\n\n    // Setup infinite scroll observer on sentinel\n    setTimeout(() => this.setupLoadMoreObserver(), 0);\n  }\n\n  onSearch(key: string, value: string): void {\n    this.searchTextByKey[key] = value ?? '';\n    if (this.config?.serverSearch) {\n      // For server-side search, emit instead of local filtering\n      try { this.config.onSearch?.(value ?? ''); } catch {}\n      this.searchChange.emit({ key, query: value ?? '' });\n      // Reset internal paging state\n      this.loadingMore = false;\n      this.lastOptionsLength = (this.config?.options || []).length;\n    }\n  }\n\n  /**\n   * Returns the currently selected option ids for the configured control.\n   */\n  private getSelectedIdsForKey(key: string): any[] {\n    if (!key || !this.form) return [];\n    const control = this.form.get(key);\n    if (!control) return [];\n    const value = control.value;\n    if (this.isMultiple) {\n      return Array.isArray(value) ? value : [];\n    }\n    return value !== undefined && value !== null ? [value] : [];\n  }\n\n  /** Programmatically close the select panel if open */\n  public closePanel(): void {\n    try {\n      this.selectRef?.close();\n    } catch {}\n  }\n\n  filteredOptions(c: DynamicSelectFieldConfig): SelectOption[] {\n    const t = (this.searchTextByKey[c.key] || '').toLowerCase().trim();\n    // In server-side mode, return options as-is (parent provides list)\n    if (c.serverSearch) return c.options || [];\n    // When not searching, return full list to preserve original ordering\n    if (!t) return c.options || [];\n\n    const allOptions = c.options || [];\n    const baseFiltered = allOptions.filter((opt) => {\n      const text = String(opt.name ?? opt.label ?? opt.value ?? '').toLowerCase();\n      return text.includes(t);\n    });\n\n    // Ensure currently selected option(s) are always visible while searching\n    const selectedIds = this.getSelectedIdsForKey(c.key);\n    if (!selectedIds.length) {\n      return baseFiltered;\n    }\n\n    const idOf = (o: SelectOption) => (o.id ?? o.value);\n    const selectedOptions = allOptions.filter(o => selectedIds.includes(idOf(o)));\n\n    // Merge selected options (keeping their original order) with filtered ones, de-duplicated\n    const seen = new Set<any>();\n    const merged: SelectOption[] = [];\n    for (const o of selectedOptions) {\n      const id = idOf(o);\n      if (id === undefined) continue;\n      if (!seen.has(id)) {\n        seen.add(id);\n        merged.push(o);\n      }\n    }\n    for (const o of baseFiltered) {\n      const id = idOf(o);\n      if (id === undefined) continue;\n      if (!seen.has(id)) {\n        seen.add(id);\n        merged.push(o);\n      }\n    }\n    return merged;\n  }\n\n  // Close when an option is selected if requested. Always close for single-select.\n  onSelectionChange(event: MatSelectChange, select: MatSelect): void {\n    // Handle select-all sentinel in multi-select\n    if (this.isMultiple && Array.isArray(event.value) && event.value.includes(this.SELECT_ALL_VALUE)) {\n      // Remove sentinel and toggle all\n      const key = this.config?.key;\n      if (key && this.form) {\n        const control = this.form.get(key);\n        // Toggle based on current state\n        this.onToggleSelectAll(select);\n        // Ensure sentinel is not present\n        if (control) {\n          const filtered = (control.value as any[]).filter(v => v !== this.SELECT_ALL_VALUE);\n          control.setValue(filtered, { emitEvent: false });\n        }\n      }\n      // Do not proceed with normal close logic for select-all\n      return;\n    }\n    // Let Angular Material auto-close for single-select.\n    // For multi-select, close only if explicitly requested.\n    const shouldClose = this.isMultiple ? !!this.config?.closeOnSelect : false;\n    if (shouldClose) {\n      try {\n        select.close();\n      } catch {}\n    }\n    // If searchable, clear the search after selection so reopening works predictably\n    if (this.config?.searchable && this.config?.key) {\n      this.searchTextByKey[this.config.key] = '';\n    }\n\n    if (typeof this.config?.onChange === 'function') {\n      try {\n        this.config.onChange(event.value, event);\n      } catch (error) {\n        console.error('cqa-dynamic-select onChange handler error:', error);\n      }\n    }\n\n    this.selectionChange.emit({\n      key: this.config?.key,\n      value: event.value,\n      event,\n    });\n  }\n\n  @HostListener('document:click', ['$event'])\n  handleDocumentClick(event: MouseEvent): void {\n    // Close when clicking outside of the trigger and outside of the open panel\n    if (!this.selectRef?.panelOpen) {\n      return;\n    }\n    const target = event.target as HTMLElement | null;\n    if (!target) return;\n    // If click is inside the component host, ignore\n    if (this.hostEl?.nativeElement && this.hostEl.nativeElement.contains(target)) {\n      return;\n    }\n    // If click is inside any open mat-select panel, ignore\n    const panelEls = Array.from(document.querySelectorAll('.mat-select-panel')) as HTMLElement[];\n    const clickInsidePanel = panelEls.some((el) => el.contains(target));\n    if (clickInsidePanel) {\n      return;\n    }\n    try {\n      this.selectRef.close();\n    } catch {}\n  }\n\n  private setupLoadMoreObserver(): void {\n    // Only if consumer indicates more data is available\n    if (!this.config?.hasMore) return;\n    // Find sentinel option rendered in the open panel\n    const sentinel = document.querySelector('.mat-select-panel .mat-option.load-more-sentinel') as HTMLElement | null;\n    if (!sentinel) return;\n    if (this.loadMoreObserver) {\n      try { this.loadMoreObserver.disconnect(); } catch {}\n      this.loadMoreObserver = undefined;\n    }\n    this.loadMoreObserver = new IntersectionObserver((entries) => {\n      for (const entry of entries) {\n        if (entry.isIntersecting) {\n          // Request more only if not currently loading and hasMore still true\n          if (!this.loadingMore && this.config?.hasMore) {\n            this.loadingMore = true;\n            const key = this.config?.key || '';\n            const q = this.searchTextByKey[key] || '';\n            // Emit outputs and invoke optional callbacks\n            this.loadMore.emit({ key, query: q });\n            try { this.config.onLoadMore?.(q); } catch {}\n          }\n        }\n      }\n    }, { root: document.querySelector('.mat-select-panel') as Element | null, threshold: 0.1 });\n    try { this.loadMoreObserver.observe(sentinel); } catch {}\n  }\n}\n\n\n","<div class=\"cqa-ui-root\">\n  <ng-container [formGroup]=\"form\">\n    <label *ngIf=\"config.label\"\n      class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4] cqa-mb-2\">{{\n      config.label }}</label>\n    <mat-form-field #host class=\"mat-select-custom cqa-w-full\" appearance=\"fill\">\n      <mat-select #selectRef=\"matSelect\" [placeholder]=\"displayPlaceholder\" [disabled]=\"isDisabled\" [multiple]=\"isMultiple\"\n        disableOptionCentering [panelClass]=\"panelClass\" [formControlName]=\"config.key\"\n        (openedChange)=\"onSelectOpenedChange($event, selectRef)\" (selectionChange)=\"onSelectionChange($event, selectRef)\">\n\n        <mat-option *ngIf=\"config.searchable\" class=\"ts-select-search\" disabled>\n          <input class=\"ts-select-search-input cqa-text-black-100\" type=\"text\" [value]=\"searchTextByKey[config.key] || ''\"\n            (click)=\"$event.stopPropagation()\" (mousedown)=\"$event.stopPropagation()\"\n            (keydown)=\"$event.stopPropagation()\" (input)=\"onSearch(config.key, $any($event.target).value)\"\n            placeholder=\"Search...\" />\n        </mat-option>\n        \n        <mat-option [ngClass]=\"{'checkmark': config.optionStyle === 'checkmark','checkbox': config.optionStyle !== 'checkmark','mat-selected': allSelected}\" [class]=\"config.optionStyle == 'checkmark' ? 'checkmark' : 'checkbox'\" *ngIf=\"isMultiple && config.showSelectAll\" [value]=\"SELECT_ALL_VALUE\">\n          <ng-container *ngIf=\"useCheckboxStyle; else selectAllDefaultTpl\">\n            <span class=\"cqa-flex cqa-items-center\">\n              <span class=\"cqa-w-4 cqa-h-4 cqa-flex-shrink-0 cqa-rounded-[4px] cqa-border cqa-border-[#D1D5DB] cqa-mr-2 cqa-flex cqa-items-center cqa-justify-center cqa-border-solid\"\n                [ngStyle]=\"allSelected ? {'background-color':'#4F46E5','border-color':'#4F46E5'} : {}\">\n                <svg *ngIf=\"allSelected\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                  <path d=\"M10 3L4.5 8.5L2 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                </svg>\n              </span>\n              <span class=\"cqa-min-w-0\">{{ config.selectAllLabel || 'All' }}</span>\n            </span>\n          </ng-container>\n          <ng-template #selectAllDefaultTpl>\n            {{ config.selectAllLabel || 'All' }}\n          </ng-template>\n        </mat-option>\n\n        <mat-option [class]=\"config.optionStyle == 'checkmark' ? 'checkmark' : 'checkbox'\" *ngFor=\"let opt of filteredOptions(config)\" [value]=\"opt.id ?? opt.value\">\n          <ng-container *ngIf=\"useCheckboxStyle; else defaultOptionTpl\">\n            <span class=\"cqa-flex cqa-items-center\">\n              <span class=\"cqa-w-4 cqa-h-4 cqa-flex-shrink-0 cqa-rounded-[4px] cqa-border cqa-border-[#D1D5DB] cqa-mr-2 cqa-flex cqa-items-center cqa-justify-center cqa-border-solid\"\n                [ngStyle]=\"isOptionSelected(opt) ? {'background-color':'#4F46E5','border-color':'#4F46E5'} : {}\">\n                <svg *ngIf=\"isOptionSelected(opt)\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                  <path d=\"M10 3L4.5 8.5L2 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                </svg>\n              </span>\n              <span class=\"cqa-min-w-0\">{{ opt.name ?? opt.label ?? opt.value }}</span>\n            </span>\n          </ng-container>\n          <ng-template #defaultOptionTpl>\n            {{ opt.name ?? opt.label ?? opt.value }}\n          </ng-template>\n        </mat-option>\n        \n        <!-- No results state (only when not loading and no options) -->\n        <mat-option disabled *ngIf=\"!(config?.options?.length || 0) && !(config?.isLoading || loadingMore)\">\n          No results\n        </mat-option>\n        <!-- Infinite scroll sentinel (serverSearch or explicit hasMore) -->\n        <mat-option disabled class=\"load-more-sentinel\" *ngIf=\"config?.hasMore\">\n          <span *ngIf=\"config?.isLoading || loadingMore\">Loading...</span>\n          <span *ngIf=\"!(config?.isLoading || loadingMore)\">Scroll to load more…</span>\n        </mat-option>\n      </mat-select>\n\n      <div>\n        <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M4 6L8 10L12 6\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </div>\n    </mat-form-field>\n  </ng-container>\n</div>"]}
463
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-select-field.component.js","sourceRoot":"","sources":["../../../../../src/lib/dynamic-select/dynamic-select-field.component.ts","../../../../../src/lib/dynamic-select/dynamic-select-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit, OnChanges, SimpleChanges, ViewChild, ElementRef, HostListener, Output, EventEmitter } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { MatSelect, MatSelectChange } from '@angular/material/select';\n\n// Local option model (previously imported from removed cqa-select component)\nexport interface SelectOption {\n  id?: any;\n  value?: any;\n  name?: string;\n  label?: string;\n}\n\nexport interface DynamicSelectFieldConfig {\n  key: string;\n  label?: string;\n  placeholder?: string;\n  disabled?: boolean;\n  multiple?: boolean;\n  searchable?: boolean;\n  /** Controls how selection indicator is shown for multi-select options. */\n  optionStyle?: 'checkmark' | 'checkbox';\n  /** Show a 'Select All' option at the top (multi-select only). */\n  showSelectAll?: boolean;\n  /** Custom label for the 'Select All' option. Defaults to 'All'. */\n  selectAllLabel?: string;\n  /** If true, close the panel when an option is selected (useful for multi-select in headers). */\n  closeOnSelect?: boolean;\n  /** Provide a default selected value (or array for multi-select) if the control has no value yet. */\n  selectedValue?: any | any[];\n  /** Optional callback invoked whenever the selection changes. */\n  onChange?: (value: any, event?: MatSelectChange) => void;\n  /** Enable server-side search mode; component will emit search instead of local filtering. */\n  serverSearch?: boolean;\n  /** Indicates more results are available for infinite scroll. */\n  hasMore?: boolean;\n  /** Optional loading flag controlled by consumer to show loading state. */\n  isLoading?: boolean;\n  /** Optional callback for server-side search when query changes. */\n  onSearch?: (query: string) => void;\n  /** Optional callback when more data is requested (infinite scroll). */\n  onLoadMore?: (query?: string) => void;\n  options: SelectOption[];\n}\n\n@Component({\n  selector: 'cqa-dynamic-select',\n  templateUrl: './dynamic-select-field.component.html',\n  styleUrls: [],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DynamicSelectFieldComponent implements OnInit, OnChanges {\n  readonly SELECT_ALL_VALUE: string = '__select_all__';\n  @Input() form!: FormGroup;\n  @Input() config!: DynamicSelectFieldConfig;\n  @Output() selectionChange = new EventEmitter<{ key: string; value: any; event: MatSelectChange }>();\n  @Output() selectClick = new EventEmitter<void>();\n  /** Emits when user types in search box (useful for server search) */\n  @Output() searchChange = new EventEmitter<{ key: string; query: string }>();\n  /** Emits when the component requests more data for the current query */\n  @Output() loadMore = new EventEmitter<{ key: string; query: string }>();\n\n  @ViewChild('selectRef', { static: false }) selectRef?: MatSelect;\n  @ViewChild('host', { static: false, read: ElementRef }) hostEl?: ElementRef<HTMLElement>;\n\n  // Must be public for template access in Angular's strict template checking mode\n  searchTextByKey: Record<string, string> = {};\n  private outsideCleanup?: () => void;\n  private loadMoreObserver?: IntersectionObserver;\n  private lastOptionsLength = 0;\n  loadingMore = false;\n\n  ngOnInit(): void {\n    if (!this.config || !this.config.key) {\n      throw new Error('cqa-dynamic-select: input \"config.key\" is required.');\n    }\n    this.applySelectedValueIfNeeded();\n    this.lastOptionsLength = (this.config?.options || []).length;\n  }\n\n  get displayPlaceholder(): string | undefined {\n    const key = this.config?.key;\n    if (!key || !this.form) return this.config?.placeholder;\n    const controlValue = this.form.get(key)?.value;\n    return this.hasExistingValue(controlValue) ? undefined : this.config?.placeholder;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if ('config' in changes) {\n      // When config changes (including toggling multiple), ensure control value shape matches\n      this.syncControlValueForMultipleMode();\n      this.applySelectedValueIfNeeded();\n      // Reset loadingMore when new options arrive (options length increased)\n      const len = (this.config?.options || []).length;\n      if (len > this.lastOptionsLength) {\n        this.loadingMore = false;\n      }\n      this.lastOptionsLength = len;\n      // If panel is open and hasMore is true, ensure the sentinel is being observed.\n      if (this.selectRef?.panelOpen && this.config?.hasMore) {\n        setTimeout(() => this.setupLoadMoreObserver(), 0);\n      }\n    }\n    if ('form' in changes && !changes['form'].firstChange) {\n      this.applySelectedValueIfNeeded();\n    }\n  }\n\n  get panelClass(): string {\n    return `ctc-select-panel ${this.isMultiple ? 'multiple' : ''}`.trim();\n  }\n\n  get isMultiple(): boolean {\n    return this.toBoolean(this.config?.multiple);\n  }\n\n  get isDisabled(): boolean {\n    return this.toBoolean(this.config?.disabled);\n  }\n  \n  get useCheckboxStyle(): boolean {\n    return this.isMultiple && (this.config?.optionStyle === 'checkbox');\n  }\n  \n  get allSelected(): boolean {\n    if (!this.isMultiple) return false;\n    const key = this.config?.key;\n    if (!key || !this.form) return false;\n    const control = this.form.get(key);\n    if (!control) return false;\n    const selected = control.value as any[];\n    const allIds = this.getAllOptionIds();\n    if (!Array.isArray(selected)) return false;\n    if (!allIds.length) return false;\n    return allIds.every(id => selected.includes(id));\n  }\n\n  private toBoolean(value: unknown): boolean {\n    if (typeof value === 'string') {\n      const v = value.trim().toLowerCase();\n      if (v === 'true' || v === '1') return true;\n      if (v === 'false' || v === '0' || v === '') return false;\n      return true; // any other non-empty string treated as truthy\n    }\n    if (typeof value === 'number') {\n      return value !== 0;\n    }\n    return !!value;\n  }\n\n  private syncControlValueForMultipleMode(): void {\n    const key = this.config?.key;\n    if (!key || !this.form) return;\n    const control = this.form.get(key);\n    if (!control) return;\n    const currentValue = control.value;\n    if (this.isMultiple) {\n      if (currentValue == null) return;\n      if (Array.isArray(currentValue)) return;\n      control.setValue([currentValue], { emitEvent: false });\n    } else {\n      if (!Array.isArray(currentValue)) return;\n      control.setValue(currentValue.length ? currentValue[0] : null, { emitEvent: false });\n    }\n  }\n\n  private applySelectedValueIfNeeded(): void {\n    const key = this.config?.key;\n    if (!key || !this.form) return;\n    const control = this.form.get(key);\n    if (!control) return;\n    const selectedValue = this.config?.selectedValue;\n    const currentValue = control.value;\n    if (this.hasExistingValue(currentValue)) {\n      return;\n    }\n    if (selectedValue === undefined || selectedValue === null) {\n      return;\n    }\n\n    if (this.isMultiple) {\n      const normalized = (Array.isArray(selectedValue) ? selectedValue : [selectedValue]).filter(\n        (val) => val !== undefined,\n      );\n      if (!normalized.length) return;\n      control.setValue(normalized, { emitEvent: false });\n    } else {\n      const normalized = Array.isArray(selectedValue)\n        ? (selectedValue.length ? selectedValue[0] : undefined)\n        : selectedValue;\n      if (normalized === undefined) return;\n      control.setValue(normalized, { emitEvent: false });\n    }\n  }\n\n  private hasExistingValue(value: any): boolean {\n    if (value === null || value === undefined) {\n      return false;\n    }\n    if (Array.isArray(value)) {\n      return value.some((val) => val !== null && val !== undefined && val !== '');\n    }\n    if (typeof value === 'string') {\n      return value.trim().length > 0;\n    }\n    return true;\n  }\n\n  isOptionSelected(opt: SelectOption): boolean {\n    const key = this.config?.key;\n    if (!key || !this.form) return false;\n    const control = this.form.get(key);\n    if (!control) return false;\n    const controlValue = control.value;\n    const optionId = opt.id ?? opt.value;\n    if (this.isMultiple) {\n      if (!Array.isArray(controlValue)) return false;\n      return controlValue.includes(optionId);\n    }\n    return controlValue === optionId;\n  }\n\n  private getAllOptionIds(): any[] {\n    const options = this.config?.options || [];\n    return options.map(o => (o.id ?? o.value)).filter(v => v !== undefined);\n  }\n\n  onToggleSelectAll(select: MatSelect): void {\n    const key = this.config?.key;\n    if (!key || !this.form) return;\n    const control = this.form.get(key);\n    if (!control) return;\n    const allIds = this.getAllOptionIds();\n    if (!allIds.length) return;\n    if (this.allSelected) {\n      control.setValue([], { emitEvent: true });\n    } else {\n      control.setValue(allIds, { emitEvent: true });\n    }\n    // Keep panel open for continued selections in multi-select\n    try { select.open(); } catch {}\n  }\n\n  onSelectOpenedChange(opened: boolean, _select: MatSelect): void {\n    if (opened) {\n      // Emit click event when select is opened (clicked)\n      this.selectClick.emit();\n    }\n    \n    if (!opened) {\n      // Reset search text on close so the next open shows full list\n      if (this.config?.key) {\n        this.searchTextByKey[this.config.key] = '';\n      }\n      // Ensure any previous custom listeners are cleared (legacy compatibility)\n      if (this.outsideCleanup) {\n        this.outsideCleanup();\n        this.outsideCleanup = undefined;\n      }\n      // Disconnect load-more observer if any\n      if (this.loadMoreObserver) {\n        try { this.loadMoreObserver.disconnect(); } catch {}\n        this.loadMoreObserver = undefined;\n      }\n      return;\n    }\n\n    // Focus the search box if enabled\n    if (this.config?.searchable) {\n      setTimeout(() => {\n        const input = document.querySelector<HTMLInputElement>('.ts-select-search-input');\n        input?.focus();\n      }, 0);\n    }\n\n    // In serverSearch mode, if no options yet, trigger initial fetch\n    if (this.config?.serverSearch) {\n      const key = this.config.key;\n      const q = this.searchTextByKey[key] || '';\n      try { this.config.onSearch?.(q); } catch {}\n      this.searchChange.emit({ key, query: q });\n    }\n\n    // Setup infinite scroll observer on sentinel\n    setTimeout(() => this.setupLoadMoreObserver(), 0);\n  }\n\n  onSearch(key: string, value: string): void {\n    this.searchTextByKey[key] = value ?? '';\n    if (this.config?.serverSearch) {\n      // For server-side search, emit instead of local filtering\n      try { this.config.onSearch?.(value ?? ''); } catch {}\n      this.searchChange.emit({ key, query: value ?? '' });\n      // Reset internal paging state\n      this.loadingMore = false;\n      this.lastOptionsLength = (this.config?.options || []).length;\n    }\n  }\n\n  /**\n   * Returns the currently selected option ids for the configured control.\n   */\n  private getSelectedIdsForKey(key: string): any[] {\n    if (!key || !this.form) return [];\n    const control = this.form.get(key);\n    if (!control) return [];\n    const value = control.value;\n    if (this.isMultiple) {\n      return Array.isArray(value) ? value : [];\n    }\n    return value !== undefined && value !== null ? [value] : [];\n  }\n\n  /** Programmatically close the select panel if open */\n  public closePanel(): void {\n    try {\n      this.selectRef?.close();\n    } catch {}\n  }\n\n  filteredOptions(c: DynamicSelectFieldConfig): SelectOption[] {\n    const t = (this.searchTextByKey[c.key] || '').toLowerCase().trim();\n    // In server-side mode, return options as-is (parent provides list)\n    if (c.serverSearch) return c.options || [];\n    // When not searching, return full list to preserve original ordering\n    if (!t) return c.options || [];\n\n    const allOptions = c.options || [];\n    const baseFiltered = allOptions.filter((opt) => {\n      const text = String(opt.name ?? opt.label ?? opt.value ?? '').toLowerCase();\n      return text.includes(t);\n    });\n\n    // Ensure currently selected option(s) are always visible while searching\n    const selectedIds = this.getSelectedIdsForKey(c.key);\n    if (!selectedIds.length) {\n      return baseFiltered;\n    }\n\n    const idOf = (o: SelectOption) => (o.id ?? o.value);\n    const selectedOptions = allOptions.filter(o => selectedIds.includes(idOf(o)));\n\n    // Merge selected options (keeping their original order) with filtered ones, de-duplicated\n    const seen = new Set<any>();\n    const merged: SelectOption[] = [];\n    for (const o of selectedOptions) {\n      const id = idOf(o);\n      if (id === undefined) continue;\n      if (!seen.has(id)) {\n        seen.add(id);\n        merged.push(o);\n      }\n    }\n    for (const o of baseFiltered) {\n      const id = idOf(o);\n      if (id === undefined) continue;\n      if (!seen.has(id)) {\n        seen.add(id);\n        merged.push(o);\n      }\n    }\n    return merged;\n  }\n\n  // Close when an option is selected if requested. Always close for single-select.\n  onSelectionChange(event: MatSelectChange, select: MatSelect): void {\n    // Handle select-all sentinel in multi-select\n    if (this.isMultiple && Array.isArray(event.value) && event.value.includes(this.SELECT_ALL_VALUE)) {\n      // Remove sentinel and toggle all\n      const key = this.config?.key;\n      if (key && this.form) {\n        const control = this.form.get(key);\n        // Toggle based on current state\n        this.onToggleSelectAll(select);\n        // Ensure sentinel is not present\n        if (control) {\n          const filtered = (control.value as any[]).filter(v => v !== this.SELECT_ALL_VALUE);\n          control.setValue(filtered, { emitEvent: false });\n        }\n      }\n      // Do not proceed with normal close logic for select-all\n      return;\n    }\n    // Let Angular Material auto-close for single-select.\n    // For multi-select, close only if explicitly requested.\n    const shouldClose = this.isMultiple ? !!this.config?.closeOnSelect : false;\n    if (shouldClose) {\n      try {\n        select.close();\n      } catch {}\n    }\n    // If searchable, clear the search after selection so reopening works predictably\n    if (this.config?.searchable && this.config?.key) {\n      this.searchTextByKey[this.config.key] = '';\n    }\n\n    if (typeof this.config?.onChange === 'function') {\n      try {\n        this.config.onChange(event.value, event);\n      } catch (error) {\n        console.error('cqa-dynamic-select onChange handler error:', error);\n      }\n    }\n\n    this.selectionChange.emit({\n      key: this.config?.key,\n      value: event.value,\n      event,\n    });\n  }\n\n  @HostListener('document:click', ['$event'])\n  handleDocumentClick(event: MouseEvent): void {\n    // Close when clicking outside of the trigger and outside of the open panel\n    if (!this.selectRef?.panelOpen) {\n      return;\n    }\n    const target = event.target as HTMLElement | null;\n    if (!target) return;\n    // If click is inside the component host, ignore\n    if (this.hostEl?.nativeElement && this.hostEl.nativeElement.contains(target)) {\n      return;\n    }\n    // If click is inside any open mat-select panel, ignore\n    const panelEls = Array.from(document.querySelectorAll('.mat-select-panel')) as HTMLElement[];\n    const clickInsidePanel = panelEls.some((el) => el.contains(target));\n    if (clickInsidePanel) {\n      return;\n    }\n    try {\n      this.selectRef.close();\n    } catch {}\n  }\n\n  private setupLoadMoreObserver(): void {\n    // Only if consumer indicates more data is available\n    if (!this.config?.hasMore) return;\n    // Find sentinel option rendered in the open panel\n    const sentinel = document.querySelector('.mat-select-panel .mat-option.load-more-sentinel') as HTMLElement | null;\n    if (!sentinel) return;\n    if (this.loadMoreObserver) {\n      try { this.loadMoreObserver.disconnect(); } catch {}\n      this.loadMoreObserver = undefined;\n    }\n    this.loadMoreObserver = new IntersectionObserver((entries) => {\n      for (const entry of entries) {\n        if (entry.isIntersecting) {\n          // Request more only if not currently loading and hasMore still true\n          if (!this.loadingMore && this.config?.hasMore) {\n            this.loadingMore = true;\n            const key = this.config?.key || '';\n            const q = this.searchTextByKey[key] || '';\n            // Emit outputs and invoke optional callbacks\n            this.loadMore.emit({ key, query: q });\n            try { this.config.onLoadMore?.(q); } catch {}\n          }\n        }\n      }\n    }, { root: document.querySelector('.mat-select-panel') as Element | null, threshold: 0.1 });\n    try { this.loadMoreObserver.observe(sentinel); } catch {}\n  }\n}\n\n\n","<div class=\"cqa-ui-root\">\n  <ng-container [formGroup]=\"form\">\n    <label *ngIf=\"config.label\"\n      class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4] cqa-mb-2\">{{\n      config.label }}</label>\n    <mat-form-field #host class=\"mat-select-custom cqa-w-full\" appearance=\"fill\">\n      <mat-select #selectRef=\"matSelect\" [placeholder]=\"displayPlaceholder\" [disabled]=\"isDisabled\" [multiple]=\"isMultiple\"\n        disableOptionCentering [panelClass]=\"panelClass\" [formControlName]=\"config.key\"\n        (openedChange)=\"onSelectOpenedChange($event, selectRef)\" (selectionChange)=\"onSelectionChange($event, selectRef)\">\n\n        <mat-option *ngIf=\"config.searchable\" class=\"ts-select-search\" disabled>\n          <input class=\"ts-select-search-input cqa-text-black-100\" type=\"text\" [value]=\"searchTextByKey[config.key] || ''\"\n            (click)=\"$event.stopPropagation()\" (mousedown)=\"$event.stopPropagation()\"\n            (keydown)=\"$event.stopPropagation()\" (input)=\"onSearch(config.key, $any($event.target).value)\"\n            placeholder=\"Search...\" />\n        </mat-option>\n        \n        <mat-option [ngClass]=\"{'checkmark': config.optionStyle === 'checkmark','checkbox': config.optionStyle !== 'checkmark','mat-selected': allSelected}\" [class]=\"config.optionStyle == 'checkmark' ? 'checkmark' : 'checkbox'\" *ngIf=\"isMultiple && config.showSelectAll\" [value]=\"SELECT_ALL_VALUE\">\n          <ng-container *ngIf=\"useCheckboxStyle; else selectAllDefaultTpl\">\n            <span class=\"cqa-flex cqa-items-center\">\n              <span class=\"cqa-w-4 cqa-h-4 cqa-flex-shrink-0 cqa-rounded-[4px] cqa-border cqa-border-[#D1D5DB] cqa-mr-2 cqa-flex cqa-items-center cqa-justify-center cqa-border-solid\"\n                [ngStyle]=\"allSelected ? {'background-color':'#4F46E5','border-color':'#4F46E5'} : {}\">\n                <svg *ngIf=\"allSelected\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                  <path d=\"M10 3L4.5 8.5L2 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                </svg>\n              </span>\n              <span class=\"cqa-min-w-0\">{{ config.selectAllLabel || 'All' }}</span>\n            </span>\n          </ng-container>\n          <ng-template #selectAllDefaultTpl>\n            {{ config.selectAllLabel || 'All' }}\n          </ng-template>\n        </mat-option>\n\n        <mat-option [class]=\"config.optionStyle == 'checkmark' ? 'checkmark' : 'checkbox'\" *ngFor=\"let opt of filteredOptions(config)\" [value]=\"opt.id ?? opt.value\">\n          <ng-container *ngIf=\"useCheckboxStyle; else defaultOptionTpl\">\n            <span class=\"cqa-flex cqa-items-center\">\n              <span class=\"cqa-w-4 cqa-h-4 cqa-flex-shrink-0 cqa-rounded-[4px] cqa-border cqa-border-[#D1D5DB] cqa-mr-2 cqa-flex cqa-items-center cqa-justify-center cqa-border-solid\"\n                [ngStyle]=\"isOptionSelected(opt) ? {'background-color':'#4F46E5','border-color':'#4F46E5'} : {}\">\n                <svg *ngIf=\"isOptionSelected(opt)\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                  <path d=\"M10 3L4.5 8.5L2 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                </svg>\n              </span>\n              <span class=\"cqa-min-w-0\">{{ opt.name ?? opt.label ?? opt.value }}</span>\n            </span>\n          </ng-container>\n          <ng-template #defaultOptionTpl>\n            {{ opt.name ?? opt.label ?? opt.value }}\n          </ng-template>\n        </mat-option>\n        \n        <!-- No results state (only when not loading and no options) -->\n        <mat-option disabled *ngIf=\"!(config?.options?.length || 0) && !(config?.isLoading || loadingMore)\">\n          No results\n        </mat-option>\n        <!-- Infinite scroll sentinel (serverSearch or explicit hasMore) -->\n        <mat-option disabled class=\"load-more-sentinel\" *ngIf=\"config?.hasMore\">\n          <span *ngIf=\"config?.isLoading || loadingMore\">Loading...</span>\n          <span *ngIf=\"!(config?.isLoading || loadingMore)\">Scroll to load more…</span>\n        </mat-option>\n      </mat-select>\n\n      <div>\n        <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M4 6L8 10L12 6\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </div>\n    </mat-form-field>\n  </ng-container>\n</div>"]}
@@ -161,6 +161,11 @@ export class DynamicFilterComponent {
161
161
  showSelectAll: item.showSelectAll,
162
162
  selectAllLabel: item.selectAllLabel,
163
163
  selectedValue: item.selectedValue,
164
+ serverSearch: item.serverSearch,
165
+ hasMore: item.hasMore,
166
+ isLoading: item.isLoading,
167
+ onSearch: item.onSearch,
168
+ onLoadMore: item.onLoadMore,
164
169
  options: item.options || []
165
170
  };
166
171
  }
@@ -392,4 +397,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
392
397
  type: ViewChildren,
393
398
  args: [DynamicSelectFieldComponent]
394
399
  }] } });
395
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-filter.component.js","sourceRoot":"","sources":["../../../../../../src/lib/filters/dynamic-filter/dynamic-filter.component.ts","../../../../../../src/lib/filters/dynamic-filter/dynamic-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChildren, QueryList } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\nimport { MatDatepickerInputEvent } from '@angular/material/datepicker';\nimport { DynamicSelectFieldConfig } from '../../dynamic-select/dynamic-select-field.component';\nimport { DynamicSelectFieldComponent } from '../../dynamic-select/dynamic-select-field.component';\n\ntype FilterType = 'select' | 'date-range';\n\nexport interface DynamicFilterOption {\n  id?: number | string;\n  name?: string;\n  value?: any;\n  label?: string;\n}\n\nexport interface DynamicFilterItem {\n  label: string;\n  placeholder?: string;\n  type: FilterType;\n  key: string;\n  options?: DynamicFilterOption[];\n  multiple?: boolean;\n  disabled?: boolean;\n  hidden?: boolean;\n  searchable?: boolean;\n  optionStyle?: 'checkmark' | 'checkbox';\n  showSelectAll?: boolean;\n  selectAllLabel?: string;\n  selectedValue?: any | any[];\n  selectedStartDate?: Date | string;\n  selectedEndDate?: Date | string;\n  onDateChange?: (value: { start: Date | null; end: Date | null }, event?: MatDatepickerInputEvent<Date> | Event) => void;\n}\n\nexport interface DynamicFilterValues {\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'cqa-dynamic-filter',\n  templateUrl: './dynamic-filter.component.html',\n  styleUrls: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { class: 'cqa-ui-root' }\n})\nexport class DynamicFilterComponent implements OnChanges {\n  @Input() config: DynamicFilterItem[] = [];\n  @Input() model: DynamicFilterValues = {};\n  @Input() showFilterPanel: boolean = true;\n  @Input() buttonLayout: 'left' | 'right' | 'bottom' = 'bottom';\n  @Output() filtersApplied = new EventEmitter<DynamicFilterValues>();\n  @Output() filtersChanged = new EventEmitter<DynamicFilterValues>();\n  @Output() resetAction = new EventEmitter<void>();\n  @Output() onApplyFilterClick = new EventEmitter<DynamicFilterValues>();\n  @Output() onResetFilterClick = new EventEmitter<void>();\n\n  form: FormGroup = this.fb.group({});\n  maxDate = new Date();\n  searchTextByKey: Record<string, string> = {};\n  private selectOutsideCleanup = new Map<any, () => void>();\n  hasSelectedFilters = false;\n  @ViewChildren(DynamicSelectFieldComponent) selectComponents?: QueryList<DynamicSelectFieldComponent>;\n\n  constructor(private readonly fb: FormBuilder) {\n    // Ensure maxDate is the end of today, so any future dates are disallowed\n    this.maxDate = this.endOfDay(new Date());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] || changes['model']) {\n      this.buildForm();\n    }\n  }\n\n  onDateChange(event: MatDatepickerInputEvent<Date> | Event, key: string): void {\n    this.invokeDateRangeChange(key, event);\n  }\n\n  // NGX DateRangePicker integration\n  ngxDateRangeByKey: Record<string, any> = {};\n  ngxRanges: any = {}; // Using 'any' to avoid Dayjs type mismatch - library accepts Date objects at runtime\n  ngxLocale = { customRangeLabel: 'Custom range' };\n  // Disable all dates after today in the ngx datepicker\n  disableFutureDates = (m: any): boolean => {\n    try {\n      const d: Date = m && typeof m.toDate === 'function' ? m.toDate() : new Date(m);\n      return d.getTime() > this.maxDate.getTime();\n    } catch {\n      return false;\n    }\n  };\n  onNgxDatesUpdated(e: any, key: string): void {\n    const group = this.getDateGroup(key);\n    if (!group) return;\n    const clamp = (d: Date | null) => (d && d.getTime() > this.maxDate.getTime() ? this.maxDate : d);\n    const startRaw = e?.startDate ? (typeof e.startDate.toDate === 'function' ? e.startDate.toDate() : new Date(e.startDate)) : null;\n    const endRaw = e?.endDate ? (typeof e.endDate.toDate === 'function' ? e.endDate.toDate() : new Date(e.endDate)) : null;\n    const start = clamp(startRaw);\n    const end = clamp(endRaw);\n    group.patchValue({ start, end }, { emitEvent: true });\n    const serialized = this.serialize();\n    this.hasSelectedFilters = Object.keys(serialized).length > 0;\n    if (start && end && group.valid) {\n      this.apply();\n    } else {\n      this.filtersChanged.emit(serialized);\n    }\n  }\n\n  private buildForm(): void {\n    const ctrls: Record<string, any> = {};\n    (this.config || []).forEach(c => {\n      if (c.hidden) return;\n      if (c.type === 'date-range') {\n        const initialRange = this.getInitialDateRangeValue(c);\n        ctrls[c.key] = this.fb.group({\n          start: new FormControl(initialRange.start),\n          end: new FormControl(initialRange.end),\n        });\n        // initialize ngx model display\n        this.ngxDateRangeByKey[c.key] = {\n          startDate: initialRange.start || null,\n          endDate: initialRange.end || null\n        };\n      } else {\n        const initial = this.resolveInitialSelectValue(c);\n        if (c.multiple) {\n          const value = Array.isArray(initial) ? initial : (initial != null ? [initial] : []);\n          ctrls[c.key] = new FormControl(value);\n        } else {\n          ctrls[c.key] = new FormControl(this.coerceToSingleValue(initial));\n        }\n      }\n    });\n    this.form = this.fb.group(ctrls);\n    // initialize apply button state based on initial values\n    this.hasSelectedFilters = Object.keys(this.serialize()).length > 0;\n    // build common ranges for ngx datepicker\n    this.ngxRanges = this.buildNgxRanges();\n    this.form.valueChanges.subscribe(() => {\n      const serialized = this.serialize();\n      this.hasSelectedFilters = Object.keys(serialized).length > 0;\n      this.filtersChanged.emit(serialized);\n    });\n  }\n\n  onSelectOpenedChange(opened: boolean, select: any): void {\n    if (opened) {\n      setTimeout(() => {\n        const onDocDown = (e: MouseEvent) => {\n          const panel = document.querySelector('.cdk-overlay-pane .mat-select-panel') as HTMLElement | null;\n          const target = e.target as Node | null;\n          const originEl = (select?._elementRef?.nativeElement as HTMLElement) || null;\n          const insidePanel = !!(panel && target && panel.contains(target));\n          const insideOrigin = !!(originEl && target && originEl.contains(target));\n          if (!insidePanel && !insideOrigin) {\n            select.close();\n          }\n        };\n        document.addEventListener('mousedown', onDocDown, true);\n        this.selectOutsideCleanup.set(select, () => document.removeEventListener('mousedown', onDocDown, true));\n      }, 0);\n    } else {\n      const cleanup = this.selectOutsideCleanup.get(select);\n      if (cleanup) cleanup();\n      this.selectOutsideCleanup.delete(select);\n    }\n  }\n\n  onSearch(key: string, text: string): void {\n    this.searchTextByKey[key] = (text || '').toLowerCase();\n  }\n\n  filteredOptions(item: DynamicFilterItem): DynamicFilterOption[] {\n    const options = item?.options || [];\n    const q = (this.searchTextByKey[item.key] || '').trim();\n    if (!q) return options;\n    return options.filter(opt => {\n      const name = (opt.name ?? opt.label ?? String(opt.value ?? '')).toLowerCase();\n      return name.includes(q);\n    });\n  }\n\n  getDateGroup(key: string): FormGroup {\n    return this.form.get(key) as FormGroup;\n  }\n\n  getSelectConfig(item: DynamicFilterItem): DynamicSelectFieldConfig {\n    return {\n      key: item.key,\n      label: item.label,\n      placeholder: item.placeholder,\n      disabled: item.disabled,\n      multiple: item.multiple,\n      searchable: item.searchable,\n      optionStyle: item.optionStyle,\n      showSelectAll: item.showSelectAll,\n      selectAllLabel: item.selectAllLabel,\n      selectedValue: item.selectedValue,\n      options: item.options || []\n    };\n  }\n\n  apply(): void {\n    this.closeAllOpenSelects();\n    const filterValues = this.serialize();\n    this.filtersApplied.emit(filterValues);\n    this.onApplyFilterClick.emit(filterValues);\n  }\n\n  reset(): void {\n    this.closeAllOpenSelects();\n    Object.keys(this.form.controls).forEach(key => {\n      const ctrl = this.form.get(key);\n      if (ctrl instanceof FormGroup) {\n        ctrl.get('start')?.setValue(undefined);\n        ctrl.get('end')?.setValue(undefined);\n        this.invokeDateRangeChange(key);\n      } else {\n        ctrl?.setValue(undefined);\n      }\n    });\n    this.resetAction.emit();\n    this.onResetFilterClick.emit();\n    const serialized = this.serialize();\n    this.hasSelectedFilters = Object.keys(serialized).length > 0;\n    this.filtersChanged.emit(serialized);\n  }\n\n  /** Close any open MatSelect panels before primary actions to avoid double-click issues */\n  preparePrimaryAction(): void {\n    this.closeAllOpenSelects();\n  }\n\n  private closeAllOpenSelects(): void {\n    try {\n      this.selectComponents?.forEach(c => c.closePanel());\n    } catch {}\n  }\n\n  private serialize(): DynamicFilterValues {\n    const result: DynamicFilterValues = {};\n    (this.config || []).forEach(c => {\n      const ctrl = this.form.get(c.key);\n      if (!ctrl) return;\n      let val: any = ctrl instanceof FormGroup ? (ctrl as FormGroup).getRawValue() : ctrl.value;\n      if (c.type === 'date-range') {\n        const start = val?.start; const end = val?.end;\n        if (start || end) result[c.key] = { start, end };\n      } else {\n        if (val !== undefined && val !== null && (Array.isArray(val) ? val.length > 0 : val !== '')) {\n          result[c.key] = val;\n        }\n      }\n    });\n    return result;\n  }\n\n  private resolveInitialSelectValue(item: DynamicFilterItem): any {\n    if (this.model && Object.prototype.hasOwnProperty.call(this.model, item.key)) {\n      return this.model[item.key];\n    }\n    if (item.selectedValue !== undefined) {\n      return item.selectedValue;\n    }\n    return undefined;\n  }\n\n  private coerceToSingleValue(value: any): any {\n    if (value === null || value === undefined) return undefined;\n    if (Array.isArray(value)) {\n      return value.length ? value[0] : undefined;\n    }\n    return value;\n  }\n\n  private getInitialDateRangeValue(item: DynamicFilterItem): { start: Date | null; end: Date | null } {\n    const modelValue = this.model?.[item.key];\n    const startSource = modelValue?.start ?? item.selectedStartDate ?? null;\n    const endSource = modelValue?.end ?? item.selectedEndDate ?? null;\n    const start = this.normalizeDateValue(startSource);\n    const end = this.normalizeDateValue(endSource);\n    const clamp = (d: Date | null) => (d && d.getTime() > this.maxDate.getTime() ? this.maxDate : d);\n    return { start: clamp(start), end: clamp(end) };\n  }\n\n  private normalizeDateValue(value: any): Date | null {\n    if (!value) return null;\n    if (value instanceof Date && !isNaN(value.getTime())) {\n      return value;\n    }\n    const parsed = new Date(value);\n    return isNaN(parsed.getTime()) ? null : parsed;\n  }\n\n  private invokeDateRangeChange(key: string, event?: MatDatepickerInputEvent<Date> | Event): void {\n    const item = (this.config || []).find(cfg => cfg.key === key);\n    if (!item?.onDateChange) return;\n    const dateGroup = this.getDateGroup(key);\n    if (!dateGroup) return;\n    const { start, end } = dateGroup.getRawValue() || {};\n    item.onDateChange(\n      {\n        start: this.normalizeDateValue(start),\n        end: this.normalizeDateValue(end),\n      },\n      event\n    );\n  }\n\n  // Mat date range picker overlay preset helpers\n  applyPresetToGroup(key: string, presetKey: 'today' | 'last7days' | 'last30days' | 'last90days' | 'thismonth' | 'lastmonth'): void {\n    const dateGroup = this.getDateGroup(key);\n    if (!dateGroup) return;\n    const { start, end } = this.getPresetDates(presetKey);\n    dateGroup.patchValue({ start, end });\n    this.filtersChanged.emit(this.serialize());\n    this.invokeDateRangeChange(key);\n  }\n\n  private getPresetDates(presetKey: 'today' | 'last7days' | 'last30days' | 'last90days' | 'thismonth' | 'lastmonth'): { start: Date; end: Date } {\n    const today = new Date();\n    const clampToEndOfToday = (d: Date) => { const nd = new Date(d); nd.setHours(23,59,59,999); return nd; };\n    switch (presetKey) {\n      case 'today':\n        return { start: today, end: today };\n      case 'last7days': {\n        const start = new Date(); start.setDate(start.getDate() - 6);\n        return { start, end: today };\n      }\n      case 'last30days': {\n        const start = new Date(); start.setDate(start.getDate() - 29);\n        return { start, end: today };\n      }\n      case 'last90days': {\n        const start = new Date(); start.setDate(start.getDate() - 89);\n        return { start, end: today };\n      }\n      case 'thismonth': {\n        const start = new Date(today.getFullYear(), today.getMonth(), 1);\n        return { start, end: today };\n      }\n      case 'lastmonth': {\n        const start = new Date(today.getFullYear(), today.getMonth() - 1, 1);\n        const end = new Date(today.getFullYear(), today.getMonth(), 0);\n        return { start, end: clampToEndOfToday(end) };\n      }\n    }\n  }\n  private startOfDay(d: Date): Date { const nd = new Date(d); nd.setHours(0,0,0,0); return nd; }\n  private endOfDay(d: Date): Date { const nd = new Date(d); nd.setHours(23,59,59,999); return nd; }\n  private startOfMonth(year: number, month: number): Date { return new Date(year, month, 1, 0,0,0,0); }\n  private endOfMonth(year: number, month: number): Date { return new Date(year, month + 1, 0, 23,59,59,999); }\n  private buildNgxRanges(): Record<string, [Date, Date]> {\n    const today = new Date();\n    const last7Start = new Date(); last7Start.setDate(last7Start.getDate() - 6);\n    const last30Start = new Date(); last30Start.setDate(last30Start.getDate() - 29);\n    const last90Start = new Date(); last90Start.setDate(last90Start.getDate() - 89);\n    const thisMonthStart = this.startOfMonth(today.getFullYear(), today.getMonth());\n    const lastMonthStart = this.startOfMonth(today.getFullYear(), today.getMonth() - 1);\n    const lastMonthEnd = this.endOfMonth(today.getFullYear(), today.getMonth() - 1);\n    return {\n      'Today': [this.startOfDay(today), this.endOfDay(today)],\n      'Last 7 Days': [this.startOfDay(last7Start), this.endOfDay(today)],\n      'Last 30 Days': [this.startOfDay(last30Start), this.endOfDay(today)],\n      'Last 90 Days': [this.startOfDay(last90Start), this.endOfDay(today)],\n      'This Month': [this.startOfDay(thisMonthStart), this.endOfDay(today)],\n      'Last Month': [this.startOfDay(lastMonthStart), this.endOfDay(lastMonthEnd)],\n    };\n  }\n  getDateValidationError(key: string): string | null {\n    const dateGroup = this.getDateGroup(key);\n    if (!dateGroup) return null;\n\n    const startCtrl = dateGroup.controls['start'];\n    const endCtrl = dateGroup.controls['end'];\n    const startVal = startCtrl?.value;\n    const endVal = endCtrl?.value;\n    const startParseErr = startCtrl?.errors?.['matDatepickerParse']?.text;\n    const endParseErr = endCtrl?.errors?.['matDatepickerParse']?.text;\n\n    if (!startVal && !endVal && !startParseErr && !endParseErr) return null;\n\n    if (startParseErr) return `Invalid start date format`;\n    if (endParseErr) return `Invalid end date format`;\n\n    if (startVal && !endVal) return `Please select an end date`;\n    if (!startVal && endVal) return `Please select a start date`;\n\n    if (dateGroup.hasError('matStartDateInvalid')) return `Start date must be before end date`;\n    if (dateGroup.hasError('matEndDateInvalid')) return `End date must be after start date`;\n\n    if (dateGroup.invalid) {\n      const config = this.config?.find(c => c.key === key);\n      return config ? `${config.label} is invalid` : 'Date range is invalid';\n    }\n\n    return null;\n  }\n\n  // Dynamic Date Picker Integration Methods removed (component no longer used)\n}\n\n\n","<div class=\"cqa-ui-root\">\n  <div class=\"cqa-filter cqa-mb-[28px]\" *ngIf=\"showFilterPanel\" style=\"height: auto;\">\n    <!-- Bottom Layout: Current design with selectors in grid and buttons below -->\n    <ng-container *ngIf=\"buttonLayout === 'bottom'\">\n      <form class=\"ts-form cqa-grid lg:cqa-grid-cols-4 md:cqa-grid-cols-2 cqa-gap-4\" [formGroup]=\"form\"\n        (keydown.enter)=\"(false)\" novalidate=\"novalidate\">\n        <ng-container *ngFor=\"let c of config\">\n          <ng-container *ngIf=\"!c.hidden\">\n            <div class=\"form-group cus-range-select cqa-flex cqa-flex-col cqa-gap-2 cqa-flex-shrink-0 filter-selector-width cqa-w-full\">\n              <!-- Select -->\n              <ng-container *ngIf=\"c.type === 'select'\">\n                <cqa-dynamic-select [form]=\"form\" [config]=\"getSelectConfig(c)\"></cqa-dynamic-select>\n              </ng-container>\n\n              <!-- Date Range --> \n              <ng-container *ngIf=\"c.type === 'date-range'\">\n                <label\n                  class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4]\">{{\n                  c.label }}</label>\n                <mat-form-field class=\"mat-date-custom\" appearance=\"fill\">\n                  <mat-date-range-input [rangePicker]=\"picker\" [formGroup]=\"getDateGroup(c.key)\" [max]=\"maxDate\">\n                    <input matStartDate formControlName=\"start\" [placeholder]=\"c.placeholder || 'Start date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                    <input matEndDate formControlName=\"end\" [placeholder]=\"c.placeholder || 'End date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                  </mat-date-range-input>\n                  <mat-date-range-picker #picker (dateChange)=\"onDateChange($event, c.key)\"\n                    [panelClass]=\"'ctc-date-range-panel'\">\n                    <mat-datepicker-actions class=\"ctc-date-actions\">\n                      <div class=\"ctc-date-presets\">\n                        <div class=\"cqa-mb-2 cqa-font-medium\">Quick Presets</div>\n                        <div class=\"btn-group\">\n                          <button type=\"button\" class=\"preset-btn today\"\n                            (click)=\"applyPresetToGroup(c.key, 'today'); picker.close()\">Today</button>\n                          <button type=\"button\" class=\"preset-btn last7days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last7days'); picker.close()\">Last 7 days</button>\n                          <button type=\"button\" class=\"preset-btn last30days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last30days'); picker.close()\">Last 30 days</button>\n                          <button type=\"button\" class=\"preset-btn last90days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last90days'); picker.close()\">Last 90 days</button>\n                          <button type=\"button\" class=\"preset-btn thismonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'thismonth'); picker.close()\">This month</button>\n                          <button type=\"button\" class=\"preset-btn lastmonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'lastmonth'); picker.close()\">Last month</button>\n                        </div>\n                      </div>\n                      <div class=\"cqa-font-medium cqa-mb-2 cqa-mt-[10px] cqa-w-full\">Custom Range</div>\n                      <button\n                        class=\"!cqa-bg-[#3f51b5] !cqa-text-white cqa-p-2 cqa-font-medium !cqa-mb-2 !cqa-mt-[10px] cqa-w-[calc(100%-32px)] !cqa-absolute cqa-bottom-[2px]\"\n                        mat-flat-button color=\"primary\" matDatepickerApply>Apply</button>\n                    </mat-datepicker-actions>\n                  </mat-date-range-picker>\n                  <div (click)=\"picker.open()\" class=\"cqa-cursor-pointer\">\n                    <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path d=\"M5.33398 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M10.666 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path\n                        d=\"M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z\"\n                        stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M2 6.66797H14\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg>\n                  </div>\n                </mat-form-field>\n                <!-- Specific validation messages -->\n                <mat-error *ngIf=\"getDateValidationError(c.key) && !picker.opened\">\n                  {{ getDateValidationError(c.key) }}\n                </mat-error>\n              </ng-container>\n            </div>\n          </ng-container>\n        </ng-container>\n      </form>\n\n      <div class=\"cqa-flex cqa-justify-end cqa-items-stretch cqa-gap-2 cqa-mt-4\">\n        <cqa-button variant=\"filled\" (mousedown)=\"preparePrimaryAction()\" (clicked)=\"apply()\" [disabled]=\"!hasSelectedFilters\">Apply Filter</cqa-button>\n        <cqa-button variant=\"outlined\" (mousedown)=\"preparePrimaryAction()\" (clicked)=\"reset()\">Reset</cqa-button>\n      </div>\n    </ng-container>\n\n    <!-- Right Layout: Buttons on leftmost side, selectors on rightmost side -->\n    <ng-container *ngIf=\"buttonLayout === 'right'\">\n      <form class=\"ts-form cqa-flex cqa-flex-wrap cqa-items-end cqa-justify-between cqa-gap-4\" [formGroup]=\"form\"\n        (keydown.enter)=\"(false)\" novalidate=\"novalidate\" style=\"height: auto;\">\n        <div class=\"cqa-flex cqa-items-stretch cqa-gap-2 cqa-flex-shrink-0 cqa-order-first cqa-mr-auto\">\n          <cqa-button variant=\"filled\" (clicked)=\"apply()\" [disabled]=\"!hasSelectedFilters\">Apply Filter</cqa-button>\n          <cqa-button variant=\"outlined\" (clicked)=\"reset()\">Reset</cqa-button>\n        </div>\n        <div class=\"cqa-flex cqa-flex-wrap cqa-items-end cqa-gap-4 cqa-flex-1 cqa-justify-end cqa-order-last cqa-ml-auto\">\n          <ng-container *ngFor=\"let c of config\">\n          <ng-container *ngIf=\"!c.hidden\">\n            <div class=\"form-group cqa-flex cqa-flex-col cqa-gap-2 cqa-flex-shrink-0 filter-selector-width\">\n              <!-- Select -->\n              <ng-container *ngIf=\"c.type === 'select'\">\n                <cqa-dynamic-select [form]=\"form\" [config]=\"getSelectConfig(c)\"></cqa-dynamic-select>\n              </ng-container>\n\n              <!-- Date Range --> \n              <ng-container *ngIf=\"c.type === 'date-range'\">\n                <label\n                  class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4]\">{{\n                  c.label }}</label>\n                <mat-form-field class=\"mat-date-custom\" appearance=\"fill\">\n                  <mat-date-range-input [rangePicker]=\"picker\" [formGroup]=\"getDateGroup(c.key)\" [max]=\"maxDate\">\n                    <input matStartDate formControlName=\"start\" [placeholder]=\"c.placeholder || 'Start date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                    <input matEndDate formControlName=\"end\" [placeholder]=\"c.placeholder || 'End date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                  </mat-date-range-input>\n                  <mat-date-range-picker #picker (dateChange)=\"onDateChange($event, c.key)\"\n                    [panelClass]=\"'ctc-date-range-panel'\">\n                    <mat-datepicker-actions class=\"ctc-date-actions\">\n                      <div class=\"ctc-date-presets\">\n                        <div class=\"cqa-mb-2 cqa-font-medium\">Quick Presets</div>\n                        <div class=\"btn-group\">\n                          <button type=\"button\" class=\"preset-btn today\"\n                            (click)=\"applyPresetToGroup(c.key, 'today'); picker.close()\">Today</button>\n                          <button type=\"button\" class=\"preset-btn last7days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last7days'); picker.close()\">Last 7 days</button>\n                          <button type=\"button\" class=\"preset-btn last30days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last30days'); picker.close()\">Last 30 days</button>\n                          <button type=\"button\" class=\"preset-btn last90days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last90days'); picker.close()\">Last 90 days</button>\n                          <button type=\"button\" class=\"preset-btn thismonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'thismonth'); picker.close()\">This month</button>\n                          <button type=\"button\" class=\"preset-btn lastmonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'lastmonth'); picker.close()\">Last month</button>\n                        </div>\n                      </div>\n                      <div class=\"cqa-font-medium cqa-mb-2 cqa-mt-[10px] cqa-w-full\">Custom Range</div>\n                      <button\n                        class=\"!cqa-bg-[#3f51b5] !cqa-text-white cqa-p-2 cqa-font-medium !cqa-mb-2 !cqa-mt-[10px] cqa-w-[calc(100%-32px)] !cqa-absolute cqa-bottom-[2px]\"\n                        mat-flat-button color=\"primary\" matDatepickerApply>Apply</button>\n                    </mat-datepicker-actions>\n                  </mat-date-range-picker>\n                  <div (click)=\"picker.open()\" class=\"cqa-cursor-pointer\">\n                    <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path d=\"M5.33398 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M10.666 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path\n                        d=\"M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z\"\n                        stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M2 6.66797H14\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg>\n                  </div>\n                </mat-form-field>\n                <!-- Specific validation messages -->\n                <mat-error *ngIf=\"getDateValidationError(c.key) && !picker.opened\">\n                  {{ getDateValidationError(c.key) }}\n                </mat-error>\n              </ng-container>\n            </div>\n          </ng-container>\n        </ng-container>\n        </div>\n      </form>\n    </ng-container>\n\n    <!-- Left Layout: Selectors on leftmost side, buttons on rightmost side -->\n    <ng-container *ngIf=\"buttonLayout === 'left'\">\n      <form class=\"ts-form cqa-flex cqa-flex-wrap cqa-items-end cqa-justify-between cqa-gap-4\" [formGroup]=\"form\"\n        (keydown.enter)=\"(false)\" novalidate=\"novalidate\" style=\"height: auto;\">\n        <div class=\"cqa-flex cqa-flex-wrap cqa-items-end cqa-gap-4 cqa-flex-1 cqa-order-first cqa-mr-auto\">\n          <ng-container *ngFor=\"let c of config\">\n          <ng-container *ngIf=\"!c.hidden\">\n            <div class=\"form-group cqa-flex cqa-flex-col cqa-gap-2 cqa-flex-shrink-0 filter-selector-width\">\n              <!-- Select -->\n              <ng-container *ngIf=\"c.type === 'select'\">\n                <cqa-dynamic-select [form]=\"form\" [config]=\"getSelectConfig(c)\"></cqa-dynamic-select>\n              </ng-container>\n\n              <!-- Date Range --> \n              <ng-container *ngIf=\"c.type === 'date-range'\">\n                <label\n                  class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4]\">{{\n                  c.label }}</label>\n                <mat-form-field class=\"mat-date-custom\" appearance=\"fill\">\n                  <mat-date-range-input [rangePicker]=\"picker\" [formGroup]=\"getDateGroup(c.key)\" [max]=\"maxDate\">\n                    <input matStartDate formControlName=\"start\" [placeholder]=\"c.placeholder || 'Start date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                    <input matEndDate formControlName=\"end\" [placeholder]=\"c.placeholder || 'End date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                  </mat-date-range-input>\n                  <mat-date-range-picker #picker (dateChange)=\"onDateChange($event, c.key)\"\n                    [panelClass]=\"'ctc-date-range-panel'\">\n                    <mat-datepicker-actions class=\"ctc-date-actions\">\n                      <div class=\"ctc-date-presets\">\n                        <div class=\"cqa-mb-2 cqa-font-medium\">Quick Presets</div>\n                        <div class=\"btn-group\">\n                          <button type=\"button\" class=\"preset-btn today\"\n                            (click)=\"applyPresetToGroup(c.key, 'today'); picker.close()\">Today</button>\n                          <button type=\"button\" class=\"preset-btn last7days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last7days'); picker.close()\">Last 7 days</button>\n                          <button type=\"button\" class=\"preset-btn last30days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last30days'); picker.close()\">Last 30 days</button>\n                          <button type=\"button\" class=\"preset-btn last90days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last90days'); picker.close()\">Last 90 days</button>\n                          <button type=\"button\" class=\"preset-btn thismonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'thismonth'); picker.close()\">This month</button>\n                          <button type=\"button\" class=\"preset-btn lastmonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'lastmonth'); picker.close()\">Last month</button>\n                        </div>\n                      </div>\n                      <div class=\"cqa-font-medium cqa-mb-2 cqa-mt-[10px] cqa-w-full\">Custom Range</div>\n                      <button\n                        class=\"!cqa-bg-[#3f51b5] !cqa-text-white cqa-p-2 cqa-font-medium !cqa-mb-2 !cqa-mt-[10px] cqa-w-[calc(100%-32px)] !cqa-absolute cqa-bottom-[2px]\"\n                        mat-flat-button color=\"primary\" matDatepickerApply>Apply</button>\n                    </mat-datepicker-actions>\n                  </mat-date-range-picker>\n                  <div (click)=\"picker.open()\" class=\"cqa-cursor-pointer\">\n                    <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path d=\"M5.33398 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M10.666 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path\n                        d=\"M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z\"\n                        stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M2 6.66797H14\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg>\n                  </div>\n                </mat-form-field>\n                <!-- Specific validation messages -->\n                <mat-error *ngIf=\"getDateValidationError(c.key) && !picker.opened\">\n                  {{ getDateValidationError(c.key) }}\n                </mat-error>\n              </ng-container>\n            </div>\n          </ng-container>\n        </ng-container>\n        </div>\n        <div class=\"cqa-flex cqa-items-stretch cqa-gap-2 cqa-flex-shrink-0 cqa-order-last cqa-ml-auto\">\n          <cqa-button variant=\"filled\" (mousedown)=\"preparePrimaryAction()\" (clicked)=\"apply()\" [disabled]=\"!hasSelectedFilters\">Apply Filter</cqa-button>\n          <cqa-button variant=\"outlined\" (mousedown)=\"preparePrimaryAction()\" (clicked)=\"reset()\">Reset</cqa-button>\n        </div>\n      </form>\n    </ng-container>\n  </div>\n</div>"]}
400
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-filter.component.js","sourceRoot":"","sources":["../../../../../../src/lib/filters/dynamic-filter/dynamic-filter.component.ts","../../../../../../src/lib/filters/dynamic-filter/dynamic-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChildren, QueryList } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\nimport { MatDatepickerInputEvent } from '@angular/material/datepicker';\nimport { DynamicSelectFieldConfig } from '../../dynamic-select/dynamic-select-field.component';\nimport { DynamicSelectFieldComponent } from '../../dynamic-select/dynamic-select-field.component';\n\ntype FilterType = 'select' | 'date-range';\n\nexport interface DynamicFilterOption {\n  id?: number | string;\n  name?: string;\n  value?: any;\n  label?: string;\n}\n\nexport interface DynamicFilterItem {\n  label: string;\n  placeholder?: string;\n  type: FilterType;\n  key: string;\n  options?: DynamicFilterOption[];\n  multiple?: boolean;\n  disabled?: boolean;\n  hidden?: boolean;\n  searchable?: boolean;\n  optionStyle?: 'checkmark' | 'checkbox';\n  showSelectAll?: boolean;\n  selectAllLabel?: string;\n  selectedValue?: any | any[];\n  // Server-driven select support (passthrough to cqa-dynamic-select)\n  serverSearch?: boolean;\n  /** More results available server-side for infinite scroll */\n  hasMore?: boolean;\n  /** External loading state for async fetching */\n  isLoading?: boolean;\n  /** Callback when search text changes (server mode) */\n  onSearch?: (query: string) => void;\n  /** Callback when more data is requested (infinite scroll) */\n  onLoadMore?: (query?: string) => void;\n  selectedStartDate?: Date | string;\n  selectedEndDate?: Date | string;\n  onDateChange?: (value: { start: Date | null; end: Date | null }, event?: MatDatepickerInputEvent<Date> | Event) => void;\n}\n\nexport interface DynamicFilterValues {\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'cqa-dynamic-filter',\n  templateUrl: './dynamic-filter.component.html',\n  styleUrls: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { class: 'cqa-ui-root' }\n})\nexport class DynamicFilterComponent implements OnChanges {\n  @Input() config: DynamicFilterItem[] = [];\n  @Input() model: DynamicFilterValues = {};\n  @Input() showFilterPanel: boolean = true;\n  @Input() buttonLayout: 'left' | 'right' | 'bottom' = 'bottom';\n  @Output() filtersApplied = new EventEmitter<DynamicFilterValues>();\n  @Output() filtersChanged = new EventEmitter<DynamicFilterValues>();\n  @Output() resetAction = new EventEmitter<void>();\n  @Output() onApplyFilterClick = new EventEmitter<DynamicFilterValues>();\n  @Output() onResetFilterClick = new EventEmitter<void>();\n\n  form: FormGroup = this.fb.group({});\n  maxDate = new Date();\n  searchTextByKey: Record<string, string> = {};\n  private selectOutsideCleanup = new Map<any, () => void>();\n  hasSelectedFilters = false;\n  @ViewChildren(DynamicSelectFieldComponent) selectComponents?: QueryList<DynamicSelectFieldComponent>;\n\n  constructor(private readonly fb: FormBuilder) {\n    // Ensure maxDate is the end of today, so any future dates are disallowed\n    this.maxDate = this.endOfDay(new Date());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] || changes['model']) {\n      this.buildForm();\n    }\n  }\n\n  onDateChange(event: MatDatepickerInputEvent<Date> | Event, key: string): void {\n    this.invokeDateRangeChange(key, event);\n  }\n\n  // NGX DateRangePicker integration\n  ngxDateRangeByKey: Record<string, any> = {};\n  ngxRanges: any = {}; // Using 'any' to avoid Dayjs type mismatch - library accepts Date objects at runtime\n  ngxLocale = { customRangeLabel: 'Custom range' };\n  // Disable all dates after today in the ngx datepicker\n  disableFutureDates = (m: any): boolean => {\n    try {\n      const d: Date = m && typeof m.toDate === 'function' ? m.toDate() : new Date(m);\n      return d.getTime() > this.maxDate.getTime();\n    } catch {\n      return false;\n    }\n  };\n  onNgxDatesUpdated(e: any, key: string): void {\n    const group = this.getDateGroup(key);\n    if (!group) return;\n    const clamp = (d: Date | null) => (d && d.getTime() > this.maxDate.getTime() ? this.maxDate : d);\n    const startRaw = e?.startDate ? (typeof e.startDate.toDate === 'function' ? e.startDate.toDate() : new Date(e.startDate)) : null;\n    const endRaw = e?.endDate ? (typeof e.endDate.toDate === 'function' ? e.endDate.toDate() : new Date(e.endDate)) : null;\n    const start = clamp(startRaw);\n    const end = clamp(endRaw);\n    group.patchValue({ start, end }, { emitEvent: true });\n    const serialized = this.serialize();\n    this.hasSelectedFilters = Object.keys(serialized).length > 0;\n    if (start && end && group.valid) {\n      this.apply();\n    } else {\n      this.filtersChanged.emit(serialized);\n    }\n  }\n\n  private buildForm(): void {\n    const ctrls: Record<string, any> = {};\n    (this.config || []).forEach(c => {\n      if (c.hidden) return;\n      if (c.type === 'date-range') {\n        const initialRange = this.getInitialDateRangeValue(c);\n        ctrls[c.key] = this.fb.group({\n          start: new FormControl(initialRange.start),\n          end: new FormControl(initialRange.end),\n        });\n        // initialize ngx model display\n        this.ngxDateRangeByKey[c.key] = {\n          startDate: initialRange.start || null,\n          endDate: initialRange.end || null\n        };\n      } else {\n        const initial = this.resolveInitialSelectValue(c);\n        if (c.multiple) {\n          const value = Array.isArray(initial) ? initial : (initial != null ? [initial] : []);\n          ctrls[c.key] = new FormControl(value);\n        } else {\n          ctrls[c.key] = new FormControl(this.coerceToSingleValue(initial));\n        }\n      }\n    });\n    this.form = this.fb.group(ctrls);\n    // initialize apply button state based on initial values\n    this.hasSelectedFilters = Object.keys(this.serialize()).length > 0;\n    // build common ranges for ngx datepicker\n    this.ngxRanges = this.buildNgxRanges();\n    this.form.valueChanges.subscribe(() => {\n      const serialized = this.serialize();\n      this.hasSelectedFilters = Object.keys(serialized).length > 0;\n      this.filtersChanged.emit(serialized);\n    });\n  }\n\n  onSelectOpenedChange(opened: boolean, select: any): void {\n    if (opened) {\n      setTimeout(() => {\n        const onDocDown = (e: MouseEvent) => {\n          const panel = document.querySelector('.cdk-overlay-pane .mat-select-panel') as HTMLElement | null;\n          const target = e.target as Node | null;\n          const originEl = (select?._elementRef?.nativeElement as HTMLElement) || null;\n          const insidePanel = !!(panel && target && panel.contains(target));\n          const insideOrigin = !!(originEl && target && originEl.contains(target));\n          if (!insidePanel && !insideOrigin) {\n            select.close();\n          }\n        };\n        document.addEventListener('mousedown', onDocDown, true);\n        this.selectOutsideCleanup.set(select, () => document.removeEventListener('mousedown', onDocDown, true));\n      }, 0);\n    } else {\n      const cleanup = this.selectOutsideCleanup.get(select);\n      if (cleanup) cleanup();\n      this.selectOutsideCleanup.delete(select);\n    }\n  }\n\n  onSearch(key: string, text: string): void {\n    this.searchTextByKey[key] = (text || '').toLowerCase();\n  }\n\n  filteredOptions(item: DynamicFilterItem): DynamicFilterOption[] {\n    const options = item?.options || [];\n    const q = (this.searchTextByKey[item.key] || '').trim();\n    if (!q) return options;\n    return options.filter(opt => {\n      const name = (opt.name ?? opt.label ?? String(opt.value ?? '')).toLowerCase();\n      return name.includes(q);\n    });\n  }\n\n  getDateGroup(key: string): FormGroup {\n    return this.form.get(key) as FormGroup;\n  }\n\n  getSelectConfig(item: DynamicFilterItem): DynamicSelectFieldConfig {\n    return {\n      key: item.key,\n      label: item.label,\n      placeholder: item.placeholder,\n      disabled: item.disabled,\n      multiple: item.multiple,\n      searchable: item.searchable,\n      optionStyle: item.optionStyle,\n      showSelectAll: item.showSelectAll,\n      selectAllLabel: item.selectAllLabel,\n      selectedValue: item.selectedValue,\n      serverSearch: item.serverSearch,\n      hasMore: item.hasMore,\n      isLoading: item.isLoading,\n      onSearch: item.onSearch,\n      onLoadMore: item.onLoadMore,\n      options: item.options || []\n    };\n  }\n\n  apply(): void {\n    this.closeAllOpenSelects();\n    const filterValues = this.serialize();\n    this.filtersApplied.emit(filterValues);\n    this.onApplyFilterClick.emit(filterValues);\n  }\n\n  reset(): void {\n    this.closeAllOpenSelects();\n    Object.keys(this.form.controls).forEach(key => {\n      const ctrl = this.form.get(key);\n      if (ctrl instanceof FormGroup) {\n        ctrl.get('start')?.setValue(undefined);\n        ctrl.get('end')?.setValue(undefined);\n        this.invokeDateRangeChange(key);\n      } else {\n        ctrl?.setValue(undefined);\n      }\n    });\n    this.resetAction.emit();\n    this.onResetFilterClick.emit();\n    const serialized = this.serialize();\n    this.hasSelectedFilters = Object.keys(serialized).length > 0;\n    this.filtersChanged.emit(serialized);\n  }\n\n  /** Close any open MatSelect panels before primary actions to avoid double-click issues */\n  preparePrimaryAction(): void {\n    this.closeAllOpenSelects();\n  }\n\n  private closeAllOpenSelects(): void {\n    try {\n      this.selectComponents?.forEach(c => c.closePanel());\n    } catch {}\n  }\n\n  private serialize(): DynamicFilterValues {\n    const result: DynamicFilterValues = {};\n    (this.config || []).forEach(c => {\n      const ctrl = this.form.get(c.key);\n      if (!ctrl) return;\n      let val: any = ctrl instanceof FormGroup ? (ctrl as FormGroup).getRawValue() : ctrl.value;\n      if (c.type === 'date-range') {\n        const start = val?.start; const end = val?.end;\n        if (start || end) result[c.key] = { start, end };\n      } else {\n        if (val !== undefined && val !== null && (Array.isArray(val) ? val.length > 0 : val !== '')) {\n          result[c.key] = val;\n        }\n      }\n    });\n    return result;\n  }\n\n  private resolveInitialSelectValue(item: DynamicFilterItem): any {\n    if (this.model && Object.prototype.hasOwnProperty.call(this.model, item.key)) {\n      return this.model[item.key];\n    }\n    if (item.selectedValue !== undefined) {\n      return item.selectedValue;\n    }\n    return undefined;\n  }\n\n  private coerceToSingleValue(value: any): any {\n    if (value === null || value === undefined) return undefined;\n    if (Array.isArray(value)) {\n      return value.length ? value[0] : undefined;\n    }\n    return value;\n  }\n\n  private getInitialDateRangeValue(item: DynamicFilterItem): { start: Date | null; end: Date | null } {\n    const modelValue = this.model?.[item.key];\n    const startSource = modelValue?.start ?? item.selectedStartDate ?? null;\n    const endSource = modelValue?.end ?? item.selectedEndDate ?? null;\n    const start = this.normalizeDateValue(startSource);\n    const end = this.normalizeDateValue(endSource);\n    const clamp = (d: Date | null) => (d && d.getTime() > this.maxDate.getTime() ? this.maxDate : d);\n    return { start: clamp(start), end: clamp(end) };\n  }\n\n  private normalizeDateValue(value: any): Date | null {\n    if (!value) return null;\n    if (value instanceof Date && !isNaN(value.getTime())) {\n      return value;\n    }\n    const parsed = new Date(value);\n    return isNaN(parsed.getTime()) ? null : parsed;\n  }\n\n  private invokeDateRangeChange(key: string, event?: MatDatepickerInputEvent<Date> | Event): void {\n    const item = (this.config || []).find(cfg => cfg.key === key);\n    if (!item?.onDateChange) return;\n    const dateGroup = this.getDateGroup(key);\n    if (!dateGroup) return;\n    const { start, end } = dateGroup.getRawValue() || {};\n    item.onDateChange(\n      {\n        start: this.normalizeDateValue(start),\n        end: this.normalizeDateValue(end),\n      },\n      event\n    );\n  }\n\n  // Mat date range picker overlay preset helpers\n  applyPresetToGroup(key: string, presetKey: 'today' | 'last7days' | 'last30days' | 'last90days' | 'thismonth' | 'lastmonth'): void {\n    const dateGroup = this.getDateGroup(key);\n    if (!dateGroup) return;\n    const { start, end } = this.getPresetDates(presetKey);\n    dateGroup.patchValue({ start, end });\n    this.filtersChanged.emit(this.serialize());\n    this.invokeDateRangeChange(key);\n  }\n\n  private getPresetDates(presetKey: 'today' | 'last7days' | 'last30days' | 'last90days' | 'thismonth' | 'lastmonth'): { start: Date; end: Date } {\n    const today = new Date();\n    const clampToEndOfToday = (d: Date) => { const nd = new Date(d); nd.setHours(23,59,59,999); return nd; };\n    switch (presetKey) {\n      case 'today':\n        return { start: today, end: today };\n      case 'last7days': {\n        const start = new Date(); start.setDate(start.getDate() - 6);\n        return { start, end: today };\n      }\n      case 'last30days': {\n        const start = new Date(); start.setDate(start.getDate() - 29);\n        return { start, end: today };\n      }\n      case 'last90days': {\n        const start = new Date(); start.setDate(start.getDate() - 89);\n        return { start, end: today };\n      }\n      case 'thismonth': {\n        const start = new Date(today.getFullYear(), today.getMonth(), 1);\n        return { start, end: today };\n      }\n      case 'lastmonth': {\n        const start = new Date(today.getFullYear(), today.getMonth() - 1, 1);\n        const end = new Date(today.getFullYear(), today.getMonth(), 0);\n        return { start, end: clampToEndOfToday(end) };\n      }\n    }\n  }\n  private startOfDay(d: Date): Date { const nd = new Date(d); nd.setHours(0,0,0,0); return nd; }\n  private endOfDay(d: Date): Date { const nd = new Date(d); nd.setHours(23,59,59,999); return nd; }\n  private startOfMonth(year: number, month: number): Date { return new Date(year, month, 1, 0,0,0,0); }\n  private endOfMonth(year: number, month: number): Date { return new Date(year, month + 1, 0, 23,59,59,999); }\n  private buildNgxRanges(): Record<string, [Date, Date]> {\n    const today = new Date();\n    const last7Start = new Date(); last7Start.setDate(last7Start.getDate() - 6);\n    const last30Start = new Date(); last30Start.setDate(last30Start.getDate() - 29);\n    const last90Start = new Date(); last90Start.setDate(last90Start.getDate() - 89);\n    const thisMonthStart = this.startOfMonth(today.getFullYear(), today.getMonth());\n    const lastMonthStart = this.startOfMonth(today.getFullYear(), today.getMonth() - 1);\n    const lastMonthEnd = this.endOfMonth(today.getFullYear(), today.getMonth() - 1);\n    return {\n      'Today': [this.startOfDay(today), this.endOfDay(today)],\n      'Last 7 Days': [this.startOfDay(last7Start), this.endOfDay(today)],\n      'Last 30 Days': [this.startOfDay(last30Start), this.endOfDay(today)],\n      'Last 90 Days': [this.startOfDay(last90Start), this.endOfDay(today)],\n      'This Month': [this.startOfDay(thisMonthStart), this.endOfDay(today)],\n      'Last Month': [this.startOfDay(lastMonthStart), this.endOfDay(lastMonthEnd)],\n    };\n  }\n  getDateValidationError(key: string): string | null {\n    const dateGroup = this.getDateGroup(key);\n    if (!dateGroup) return null;\n\n    const startCtrl = dateGroup.controls['start'];\n    const endCtrl = dateGroup.controls['end'];\n    const startVal = startCtrl?.value;\n    const endVal = endCtrl?.value;\n    const startParseErr = startCtrl?.errors?.['matDatepickerParse']?.text;\n    const endParseErr = endCtrl?.errors?.['matDatepickerParse']?.text;\n\n    if (!startVal && !endVal && !startParseErr && !endParseErr) return null;\n\n    if (startParseErr) return `Invalid start date format`;\n    if (endParseErr) return `Invalid end date format`;\n\n    if (startVal && !endVal) return `Please select an end date`;\n    if (!startVal && endVal) return `Please select a start date`;\n\n    if (dateGroup.hasError('matStartDateInvalid')) return `Start date must be before end date`;\n    if (dateGroup.hasError('matEndDateInvalid')) return `End date must be after start date`;\n\n    if (dateGroup.invalid) {\n      const config = this.config?.find(c => c.key === key);\n      return config ? `${config.label} is invalid` : 'Date range is invalid';\n    }\n\n    return null;\n  }\n\n  // Dynamic Date Picker Integration Methods removed (component no longer used)\n}\n\n\n","<div class=\"cqa-ui-root\">\n  <div class=\"cqa-filter cqa-mb-[28px]\" *ngIf=\"showFilterPanel\" style=\"height: auto;\">\n    <!-- Bottom Layout: Current design with selectors in grid and buttons below -->\n    <ng-container *ngIf=\"buttonLayout === 'bottom'\">\n      <form class=\"ts-form cqa-grid lg:cqa-grid-cols-4 md:cqa-grid-cols-2 cqa-gap-4\" [formGroup]=\"form\"\n        (keydown.enter)=\"(false)\" novalidate=\"novalidate\">\n        <ng-container *ngFor=\"let c of config\">\n          <ng-container *ngIf=\"!c.hidden\">\n            <div class=\"form-group cus-range-select cqa-flex cqa-flex-col cqa-gap-2 cqa-flex-shrink-0 filter-selector-width cqa-w-full\">\n              <!-- Select -->\n              <ng-container *ngIf=\"c.type === 'select'\">\n                <cqa-dynamic-select [form]=\"form\" [config]=\"getSelectConfig(c)\"></cqa-dynamic-select>\n              </ng-container>\n\n              <!-- Date Range --> \n              <ng-container *ngIf=\"c.type === 'date-range'\">\n                <label\n                  class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4]\">{{\n                  c.label }}</label>\n                <mat-form-field class=\"mat-date-custom\" appearance=\"fill\">\n                  <mat-date-range-input [rangePicker]=\"picker\" [formGroup]=\"getDateGroup(c.key)\" [max]=\"maxDate\">\n                    <input matStartDate formControlName=\"start\" [placeholder]=\"c.placeholder || 'Start date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                    <input matEndDate formControlName=\"end\" [placeholder]=\"c.placeholder || 'End date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                  </mat-date-range-input>\n                  <mat-date-range-picker #picker (dateChange)=\"onDateChange($event, c.key)\"\n                    [panelClass]=\"'ctc-date-range-panel'\">\n                    <mat-datepicker-actions class=\"ctc-date-actions\">\n                      <div class=\"ctc-date-presets\">\n                        <div class=\"cqa-mb-2 cqa-font-medium\">Quick Presets</div>\n                        <div class=\"btn-group\">\n                          <button type=\"button\" class=\"preset-btn today\"\n                            (click)=\"applyPresetToGroup(c.key, 'today'); picker.close()\">Today</button>\n                          <button type=\"button\" class=\"preset-btn last7days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last7days'); picker.close()\">Last 7 days</button>\n                          <button type=\"button\" class=\"preset-btn last30days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last30days'); picker.close()\">Last 30 days</button>\n                          <button type=\"button\" class=\"preset-btn last90days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last90days'); picker.close()\">Last 90 days</button>\n                          <button type=\"button\" class=\"preset-btn thismonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'thismonth'); picker.close()\">This month</button>\n                          <button type=\"button\" class=\"preset-btn lastmonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'lastmonth'); picker.close()\">Last month</button>\n                        </div>\n                      </div>\n                      <div class=\"cqa-font-medium cqa-mb-2 cqa-mt-[10px] cqa-w-full\">Custom Range</div>\n                      <button\n                        class=\"!cqa-bg-[#3f51b5] !cqa-text-white cqa-p-2 cqa-font-medium !cqa-mb-2 !cqa-mt-[10px] cqa-w-[calc(100%-32px)] !cqa-absolute cqa-bottom-[2px]\"\n                        mat-flat-button color=\"primary\" matDatepickerApply>Apply</button>\n                    </mat-datepicker-actions>\n                  </mat-date-range-picker>\n                  <div (click)=\"picker.open()\" class=\"cqa-cursor-pointer\">\n                    <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path d=\"M5.33398 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M10.666 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path\n                        d=\"M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z\"\n                        stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M2 6.66797H14\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg>\n                  </div>\n                </mat-form-field>\n                <!-- Specific validation messages -->\n                <mat-error *ngIf=\"getDateValidationError(c.key) && !picker.opened\">\n                  {{ getDateValidationError(c.key) }}\n                </mat-error>\n              </ng-container>\n            </div>\n          </ng-container>\n        </ng-container>\n      </form>\n\n      <div class=\"cqa-flex cqa-justify-end cqa-items-stretch cqa-gap-2 cqa-mt-4\">\n        <cqa-button variant=\"filled\" (mousedown)=\"preparePrimaryAction()\" (clicked)=\"apply()\" [disabled]=\"!hasSelectedFilters\">Apply Filter</cqa-button>\n        <cqa-button variant=\"outlined\" (mousedown)=\"preparePrimaryAction()\" (clicked)=\"reset()\">Reset</cqa-button>\n      </div>\n    </ng-container>\n\n    <!-- Right Layout: Buttons on leftmost side, selectors on rightmost side -->\n    <ng-container *ngIf=\"buttonLayout === 'right'\">\n      <form class=\"ts-form cqa-flex cqa-flex-wrap cqa-items-end cqa-justify-between cqa-gap-4\" [formGroup]=\"form\"\n        (keydown.enter)=\"(false)\" novalidate=\"novalidate\" style=\"height: auto;\">\n        <div class=\"cqa-flex cqa-items-stretch cqa-gap-2 cqa-flex-shrink-0 cqa-order-first cqa-mr-auto\">\n          <cqa-button variant=\"filled\" (clicked)=\"apply()\" [disabled]=\"!hasSelectedFilters\">Apply Filter</cqa-button>\n          <cqa-button variant=\"outlined\" (clicked)=\"reset()\">Reset</cqa-button>\n        </div>\n        <div class=\"cqa-flex cqa-flex-wrap cqa-items-end cqa-gap-4 cqa-flex-1 cqa-justify-end cqa-order-last cqa-ml-auto\">\n          <ng-container *ngFor=\"let c of config\">\n          <ng-container *ngIf=\"!c.hidden\">\n            <div class=\"form-group cqa-flex cqa-flex-col cqa-gap-2 cqa-flex-shrink-0 filter-selector-width\">\n              <!-- Select -->\n              <ng-container *ngIf=\"c.type === 'select'\">\n                <cqa-dynamic-select [form]=\"form\" [config]=\"getSelectConfig(c)\"></cqa-dynamic-select>\n              </ng-container>\n\n              <!-- Date Range --> \n              <ng-container *ngIf=\"c.type === 'date-range'\">\n                <label\n                  class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4]\">{{\n                  c.label }}</label>\n                <mat-form-field class=\"mat-date-custom\" appearance=\"fill\">\n                  <mat-date-range-input [rangePicker]=\"picker\" [formGroup]=\"getDateGroup(c.key)\" [max]=\"maxDate\">\n                    <input matStartDate formControlName=\"start\" [placeholder]=\"c.placeholder || 'Start date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                    <input matEndDate formControlName=\"end\" [placeholder]=\"c.placeholder || 'End date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                  </mat-date-range-input>\n                  <mat-date-range-picker #picker (dateChange)=\"onDateChange($event, c.key)\"\n                    [panelClass]=\"'ctc-date-range-panel'\">\n                    <mat-datepicker-actions class=\"ctc-date-actions\">\n                      <div class=\"ctc-date-presets\">\n                        <div class=\"cqa-mb-2 cqa-font-medium\">Quick Presets</div>\n                        <div class=\"btn-group\">\n                          <button type=\"button\" class=\"preset-btn today\"\n                            (click)=\"applyPresetToGroup(c.key, 'today'); picker.close()\">Today</button>\n                          <button type=\"button\" class=\"preset-btn last7days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last7days'); picker.close()\">Last 7 days</button>\n                          <button type=\"button\" class=\"preset-btn last30days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last30days'); picker.close()\">Last 30 days</button>\n                          <button type=\"button\" class=\"preset-btn last90days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last90days'); picker.close()\">Last 90 days</button>\n                          <button type=\"button\" class=\"preset-btn thismonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'thismonth'); picker.close()\">This month</button>\n                          <button type=\"button\" class=\"preset-btn lastmonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'lastmonth'); picker.close()\">Last month</button>\n                        </div>\n                      </div>\n                      <div class=\"cqa-font-medium cqa-mb-2 cqa-mt-[10px] cqa-w-full\">Custom Range</div>\n                      <button\n                        class=\"!cqa-bg-[#3f51b5] !cqa-text-white cqa-p-2 cqa-font-medium !cqa-mb-2 !cqa-mt-[10px] cqa-w-[calc(100%-32px)] !cqa-absolute cqa-bottom-[2px]\"\n                        mat-flat-button color=\"primary\" matDatepickerApply>Apply</button>\n                    </mat-datepicker-actions>\n                  </mat-date-range-picker>\n                  <div (click)=\"picker.open()\" class=\"cqa-cursor-pointer\">\n                    <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path d=\"M5.33398 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M10.666 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path\n                        d=\"M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z\"\n                        stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M2 6.66797H14\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg>\n                  </div>\n                </mat-form-field>\n                <!-- Specific validation messages -->\n                <mat-error *ngIf=\"getDateValidationError(c.key) && !picker.opened\">\n                  {{ getDateValidationError(c.key) }}\n                </mat-error>\n              </ng-container>\n            </div>\n          </ng-container>\n        </ng-container>\n        </div>\n      </form>\n    </ng-container>\n\n    <!-- Left Layout: Selectors on leftmost side, buttons on rightmost side -->\n    <ng-container *ngIf=\"buttonLayout === 'left'\">\n      <form class=\"ts-form cqa-flex cqa-flex-wrap cqa-items-end cqa-justify-between cqa-gap-4\" [formGroup]=\"form\"\n        (keydown.enter)=\"(false)\" novalidate=\"novalidate\" style=\"height: auto;\">\n        <div class=\"cqa-flex cqa-flex-wrap cqa-items-end cqa-gap-4 cqa-flex-1 cqa-order-first cqa-mr-auto\">\n          <ng-container *ngFor=\"let c of config\">\n          <ng-container *ngIf=\"!c.hidden\">\n            <div class=\"form-group cqa-flex cqa-flex-col cqa-gap-2 cqa-flex-shrink-0 filter-selector-width\">\n              <!-- Select -->\n              <ng-container *ngIf=\"c.type === 'select'\">\n                <cqa-dynamic-select [form]=\"form\" [config]=\"getSelectConfig(c)\"></cqa-dynamic-select>\n              </ng-container>\n\n              <!-- Date Range --> \n              <ng-container *ngIf=\"c.type === 'date-range'\">\n                <label\n                  class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4]\">{{\n                  c.label }}</label>\n                <mat-form-field class=\"mat-date-custom\" appearance=\"fill\">\n                  <mat-date-range-input [rangePicker]=\"picker\" [formGroup]=\"getDateGroup(c.key)\" [max]=\"maxDate\">\n                    <input matStartDate formControlName=\"start\" [placeholder]=\"c.placeholder || 'Start date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                    <input matEndDate formControlName=\"end\" [placeholder]=\"c.placeholder || 'End date'\" [max]=\"maxDate\" required\n                      [readonly]=\"true\" (focus)=\"picker.open()\" (click)=\"picker.open()\" />\n                  </mat-date-range-input>\n                  <mat-date-range-picker #picker (dateChange)=\"onDateChange($event, c.key)\"\n                    [panelClass]=\"'ctc-date-range-panel'\">\n                    <mat-datepicker-actions class=\"ctc-date-actions\">\n                      <div class=\"ctc-date-presets\">\n                        <div class=\"cqa-mb-2 cqa-font-medium\">Quick Presets</div>\n                        <div class=\"btn-group\">\n                          <button type=\"button\" class=\"preset-btn today\"\n                            (click)=\"applyPresetToGroup(c.key, 'today'); picker.close()\">Today</button>\n                          <button type=\"button\" class=\"preset-btn last7days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last7days'); picker.close()\">Last 7 days</button>\n                          <button type=\"button\" class=\"preset-btn last30days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last30days'); picker.close()\">Last 30 days</button>\n                          <button type=\"button\" class=\"preset-btn last90days\"\n                            (click)=\"applyPresetToGroup(c.key, 'last90days'); picker.close()\">Last 90 days</button>\n                          <button type=\"button\" class=\"preset-btn thismonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'thismonth'); picker.close()\">This month</button>\n                          <button type=\"button\" class=\"preset-btn lastmonth\"\n                            (click)=\"applyPresetToGroup(c.key, 'lastmonth'); picker.close()\">Last month</button>\n                        </div>\n                      </div>\n                      <div class=\"cqa-font-medium cqa-mb-2 cqa-mt-[10px] cqa-w-full\">Custom Range</div>\n                      <button\n                        class=\"!cqa-bg-[#3f51b5] !cqa-text-white cqa-p-2 cqa-font-medium !cqa-mb-2 !cqa-mt-[10px] cqa-w-[calc(100%-32px)] !cqa-absolute cqa-bottom-[2px]\"\n                        mat-flat-button color=\"primary\" matDatepickerApply>Apply</button>\n                    </mat-datepicker-actions>\n                  </mat-date-range-picker>\n                  <div (click)=\"picker.open()\" class=\"cqa-cursor-pointer\">\n                    <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path d=\"M5.33398 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M10.666 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path\n                        d=\"M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z\"\n                        stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M2 6.66797H14\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg>\n                  </div>\n                </mat-form-field>\n                <!-- Specific validation messages -->\n                <mat-error *ngIf=\"getDateValidationError(c.key) && !picker.opened\">\n                  {{ getDateValidationError(c.key) }}\n                </mat-error>\n              </ng-container>\n            </div>\n          </ng-container>\n        </ng-container>\n        </div>\n        <div class=\"cqa-flex cqa-items-stretch cqa-gap-2 cqa-flex-shrink-0 cqa-order-last cqa-ml-auto\">\n          <cqa-button variant=\"filled\" (mousedown)=\"preparePrimaryAction()\" (clicked)=\"apply()\" [disabled]=\"!hasSelectedFilters\">Apply Filter</cqa-button>\n          <cqa-button variant=\"outlined\" (mousedown)=\"preparePrimaryAction()\" (clicked)=\"reset()\">Reset</cqa-button>\n        </div>\n      </form>\n    </ng-container>\n  </div>\n</div>"]}
@@ -1550,7 +1550,7 @@ class DynamicSelectFieldComponent {
1550
1550
  return this.hasExistingValue(controlValue) ? undefined : (_d = this.config) === null || _d === void 0 ? void 0 : _d.placeholder;
1551
1551
  }
1552
1552
  ngOnChanges(changes) {
1553
- var _a;
1553
+ var _a, _b, _c;
1554
1554
  if ('config' in changes) {
1555
1555
  // When config changes (including toggling multiple), ensure control value shape matches
1556
1556
  this.syncControlValueForMultipleMode();
@@ -1561,6 +1561,10 @@ class DynamicSelectFieldComponent {
1561
1561
  this.loadingMore = false;
1562
1562
  }
1563
1563
  this.lastOptionsLength = len;
1564
+ // If panel is open and hasMore is true, ensure the sentinel is being observed.
1565
+ if (((_b = this.selectRef) === null || _b === void 0 ? void 0 : _b.panelOpen) && ((_c = this.config) === null || _c === void 0 ? void 0 : _c.hasMore)) {
1566
+ setTimeout(() => this.setupLoadMoreObserver(), 0);
1567
+ }
1564
1568
  }
1565
1569
  if ('form' in changes && !changes['form'].firstChange) {
1566
1570
  this.applySelectedValueIfNeeded();
@@ -2145,6 +2149,11 @@ class DynamicFilterComponent {
2145
2149
  showSelectAll: item.showSelectAll,
2146
2150
  selectAllLabel: item.selectAllLabel,
2147
2151
  selectedValue: item.selectedValue,
2152
+ serverSearch: item.serverSearch,
2153
+ hasMore: item.hasMore,
2154
+ isLoading: item.isLoading,
2155
+ onSearch: item.onSearch,
2156
+ onLoadMore: item.onLoadMore,
2148
2157
  options: item.options || []
2149
2158
  };
2150
2159
  }