axidio-styleguide-library1-v2 0.2.16 → 0.2.18

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.
@@ -7,8 +7,10 @@ import * as i3 from "../header-alt/header-alt.component";
7
7
  export class AxTableComponent {
8
8
  constructor() {
9
9
  this.clickEvent = new EventEmitter();
10
+ // UI State
10
11
  this.isHeaderVisible = true;
11
12
  this.isUserSort = false;
13
+ // Data and pagination
12
14
  this.tableHeadList = [];
13
15
  this.masterList = [];
14
16
  this.itemList = [];
@@ -19,8 +21,10 @@ export class AxTableComponent {
19
21
  this.totalPages = 1;
20
22
  this.goToPageNumber = 1;
21
23
  this.pagesToShow = [];
24
+ // Sorting
22
25
  this.sortColumn = '';
23
26
  this.sortDirection = '';
27
+ // Configuration
24
28
  this.chartConfiguration = {};
25
29
  this.defaultConfiguration = {};
26
30
  }
@@ -29,6 +33,7 @@ export class AxTableComponent {
29
33
  return;
30
34
  this.initializeTable();
31
35
  }
36
+ /** ---------------- Initialization ---------------- */
32
37
  initializeTable() {
33
38
  this.tableHeadList = Object.keys(this.tableData.data[0]);
34
39
  this.setupChartConfiguration();
@@ -51,6 +56,7 @@ export class AxTableComponent {
51
56
  this.isHeaderVisible = meta.isHeaderVisible;
52
57
  }
53
58
  }
59
+ /** ---------------- Pagination ---------------- */
54
60
  loadPage() {
55
61
  if (this.tableData.metaData.isPaginationHidden) {
56
62
  this.currentList = this.itemList;
@@ -117,11 +123,13 @@ export class AxTableComponent {
117
123
  event.preventDefault();
118
124
  }
119
125
  }
126
+ /** ---------------- Sorting ---------------- */
120
127
  sortByColumn(id) {
121
128
  const meta = this.tableData.metaData;
122
129
  if (id === 'viewDetails' || meta.isHeaderSortHidden)
123
130
  return;
124
131
  this.isUserSort = true;
132
+ // 3-state toggle: asc → desc → default
125
133
  if (id !== this.sortColumn) {
126
134
  this.sortColumn = id;
127
135
  this.sortDirection = 'asc';
@@ -160,6 +168,7 @@ export class AxTableComponent {
160
168
  checkIfColumnCurrentlyBeingSorted(id) {
161
169
  return this.sortColumn === id;
162
170
  }
171
+ /** ---------------- Search ---------------- */
163
172
  onSearch(event) {
164
173
  const searchText = (event.target.value || '').trim().toLowerCase();
165
174
  this.itemList = searchText
@@ -170,6 +179,7 @@ export class AxTableComponent {
170
179
  this.calculateTotalPages();
171
180
  this.refreshPagination();
172
181
  }
182
+ /** ---------------- Utilities ---------------- */
173
183
  getWidthById(_, index) {
174
184
  if (this.tableHeadList.length === 3) {
175
185
  return index === 1 ? '60%' : '20%';
@@ -192,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
192
202
  }], clickEvent: [{
193
203
  type: Output
194
204
  }] } });
195
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ax-table.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/ax-table/ax-table.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/ax-table/ax-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\r\nimport ChartHelper from '../chart-helper';\r\n\r\n@Component({\r\n  selector: 'lib-ax-table',\r\n  templateUrl: './ax-table.component.html',\r\n  styleUrls: ['./ax-table.component.less', '../common-styles.less'],\r\n})\r\nexport class AxTableComponent implements OnInit {\r\n  @Input() tableData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n\r\n  isHeaderVisible = true;\r\n  isUserSort = false;\r\n\r\n  tableHeadList: string[] = [];\r\n  masterList: any[] = [];\r\n  itemList: any[] = [];\r\n  currentList: any[] = [];\r\n\r\n  pageSize = 10;\r\n  currentPage = 1;\r\n  totalItems = 0;\r\n  totalPages = 1;\r\n  goToPageNumber = 1;\r\n  pagesToShow: number[] = [];\r\n\r\n  sortColumn = '';\r\n  sortDirection: 'asc' | 'desc' | '' = '';\r\n\r\n  chartConfiguration: any = {};\r\n  defaultConfiguration: any = {};\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    if (!this.tableData || !this.tableData.data?.length) return;\r\n\r\n    this.initializeTable();\r\n  }\r\n\r\n  private initializeTable(): void {\r\n    this.tableHeadList = Object.keys(this.tableData.data[0]);\r\n    this.setupChartConfiguration();\r\n    this.masterList = [...this.tableData.data];\r\n    this.itemList = [...this.masterList];\r\n    this.totalItems = this.itemList.length;\r\n\r\n    this.calculateTotalPages();\r\n    this.generatePagesToShow();\r\n    this.setHeaderVisibility();\r\n    this.loadPage();\r\n  }\r\n\r\n  private setupChartConfiguration(): void {\r\n    for (const key in this.defaultConfiguration) {\r\n      this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(\r\n        key,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n  }\r\n\r\n  private setHeaderVisibility(): void {\r\n    const meta = this.tableData.metaData;\r\n    if (meta.isHeaderVisible !== undefined) {\r\n      this.isHeaderVisible = meta.isHeaderVisible;\r\n    }\r\n  }\r\n\r\n  private loadPage(): void {\r\n    if (this.tableData.metaData.isPaginationHidden) {\r\n      this.currentList = this.itemList;\r\n      return;\r\n    }\r\n\r\n    const start = (this.currentPage - 1) * this.pageSize;\r\n    const end = start + this.pageSize;\r\n    this.currentList = this.itemList.slice(start, end);\r\n  }\r\n\r\n  private calculateTotalPages(): void {\r\n    this.totalPages = Math.ceil(this.totalItems / this.pageSize);\r\n    this.goToPageNumber = this.currentPage;\r\n  }\r\n\r\n  private generatePagesToShow(): void {\r\n    const maxPagesToShow = 5;\r\n    let start = Math.max(1, this.currentPage - Math.floor(maxPagesToShow / 2));\r\n    let end = Math.min(this.totalPages, start + maxPagesToShow - 1);\r\n\r\n    if (end - start + 1 < maxPagesToShow) {\r\n      start = Math.max(1, end - maxPagesToShow + 1);\r\n    }\r\n\r\n    this.pagesToShow = Array.from({ length: end - start + 1 }, (_, i) => start + i);\r\n  }\r\n\r\n  private refreshPagination(): void {\r\n    this.loadPage();\r\n    this.goToPageNumber = this.currentPage;\r\n    this.generatePagesToShow();\r\n  }\r\n\r\n  goToFirstPage(): void {\r\n    if (this.currentPage !== 1) {\r\n      this.currentPage = 1;\r\n      this.refreshPagination();\r\n    }\r\n  }\r\n\r\n  goToPreviousPage(): void {\r\n    if (this.currentPage > 1) {\r\n      this.currentPage--;\r\n      this.refreshPagination();\r\n    }\r\n  }\r\n\r\n  goToNextPage(): void {\r\n    if (this.currentPage < this.totalPages) {\r\n      this.currentPage++;\r\n      this.refreshPagination();\r\n    }\r\n  }\r\n\r\n  goToLastPage(): void {\r\n    if (this.currentPage !== this.totalPages) {\r\n      this.currentPage = this.totalPages;\r\n      this.refreshPagination();\r\n    }\r\n  }\r\n\r\n  goToSpecificPage(): void {\r\n    let pageNum = Number(this.goToPageNumber);\r\n\r\n    if (isNaN(pageNum) || pageNum < 1) pageNum = 1;\r\n    if (pageNum > this.totalPages) pageNum = this.totalPages;\r\n\r\n    this.currentPage = pageNum;\r\n    this.refreshPagination();\r\n  }\r\n\r\n  preventNegative(event: KeyboardEvent): void {\r\n    const invalidKeys = ['-', '+', 'e'];\r\n    if (invalidKeys.includes(event.key.toLowerCase())) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  sortByColumn(id: string): void {\r\n    const meta = this.tableData.metaData;\r\n    if (id === 'viewDetails' || meta.isHeaderSortHidden) return;\r\n\r\n    this.isUserSort = true;\r\n\r\n    if (id !== this.sortColumn) {\r\n      this.sortColumn = id;\r\n      this.sortDirection = 'asc';\r\n    } else if (this.sortDirection === 'asc') {\r\n      this.sortDirection = 'desc';\r\n    } else {\r\n      this.resetSort();\r\n      return;\r\n    }\r\n\r\n    this.sortItemList();\r\n    this.currentPage = 1;\r\n    this.refreshPagination();\r\n  }\r\n\r\n  private sortItemList(): void {\r\n    const compare = (a: any, b: any): number => {\r\n      const numA = parseFloat(a);\r\n      const numB = parseFloat(b);\r\n      if (!isNaN(numA) && !isNaN(numB)) return numA - numB;\r\n      return a < b ? -1 : a > b ? 1 : 0;\r\n    };\r\n\r\n    this.itemList.sort((a, b) => {\r\n      const result = compare(a[this.sortColumn], b[this.sortColumn]);\r\n      return this.sortDirection === 'asc' ? result : -result;\r\n    });\r\n  }\r\n\r\n  private resetSort(): void {\r\n    this.sortColumn = '';\r\n    this.sortDirection = '';\r\n    this.itemList = [...this.masterList];\r\n    this.currentPage = 1;\r\n    this.refreshPagination();\r\n  }\r\n\r\n  checkIfColumnCurrentlyBeingSorted(id: string): boolean {\r\n    return this.sortColumn === id;\r\n  }\r\n\r\n  onSearch(event: any): void {\r\n    const searchText = (event.target.value || '').trim().toLowerCase();\r\n    this.itemList = searchText\r\n      ? this.masterList.filter(row =>\r\n          this.tableHeadList.some(\r\n            col => row[col]?.toString().toLowerCase().includes(searchText)\r\n          )\r\n        )\r\n      : [...this.masterList];\r\n\r\n    this.currentPage = 1;\r\n    this.totalItems = this.itemList.length;\r\n    this.calculateTotalPages();\r\n    this.refreshPagination();\r\n  }\r\n\r\n  getWidthById(_: string, index: number): string {\r\n    if (this.tableHeadList.length === 3) {\r\n      return index === 1 ? '60%' : '20%';\r\n    }\r\n    return `${100 / this.tableHeadList.length}%`;\r\n  }\r\n\r\n  handleClick(row: any): void {\r\n    this.clickEvent.emit(row);\r\n  }\r\n}","<div class=\"d-flex align-items-center justify-content-between w-100\">\r\n  <div class=\"d-flex align-items-center gap-2\">\r\n    <lib-header-alt [title]=\"tableData.metaData.title\" *ngIf=\"!isHeaderVisible\"></lib-header-alt>\r\n  </div>\r\n\r\n  <input\r\n    *ngIf=\"!tableData.metaData.isSearchHidden\"\r\n    type=\"text\"\r\n    class=\"form-control custom-input medium-font-size textbox-ax-common\"\r\n    placeholder=\"Search\"\r\n    autocomplete=\"off\"\r\n    (keyup)=\"onSearch($event)\"\r\n  />\r\n</div>\r\n\r\n<div class=\"popup-body-for-scroll\">\r\n  <div class=\"table-wrapper\">\r\n    <div class=\"table-responsive border\">\r\n      <table class=\"table table-bordered table-hover align-middle mb-0\">\r\n        <thead class=\"table-dark\">\r\n          <tr class=\"table-header\">\r\n            <th\r\n              *ngFor=\"let header of tableHeadList; index as i\"\r\n              (click)=\"sortByColumn(header)\"\r\n              [ngClass]=\"\r\n                !tableData.metaData.isHeaderAlignedToCenter\r\n                  ? i === tableHeadList.length - 1\r\n                    ? 'textalign-right'\r\n                    : 'textalign-left'\r\n                  : 'textalign-center'\r\n              \"\r\n              [style.width]=\"getWidthById(header, i)\"\r\n              [style.backgroundColor]=\"tableData.metaData.headerColor\"\r\n              [style.color]=\"tableData.metaData.headerTextColor\"\r\n            >\r\n              <span\r\n                *ngIf=\"(!tableData.metaData.isFirstColumnHeaderHidden && i === 0) || i > 0\"\r\n                [ngClass]=\"\r\n                  !tableData.metaData.isHeaderSortHidden ? 'cursor-pointer' : 'cursor-default'\r\n                \"\r\n              >\r\n                {{ header }}\r\n              </span>\r\n\r\n              <i\r\n                *ngIf=\"checkIfColumnCurrentlyBeingSorted(header) || !isUserSort\"\r\n                class=\"sort-icons fa\"\r\n                [ngClass]=\"\r\n                  !isUserSort || sortColumn !== header\r\n                    ? 'fa-sort'\r\n                    : sortDirection === 'asc'\r\n                      ? 'fa-sort-asc'\r\n                      : sortDirection === 'desc'\r\n                        ? 'fa-sort-desc'\r\n                        : 'fa-sort'\r\n                \"\r\n              ></i>\r\n            </th>\r\n          </tr>\r\n        </thead>\r\n\r\n        <tbody>\r\n          <tr\r\n            *ngFor=\"let row of currentList\"\r\n            [ngClass]=\"tableData?.highlightedTexts?.includes(row[tableHeadList[0]]) ? 'font-weight-bold' : ''\"\r\n          >\r\n            <td\r\n              *ngFor=\"let header of tableHeadList; index as i\"\r\n              (click)=\"handleClick(row)\"\r\n              class=\"table-cell\"\r\n              [style.width]=\"getWidthById(header, i)\"\r\n              [ngClass]=\"\r\n                !tableData.metaData.isAllAlignedToRight\r\n                  ? i === tableHeadList.length - 1\r\n                    ? 'textalign-right last-column-color'\r\n                    : 'textalign-left'\r\n                  : 'textalign-right'\r\n              \"\r\n              [style.cursor]=\"tableData.metaData.hasDrillDown ? 'pointer' : 'default'\"\r\n            >\r\n              <span>{{ row[header] }}</span>\r\n            </td>\r\n          </tr>\r\n        </tbody>\r\n      </table>\r\n    </div>\r\n\r\n    <div class=\"pagination-bar mt-0\">\r\n      <span>Go To</span>\r\n      <input\r\n        type=\"number\"\r\n        class=\"page-input\"\r\n        min=\"1\"\r\n        [max]=\"totalPages\"\r\n        [(ngModel)]=\"goToPageNumber\"\r\n        (keypress)=\"preventNegative($event)\"\r\n        (keyup.enter)=\"goToSpecificPage()\"\r\n      />\r\n\r\n      <span>\r\n        {{ currentList.length > 0 ? (currentPage - 1) * pageSize + 1 : 0 }} -\r\n        {{ (currentPage - 1) * pageSize + currentList.length }} of {{ totalItems | number }}\r\n      </span>\r\n\r\n      <button [disabled]=\"currentPage === 1\" (click)=\"goToFirstPage()\" class=\"pagination-btn\" title=\"First Page\">\r\n        <i class=\"bi bi-chevron-double-left\"></i>\r\n      </button>\r\n      <button [disabled]=\"currentPage === 1\" (click)=\"goToPreviousPage()\" class=\"pagination-btn\" title=\"Previous Page\">\r\n        <i class=\"bi bi-chevron-left\"></i>\r\n      </button>\r\n      <button\r\n        [disabled]=\"currentPage === totalPages\"\r\n        (click)=\"goToNextPage()\"\r\n        class=\"pagination-btn\"\r\n        title=\"Next Page\"\r\n      >\r\n        <i class=\"bi bi-chevron-right\"></i>\r\n      </button>\r\n      <button\r\n        [disabled]=\"currentPage === totalPages\"\r\n        (click)=\"goToLastPage()\"\r\n        class=\"pagination-btn\"\r\n        title=\"Last Page\"\r\n      >\r\n        <i class=\"bi bi-chevron-double-right\"></i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ax-table.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/ax-table/ax-table.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/ax-table/ax-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\r\nimport ChartHelper from '../chart-helper';\r\n\r\n@Component({\r\n  selector: 'lib-ax-table',\r\n  templateUrl: './ax-table.component.html',\r\n  styleUrls: ['./ax-table.component.less', '../common-styles.less'],\r\n})\r\nexport class AxTableComponent implements OnInit {\r\n  @Input() tableData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n\r\n  // UI State\r\n  isHeaderVisible = true;\r\n  isUserSort = false;\r\n\r\n  // Data and pagination\r\n  tableHeadList: string[] = [];\r\n  masterList: any[] = [];\r\n  itemList: any[] = [];\r\n  currentList: any[] = [];\r\n\r\n  pageSize = 10;\r\n  currentPage = 1;\r\n  totalItems = 0;\r\n  totalPages = 1;\r\n  goToPageNumber = 1;\r\n  pagesToShow: number[] = [];\r\n\r\n  // Sorting\r\n  sortColumn = '';\r\n  sortDirection: 'asc' | 'desc' | '' = '';\r\n\r\n  // Configuration\r\n  chartConfiguration: any = {};\r\n  defaultConfiguration: any = {};\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    if (!this.tableData || !this.tableData.data?.length) return;\r\n\r\n    this.initializeTable();\r\n  }\r\n\r\n  /** ---------------- Initialization ---------------- */\r\n  private initializeTable(): void {\r\n    this.tableHeadList = Object.keys(this.tableData.data[0]);\r\n    this.setupChartConfiguration();\r\n    this.masterList = [...this.tableData.data];\r\n    this.itemList = [...this.masterList];\r\n    this.totalItems = this.itemList.length;\r\n\r\n    this.calculateTotalPages();\r\n    this.generatePagesToShow();\r\n    this.setHeaderVisibility();\r\n    this.loadPage();\r\n  }\r\n\r\n  private setupChartConfiguration(): void {\r\n    for (const key in this.defaultConfiguration) {\r\n      this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(\r\n        key,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n  }\r\n\r\n  private setHeaderVisibility(): void {\r\n    const meta = this.tableData.metaData;\r\n    if (meta.isHeaderVisible !== undefined) {\r\n      this.isHeaderVisible = meta.isHeaderVisible;\r\n    }\r\n  }\r\n\r\n  /** ---------------- Pagination ---------------- */\r\n  private loadPage(): void {\r\n    if (this.tableData.metaData.isPaginationHidden) {\r\n      this.currentList = this.itemList;\r\n      return;\r\n    }\r\n\r\n    const start = (this.currentPage - 1) * this.pageSize;\r\n    const end = start + this.pageSize;\r\n    this.currentList = this.itemList.slice(start, end);\r\n  }\r\n\r\n  private calculateTotalPages(): void {\r\n    this.totalPages = Math.ceil(this.totalItems / this.pageSize);\r\n    this.goToPageNumber = this.currentPage;\r\n  }\r\n\r\n  private generatePagesToShow(): void {\r\n    const maxPagesToShow = 5;\r\n    let start = Math.max(1, this.currentPage - Math.floor(maxPagesToShow / 2));\r\n    let end = Math.min(this.totalPages, start + maxPagesToShow - 1);\r\n\r\n    if (end - start + 1 < maxPagesToShow) {\r\n      start = Math.max(1, end - maxPagesToShow + 1);\r\n    }\r\n\r\n    this.pagesToShow = Array.from({ length: end - start + 1 }, (_, i) => start + i);\r\n  }\r\n\r\n  private refreshPagination(): void {\r\n    this.loadPage();\r\n    this.goToPageNumber = this.currentPage;\r\n    this.generatePagesToShow();\r\n  }\r\n\r\n  goToFirstPage(): void {\r\n    if (this.currentPage !== 1) {\r\n      this.currentPage = 1;\r\n      this.refreshPagination();\r\n    }\r\n  }\r\n\r\n  goToPreviousPage(): void {\r\n    if (this.currentPage > 1) {\r\n      this.currentPage--;\r\n      this.refreshPagination();\r\n    }\r\n  }\r\n\r\n  goToNextPage(): void {\r\n    if (this.currentPage < this.totalPages) {\r\n      this.currentPage++;\r\n      this.refreshPagination();\r\n    }\r\n  }\r\n\r\n  goToLastPage(): void {\r\n    if (this.currentPage !== this.totalPages) {\r\n      this.currentPage = this.totalPages;\r\n      this.refreshPagination();\r\n    }\r\n  }\r\n\r\n  goToSpecificPage(): void {\r\n    let pageNum = Number(this.goToPageNumber);\r\n\r\n    if (isNaN(pageNum) || pageNum < 1) pageNum = 1;\r\n    if (pageNum > this.totalPages) pageNum = this.totalPages;\r\n\r\n    this.currentPage = pageNum;\r\n    this.refreshPagination();\r\n  }\r\n\r\n  preventNegative(event: KeyboardEvent): void {\r\n    const invalidKeys = ['-', '+', 'e'];\r\n    if (invalidKeys.includes(event.key.toLowerCase())) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  /** ---------------- Sorting ---------------- */\r\n  sortByColumn(id: string): void {\r\n    const meta = this.tableData.metaData;\r\n    if (id === 'viewDetails' || meta.isHeaderSortHidden) return;\r\n\r\n    this.isUserSort = true;\r\n\r\n    // 3-state toggle: asc → desc → default\r\n    if (id !== this.sortColumn) {\r\n      this.sortColumn = id;\r\n      this.sortDirection = 'asc';\r\n    } else if (this.sortDirection === 'asc') {\r\n      this.sortDirection = 'desc';\r\n    } else {\r\n      this.resetSort();\r\n      return;\r\n    }\r\n\r\n    this.sortItemList();\r\n    this.currentPage = 1;\r\n    this.refreshPagination();\r\n  }\r\n\r\n  private sortItemList(): void {\r\n    const compare = (a: any, b: any): number => {\r\n      const numA = parseFloat(a);\r\n      const numB = parseFloat(b);\r\n      if (!isNaN(numA) && !isNaN(numB)) return numA - numB;\r\n      return a < b ? -1 : a > b ? 1 : 0;\r\n    };\r\n\r\n    this.itemList.sort((a, b) => {\r\n      const result = compare(a[this.sortColumn], b[this.sortColumn]);\r\n      return this.sortDirection === 'asc' ? result : -result;\r\n    });\r\n  }\r\n\r\n  private resetSort(): void {\r\n    this.sortColumn = '';\r\n    this.sortDirection = '';\r\n    this.itemList = [...this.masterList];\r\n    this.currentPage = 1;\r\n    this.refreshPagination();\r\n  }\r\n\r\n  checkIfColumnCurrentlyBeingSorted(id: string): boolean {\r\n    return this.sortColumn === id;\r\n  }\r\n\r\n  /** ---------------- Search ---------------- */\r\n  onSearch(event: any): void {\r\n    const searchText = (event.target.value || '').trim().toLowerCase();\r\n    this.itemList = searchText\r\n      ? this.masterList.filter(row =>\r\n          this.tableHeadList.some(\r\n            col => row[col]?.toString().toLowerCase().includes(searchText)\r\n          )\r\n        )\r\n      : [...this.masterList];\r\n\r\n    this.currentPage = 1;\r\n    this.totalItems = this.itemList.length;\r\n    this.calculateTotalPages();\r\n    this.refreshPagination();\r\n  }\r\n\r\n  /** ---------------- Utilities ---------------- */\r\n  getWidthById(_: string, index: number): string {\r\n    if (this.tableHeadList.length === 3) {\r\n      return index === 1 ? '60%' : '20%';\r\n    }\r\n    return `${100 / this.tableHeadList.length}%`;\r\n  }\r\n\r\n  handleClick(row: any): void {\r\n    this.clickEvent.emit(row);\r\n  }\r\n}","<div class=\"d-flex align-items-center justify-content-between w-100\">\r\n  <div class=\"d-flex align-items-center gap-2\">\r\n    <lib-header-alt [title]=\"tableData.metaData.title\" *ngIf=\"!isHeaderVisible\"></lib-header-alt>\r\n  </div>\r\n\r\n  <input\r\n    *ngIf=\"!tableData.metaData.isSearchHidden\"\r\n    type=\"text\"\r\n    class=\"form-control custom-input medium-font-size textbox-ax-common\"\r\n    placeholder=\"Search\"\r\n    autocomplete=\"off\"\r\n    (keyup)=\"onSearch($event)\"\r\n  />\r\n</div>\r\n\r\n<div class=\"popup-body-for-scroll\">\r\n  <div class=\"table-wrapper\">\r\n    <div class=\"table-responsive border\">\r\n      <table class=\"table table-bordered table-hover align-middle mb-0\">\r\n        <thead class=\"table-dark\">\r\n          <tr class=\"table-header\">\r\n            <th\r\n              *ngFor=\"let header of tableHeadList; index as i\"\r\n              (click)=\"sortByColumn(header)\"\r\n              [ngClass]=\"\r\n                !tableData.metaData.isHeaderAlignedToCenter\r\n                  ? i === tableHeadList.length - 1\r\n                    ? 'textalign-right'\r\n                    : 'textalign-left'\r\n                  : 'textalign-center'\r\n              \"\r\n              [style.width]=\"getWidthById(header, i)\"\r\n              [style.backgroundColor]=\"tableData.metaData.headerColor\"\r\n              [style.color]=\"tableData.metaData.headerTextColor\"\r\n            >\r\n              <span\r\n                *ngIf=\"(!tableData.metaData.isFirstColumnHeaderHidden && i === 0) || i > 0\"\r\n                [ngClass]=\"\r\n                  !tableData.metaData.isHeaderSortHidden ? 'cursor-pointer' : 'cursor-default'\r\n                \"\r\n              >\r\n                {{ header }}\r\n              </span>\r\n\r\n              <i\r\n                *ngIf=\"checkIfColumnCurrentlyBeingSorted(header) || !isUserSort\"\r\n                class=\"sort-icons fa\"\r\n                [ngClass]=\"\r\n                  !isUserSort || sortColumn !== header\r\n                    ? 'fa-sort'\r\n                    : sortDirection === 'asc'\r\n                      ? 'fa-sort-asc'\r\n                      : sortDirection === 'desc'\r\n                        ? 'fa-sort-desc'\r\n                        : 'fa-sort'\r\n                \"\r\n              ></i>\r\n            </th>\r\n          </tr>\r\n        </thead>\r\n\r\n        <tbody>\r\n          <tr\r\n            *ngFor=\"let row of currentList\"\r\n            [ngClass]=\"tableData?.highlightedTexts?.includes(row[tableHeadList[0]]) ? 'font-weight-bold' : ''\"\r\n          >\r\n            <td\r\n              *ngFor=\"let header of tableHeadList; index as i\"\r\n              (click)=\"handleClick(row)\"\r\n              class=\"table-cell\"\r\n              [style.width]=\"getWidthById(header, i)\"\r\n              [ngClass]=\"\r\n                !tableData.metaData.isAllAlignedToRight\r\n                  ? i === tableHeadList.length - 1\r\n                    ? 'textalign-right last-column-color'\r\n                    : 'textalign-left'\r\n                  : 'textalign-right'\r\n              \"\r\n              [style.cursor]=\"tableData.metaData.hasDrillDown ? 'pointer' : 'default'\"\r\n            >\r\n              <span>{{ row[header] }}</span>\r\n            </td>\r\n          </tr>\r\n        </tbody>\r\n      </table>\r\n    </div>\r\n\r\n    <div class=\"pagination-bar mt-0\">\r\n      <span>Go To</span>\r\n      <input\r\n        type=\"number\"\r\n        class=\"page-input\"\r\n        min=\"1\"\r\n        [max]=\"totalPages\"\r\n        [(ngModel)]=\"goToPageNumber\"\r\n        (keypress)=\"preventNegative($event)\"\r\n        (keyup.enter)=\"goToSpecificPage()\"\r\n      />\r\n\r\n      <span>\r\n        {{ currentList.length > 0 ? (currentPage - 1) * pageSize + 1 : 0 }} -\r\n        {{ (currentPage - 1) * pageSize + currentList.length }} of {{ totalItems | number }}\r\n      </span>\r\n\r\n      <button [disabled]=\"currentPage === 1\" (click)=\"goToFirstPage()\" class=\"pagination-btn\" title=\"First Page\">\r\n        <i class=\"bi bi-chevron-double-left\"></i>\r\n      </button>\r\n      <button [disabled]=\"currentPage === 1\" (click)=\"goToPreviousPage()\" class=\"pagination-btn\" title=\"Previous Page\">\r\n        <i class=\"bi bi-chevron-left\"></i>\r\n      </button>\r\n      <button\r\n        [disabled]=\"currentPage === totalPages\"\r\n        (click)=\"goToNextPage()\"\r\n        class=\"pagination-btn\"\r\n        title=\"Next Page\"\r\n      >\r\n        <i class=\"bi bi-chevron-right\"></i>\r\n      </button>\r\n      <button\r\n        [disabled]=\"currentPage === totalPages\"\r\n        (click)=\"goToLastPage()\"\r\n        class=\"pagination-btn\"\r\n        title=\"Last Page\"\r\n      >\r\n        <i class=\"bi bi-chevron-double-right\"></i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
@@ -4669,8 +4669,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
4669
4669
  class AxTableComponent {
4670
4670
  constructor() {
4671
4671
  this.clickEvent = new EventEmitter();
4672
+ // UI State
4672
4673
  this.isHeaderVisible = true;
4673
4674
  this.isUserSort = false;
4675
+ // Data and pagination
4674
4676
  this.tableHeadList = [];
4675
4677
  this.masterList = [];
4676
4678
  this.itemList = [];
@@ -4681,8 +4683,10 @@ class AxTableComponent {
4681
4683
  this.totalPages = 1;
4682
4684
  this.goToPageNumber = 1;
4683
4685
  this.pagesToShow = [];
4686
+ // Sorting
4684
4687
  this.sortColumn = '';
4685
4688
  this.sortDirection = '';
4689
+ // Configuration
4686
4690
  this.chartConfiguration = {};
4687
4691
  this.defaultConfiguration = {};
4688
4692
  }
@@ -4691,6 +4695,7 @@ class AxTableComponent {
4691
4695
  return;
4692
4696
  this.initializeTable();
4693
4697
  }
4698
+ /** ---------------- Initialization ---------------- */
4694
4699
  initializeTable() {
4695
4700
  this.tableHeadList = Object.keys(this.tableData.data[0]);
4696
4701
  this.setupChartConfiguration();
@@ -4713,6 +4718,7 @@ class AxTableComponent {
4713
4718
  this.isHeaderVisible = meta.isHeaderVisible;
4714
4719
  }
4715
4720
  }
4721
+ /** ---------------- Pagination ---------------- */
4716
4722
  loadPage() {
4717
4723
  if (this.tableData.metaData.isPaginationHidden) {
4718
4724
  this.currentList = this.itemList;
@@ -4779,11 +4785,13 @@ class AxTableComponent {
4779
4785
  event.preventDefault();
4780
4786
  }
4781
4787
  }
4788
+ /** ---------------- Sorting ---------------- */
4782
4789
  sortByColumn(id) {
4783
4790
  const meta = this.tableData.metaData;
4784
4791
  if (id === 'viewDetails' || meta.isHeaderSortHidden)
4785
4792
  return;
4786
4793
  this.isUserSort = true;
4794
+ // 3-state toggle: asc → desc → default
4787
4795
  if (id !== this.sortColumn) {
4788
4796
  this.sortColumn = id;
4789
4797
  this.sortDirection = 'asc';
@@ -4822,6 +4830,7 @@ class AxTableComponent {
4822
4830
  checkIfColumnCurrentlyBeingSorted(id) {
4823
4831
  return this.sortColumn === id;
4824
4832
  }
4833
+ /** ---------------- Search ---------------- */
4825
4834
  onSearch(event) {
4826
4835
  const searchText = (event.target.value || '').trim().toLowerCase();
4827
4836
  this.itemList = searchText
@@ -4832,6 +4841,7 @@ class AxTableComponent {
4832
4841
  this.calculateTotalPages();
4833
4842
  this.refreshPagination();
4834
4843
  }
4844
+ /** ---------------- Utilities ---------------- */
4835
4845
  getWidthById(_, index) {
4836
4846
  if (this.tableHeadList.length === 3) {
4837
4847
  return index === 1 ? '60%' : '20%';