mis-crystal-design-system 18.1.10-test → 18.1.10
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.
|
@@ -360,8 +360,21 @@ export class TableComponent {
|
|
|
360
360
|
// Pagination related variables
|
|
361
361
|
this.pages = signal([]);
|
|
362
362
|
this.tableLength = signal(0);
|
|
363
|
-
this.selectedPage = signal(1); // Internal state for selected page
|
|
364
|
-
this.isInternalPageUpdate = false; // Flag to prevent effect from overwriting user-initiated updates
|
|
363
|
+
this.selectedPage = signal(1); // Internal state for selected page - this is the source of truth
|
|
364
|
+
this.isInternalPageUpdate = false; // Flag to prevent effect from overwriting during user-initiated updates
|
|
365
|
+
/**
|
|
366
|
+
* LEGACY CODE WORKAROUND: Track user-initiated page selections to prevent config overwrites.
|
|
367
|
+
*
|
|
368
|
+
* Some legacy parent components don't update tableConfig.paginationConfig.selectedPage when
|
|
369
|
+
* the page changes. This causes the effect to overwrite user selections with stale config values.
|
|
370
|
+
*
|
|
371
|
+
* IDEAL SOLUTION: Parent components should always update config.selectedPage in their
|
|
372
|
+
* pageSelected event handler. This workaround protects user actions until legacy code
|
|
373
|
+
* can be updated.
|
|
374
|
+
*
|
|
375
|
+
* TODO: Remove this workaround once all parent components properly update config.selectedPage
|
|
376
|
+
*/
|
|
377
|
+
this.userSelectedPage = null;
|
|
365
378
|
this.pageSelected = output();
|
|
366
379
|
this.pageSizeChanged = output();
|
|
367
380
|
this.pageSizeOptions = computed(() => {
|
|
@@ -407,29 +420,46 @@ export class TableComponent {
|
|
|
407
420
|
// --- PAGINATION PAGE ARRAY LOGIC (MOVED/REPLACED initializePagination) ---
|
|
408
421
|
const len = config?.paginationConfig?.noOfPages;
|
|
409
422
|
const disablePageJumping = config?.paginationConfig?.disablePageJumping;
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
423
|
+
/**
|
|
424
|
+
* LEGACY CODE WORKAROUND: Protect user-initiated page selections from config overwrites.
|
|
425
|
+
*
|
|
426
|
+
* When users click pagination arrows, we update internal state immediately. However,
|
|
427
|
+
* some legacy parent components don't update config.selectedPage, causing the effect
|
|
428
|
+
* to run with stale config values that would overwrite the user's selection.
|
|
429
|
+
*
|
|
430
|
+
* Strategy: Treat internal state as source of truth for user-initiated changes.
|
|
431
|
+
* Only sync from config when it's safe (not a user-selected page).
|
|
432
|
+
*
|
|
433
|
+
* IDEAL: Parent should always update config.selectedPage in pageSelected handler.
|
|
434
|
+
*/
|
|
435
|
+
const currentSelectedPage = this.selectedPage();
|
|
436
|
+
const configSelectedPage = config?.paginationConfig?.selectedPage;
|
|
437
|
+
const isUserSelectedPage = this.userSelectedPage !== null && currentSelectedPage === this.userSelectedPage;
|
|
438
|
+
if (!this.isInternalPageUpdate) {
|
|
415
439
|
// Only sync from config if:
|
|
416
|
-
// 1.
|
|
417
|
-
// 2.
|
|
418
|
-
//
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
440
|
+
// 1. Config has a selectedPage value
|
|
441
|
+
// 2. Current page is NOT a user-initiated selection (protect user actions)
|
|
442
|
+
// 3. Config value is valid and different from current
|
|
443
|
+
if (configSelectedPage !== undefined && configSelectedPage !== null && !isUserSelectedPage) {
|
|
444
|
+
const maxPages = config?.paginationConfig?.noOfPages || 1;
|
|
445
|
+
if (currentSelectedPage !== configSelectedPage &&
|
|
446
|
+
configSelectedPage >= 1 &&
|
|
447
|
+
configSelectedPage <= maxPages) {
|
|
448
|
+
this.selectedPage.set(configSelectedPage);
|
|
449
|
+
}
|
|
424
450
|
}
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
if (currentPage === 0 || currentPage < 1) {
|
|
451
|
+
// If config doesn't have selectedPage, only initialize invalid state
|
|
452
|
+
// Never reset a valid page number, especially user-selected ones
|
|
453
|
+
if ((configSelectedPage === undefined || configSelectedPage === null) &&
|
|
454
|
+
!isUserSelectedPage &&
|
|
455
|
+
(currentSelectedPage === 0 || currentSelectedPage < 1)) {
|
|
431
456
|
this.selectedPage.set(1);
|
|
432
457
|
}
|
|
458
|
+
// Clear user selection tracking when config matches user's selection
|
|
459
|
+
// This indicates parent has updated config correctly
|
|
460
|
+
if (configSelectedPage === this.userSelectedPage) {
|
|
461
|
+
this.userSelectedPage = null;
|
|
462
|
+
}
|
|
433
463
|
}
|
|
434
464
|
// Reset the flag after processing
|
|
435
465
|
this.isInternalPageUpdate = false;
|
|
@@ -653,9 +683,19 @@ export class TableComponent {
|
|
|
653
683
|
// Guard clause to prevent out-of-range updates
|
|
654
684
|
if (pageNumber < 1 || pageNumber > this.tableConfig().paginationConfig.noOfPages)
|
|
655
685
|
return;
|
|
656
|
-
|
|
686
|
+
/**
|
|
687
|
+
* LEGACY CODE WORKAROUND: Track user-initiated page selection.
|
|
688
|
+
*
|
|
689
|
+
* We track this to prevent the effect from overwriting user selections when
|
|
690
|
+
* legacy parent components don't update config.selectedPage. The effect will
|
|
691
|
+
* skip syncing from config while this page is marked as user-selected.
|
|
692
|
+
*
|
|
693
|
+
* IDEAL: Parent should update config.selectedPage in pageSelected handler.
|
|
694
|
+
* Once all parents do this, we can remove userSelectedPage tracking.
|
|
695
|
+
*/
|
|
657
696
|
this.isInternalPageUpdate = true;
|
|
658
|
-
|
|
697
|
+
this.userSelectedPage = pageNumber;
|
|
698
|
+
// Update internal state immediately - this is the source of truth
|
|
659
699
|
this.selectedPage.set(pageNumber);
|
|
660
700
|
// Reset header checkbox when navigating to a different page
|
|
661
701
|
this.selectAllCheckbox.set(false);
|
|
@@ -672,7 +712,7 @@ export class TableComponent {
|
|
|
672
712
|
this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);
|
|
673
713
|
}
|
|
674
714
|
}
|
|
675
|
-
// Emit to parent
|
|
715
|
+
// Emit to parent - they may or may not update config, but we protect our state
|
|
676
716
|
this.pageSelected.emit(pageNumber);
|
|
677
717
|
}
|
|
678
718
|
// Main container related functions
|
|
@@ -856,4 +896,4 @@ export class TableComponent {
|
|
|
856
896
|
args: ["table"]
|
|
857
897
|
}] }); })();
|
|
858
898
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TableComponent, { className: "TableComponent" }); })();
|
|
859
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/table.component.ts","../../../../projects/mis-components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  OnChanges,\n  OnInit,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewChildren,\n  input,\n  output,\n  signal,\n  computed,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  untracked\n} from \"@angular/core\";\nimport { Filter, TableFilterComponent } from \"./filter/filter.component\";\nimport { SortState } from \"./sort-icons.directive\";\nimport { effect } from \"@angular/core\";\nimport { DropdownItem } from \"mis-crystal-design-system/dropdown\";\n\n@Component({\n  selector: \"mis-table\",\n  templateUrl: \"table.component.html\",\n  styleUrls: [\"table.component.css\"]\n})\nexport class TableComponent implements OnInit, AfterViewInit, OnChanges {\n  // Initialize with -1 to indicate no row is colored at the beginning\n  activeRowIndex = signal<number[]>([]);\n  hasCheckboxActions = signal<boolean>(false);\n  selectAllCheckbox = signal<boolean>(false);\n\n  // Filter related variables\n  showFilter = signal<boolean>(false);\n  filterName = signal<string>(\"\");\n  filterData = signal<Array<Filter>>([]);\n  filterContainerStyles = signal<any>({});\n  appliedFilters = signal<{ [key: string]: Array<{ name: string; value: string }> }>({});\n  \n  // Convert outputs to signal-based outputs\n  filtersUpdated = output<{\n    [key: string]: Array<{ name: string; value: string }>;\n  }>();\n\n  @ViewChild(\"filter\") filter: TableFilterComponent | any;\n  @ViewChildren(\"colHeaderRef\") colHeaders: QueryList<ElementRef> | any;\n\n  // Pagination related variables\n  pages = signal<Array<number>>([]);\n  tableLength = signal<number>(0);\n  selectedPage = signal<number>(1); // Internal state for selected page\n  private isInternalPageUpdate = false; // Flag to prevent effect from overwriting user-initiated updates\n  pageSelected = output<number>();\n  pageSizeChanged = output<number>();\n  pageSizeOptions = computed(() => {\n    const config = this.tableConfig()?.paginationConfig;\n    if (!config?.pageSizes || !Array.isArray(config.pageSizes) || !config.pageSizes?.length) return [];\n  \n    return config.pageSizes?.map(option => ({\n      label: option?.toString() || '',\n      value: option?.toString() || '',\n    })) || [];\n  });\n\n  showPageSizeDropdown = computed(() => {\n    return !!this.tableConfig()?.paginationConfig?.showPageSizeDropdown;\n  });\n\n  selectedPageSizeOption = signal<DropdownItem>({ label: \"\", value: \"\" });\n\n  // Convert inputs to signal-based inputs\n  tableConfig = input<TableConfig>();\n  subTableconfig = input<TableConfig>();\n  tableDataLoading = input<boolean>();\n  expandedIndex = input<number>();\n  tableData = input<Array<Array<any>>>([]);\n  subTableData = input<Array<Array<any>>>([]);\n  subTableDataLoading = input<boolean>();\n  currentSort = input<{column: string, direction: 'ASC' | 'DESC' | ''} | null>();\n  @ViewChild(\"table\") table: ElementRef | any;\n  collapseColIndex = signal<number>(-1);\n  previewLines = signal<number>(0);\n  rowCollapseConfigIndex = signal<number>(-1);\n  expandedMap = signal<Record<string, boolean>>({});\n\n\n  // Sorting related properties\n  multiColumnSort = signal<SortState[]>([]);\n  sortChange = output<SortState>();\n  headerAction = output<{ type: string; payload?: any }>();\n\n  \n  constructor(private renderer: Renderer2) {\n    effect(() => {\n        this.tableLength.set(this.tableData()?.length ?? 0);\n        \n        const config = this.tableConfig();\n        \n        if (config && config.activeRowIndex !== null && config.activeRowIndex !== undefined) {\n            const activeRowIndex = config.activeRowIndex;\n            this.activeRowIndex.set(Array.isArray(activeRowIndex) ? activeRowIndex : [activeRowIndex]);\n        }\n\n        if (this.rowCollapseConfigIndex() !== -1) {\n             this.buildExpandedMap();\n        }\n\n        // --- PAGINATION PAGE ARRAY LOGIC (MOVED/REPLACED initializePagination) ---\n        const len = config?.paginationConfig?.noOfPages;\n        const disablePageJumping = config?.paginationConfig?.disablePageJumping;\n        \n        // Sync selectedPage from config if provided (for when parent updates the page)\n        // Don't sync if this is an internal update (user clicked arrow) to prevent overwriting\n        if (!this.isInternalPageUpdate && config?.paginationConfig?.selectedPage !== undefined && config?.paginationConfig?.selectedPage !== null) {\n          const configSelectedPage = config.paginationConfig.selectedPage;\n          const currentSelectedPage = this.selectedPage();\n          // Only sync from config if:\n          // 1. The values are different (config has a new value)\n          // 2. The config value is valid (within page range)\n          // This prevents overwriting user-initiated updates with stale config values\n          const maxPages = config?.paginationConfig?.noOfPages || 1;\n          if (currentSelectedPage !== configSelectedPage && \n              configSelectedPage >= 1 && \n              configSelectedPage <= maxPages) {\n            this.selectedPage.set(configSelectedPage);\n          }\n        } else if (!this.isInternalPageUpdate) {\n          // If config doesn't have selectedPage, only initialize if current state is invalid\n          // Don't reset a valid page number just because config doesn't specify it\n          const currentPage = this.selectedPage();\n          if (currentPage === 0 || currentPage < 1) {\n            this.selectedPage.set(1);\n          }\n        }\n        // Reset the flag after processing\n        this.isInternalPageUpdate = false;\n        \n        // Only run if pagination is configured and page jumping is enabled\n        if (len && len > 0 && !disablePageJumping) {\n            // Read the internal state of the selected page for calculating the pages array.\n            // Since this runs on every config change, we rely on the value set \n            // by updateSelectedPage() or synced from config above.\n            const pageNumber = this.selectedPage(); \n\n            if (len <= 7) {\n                const newPages = [];\n                for (let i = 1; i <= len; i++) {\n                    newPages.push(i);\n                }\n                this.pages.set(newPages);\n            } else {\n                if (pageNumber - 2 <= 1) {\n                    this.pages.set([1, 2, 3, 4, 0, len]);\n                } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n                    this.pages.set([1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len]);\n                } else if (pageNumber + 2 >= len) {\n                    this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);\n                }\n            }\n        }\n        // --- END PAGINATION PAGE ARRAY LOGIC ---\n\n        \n        if(config?.paginationConfig?.showPageSizeDropdown) {\n          const options = this.pageSizeOptions();\n          const rowsPerPage = this.tableConfig()?.paginationConfig?.rowsPerPage;\n          \n          if (!Array.isArray(options) || !rowsPerPage) {\n            this.selectedPageSizeOption.set({ label: \"\", value: \"\" });\n            return;\n          }\n          \n          const selected = options.find(opt => opt?.value === rowsPerPage.toString());\n          if (selected) {\n            this.selectedPageSizeOption.set(selected);\n          } else if (options.length > 0) {\n            // If configured rowsPerPage is not among options, pick the floor value and notify parent\n            const target = Number(rowsPerPage);\n            //Sort the options\n            const sorted = options\n              .map(opt => ({ opt, num: Number(opt?.value) }))\n              .filter(({ num }) => Number.isFinite(num))\n              .sort((a, b) => a.num - b.num);\n\n            let floorOption = sorted[0]?.opt;\n            for (let i = sorted.length - 1; i >= 0; i--) {\n              if (sorted[i].num <= target) {\n                floorOption = sorted[i].opt;\n                break;\n              }\n            }\n            console.error(\"The configured rowsPerPage was not matched to any of the pageSizes sent in the paginationConfig. Selecting the nearest floor value among the available pageSizes.\");\n            this.selectedPageSizeOption.set(floorOption);\n            this.onPageSizeChange(floorOption);\n          } else {\n            console.error(\"No page size options available.\")\n          }\n        }\n    }, { allowSignalWrites: true });\n\n    // Reactive height calculation: maintains exact old behavior for backward compatibility\n    // Old code: height - 56 + \"px\" (flawed for percentages, but we maintain it)\n    // Note: Effect must be in constructor, not lifecycle hooks (NG0203 error otherwise)\n    // effect(() => {\n    //   const config = this.tableConfig();\n    //   if (!config?.paginationConfig || !this.table?.nativeElement) return;\n    \n    //   const height = config.height;\n    //   // Old behavior: height - 56 + \"px\" (maintains the flaw for backward compatibility)\n    //   const result = (height as any) - 56;\n    //   const finalHeight = result + \"px\";\n    //   this.renderer.setStyle(this.table.nativeElement, \"height\", finalHeight);\n    // });\n  }\n\n\n  // Function to handle row click\n  selectRow(index: number) {\n    if (this.hasCheckboxActions()) return;\n    this.activeRowIndex.set([index]); // Set the selected index to the clicked row's index\n    !!this.tableConfig().rowConfig.action && this.tableConfig().rowConfig.action(index);\n  }\n\n  ngOnInit(): void {\n    this.hasCheckboxActions.set(this.tableConfig().colConfig?.some(col => col.type === \"actions\" && col.actionType === \"checkbox\"));\n    this.tableLength.set(!!this.tableData() ? this.tableData().length : 0);\n    this.initializeFilters();\n    if (this.tableConfig().paginationConfig) {\n      this.initializePagination();\n    }\n    if (this.tableConfig().canScrollHorizontally === undefined) {\n      // Note: We can't directly modify input signals, this should be handled by parent component\n    }\n    document.addEventListener(\"click\", event => {\n      if (this.filter) {\n        let isCheckBoxClicked = true;\n        let targetElement = event.target as HTMLSpanElement;\n        if (targetElement.className === \"checkmark\") {\n          isCheckBoxClicked = true;\n          this.showFilter.set(true);\n        }\n        let isClickInsideElement = this.filter.container.nativeElement.contains(event.target);\n        if (!isClickInsideElement && !isCheckBoxClicked) {\n          this.toggleFilter(this.filterName());\n        }\n      }\n    });\n\n    // fetch collapseColIndex and previewLines if present\n    this.rowCollapseConfigIndex.set(this.tableConfig()?.colConfig?.findIndex(\n      col => col.type === 'actions' && col.actionType === 'row-collapse'\n    ));\n    if (this.rowCollapseConfigIndex() !== -1) {\n      this.collapseColIndex.set(this.tableConfig().colConfig[this.rowCollapseConfigIndex()].collapseColumnIndex ?? null);\n      this.previewLines.set(this.tableConfig().colConfig[this.rowCollapseConfigIndex()].previewLines ?? null);\n      this.buildExpandedMap();\n    }\n  }\n\n  buildExpandedMap(): void{\n    const newExpandedMap: Record<string, boolean> = {};\n    const collapseIndex = this.rowCollapseConfigIndex();\n    \n    this.tableData().forEach((row, rowIndex) => {\n        newExpandedMap[`${rowIndex}`] = row[collapseIndex];\n    });\n    this.expandedMap.set(newExpandedMap);\n}\n\n  ngAfterViewInit() {\n    // ViewChild is now available - manually trigger height calculation once\n    // The effect in constructor will handle subsequent config changes\n    const config = this.tableConfig();\n    if (config?.paginationConfig && this.table?.nativeElement) {\n      const height = config.height;\n      const result = (height as any) - 56;\n      const finalHeight = result + \"px\";\n      this.renderer.setStyle(this.table.nativeElement, \"height\", finalHeight);\n    }\n  }\n  \n  ngOnChanges() {\n    this.tableLength.set(this.tableData()?.length ?? 0);\n    if (this.tableConfig().activeRowIndex !== null && this.tableConfig().activeRowIndex !== undefined) {\n      const activeRowIndex = this.tableConfig().activeRowIndex;\n      this.activeRowIndex.set(Array.isArray(activeRowIndex) ? activeRowIndex : [activeRowIndex])\n    }\n  }\n\n  // Filter related functions\n  initializeFilters() {\n    const newAppliedFilters: { [key: string]: Array<{ name: string; value: string }> } = {};\n    const allFilters: Array<Filter> = [];\n    \n    for (let colHeader of this.tableConfig()?.colHeaderConfig) {\n      if (colHeader.filters) {\n        let filters = [];\n        for (let filter of colHeader.filters) {\n          if (filter.checked) {\n            filters.push({\n              name: filter.name,\n              value: filter.value\n            });\n          }\n          // Add all filters to the filterData array\n          allFilters.push(filter);\n        }\n        if (filters.length > 0) newAppliedFilters[colHeader.data] = filters;\n      }\n    }\n    this.appliedFilters.set(newAppliedFilters);\n    this.filterData.set(allFilters);\n }\n  toggleFilter(filterName: string) {\n    if (!this.showFilter()) {\n      this.filterName.set(filterName);\n      this.showFilter.set(true);\n\n      let offSet = 0;\n      let colHeadersReversed = this.colHeaders.toArray().reverse();\n\n      for (let header of colHeadersReversed) {\n        if (header.nativeElement.innerText === filterName) break;\n        offSet += header.nativeElement.offsetWidth;\n      }\n      this.filterContainerStyles.set({\n        top: \"44px\",\n        right: offSet > 0 ? offSet - 116 + \"px\" : \"12px\"\n      });\n    } else {\n      this.filterName.set(\"\");\n      this.filterData.set([]);\n      this.showFilter.set(false);\n    }\n  }\n  updateAppliedFilters(appliedFilters: Array<{ name: string; value: string }>) {\n    const currentFilters = this.appliedFilters();\n    if (appliedFilters.length == 0) {\n      delete currentFilters[this.filterName()];\n    } else {\n      currentFilters[this.filterName()] = appliedFilters;\n    }\n    this.appliedFilters.set({ ...currentFilters });\n    this.filtersUpdated.emit({ ...this.appliedFilters() });\n    this.toggleFilter(this.filterName());\n  }\n\n  // Pagination related functions\n  initializePagination() {\n    if (this.tableConfig().paginationConfig) {\n      // Initialize selectedPage from config if provided, otherwise default to 1\n      // const configSelectedPage = this.tableConfig().paginationConfig.selectedPage;\n      // this.selectedPage.set(configSelectedPage ?? 1);\n      \n      let len = this.tableConfig().paginationConfig.noOfPages;\n      if (len <= 7) {\n        const newPages = [];\n        for (let i = 1; i <= len; i++) {\n          newPages.push(i);\n        }\n        this.pages.set(newPages);\n      } else {\n        this.pages.set([1, 2, 3, 4, 0, len]);\n      }\n    }\n  }\n  updateSelectedPage(pageNumber: number) {\n    // Guard clause to prevent out-of-range updates\n    if (pageNumber < 1 || pageNumber > this.tableConfig().paginationConfig.noOfPages) return;\n\n    // Set flag to prevent effect from overwriting this user-initiated update\n    this.isInternalPageUpdate = true;\n\n    // Update internal selectedPage state immediately\n    this.selectedPage.set(pageNumber);\n\n    // Reset header checkbox when navigating to a different page\n    this.selectAllCheckbox.set(false);\n    \n    // Update page numbers display for pagination with many pages\n    let len = this.tableConfig().paginationConfig.noOfPages;\n    if (len > 7) {\n      if (pageNumber - 2 <= 1) {\n        this.pages.set([1, 2, 3, 4, 0, len]);\n      } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n        this.pages.set([1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len]);\n      } else if (pageNumber + 2 >= len) {\n        this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);\n      }\n    }\n    \n    // Emit to parent so they can update their config\n    this.pageSelected.emit(pageNumber);\n  }\n\n  // Main container related functions\n  getContainerHeight() {\n    if (this.tableConfig()?.height) return this.tableConfig().height;\n    else return \"\";\n  }\n  getContainerWidth() {\n    if (this.tableConfig()?.width) return this.tableConfig().width;\n    else return \"\";\n  }\n\n  // Column Headers related functions\n  getColHeadersRowStyles() {\n    const { colHeadersRowConfig } = this.tableConfig();\n    const minHeight = colHeadersRowConfig?.height || \"44px\";\n    const borderTop = (colHeadersRowConfig?.style as any)?.borderTop || \"\";\n    const borderBottom = (colHeadersRowConfig?.style as any)?.borderBottom || \"1px solid #E0E0E0\";\n    const backgroundColor = (colHeadersRowConfig?.style as any)?.backgroundColor || \"#FFFFFF\";\n    const fontSize = (colHeadersRowConfig?.style as any)?.fontSize || \"14px\";\n    return {\n      \"min-height\": minHeight,\n      \"border-top\": borderTop,\n      \"border-bottom\": borderBottom,\n      \"background-color\": backgroundColor,\n      \"font-size\": fontSize\n    };\n  }\n\n  onSortChange(sortState: SortState) {\n    // Emit the sort change to the parent component\n    this.sortChange.emit(sortState);\n    \n    // Handle multi-column sort if enabled\n    if (this.tableConfig().multiColumnSort) {\n      const currentMultiSort = this.multiColumnSort();\n      const index = currentMultiSort.findIndex(sort => sort.column === sortState.column);\n      if (index !== -1) {\n        if (sortState.direction === null) {\n          const newMultiSort = [...currentMultiSort];\n          newMultiSort.splice(index, 1);\n          this.multiColumnSort.set(newMultiSort);\n        } else {\n          const newMultiSort = [...currentMultiSort];\n          newMultiSort[index] = sortState;\n          this.multiColumnSort.set(newMultiSort);\n        }\n      } else if (sortState.direction !== null) {\n        this.multiColumnSort.set([...currentMultiSort, sortState]);\n      }\n    }\n  }\n\n  getActionsCellStyle(style: any): any {\n    if (!style) return {};\n    const { width, ...restStyle } = style;\n    return restStyle;\n  }\n\n  onActionClick(event: any, rowIndex: number): void {\n    if (event.actionType === 'checkbox') {\n      const currentActiveRows = this.activeRowIndex();\n      if (event.value) {\n        this.activeRowIndex.set([...currentActiveRows, rowIndex]);\n      } else {\n        this.activeRowIndex.set(currentActiveRows.filter(index => index !== rowIndex));\n      }\n\n      const actionInfo = this.findActionConfig('checkbox');\n      if (actionInfo && this.tableData()[rowIndex]) {\n        const { index, config } = actionInfo;\n        // Note: We can't directly modify input signals, this should be handled by parent component\n        const checkedItems = this.tableData().filter(row => row[index] === true);\n        config.action?.(checkedItems);\n      }\n\n    } else if(event.actionType === 'row-collapse'){\n      const rowCollapse = this.findActionConfig('row-collapse');\n      if (rowCollapse && this.tableData()[rowIndex]) {\n        // Note: We can't directly modify input signals, this should be handled by parent component\n        rowCollapse.config.action?.(this.tableData());\n        this.buildExpandedMap();\n      }\n    }\n  }\n\n  findActionConfig(actionType: string): { index: number, config: ColConfig } | null {\n    for (let i = 0; i < this.tableConfig().colConfig.length; i++) {\n      const col = this.tableConfig().colConfig[i];\n      if (col.type === 'actions' && col.actionType === actionType) {\n        return { index: i, config: col };\n      }\n    }\n    return null;\n  }\n  \n\n  isRowDisabled(row: any): boolean {\n    return typeof this.tableConfig().rowConfig.disableRow === \"function\" ? this.tableConfig().rowConfig.disableRow(row) : false;\n  }\n\n  toggleCheckbox() {\n    this.selectAllCheckbox.set(!this.selectAllCheckbox());\n    const checkboxColIndex = this.tableConfig().colConfig.findIndex(col => col.type === 'actions' && col.actionType === 'checkbox');\n    if (checkboxColIndex !== -1) {\n      // Note: We can't directly modify input signals, this should be handled by parent component\n      const updatedTableData = this.tableData().map((row: any[]) => {\n        const updatedRow = [...row];\n        const currentCheckbox = updatedRow[checkboxColIndex];\n        const isDisabled = this.isRowDisabled(row);\n        if (!isDisabled) {\n          updatedRow[checkboxColIndex] = this.selectAllCheckbox();\n        }\n        return updatedRow;\n      });\n      this.headerAction?.emit({\n        type: \"checkboxToggle\",\n        payload: updatedTableData\n      });\n    }\n  }\n\n\n  onPageSizeChange(selectedOption: DropdownItem) {\n    this.pageSizeChanged.emit(parseInt(selectedOption.value));\n  }\n\n  shouldShowPagination(): boolean {\n      const config = this.tableConfig()?.paginationConfig;\n      if (!config) return false;\n      const hasMultiplePages = config.noOfPages > 1;\n      const hasEnoughData = this.tableLength() > config.rowsPerPage;\n      return this.showPageSizeDropdown() || hasMultiplePages || hasEnoughData;\n  }\n}\n\nexport interface TableConfig {\n  height: string | \"100%\";\n  width: string | \"100%\";\n  paginationConfig?: PaginationConfig | undefined | null;\n  colHeadersRowConfig: RowConfig | undefined | null;\n  rowConfig: RowConfig | undefined | null;\n  colHeaderConfig: Array<ColHeaderConfig>;\n  colConfig: Array<ColConfig>;\n  canExpand?: boolean;\n  canScrollHorizontally?: boolean;\n  cellHover?: boolean;\n  activeRowIndex?: number | number[];\n  multiColumnSort?: boolean;\n}\nexport interface PaginationConfig {\n  noOfPages: number;\n  rowsPerPage: number;\n  totalNoOfRows: number;\n  selectedPage?: number;\n  disablePageJumping?: boolean;\n  showPageSizeDropdown?: boolean; // When true, rowsPerPage value should be included in pageSizes array\n  pageSizes?: number[];\n}\nexport interface RowConfig {\n  height?: string | undefined | null;\n  style?: {};\n  action?: any;\n  disableRow?: (data: any) => boolean;\n}\nexport interface ColHeaderConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"checkbox\";\n  data: any;\n  componentRef?: any;\n  filters?: Array<Filter> | null;\n  style?: {};\n  action?: any;\n  isSortable?: boolean;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\nexport interface ColConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"actions\" | \"html\";\n  componentRef?: any;\n  style?: {};\n  action?: any;\n  actionItems?: ActionItem[];\n  actionType?: \"inline\" | \"dropdown\" | \"checkbox\" | \"row-collapse\"; // inline for individual icons, dropdown for menu\n  disable?: (rowData: any) => boolean;\n  collapseColumnIndex?: number;\n  previewLines?: number;\n}\nexport interface ActionItem {\n  label: string;\n  value: string;\n  icon?: string;\n  disable?: (data: any) => boolean;\n  action?: (data: any) => void;\n  children?: ActionItem[];\n}\nexport interface InternalActionItem extends ActionItem {\n  showSubmenu?: boolean;\n}\n","<div\n  [ngStyle]=\"{\n    height: getContainerHeight(),\n    width: getContainerWidth(),\n    'overflow-x': tableConfig().canScrollHorizontally ? 'auto' : 'unset'\n  }\"\n  id=\"main-container\"\n>\n  <mis-table-filter\n    #filter\n    (filtersApplied)=\"updateAppliedFilters($event)\"\n    *ngIf=\"showFilter()\"\n    [containerStyles]=\"filterContainerStyles()\"\n    [filtersData]=\"filterData()\"\n  ></mis-table-filter>\n  <div\n    #table\n    id=\"table-container\"\n    [ngClass]=\"{ 'no-scrollbar': expandedIndex() < 0, scrollbar: !(expandedIndex() < 0), 'scroll-horizontally': tableConfig().canScrollHorizontally }\"\n  >\n    <div\n    [ngStyle]=\"getColHeadersRowStyles()\"\n      id=\"col-headers-container\"\n    >\n      <div\n        #colHeaderRef\n        (click)=\"colHeader?.action ? colHeader?.action(colHeader) : null\"\n        *ngFor=\"let colHeader of tableConfig()?.colHeaderConfig\"\n        class=\"col-header\"\n        [ngStyle]=\"{\n          width: colHeader?.style?.width || '',\n          cursor: colHeader.action ? 'pointer' : 'default',\n          'justify-content': colHeader?.style?.justifyContent\n            ? colHeader?.style?.justifyContent\n            : colHeader.type === 'number'\n            ? 'flex-end'\n            : 'space-between'\n        }\"\n      >\n        <p *ngIf=\"colHeader?.type !== 'custom' && colHeader?.type !== 'checkbox'\" class=\"col-header-text\">\n          {{ colHeader?.data || \" \" }}\n        </p>\n        <span\n          (click)=\"filterData.set(colHeader.filters); toggleFilter(colHeader.data); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type !== 'custom' && colHeader?.filters && colHeader?.filters?.length > 0\"\n          class=\"filter-icon\"\n        >\n          <span *ngIf=\"appliedFilters()[colHeader.data]?.length > 0\" id=\"filter-active\"></span>\n          <svg fill=\"none\" height=\"10\" viewBox=\"0 0 13 10\" width=\"13\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path\n              clip-rule=\"evenodd\"\n              d=\"M4.97546 10H7.64213V8H4.97546V10ZM0.308472 0V2H12.3085V0H0.308472ZM2.30847 6H10.3085V4H2.30847V6Z\"\n              fill=\"#181F33\"\n              fill-rule=\"evenodd\"\n            />\n          </svg>\n        </span>\n        <span\n          (click)=\"toggleCheckbox(); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type === 'checkbox'\"\n          class=\"checkbox-icon\"\n        >\n          <mis-checkbox [checked]=\"selectAllCheckbox()\"></mis-checkbox>\n        </span>\n        <span *ngIf=\"colHeader?.isSortable && !colHeader?.filters\" appSortIcons\n          [column]=\"colHeader\"\n          [activeSort]=\"currentSort()\"\n          [activeSorts]=\"multiColumnSort()\"\n          [multiColumnSort]=\"tableConfig().multiColumnSort\"\n          (sortChange)=\"onSortChange($event)\"\n          class=\"sort-icon\">\n        </span>\n      <ng-template *ngIf=\"colHeader?.type === 'custom'\" customTableCell [customComponent]=\"colHeader?.componentRef\" [data]=\"colHeader.data\"></ng-template>\n      </div>\n    </div>\n    \n    <div id=\"data-container\">\n      <div class=\"row-wrapper\" *ngFor=\"let row of tableData(); let i = index; let rowIndex = index\">\n        <div\n          class=\"t-row\"\n          [ngClass]=\"{ 't-row-hover': tableConfig().cellHover, 'active-row': activeRowIndex().includes(i) }\"\n          [ngStyle]=\"{ 'min-height': tableConfig()?.rowConfig?.height ? tableConfig().rowConfig.height : '44px' }\"\n          (click)=\"selectRow(i)\"\n          [class.disabled-row]=\"isRowDisabled(row)\"\n          >\n          <div\n            (click)=\"tableConfig()?.colConfig[colIndex]?.action && tableConfig()?.colConfig[colIndex]?.actionType !== 'checkbox' ? tableConfig()?.colConfig[colIndex]?.action(col) : null\"\n            *ngFor=\"let col of row; let colIndex = index\"\n            [ngStyle]=\"{\n              width: tableConfig()?.colConfig[colIndex]?.style?.width || tableConfig()?.colHeaderConfig[colIndex]?.style?.width || ''\n            }\"\n            class=\"t-col-container\"\n            [ngClass]=\"{ 't-col-container-hover': tableConfig().cellHover }\"\n          >\n            <div\n              class=\"t-col\"\n              [style]=\"tableConfig().colConfig[colIndex]?.style\"\n              [ngStyle]=\"{\n                width: '100%',\n                cursor: tableConfig().colConfig[colIndex]?.action ? 'pointer' : 'default',\n                'justify-content': tableConfig().colConfig[colIndex]?.style?.justifyContent\n                  ? tableConfig().colConfig[colIndex]?.style?.justifyContent\n                  : tableConfig().colConfig[colIndex]?.type === 'number'\n                  ? 'flex-end'\n                  : 'space-between'\n              }\"\n            >\n            <div\n            *ngIf=\"tableConfig().colConfig[colIndex]?.type !== 'custom' && tableConfig().colConfig[colIndex]?.type !== 'actions'\"\n            [ngStyle]=\"{\n              color: tableConfig()?.colConfig[colIndex]?.style?.color || '',\n              '--collapsed-lines': previewLines() || 3\n            }\"\n            [ngClass]=\"{\n              'collapsed-cell': collapseColIndex() == colIndex && expandedMap()[rowIndex]\n            }\"\n            class=\"t-col-text\"\n          >\n            <!-- Render as HTML -->\n            <ng-container *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'html'; else plainText\">\n              <span [innerHTML]=\"col\"></span>\n            </ng-container>\n          \n            <!-- Render as plain text -->\n            <ng-template #plainText>\n              <span>{{ col }}</span>\n            </ng-template>\n          </div>\n        \n              <ng-template\n                *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'custom'\"\n                [customComponent]=\"tableConfig().colConfig[colIndex].componentRef\"\n                [data]=\"col\"\n                customTableCell\n              ></ng-template>\n                <mis-actions-cell\n                  *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'actions'\"\n                  [cellData]=\"col\"\n                  [config]=\"tableConfig().colConfig[colIndex]\"\n                  (actionClick)=\"onActionClick($event, rowIndex)\"\n                  [ngClass]=\"{\n                    'disable-actions': (tableConfig().colConfig[colIndex]?.actionType === 'checkbox' || tableConfig().colConfig[colIndex]?.actionType === 'row-collapse') && isRowDisabled(row)\n                  }\"\n                ></mis-actions-cell>\n\n            </div>\n          </div>\n        </div>\n        <div *ngIf=\"tableConfig()?.canExpand && expandedIndex() === i\" class=\"sub-row\">\n          <ng-container *ngIf=\"subTableDataLoading()\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              Loading...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading() && subTableData().length === 0\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              No Data Available...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading() && subTableData().length > 0\">\n            <sub-table [config]=\"subTableconfig()\" [tableData]=\"subTableData()\"></sub-table>\n          </ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div id=\"pagination-content-container\">\n    @if(shouldShowPagination()){\n      <div \n        id=\"pagination-container\"\n      >\n        <p id=\"pagination-text\">\n          Showing\n          {{ (selectedPage() - 1) * tableConfig().paginationConfig.rowsPerPage + 1 }}-{{\n            (selectedPage() - 1) * tableConfig().paginationConfig.rowsPerPage + tableLength()\n          }}\n          of {{ tableConfig().paginationConfig.totalNoOfRows }} items\n        </p>\n        @if(showPageSizeDropdown()) {\n          <div class=\"page-size-selector\">\n            <mis-dropdown\n              [data]=\"pageSizeOptions()\"\n              [selectedItem]=\"selectedPageSizeOption()\"\n              [width]=\"'90px'\"\n              [height]=\"'32px'\"\n              [searchEnabled]=\"false\"\n              [dropdownListHeight]=\"'100px'\"\n              (onChange)=\"onPageSizeChange($event)\"\n              class=\"page-size-dropdown\"\n            ></mis-dropdown>\n          </div>\n        }\n        <div id=\"pages-container\">\n          <span   (click)=\"selectedPage() > 1 && updateSelectedPage(selectedPage() - 1)\" class=\"page\" [class.page-nav-inactive]=\"selectedPage() === 1\">\n            <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                clip-rule=\"evenodd\"\n                d=\"M0.857405 5.56295C0.855794 5.56139 0.854188 5.55982 0.852588 5.55824C0.695955 5.40408 0.617641 5.20203 0.617647 4.99998C0.617641 4.79793 0.695955 4.59588 0.852588 4.44172C0.854188 4.44014 0.855794 4.43858 0.857404 4.43702L5.13066 0.231231C5.44392 -0.0770771 5.9518 -0.0770771 6.26506 0.231231C6.57831 0.53954 6.57831 1.03941 6.26506 1.34772L2.5542 4.99998L6.26506 8.65225C6.57831 8.96055 6.57831 9.46042 6.26506 9.76873C5.9518 10.077 5.44392 10.077 5.13066 9.76873L0.857405 5.56295Z\"\n                fill=\"#181F33\"\n                fill-rule=\"evenodd\"\n              />\n            </svg>\n          </span>\n            <!-- Page numbers (only show if disablePageJumping is false) -->\n            <ng-container *ngIf=\"!tableConfig().paginationConfig?.disablePageJumping\">\n              <div *ngFor=\"let pageNumber of pages()\">\n                <span\n                  (click)=\"updateSelectedPage(pageNumber)\"\n                  *ngIf=\"pageNumber != 0\"\n                  [ngClass]=\"{ 'page-active': pageNumber === selectedPage() }\"\n                  class=\"page page-jumping-enabled\"\n                >{{ pageNumber }}</span>\n                <span *ngIf=\"pageNumber == 0\" class=\"page-seperator\">\n                  <div [ngStyle]=\"{ display: 'flex' }\">\n                    <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                    <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                    <span class=\"dot\"></span>\n                  </div>          \n                </span>\n              </div>\n            </ng-container>\n        \n          <span [class.page-nav-inactive]=\"selectedPage() === tableConfig().paginationConfig?.noOfPages\"\n          (click)=\"selectedPage() < tableConfig().paginationConfig?.noOfPages && updateSelectedPage(selectedPage() + 1)\" class=\"page\">\n            <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                clip-rule=\"evenodd\"\n                d=\"M6.1426 5.56295C6.14421 5.56139 6.14581 5.55982 6.14741 5.55824C6.30405 5.40408 6.38236 5.20203 6.38236 4.99998C6.38236 4.79793 6.30405 4.59588 6.14741 4.44172C6.14581 4.44014 6.14421 4.43858 6.1426 4.43702L1.86934 0.231231C1.55608 -0.0770771 1.0482 -0.0770771 0.734942 0.231231C0.421688 0.53954 0.421688 1.03941 0.734942 1.34772L4.4458 4.99998L0.734941 8.65225C0.421686 8.96055 0.421686 9.46042 0.734941 9.76873C1.0482 10.077 1.55608 10.077 1.86934 9.76873L6.1426 5.56295Z\"\n                fill=\"#181F33\"\n                fill-rule=\"evenodd\"\n              />\n            </svg>\n          </span>\n        </div>\n      </div>\n    }\n  </div>\n</div>\n"]}
|
|
899
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/table.component.ts","../../../../projects/mis-components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  OnChanges,\n  OnInit,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewChildren,\n  input,\n  output,\n  signal,\n  computed,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  untracked\n} from \"@angular/core\";\nimport { Filter, TableFilterComponent } from \"./filter/filter.component\";\nimport { SortState } from \"./sort-icons.directive\";\nimport { effect } from \"@angular/core\";\nimport { DropdownItem } from \"mis-crystal-design-system/dropdown\";\n\n@Component({\n  selector: \"mis-table\",\n  templateUrl: \"table.component.html\",\n  styleUrls: [\"table.component.css\"]\n})\nexport class TableComponent implements OnInit, AfterViewInit, OnChanges {\n  // Initialize with -1 to indicate no row is colored at the beginning\n  activeRowIndex = signal<number[]>([]);\n  hasCheckboxActions = signal<boolean>(false);\n  selectAllCheckbox = signal<boolean>(false);\n\n  // Filter related variables\n  showFilter = signal<boolean>(false);\n  filterName = signal<string>(\"\");\n  filterData = signal<Array<Filter>>([]);\n  filterContainerStyles = signal<any>({});\n  appliedFilters = signal<{ [key: string]: Array<{ name: string; value: string }> }>({});\n  \n  // Convert outputs to signal-based outputs\n  filtersUpdated = output<{\n    [key: string]: Array<{ name: string; value: string }>;\n  }>();\n\n  @ViewChild(\"filter\") filter: TableFilterComponent | any;\n  @ViewChildren(\"colHeaderRef\") colHeaders: QueryList<ElementRef> | any;\n\n  // Pagination related variables\n  pages = signal<Array<number>>([]);\n  tableLength = signal<number>(0);\n  selectedPage = signal<number>(1); // Internal state for selected page - this is the source of truth\n  private isInternalPageUpdate = false; // Flag to prevent effect from overwriting during user-initiated updates\n  \n  /**\n   * LEGACY CODE WORKAROUND: Track user-initiated page selections to prevent config overwrites.\n   * \n   * Some legacy parent components don't update tableConfig.paginationConfig.selectedPage when\n   * the page changes. This causes the effect to overwrite user selections with stale config values.\n   * \n   * IDEAL SOLUTION: Parent components should always update config.selectedPage in their\n   * pageSelected event handler. This workaround protects user actions until legacy code\n   * can be updated.\n   * \n   * TODO: Remove this workaround once all parent components properly update config.selectedPage\n   */\n  private userSelectedPage: number | null = null;\n  \n  pageSelected = output<number>();\n  pageSizeChanged = output<number>();\n  pageSizeOptions = computed(() => {\n    const config = this.tableConfig()?.paginationConfig;\n    if (!config?.pageSizes || !Array.isArray(config.pageSizes) || !config.pageSizes?.length) return [];\n  \n    return config.pageSizes?.map(option => ({\n      label: option?.toString() || '',\n      value: option?.toString() || '',\n    })) || [];\n  });\n\n  showPageSizeDropdown = computed(() => {\n    return !!this.tableConfig()?.paginationConfig?.showPageSizeDropdown;\n  });\n\n  selectedPageSizeOption = signal<DropdownItem>({ label: \"\", value: \"\" });\n\n  // Convert inputs to signal-based inputs\n  tableConfig = input<TableConfig>();\n  subTableconfig = input<TableConfig>();\n  tableDataLoading = input<boolean>();\n  expandedIndex = input<number>();\n  tableData = input<Array<Array<any>>>([]);\n  subTableData = input<Array<Array<any>>>([]);\n  subTableDataLoading = input<boolean>();\n  currentSort = input<{column: string, direction: 'ASC' | 'DESC' | ''} | null>();\n  @ViewChild(\"table\") table: ElementRef | any;\n  collapseColIndex = signal<number>(-1);\n  previewLines = signal<number>(0);\n  rowCollapseConfigIndex = signal<number>(-1);\n  expandedMap = signal<Record<string, boolean>>({});\n\n\n  // Sorting related properties\n  multiColumnSort = signal<SortState[]>([]);\n  sortChange = output<SortState>();\n  headerAction = output<{ type: string; payload?: any }>();\n\n  \n  constructor(private renderer: Renderer2) {\n    effect(() => {\n        this.tableLength.set(this.tableData()?.length ?? 0);\n        \n        const config = this.tableConfig();\n        \n        if (config && config.activeRowIndex !== null && config.activeRowIndex !== undefined) {\n            const activeRowIndex = config.activeRowIndex;\n            this.activeRowIndex.set(Array.isArray(activeRowIndex) ? activeRowIndex : [activeRowIndex]);\n        }\n\n        if (this.rowCollapseConfigIndex() !== -1) {\n             this.buildExpandedMap();\n        }\n\n        // --- PAGINATION PAGE ARRAY LOGIC (MOVED/REPLACED initializePagination) ---\n        const len = config?.paginationConfig?.noOfPages;\n        const disablePageJumping = config?.paginationConfig?.disablePageJumping;\n        \n        /**\n         * LEGACY CODE WORKAROUND: Protect user-initiated page selections from config overwrites.\n         * \n         * When users click pagination arrows, we update internal state immediately. However,\n         * some legacy parent components don't update config.selectedPage, causing the effect\n         * to run with stale config values that would overwrite the user's selection.\n         * \n         * Strategy: Treat internal state as source of truth for user-initiated changes.\n         * Only sync from config when it's safe (not a user-selected page).\n         * \n         * IDEAL: Parent should always update config.selectedPage in pageSelected handler.\n         */\n        const currentSelectedPage = this.selectedPage();\n        const configSelectedPage = config?.paginationConfig?.selectedPage;\n        const isUserSelectedPage = this.userSelectedPage !== null && currentSelectedPage === this.userSelectedPage;\n        \n        if (!this.isInternalPageUpdate) {\n          // Only sync from config if:\n          // 1. Config has a selectedPage value\n          // 2. Current page is NOT a user-initiated selection (protect user actions)\n          // 3. Config value is valid and different from current\n          if (configSelectedPage !== undefined && configSelectedPage !== null && !isUserSelectedPage) {\n            const maxPages = config?.paginationConfig?.noOfPages || 1;\n            if (currentSelectedPage !== configSelectedPage && \n                configSelectedPage >= 1 && \n                configSelectedPage <= maxPages) {\n              this.selectedPage.set(configSelectedPage);\n            }\n          }\n          \n          // If config doesn't have selectedPage, only initialize invalid state\n          // Never reset a valid page number, especially user-selected ones\n          if ((configSelectedPage === undefined || configSelectedPage === null) && \n              !isUserSelectedPage &&\n              (currentSelectedPage === 0 || currentSelectedPage < 1)) {\n            this.selectedPage.set(1);\n          }\n          \n          // Clear user selection tracking when config matches user's selection\n          // This indicates parent has updated config correctly\n          if (configSelectedPage === this.userSelectedPage) {\n            this.userSelectedPage = null;\n          }\n        }\n        \n        // Reset the flag after processing\n        this.isInternalPageUpdate = false;\n        \n        // Only run if pagination is configured and page jumping is enabled\n        if (len && len > 0 && !disablePageJumping) {\n            // Read the internal state of the selected page for calculating the pages array.\n            // Since this runs on every config change, we rely on the value set \n            // by updateSelectedPage() or synced from config above.\n            const pageNumber = this.selectedPage(); \n\n            if (len <= 7) {\n                const newPages = [];\n                for (let i = 1; i <= len; i++) {\n                    newPages.push(i);\n                }\n                this.pages.set(newPages);\n            } else {\n                if (pageNumber - 2 <= 1) {\n                    this.pages.set([1, 2, 3, 4, 0, len]);\n                } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n                    this.pages.set([1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len]);\n                } else if (pageNumber + 2 >= len) {\n                    this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);\n                }\n            }\n        }\n        // --- END PAGINATION PAGE ARRAY LOGIC ---\n\n        \n        if(config?.paginationConfig?.showPageSizeDropdown) {\n          const options = this.pageSizeOptions();\n          const rowsPerPage = this.tableConfig()?.paginationConfig?.rowsPerPage;\n          \n          if (!Array.isArray(options) || !rowsPerPage) {\n            this.selectedPageSizeOption.set({ label: \"\", value: \"\" });\n            return;\n          }\n          \n          const selected = options.find(opt => opt?.value === rowsPerPage.toString());\n          if (selected) {\n            this.selectedPageSizeOption.set(selected);\n          } else if (options.length > 0) {\n            // If configured rowsPerPage is not among options, pick the floor value and notify parent\n            const target = Number(rowsPerPage);\n            //Sort the options\n            const sorted = options\n              .map(opt => ({ opt, num: Number(opt?.value) }))\n              .filter(({ num }) => Number.isFinite(num))\n              .sort((a, b) => a.num - b.num);\n\n            let floorOption = sorted[0]?.opt;\n            for (let i = sorted.length - 1; i >= 0; i--) {\n              if (sorted[i].num <= target) {\n                floorOption = sorted[i].opt;\n                break;\n              }\n            }\n            console.error(\"The configured rowsPerPage was not matched to any of the pageSizes sent in the paginationConfig. Selecting the nearest floor value among the available pageSizes.\");\n            this.selectedPageSizeOption.set(floorOption);\n            this.onPageSizeChange(floorOption);\n          } else {\n            console.error(\"No page size options available.\")\n          }\n        }\n    }, { allowSignalWrites: true });\n\n    // Reactive height calculation: maintains exact old behavior for backward compatibility\n    // Old code: height - 56 + \"px\" (flawed for percentages, but we maintain it)\n    // Note: Effect must be in constructor, not lifecycle hooks (NG0203 error otherwise)\n    // effect(() => {\n    //   const config = this.tableConfig();\n    //   if (!config?.paginationConfig || !this.table?.nativeElement) return;\n    \n    //   const height = config.height;\n    //   // Old behavior: height - 56 + \"px\" (maintains the flaw for backward compatibility)\n    //   const result = (height as any) - 56;\n    //   const finalHeight = result + \"px\";\n    //   this.renderer.setStyle(this.table.nativeElement, \"height\", finalHeight);\n    // });\n  }\n\n\n  // Function to handle row click\n  selectRow(index: number) {\n    if (this.hasCheckboxActions()) return;\n    this.activeRowIndex.set([index]); // Set the selected index to the clicked row's index\n    !!this.tableConfig().rowConfig.action && this.tableConfig().rowConfig.action(index);\n  }\n\n  ngOnInit(): void {\n    this.hasCheckboxActions.set(this.tableConfig().colConfig?.some(col => col.type === \"actions\" && col.actionType === \"checkbox\"));\n    this.tableLength.set(!!this.tableData() ? this.tableData().length : 0);\n    this.initializeFilters();\n    if (this.tableConfig().paginationConfig) {\n      this.initializePagination();\n    }\n    if (this.tableConfig().canScrollHorizontally === undefined) {\n      // Note: We can't directly modify input signals, this should be handled by parent component\n    }\n    document.addEventListener(\"click\", event => {\n      if (this.filter) {\n        let isCheckBoxClicked = true;\n        let targetElement = event.target as HTMLSpanElement;\n        if (targetElement.className === \"checkmark\") {\n          isCheckBoxClicked = true;\n          this.showFilter.set(true);\n        }\n        let isClickInsideElement = this.filter.container.nativeElement.contains(event.target);\n        if (!isClickInsideElement && !isCheckBoxClicked) {\n          this.toggleFilter(this.filterName());\n        }\n      }\n    });\n\n    // fetch collapseColIndex and previewLines if present\n    this.rowCollapseConfigIndex.set(this.tableConfig()?.colConfig?.findIndex(\n      col => col.type === 'actions' && col.actionType === 'row-collapse'\n    ));\n    if (this.rowCollapseConfigIndex() !== -1) {\n      this.collapseColIndex.set(this.tableConfig().colConfig[this.rowCollapseConfigIndex()].collapseColumnIndex ?? null);\n      this.previewLines.set(this.tableConfig().colConfig[this.rowCollapseConfigIndex()].previewLines ?? null);\n      this.buildExpandedMap();\n    }\n  }\n\n  buildExpandedMap(): void{\n    const newExpandedMap: Record<string, boolean> = {};\n    const collapseIndex = this.rowCollapseConfigIndex();\n    \n    this.tableData().forEach((row, rowIndex) => {\n        newExpandedMap[`${rowIndex}`] = row[collapseIndex];\n    });\n    this.expandedMap.set(newExpandedMap);\n}\n\n  ngAfterViewInit() {\n    // ViewChild is now available - manually trigger height calculation once\n    // The effect in constructor will handle subsequent config changes\n    const config = this.tableConfig();\n    if (config?.paginationConfig && this.table?.nativeElement) {\n      const height = config.height;\n      const result = (height as any) - 56;\n      const finalHeight = result + \"px\";\n      this.renderer.setStyle(this.table.nativeElement, \"height\", finalHeight);\n    }\n  }\n  \n  ngOnChanges() {\n    this.tableLength.set(this.tableData()?.length ?? 0);\n    if (this.tableConfig().activeRowIndex !== null && this.tableConfig().activeRowIndex !== undefined) {\n      const activeRowIndex = this.tableConfig().activeRowIndex;\n      this.activeRowIndex.set(Array.isArray(activeRowIndex) ? activeRowIndex : [activeRowIndex])\n    }\n  }\n\n  // Filter related functions\n  initializeFilters() {\n    const newAppliedFilters: { [key: string]: Array<{ name: string; value: string }> } = {};\n    const allFilters: Array<Filter> = [];\n    \n    for (let colHeader of this.tableConfig()?.colHeaderConfig) {\n      if (colHeader.filters) {\n        let filters = [];\n        for (let filter of colHeader.filters) {\n          if (filter.checked) {\n            filters.push({\n              name: filter.name,\n              value: filter.value\n            });\n          }\n          // Add all filters to the filterData array\n          allFilters.push(filter);\n        }\n        if (filters.length > 0) newAppliedFilters[colHeader.data] = filters;\n      }\n    }\n    this.appliedFilters.set(newAppliedFilters);\n    this.filterData.set(allFilters);\n }\n  toggleFilter(filterName: string) {\n    if (!this.showFilter()) {\n      this.filterName.set(filterName);\n      this.showFilter.set(true);\n\n      let offSet = 0;\n      let colHeadersReversed = this.colHeaders.toArray().reverse();\n\n      for (let header of colHeadersReversed) {\n        if (header.nativeElement.innerText === filterName) break;\n        offSet += header.nativeElement.offsetWidth;\n      }\n      this.filterContainerStyles.set({\n        top: \"44px\",\n        right: offSet > 0 ? offSet - 116 + \"px\" : \"12px\"\n      });\n    } else {\n      this.filterName.set(\"\");\n      this.filterData.set([]);\n      this.showFilter.set(false);\n    }\n  }\n  updateAppliedFilters(appliedFilters: Array<{ name: string; value: string }>) {\n    const currentFilters = this.appliedFilters();\n    if (appliedFilters.length == 0) {\n      delete currentFilters[this.filterName()];\n    } else {\n      currentFilters[this.filterName()] = appliedFilters;\n    }\n    this.appliedFilters.set({ ...currentFilters });\n    this.filtersUpdated.emit({ ...this.appliedFilters() });\n    this.toggleFilter(this.filterName());\n  }\n\n  // Pagination related functions\n  initializePagination() {\n    if (this.tableConfig().paginationConfig) {\n      // Initialize selectedPage from config if provided, otherwise default to 1\n      // const configSelectedPage = this.tableConfig().paginationConfig.selectedPage;\n      // this.selectedPage.set(configSelectedPage ?? 1);\n      \n      let len = this.tableConfig().paginationConfig.noOfPages;\n      if (len <= 7) {\n        const newPages = [];\n        for (let i = 1; i <= len; i++) {\n          newPages.push(i);\n        }\n        this.pages.set(newPages);\n      } else {\n        this.pages.set([1, 2, 3, 4, 0, len]);\n      }\n    }\n  }\n  updateSelectedPage(pageNumber: number) {\n    // Guard clause to prevent out-of-range updates\n    if (pageNumber < 1 || pageNumber > this.tableConfig().paginationConfig.noOfPages) return;\n\n    /**\n     * LEGACY CODE WORKAROUND: Track user-initiated page selection.\n     * \n     * We track this to prevent the effect from overwriting user selections when\n     * legacy parent components don't update config.selectedPage. The effect will\n     * skip syncing from config while this page is marked as user-selected.\n     * \n     * IDEAL: Parent should update config.selectedPage in pageSelected handler.\n     * Once all parents do this, we can remove userSelectedPage tracking.\n     */\n    this.isInternalPageUpdate = true;\n    this.userSelectedPage = pageNumber;\n\n    // Update internal state immediately - this is the source of truth\n    this.selectedPage.set(pageNumber);\n\n    // Reset header checkbox when navigating to a different page\n    this.selectAllCheckbox.set(false);\n    \n    // Update page numbers display for pagination with many pages\n    let len = this.tableConfig().paginationConfig.noOfPages;\n    if (len > 7) {\n      if (pageNumber - 2 <= 1) {\n        this.pages.set([1, 2, 3, 4, 0, len]);\n      } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n        this.pages.set([1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len]);\n      } else if (pageNumber + 2 >= len) {\n        this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);\n      }\n    }\n    \n    // Emit to parent - they may or may not update config, but we protect our state\n    this.pageSelected.emit(pageNumber);\n  }\n\n  // Main container related functions\n  getContainerHeight() {\n    if (this.tableConfig()?.height) return this.tableConfig().height;\n    else return \"\";\n  }\n  getContainerWidth() {\n    if (this.tableConfig()?.width) return this.tableConfig().width;\n    else return \"\";\n  }\n\n  // Column Headers related functions\n  getColHeadersRowStyles() {\n    const { colHeadersRowConfig } = this.tableConfig();\n    const minHeight = colHeadersRowConfig?.height || \"44px\";\n    const borderTop = (colHeadersRowConfig?.style as any)?.borderTop || \"\";\n    const borderBottom = (colHeadersRowConfig?.style as any)?.borderBottom || \"1px solid #E0E0E0\";\n    const backgroundColor = (colHeadersRowConfig?.style as any)?.backgroundColor || \"#FFFFFF\";\n    const fontSize = (colHeadersRowConfig?.style as any)?.fontSize || \"14px\";\n    return {\n      \"min-height\": minHeight,\n      \"border-top\": borderTop,\n      \"border-bottom\": borderBottom,\n      \"background-color\": backgroundColor,\n      \"font-size\": fontSize\n    };\n  }\n\n  onSortChange(sortState: SortState) {\n    // Emit the sort change to the parent component\n    this.sortChange.emit(sortState);\n    \n    // Handle multi-column sort if enabled\n    if (this.tableConfig().multiColumnSort) {\n      const currentMultiSort = this.multiColumnSort();\n      const index = currentMultiSort.findIndex(sort => sort.column === sortState.column);\n      if (index !== -1) {\n        if (sortState.direction === null) {\n          const newMultiSort = [...currentMultiSort];\n          newMultiSort.splice(index, 1);\n          this.multiColumnSort.set(newMultiSort);\n        } else {\n          const newMultiSort = [...currentMultiSort];\n          newMultiSort[index] = sortState;\n          this.multiColumnSort.set(newMultiSort);\n        }\n      } else if (sortState.direction !== null) {\n        this.multiColumnSort.set([...currentMultiSort, sortState]);\n      }\n    }\n  }\n\n  getActionsCellStyle(style: any): any {\n    if (!style) return {};\n    const { width, ...restStyle } = style;\n    return restStyle;\n  }\n\n  onActionClick(event: any, rowIndex: number): void {\n    if (event.actionType === 'checkbox') {\n      const currentActiveRows = this.activeRowIndex();\n      if (event.value) {\n        this.activeRowIndex.set([...currentActiveRows, rowIndex]);\n      } else {\n        this.activeRowIndex.set(currentActiveRows.filter(index => index !== rowIndex));\n      }\n\n      const actionInfo = this.findActionConfig('checkbox');\n      if (actionInfo && this.tableData()[rowIndex]) {\n        const { index, config } = actionInfo;\n        // Note: We can't directly modify input signals, this should be handled by parent component\n        const checkedItems = this.tableData().filter(row => row[index] === true);\n        config.action?.(checkedItems);\n      }\n\n    } else if(event.actionType === 'row-collapse'){\n      const rowCollapse = this.findActionConfig('row-collapse');\n      if (rowCollapse && this.tableData()[rowIndex]) {\n        // Note: We can't directly modify input signals, this should be handled by parent component\n        rowCollapse.config.action?.(this.tableData());\n        this.buildExpandedMap();\n      }\n    }\n  }\n\n  findActionConfig(actionType: string): { index: number, config: ColConfig } | null {\n    for (let i = 0; i < this.tableConfig().colConfig.length; i++) {\n      const col = this.tableConfig().colConfig[i];\n      if (col.type === 'actions' && col.actionType === actionType) {\n        return { index: i, config: col };\n      }\n    }\n    return null;\n  }\n  \n\n  isRowDisabled(row: any): boolean {\n    return typeof this.tableConfig().rowConfig.disableRow === \"function\" ? this.tableConfig().rowConfig.disableRow(row) : false;\n  }\n\n  toggleCheckbox() {\n    this.selectAllCheckbox.set(!this.selectAllCheckbox());\n    const checkboxColIndex = this.tableConfig().colConfig.findIndex(col => col.type === 'actions' && col.actionType === 'checkbox');\n    if (checkboxColIndex !== -1) {\n      // Note: We can't directly modify input signals, this should be handled by parent component\n      const updatedTableData = this.tableData().map((row: any[]) => {\n        const updatedRow = [...row];\n        const currentCheckbox = updatedRow[checkboxColIndex];\n        const isDisabled = this.isRowDisabled(row);\n        if (!isDisabled) {\n          updatedRow[checkboxColIndex] = this.selectAllCheckbox();\n        }\n        return updatedRow;\n      });\n      this.headerAction?.emit({\n        type: \"checkboxToggle\",\n        payload: updatedTableData\n      });\n    }\n  }\n\n\n  onPageSizeChange(selectedOption: DropdownItem) {\n    this.pageSizeChanged.emit(parseInt(selectedOption.value));\n  }\n\n  shouldShowPagination(): boolean {\n      const config = this.tableConfig()?.paginationConfig;\n      if (!config) return false;\n      const hasMultiplePages = config.noOfPages > 1;\n      const hasEnoughData = this.tableLength() > config.rowsPerPage;\n      return this.showPageSizeDropdown() || hasMultiplePages || hasEnoughData;\n  }\n}\n\nexport interface TableConfig {\n  height: string | \"100%\";\n  width: string | \"100%\";\n  paginationConfig?: PaginationConfig | undefined | null;\n  colHeadersRowConfig: RowConfig | undefined | null;\n  rowConfig: RowConfig | undefined | null;\n  colHeaderConfig: Array<ColHeaderConfig>;\n  colConfig: Array<ColConfig>;\n  canExpand?: boolean;\n  canScrollHorizontally?: boolean;\n  cellHover?: boolean;\n  activeRowIndex?: number | number[];\n  multiColumnSort?: boolean;\n}\nexport interface PaginationConfig {\n  noOfPages: number;\n  rowsPerPage: number;\n  totalNoOfRows: number;\n  selectedPage?: number;\n  disablePageJumping?: boolean;\n  showPageSizeDropdown?: boolean; // When true, rowsPerPage value should be included in pageSizes array\n  pageSizes?: number[];\n}\nexport interface RowConfig {\n  height?: string | undefined | null;\n  style?: {};\n  action?: any;\n  disableRow?: (data: any) => boolean;\n}\nexport interface ColHeaderConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"checkbox\";\n  data: any;\n  componentRef?: any;\n  filters?: Array<Filter> | null;\n  style?: {};\n  action?: any;\n  isSortable?: boolean;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\nexport interface ColConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"actions\" | \"html\";\n  componentRef?: any;\n  style?: {};\n  action?: any;\n  actionItems?: ActionItem[];\n  actionType?: \"inline\" | \"dropdown\" | \"checkbox\" | \"row-collapse\"; // inline for individual icons, dropdown for menu\n  disable?: (rowData: any) => boolean;\n  collapseColumnIndex?: number;\n  previewLines?: number;\n}\nexport interface ActionItem {\n  label: string;\n  value: string;\n  icon?: string;\n  disable?: (data: any) => boolean;\n  action?: (data: any) => void;\n  children?: ActionItem[];\n}\nexport interface InternalActionItem extends ActionItem {\n  showSubmenu?: boolean;\n}\n","<div\n  [ngStyle]=\"{\n    height: getContainerHeight(),\n    width: getContainerWidth(),\n    'overflow-x': tableConfig().canScrollHorizontally ? 'auto' : 'unset'\n  }\"\n  id=\"main-container\"\n>\n  <mis-table-filter\n    #filter\n    (filtersApplied)=\"updateAppliedFilters($event)\"\n    *ngIf=\"showFilter()\"\n    [containerStyles]=\"filterContainerStyles()\"\n    [filtersData]=\"filterData()\"\n  ></mis-table-filter>\n  <div\n    #table\n    id=\"table-container\"\n    [ngClass]=\"{ 'no-scrollbar': expandedIndex() < 0, scrollbar: !(expandedIndex() < 0), 'scroll-horizontally': tableConfig().canScrollHorizontally }\"\n  >\n    <div\n    [ngStyle]=\"getColHeadersRowStyles()\"\n      id=\"col-headers-container\"\n    >\n      <div\n        #colHeaderRef\n        (click)=\"colHeader?.action ? colHeader?.action(colHeader) : null\"\n        *ngFor=\"let colHeader of tableConfig()?.colHeaderConfig\"\n        class=\"col-header\"\n        [ngStyle]=\"{\n          width: colHeader?.style?.width || '',\n          cursor: colHeader.action ? 'pointer' : 'default',\n          'justify-content': colHeader?.style?.justifyContent\n            ? colHeader?.style?.justifyContent\n            : colHeader.type === 'number'\n            ? 'flex-end'\n            : 'space-between'\n        }\"\n      >\n        <p *ngIf=\"colHeader?.type !== 'custom' && colHeader?.type !== 'checkbox'\" class=\"col-header-text\">\n          {{ colHeader?.data || \" \" }}\n        </p>\n        <span\n          (click)=\"filterData.set(colHeader.filters); toggleFilter(colHeader.data); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type !== 'custom' && colHeader?.filters && colHeader?.filters?.length > 0\"\n          class=\"filter-icon\"\n        >\n          <span *ngIf=\"appliedFilters()[colHeader.data]?.length > 0\" id=\"filter-active\"></span>\n          <svg fill=\"none\" height=\"10\" viewBox=\"0 0 13 10\" width=\"13\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path\n              clip-rule=\"evenodd\"\n              d=\"M4.97546 10H7.64213V8H4.97546V10ZM0.308472 0V2H12.3085V0H0.308472ZM2.30847 6H10.3085V4H2.30847V6Z\"\n              fill=\"#181F33\"\n              fill-rule=\"evenodd\"\n            />\n          </svg>\n        </span>\n        <span\n          (click)=\"toggleCheckbox(); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type === 'checkbox'\"\n          class=\"checkbox-icon\"\n        >\n          <mis-checkbox [checked]=\"selectAllCheckbox()\"></mis-checkbox>\n        </span>\n        <span *ngIf=\"colHeader?.isSortable && !colHeader?.filters\" appSortIcons\n          [column]=\"colHeader\"\n          [activeSort]=\"currentSort()\"\n          [activeSorts]=\"multiColumnSort()\"\n          [multiColumnSort]=\"tableConfig().multiColumnSort\"\n          (sortChange)=\"onSortChange($event)\"\n          class=\"sort-icon\">\n        </span>\n      <ng-template *ngIf=\"colHeader?.type === 'custom'\" customTableCell [customComponent]=\"colHeader?.componentRef\" [data]=\"colHeader.data\"></ng-template>\n      </div>\n    </div>\n    \n    <div id=\"data-container\">\n      <div class=\"row-wrapper\" *ngFor=\"let row of tableData(); let i = index; let rowIndex = index\">\n        <div\n          class=\"t-row\"\n          [ngClass]=\"{ 't-row-hover': tableConfig().cellHover, 'active-row': activeRowIndex().includes(i) }\"\n          [ngStyle]=\"{ 'min-height': tableConfig()?.rowConfig?.height ? tableConfig().rowConfig.height : '44px' }\"\n          (click)=\"selectRow(i)\"\n          [class.disabled-row]=\"isRowDisabled(row)\"\n          >\n          <div\n            (click)=\"tableConfig()?.colConfig[colIndex]?.action && tableConfig()?.colConfig[colIndex]?.actionType !== 'checkbox' ? tableConfig()?.colConfig[colIndex]?.action(col) : null\"\n            *ngFor=\"let col of row; let colIndex = index\"\n            [ngStyle]=\"{\n              width: tableConfig()?.colConfig[colIndex]?.style?.width || tableConfig()?.colHeaderConfig[colIndex]?.style?.width || ''\n            }\"\n            class=\"t-col-container\"\n            [ngClass]=\"{ 't-col-container-hover': tableConfig().cellHover }\"\n          >\n            <div\n              class=\"t-col\"\n              [style]=\"tableConfig().colConfig[colIndex]?.style\"\n              [ngStyle]=\"{\n                width: '100%',\n                cursor: tableConfig().colConfig[colIndex]?.action ? 'pointer' : 'default',\n                'justify-content': tableConfig().colConfig[colIndex]?.style?.justifyContent\n                  ? tableConfig().colConfig[colIndex]?.style?.justifyContent\n                  : tableConfig().colConfig[colIndex]?.type === 'number'\n                  ? 'flex-end'\n                  : 'space-between'\n              }\"\n            >\n            <div\n            *ngIf=\"tableConfig().colConfig[colIndex]?.type !== 'custom' && tableConfig().colConfig[colIndex]?.type !== 'actions'\"\n            [ngStyle]=\"{\n              color: tableConfig()?.colConfig[colIndex]?.style?.color || '',\n              '--collapsed-lines': previewLines() || 3\n            }\"\n            [ngClass]=\"{\n              'collapsed-cell': collapseColIndex() == colIndex && expandedMap()[rowIndex]\n            }\"\n            class=\"t-col-text\"\n          >\n            <!-- Render as HTML -->\n            <ng-container *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'html'; else plainText\">\n              <span [innerHTML]=\"col\"></span>\n            </ng-container>\n          \n            <!-- Render as plain text -->\n            <ng-template #plainText>\n              <span>{{ col }}</span>\n            </ng-template>\n          </div>\n        \n              <ng-template\n                *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'custom'\"\n                [customComponent]=\"tableConfig().colConfig[colIndex].componentRef\"\n                [data]=\"col\"\n                customTableCell\n              ></ng-template>\n                <mis-actions-cell\n                  *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'actions'\"\n                  [cellData]=\"col\"\n                  [config]=\"tableConfig().colConfig[colIndex]\"\n                  (actionClick)=\"onActionClick($event, rowIndex)\"\n                  [ngClass]=\"{\n                    'disable-actions': (tableConfig().colConfig[colIndex]?.actionType === 'checkbox' || tableConfig().colConfig[colIndex]?.actionType === 'row-collapse') && isRowDisabled(row)\n                  }\"\n                ></mis-actions-cell>\n\n            </div>\n          </div>\n        </div>\n        <div *ngIf=\"tableConfig()?.canExpand && expandedIndex() === i\" class=\"sub-row\">\n          <ng-container *ngIf=\"subTableDataLoading()\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              Loading...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading() && subTableData().length === 0\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              No Data Available...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading() && subTableData().length > 0\">\n            <sub-table [config]=\"subTableconfig()\" [tableData]=\"subTableData()\"></sub-table>\n          </ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div id=\"pagination-content-container\">\n    @if(shouldShowPagination()){\n      <div \n        id=\"pagination-container\"\n      >\n        <p id=\"pagination-text\">\n          Showing\n          {{ (selectedPage() - 1) * tableConfig().paginationConfig.rowsPerPage + 1 }}-{{\n            (selectedPage() - 1) * tableConfig().paginationConfig.rowsPerPage + tableLength()\n          }}\n          of {{ tableConfig().paginationConfig.totalNoOfRows }} items\n        </p>\n        @if(showPageSizeDropdown()) {\n          <div class=\"page-size-selector\">\n            <mis-dropdown\n              [data]=\"pageSizeOptions()\"\n              [selectedItem]=\"selectedPageSizeOption()\"\n              [width]=\"'90px'\"\n              [height]=\"'32px'\"\n              [searchEnabled]=\"false\"\n              [dropdownListHeight]=\"'100px'\"\n              (onChange)=\"onPageSizeChange($event)\"\n              class=\"page-size-dropdown\"\n            ></mis-dropdown>\n          </div>\n        }\n        <div id=\"pages-container\">\n          <span   (click)=\"selectedPage() > 1 && updateSelectedPage(selectedPage() - 1)\" class=\"page\" [class.page-nav-inactive]=\"selectedPage() === 1\">\n            <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                clip-rule=\"evenodd\"\n                d=\"M0.857405 5.56295C0.855794 5.56139 0.854188 5.55982 0.852588 5.55824C0.695955 5.40408 0.617641 5.20203 0.617647 4.99998C0.617641 4.79793 0.695955 4.59588 0.852588 4.44172C0.854188 4.44014 0.855794 4.43858 0.857404 4.43702L5.13066 0.231231C5.44392 -0.0770771 5.9518 -0.0770771 6.26506 0.231231C6.57831 0.53954 6.57831 1.03941 6.26506 1.34772L2.5542 4.99998L6.26506 8.65225C6.57831 8.96055 6.57831 9.46042 6.26506 9.76873C5.9518 10.077 5.44392 10.077 5.13066 9.76873L0.857405 5.56295Z\"\n                fill=\"#181F33\"\n                fill-rule=\"evenodd\"\n              />\n            </svg>\n          </span>\n            <!-- Page numbers (only show if disablePageJumping is false) -->\n            <ng-container *ngIf=\"!tableConfig().paginationConfig?.disablePageJumping\">\n              <div *ngFor=\"let pageNumber of pages()\">\n                <span\n                  (click)=\"updateSelectedPage(pageNumber)\"\n                  *ngIf=\"pageNumber != 0\"\n                  [ngClass]=\"{ 'page-active': pageNumber === selectedPage() }\"\n                  class=\"page page-jumping-enabled\"\n                >{{ pageNumber }}</span>\n                <span *ngIf=\"pageNumber == 0\" class=\"page-seperator\">\n                  <div [ngStyle]=\"{ display: 'flex' }\">\n                    <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                    <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                    <span class=\"dot\"></span>\n                  </div>          \n                </span>\n              </div>\n            </ng-container>\n        \n          <span [class.page-nav-inactive]=\"selectedPage() === tableConfig().paginationConfig?.noOfPages\"\n          (click)=\"selectedPage() < tableConfig().paginationConfig?.noOfPages && updateSelectedPage(selectedPage() + 1)\" class=\"page\">\n            <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                clip-rule=\"evenodd\"\n                d=\"M6.1426 5.56295C6.14421 5.56139 6.14581 5.55982 6.14741 5.55824C6.30405 5.40408 6.38236 5.20203 6.38236 4.99998C6.38236 4.79793 6.30405 4.59588 6.14741 4.44172C6.14581 4.44014 6.14421 4.43858 6.1426 4.43702L1.86934 0.231231C1.55608 -0.0770771 1.0482 -0.0770771 0.734942 0.231231C0.421688 0.53954 0.421688 1.03941 0.734942 1.34772L4.4458 4.99998L0.734941 8.65225C0.421686 8.96055 0.421686 9.46042 0.734941 9.76873C1.0482 10.077 1.55608 10.077 1.86934 9.76873L6.1426 5.56295Z\"\n                fill=\"#181F33\"\n                fill-rule=\"evenodd\"\n              />\n            </svg>\n          </span>\n        </div>\n      </div>\n    }\n  </div>\n</div>\n"]}
|
|
@@ -371,8 +371,21 @@ class TableComponent {
|
|
|
371
371
|
// Pagination related variables
|
|
372
372
|
this.pages = signal([]);
|
|
373
373
|
this.tableLength = signal(0);
|
|
374
|
-
this.selectedPage = signal(1); // Internal state for selected page
|
|
375
|
-
this.isInternalPageUpdate = false; // Flag to prevent effect from overwriting user-initiated updates
|
|
374
|
+
this.selectedPage = signal(1); // Internal state for selected page - this is the source of truth
|
|
375
|
+
this.isInternalPageUpdate = false; // Flag to prevent effect from overwriting during user-initiated updates
|
|
376
|
+
/**
|
|
377
|
+
* LEGACY CODE WORKAROUND: Track user-initiated page selections to prevent config overwrites.
|
|
378
|
+
*
|
|
379
|
+
* Some legacy parent components don't update tableConfig.paginationConfig.selectedPage when
|
|
380
|
+
* the page changes. This causes the effect to overwrite user selections with stale config values.
|
|
381
|
+
*
|
|
382
|
+
* IDEAL SOLUTION: Parent components should always update config.selectedPage in their
|
|
383
|
+
* pageSelected event handler. This workaround protects user actions until legacy code
|
|
384
|
+
* can be updated.
|
|
385
|
+
*
|
|
386
|
+
* TODO: Remove this workaround once all parent components properly update config.selectedPage
|
|
387
|
+
*/
|
|
388
|
+
this.userSelectedPage = null;
|
|
376
389
|
this.pageSelected = output();
|
|
377
390
|
this.pageSizeChanged = output();
|
|
378
391
|
this.pageSizeOptions = computed(() => {
|
|
@@ -418,29 +431,46 @@ class TableComponent {
|
|
|
418
431
|
// --- PAGINATION PAGE ARRAY LOGIC (MOVED/REPLACED initializePagination) ---
|
|
419
432
|
const len = config?.paginationConfig?.noOfPages;
|
|
420
433
|
const disablePageJumping = config?.paginationConfig?.disablePageJumping;
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
434
|
+
/**
|
|
435
|
+
* LEGACY CODE WORKAROUND: Protect user-initiated page selections from config overwrites.
|
|
436
|
+
*
|
|
437
|
+
* When users click pagination arrows, we update internal state immediately. However,
|
|
438
|
+
* some legacy parent components don't update config.selectedPage, causing the effect
|
|
439
|
+
* to run with stale config values that would overwrite the user's selection.
|
|
440
|
+
*
|
|
441
|
+
* Strategy: Treat internal state as source of truth for user-initiated changes.
|
|
442
|
+
* Only sync from config when it's safe (not a user-selected page).
|
|
443
|
+
*
|
|
444
|
+
* IDEAL: Parent should always update config.selectedPage in pageSelected handler.
|
|
445
|
+
*/
|
|
446
|
+
const currentSelectedPage = this.selectedPage();
|
|
447
|
+
const configSelectedPage = config?.paginationConfig?.selectedPage;
|
|
448
|
+
const isUserSelectedPage = this.userSelectedPage !== null && currentSelectedPage === this.userSelectedPage;
|
|
449
|
+
if (!this.isInternalPageUpdate) {
|
|
426
450
|
// Only sync from config if:
|
|
427
|
-
// 1.
|
|
428
|
-
// 2.
|
|
429
|
-
//
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
451
|
+
// 1. Config has a selectedPage value
|
|
452
|
+
// 2. Current page is NOT a user-initiated selection (protect user actions)
|
|
453
|
+
// 3. Config value is valid and different from current
|
|
454
|
+
if (configSelectedPage !== undefined && configSelectedPage !== null && !isUserSelectedPage) {
|
|
455
|
+
const maxPages = config?.paginationConfig?.noOfPages || 1;
|
|
456
|
+
if (currentSelectedPage !== configSelectedPage &&
|
|
457
|
+
configSelectedPage >= 1 &&
|
|
458
|
+
configSelectedPage <= maxPages) {
|
|
459
|
+
this.selectedPage.set(configSelectedPage);
|
|
460
|
+
}
|
|
435
461
|
}
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
if (currentPage === 0 || currentPage < 1) {
|
|
462
|
+
// If config doesn't have selectedPage, only initialize invalid state
|
|
463
|
+
// Never reset a valid page number, especially user-selected ones
|
|
464
|
+
if ((configSelectedPage === undefined || configSelectedPage === null) &&
|
|
465
|
+
!isUserSelectedPage &&
|
|
466
|
+
(currentSelectedPage === 0 || currentSelectedPage < 1)) {
|
|
442
467
|
this.selectedPage.set(1);
|
|
443
468
|
}
|
|
469
|
+
// Clear user selection tracking when config matches user's selection
|
|
470
|
+
// This indicates parent has updated config correctly
|
|
471
|
+
if (configSelectedPage === this.userSelectedPage) {
|
|
472
|
+
this.userSelectedPage = null;
|
|
473
|
+
}
|
|
444
474
|
}
|
|
445
475
|
// Reset the flag after processing
|
|
446
476
|
this.isInternalPageUpdate = false;
|
|
@@ -664,9 +694,19 @@ class TableComponent {
|
|
|
664
694
|
// Guard clause to prevent out-of-range updates
|
|
665
695
|
if (pageNumber < 1 || pageNumber > this.tableConfig().paginationConfig.noOfPages)
|
|
666
696
|
return;
|
|
667
|
-
|
|
697
|
+
/**
|
|
698
|
+
* LEGACY CODE WORKAROUND: Track user-initiated page selection.
|
|
699
|
+
*
|
|
700
|
+
* We track this to prevent the effect from overwriting user selections when
|
|
701
|
+
* legacy parent components don't update config.selectedPage. The effect will
|
|
702
|
+
* skip syncing from config while this page is marked as user-selected.
|
|
703
|
+
*
|
|
704
|
+
* IDEAL: Parent should update config.selectedPage in pageSelected handler.
|
|
705
|
+
* Once all parents do this, we can remove userSelectedPage tracking.
|
|
706
|
+
*/
|
|
668
707
|
this.isInternalPageUpdate = true;
|
|
669
|
-
|
|
708
|
+
this.userSelectedPage = pageNumber;
|
|
709
|
+
// Update internal state immediately - this is the source of truth
|
|
670
710
|
this.selectedPage.set(pageNumber);
|
|
671
711
|
// Reset header checkbox when navigating to a different page
|
|
672
712
|
this.selectAllCheckbox.set(false);
|
|
@@ -683,7 +723,7 @@ class TableComponent {
|
|
|
683
723
|
this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);
|
|
684
724
|
}
|
|
685
725
|
}
|
|
686
|
-
// Emit to parent
|
|
726
|
+
// Emit to parent - they may or may not update config, but we protect our state
|
|
687
727
|
this.pageSelected.emit(pageNumber);
|
|
688
728
|
}
|
|
689
729
|
// Main container related functions
|