@cqa-lib/cqa-ui 1.0.42 → 1.0.43

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.
@@ -114,6 +114,9 @@ export class DynamicFilterComponent {
114
114
  disabled: item.disabled,
115
115
  multiple: item.multiple,
116
116
  searchable: item.searchable,
117
+ optionStyle: item.optionStyle,
118
+ showSelectAll: item.showSelectAll,
119
+ selectAllLabel: item.selectAllLabel,
117
120
  selectedValue: item.selectedValue,
118
121
  options: item.options || []
119
122
  };
@@ -307,4 +310,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
307
310
  }], onResetFilterClick: [{
308
311
  type: Output
309
312
  }] } });
310
- //# 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 } 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';\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  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})\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\n  constructor(private readonly fb: FormBuilder) {}\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  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      } 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    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      selectedValue: item.selectedValue,\n      options: item.options || []\n    };\n  }\n\n  apply(): void {\n    const filterValues = this.serialize();\n    this.filtersApplied.emit(filterValues);\n    this.onApplyFilterClick.emit(filterValues);\n  }\n\n  reset(): void {\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  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    return {\n      start: this.normalizeDateValue(startSource),\n      end: this.normalizeDateValue(endSource),\n    };\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  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 id=\"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 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      </form>\n\n      <div class=\"cqa-flex cqa-justify-end cqa-items-stretch cqa-gap-2 cqa-mt-4\">\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    </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\" (clicked)=\"apply()\" [disabled]=\"!hasSelectedFilters\">Apply Filter</cqa-button>\n          <cqa-button variant=\"outlined\" (clicked)=\"reset()\">Reset</cqa-button>\n        </div>\n      </form>\n    </ng-container>\n  </div>\n</div>"]}
313
+ //# 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 } 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';\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})\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\n  constructor(private readonly fb: FormBuilder) {}\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  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      } 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    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    const filterValues = this.serialize();\n    this.filtersApplied.emit(filterValues);\n    this.onApplyFilterClick.emit(filterValues);\n  }\n\n  reset(): void {\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  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    return {\n      start: this.normalizeDateValue(startSource),\n      end: this.normalizeDateValue(endSource),\n    };\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  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 id=\"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 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      </form>\n\n      <div class=\"cqa-flex cqa-justify-end cqa-items-stretch cqa-gap-2 cqa-mt-4\">\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    </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\" (clicked)=\"apply()\" [disabled]=\"!hasSelectedFilters\">Apply Filter</cqa-button>\n          <cqa-button variant=\"outlined\" (clicked)=\"reset()\">Reset</cqa-button>\n        </div>\n      </form>\n    </ng-container>\n  </div>\n</div>"]}