@unifylib/ui-lib 1.1.37 → 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/iq-ui-lib.mjs +5 -0
- package/esm2022/lib/components/advanced-filter/filter-builder/filter-builder.component.mjs +5 -2
- package/esm2022/lib/components/base-table/base-table.component.mjs +6 -2
- package/fesm2022/iq-ui-lib.mjs +6293 -0
- package/fesm2022/iq-ui-lib.mjs.map +1 -0
- package/fesm2022/unifylib-ui-lib.mjs +9 -2
- package/fesm2022/unifylib-ui-lib.mjs.map +1 -1
- package/lib/components/base-table/base-table.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXEtdWktbGliLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvaW52b2ljZXEvdWktbGliL3NyYy9pcS11aS1saWIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -109,7 +109,10 @@ export class FilterBuilderComponent {
|
|
|
109
109
|
clearTimeout(this.autoApplyTimeout);
|
|
110
110
|
this.autoApplyTimeout = null;
|
|
111
111
|
}
|
|
112
|
-
|
|
112
|
+
setTimeout(() => {
|
|
113
|
+
this.doSearch();
|
|
114
|
+
this.applyFilter.emit();
|
|
115
|
+
}, 0);
|
|
113
116
|
}
|
|
114
117
|
scheduleAutoApply() {
|
|
115
118
|
if (this.autoApplyTimeout) {
|
|
@@ -282,4 +285,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
282
285
|
type: HostListener,
|
|
283
286
|
args: ['keydown', ['$event']]
|
|
284
287
|
}] } });
|
|
285
|
-
//# 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    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"]}
|
|
@@ -100,6 +100,8 @@ export class BaseTableComponent extends BaseUtils {
|
|
|
100
100
|
this.filterRequest = new FilterRequest();
|
|
101
101
|
this.initializeMobilePageSize();
|
|
102
102
|
effect(() => {
|
|
103
|
+
if (this.applyingFilters)
|
|
104
|
+
return;
|
|
103
105
|
if (this.pageInfo.lazyLoadData !== true || this.enforceRefresh === true) {
|
|
104
106
|
this.loadData();
|
|
105
107
|
}
|
|
@@ -461,8 +463,10 @@ export class BaseTableComponent extends BaseUtils {
|
|
|
461
463
|
this.searchStr = $event.searchStr;
|
|
462
464
|
}
|
|
463
465
|
applyPendingFilters() {
|
|
464
|
-
this.
|
|
466
|
+
this.applyingFilters = true;
|
|
467
|
+
this.advancedAppliedFilter = [...this.pendingFilters];
|
|
465
468
|
this.loadData();
|
|
469
|
+
this.applyingFilters = false;
|
|
466
470
|
}
|
|
467
471
|
handleFilterEmpty($event) {
|
|
468
472
|
if ($event) {
|
|
@@ -625,4 +629,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
625
629
|
}], clickRoutePage: [{
|
|
626
630
|
type: Output
|
|
627
631
|
}] } });
|
|
628
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/base-table/base-table.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/base-table/base-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  effect,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges\r\n} from \"@angular/core\";\r\nimport {MatTableDataSource} from \"@angular/material/table\";\r\nimport {TranslateModule, TranslateService} from \"@ngx-translate/core\";\r\nimport {MatSortModule, Sort} from \"@angular/material/sort\";\r\nimport {\r\n  CurrencyPipe,\r\n  DatePipe,\r\n  DecimalPipe,\r\n  NgClass,\r\n  NgForOf,\r\n  NgIf,\r\n  NgStyle,\r\n  NgSwitch,\r\n  NgSwitchCase,\r\n  NgSwitchDefault\r\n} from \"@angular/common\";\r\nimport {MatIcon} from \"@angular/material/icon\";\r\nimport {MatButton, MatButtonModule, MatIconButton} from \"@angular/material/button\";\r\nimport {NgxPaginationModule} from \"ngx-pagination\";\r\nimport {ButtonActionsComponent} from \"../button-actions/button-actions.component\";\r\nimport {ShareDataService} from \"../../services/trigger-form.service\";\r\nimport {BaseUtils} from \"../../utils/base-utils\";\r\nimport {BackendService} from \"../../services/backend-service\";\r\nimport {Filter} from \"../../base-model/filter.model\";\r\nimport {FilterRequest} from \"../../base-model/filter-request\";\r\nimport {\r\n  ButtonActionSettings,\r\n  EMPTY_PAGE_INFO,\r\n  FieldInfo,\r\n  FRONT_END_COLUMN_TYPES,\r\n  PageInfo,\r\n  TABLE_RECORD_ACTION,\r\n  TableColumn\r\n} from \"../../base-model\";\r\nimport {ReportRequest} from \"../../base-model/report-request.model\";\r\nimport {TablePageUserAction} from \"../../base-model/table-page-user-action.interface\";\r\nimport {Workflow} from \"../../base-model/workflow/workflow.model\";\r\nimport {ResponseEnvelop} from \"../../base-model/response-envelop.model\";\r\nimport {Router} from \"@angular/router\";\r\nimport {MatLabel} from \"@angular/material/form-field\";\r\nimport {TitleBarComponent} from \"../title-bar/title-bar.component\";\r\nimport {PaginatorComponent} from \"../paginator/paginator.component\";\r\nimport {MatCheckbox} from \"@angular/material/checkbox\";\r\nimport {FilterBuilderComponent} from \"../advanced-filter/filter-builder/filter-builder.component\";\r\nimport {FieldFilter} from \"../../base-model/field-filter.model\";\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from \"@angular/material/menu\";\r\n\r\n@Component({\r\n  selector: 'app-base-table',\r\n  standalone: true,\r\n  templateUrl: './base-table.component.html',\r\n  styleUrls: ['./base-table.component.scss'],\r\n  animations: [],\r\n  imports: [\r\n    NgStyle,\r\n    NgClass,\r\n    TranslateModule,\r\n    MatIcon,\r\n    MatSortModule,\r\n    NgIf,\r\n    NgSwitch,\r\n    MatButtonModule,\r\n    DatePipe,\r\n    CurrencyPipe,\r\n    NgxPaginationModule,\r\n    NgSwitchCase,\r\n    NgSwitchDefault,\r\n    MatIconButton,\r\n    NgForOf,\r\n    MatButton,\r\n    ButtonActionsComponent,\r\n    MatLabel,\r\n    TitleBarComponent,\r\n    PaginatorComponent,\r\n    DecimalPipe,\r\n    MatCheckbox,\r\n    FilterBuilderComponent,\r\n    MatMenuTrigger,\r\n    MatMenu,\r\n    MatMenuItem,\r\n\r\n  ]\r\n})\r\nexport class BaseTableComponent extends BaseUtils implements OnInit, OnChanges, OnDestroy {\r\n  types: string[] = [\"pdf\", \"csv\", \"xlsx\"]\r\n  collection = {count: 60, data: []};\r\n  config = {\r\n    itemsPerPage: 15,\r\n    currentPage: 1,\r\n    totalItems: this.collection.count\r\n  };\r\n  public maxSize: number = 7;\r\n  public directionLinks: boolean = true;\r\n  public autoHide: boolean = false;\r\n  public responsive: boolean = true;\r\n  public labels: any = {\r\n    previousLabel: '<',\r\n    nextLabel: '>',\r\n    screenReaderPaginationLabel: 'Pagination',\r\n    screenReaderPageLabel: 'page',\r\n    screenReaderCurrentLabel: `You're on page`\r\n  };\r\n\r\n  @Input()\r\n  filterFields: FieldInfo[];\r\n  @Input() noDataFoundSvgPath: string;\r\n  @Input() noDataFoundTitle = 'noDataFoundTitle';\r\n  @Input() noDataFoundSubtitle = 'noDataFoundSubtitle';\r\n  @Input() noResultSvgPath: string;\r\n  @Input() noResultTitle = 'noResultTitle';\r\n  @Input() noResultSubtitle = 'noResultSubtitle';\r\n  totalElements = 0;\r\n  pagesCount = 0;\r\n  pageIndex = 1;\r\n  pageSize = 15;\r\n  mobileDisplayedItems = 0;\r\n  private selectedStatusFilter: Filter[] = [];\r\n  advancedAppliedFilter: any[] = [];\r\n  pendingFilters: any[] = [];\r\n  searchStr: string = '';\r\n  private filterRequest: FilterRequest = new FilterRequest();\r\n  private timer: any;\r\n  @Input()\r\n  override pageInfo: PageInfo = EMPTY_PAGE_INFO;\r\n\r\n  @Input()\r\n  enablePagination: boolean = true;\r\n\r\n  @Input()\r\n  mobilePageSize: number = 2;\r\n\r\n  @Input()\r\n  mobileLoadMoreIncrement: number = 2;\r\n\r\n  @Input() data?: MatTableDataSource<any>;\r\n  @Input()\r\n  listAction: ButtonActionSettings[] = [];\r\n\r\n  @Input()\r\n  extraActions: ButtonActionSettings[] = [];\r\n\r\n  @Input()\r\n  buttonsDisplayMode: 'dropdown' | 'list' = 'dropdown';\r\n\r\n  @Input()\r\n  columns: TableColumn<any>[];\r\n\r\n  @Input()\r\n  filters: Filter[] = [];\r\n\r\n  @Input() //@ts-ignore\r\n  pathParam: number;\r\n\r\n  @Input()\r\n  extraButton:  ButtonActionSettings[] = [];\r\n\r\n  @Output() buttonClicked = new EventEmitter<ButtonActionSettings>();\r\n\r\n  @Input() //@ts-ignore\r\n  enforceRefresh: boolean = false;\r\n\r\n  @Input()\r\n  isPending: boolean = false;\r\n\r\n  @Input()\r\n  trigger: boolean = false;\r\n\r\n  @Input()\r\n  reportRequest: ReportRequest = new ReportRequest({});\r\n\r\n  @Input()\r\n  separateEndpointData: any;\r\n  @Input()\r\n  manageablePages: boolean = false;\r\n  @Input()\r\n  totalPagesCount: number = 0;\r\n  @Input()\r\n  currentPageIndex: number = 0;\r\n\r\n  @Output()\r\n  pageChange: EventEmitter<any> = new EventEmitter();\r\n\r\n\r\n  @Output()\r\n  userAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n  @Output()\r\n  hyperLinkAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n\r\n  @Output()\r\n  extraAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n\r\n  @Output()\r\n  selectedColumn: EventEmitter<Sort> = new EventEmitter<Sort>();\r\n\r\n  @Output()\r\n  listActionClicked: EventEmitter<{ action: ButtonActionSettings, row: any , isPending: boolean}> = new EventEmitter<{\r\n    action: ButtonActionSettings,\r\n    row: any,\r\n    isPending: boolean\r\n  }>();\r\n\r\n  @Output()\r\n  showDialog: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  usedWorkflow!: Workflow;\r\n\r\n  mode:any;\r\n\r\n  @Input()\r\n  customizedData?: MatTableDataSource<any>;\r\n  dataSource: MatTableDataSource<any>;\r\n  selectedRowIndex = -1;\r\n  noDataFound = false;\r\n  totalRequiredCountItem = 0;\r\n\r\n\r\n  @Output()\r\n  clickRoutePage: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  constructor(\r\n      private backendService: BackendService,\r\n      public translateService: TranslateService,\r\n      public shareDataService: ShareDataService,\r\n      @Inject('securityManager') private securityManager: any,\r\n      private router: Router,\r\n  ) {\r\n    super();\r\n    this.dataSource = new MatTableDataSource();\r\n    this.columns = [];\r\n    this.filterRequest = new FilterRequest();\r\n\r\n    this.initializeMobilePageSize();\r\n\r\n    effect(() => {\r\n      if (this.pageInfo.lazyLoadData !== true || this.enforceRefresh === true) {\r\n        this.loadData();\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.backendService.isEmptyItems = this.dataSource.data.length <= 0;\r\n    if (this.customizedData) {\r\n      this.dataSource = this.customizedData;\r\n    }\r\n    if(this.manageablePages) {\r\n      this.pagesCount = this.totalPagesCount;\r\n      this.pageIndex = this.currentPageIndex;\r\n    }\r\n\r\n    this.initializeMobilePageSize();\r\n    this.mobileDisplayedItems = this.pageSize;\r\n  }\r\n\r\n  private isMobile(): boolean {\r\n    return typeof window !== 'undefined' && window.innerWidth <= 768;\r\n  }\r\n\r\n  private initializeMobilePageSize(): void {\r\n    if (this.isMobile() && this.pageSize > this.mobilePageSize) {\r\n      this.pageSize = this.mobilePageSize;\r\n      if (this.reportRequest?.filterRequest) {\r\n        this.reportRequest.filterRequest.pageSize = this.mobilePageSize;\r\n      }\r\n    }\r\n  }\r\n\r\n  onPageChange(event: number) {\r\n    this.pageIndex = event;\r\n    this.getNext(this.pageIndex - 1);\r\n    if (this.manageablePages) {\r\n      this.pageChange.emit(this.pageIndex);\r\n    }\r\n  }\r\n\r\n\r\n  extractFieldName(element: any, property: string) {\r\n    if (property?.includes('.')) {\r\n      return property.split('.').reduce((acc, part) => acc && acc[part], element);\r\n    } else {\r\n      const c = this.columns.find(c => c.property === property);\r\n      if (Array.isArray(element[property]) && c.arraySubProperty ) {\r\n        const fieldValues = element[property].map(f => f[c.arraySubProperty]);\r\n        return  fieldValues.join(', ');\r\n      }else {\r\n        return element[property];\r\n      }\r\n    }\r\n  }\r\n\r\n  get visibleColumns() {\r\n    this.buildGroups()\r\n    return this.columns.filter(column => column.visible).map(column => column.property);\r\n  }\r\n\r\n  get visibleColumnsArray() {\r\n    return this.visibleColumns;\r\n  }\r\n\r\n  getColumn(property: string): TableColumn<any> | undefined {\r\n    return this.columns.find(c => c.property === property);\r\n  }\r\n\r\n  getSortDirection(property: string): 'asc' | 'desc' | '' {\r\n    if (this.reportRequest?.filterRequest?.sortKey === property) {\r\n      return this.reportRequest.filterRequest.sortDirection === 'ASC' ? 'asc' : 'desc';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  handleSortClick(property: string): void {\r\n    const COLUMN = this.getColumn(property);\r\n    if (!COLUMN || !COLUMN.enableSorting) {\r\n      return;\r\n    }\r\n\r\n    const CURRENT_DIRECTION = this.getSortDirection(property);\r\n    let NEW_DIRECTION: 'asc' | 'desc' = 'asc';\r\n\r\n    if (CURRENT_DIRECTION === 'asc') {\r\n      NEW_DIRECTION = 'desc';\r\n    }\r\n\r\n    this.onSortAction({\r\n      active: property,\r\n      direction: NEW_DIRECTION\r\n    });\r\n  }\r\n\r\n  sortState: any = {};\r\n\r\n  getNext(pageIndex: number) {\r\n    this.reportRequest.filterRequest.pageIndex = pageIndex;\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    this.loadData();\r\n  }\r\n  onPageSizeChange(event: number) {\r\n    this.pageSize = event;\r\n    this.pageIndex = 1; // reset to first page on page size change\r\n    this.mobileDisplayedItems = 0;\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    this.getNext(0);\r\n  }\r\n\r\n  onLoadMore(itemsToLoad: number) {\r\n    const currentDisplayed = this.mobileDisplayedItems || this.dataSource.data.length || this.pageSize;\r\n    this.pageSize = Math.min(currentDisplayed + itemsToLoad, this.totalElements);\r\n    this.mobileDisplayedItems = this.pageSize;\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    this.reportRequest.filterRequest.pageIndex = 0;\r\n    this.pageIndex = 1;\r\n    this.loadData(true);\r\n  }\r\n\r\n  private loadData(skipMobileReset: boolean = false) {\r\n    clearTimeout(this.timer);\r\n\r\n    if (!skipMobileReset) {\r\n      this.initializeMobilePageSize();\r\n    }\r\n\r\n    if (!this.reportRequest.filterRequest) {\r\n      this.reportRequest.filterRequest = new FilterRequest(this.pageSize || this.pageInfo.pageSize);\r\n      this.reportRequest.filterRequest.searchStr = this.searchStr;\r\n      this.reportRequest.filterRequest.filters = [\r\n        ...(this.advancedAppliedFilter || []),\r\n        ...(this.filters || []).filter(f =>\r\n          !(this.advancedAppliedFilter || []).some(a => a.field === f.fieldName)\r\n        )\r\n      ];\r\n    }\r\n\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    if (this.separateEndpointData || !this.pageInfo.apiUri || this.pageInfo.apiUri.length === 0) {\r\n      this.dataSource.data = this.separateEndpointData;\r\n    } else if(this.reportRequest == undefined){\r\n      return;\r\n    } else if(!this.manageablePages)  {\r\n      this.timer = setTimeout(() => {\r\n          this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n          this.reportRequest.filterRequest.columns = this.columns?.filter(c => FRONT_END_COLUMN_TYPES.indexOf(c.type) < 0 ).map(c => c.property) || [];\r\n          this.reportRequest.filterRequest.pendingPage = this.isPending;\r\n          this.reportRequest.filterRequest.searchStr = this.searchStr;\r\n          this.reportRequest.filterRequest.filters = [\r\n            ...(this.advancedAppliedFilter || []),\r\n            ...(this.filters || []).filter(f =>\r\n              !(this.advancedAppliedFilter || []).some(a => a.field === f.fieldName)\r\n            )\r\n          ];\r\n            this.backendService.getItemsByFilter(this.reportRequest?.filterRequest, this.pageInfo.apiUri).subscribe(resp => {\r\n              const responseEnvelope = new ResponseEnvelop(resp);\r\n              if (responseEnvelope.valid) {\r\n                this.totalRequiredCountItem = this.reportRequest.filterRequest.pageSize\r\n                this.noDataFound = responseEnvelope.body.length < 1;\r\n                this.dataSource.data = responseEnvelope.body;\r\n                this.backendService.isEmptyItems = this.dataSource.data.length <= 0;\r\n                this.totalElements = responseEnvelope.totalSize || 0;\r\n                this.pagesCount = Math.ceil(this.totalElements / this.pageSize) || 1;\r\n                this.pageIndex = (this.reportRequest.filterRequest.pageIndex || 0) + 1;\r\n                this.config.totalItems = responseEnvelope.totalSize || 0;\r\n                this.config.currentPage = this.pageIndex + 1;\r\n                this.mobileDisplayedItems = this.dataSource.data.length;\r\n              }\r\n            });\r\n          }\r\n          , 300);\r\n    }\r\n  }\r\n\r\n  getStatusDescription(element: any) {\r\n    return this.backendService.getStatusDescription(element, this.usedWorkflow);\r\n  }\r\n\r\n  getStateType(element: any) {\r\n    return element.stateType\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes[\"customizedData\"] && !changes[\"customizedData\"].isFirstChange()) {\r\n      this.dataSource.data = changes[\"customizedData\"].currentValue?.data || [];  // Update data source with new data\r\n      this.pagesCount=this.totalPagesCount;\r\n      this.pageIndex=this.currentPageIndex;\r\n    }\r\n    if (changes[\"enforceRefresh\"] && !changes[\"enforceRefresh\"].isFirstChange()) {\r\n      this.loadData();\r\n    }\r\n    if (changes[\"isPending\"] && !changes[\"isPending\"].isFirstChange()) {\r\n      this.loadData();\r\n    }\r\n  }\r\n  getCroppedText(elementValue: any, subWidth: number = 20) {\r\n    return elementValue && elementValue.length > subWidth ? elementValue.substring(0, subWidth) + \"...\" : elementValue;\r\n  }\r\n\r\n  emitEvent(element: any) {\r\n    this.showDialog.emit(element);\r\n  }\r\n\r\n  extractFormat(column: TableColumn<any>) {\r\n    return column?.format || 'd/M/yyyy, h:mm a';\r\n  }\r\n\r\n  actionListClicked(listAction: ButtonActionSettings, element: any) {\r\n    this.listActionClicked.emit({action:listAction, row: element, isPending: this.isPending});\r\n  }\r\n\r\n  hyperLinkClicked(actionName: string, element: any) {\r\n    const action = TABLE_RECORD_ACTION;\r\n    action.actionKey = actionName;\r\n    action.item = element;\r\n    action.pageInfo = this.pageInfo;\r\n    this.hyperLinkAction.emit(action)\r\n  }\r\n\r\n\r\n  emitRoutePage(element: any){\r\n    this.clickRoutePage.emit(element);\r\n  }\r\n\r\n  onSelectItem(row: any) {\r\n    if (this.pageInfo.selfRouting) {\r\n      const mode = this.isPending ? 'pending' : 'view';\r\n      const url = `${this.pageInfo.listRoutePath || this.router.url}/view`;\r\n\r\n      const encryptedId = this.backendService.encrypt(String(row.id));\r\n      const encryptedMode = this.backendService.encrypt(mode);\r\n\r\n      const encryptedRow = this.backendService.encrypt(JSON.stringify(row));\r\n\r\n      this.router.navigate([url], {\r\n        queryParams: { token: encryptedId, mode: encryptedMode },\r\n        state: { raw: encryptedRow },\r\n      });\r\n      return;\r\n    }\r\n    // const action = SELECT_RECORD_ACTION;\r\n    // action.id = row?.id;\r\n    // action.item = row;\r\n    // this.userAction.emit(action)\r\n  }\r\n\r\n  openNewTab(row) {\r\n    if (!this.pageInfo.embededTableOnly) {\r\n      const mode = this.isPending ? 'pending' : 'view';\r\n      window.open(`${this.pageInfo.listRoutePath}/${mode}` + '/' + row?.id);\r\n    }\r\n  }\r\n\r\n  onViewModeChangedReceived(isPending: boolean) {\r\n    this.switchViewMode(isPending);\r\n  }\r\n\r\n  switchViewMode(isPending: boolean) {\r\n    this.isPending = isPending;\r\n    this.loadData();\r\n  }\r\n\r\n  onAddNewAction($event: any) {\r\n    const url = `${this.pageInfo.listRoutePath || this.router.url}/view`;\r\n    const encryptedId = this.backendService.encrypt(\"-1\");\r\n    const encryptedMode = this.backendService.encrypt(\"pending\");\r\n    this.router.navigate([`${url}`],\r\n      { queryParams: { token: encryptedId , mode : encryptedMode } });\r\n\r\n    // const action = SELECT_RECORD_ACTION;\r\n    // action.id = row?.id;\r\n    // action.item = row;\r\n    // this.userAction.emit(action)\r\n  }\r\n\r\n  showAddNew() {\r\n    return this.pageInfo.hasAddButton ;\r\n  }\r\n\r\n  onExtraButtionAction($event: any) {\r\n    this.extraAction.emit($event);\r\n\r\n  }\r\n\r\n  hasGroups() {\r\n    let b = this.columns.findIndex(p => p.group);\r\n    return b >= 0;\r\n  }\r\n  groupNames: any = []\r\n  groupSpans: Map<string, number> = new Map();\r\n\r\n  buildGroups(){\r\n    let count = 0;\r\n    this.groupNames = [];\r\n    this.groupSpans.clear();\r\n    if(this.hasGroups() === false){\r\n      return;\r\n    }\r\n    this.columns\r\n      .filter(column => column.visible === true)\r\n      .forEach((column) => {\r\n        if (column.group === \"-\") {\r\n          this.groupNames.push(count.toString());\r\n          this.insertInMap(count);\r\n          count++;\r\n          return;\r\n        } else if (!this.groupNames.includes(column.group)) {\r\n          this.groupNames.push(column.group);\r\n          this.insertInMap(column.group);\r\n          return;\r\n        }\r\n        this.insertInMap(column.group);\r\n      });\r\n  }\r\n\r\n  insertInMap(key){\r\n    if(this.groupSpans.has(key)){\r\n      this.groupSpans.set(key.toString(), this.groupSpans.get(key) + 1);\r\n    } else {\r\n      this.groupSpans.set(key.toString(), 1);\r\n    }\r\n  }\r\n\r\n  isHumanMade(str){\r\n    return isNaN(str);\r\n  }\r\n\r\n  actionButtonClicked(actionKey: string, item: any): void {\r\n    if (actionKey === 'navigate') {\r\n      this.handleNavigateAction(item);\r\n      return;\r\n    }\r\n\r\n    this.emitTableAction(actionKey, item);\r\n  }\r\n\r\n  private handleNavigateAction(item: any): void {\r\n    const mode = this.isPending ? 'pending' : 'view';\r\n    const basePath = this.pageInfo.listRoutePath || this.router.url;\r\n    const url = `${basePath}/view`;\r\n\r\n    const encryptedId = this.backendService.encrypt(item.id.toString());\r\n    const encryptedMode = this.backendService.encrypt(mode);\r\n\r\n    this.router.navigate([url], {\r\n      queryParams: { token: encryptedId, mode: encryptedMode }\r\n    });\r\n  }\r\n\r\n  private emitTableAction(actionKey: string, item: any): void {\r\n    const action = TABLE_RECORD_ACTION;\r\n    action.actionKey = actionKey;\r\n    action.item = item;\r\n    action.pageInfo = this.pageInfo;\r\n    this.userAction.emit(action);\r\n  }\r\n\r\n  extractReport(reportType: any) {\r\n    const myFilters = this.reportRequest.filterRequest;\r\n    const reportRequest = this.backendService.buildReportRequest(this.columns, this.pageInfo.labelsSection + '.list_title',\r\n      myFilters, reportType, this.pageInfo, this.searchStr, 'LANDSCAPE');\r\n    this.backendService.downloadReport(reportRequest, this.pageInfo.apiUri);\r\n  }\r\n\r\n  getIcon(status: string): string {\r\n    switch (status) {\r\n      case 'pass': return 'check_circle';\r\n      case 'warning': return 'warning';\r\n      case 'error': return 'error';\r\n      default: return 'help';\r\n    }\r\n  }\r\n\r\n  actionCheckedClicked(property: string, element) {\r\n    element[property]= !element[property];\r\n    this.actionButtonClicked(property, element);\r\n  }\r\n\r\n\r\n  isDarkHighlight(row: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !row[groupByProp]) {\r\n      return false;\r\n    }\r\n\r\n    const cellValue = row[groupByProp].toString();\r\n\r\n    return groupByValues.some(val =>\r\n      cellValue.includes(val) && cellValue.length > val.length\r\n    );\r\n  }\r\n\r\n  shouldRenderAsHyperLink(element: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !element[groupByProp]) {\r\n      return false;\r\n    }\r\n\r\n    const value = element[groupByProp].toString();\r\n\r\n    return !groupByValues.some(v => value.includes(v) && value.length >= v.length);\r\n  }\r\n\r\n\r\n  onSortAction($event: Sort) {\r\n    this.reportRequest.filterRequest.sortKey = $event.active && $event.direction ?\r\n      this.columns.find(c => c.property === $event.active)?.orderByProperty || $event.active\r\n      : 'id';\r\n    this.reportRequest.filterRequest.sortDirection = $event.direction === 'asc' ? 'ASC' : 'DESC';\r\n    this.reportRequest.filterRequest.pageIndex = 0;\r\n      this.selectedColumn.emit($event);\r\n      this.loadData();\r\n  }\r\n\r\n  shouldShowButton(element: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !element[groupByProp]) {\r\n      return true;\r\n    }\r\n\r\n    const value = element[groupByProp].toString();\r\n\r\n    return !groupByValues.some(v => value.includes(v) && value.length >= v.length);\r\n  }\r\n\r\n  storePendingFilters($event: { filters: FieldFilter[], searchStr: string }): void {\r\n    this.pendingFilters = $event.filters || [];\r\n      this.searchStr = $event.searchStr;\r\n  }\r\n\r\n  applyPendingFilters(): void {\r\n    this.advancedAppliedFilter = this.pendingFilters || [];\r\n    this.loadData();\r\n  }\r\n\r\n  handleFilterEmpty($event: boolean): void {\r\n    if ($event) {\r\n      this.pendingFilters = [];\r\n      this.advancedAppliedFilter = [];\r\n      this.loadData();\r\n    }\r\n  }\r\n\r\n  resetData($event: boolean) {\r\n    if ($event) {\r\n      this.advancedAppliedFilter = [];\r\n      this.pendingFilters = [];\r\n      this.loadData();\r\n      // this.paginator.firstPage();\r\n    }\r\n  }\r\n\r\n  hasFiltersApplied(): boolean {\r\n    return (this.advancedAppliedFilter && this.advancedAppliedFilter.length > 0) ||\r\n           (this.filters && this.filters.length > 0) ||\r\n           (this.pendingFilters && this.pendingFilters.length > 0);\r\n  }\r\n\r\n  getDisplaySvgPath(): string {\r\n    return this.hasFiltersApplied() && this.noResultSvgPath ? this.noResultSvgPath : this.noDataFoundSvgPath;\r\n  }\r\n\r\n  getDisplayTitle(): string {\r\n    return this.hasFiltersApplied() && this.noResultSvgPath ? this.noResultTitle : this.noDataFoundTitle;\r\n  }\r\n\r\n  getDisplaySubtitle(): string {\r\n    return this.hasFiltersApplied() && this.noResultSvgPath ? this.noResultSubtitle : this.noDataFoundSubtitle;\r\n  }\r\n\r\n  buttonClickedEvent($event: ButtonActionSettings) {\r\n\r\n  }\r\n\r\n  getMobileCardIdColumn(): TableColumn<any> | undefined {\r\n    return this.columns.find(c => c.visible && c.mobileCardId === true);\r\n  }\r\n\r\n  getMobileCardStatusColumn(): TableColumn<any> | undefined {\r\n    return this.columns.find(c => c.visible && c.mobileCardStatus === true);\r\n  }\r\n\r\n  getMobileCardColumns(): TableColumn<any>[] {\r\n    const idCol = this.getMobileCardIdColumn();\r\n    const statusCol = this.getMobileCardStatusColumn();\r\n\r\n    return this.columns.filter(c =>\r\n      c.visible &&\r\n      c.property !== 'actions' &&\r\n      c !== idCol &&\r\n      c !== statusCol\r\n    );\r\n  }\r\n\r\n  override labelKeyByValue(column: TableColumn<any> | undefined, row: any): string {\r\n    if (!column || !column.property) return '';\r\n    return super.labelKeyByValue(column, row);\r\n  }\r\n}\r\n","<div class=\"flex-column baseTable\">\r\n  <div class=\"flex-row flex-100\" >\r\n    <div class=\"flex-column align-start flex-100\" style=\"width: 100%;\">\r\n      <app-title-bar\r\n        [pageTitle]=\"pageInfo.hideTitle ? '' : pageInfo.labelsSection+'.list_title'\"\r\n        [subTitle]=\"(pageInfo.hideTitle || pageInfo.hideSubtitle) ? '' : pageInfo.labelsSection+'.subtitle'\"\r\n        [titleMode]=\"''\"\r\n        [pageInfo]=\"pageInfo\"\r\n        [newAction]=\"showAddNew()\"\r\n        [showExtractButton]=\"!pageInfo.hideExtractButton\"\r\n        [draftSupported]=\"pageInfo.draftSupported\"\r\n        [isPending]=\"isPending\"\r\n        [onViewModeChange]=\"switchViewMode.bind(this)\"\r\n        [buttons]=\"extraActions\"\r\n        [buttonsDisplayMode]=\"buttonsDisplayMode\"\r\n        (newActionClicked)=\"onAddNewAction($event)\"\r\n        (extractReport)=\"extractReport($event)\"\r\n        (viewModeChanged)=\"onViewModeChangedReceived($event)\"\r\n        (buttonClicked)=\"buttonClicked.emit($event)\"\r\n        [totalElements]=\"pageInfo.hideTitle ? undefined : totalElements\">\r\n      </app-title-bar>\r\n    </div>\r\n  </div>\r\n\r\n  <div class=\"filter-row\" *ngIf=\"!pageInfo.hideAdvancedFilter\">\r\n    <app-filter-builder\r\n      *ngIf=\"!pageInfo.hideAdvancedFilter\"\r\n      [pageInfo]=\"pageInfo\"\r\n      [columns]=\"columns\"\r\n      [filterFields]=\"filterFields\"\r\n      [pendingFilters]=\"pendingFilters\"\r\n      [showExportButton]=\"!pageInfo.hideExtractButton\"\r\n      (filterInformation)=\"storePendingFilters($event)\"\r\n      (isEmpty)=\"handleFilterEmpty($event)\"\r\n      (applyFilter)=\"applyPendingFilters()\"\r\n      (sortByClicked)=\"handleSortClick($event)\"\r\n      (exportClicked)=\"extractReport($event)\">\r\n    </app-filter-builder>\r\n\r\n    <div class=\"button-group\" *ngIf=\"!pageInfo.hideExtractButton\">\r\n      <button *ngIf=\"!pageInfo.hideExtractButton\"\r\n        mat-flat-button\r\n        [matMenuTriggerFor]=\"exportMenu\"\r\n        class=\"btn-export\"\r\n      >\r\n        <div class=\"button-text\">\r\n          <mat-icon>file_export</mat-icon>\r\n          <span>{{ 'export' | translate }}</span>\r\n          <mat-icon class=\"arrow-icon\">keyboard_arrow_down</mat-icon>\r\n        </div>\r\n      </button>\r\n\r\n      <mat-menu #exportMenu=\"matMenu\">\r\n        <button mat-menu-item (click)=\"extractReport('pdf')\">PDF</button>\r\n        <button mat-menu-item (click)=\"extractReport('xlsx')\">Excel</button>\r\n        <button mat-menu-item (click)=\"extractReport('csv')\">CSV</button>\r\n      </mat-menu>\r\n\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <div class=\"flex-row flex-100 baseTable__detailsColumn\">\r\n    <div class=\"flex-100\">\r\n      <div class=\"flex-row flex-100 mainTable\">\r\n        <div class=\"table-container\">\r\n          <div class=\"table-header\" [attr.data-sort]=\"sortState\">\r\n            <div *ngFor=\"let columnProp of visibleColumnsArray; let i = index\"\r\n                 class=\"table-header-cell\"\r\n                 [class.sortable]=\"getColumn(columnProp)?.enableSorting\"\r\n                 [class.first-cell]=\"i === 0\"\r\n                 [class.last-cell]=\"i === visibleColumnsArray.length - 1\"\r\n                 [class.actions-cell]=\"i === visibleColumnsArray.length - 1 && columnProp === 'actions'\"\r\n                 [class.has-width]=\"getColumn(columnProp)?.width\"\r\n                 [ngStyle]=\"getColumn(columnProp)?.width ? {'width': getColumn(columnProp)?.width + '%', 'flex-basis': getColumn(columnProp)?.width + '%'} : {}\"\r\n                 (click)=\"getColumn(columnProp)?.enableSorting && handleSortClick(columnProp)\">\r\n              <div class=\"table-header-content\">\r\n                <span class=\"table-header-label\">{{ labelKey(getColumn(columnProp)) | translate }}</span>\r\n                <ng-container *ngIf=\"getColumn(columnProp)?.enableSorting\">\r\n                  <mat-icon *ngIf=\"getSortDirection(columnProp) === 'asc'\"\r\n                           class=\"sort-icon sort-asc\">arrow_drop_up</mat-icon>\r\n                  <mat-icon *ngIf=\"getSortDirection(columnProp) === 'desc'\"\r\n                           class=\"sort-icon sort-desc\">arrow_drop_down</mat-icon>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"table-body\">\r\n            <div *ngFor=\"let row of dataSource.data; let rowIndex = index\"\r\n                 class=\"table-row\"\r\n                 [attr.id]=\"'table-row-' + (row?.id || row?.key || '')\"\r\n                 [ngClass]=\"{\r\n                   'table-row--highlight': selectedRowIndex == row.id || (pageInfo.groupByProperty && pageInfo.groupByValue?.includes(row[pageInfo.groupByProperty])),\r\n                   'table-row--dark-highlight': isDarkHighlight(row)\r\n                 }\"\r\n                 (auxclick)=\"openNewTab(row)\"\r\n                 (click)=\"$event.stopPropagation(); onSelectItem(row)\">\r\n              <div *ngFor=\"let columnProp of visibleColumnsArray; let i = index\"\r\n                   class=\"table-cell\"\r\n                   [class.first-cell]=\"i === 0\"\r\n                   [class.last-cell]=\"i === visibleColumnsArray.length - 1\"\r\n                   [class.actions-cell]=\"i === visibleColumnsArray.length - 1 && columnProp === 'actions'\"\r\n                   [class.has-width]=\"getColumn(columnProp)?.width\"\r\n                   [ngStyle]=\"getColumn(columnProp)?.width ? {'width': getColumn(columnProp)?.width + '%', 'flex-basis': getColumn(columnProp)?.width + '%'} : {}\">\r\n                <ng-container [ngSwitch]=\"getColumn(columnProp)?.type\">\r\n                  <ng-container *ngSwitchCase=\"'workflowStatus'\">\r\n                    <button mat-button class=\"wfStatus {{ getStatusDescription(row)}}\" [attr.id]=\"'table-btn-wf-'+columnProp+'-'+(row.id || row.key || '')\">{{ getStatusDescription(row) }}</button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'hyper-text'\">\r\n                    <mat-label (click)=\"hyperLinkClicked(columnProp, row)\" [ngClass]=\"{'hyper-link': shouldRenderAsHyperLink(row)}\">\r\n                      {{ extractFieldName(row, columnProp) }}\r\n                    </mat-label>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'button'\">\r\n                    <button *ngIf=\"shouldShowButton(row)\" mat-button class=\"primary\" (click)=\"$event.stopPropagation(); actionButtonClicked(columnProp, row)\" [attr.id]=\"'table-btn-action-'+columnProp\">\r\n                      {{ labelKey(getColumn(columnProp)) + '_title' | translate }}\r\n                    </button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'icon'\">\r\n                    <mat-icon [ngClass]=\"{\r\n                      'mainTable__td__icon-green': row[columnProp] === 'pass',\r\n                      'mainTable__td__icon-orange': row[columnProp] === 'warning',\r\n                      'mainTable__td__icon-red': row[columnProp] === 'error'\r\n                    }\">\r\n                      {{ getIcon(row[columnProp]) }}\r\n                    </mat-icon>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'checkbox'\">\r\n                    <mat-checkbox class=\"primary\" [checked]=\"row[columnProp]\" (click)=\"$event.stopPropagation();actionCheckedClicked(columnProp,row)\"></mat-checkbox>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'stateType'\">\r\n                    <button mat-button class=\"stateType {{ row[columnProp]}}\" [attr.id]=\"'table-btn-state-'+columnProp\">{{ labelKeyByValue(getColumn(columnProp), row) | translate}}</button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'date'\">\r\n                    {{ extractFieldName(row, columnProp) | date:'dd/MM/yyyy' }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'croppedText'\">\r\n                    {{ getCroppedText(row[columnProp], row[getColumn(columnProp)?.width]) }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'download'\">\r\n                    <mat-icon class=\"mainTable__td__icon-blue\">system_update_alt</mat-icon>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'onOff'\">\r\n                    <mat-icon *ngIf=\"row[columnProp] === null\" class=\"mainTable__td__icon-darkorange\">flag</mat-icon>\r\n                    <mat-icon *ngIf=\"row[columnProp] === false\" class=\"mainTable__td__icon-red\">flag</mat-icon>\r\n                    <mat-icon *ngIf=\"row[columnProp] === true\" class=\"mainTable__td__icon-green\">flag</mat-icon>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'status'\">\r\n                    <span *ngIf=\"row[columnProp] === null || row[columnProp] === false\">\r\n                      {{ pageInfo.labelsSection + '.' + getColumn(columnProp)?.label + 'InActive' | translate }}\r\n                    </span>\r\n                    <span *ngIf=\"row[columnProp] === true\">\r\n                      {{ pageInfo.labelsSection + '.' + getColumn(columnProp)?.label + 'Active' | translate }}\r\n                    </span>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'info'\">\r\n                    <button mat-icon-button (click)=\"$event.stopPropagation();emitEvent(row)\" [attr.id]=\"'table-btn-info-'+row.id\">\r\n                      <mat-icon>info</mat-icon>\r\n                    </button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'netAmount'\">\r\n                    <div class=\"mainTable__td__currency\" style=\"display:inline-block;\">{{ row[getColumn(columnProp)?.currency] }}</div>\r\n                    <span class=\"mainTable__td__property\" style=\"display:inline-block; margin-left:6px; margin-right:6px;\">\r\n                      {{ extractFieldName(row, columnProp) | currency:'':'' }}</span>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'localDateTime'\">\r\n                    {{ extractFieldName(row, columnProp) | date : extractFormat(getColumn(columnProp)) }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'bigdecimal'\">\r\n                    <small><sup class=\"mainTable__td__currency\">{{row[getColumn(columnProp)?.currency]}}</sup></small>\r\n                    {{ extractFieldName(row, columnProp) | number : (getColumn(columnProp)?.digitInfo || '1.3-5') }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'listAction'\">\r\n                    <app-button-actions\r\n                      [buttonsAction]=\"getColumn(columnProp)?.viewType === 'buttonsAction'\"\r\n                      [listAction]=\"listAction\"\r\n                      [actions]=\"listAction\"\r\n                      (clickedButton)=\"actionListClicked($event,row)\">\r\n                    </app-button-actions>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchDefault>\r\n                    <ng-container *ngIf=\"getColumn(columnProp)?.translate; else noTranslate\">\r\n                      <span (click)=\"emitRoutePage(row)\">\r\n                        {{ pageInfo.labelsSection + \".\" + extractFieldName(row, columnProp) | translate }}\r\n                      </span>\r\n                    </ng-container>\r\n                    <ng-template #noTranslate>\r\n                      <span (click)=\"emitRoutePage(row)\" [innerHtml]='extractFieldName(row, columnProp)'></span>\r\n                    </ng-template>\r\n                  </ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- Mobile Card View -->\r\n      <div class=\"mobile-cards-container\">\r\n        <div *ngFor=\"let row of dataSource.data; let rowIndex = index\"\r\n             class=\"mobile-card\"\r\n             [attr.id]=\"'mobile-card-' + (row?.id || row?.key || '')\"\r\n             [ngClass]=\"{\r\n               'mobile-card--highlight': selectedRowIndex == row.id || (pageInfo.groupByProperty && pageInfo.groupByValue?.includes(row[pageInfo.groupByProperty])),\r\n               'mobile-card--dark-highlight': isDarkHighlight(row)\r\n             }\"\r\n             (auxclick)=\"openNewTab(row)\"\r\n             (click)=\"$event.stopPropagation(); onSelectItem(row)\">\r\n          \r\n          <!-- Mobile Card Header: ID/Name and Status -->\r\n          <div class=\"mobile-card__header\">\r\n            <div class=\"mobile-card__header-id\">\r\n              <span class=\"mobile-card__id-text\">{{ extractFieldName(row, getMobileCardIdColumn()?.property || 'id') }}</span>\r\n            </div>\r\n            <div class=\"mobile-card__header-status\" *ngIf=\"getMobileCardStatusColumn()\">\r\n              <button mat-button class=\"stateType {{ row[getMobileCardStatusColumn()?.property]}}\" \r\n                      [attr.id]=\"'mobile-btn-state-'+getMobileCardStatusColumn()?.property\">\r\n                {{ labelKeyByValue(getMobileCardStatusColumn(), row) | translate}}\r\n              </button>\r\n            </div>\r\n          </div>\r\n\r\n          <!-- Divider -->\r\n          <div class=\"mobile-card__divider\"></div>\r\n\r\n          <!-- Mobile Card Body: Other columns -->\r\n          <div class=\"mobile-card__body\">\r\n            <div *ngFor=\"let column of getMobileCardColumns()\" class=\"mobile-card__row\">\r\n              <div class=\"mobile-card__row-label\">\r\n                <span>{{ labelKey(column) | translate }} :</span>\r\n              </div>\r\n              <div class=\"mobile-card__row-value\">\r\n                <ng-container [ngSwitch]=\"column.type\">\r\n                  <ng-container *ngSwitchCase=\"'stateType'\">\r\n                    <button mat-button class=\"stateType {{ row[column.property]}}\" \r\n                            [attr.id]=\"'mobile-btn-state-'+column.property\">\r\n                      {{ labelKeyByValue(column, row) | translate}}\r\n                    </button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'date'\">\r\n                    {{ extractFieldName(row, column.property) | date:'dd/MM/yyyy' }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'netAmount'\">\r\n                    <span class=\"mobile-card__amount-currency\">{{ row[column.currency] }}</span>\r\n                    <span class=\"mobile-card__amount-value\">{{ extractFieldName(row, column.property) | currency:'':'' }}</span>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'localDateTime'\">\r\n                    {{ extractFieldName(row, column.property) | date : extractFormat(column) }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'bigdecimal'\">\r\n                    <small><sup class=\"mainTable__td__currency\">{{row[column.currency]}}</sup></small>\r\n                    {{ extractFieldName(row, column.property) | number : (column.digitInfo || '1.3-5') }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchDefault>\r\n                    <ng-container *ngIf=\"column.translate; else noTranslate\">\r\n                      <span>{{ pageInfo.labelsSection + \".\" + extractFieldName(row, column.property) | translate }}</span>\r\n                    </ng-container>\r\n                    <ng-template #noTranslate>\r\n                      <span [innerHtml]='extractFieldName(row, column.property)'></span>\r\n                    </ng-template>\r\n                  </ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <!-- Mobile Card Actions -->\r\n          <div class=\"mobile-card__actions\" *ngIf=\"listAction && listAction.length > 0\">\r\n            <app-button-actions\r\n              [buttonsAction]=\"true\"\r\n              [listAction]=\"listAction\"\r\n              [actions]=\"listAction\"\r\n              (clickedButton)=\"actionListClicked($event,row)\">\r\n            </app-button-actions>\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n      <div *ngIf=\"noDataFound\" class=\"dataNotFound flex-column\">\r\n        <img *ngIf=\"getDisplaySvgPath()\" [src]=\"getDisplaySvgPath()\" class=\"dataNotFound__icon\" alt=\"No data found\" />\r\n        <span class=\"dataNotFound__title\">{{ getDisplayTitle() | translate}}</span>\r\n        <span class=\"dataNotFound__subtitle\">{{ getDisplaySubtitle() | translate}}</span>\r\n      </div>\r\n\r\n\r\n      <div  *ngIf=\"(dataSource.data?.length > 0 || customizedData) && !pageInfo.hidePagination\" class=\"main-pagination flex-row\">\r\n        <ng-container *ngIf=\"enablePagination\">\r\n          <div class=\"flex-column flex-100\">\r\n            <app-paginator\r\n              [currentPage]=\"pageIndex\"\r\n              [totalItems]=\"totalElements\"\r\n              [pageSize]=\"pageSize\"\r\n              [pageSizeOptions]=\"[5, 10, 25, 50]\"\r\n              [mobileLoadMoreIncrement]=\"mobileLoadMoreIncrement\"\r\n              [displayedItems]=\"mobileDisplayedItems || dataSource.data.length\"\r\n              (pageChange)=\"onPageChange($event)\"\r\n              (pageSizeChange)=\"onPageSizeChange($event)\"\r\n              (loadMore)=\"onLoadMore($event)\">\r\n            </app-paginator>\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
632
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/base-table/base-table.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/base-table/base-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  effect,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges\r\n} from \"@angular/core\";\r\nimport {MatTableDataSource} from \"@angular/material/table\";\r\nimport {TranslateModule, TranslateService} from \"@ngx-translate/core\";\r\nimport {MatSortModule, Sort} from \"@angular/material/sort\";\r\nimport {\r\n  CurrencyPipe,\r\n  DatePipe,\r\n  DecimalPipe,\r\n  NgClass,\r\n  NgForOf,\r\n  NgIf,\r\n  NgStyle,\r\n  NgSwitch,\r\n  NgSwitchCase,\r\n  NgSwitchDefault\r\n} from \"@angular/common\";\r\nimport {MatIcon} from \"@angular/material/icon\";\r\nimport {MatButton, MatButtonModule, MatIconButton} from \"@angular/material/button\";\r\nimport {NgxPaginationModule} from \"ngx-pagination\";\r\nimport {ButtonActionsComponent} from \"../button-actions/button-actions.component\";\r\nimport {ShareDataService} from \"../../services/trigger-form.service\";\r\nimport {BaseUtils} from \"../../utils/base-utils\";\r\nimport {BackendService} from \"../../services/backend-service\";\r\nimport {Filter} from \"../../base-model/filter.model\";\r\nimport {FilterRequest} from \"../../base-model/filter-request\";\r\nimport {\r\n  ButtonActionSettings,\r\n  EMPTY_PAGE_INFO,\r\n  FieldInfo,\r\n  FRONT_END_COLUMN_TYPES,\r\n  PageInfo,\r\n  TABLE_RECORD_ACTION,\r\n  TableColumn\r\n} from \"../../base-model\";\r\nimport {ReportRequest} from \"../../base-model/report-request.model\";\r\nimport {TablePageUserAction} from \"../../base-model/table-page-user-action.interface\";\r\nimport {Workflow} from \"../../base-model/workflow/workflow.model\";\r\nimport {ResponseEnvelop} from \"../../base-model/response-envelop.model\";\r\nimport {Router} from \"@angular/router\";\r\nimport {MatLabel} from \"@angular/material/form-field\";\r\nimport {TitleBarComponent} from \"../title-bar/title-bar.component\";\r\nimport {PaginatorComponent} from \"../paginator/paginator.component\";\r\nimport {MatCheckbox} from \"@angular/material/checkbox\";\r\nimport {FilterBuilderComponent} from \"../advanced-filter/filter-builder/filter-builder.component\";\r\nimport {FieldFilter} from \"../../base-model/field-filter.model\";\r\nimport {MatMenu, MatMenuItem, MatMenuTrigger} from \"@angular/material/menu\";\r\n\r\n@Component({\r\n  selector: 'app-base-table',\r\n  standalone: true,\r\n  templateUrl: './base-table.component.html',\r\n  styleUrls: ['./base-table.component.scss'],\r\n  animations: [],\r\n  imports: [\r\n    NgStyle,\r\n    NgClass,\r\n    TranslateModule,\r\n    MatIcon,\r\n    MatSortModule,\r\n    NgIf,\r\n    NgSwitch,\r\n    MatButtonModule,\r\n    DatePipe,\r\n    CurrencyPipe,\r\n    NgxPaginationModule,\r\n    NgSwitchCase,\r\n    NgSwitchDefault,\r\n    MatIconButton,\r\n    NgForOf,\r\n    MatButton,\r\n    ButtonActionsComponent,\r\n    MatLabel,\r\n    TitleBarComponent,\r\n    PaginatorComponent,\r\n    DecimalPipe,\r\n    MatCheckbox,\r\n    FilterBuilderComponent,\r\n    MatMenuTrigger,\r\n    MatMenu,\r\n    MatMenuItem,\r\n\r\n  ]\r\n})\r\nexport class BaseTableComponent extends BaseUtils implements OnInit, OnChanges, OnDestroy {\r\n  types: string[] = [\"pdf\", \"csv\", \"xlsx\"]\r\n  collection = {count: 60, data: []};\r\n  config = {\r\n    itemsPerPage: 15,\r\n    currentPage: 1,\r\n    totalItems: this.collection.count\r\n  };\r\n  public maxSize: number = 7;\r\n  public directionLinks: boolean = true;\r\n  public autoHide: boolean = false;\r\n  public responsive: boolean = true;\r\n  public labels: any = {\r\n    previousLabel: '<',\r\n    nextLabel: '>',\r\n    screenReaderPaginationLabel: 'Pagination',\r\n    screenReaderPageLabel: 'page',\r\n    screenReaderCurrentLabel: `You're on page`\r\n  };\r\n\r\n  @Input()\r\n  filterFields: FieldInfo[];\r\n  @Input() noDataFoundSvgPath: string;\r\n  @Input() noDataFoundTitle = 'noDataFoundTitle';\r\n  @Input() noDataFoundSubtitle = 'noDataFoundSubtitle';\r\n  @Input() noResultSvgPath: string;\r\n  @Input() noResultTitle = 'noResultTitle';\r\n  @Input() noResultSubtitle = 'noResultSubtitle';\r\n  totalElements = 0;\r\n  pagesCount = 0;\r\n  pageIndex = 1;\r\n  pageSize = 15;\r\n  mobileDisplayedItems = 0;\r\n  private selectedStatusFilter: Filter[] = [];\r\n  advancedAppliedFilter: any[] = [];\r\n  pendingFilters: any[] = [];\r\n  searchStr: string = '';\r\n  private filterRequest: FilterRequest = new FilterRequest();\r\n  private timer: any;\r\n  @Input()\r\n  override pageInfo: PageInfo = EMPTY_PAGE_INFO;\r\n\r\n  @Input()\r\n  enablePagination: boolean = true;\r\n\r\n  @Input()\r\n  mobilePageSize: number = 2;\r\n\r\n  @Input()\r\n  mobileLoadMoreIncrement: number = 2;\r\n\r\n  @Input() data?: MatTableDataSource<any>;\r\n  @Input()\r\n  listAction: ButtonActionSettings[] = [];\r\n\r\n  @Input()\r\n  extraActions: ButtonActionSettings[] = [];\r\n\r\n  @Input()\r\n  buttonsDisplayMode: 'dropdown' | 'list' = 'dropdown';\r\n\r\n  @Input()\r\n  columns: TableColumn<any>[];\r\n\r\n  @Input()\r\n  filters: Filter[] = [];\r\n\r\n  @Input() //@ts-ignore\r\n  pathParam: number;\r\n\r\n  @Input()\r\n  extraButton:  ButtonActionSettings[] = [];\r\n\r\n  @Output() buttonClicked = new EventEmitter<ButtonActionSettings>();\r\n\r\n  @Input() //@ts-ignore\r\n  enforceRefresh: boolean = false;\r\n\r\n  @Input()\r\n  isPending: boolean = false;\r\n\r\n  @Input()\r\n  trigger: boolean = false;\r\n\r\n  @Input()\r\n  reportRequest: ReportRequest = new ReportRequest({});\r\n\r\n  @Input()\r\n  separateEndpointData: any;\r\n  @Input()\r\n  manageablePages: boolean = false;\r\n  @Input()\r\n  totalPagesCount: number = 0;\r\n  @Input()\r\n  currentPageIndex: number = 0;\r\n\r\n  @Output()\r\n  pageChange: EventEmitter<any> = new EventEmitter();\r\n\r\n\r\n  @Output()\r\n  userAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n  @Output()\r\n  hyperLinkAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n\r\n  @Output()\r\n  extraAction: EventEmitter<TablePageUserAction> = new EventEmitter<TablePageUserAction>();\r\n\r\n  @Output()\r\n  selectedColumn: EventEmitter<Sort> = new EventEmitter<Sort>();\r\n\r\n  @Output()\r\n  listActionClicked: EventEmitter<{ action: ButtonActionSettings, row: any , isPending: boolean}> = new EventEmitter<{\r\n    action: ButtonActionSettings,\r\n    row: any,\r\n    isPending: boolean\r\n  }>();\r\n\r\n  @Output()\r\n  showDialog: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  usedWorkflow!: Workflow;\r\n\r\n  mode:any;\r\n\r\n  @Input()\r\n  customizedData?: MatTableDataSource<any>;\r\n  dataSource: MatTableDataSource<any>;\r\n  selectedRowIndex = -1;\r\n  noDataFound = false;\r\n  totalRequiredCountItem = 0;\r\n\r\n\r\n  @Output()\r\n  clickRoutePage: EventEmitter<any> = new EventEmitter<any>();\r\n  private applyingFilters: boolean;\r\n\r\n  constructor(\r\n      private backendService: BackendService,\r\n      public translateService: TranslateService,\r\n      public shareDataService: ShareDataService,\r\n      @Inject('securityManager') private securityManager: any,\r\n      private router: Router,\r\n  ) {\r\n    super();\r\n    this.dataSource = new MatTableDataSource();\r\n    this.columns = [];\r\n    this.filterRequest = new FilterRequest();\r\n\r\n    this.initializeMobilePageSize();\r\n\r\n    effect(() => {\r\n      if (this.applyingFilters) return;\r\n\r\n      if (this.pageInfo.lazyLoadData !== true || this.enforceRefresh === true) {\r\n        this.loadData();\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.backendService.isEmptyItems = this.dataSource.data.length <= 0;\r\n    if (this.customizedData) {\r\n      this.dataSource = this.customizedData;\r\n    }\r\n    if(this.manageablePages) {\r\n      this.pagesCount = this.totalPagesCount;\r\n      this.pageIndex = this.currentPageIndex;\r\n    }\r\n\r\n    this.initializeMobilePageSize();\r\n    this.mobileDisplayedItems = this.pageSize;\r\n  }\r\n\r\n  private isMobile(): boolean {\r\n    return typeof window !== 'undefined' && window.innerWidth <= 768;\r\n  }\r\n\r\n  private initializeMobilePageSize(): void {\r\n    if (this.isMobile() && this.pageSize > this.mobilePageSize) {\r\n      this.pageSize = this.mobilePageSize;\r\n      if (this.reportRequest?.filterRequest) {\r\n        this.reportRequest.filterRequest.pageSize = this.mobilePageSize;\r\n      }\r\n    }\r\n  }\r\n\r\n  onPageChange(event: number) {\r\n    this.pageIndex = event;\r\n    this.getNext(this.pageIndex - 1);\r\n    if (this.manageablePages) {\r\n      this.pageChange.emit(this.pageIndex);\r\n    }\r\n  }\r\n\r\n\r\n  extractFieldName(element: any, property: string) {\r\n    if (property?.includes('.')) {\r\n      return property.split('.').reduce((acc, part) => acc && acc[part], element);\r\n    } else {\r\n      const c = this.columns.find(c => c.property === property);\r\n      if (Array.isArray(element[property]) && c.arraySubProperty ) {\r\n        const fieldValues = element[property].map(f => f[c.arraySubProperty]);\r\n        return  fieldValues.join(', ');\r\n      }else {\r\n        return element[property];\r\n      }\r\n    }\r\n  }\r\n\r\n  get visibleColumns() {\r\n    this.buildGroups()\r\n    return this.columns.filter(column => column.visible).map(column => column.property);\r\n  }\r\n\r\n  get visibleColumnsArray() {\r\n    return this.visibleColumns;\r\n  }\r\n\r\n  getColumn(property: string): TableColumn<any> | undefined {\r\n    return this.columns.find(c => c.property === property);\r\n  }\r\n\r\n  getSortDirection(property: string): 'asc' | 'desc' | '' {\r\n    if (this.reportRequest?.filterRequest?.sortKey === property) {\r\n      return this.reportRequest.filterRequest.sortDirection === 'ASC' ? 'asc' : 'desc';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  handleSortClick(property: string): void {\r\n    const COLUMN = this.getColumn(property);\r\n    if (!COLUMN || !COLUMN.enableSorting) {\r\n      return;\r\n    }\r\n\r\n    const CURRENT_DIRECTION = this.getSortDirection(property);\r\n    let NEW_DIRECTION: 'asc' | 'desc' = 'asc';\r\n\r\n    if (CURRENT_DIRECTION === 'asc') {\r\n      NEW_DIRECTION = 'desc';\r\n    }\r\n\r\n    this.onSortAction({\r\n      active: property,\r\n      direction: NEW_DIRECTION\r\n    });\r\n  }\r\n\r\n  sortState: any = {};\r\n\r\n  getNext(pageIndex: number) {\r\n    this.reportRequest.filterRequest.pageIndex = pageIndex;\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    this.loadData();\r\n  }\r\n  onPageSizeChange(event: number) {\r\n    this.pageSize = event;\r\n    this.pageIndex = 1; // reset to first page on page size change\r\n    this.mobileDisplayedItems = 0;\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    this.getNext(0);\r\n  }\r\n\r\n  onLoadMore(itemsToLoad: number) {\r\n    const currentDisplayed = this.mobileDisplayedItems || this.dataSource.data.length || this.pageSize;\r\n    this.pageSize = Math.min(currentDisplayed + itemsToLoad, this.totalElements);\r\n    this.mobileDisplayedItems = this.pageSize;\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    this.reportRequest.filterRequest.pageIndex = 0;\r\n    this.pageIndex = 1;\r\n    this.loadData(true);\r\n  }\r\n\r\n  private loadData(skipMobileReset: boolean = false) {\r\n    clearTimeout(this.timer);\r\n\r\n    if (!skipMobileReset) {\r\n      this.initializeMobilePageSize();\r\n    }\r\n\r\n    if (!this.reportRequest.filterRequest) {\r\n      this.reportRequest.filterRequest = new FilterRequest(this.pageSize || this.pageInfo.pageSize);\r\n      this.reportRequest.filterRequest.searchStr = this.searchStr;\r\n      this.reportRequest.filterRequest.filters = [\r\n        ...(this.advancedAppliedFilter || []),\r\n        ...(this.filters || []).filter(f =>\r\n          !(this.advancedAppliedFilter || []).some(a => a.field === f.fieldName)\r\n        )\r\n      ];\r\n    }\r\n\r\n    this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n    if (this.separateEndpointData || !this.pageInfo.apiUri || this.pageInfo.apiUri.length === 0) {\r\n      this.dataSource.data = this.separateEndpointData;\r\n    } else if(this.reportRequest == undefined){\r\n      return;\r\n    } else if(!this.manageablePages)  {\r\n      this.timer = setTimeout(() => {\r\n          this.reportRequest.filterRequest.pageSize = this.pageSize;\r\n          this.reportRequest.filterRequest.columns = this.columns?.filter(c => FRONT_END_COLUMN_TYPES.indexOf(c.type) < 0 ).map(c => c.property) || [];\r\n          this.reportRequest.filterRequest.pendingPage = this.isPending;\r\n          this.reportRequest.filterRequest.searchStr = this.searchStr;\r\n          this.reportRequest.filterRequest.filters = [\r\n            ...(this.advancedAppliedFilter || []),\r\n            ...(this.filters || []).filter(f =>\r\n              !(this.advancedAppliedFilter || []).some(a => a.field === f.fieldName)\r\n            )\r\n          ];\r\n            this.backendService.getItemsByFilter(this.reportRequest?.filterRequest, this.pageInfo.apiUri).subscribe(resp => {\r\n              const responseEnvelope = new ResponseEnvelop(resp);\r\n              if (responseEnvelope.valid) {\r\n                this.totalRequiredCountItem = this.reportRequest.filterRequest.pageSize\r\n                this.noDataFound = responseEnvelope.body.length < 1;\r\n                this.dataSource.data = responseEnvelope.body;\r\n                this.backendService.isEmptyItems = this.dataSource.data.length <= 0;\r\n                this.totalElements = responseEnvelope.totalSize || 0;\r\n                this.pagesCount = Math.ceil(this.totalElements / this.pageSize) || 1;\r\n                this.pageIndex = (this.reportRequest.filterRequest.pageIndex || 0) + 1;\r\n                this.config.totalItems = responseEnvelope.totalSize || 0;\r\n                this.config.currentPage = this.pageIndex + 1;\r\n                this.mobileDisplayedItems = this.dataSource.data.length;\r\n              }\r\n            });\r\n          }\r\n          , 300);\r\n    }\r\n  }\r\n\r\n  getStatusDescription(element: any) {\r\n    return this.backendService.getStatusDescription(element, this.usedWorkflow);\r\n  }\r\n\r\n  getStateType(element: any) {\r\n    return element.stateType\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes[\"customizedData\"] && !changes[\"customizedData\"].isFirstChange()) {\r\n      this.dataSource.data = changes[\"customizedData\"].currentValue?.data || [];  // Update data source with new data\r\n      this.pagesCount=this.totalPagesCount;\r\n      this.pageIndex=this.currentPageIndex;\r\n    }\r\n    if (changes[\"enforceRefresh\"] && !changes[\"enforceRefresh\"].isFirstChange()) {\r\n      this.loadData();\r\n    }\r\n    if (changes[\"isPending\"] && !changes[\"isPending\"].isFirstChange()) {\r\n      this.loadData();\r\n    }\r\n  }\r\n  getCroppedText(elementValue: any, subWidth: number = 20) {\r\n    return elementValue && elementValue.length > subWidth ? elementValue.substring(0, subWidth) + \"...\" : elementValue;\r\n  }\r\n\r\n  emitEvent(element: any) {\r\n    this.showDialog.emit(element);\r\n  }\r\n\r\n  extractFormat(column: TableColumn<any>) {\r\n    return column?.format || 'd/M/yyyy, h:mm a';\r\n  }\r\n\r\n  actionListClicked(listAction: ButtonActionSettings, element: any) {\r\n    this.listActionClicked.emit({action:listAction, row: element, isPending: this.isPending});\r\n  }\r\n\r\n  hyperLinkClicked(actionName: string, element: any) {\r\n    const action = TABLE_RECORD_ACTION;\r\n    action.actionKey = actionName;\r\n    action.item = element;\r\n    action.pageInfo = this.pageInfo;\r\n    this.hyperLinkAction.emit(action)\r\n  }\r\n\r\n\r\n  emitRoutePage(element: any){\r\n    this.clickRoutePage.emit(element);\r\n  }\r\n\r\n  onSelectItem(row: any) {\r\n    if (this.pageInfo.selfRouting) {\r\n      const mode = this.isPending ? 'pending' : 'view';\r\n      const url = `${this.pageInfo.listRoutePath || this.router.url}/view`;\r\n\r\n      const encryptedId = this.backendService.encrypt(String(row.id));\r\n      const encryptedMode = this.backendService.encrypt(mode);\r\n\r\n      const encryptedRow = this.backendService.encrypt(JSON.stringify(row));\r\n\r\n      this.router.navigate([url], {\r\n        queryParams: { token: encryptedId, mode: encryptedMode },\r\n        state: { raw: encryptedRow },\r\n      });\r\n      return;\r\n    }\r\n    // const action = SELECT_RECORD_ACTION;\r\n    // action.id = row?.id;\r\n    // action.item = row;\r\n    // this.userAction.emit(action)\r\n  }\r\n\r\n  openNewTab(row) {\r\n    if (!this.pageInfo.embededTableOnly) {\r\n      const mode = this.isPending ? 'pending' : 'view';\r\n      window.open(`${this.pageInfo.listRoutePath}/${mode}` + '/' + row?.id);\r\n    }\r\n  }\r\n\r\n  onViewModeChangedReceived(isPending: boolean) {\r\n    this.switchViewMode(isPending);\r\n  }\r\n\r\n  switchViewMode(isPending: boolean) {\r\n    this.isPending = isPending;\r\n    this.loadData();\r\n  }\r\n\r\n  onAddNewAction($event: any) {\r\n    const url = `${this.pageInfo.listRoutePath || this.router.url}/view`;\r\n    const encryptedId = this.backendService.encrypt(\"-1\");\r\n    const encryptedMode = this.backendService.encrypt(\"pending\");\r\n    this.router.navigate([`${url}`],\r\n      { queryParams: { token: encryptedId , mode : encryptedMode } });\r\n\r\n    // const action = SELECT_RECORD_ACTION;\r\n    // action.id = row?.id;\r\n    // action.item = row;\r\n    // this.userAction.emit(action)\r\n  }\r\n\r\n  showAddNew() {\r\n    return this.pageInfo.hasAddButton ;\r\n  }\r\n\r\n  onExtraButtionAction($event: any) {\r\n    this.extraAction.emit($event);\r\n\r\n  }\r\n\r\n  hasGroups() {\r\n    let b = this.columns.findIndex(p => p.group);\r\n    return b >= 0;\r\n  }\r\n  groupNames: any = []\r\n  groupSpans: Map<string, number> = new Map();\r\n\r\n  buildGroups(){\r\n    let count = 0;\r\n    this.groupNames = [];\r\n    this.groupSpans.clear();\r\n    if(this.hasGroups() === false){\r\n      return;\r\n    }\r\n    this.columns\r\n      .filter(column => column.visible === true)\r\n      .forEach((column) => {\r\n        if (column.group === \"-\") {\r\n          this.groupNames.push(count.toString());\r\n          this.insertInMap(count);\r\n          count++;\r\n          return;\r\n        } else if (!this.groupNames.includes(column.group)) {\r\n          this.groupNames.push(column.group);\r\n          this.insertInMap(column.group);\r\n          return;\r\n        }\r\n        this.insertInMap(column.group);\r\n      });\r\n  }\r\n\r\n  insertInMap(key){\r\n    if(this.groupSpans.has(key)){\r\n      this.groupSpans.set(key.toString(), this.groupSpans.get(key) + 1);\r\n    } else {\r\n      this.groupSpans.set(key.toString(), 1);\r\n    }\r\n  }\r\n\r\n  isHumanMade(str){\r\n    return isNaN(str);\r\n  }\r\n\r\n  actionButtonClicked(actionKey: string, item: any): void {\r\n    if (actionKey === 'navigate') {\r\n      this.handleNavigateAction(item);\r\n      return;\r\n    }\r\n\r\n    this.emitTableAction(actionKey, item);\r\n  }\r\n\r\n  private handleNavigateAction(item: any): void {\r\n    const mode = this.isPending ? 'pending' : 'view';\r\n    const basePath = this.pageInfo.listRoutePath || this.router.url;\r\n    const url = `${basePath}/view`;\r\n\r\n    const encryptedId = this.backendService.encrypt(item.id.toString());\r\n    const encryptedMode = this.backendService.encrypt(mode);\r\n\r\n    this.router.navigate([url], {\r\n      queryParams: { token: encryptedId, mode: encryptedMode }\r\n    });\r\n  }\r\n\r\n  private emitTableAction(actionKey: string, item: any): void {\r\n    const action = TABLE_RECORD_ACTION;\r\n    action.actionKey = actionKey;\r\n    action.item = item;\r\n    action.pageInfo = this.pageInfo;\r\n    this.userAction.emit(action);\r\n  }\r\n\r\n  extractReport(reportType: any) {\r\n    const myFilters = this.reportRequest.filterRequest;\r\n    const reportRequest = this.backendService.buildReportRequest(this.columns, this.pageInfo.labelsSection + '.list_title',\r\n      myFilters, reportType, this.pageInfo, this.searchStr, 'LANDSCAPE');\r\n    this.backendService.downloadReport(reportRequest, this.pageInfo.apiUri);\r\n  }\r\n\r\n  getIcon(status: string): string {\r\n    switch (status) {\r\n      case 'pass': return 'check_circle';\r\n      case 'warning': return 'warning';\r\n      case 'error': return 'error';\r\n      default: return 'help';\r\n    }\r\n  }\r\n\r\n  actionCheckedClicked(property: string, element) {\r\n    element[property]= !element[property];\r\n    this.actionButtonClicked(property, element);\r\n  }\r\n\r\n\r\n  isDarkHighlight(row: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !row[groupByProp]) {\r\n      return false;\r\n    }\r\n\r\n    const cellValue = row[groupByProp].toString();\r\n\r\n    return groupByValues.some(val =>\r\n      cellValue.includes(val) && cellValue.length > val.length\r\n    );\r\n  }\r\n\r\n  shouldRenderAsHyperLink(element: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !element[groupByProp]) {\r\n      return false;\r\n    }\r\n\r\n    const value = element[groupByProp].toString();\r\n\r\n    return !groupByValues.some(v => value.includes(v) && value.length >= v.length);\r\n  }\r\n\r\n\r\n  onSortAction($event: Sort) {\r\n    this.reportRequest.filterRequest.sortKey = $event.active && $event.direction ?\r\n      this.columns.find(c => c.property === $event.active)?.orderByProperty || $event.active\r\n      : 'id';\r\n    this.reportRequest.filterRequest.sortDirection = $event.direction === 'asc' ? 'ASC' : 'DESC';\r\n    this.reportRequest.filterRequest.pageIndex = 0;\r\n      this.selectedColumn.emit($event);\r\n      this.loadData();\r\n  }\r\n\r\n  shouldShowButton(element: any): boolean {\r\n    const groupByProp = this.pageInfo?.groupByProperty;\r\n    const groupByValues = this.pageInfo?.groupByValue;\r\n\r\n    if (!groupByProp || !groupByValues || !element[groupByProp]) {\r\n      return true;\r\n    }\r\n\r\n    const value = element[groupByProp].toString();\r\n\r\n    return !groupByValues.some(v => value.includes(v) && value.length >= v.length);\r\n  }\r\n\r\n  storePendingFilters($event: { filters: FieldFilter[], searchStr: string }): void {\r\n    this.pendingFilters = $event.filters || [];\r\n      this.searchStr = $event.searchStr;\r\n  }\r\n\r\n  applyPendingFilters(): void {\r\n    this.applyingFilters = true;\r\n    this.advancedAppliedFilter = [...this.pendingFilters];\r\n    this.loadData();\r\n    this.applyingFilters = false;\r\n  }\r\n\r\n  handleFilterEmpty($event: boolean): void {\r\n    if ($event) {\r\n      this.pendingFilters = [];\r\n      this.advancedAppliedFilter = [];\r\n      this.loadData();\r\n    }\r\n  }\r\n\r\n  resetData($event: boolean) {\r\n    if ($event) {\r\n      this.advancedAppliedFilter = [];\r\n      this.pendingFilters = [];\r\n      this.loadData();\r\n      // this.paginator.firstPage();\r\n    }\r\n  }\r\n\r\n  hasFiltersApplied(): boolean {\r\n    return (this.advancedAppliedFilter && this.advancedAppliedFilter.length > 0) ||\r\n           (this.filters && this.filters.length > 0) ||\r\n           (this.pendingFilters && this.pendingFilters.length > 0);\r\n  }\r\n\r\n  getDisplaySvgPath(): string {\r\n    return this.hasFiltersApplied() && this.noResultSvgPath ? this.noResultSvgPath : this.noDataFoundSvgPath;\r\n  }\r\n\r\n  getDisplayTitle(): string {\r\n    return this.hasFiltersApplied() && this.noResultSvgPath ? this.noResultTitle : this.noDataFoundTitle;\r\n  }\r\n\r\n  getDisplaySubtitle(): string {\r\n    return this.hasFiltersApplied() && this.noResultSvgPath ? this.noResultSubtitle : this.noDataFoundSubtitle;\r\n  }\r\n\r\n  buttonClickedEvent($event: ButtonActionSettings) {\r\n\r\n  }\r\n\r\n  getMobileCardIdColumn(): TableColumn<any> | undefined {\r\n    return this.columns.find(c => c.visible && c.mobileCardId === true);\r\n  }\r\n\r\n  getMobileCardStatusColumn(): TableColumn<any> | undefined {\r\n    return this.columns.find(c => c.visible && c.mobileCardStatus === true);\r\n  }\r\n\r\n  getMobileCardColumns(): TableColumn<any>[] {\r\n    const idCol = this.getMobileCardIdColumn();\r\n    const statusCol = this.getMobileCardStatusColumn();\r\n\r\n    return this.columns.filter(c =>\r\n      c.visible &&\r\n      c.property !== 'actions' &&\r\n      c !== idCol &&\r\n      c !== statusCol\r\n    );\r\n  }\r\n\r\n  override labelKeyByValue(column: TableColumn<any> | undefined, row: any): string {\r\n    if (!column || !column.property) return '';\r\n    return super.labelKeyByValue(column, row);\r\n  }\r\n}\r\n","<div class=\"flex-column baseTable\">\r\n  <div class=\"flex-row flex-100\" >\r\n    <div class=\"flex-column align-start flex-100\" style=\"width: 100%;\">\r\n      <app-title-bar\r\n        [pageTitle]=\"pageInfo.hideTitle ? '' : pageInfo.labelsSection+'.list_title'\"\r\n        [subTitle]=\"(pageInfo.hideTitle || pageInfo.hideSubtitle) ? '' : pageInfo.labelsSection+'.subtitle'\"\r\n        [titleMode]=\"''\"\r\n        [pageInfo]=\"pageInfo\"\r\n        [newAction]=\"showAddNew()\"\r\n        [showExtractButton]=\"!pageInfo.hideExtractButton\"\r\n        [draftSupported]=\"pageInfo.draftSupported\"\r\n        [isPending]=\"isPending\"\r\n        [onViewModeChange]=\"switchViewMode.bind(this)\"\r\n        [buttons]=\"extraActions\"\r\n        [buttonsDisplayMode]=\"buttonsDisplayMode\"\r\n        (newActionClicked)=\"onAddNewAction($event)\"\r\n        (extractReport)=\"extractReport($event)\"\r\n        (viewModeChanged)=\"onViewModeChangedReceived($event)\"\r\n        (buttonClicked)=\"buttonClicked.emit($event)\"\r\n        [totalElements]=\"pageInfo.hideTitle ? undefined : totalElements\">\r\n      </app-title-bar>\r\n    </div>\r\n  </div>\r\n\r\n  <div class=\"filter-row\" *ngIf=\"!pageInfo.hideAdvancedFilter\">\r\n    <app-filter-builder\r\n      *ngIf=\"!pageInfo.hideAdvancedFilter\"\r\n      [pageInfo]=\"pageInfo\"\r\n      [columns]=\"columns\"\r\n      [filterFields]=\"filterFields\"\r\n      [pendingFilters]=\"pendingFilters\"\r\n      [showExportButton]=\"!pageInfo.hideExtractButton\"\r\n      (filterInformation)=\"storePendingFilters($event)\"\r\n      (isEmpty)=\"handleFilterEmpty($event)\"\r\n      (applyFilter)=\"applyPendingFilters()\"\r\n      (sortByClicked)=\"handleSortClick($event)\"\r\n      (exportClicked)=\"extractReport($event)\">\r\n    </app-filter-builder>\r\n\r\n    <div class=\"button-group\" *ngIf=\"!pageInfo.hideExtractButton\">\r\n      <button *ngIf=\"!pageInfo.hideExtractButton\"\r\n        mat-flat-button\r\n        [matMenuTriggerFor]=\"exportMenu\"\r\n        class=\"btn-export\"\r\n      >\r\n        <div class=\"button-text\">\r\n          <mat-icon>file_export</mat-icon>\r\n          <span>{{ 'export' | translate }}</span>\r\n          <mat-icon class=\"arrow-icon\">keyboard_arrow_down</mat-icon>\r\n        </div>\r\n      </button>\r\n\r\n      <mat-menu #exportMenu=\"matMenu\">\r\n        <button mat-menu-item (click)=\"extractReport('pdf')\">PDF</button>\r\n        <button mat-menu-item (click)=\"extractReport('xlsx')\">Excel</button>\r\n        <button mat-menu-item (click)=\"extractReport('csv')\">CSV</button>\r\n      </mat-menu>\r\n\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <div class=\"flex-row flex-100 baseTable__detailsColumn\">\r\n    <div class=\"flex-100\">\r\n      <div class=\"flex-row flex-100 mainTable\">\r\n        <div class=\"table-container\">\r\n          <div class=\"table-header\" [attr.data-sort]=\"sortState\">\r\n            <div *ngFor=\"let columnProp of visibleColumnsArray; let i = index\"\r\n                 class=\"table-header-cell\"\r\n                 [class.sortable]=\"getColumn(columnProp)?.enableSorting\"\r\n                 [class.first-cell]=\"i === 0\"\r\n                 [class.last-cell]=\"i === visibleColumnsArray.length - 1\"\r\n                 [class.actions-cell]=\"i === visibleColumnsArray.length - 1 && columnProp === 'actions'\"\r\n                 [class.has-width]=\"getColumn(columnProp)?.width\"\r\n                 [ngStyle]=\"getColumn(columnProp)?.width ? {'width': getColumn(columnProp)?.width + '%', 'flex-basis': getColumn(columnProp)?.width + '%'} : {}\"\r\n                 (click)=\"getColumn(columnProp)?.enableSorting && handleSortClick(columnProp)\">\r\n              <div class=\"table-header-content\">\r\n                <span class=\"table-header-label\">{{ labelKey(getColumn(columnProp)) | translate }}</span>\r\n                <ng-container *ngIf=\"getColumn(columnProp)?.enableSorting\">\r\n                  <mat-icon *ngIf=\"getSortDirection(columnProp) === 'asc'\"\r\n                           class=\"sort-icon sort-asc\">arrow_drop_up</mat-icon>\r\n                  <mat-icon *ngIf=\"getSortDirection(columnProp) === 'desc'\"\r\n                           class=\"sort-icon sort-desc\">arrow_drop_down</mat-icon>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"table-body\">\r\n            <div *ngFor=\"let row of dataSource.data; let rowIndex = index\"\r\n                 class=\"table-row\"\r\n                 [attr.id]=\"'table-row-' + (row?.id || row?.key || '')\"\r\n                 [ngClass]=\"{\r\n                   'table-row--highlight': selectedRowIndex == row.id || (pageInfo.groupByProperty && pageInfo.groupByValue?.includes(row[pageInfo.groupByProperty])),\r\n                   'table-row--dark-highlight': isDarkHighlight(row)\r\n                 }\"\r\n                 (auxclick)=\"openNewTab(row)\"\r\n                 (click)=\"$event.stopPropagation(); onSelectItem(row)\">\r\n              <div *ngFor=\"let columnProp of visibleColumnsArray; let i = index\"\r\n                   class=\"table-cell\"\r\n                   [class.first-cell]=\"i === 0\"\r\n                   [class.last-cell]=\"i === visibleColumnsArray.length - 1\"\r\n                   [class.actions-cell]=\"i === visibleColumnsArray.length - 1 && columnProp === 'actions'\"\r\n                   [class.has-width]=\"getColumn(columnProp)?.width\"\r\n                   [ngStyle]=\"getColumn(columnProp)?.width ? {'width': getColumn(columnProp)?.width + '%', 'flex-basis': getColumn(columnProp)?.width + '%'} : {}\">\r\n                <ng-container [ngSwitch]=\"getColumn(columnProp)?.type\">\r\n                  <ng-container *ngSwitchCase=\"'workflowStatus'\">\r\n                    <button mat-button class=\"wfStatus {{ getStatusDescription(row)}}\" [attr.id]=\"'table-btn-wf-'+columnProp+'-'+(row.id || row.key || '')\">{{ getStatusDescription(row) }}</button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'hyper-text'\">\r\n                    <mat-label (click)=\"hyperLinkClicked(columnProp, row)\" [ngClass]=\"{'hyper-link': shouldRenderAsHyperLink(row)}\">\r\n                      {{ extractFieldName(row, columnProp) }}\r\n                    </mat-label>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'button'\">\r\n                    <button *ngIf=\"shouldShowButton(row)\" mat-button class=\"primary\" (click)=\"$event.stopPropagation(); actionButtonClicked(columnProp, row)\" [attr.id]=\"'table-btn-action-'+columnProp\">\r\n                      {{ labelKey(getColumn(columnProp)) + '_title' | translate }}\r\n                    </button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'icon'\">\r\n                    <mat-icon [ngClass]=\"{\r\n                      'mainTable__td__icon-green': row[columnProp] === 'pass',\r\n                      'mainTable__td__icon-orange': row[columnProp] === 'warning',\r\n                      'mainTable__td__icon-red': row[columnProp] === 'error'\r\n                    }\">\r\n                      {{ getIcon(row[columnProp]) }}\r\n                    </mat-icon>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'checkbox'\">\r\n                    <mat-checkbox class=\"primary\" [checked]=\"row[columnProp]\" (click)=\"$event.stopPropagation();actionCheckedClicked(columnProp,row)\"></mat-checkbox>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'stateType'\">\r\n                    <button mat-button class=\"stateType {{ row[columnProp]}}\" [attr.id]=\"'table-btn-state-'+columnProp\">{{ labelKeyByValue(getColumn(columnProp), row) | translate}}</button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'date'\">\r\n                    {{ extractFieldName(row, columnProp) | date:'dd/MM/yyyy' }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'croppedText'\">\r\n                    {{ getCroppedText(row[columnProp], row[getColumn(columnProp)?.width]) }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'download'\">\r\n                    <mat-icon class=\"mainTable__td__icon-blue\">system_update_alt</mat-icon>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'onOff'\">\r\n                    <mat-icon *ngIf=\"row[columnProp] === null\" class=\"mainTable__td__icon-darkorange\">flag</mat-icon>\r\n                    <mat-icon *ngIf=\"row[columnProp] === false\" class=\"mainTable__td__icon-red\">flag</mat-icon>\r\n                    <mat-icon *ngIf=\"row[columnProp] === true\" class=\"mainTable__td__icon-green\">flag</mat-icon>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'status'\">\r\n                    <span *ngIf=\"row[columnProp] === null || row[columnProp] === false\">\r\n                      {{ pageInfo.labelsSection + '.' + getColumn(columnProp)?.label + 'InActive' | translate }}\r\n                    </span>\r\n                    <span *ngIf=\"row[columnProp] === true\">\r\n                      {{ pageInfo.labelsSection + '.' + getColumn(columnProp)?.label + 'Active' | translate }}\r\n                    </span>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'info'\">\r\n                    <button mat-icon-button (click)=\"$event.stopPropagation();emitEvent(row)\" [attr.id]=\"'table-btn-info-'+row.id\">\r\n                      <mat-icon>info</mat-icon>\r\n                    </button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'netAmount'\">\r\n                    <div class=\"mainTable__td__currency\" style=\"display:inline-block;\">{{ row[getColumn(columnProp)?.currency] }}</div>\r\n                    <span class=\"mainTable__td__property\" style=\"display:inline-block; margin-left:6px; margin-right:6px;\">\r\n                      {{ extractFieldName(row, columnProp) | currency:'':'' }}</span>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'localDateTime'\">\r\n                    {{ extractFieldName(row, columnProp) | date : extractFormat(getColumn(columnProp)) }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'bigdecimal'\">\r\n                    <small><sup class=\"mainTable__td__currency\">{{row[getColumn(columnProp)?.currency]}}</sup></small>\r\n                    {{ extractFieldName(row, columnProp) | number : (getColumn(columnProp)?.digitInfo || '1.3-5') }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'listAction'\">\r\n                    <app-button-actions\r\n                      [buttonsAction]=\"getColumn(columnProp)?.viewType === 'buttonsAction'\"\r\n                      [listAction]=\"listAction\"\r\n                      [actions]=\"listAction\"\r\n                      (clickedButton)=\"actionListClicked($event,row)\">\r\n                    </app-button-actions>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchDefault>\r\n                    <ng-container *ngIf=\"getColumn(columnProp)?.translate; else noTranslate\">\r\n                      <span (click)=\"emitRoutePage(row)\">\r\n                        {{ pageInfo.labelsSection + \".\" + extractFieldName(row, columnProp) | translate }}\r\n                      </span>\r\n                    </ng-container>\r\n                    <ng-template #noTranslate>\r\n                      <span (click)=\"emitRoutePage(row)\" [innerHtml]='extractFieldName(row, columnProp)'></span>\r\n                    </ng-template>\r\n                  </ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- Mobile Card View -->\r\n      <div class=\"mobile-cards-container\">\r\n        <div *ngFor=\"let row of dataSource.data; let rowIndex = index\"\r\n             class=\"mobile-card\"\r\n             [attr.id]=\"'mobile-card-' + (row?.id || row?.key || '')\"\r\n             [ngClass]=\"{\r\n               'mobile-card--highlight': selectedRowIndex == row.id || (pageInfo.groupByProperty && pageInfo.groupByValue?.includes(row[pageInfo.groupByProperty])),\r\n               'mobile-card--dark-highlight': isDarkHighlight(row)\r\n             }\"\r\n             (auxclick)=\"openNewTab(row)\"\r\n             (click)=\"$event.stopPropagation(); onSelectItem(row)\">\r\n          \r\n          <!-- Mobile Card Header: ID/Name and Status -->\r\n          <div class=\"mobile-card__header\">\r\n            <div class=\"mobile-card__header-id\">\r\n              <span class=\"mobile-card__id-text\">{{ extractFieldName(row, getMobileCardIdColumn()?.property || 'id') }}</span>\r\n            </div>\r\n            <div class=\"mobile-card__header-status\" *ngIf=\"getMobileCardStatusColumn()\">\r\n              <button mat-button class=\"stateType {{ row[getMobileCardStatusColumn()?.property]}}\" \r\n                      [attr.id]=\"'mobile-btn-state-'+getMobileCardStatusColumn()?.property\">\r\n                {{ labelKeyByValue(getMobileCardStatusColumn(), row) | translate}}\r\n              </button>\r\n            </div>\r\n          </div>\r\n\r\n          <!-- Divider -->\r\n          <div class=\"mobile-card__divider\"></div>\r\n\r\n          <!-- Mobile Card Body: Other columns -->\r\n          <div class=\"mobile-card__body\">\r\n            <div *ngFor=\"let column of getMobileCardColumns()\" class=\"mobile-card__row\">\r\n              <div class=\"mobile-card__row-label\">\r\n                <span>{{ labelKey(column) | translate }} :</span>\r\n              </div>\r\n              <div class=\"mobile-card__row-value\">\r\n                <ng-container [ngSwitch]=\"column.type\">\r\n                  <ng-container *ngSwitchCase=\"'stateType'\">\r\n                    <button mat-button class=\"stateType {{ row[column.property]}}\" \r\n                            [attr.id]=\"'mobile-btn-state-'+column.property\">\r\n                      {{ labelKeyByValue(column, row) | translate}}\r\n                    </button>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'date'\">\r\n                    {{ extractFieldName(row, column.property) | date:'dd/MM/yyyy' }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'netAmount'\">\r\n                    <span class=\"mobile-card__amount-currency\">{{ row[column.currency] }}</span>\r\n                    <span class=\"mobile-card__amount-value\">{{ extractFieldName(row, column.property) | currency:'':'' }}</span>\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'localDateTime'\">\r\n                    {{ extractFieldName(row, column.property) | date : extractFormat(column) }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchCase=\"'bigdecimal'\">\r\n                    <small><sup class=\"mainTable__td__currency\">{{row[column.currency]}}</sup></small>\r\n                    {{ extractFieldName(row, column.property) | number : (column.digitInfo || '1.3-5') }}\r\n                  </ng-container>\r\n\r\n                  <ng-container *ngSwitchDefault>\r\n                    <ng-container *ngIf=\"column.translate; else noTranslate\">\r\n                      <span>{{ pageInfo.labelsSection + \".\" + extractFieldName(row, column.property) | translate }}</span>\r\n                    </ng-container>\r\n                    <ng-template #noTranslate>\r\n                      <span [innerHtml]='extractFieldName(row, column.property)'></span>\r\n                    </ng-template>\r\n                  </ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <!-- Mobile Card Actions -->\r\n          <div class=\"mobile-card__actions\" *ngIf=\"listAction && listAction.length > 0\">\r\n            <app-button-actions\r\n              [buttonsAction]=\"true\"\r\n              [listAction]=\"listAction\"\r\n              [actions]=\"listAction\"\r\n              (clickedButton)=\"actionListClicked($event,row)\">\r\n            </app-button-actions>\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n      <div *ngIf=\"noDataFound\" class=\"dataNotFound flex-column\">\r\n        <img *ngIf=\"getDisplaySvgPath()\" [src]=\"getDisplaySvgPath()\" class=\"dataNotFound__icon\" alt=\"No data found\" />\r\n        <span class=\"dataNotFound__title\">{{ getDisplayTitle() | translate}}</span>\r\n        <span class=\"dataNotFound__subtitle\">{{ getDisplaySubtitle() | translate}}</span>\r\n      </div>\r\n\r\n\r\n      <div  *ngIf=\"(dataSource.data?.length > 0 || customizedData) && !pageInfo.hidePagination\" class=\"main-pagination flex-row\">\r\n        <ng-container *ngIf=\"enablePagination\">\r\n          <div class=\"flex-column flex-100\">\r\n            <app-paginator\r\n              [currentPage]=\"pageIndex\"\r\n              [totalItems]=\"totalElements\"\r\n              [pageSize]=\"pageSize\"\r\n              [pageSizeOptions]=\"[5, 10, 25, 50]\"\r\n              [mobileLoadMoreIncrement]=\"mobileLoadMoreIncrement\"\r\n              [displayedItems]=\"mobileDisplayedItems || dataSource.data.length\"\r\n              (pageChange)=\"onPageChange($event)\"\r\n              (pageSizeChange)=\"onPageSizeChange($event)\"\r\n              (loadMore)=\"onLoadMore($event)\">\r\n            </app-paginator>\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|