mis-crystal-design-system 18.1.11 → 18.1.13-test-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/filter/filter-panel/filter-panel.component.mjs +4 -5
- package/esm2022/mobile-filter/mobile-filter.component.mjs +21 -8
- package/esm2022/table/table.component.mjs +66 -25
- package/fesm2022/mis-crystal-design-system-filter.mjs +3 -4
- package/fesm2022/mis-crystal-design-system-filter.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-mobile-filter.mjs +20 -7
- package/fesm2022/mis-crystal-design-system-mobile-filter.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +65 -24
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/mobile-filter/mobile-filter.component.d.ts +2 -1
- package/package.json +18 -18
- package/styles/mis-old-icon-styles.scss +5 -5
- package/table/table.component.d.ts +11 -0
|
@@ -776,19 +776,20 @@ export class TableComponent {
|
|
|
776
776
|
}
|
|
777
777
|
onActionClick(event, rowIndex) {
|
|
778
778
|
if (event.actionType === 'checkbox') {
|
|
779
|
-
const currentActiveRows = this.activeRowIndex();
|
|
780
|
-
if (event.value) {
|
|
781
|
-
this.activeRowIndex.set([...currentActiveRows, rowIndex]);
|
|
782
|
-
}
|
|
783
|
-
else {
|
|
784
|
-
this.activeRowIndex.set(currentActiveRows.filter(index => index !== rowIndex));
|
|
785
|
-
}
|
|
786
779
|
const actionInfo = this.findActionConfig('checkbox');
|
|
787
780
|
if (actionInfo && this.tableData()[rowIndex]) {
|
|
788
781
|
const { index, config } = actionInfo;
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
782
|
+
const currentActiveRows = this.activeRowIndex();
|
|
783
|
+
// Calculate new checked row indices
|
|
784
|
+
const checkedRowIndices = event.value
|
|
785
|
+
? [...currentActiveRows, rowIndex]
|
|
786
|
+
: currentActiveRows.filter(i => i !== rowIndex);
|
|
787
|
+
// Update checkbox state and get updated tableData
|
|
788
|
+
const updatedTableData = this.updateCheckboxState(checkedRowIndices, index);
|
|
789
|
+
// Build checkedItems from updated tableData - preserve ALL columns
|
|
790
|
+
const checkedItems = this.buildCheckedItems(checkedRowIndices, updatedTableData);
|
|
791
|
+
// Call action with all checked items (all columns preserved)
|
|
792
|
+
config.action?.(checkedItems, rowIndex);
|
|
792
793
|
}
|
|
793
794
|
}
|
|
794
795
|
else if (event.actionType === 'row-collapse') {
|
|
@@ -812,24 +813,64 @@ export class TableComponent {
|
|
|
812
813
|
isRowDisabled(row) {
|
|
813
814
|
return typeof this.tableConfig().rowConfig.disableRow === "function" ? this.tableConfig().rowConfig.disableRow(row) : false;
|
|
814
815
|
}
|
|
816
|
+
/**
|
|
817
|
+
* Updates activeRowIndex and calculates updated tableData based on checkbox state
|
|
818
|
+
* This is the single source of truth for checkbox state management
|
|
819
|
+
* Preserves checkbox state for disabled rows
|
|
820
|
+
*/
|
|
821
|
+
updateCheckboxState(checkedRowIndices, checkboxColIndex) {
|
|
822
|
+
const currentData = this.tableData();
|
|
823
|
+
// Update activeRowIndex
|
|
824
|
+
this.activeRowIndex.set(checkedRowIndices);
|
|
825
|
+
// Calculate updated tableData - child is single source of truth
|
|
826
|
+
const updatedTableData = currentData.map((row, i) => {
|
|
827
|
+
const rowCopy = Array.from(row);
|
|
828
|
+
const isDisabled = this.isRowDisabled(row);
|
|
829
|
+
// Only update checkbox state for non-disabled rows
|
|
830
|
+
// Disabled rows preserve their original checkbox state
|
|
831
|
+
if (!isDisabled) {
|
|
832
|
+
rowCopy[checkboxColIndex] = checkedRowIndices.includes(i);
|
|
833
|
+
}
|
|
834
|
+
// else: keep original checkbox state (rowCopy[checkboxColIndex] remains unchanged)
|
|
835
|
+
return rowCopy;
|
|
836
|
+
});
|
|
837
|
+
// Emit updated tableData to parent
|
|
838
|
+
this.headerAction?.emit({
|
|
839
|
+
type: "checkboxToggle",
|
|
840
|
+
payload: updatedTableData
|
|
841
|
+
});
|
|
842
|
+
return updatedTableData;
|
|
843
|
+
}
|
|
844
|
+
/**
|
|
845
|
+
* Builds checkedItems array from checked row indices and updated tableData
|
|
846
|
+
* Preserves ALL columns in each checked item
|
|
847
|
+
*/
|
|
848
|
+
buildCheckedItems(checkedRowIndices, updatedTableData) {
|
|
849
|
+
return checkedRowIndices
|
|
850
|
+
.map(checkedIndex => {
|
|
851
|
+
const row = updatedTableData[checkedIndex];
|
|
852
|
+
if (row) {
|
|
853
|
+
// Return full row with ALL columns: [checkbox, col1, col2, ...]
|
|
854
|
+
return [...row];
|
|
855
|
+
}
|
|
856
|
+
return null;
|
|
857
|
+
})
|
|
858
|
+
.filter(row => row !== null);
|
|
859
|
+
}
|
|
815
860
|
toggleCheckbox() {
|
|
816
861
|
this.selectAllCheckbox.set(!this.selectAllCheckbox());
|
|
817
862
|
const checkboxColIndex = this.tableConfig().colConfig.findIndex(col => col.type === 'actions' && col.actionType === 'checkbox');
|
|
818
863
|
if (checkboxColIndex !== -1) {
|
|
819
|
-
|
|
820
|
-
const
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
this.headerAction?.emit({
|
|
830
|
-
type: "checkboxToggle",
|
|
831
|
-
payload: updatedTableData
|
|
832
|
-
});
|
|
864
|
+
const isSelectAll = this.selectAllCheckbox();
|
|
865
|
+
const currentData = this.tableData();
|
|
866
|
+
// Calculate checked row indices based on select all/deselect all
|
|
867
|
+
const checkedRowIndices = isSelectAll
|
|
868
|
+
? currentData
|
|
869
|
+
.map((row, index) => this.isRowDisabled(row) ? -1 : index)
|
|
870
|
+
.filter(index => index !== -1)
|
|
871
|
+
: [];
|
|
872
|
+
// Update checkbox state and get updated tableData
|
|
873
|
+
this.updateCheckboxState(checkedRowIndices, checkboxColIndex);
|
|
833
874
|
}
|
|
834
875
|
}
|
|
835
876
|
onPageSizeChange(selectedOption) {
|
|
@@ -896,4 +937,4 @@ export class TableComponent {
|
|
|
896
937
|
args: ["table"]
|
|
897
938
|
}] }); })();
|
|
898
939
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TableComponent, { className: "TableComponent" }); })();
|
|
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"]}
|
|
940
|
+
//# 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 actionInfo = this.findActionConfig('checkbox');\n      if (actionInfo && this.tableData()[rowIndex]) {\n        const { index, config } = actionInfo;\n        const currentActiveRows = this.activeRowIndex();\n        \n        // Calculate new checked row indices\n        const checkedRowIndices = event.value\n          ? [...currentActiveRows, rowIndex]\n          : currentActiveRows.filter(i => i !== rowIndex);\n        \n        // Update checkbox state and get updated tableData\n        const updatedTableData = this.updateCheckboxState(checkedRowIndices, index);\n        \n        // Build checkedItems from updated tableData - preserve ALL columns\n        const checkedItems = this.buildCheckedItems(checkedRowIndices, updatedTableData);\n        \n        // Call action with all checked items (all columns preserved)\n        config.action?.(checkedItems, rowIndex);\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  /**\n   * Updates activeRowIndex and calculates updated tableData based on checkbox state\n   * This is the single source of truth for checkbox state management\n   * Preserves checkbox state for disabled rows\n   */\n  private updateCheckboxState(checkedRowIndices: number[], checkboxColIndex: number): any[][] {\n    const currentData = this.tableData();\n    \n    // Update activeRowIndex\n    this.activeRowIndex.set(checkedRowIndices);\n    \n    // Calculate updated tableData - child is single source of truth\n    const updatedTableData = currentData.map((row, i) => {\n      const rowCopy = Array.from(row);\n      const isDisabled = this.isRowDisabled(row);\n      \n      // Only update checkbox state for non-disabled rows\n      // Disabled rows preserve their original checkbox state\n      if (!isDisabled) {\n        rowCopy[checkboxColIndex] = checkedRowIndices.includes(i);\n      }\n      // else: keep original checkbox state (rowCopy[checkboxColIndex] remains unchanged)\n      \n      return rowCopy;\n    });\n    \n    // Emit updated tableData to parent\n    this.headerAction?.emit({\n      type: \"checkboxToggle\",\n      payload: updatedTableData\n    });\n    \n    return updatedTableData;\n  }\n\n  /**\n   * Builds checkedItems array from checked row indices and updated tableData\n   * Preserves ALL columns in each checked item\n   */\n  private buildCheckedItems(checkedRowIndices: number[], updatedTableData: any[][]): any[][] {\n    return checkedRowIndices\n      .map(checkedIndex => {\n        const row = updatedTableData[checkedIndex];\n        if (row) {\n          // Return full row with ALL columns: [checkbox, col1, col2, ...]\n          return [...row];\n        }\n        return null;\n      })\n      .filter(row => row !== null) as any[][];\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      const isSelectAll = this.selectAllCheckbox();\n      const currentData = this.tableData();\n      \n      // Calculate checked row indices based on select all/deselect all\n      const checkedRowIndices = isSelectAll\n        ? currentData\n            .map((row, index) => this.isRowDisabled(row) ? -1 : index)\n            .filter(index => index !== -1)\n        : [];\n      \n      // Update checkbox state and get updated tableData\n      this.updateCheckboxState(checkedRowIndices, checkboxColIndex);\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"]}
|
|
@@ -271,7 +271,7 @@ function FilterPanelComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
|
271
271
|
i0.ɵɵadvance();
|
|
272
272
|
i0.ɵɵproperty("ngForOf", ctx_r1.config());
|
|
273
273
|
i0.ɵɵadvance(2);
|
|
274
|
-
i0.ɵɵproperty("name", "
|
|
274
|
+
i0.ɵɵproperty("name", "Reset")("size", "Small")("type", "Text");
|
|
275
275
|
i0.ɵɵadvance();
|
|
276
276
|
i0.ɵɵproperty("name", "Apply")("size", "Small")("type", "Solid")("disabled", ctx_r1.filterForm.invalid);
|
|
277
277
|
} }
|
|
@@ -459,8 +459,7 @@ class FilterPanelComponent {
|
|
|
459
459
|
cfg.forEach(filter => {
|
|
460
460
|
const value = cleanData[filter.key];
|
|
461
461
|
if (filter.type === 'multiSelect' && Array.isArray(value)) {
|
|
462
|
-
|
|
463
|
-
cleanData[filter.key] = value.map((v) => v?.value || v);
|
|
462
|
+
cleanData[filter.key] = value;
|
|
464
463
|
}
|
|
465
464
|
});
|
|
466
465
|
return cleanData;
|
|
@@ -562,7 +561,7 @@ class FilterPanelComponent {
|
|
|
562
561
|
}
|
|
563
562
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FilterPanelComponent, [{
|
|
564
563
|
type: Component,
|
|
565
|
-
args: [{ selector: 'mis-filter-panel', animations: [slideFromRight], template: "<div class=\"filter-panel-container\" *ngIf=\"show()\" @slideFromRight>\n <div class=\"panel-header\">\n <span>Filters</span>\n <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"ic-navigation-cancel-24\">\n <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\" />\n </g>\n </svg>\n </div>\n \n <div class=\"horizontal-divider first\"></div>\n \n <div class=\"filters\" [formGroup]=\"filterForm\">\n <ng-container *ngFor=\"let filter of config(); let last = last\">\n <div class=\"filter\" *ngIf=\"!filter.hidden\">\n <span class=\"filter-title\">{{filter.title}}</span>\n <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n <div class=\"multiselect-filter\">\n <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key)?.value || []\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'select'\">\n <div class=\"multiselect-filter\">\n <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key)?.value\">\n </mis-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'checkbox'\">\n <div class=\"checkbox-row\">\n <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key)?.value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n <span class=\"checkbox-label\">{{option.label}}</span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'datePicker'\">\n <mis-input type=\"rounded\">\n <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datePickerConfig\" [placeholder]=\"filterForm.get(filter.key)?.value || filter.placeholder || 'Select'\" [value]=\"filterForm.get(filter.key)?.value || filter.placeholder || 'Select'\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key)?.value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n <mis-input type=\"rounded\">\n <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n [placeholder]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\"\n [value]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\" [positionX]=\"'start'\"\n [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates()\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n [dpConfig]=\"filter.dateRangePickerConfig\" />\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'text'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'number'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'range'\">\n <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"min\"\n />\n </div>\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"max\"\n [min]=\"filterForm.get(filter.key)?.get('min')?.value || 0\"\n />\n </div>\n </div>\n </ng-container>\n <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n </div>\n </ng-container>\n </div>\n \n <div class=\"actions\">\n <mis-button [name]=\"'Clear All'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n </div>\n </div>", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.filter-panel-container{display:flex;flex-direction:column;height:100%;max-width:100%;min-width:20rem;position:absolute;right:0;background:var(--bg-primary, #FFFFFF);top:0;z-index:999;box-shadow:0 0 5px #000000a6;transition:all .3s ease}.filter-panel-container .panel-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;font-weight:700;margin:0 1rem;flex-basis:5%}.filter-panel-container .panel-header span{font-size:1.25rem}.filter-panel-container .panel-header .close-icon{cursor:pointer;border-radius:50%;transform:scale(1.4);padding:.3rem;transition:all .3s ease}.filter-panel-container .panel-header .close-icon:hover{background:var(--bg-tertiary, #F5F5F5)}.filter-panel-container .panel-header .close-icon:active{background:var(--border-primary, #E0E0E0)}.filter-panel-container .mat-divider.horizontal{margin:1rem}.filters{display:flex;flex-direction:column;flex:1;row-gap:.5rem;overflow:auto;padding:0 1rem}.filters .filter{display:flex;flex-direction:column}.filters .filter .filter-title{color:var(--text-secondary, #6A737D);font-size:.875rem;font-weight:700;line-height:20px;letter-spacing:.25px}.filters .filter .checkbox-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:.8rem 0}.filters .filter .checkbox-row .checkbox-container{display:flex;flex-direction:row;align-items:center;gap:.5rem}.filters .filter .checkbox-row .checkbox-label{display:block;width:8rem}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-inner-container{width:20px;height:20px}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-frame{border-radius:5px}.filters .filter .multiselect-filter,.filters .filter mis-input{padding:.7rem 0}.horizontal-divider{display:block;width:100%;height:1px;margin:.5rem 0;background:var(--border-primary, #E0E0E0)}.first{margin-top:0}.actions{display:flex;flex-direction:row;justify-content:end;align-items:center;gap:1rem;border-top:1px solid var(--border-primary, #E0E0E0);flex-basis:4%;padding:.5rem}.actions button{font-weight:700;border-radius:.5rem;width:6rem}.no-padding ::ng-deep .container{padding:0!important}.range-container{display:flex;justify-content:space-between;padding:.8rem 0}.range-container .range-inner-container{display:flex;flex-direction:column}.range-container .range-inner-container input{height:2.2rem;outline:none;border-radius:.375rem;border:1px solid var(--border-primary, #E0E0E0);width:8rem;padding:0 .5rem}.range-container .range-inner-container span{margin-bottom:.2rem}input.ng-invalid.ng-touched{border:1px solid var(--brand-error, #B00020);background-color:var(--brand-error-lightest, #FDF2F2)}\n"] }]
|
|
564
|
+
args: [{ selector: 'mis-filter-panel', animations: [slideFromRight], template: "<div class=\"filter-panel-container\" *ngIf=\"show()\" @slideFromRight>\n <div class=\"panel-header\">\n <span>Filters</span>\n <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"ic-navigation-cancel-24\">\n <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\" />\n </g>\n </svg>\n </div>\n \n <div class=\"horizontal-divider first\"></div>\n \n <div class=\"filters\" [formGroup]=\"filterForm\">\n <ng-container *ngFor=\"let filter of config(); let last = last\">\n <div class=\"filter\" *ngIf=\"!filter.hidden\">\n <span class=\"filter-title\">{{filter.title}}</span>\n <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n <div class=\"multiselect-filter\">\n <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key)?.value || []\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'select'\">\n <div class=\"multiselect-filter\">\n <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key)?.value\">\n </mis-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'checkbox'\">\n <div class=\"checkbox-row\">\n <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key)?.value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n <span class=\"checkbox-label\">{{option.label}}</span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'datePicker'\">\n <mis-input type=\"rounded\">\n <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datePickerConfig\" [placeholder]=\"filterForm.get(filter.key)?.value || filter.placeholder || 'Select'\" [value]=\"filterForm.get(filter.key)?.value || filter.placeholder || 'Select'\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key)?.value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n <mis-input type=\"rounded\">\n <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n [placeholder]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\"\n [value]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\" [positionX]=\"'start'\"\n [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates()\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n [dpConfig]=\"filter.dateRangePickerConfig\" />\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'text'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'number'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'range'\">\n <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"min\"\n />\n </div>\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"max\"\n [min]=\"filterForm.get(filter.key)?.get('min')?.value || 0\"\n />\n </div>\n </div>\n </ng-container>\n <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n </div>\n </ng-container>\n </div>\n \n <div class=\"actions\">\n <mis-button [name]=\"'Reset'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n </div>\n </div>", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.filter-panel-container{display:flex;flex-direction:column;height:100%;max-width:100%;min-width:20rem;position:absolute;right:0;background:var(--bg-primary, #FFFFFF);top:0;z-index:999;box-shadow:0 0 5px #000000a6;transition:all .3s ease}.filter-panel-container .panel-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;font-weight:700;margin:0 1rem;flex-basis:5%}.filter-panel-container .panel-header span{font-size:1.25rem}.filter-panel-container .panel-header .close-icon{cursor:pointer;border-radius:50%;transform:scale(1.4);padding:.3rem;transition:all .3s ease}.filter-panel-container .panel-header .close-icon:hover{background:var(--bg-tertiary, #F5F5F5)}.filter-panel-container .panel-header .close-icon:active{background:var(--border-primary, #E0E0E0)}.filter-panel-container .mat-divider.horizontal{margin:1rem}.filters{display:flex;flex-direction:column;flex:1;row-gap:.5rem;overflow:auto;padding:0 1rem}.filters .filter{display:flex;flex-direction:column}.filters .filter .filter-title{color:var(--text-secondary, #6A737D);font-size:.875rem;font-weight:700;line-height:20px;letter-spacing:.25px}.filters .filter .checkbox-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:.8rem 0}.filters .filter .checkbox-row .checkbox-container{display:flex;flex-direction:row;align-items:center;gap:.5rem}.filters .filter .checkbox-row .checkbox-label{display:block;width:8rem}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-inner-container{width:20px;height:20px}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-frame{border-radius:5px}.filters .filter .multiselect-filter,.filters .filter mis-input{padding:.7rem 0}.horizontal-divider{display:block;width:100%;height:1px;margin:.5rem 0;background:var(--border-primary, #E0E0E0)}.first{margin-top:0}.actions{display:flex;flex-direction:row;justify-content:end;align-items:center;gap:1rem;border-top:1px solid var(--border-primary, #E0E0E0);flex-basis:4%;padding:.5rem}.actions button{font-weight:700;border-radius:.5rem;width:6rem}.no-padding ::ng-deep .container{padding:0!important}.range-container{display:flex;justify-content:space-between;padding:.8rem 0}.range-container .range-inner-container{display:flex;flex-direction:column}.range-container .range-inner-container input{height:2.2rem;outline:none;border-radius:.375rem;border:1px solid var(--border-primary, #E0E0E0);width:8rem;padding:0 .5rem}.range-container .range-inner-container span{margin-bottom:.2rem}input.ng-invalid.ng-touched{border:1px solid var(--brand-error, #B00020);background-color:var(--brand-error-lightest, #FDF2F2)}\n"] }]
|
|
566
565
|
}], () => [{ type: HasValuePipe }], null); })();
|
|
567
566
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FilterPanelComponent, { className: "FilterPanelComponent" }); })();
|
|
568
567
|
|