@unifylib/ui-lib 1.1.36 → 1.1.38
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/advanced-filter/filter-builder/filter-builder.component.mjs +14 -2
- package/esm2022/lib/components/base-form-canvas/base-form-canvas.component.mjs +3 -1
- package/esm2022/lib/components/base-table/base-table.component.mjs +7 -6
- package/esm2022/lib/components/editable-base-table/editable-base-table.component.mjs +13 -3
- package/esm2022/lib/components/title-bar/title-bar.component.mjs +10 -8
- package/fesm2022/iq-ui-lib.mjs +42 -15
- package/fesm2022/iq-ui-lib.mjs.map +1 -1
- package/fesm2022/unifylib-ui-lib.mjs +42 -15
- package/fesm2022/unifylib-ui-lib.mjs.map +1 -1
- package/lib/components/base-table/base-table.component.d.ts +1 -0
- package/lib/components/editable-base-table/editable-base-table.component.d.ts +2 -0
- package/lib/components/title-bar/title-bar.component.d.ts +2 -1
- package/package.json +1 -1
|
@@ -76,6 +76,15 @@ export class FilterBuilderComponent {
|
|
|
76
76
|
if (isInputElement) {
|
|
77
77
|
event.preventDefault();
|
|
78
78
|
event.stopPropagation();
|
|
79
|
+
if (this.searchTimeout) {
|
|
80
|
+
clearTimeout(this.searchTimeout);
|
|
81
|
+
this.searchTimeout = null;
|
|
82
|
+
}
|
|
83
|
+
setTimeout(() => {
|
|
84
|
+
this.doSearch();
|
|
85
|
+
this.onApplyFilter();
|
|
86
|
+
}, 0);
|
|
87
|
+
return;
|
|
79
88
|
}
|
|
80
89
|
this.onApplyFilter();
|
|
81
90
|
}
|
|
@@ -100,7 +109,10 @@ export class FilterBuilderComponent {
|
|
|
100
109
|
clearTimeout(this.autoApplyTimeout);
|
|
101
110
|
this.autoApplyTimeout = null;
|
|
102
111
|
}
|
|
103
|
-
|
|
112
|
+
setTimeout(() => {
|
|
113
|
+
this.doSearch();
|
|
114
|
+
this.applyFilter.emit();
|
|
115
|
+
}, 0);
|
|
104
116
|
}
|
|
105
117
|
scheduleAutoApply() {
|
|
106
118
|
if (this.autoApplyTimeout) {
|
|
@@ -273,4 +285,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
273
285
|
type: HostListener,
|
|
274
286
|
args: ['keydown', ['$event']]
|
|
275
287
|
}] } });
|
|
276
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-builder.component.js","sourceRoot":"","sources":["../../../../../../../../projects/invoiceq/ui-lib/src/lib/components/advanced-filter/filter-builder/filter-builder.component.ts","../../../../../../../../projects/invoiceq/ui-lib/src/lib/components/advanced-filter/filter-builder/filter-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output} from '@angular/core';\r\nimport {CommonModule, formatDate, NgForOf} from '@angular/common';\r\nimport {FieldInfo, PageInfo, TableColumn} from \"../../../base-model\";\r\nimport {FieldFilter} from \"../../../base-model/field-filter.model\";\r\nimport {FieldFilterComponent} from \"../field-filter/field-filter.component\";\r\nimport {TranslateModule} from \"@ngx-translate/core\";\r\nimport {MatButtonModule} from \"@angular/material/button\";\r\nimport {MatIcon} from \"@angular/material/icon\";\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from \"@angular/material/menu\";\r\n\r\n@Component({\r\n  selector: 'app-filter-builder',\r\n  templateUrl: './filter-builder.component.html',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FieldFilterComponent,\r\n    TranslateModule,\r\n    MatButtonModule,\r\n    MatIcon,\r\n    MatMenu,\r\n    MatMenuItem,\r\n    MatMenuTrigger,\r\n    NgForOf\r\n  ],\r\n  styleUrls: ['./filter-builder.component.scss']\r\n})\r\nexport class FilterBuilderComponent implements OnInit, OnDestroy {\r\n\r\n  @Input()\r\n  columns: TableColumn<any>[];\r\n\r\n@Input()\r\n  isChecked: boolean;\r\n  @Input()\r\n  filterFields: FieldInfo[];\r\n  @Input()\r\n  pageInfo: PageInfo;\r\n  @Input()\r\n  pendingFilters: FieldFilter[] = [];\r\n\r\n  @Input()\r\n  showExportButton: boolean = false;\r\n\r\n  filter: FieldFilter;\r\n  filters: FieldFilter[] = [];\r\n\r\n  private searchTimeout: any;\r\n  private autoApplyTimeout: any;\r\n\r\n  @Output()\r\n  filterInformation: EventEmitter<{ filters: FieldFilter[], searchStr: string }> = new EventEmitter<{ filters: FieldFilter[], searchStr: string }>();\r\n\r\n  @Output()\r\n  isEmpty: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  @Output()\r\n  applyFilter: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  sortByClicked: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  @Output()\r\n  exportClicked: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  constructor() {\r\n  }\r\n\r\n  isMobile(): boolean {\r\n    return typeof window !== 'undefined' && window.innerWidth <= 768;\r\n  }\r\n\r\n  getSortableColumns(): TableColumn<any>[] {\r\n    if (!this.columns) {\r\n      return [];\r\n    }\r\n    return this.columns.filter(column =>\r\n      column.visible === true && column.enableSorting === true\r\n    );\r\n  }\r\n\r\n  labelKey(column: TableColumn<any>): string {\r\n    if (!column || !column.property) {\r\n      return '';\r\n    }\r\n    const configuredKey = column.label ? column.label : column.property;\r\n    if (!this.pageInfo || !this.pageInfo.labelsSection) {\r\n      return configuredKey;\r\n    }\r\n    return configuredKey.startsWith(this.pageInfo.labelsSection)\r\n      ? `${configuredKey}`\r\n      : `${this.pageInfo.labelsSection}.${configuredKey}`;\r\n  }\r\n\r\n  onSortByClick(columnProperty: string): void {\r\n    this.sortByClicked.emit(columnProperty);\r\n  }\r\n\r\n  onExportClick(reportType: string): void {\r\n    this.exportClicked.emit(reportType);\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n\r\n    this.switchToAdvanced();\r\n    if (!this.filter) {\r\n      this.filter = this.createDefaultFieldFilter();\r\n    }\r\n    if (this.filterFields && this.filterFields.length) {\r\n      this.filters = this.filterFields.map(() => this.createDefaultFieldFilter());\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.searchTimeout) {\r\n      clearTimeout(this.searchTimeout);\r\n      this.searchTimeout = null;\r\n    }\r\n    if (this.autoApplyTimeout) {\r\n      clearTimeout(this.autoApplyTimeout);\r\n      this.autoApplyTimeout = null;\r\n    }\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  onKeyDown(event: KeyboardEvent): void {\r\n    if (event.key === 'Enter' && !event.shiftKey && !event.ctrlKey && !event.metaKey) {\r\n      const target = event.target as HTMLElement;\r\n      const isInputElement = target.tagName === 'INPUT' ||\r\n                            target.tagName === 'TEXTAREA' ||\r\n                            target.tagName === 'SELECT' ||\r\n                            target.isContentEditable;\r\n\r\n      if (isInputElement) {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n      }\r\n      this.onApplyFilter();\r\n    }\r\n  }\r\n\r\n\r\n  doSearch() {\r\n    let searchStr = '';\r\n    const filtersArray = (this.filters || [])\r\n      .filter(f => !!f && f.fieldName && f.valueObject !== undefined && f.valueObject !== null && f.valueObject !== '')\r\n      .map(f => {\r\n        const fieldInfo = this.filterFields?.find(field => field.property === f.fieldName);\r\n        if (fieldInfo?.multiLevelSearchEnable && f.valueObject) {\r\n          searchStr = f.valueObject;\r\n          return null;\r\n        }\r\n        return {...f};\r\n      })\r\n      .filter(f => f !== null);\r\n\r\n    this.filterInformation.emit({ filters: filtersArray, searchStr });\r\n  }\r\n\r\n  onApplyFilter(): void {\r\n    if (this.autoApplyTimeout) {\r\n      clearTimeout(this.autoApplyTimeout);\r\n      this.autoApplyTimeout = null;\r\n    }\r\n    this.applyFilter.emit();\r\n  }\r\n\r\n  private scheduleAutoApply(): void {\r\n    if (this.autoApplyTimeout) {\r\n      clearTimeout(this.autoApplyTimeout);\r\n      this.autoApplyTimeout = null;\r\n    }\r\n    this.autoApplyTimeout = setTimeout(() => {\r\n      this.onApplyFilter();\r\n      this.autoApplyTimeout = null;\r\n    }, 10000);\r\n  }\r\n\r\n  private scheduleSearch(delayMs: number = 800) {\r\n    if (this.searchTimeout) {\r\n      clearTimeout(this.searchTimeout);\r\n    }\r\n    this.searchTimeout = setTimeout(() => {\r\n      this.doSearch();\r\n    }, delayMs);\r\n  }\r\n\r\n  formChanges($event: any, index?: number, fieldInfo?: FieldInfo) {\r\n    if (this.autoApplyTimeout) {\r\n      clearTimeout(this.autoApplyTimeout);\r\n      this.autoApplyTimeout = null;\r\n    }\r\n\r\n    const formatIfDate = (type?: string, value?: any) => {\r\n      if (!type || value === undefined || value === null || value === '') return value;\r\n      if ((type || '').toLowerCase().includes('date')) {\r\n        return formatDate(value, 'yyyy-MM-dd', 'en_US');\r\n      }\r\n      return value;\r\n    };\r\n\r\n    if (index === undefined || !fieldInfo) {\r\n      if (!this.filterFields || !this.filterFields.length) {\r\n        this.filters = [];\r\n        this.doSearch();\r\n        return;\r\n      }\r\n\r\n      this.filters = this.filterFields.map((fi) => {\r\n        const controlName = fi.property;\r\n        let value = $event ? $event[controlName] : undefined;\r\n        if (value === undefined || value === null || value === '') {\r\n          return this.createDefaultFieldFilter();\r\n        }\r\n        const fieldName = controlName === 'from' || controlName === 'to' ?  fi.targetProperty : controlName;\r\n\r\n        return {\r\n          fieldName: fieldName,\r\n          operator: fi.filterOperator || 'EQUALS',\r\n          filterType: 'FILED_FILTER',\r\n          fieldType: this.typeMap(fi.type) as any,\r\n          valueObject: formatIfDate(fi.type, value) as any\r\n        } as FieldFilter;\r\n      });\r\n\r\n      const hasTextField = (this.filterFields || []).some(fi => ((fi.type || '').toLowerCase() === 'text'));\r\n      if (hasTextField) {\r\n        this.scheduleSearch();\r\n      } else {\r\n        this.doSearch();\r\n      }\r\n      this.scheduleAutoApply();\r\n      return;\r\n    }\r\n\r\n    if (!this.filters) {\r\n      this.filters = [];\r\n    }\r\n    if (this.filters.length < index + 1) {\r\n      this.filters.length = index + 1;\r\n    }\r\n\r\n    let controlName = fieldInfo.property;\r\n    let value = $event ? $event[controlName] : undefined;\r\n    if ($event && $event.filterField !== undefined && $event.fromValue !== undefined) {\r\n      controlName = $event.filterField || controlName;\r\n      value = $event.fromValue;\r\n    }\r\n\r\n    if (value === undefined || value === null || value === '') {\r\n      this.filters[index] = this.createDefaultFieldFilter();\r\n    } else {\r\n      this.filters[index] = {\r\n        fieldName: controlName,\r\n        operator:  fieldInfo.filterOperator || 'EQUALS',\r\n        filterType: 'FILED_FILTER',\r\n        fieldType: this.typeMap(fieldInfo.type) as any,\r\n        valueObject: formatIfDate(fieldInfo.type, value) as any\r\n      } as FieldFilter;\r\n    }\r\n    const isTextField = ((fieldInfo.type || '').toLowerCase() === 'text');\r\n    if (isTextField) {\r\n      this.scheduleSearch();\r\n    } else {\r\n      this.doSearch();\r\n    }\r\n    this.scheduleAutoApply();\r\n  }\r\n  typeMap(colType?: string): string {\r\n    const t = (colType || '').toLowerCase();\r\n    if (t.includes('number') || t.includes('int') || t === 'long') return 'Long';\r\n    if (t.includes('date') || t.includes('time')) return 'Date';\r\n    if (t.includes('bool')) return 'Boolean';\r\n    return 'String';\r\n  }\r\n\r\n  isEditable(_index?: number) {\r\n    return true;\r\n  }\r\n\r\n\r\n  deleteAll() {\r\n    this.filter = this.createDefaultFieldFilter();\r\n    this.filters = this.filterFields ? this.filterFields.map(() => this.createDefaultFieldFilter()) : [];\r\n    this.isEmpty.emit(true);\r\n  }\r\n\r\n\r\n  switchToAdvanced() {\r\n    if (this.isChecked) {\r\n      if (!this.filter || Object.keys(this.filter).length === 0) {\r\n        this.filter = this.createDefaultFieldFilter();\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  private createDefaultFieldFilter(): FieldFilter {\r\n    return {\r\n      fieldName: '',\r\n      operator: '',\r\n      filterType: '',\r\n      fieldType: '',\r\n      valueObject: ''\r\n    } as FieldFilter;\r\n  }\r\n}\r\n","<div class=\"main-filter-builder\">\r\n\r\n  <!-- Desktop View -->\r\n  <div class=\"filterForm desktop-view\">\r\n    <div class=\"filterForm__row\">\r\n      <div class=\"filterForm__col\">\r\n        <app-field-filter\r\n          [editable]=\"isEditable()\"\r\n          [filter]=\"filter\"\r\n          [pageInfo]=\"pageInfo\"\r\n          *ngIf=\"isEditable()\"\r\n          [filterFields]=\"filterFields\"\r\n          (filterFieldInformation)=\"formChanges($event)\"\r\n          class=\"filterForm__filed-filter\"\r\n        >\r\n        </app-field-filter>\r\n      </div>\r\n      <div class=\"button-group\">\r\n        <button\r\n          mat-flat-button\r\n          class=\"btn-apply-filter\"\r\n          (click)=\"onApplyFilter()\">\r\n          <div class=\"button-text\">\r\n            <mat-icon>filter_list</mat-icon>\r\n            <span>{{ 'FILTER-BUILDER.applyFilter' | translate }}</span>\r\n          </div>\r\n        </button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Mobile View -->\r\n  <div class=\"mobile-view\">\r\n    <!-- Mobile Row 1: Search Field and Export Button -->\r\n    <div class=\"mobile-search-row\">\r\n      <div class=\"mobile-search-field\">\r\n        <app-field-filter\r\n          [editable]=\"isEditable()\"\r\n          [filter]=\"filter\"\r\n          [pageInfo]=\"pageInfo\"\r\n          *ngIf=\"isEditable()\"\r\n          [filterFields]=\"filterFields\"\r\n          (filterFieldInformation)=\"formChanges($event)\"\r\n          class=\"mobile-field-filter\"\r\n        >\r\n        </app-field-filter>\r\n      </div>\r\n      <button\r\n        *ngIf=\"showExportButton\"\r\n        mat-flat-button\r\n        class=\"btn-export-mobile\"\r\n        [matMenuTriggerFor]=\"exportMenu\">\r\n        <div class=\"button-content\">\r\n          <mat-icon>file_export</mat-icon>\r\n          <mat-icon class=\"arrow-icon\">keyboard_arrow_down</mat-icon>\r\n        </div>\r\n      </button>\r\n      <mat-menu #exportMenu=\"matMenu\">\r\n        <button mat-menu-item (click)=\"onExportClick('pdf')\">PDF</button>\r\n        <button mat-menu-item (click)=\"onExportClick('xlsx')\">Excel</button>\r\n        <button mat-menu-item (click)=\"onExportClick('csv')\">CSV</button>\r\n      </mat-menu>\r\n    </div>\r\n\r\n    <!-- Mobile Row 2: Filter By and Sort By Buttons -->\r\n    <div class=\"mobile-filter-row\">\r\n      <button\r\n        mat-flat-button\r\n        class=\"btn-filter-by\"\r\n        (click)=\"onApplyFilter()\">\r\n        <div class=\"button-content\">\r\n          <mat-icon>filter_list</mat-icon>\r\n          <span>{{ 'FILTER-BUILDER.filterBy' | translate }}</span>\r\n        </div>\r\n      </button>\r\n      <button\r\n        mat-flat-button\r\n        class=\"btn-sort-by\"\r\n        [matMenuTriggerFor]=\"sortMenu\">\r\n        <div class=\"button-content\">\r\n          <mat-icon>unfold_more</mat-icon>\r\n          <span>{{ 'FILTER-BUILDER.sortBy' | translate }}</span>\r\n          <mat-icon class=\"arrow-icon\">keyboard_arrow_down</mat-icon>\r\n        </div>\r\n      </button>\r\n      <mat-menu #sortMenu=\"matMenu\">\r\n        <button \r\n          *ngFor=\"let column of getSortableColumns()\" \r\n          mat-menu-item \r\n          (click)=\"onSortByClick(column.property)\">\r\n          {{ labelKey(column) | translate }}\r\n        </button>\r\n        <button \r\n          *ngIf=\"getSortableColumns().length === 0\" \r\n          mat-menu-item \r\n          disabled>\r\n          {{ 'FILTER-BUILDER.noSortableColumns' | translate }}\r\n        </button>\r\n      </mat-menu>\r\n    </div>\r\n  </div>\r\n\r\n<!--  <div *ngIf=\"checkIsEmpty()\" class=\"line-top\">-->\r\n<!--    <mat-divider></mat-divider>-->\r\n<!--  </div>-->\r\n\r\n<!--  <div class=\"line-bottom\">-->\r\n<!--    <mat-divider></mat-divider>-->\r\n<!--  </div>-->\r\n\r\n<!--  <div class=\"action\">-->\r\n<!--    <button class=\"btn-none-background-primary action__clear\" mat-button (click)=\"deleteAll()\">-->\r\n<!--      {{'FILTER-BUILDER.clearAllFilters' | translate}}-->\r\n<!--    </button>-->\r\n<!--    <button class=\"btn-background-primary\" mat-button (click)=\"doSearch()\">-->\r\n<!--      {{'FILTER-BUILDER.search' | translate}}-->\r\n<!--    </button>-->\r\n<!--  </div>-->\r\n</div>\r\n"]}
|
|
288
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-builder.component.js","sourceRoot":"","sources":["../../../../../../../../projects/invoiceq/ui-lib/src/lib/components/advanced-filter/filter-builder/filter-builder.component.ts","../../../../../../../../projects/invoiceq/ui-lib/src/lib/components/advanced-filter/filter-builder/filter-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output} from '@angular/core';\r\nimport {CommonModule, formatDate, NgForOf} from '@angular/common';\r\nimport {FieldInfo, PageInfo, TableColumn} from \"../../../base-model\";\r\nimport {FieldFilter} from \"../../../base-model/field-filter.model\";\r\nimport {FieldFilterComponent} from \"../field-filter/field-filter.component\";\r\nimport {TranslateModule} from \"@ngx-translate/core\";\r\nimport {MatButtonModule} from \"@angular/material/button\";\r\nimport {MatIcon} from \"@angular/material/icon\";\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from \"@angular/material/menu\";\r\n\r\n@Component({\r\n  selector: 'app-filter-builder',\r\n  templateUrl: './filter-builder.component.html',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FieldFilterComponent,\r\n    TranslateModule,\r\n    MatButtonModule,\r\n    MatIcon,\r\n    MatMenu,\r\n    MatMenuItem,\r\n    MatMenuTrigger,\r\n    NgForOf\r\n  ],\r\n  styleUrls: ['./filter-builder.component.scss']\r\n})\r\nexport class FilterBuilderComponent implements OnInit, OnDestroy {\r\n\r\n  @Input()\r\n  columns: TableColumn<any>[];\r\n\r\n@Input()\r\n  isChecked: boolean;\r\n  @Input()\r\n  filterFields: FieldInfo[];\r\n  @Input()\r\n  pageInfo: PageInfo;\r\n  @Input()\r\n  pendingFilters: FieldFilter[] = [];\r\n\r\n  @Input()\r\n  showExportButton: boolean = false;\r\n\r\n  filter: FieldFilter;\r\n  filters: FieldFilter[] = [];\r\n\r\n  private searchTimeout: any;\r\n  private autoApplyTimeout: any;\r\n\r\n  @Output()\r\n  filterInformation: EventEmitter<{ filters: FieldFilter[], searchStr: string }> = new EventEmitter<{ filters: FieldFilter[], searchStr: string }>();\r\n\r\n  @Output()\r\n  isEmpty: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  @Output()\r\n  applyFilter: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  sortByClicked: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  @Output()\r\n  exportClicked: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  constructor() {\r\n  }\r\n\r\n  isMobile(): boolean {\r\n    return typeof window !== 'undefined' && window.innerWidth <= 768;\r\n  }\r\n\r\n  getSortableColumns(): TableColumn<any>[] {\r\n    if (!this.columns) {\r\n      return [];\r\n    }\r\n    return this.columns.filter(column =>\r\n      column.visible === true && column.enableSorting === true\r\n    );\r\n  }\r\n\r\n  labelKey(column: TableColumn<any>): string {\r\n    if (!column || !column.property) {\r\n      return '';\r\n    }\r\n    const configuredKey = column.label ? column.label : column.property;\r\n    if (!this.pageInfo || !this.pageInfo.labelsSection) {\r\n      return configuredKey;\r\n    }\r\n    return configuredKey.startsWith(this.pageInfo.labelsSection)\r\n      ? `${configuredKey}`\r\n      : `${this.pageInfo.labelsSection}.${configuredKey}`;\r\n  }\r\n\r\n  onSortByClick(columnProperty: string): void {\r\n    this.sortByClicked.emit(columnProperty);\r\n  }\r\n\r\n  onExportClick(reportType: string): void {\r\n    this.exportClicked.emit(reportType);\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n\r\n    this.switchToAdvanced();\r\n    if (!this.filter) {\r\n      this.filter = this.createDefaultFieldFilter();\r\n    }\r\n    if (this.filterFields && this.filterFields.length) {\r\n      this.filters = this.filterFields.map(() => this.createDefaultFieldFilter());\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.searchTimeout) {\r\n      clearTimeout(this.searchTimeout);\r\n      this.searchTimeout = null;\r\n    }\r\n    if (this.autoApplyTimeout) {\r\n      clearTimeout(this.autoApplyTimeout);\r\n      this.autoApplyTimeout = null;\r\n    }\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  onKeyDown(event: KeyboardEvent): void {\r\n    if (event.key === 'Enter' && !event.shiftKey && !event.ctrlKey && !event.metaKey) {\r\n      const target = event.target as HTMLElement;\r\n      const isInputElement = target.tagName === 'INPUT' ||\r\n                            target.tagName === 'TEXTAREA' ||\r\n                            target.tagName === 'SELECT' ||\r\n                            target.isContentEditable;\r\n\r\n      if (isInputElement) {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n        if (this.searchTimeout) {\r\n          clearTimeout(this.searchTimeout);\r\n          this.searchTimeout = null;\r\n        }\r\n        setTimeout(() => {\r\n          this.doSearch();\r\n          this.onApplyFilter();\r\n        }, 0);\r\n        return;\r\n      }\r\n      this.onApplyFilter();\r\n    }\r\n  }\r\n\r\n\r\n  doSearch() {\r\n    let searchStr = '';\r\n    const filtersArray = (this.filters || [])\r\n      .filter(f => !!f && f.fieldName && f.valueObject !== undefined && f.valueObject !== null && f.valueObject !== '')\r\n      .map(f => {\r\n        const fieldInfo = this.filterFields?.find(field => field.property === f.fieldName);\r\n        if (fieldInfo?.multiLevelSearchEnable && f.valueObject) {\r\n          searchStr = f.valueObject;\r\n          return null;\r\n        }\r\n        return {...f};\r\n      })\r\n      .filter(f => f !== null);\r\n\r\n    this.filterInformation.emit({ filters: filtersArray, searchStr });\r\n  }\r\n\r\n  onApplyFilter(): void {\r\n    if (this.autoApplyTimeout) {\r\n      clearTimeout(this.autoApplyTimeout);\r\n      this.autoApplyTimeout = null;\r\n    }\r\n    setTimeout(() => {\r\n      this.doSearch();\r\n      this.applyFilter.emit();\r\n    }, 0);\r\n  }\r\n\r\n  private scheduleAutoApply(): void {\r\n    if (this.autoApplyTimeout) {\r\n      clearTimeout(this.autoApplyTimeout);\r\n      this.autoApplyTimeout = null;\r\n    }\r\n    this.autoApplyTimeout = setTimeout(() => {\r\n      this.onApplyFilter();\r\n      this.autoApplyTimeout = null;\r\n    }, 10000);\r\n  }\r\n\r\n  private scheduleSearch(delayMs: number = 800) {\r\n    if (this.searchTimeout) {\r\n      clearTimeout(this.searchTimeout);\r\n    }\r\n    this.searchTimeout = setTimeout(() => {\r\n      this.doSearch();\r\n    }, delayMs);\r\n  }\r\n\r\n  formChanges($event: any, index?: number, fieldInfo?: FieldInfo) {\r\n    if (this.autoApplyTimeout) {\r\n      clearTimeout(this.autoApplyTimeout);\r\n      this.autoApplyTimeout = null;\r\n    }\r\n\r\n    const formatIfDate = (type?: string, value?: any) => {\r\n      if (!type || value === undefined || value === null || value === '') return value;\r\n      if ((type || '').toLowerCase().includes('date')) {\r\n        return formatDate(value, 'yyyy-MM-dd', 'en_US');\r\n      }\r\n      return value;\r\n    };\r\n\r\n    if (index === undefined || !fieldInfo) {\r\n      if (!this.filterFields || !this.filterFields.length) {\r\n        this.filters = [];\r\n        this.doSearch();\r\n        return;\r\n      }\r\n\r\n      this.filters = this.filterFields.map((fi) => {\r\n        const controlName = fi.property;\r\n        let value = $event ? $event[controlName] : undefined;\r\n        if (value === undefined || value === null || value === '') {\r\n          return this.createDefaultFieldFilter();\r\n        }\r\n        const fieldName = controlName === 'from' || controlName === 'to' ?  fi.targetProperty : controlName;\r\n\r\n        return {\r\n          fieldName: fieldName,\r\n          operator: fi.filterOperator || 'EQUALS',\r\n          filterType: 'FILED_FILTER',\r\n          fieldType: this.typeMap(fi.type) as any,\r\n          valueObject: formatIfDate(fi.type, value) as any\r\n        } as FieldFilter;\r\n      });\r\n\r\n      const hasTextField = (this.filterFields || []).some(fi => ((fi.type || '').toLowerCase() === 'text'));\r\n      if (hasTextField) {\r\n        this.scheduleSearch();\r\n      } else {\r\n        this.doSearch();\r\n      }\r\n      this.scheduleAutoApply();\r\n      return;\r\n    }\r\n\r\n    if (!this.filters) {\r\n      this.filters = [];\r\n    }\r\n    if (this.filters.length < index + 1) {\r\n      this.filters.length = index + 1;\r\n    }\r\n\r\n    let controlName = fieldInfo.property;\r\n    let value = $event ? $event[controlName] : undefined;\r\n    if ($event && $event.filterField !== undefined && $event.fromValue !== undefined) {\r\n      controlName = $event.filterField || controlName;\r\n      value = $event.fromValue;\r\n    }\r\n\r\n    if (value === undefined || value === null || value === '') {\r\n      this.filters[index] = this.createDefaultFieldFilter();\r\n    } else {\r\n      this.filters[index] = {\r\n        fieldName: controlName,\r\n        operator:  fieldInfo.filterOperator || 'EQUALS',\r\n        filterType: 'FILED_FILTER',\r\n        fieldType: this.typeMap(fieldInfo.type) as any,\r\n        valueObject: formatIfDate(fieldInfo.type, value) as any\r\n      } as FieldFilter;\r\n    }\r\n    const isTextField = ((fieldInfo.type || '').toLowerCase() === 'text');\r\n    if (isTextField) {\r\n      this.scheduleSearch();\r\n    } else {\r\n      this.doSearch();\r\n    }\r\n    this.scheduleAutoApply();\r\n  }\r\n  typeMap(colType?: string): string {\r\n    const t = (colType || '').toLowerCase();\r\n    if (t.includes('number') || t.includes('int') || t === 'long') return 'Long';\r\n    if (t.includes('date') || t.includes('time')) return 'Date';\r\n    if (t.includes('bool')) return 'Boolean';\r\n    return 'String';\r\n  }\r\n\r\n  isEditable(_index?: number) {\r\n    return true;\r\n  }\r\n\r\n\r\n  deleteAll() {\r\n    this.filter = this.createDefaultFieldFilter();\r\n    this.filters = this.filterFields ? this.filterFields.map(() => this.createDefaultFieldFilter()) : [];\r\n    this.isEmpty.emit(true);\r\n  }\r\n\r\n\r\n  switchToAdvanced() {\r\n    if (this.isChecked) {\r\n      if (!this.filter || Object.keys(this.filter).length === 0) {\r\n        this.filter = this.createDefaultFieldFilter();\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  private createDefaultFieldFilter(): FieldFilter {\r\n    return {\r\n      fieldName: '',\r\n      operator: '',\r\n      filterType: '',\r\n      fieldType: '',\r\n      valueObject: ''\r\n    } as FieldFilter;\r\n  }\r\n}\r\n","<div class=\"main-filter-builder\">\r\n\r\n  <!-- Desktop View -->\r\n  <div class=\"filterForm desktop-view\">\r\n    <div class=\"filterForm__row\">\r\n      <div class=\"filterForm__col\">\r\n        <app-field-filter\r\n          [editable]=\"isEditable()\"\r\n          [filter]=\"filter\"\r\n          [pageInfo]=\"pageInfo\"\r\n          *ngIf=\"isEditable()\"\r\n          [filterFields]=\"filterFields\"\r\n          (filterFieldInformation)=\"formChanges($event)\"\r\n          class=\"filterForm__filed-filter\"\r\n        >\r\n        </app-field-filter>\r\n      </div>\r\n      <div class=\"button-group\">\r\n        <button\r\n          mat-flat-button\r\n          class=\"btn-apply-filter\"\r\n          (click)=\"onApplyFilter()\">\r\n          <div class=\"button-text\">\r\n            <mat-icon>filter_list</mat-icon>\r\n            <span>{{ 'FILTER-BUILDER.applyFilter' | translate }}</span>\r\n          </div>\r\n        </button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Mobile View -->\r\n  <div class=\"mobile-view\">\r\n    <!-- Mobile Row 1: Search Field and Export Button -->\r\n    <div class=\"mobile-search-row\">\r\n      <div class=\"mobile-search-field\">\r\n        <app-field-filter\r\n          [editable]=\"isEditable()\"\r\n          [filter]=\"filter\"\r\n          [pageInfo]=\"pageInfo\"\r\n          *ngIf=\"isEditable()\"\r\n          [filterFields]=\"filterFields\"\r\n          (filterFieldInformation)=\"formChanges($event)\"\r\n          class=\"mobile-field-filter\"\r\n        >\r\n        </app-field-filter>\r\n      </div>\r\n      <button\r\n        *ngIf=\"showExportButton\"\r\n        mat-flat-button\r\n        class=\"btn-export-mobile\"\r\n        [matMenuTriggerFor]=\"exportMenu\">\r\n        <div class=\"button-content\">\r\n          <mat-icon>file_export</mat-icon>\r\n          <mat-icon class=\"arrow-icon\">keyboard_arrow_down</mat-icon>\r\n        </div>\r\n      </button>\r\n      <mat-menu #exportMenu=\"matMenu\">\r\n        <button mat-menu-item (click)=\"onExportClick('pdf')\">PDF</button>\r\n        <button mat-menu-item (click)=\"onExportClick('xlsx')\">Excel</button>\r\n        <button mat-menu-item (click)=\"onExportClick('csv')\">CSV</button>\r\n      </mat-menu>\r\n    </div>\r\n\r\n    <!-- Mobile Row 2: Filter By and Sort By Buttons -->\r\n    <div class=\"mobile-filter-row\">\r\n      <button\r\n        mat-flat-button\r\n        class=\"btn-filter-by\"\r\n        (click)=\"onApplyFilter()\">\r\n        <div class=\"button-content\">\r\n          <mat-icon>filter_list</mat-icon>\r\n          <span>{{ 'FILTER-BUILDER.filterBy' | translate }}</span>\r\n        </div>\r\n      </button>\r\n      <button\r\n        mat-flat-button\r\n        class=\"btn-sort-by\"\r\n        [matMenuTriggerFor]=\"sortMenu\">\r\n        <div class=\"button-content\">\r\n          <mat-icon>unfold_more</mat-icon>\r\n          <span>{{ 'FILTER-BUILDER.sortBy' | translate }}</span>\r\n          <mat-icon class=\"arrow-icon\">keyboard_arrow_down</mat-icon>\r\n        </div>\r\n      </button>\r\n      <mat-menu #sortMenu=\"matMenu\">\r\n        <button \r\n          *ngFor=\"let column of getSortableColumns()\" \r\n          mat-menu-item \r\n          (click)=\"onSortByClick(column.property)\">\r\n          {{ labelKey(column) | translate }}\r\n        </button>\r\n        <button \r\n          *ngIf=\"getSortableColumns().length === 0\" \r\n          mat-menu-item \r\n          disabled>\r\n          {{ 'FILTER-BUILDER.noSortableColumns' | translate }}\r\n        </button>\r\n      </mat-menu>\r\n    </div>\r\n  </div>\r\n\r\n<!--  <div *ngIf=\"checkIsEmpty()\" class=\"line-top\">-->\r\n<!--    <mat-divider></mat-divider>-->\r\n<!--  </div>-->\r\n\r\n<!--  <div class=\"line-bottom\">-->\r\n<!--    <mat-divider></mat-divider>-->\r\n<!--  </div>-->\r\n\r\n<!--  <div class=\"action\">-->\r\n<!--    <button class=\"btn-none-background-primary action__clear\" mat-button (click)=\"deleteAll()\">-->\r\n<!--      {{'FILTER-BUILDER.clearAllFilters' | translate}}-->\r\n<!--    </button>-->\r\n<!--    <button class=\"btn-background-primary\" mat-button (click)=\"doSearch()\">-->\r\n<!--      {{'FILTER-BUILDER.search' | translate}}-->\r\n<!--    </button>-->\r\n<!--  </div>-->\r\n</div>\r\n"]}
|