ms-data-grid 0.0.77 → 0.0.78

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.
@@ -884,15 +884,21 @@ export class DataGridComponent {
884
884
  // this.dateFormat = user?.date_format;
885
885
  if (!this.dateFormat) {
886
886
  const storedDateFormat = localStorage.getItem('dateformat');
887
- this.dateFormat = storedDateFormat ? JSON.parse(storedDateFormat) : 'dd/MM/yyyy';
887
+ if (storedDateFormat) {
888
+ this.dateFormat = storedDateFormat ? JSON.parse(storedDateFormat) : 'dd/MM/yyyy';
889
+ }
888
890
  }
889
891
  if (!this.currencyFormat) {
890
892
  const storedCurrencyFormat = localStorage.getItem('currencyFormat');
891
- this.currencyFormat = storedCurrencyFormat ? JSON.parse(storedCurrencyFormat) : '1,234,567.89';
893
+ if (storedCurrencyFormat) {
894
+ this.currencyFormat = storedCurrencyFormat ? JSON.parse(storedCurrencyFormat) : '1,234,567.89';
895
+ }
892
896
  }
893
897
  if (!this.currencySymbol) {
894
898
  const storedCurrencySymbol = localStorage.getItem('currencySymbol');
895
- this.currencySymbol = storedCurrencySymbol ? JSON.parse(storedCurrencySymbol) : '$';
899
+ if (storedCurrencySymbol) {
900
+ this.currencySymbol = storedCurrencySymbol ? JSON.parse(storedCurrencySymbol) : '$';
901
+ }
896
902
  }
897
903
  }
898
904
  async ngOnChanges(changes) {
@@ -5404,4 +5410,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
5404
5410
  type: ViewChild,
5405
5411
  args: ['fullscreenImageTemplate']
5406
5412
  }] } });
5407
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.component.js","sourceRoot":"","sources":["../../../../../projects/data-grid/src/lib/data-grid/data-grid.component.ts","../../../../../projects/data-grid/src/lib/data-grid/data-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  Input,\r\n  Output,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  ElementRef,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  HostListener,\r\n  ChangeDetectorRef,\r\n  EventEmitter,\r\n  NgZone,\r\n  Renderer2,\r\n  AfterViewChecked,\r\n  EmbeddedViewRef,\r\n  TemplateRef,\r\n  ChangeDetectionStrategy,\r\n  QueryList,\r\n  ViewChildren,\r\n  inject,\r\n  Injector\r\n} from '@angular/core';\r\nimport { SplitColumnsService } from '../services/split-columns.service';\r\nimport { CommonService } from '../services/common.service';\r\nimport {\r\n  CdkDrag,\r\n  CdkDragDrop,\r\n  CdkDragEnd,\r\n  CdkDragEnter,\r\n  CdkDragExit,\r\n  CdkDragMove,\r\n  CdkDragSortEvent,\r\n  CdkDragStart,\r\n  DragDrop,\r\n  moveItemInArray,\r\n} from '@angular/cdk/drag-drop';\r\nimport {\r\n  trigger,\r\n  state,\r\n  style,\r\n  transition,\r\n  animate,\r\n  query,\r\n  stagger,\r\n} from '@angular/animations';\r\nimport { CdkDropList } from '@angular/cdk/drag-drop';\r\nimport { STATUSES_BADGE_MAP } from './statuses';\r\nimport { CopyServiceService } from '../services/copy-service.service';\r\nimport { firstValueFrom, take } from 'rxjs';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { ExportService } from '../services/export.service';\r\nimport { CellHostDirective } from '../directives/cellHost.directive';\r\nimport { DatePipe } from '@angular/common';\r\nimport { FormatCurrencyPipe } from '../pipes/format-currency.pipe';\r\n\r\ninterface CellPosition {\r\n  rowIndex: number;\r\n  colIndex: number;\r\n  subColIndex: number;\r\n  field: string;\r\n  key: string;\r\n}\r\nexport enum RowAnimationType {\r\n  None = 'none',\r\n  Spread = 'spreadAnimation',\r\n  Bounce = 'bounceAnimation',\r\n  SlideUp = 'slideUpFromBottom',\r\n  Flip = 'flipAnimation',\r\n  Skew = 'skewAnimation',\r\n  SlideRight = 'slideFromRight',\r\n}\r\n\r\n\r\nexport const sortingAnimation = trigger('listSort', [\r\n  transition('* => *', [\r\n    // Query all elements entering or leaving\r\n    query(':enter, :leave', style({ position: 'absolute', width: '100%' }), { optional: true }),\r\n\r\n    // Animate leaving elements upward with fade out\r\n    query(':leave', [\r\n      animate('300ms ease-in', style({ transform: 'translateY(-20px)', opacity: 0 }))\r\n    ], { optional: true }),\r\n\r\n    // Stagger the entering elements for a smoother effect\r\n    query(':enter', [\r\n      style({ transform: 'translateY(20px)', opacity: 0 }),\r\n      stagger(50, [\r\n        animate('300ms ease-out', style({ transform: 'translateY(0)', opacity: 1 }))\r\n      ])\r\n    ], { optional: true })\r\n  ])\r\n]);\r\n@Component({\r\n  selector: 'data-grid',\r\n  templateUrl: './data-grid.component.html',\r\n  styleUrls: ['./data-grid.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [\r\n    trigger('accordionToggle', [\r\n      state(\r\n        'collapsed',\r\n        style({ height: '0px', overflow: 'unset' })\r\n      ),\r\n      state('expanded', style({ height: '*', overflow: 'unset' })),\r\n      transition('collapsed <=> expanded', animate('300ms ease-in')),\r\n    ]),\r\n    trigger('slideToggle', [\r\n      transition(':enter', [\r\n        style({ height: '0px', opacity: 0, overflow: 'hidden' }),\r\n        animate('300ms ease-out', style({ height: '*', opacity: 1 }))\r\n      ]),\r\n      transition(':leave', [\r\n        style({ height: '*', opacity: 1, overflow: 'hidden' }),\r\n        animate('300ms ease-in', style({ height: '0px', opacity: 0 }))\r\n      ])\r\n    ]),\r\n    trigger('slideUp', [\r\n      state('void', style({ transform: 'translateY(100%)', opacity: 0 })),\r\n      state('*', style({ transform: 'translateY(0)', opacity: 1 })),\r\n      transition('void => *', animate('300ms ease-out')),\r\n      transition('* => void', animate('300ms ease-in')),\r\n    ]),\r\n    trigger('rowDynamic', [\r\n\r\n      /* -------------------- SPREAD -------------------- */\r\n      transition('* => spreadAnimation', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'scaleX(0.7)' }),\r\n          stagger(60, [\r\n            animate('350ms ease-out',\r\n              style({ opacity: 1, transform: 'scaleX(1)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('220ms ease-in',\r\n              style({ opacity: 0, transform: 'scaleX(0.7)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n      /* -------------------- BOUNCE -------------------- */\r\n      transition('* => bounceAnimation', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'translateY(-10px)' }),\r\n          stagger(45, [\r\n            animate(\r\n              '500ms cubic-bezier(.68,-0.55,.27,1.55)',\r\n              style({ opacity: 1, transform: 'translateY(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('200ms ease-in',\r\n              style({ opacity: 0, transform: 'translateY(10px)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n      /* -------------------- NEW 1: FLIP -------------------- */\r\n      transition('* => flipAnimation', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'rotateX(-80deg)' }),\r\n          stagger(70, [\r\n            animate('450ms ease-out',\r\n              style({ opacity: 1, transform: 'rotateX(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(50, [\r\n            animate('250ms ease-in',\r\n              style({ opacity: 0, transform: 'rotateX(80deg)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n      /* -------------------- NEW 2: SKEW -------------------- */\r\n      transition('* => skewAnimation', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'skewY(6deg) translateY(8px)' }),\r\n          stagger(60, [\r\n            animate('320ms ease-out',\r\n              style({ opacity: 1, transform: 'skewY(0deg) translateY(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('220ms ease-in',\r\n              style({ opacity: 0, transform: 'skewY(-6deg) translateY(-8px)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n      transition('* => slideUpFromBottom', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'translateY(100vh)' }),\r\n          stagger(60, [\r\n            animate('500ms cubic-bezier(0.25, 0.8, 0.25, 1)',\r\n              style({ opacity: 1, transform: 'translateY(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('300ms ease-in',\r\n              style({ opacity: 0, transform: 'translateY(-50px)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n      transition('* => slideFromRight', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'translateX(100vw)' }),\r\n          stagger(60, [\r\n            animate('500ms cubic-bezier(0.25, 0.8, 0.25, 1)',\r\n              style({ opacity: 1, transform: 'translateX(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('300ms ease-in',\r\n              style({ opacity: 0, transform: 'translateX(50px)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n\r\n\r\n    ])\r\n\r\n\r\n  ],\r\n\r\n})\r\nexport class DataGridComponent implements OnChanges, AfterViewInit, OnInit, AfterViewChecked {\r\n  //  **************************************//\r\n  //  **************************************//\r\n  // **********  Input Goes Here *********** //\r\n  //  **************************************//\r\n  //  **************************************//\r\n\r\n\r\n  @Input() rowAnimation: RowAnimationType = RowAnimationType.None;\r\n\r\n  // Pagination Config Store Here\r\n  @Input() paginationConfig: any = {};\r\n\r\n  // The dataset store here;\r\n  @Input() dataSet: any[] = [];\r\n\r\n  // The columns Store Here\r\n  @Input() columns: any[] = [];\r\n\r\n  // Row Height;\r\n  @Input() rowHeight: number = 44;\r\n\r\n  // Header Row Height;\r\n  @Input() headerRowHeight: number = 50;\r\n\r\n  // Show Vertical Borders;\r\n  @Input() showVerticalBorder: boolean = false;\r\n\r\n  // Even Rows Background Color;\r\n  @Input() evenRowsBackgroundColor: string | undefined = '';\r\n\r\n  // Even Rows Background Color;\r\n  @Input() oddRowsBackgroundColor: string | undefined = '#f2f2f2';\r\n\r\n  // Header Rows Background Color;\r\n  @Input() headerBackgroundColor: string = '#f6f8ff';\r\n\r\n  // Header Rows Background Color;\r\n  @Input() checkboxesBackgroundColor: string = '#f6f8ff';\r\n\r\n  // Show Columns Grouping;\r\n  @Input() showColumnsGrouping: boolean = false;\r\n\r\n  // Row Hovered Background color;\r\n  @Input() rowHoverColor: string | undefined = 'rgba(0, 123, 255, 0.1)';\r\n\r\n  // Left PinnedBackground color;\r\n  @Input() leftPinnedBackgroundColor: string | undefined = '#f6f8ff';\r\n\r\n  // Body Background color;\r\n  @Input() bodyBackgroundColor: string | undefined = '#f6f8ff';\r\n\r\n  // Right Pinned Background color;\r\n  @Input() rightPinnedBackgroundColor: string | undefined = '#f6f8ff';\r\n\r\n  // Side Menu Background color;\r\n  @Input() sidemenuBackgroundColor: string | undefined = '#f6f8ff';\r\n\r\n  // Body text color;\r\n  @Input() bodyTextColor: string | undefined = '#0c112b';\r\n\r\n  // Header text color;\r\n  @Input() headerTextColor: string | undefined = '#2a1f73';\r\n\r\n  // Header text color;\r\n  @Input() checkboxesColor: string | undefined = '#2a1f73';\r\n\r\n  // Header text size;\r\n  @Input() headerTextFontsSize: number | undefined = 14;\r\n\r\n  // Body text color;\r\n  @Input() bodyTextFontsSize: number | undefined = 14;\r\n\r\n  // Header font weight;\r\n  @Input() headerFontWeight: number | undefined = 500;\r\n\r\n  // Body Font Weight;\r\n  @Input() bodyFontWeight: number | undefined = 400;\r\n\r\n  // Checked Row Background Color;\r\n  @Input() checkedRowBackgroundColor: string | undefined = 'aliceblue';\r\n\r\n  // dropdowns Background Color;\r\n  @Input() dropdownsBackgroundColor: string | undefined = '#f6f8f8';\r\n\r\n\r\n  @Input() footerRowBackgroundColor: string | undefined = '';\r\n\r\n  // Footer row Height;\r\n  @Input() footerRowHeight: number = 46;\r\n\r\n  // Footer row Height;\r\n  @Input() topGroupedBadgesBackgroundColor: string | undefined = '';\r\n\r\n  // Show Row wise grouping;\r\n  @Input() showRowsGrouping: boolean | undefined = false;\r\n\r\n  // Show Row wise grouping;\r\n  @Input() showFilterRow: boolean | undefined = false;\r\n\r\n  // Show Row wise grouping;\r\n  @Input() fontFaimly: string | undefined = 'sans-serif';\r\n\r\n  // Show SideColumn;\r\n  @Input() showSideMenu: boolean = false;\r\n\r\n  // Footer Padding\r\n  @Input() footerPadding: number = 3\r\n\r\n\r\n  // Footer Padding\r\n  @Input() topFilterRowHeight: number = 50;\r\n\r\n  // Show Rows shading\r\n  @Input() rowShadingEnabled: boolean = false;\r\n\r\n  // Show Rows shading\r\n  @Input() showSerialNumber: boolean = false;\r\n\r\n  // Single Spa Url Attach to icons\r\n  @Input() singleSpaAssetsPath: string = 'assets/';\r\n\r\n\r\n  // Applied Filters\r\n  @Input() filtersConfig: any[] = [];\r\n\r\n\r\n  // Applied Filters\r\n  @Input() loading: boolean = false;\r\n\r\n  //Vertical Scrollbar style\r\n  @Input() verticalScrollbarWidth: 'auto' | 'thin' = 'auto';\r\n\r\n  //Horizintal Scrollbar style\r\n  @Input() horizintalScrollbarWidth: 'auto' | 'thin' = 'auto';\r\n\r\n  // Show Cell details box\r\n  @Input() showCellDetailsBox: boolean = false;\r\n\r\n  //Date format\r\n\r\n  @Input() dateFormat: string = ''\r\n\r\n  //Date format\r\n  @Input() tableSearch: string = '';\r\n\r\n\r\n  //Date format\r\n  @Input() actions: any[] = ['edit', 'delete'];\r\n\r\n\r\n  // Table Config for paginations is here\r\n  @Input() config: any;\r\n\r\n\r\n  // Selection task bar\r\n  @Input() showTaskbar = false\r\n\r\n  // Table Name for state manage\r\n  @Input() tableName = true\r\n\r\n\r\n  // Listing type\r\n  @Input() listingType: string | boolean = '';\r\n\r\n  // Listing type\r\n\r\n  @Input() checkboxState: { reset: boolean } = {\r\n    reset: true\r\n  }\r\n\r\n  // Taskbar actions\r\n  @Input() taskbarActions: any[] = []\r\n\r\n\r\n  // Sorting Config to show sort icons\r\n  @Input() sortingConfig: { field: string, order_by: string } | null = null;\r\n\r\n\r\n  @Input() tableFilterViewId: any = '';\r\n\r\n\r\n  @Input() selectedTableLayout: any = 'medium'\r\n\r\n  @Input() closeDropdown: { preset: { closed: boolean, loading: boolean } } = { preset: { closed: false, loading: false } };\r\n\r\n  // Table View\r\n\r\n  // GlobalSearch\r\n  @Input() globalSearchText: string = '';\r\n\r\n  // Nested Table Row Fontsize\r\n  @Input() nestedTablerowFontsize = 14;\r\n\r\n  // Nested table row Header row Height\r\n  @Input() nestedTableHeaderRowHeight = 40;\r\n\r\n  // Nested Table row height\r\n  @Input() nestedTablerowHeight = 45;\r\n\r\n\r\n  @Input() gridType: string = '';\r\n\r\n  @Input() currencySymbol: string = '';\r\n\r\n  @Input() currencyFormat: string = '';\r\n\r\n  @Input() leftPinnedBoxshadow: string = '';\r\n\r\n  @Input() rightPinnedBoxshadow: string = '';\r\n\r\n  // GlobalSearch\r\n  @Input() selectedRowsBackgroundColor: string = '#8ac5ff';\r\n\r\n  // GlobalSearch\r\n  @Input() nestedTableHeaderBackgroundColor: string = '#f6f8ff';\r\n\r\n\r\n  @Input() nestedTableRowBackgroundColor: string = '#eaeaea';\r\n\r\n  @Input() tableView: any[] = [];\r\n\r\n  @Input() buttons: { name: string; is_showIcon: boolean; icon: string, has_permission: boolean }[] = [];\r\n\r\n  @Input() keepMultipleExpandedDetails = false;\r\n\r\n\r\n  @Input() showTotalAmountRow = false;\r\n\r\n\r\n  @Input() enableGlobalSearch = true;\r\n\r\n\r\n  @Input() tableType = '';\r\n\r\n\r\n  @Input() enableExport = false;\r\n\r\n\r\n  @Input() showFullScreenButton = false;\r\n\r\n\r\n  @Input() enableCut = false;\r\n\r\n\r\n  @Input() tabs: string[] = [];\r\n\r\n  @Input() showCheckboxes = true;\r\n\r\n\r\n  @Input() pageSizeOptions = [10, 25, 50, 75, 100, 150, 200, 250, 300, 500];\r\n\r\n\r\n  @Input() resetAllFilters = { resetAll: false };\r\n\r\n\r\n  @Input() columnThreedotsMunuConfig = {\r\n    showPinleft: true,\r\n    showPinright: true,\r\n    showAscending: true,\r\n    showDescending: true,\r\n    showFilter: true,\r\n    showRowsGrouping: this.showRowsGrouping,\r\n    showAutosizeAllColumns: true,\r\n    showAutosizeThisColumn: false,\r\n    showChoseColumns: false,\r\n    showResetColumns: false,\r\n  };\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  // ///////////////////////////////////////////////////////////////////////////////////////////\r\n  // ///////////////////////////////////////////////////////////////////////////////////////////\r\n  //                         Out Put Events\r\n  // ///////////////////////////////////////////////////////////////////////////////////////////\r\n  // ///////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n\r\n  //Change Table Layout\r\n  @ViewChildren(CellHostDirective) cellHosts!: QueryList<CellHostDirective>;\r\n\r\n  @Output() public changeLayout = new EventEmitter<any>();\r\n\r\n  @Output() public customCellEvent = new EventEmitter<any>();\r\n\r\n  // Filter Apply event;\r\n  @Output() public filterOptions = new EventEmitter<any>();\r\n\r\n  @Output() genericEvent: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() tablePresetConfig: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() sortingOrderOptions: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output() createUpdateConfigListing: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  isFullScreen = false;\r\n  activeTab: string | null = null;\r\n  groupedColumns: any[] = [];\r\n  activeCol: any = null;\r\n  activeFilterCell: any = null;\r\n  showActionsDropDown = false;\r\n  sideMenuVisible = false;\r\n  pivotMode: boolean = false;\r\n  columnSearch: string = '';\r\n  expandAllAccordians = true;\r\n  currentOpenedSideMenue: 'cols' | 'filtrs' | null = null;\r\n  originalColumns: any[] = [];\r\n  originalDataSet: any[] = [];\r\n  activeTopButton: string | null = '';\r\n  filterColumnsList: any[] = [];\r\n  groupBoxPadding = 200;\r\n  presetName: string = '';\r\n  presetFilter: boolean = false;\r\n  searchTextPresetTable = '';\r\n  addFilterColumnInput = '';\r\n  searchInDropdown = '';\r\n  private secretKey = 'tb-super-admin'\r\n  addFilterDropdownSearch = ''\r\n  topShowHideColumns = '';\r\n  choseColumnsSearch = ''\r\n  sideNestedFilterSearch = ''\r\n  editinDropdownSearch = '';\r\n  isThreeDotsFilterOpen = false;\r\n  confirmDelete = false;\r\n  fontFamilies: string[] = [\r\n    // Common Excel fonts\r\n    'Arial',\r\n    'Arial Black',\r\n    'Bahnschrift',\r\n    'Calibri',\r\n    'Cambria',\r\n    'Cambria Math',\r\n    'math',\r\n    'Candara',\r\n    'Comic Sans MS',\r\n    'Consolas',\r\n    'Constantia',\r\n    'Corbel',\r\n    'Courier New',\r\n    'Ebrima',\r\n    'Franklin Gothic Medium',\r\n    'Gabriola',\r\n    'Gadugi',\r\n    'Georgia',\r\n    'Impact',\r\n    'Ink Free',\r\n    'Javanese Text',\r\n    'Leelawadee UI',\r\n    'Lucida Console',\r\n    'Lucida Sans Unicode',\r\n    'Malgun Gothic',\r\n    'Microsoft Himalaya',\r\n    'Microsoft JhengHei',\r\n    'Microsoft New Tai Lue',\r\n    'Microsoft PhagsPa',\r\n    'Microsoft Sans Serif',\r\n    'Microsoft Tai Le',\r\n    'Microsoft YaHei',\r\n    'Microsoft Yi Baiti',\r\n    'Mongolian Baiti',\r\n    'MS Gothic',\r\n    'MS PGothic',\r\n    'MS UI Gothic',\r\n    'MV Boli',\r\n    'Nirmala UI',\r\n    'Palatino Linotype',\r\n    'Segoe Print',\r\n    'Segoe Script',\r\n    'Segoe UI',\r\n    'Segoe UI Historic',\r\n    'Segoe UI Emoji',\r\n    'Segoe UI Symbol',\r\n    'SimSun',\r\n    'Sitka Small',\r\n    'Sylfaen',\r\n    'Symbol',\r\n    'Tahoma',\r\n    'Times New Roman',\r\n    'Trebuchet MS',\r\n    'Verdana',\r\n    'Webdings',\r\n    'Wingdings',\r\n    'Yu Gothic',\r\n    'sans-serif',\r\n    'serif',\r\n    'monospace',\r\n    'Inter'\r\n  ];\r\n\r\n  fontSizes: string[] = [\r\n    '8', '9', '10', '11', '12', '14', '16', '18', '20', '24', '28', '32'\r\n  ];\r\n\r\n  hasScroll = false;\r\n\r\n\r\n\r\n\r\n  constructor(\r\n    private columnService: SplitColumnsService,\r\n    public cdr: ChangeDetectorRef,\r\n    public commonSevice: CommonService,\r\n    private elementRef: ElementRef,\r\n    private ngZone: NgZone,\r\n    private copyService: CopyServiceService,\r\n    private renderer: Renderer2,\r\n    private sanitizer: DomSanitizer,\r\n    private exportService: ExportService,\r\n    private datePipe: DatePipe,\r\n    private formatCurrency: FormatCurrencyPipe,\r\n\r\n  ) { }\r\n\r\n  @ViewChild('cellText', { static: false }) cellText!: any;\r\n  @ViewChild('nestedHeader', { static: false }) nestedHeader!: ElementRef;\r\n  ngAfterViewInit() {\r\n    this.ngZone.onStable.pipe(take(1)).subscribe(async () => {\r\n      await this.SetColumnsDefaultWidth();\r\n      await this.refreshHeaders();\r\n      this.updateFlattenedData();\r\n      this.computeViewportRows();\r\n      this.updateVisibleRows(0);\r\n      this.hasScroll = this.hasHorizontalScrollbar();\r\n\r\n      if (this.cellText) {\r\n        const observer = new ResizeObserver(() => {\r\n          this.cdr.detectChanges();\r\n        });\r\n        observer.observe(this.cellText.nativeElement);\r\n      }\r\n\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.renderCustomCells();\r\n  }\r\n\r\n  private injector = inject(Injector);\r\n\r\n  createCellInjector(row: any, col: any): Injector {\r\n    return Injector.create({\r\n      providers: [\r\n        { provide: 'rowData', useValue: row },\r\n        { provide: 'colData', useValue: col }\r\n      ],\r\n      parent: this.injector\r\n    });\r\n  }\r\n\r\n\r\n  private renderCustomCells(): void {\r\n    const hosts = this.cellHosts.toArray();\r\n    let hostIndex = 0;\r\n\r\n    for (const row of this.visibleRows) {\r\n      for (const col of this.columns) {\r\n        const host = hosts[hostIndex++];\r\n        if (!host || !col.cellRenderer) continue;\r\n\r\n        const viewContainer = host.viewContainerRef;\r\n        viewContainer.clear();\r\n\r\n        const compRef = viewContainer.createComponent(col.cellRenderer);\r\n\r\n        const params = {\r\n          row,\r\n          col,\r\n          value: this.getNestedValue(row, col.field),\r\n          api: this,\r\n        };\r\n\r\n        if ((compRef.instance as any).gridInit) {\r\n          (compRef.instance as any).gridInit(params);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewChecked(): void {\r\n    this.addStylesToImages();\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  ngOnInit() {\r\n    //  if (this.tabs?.length) {\r\n    //   this.activeTab = this.tabs[0];\r\n    // }\r\n    // this.autosizeAllColumns();\r\n    if (!this.curretaTablePresetForUpdate) {\r\n      this.autosizeAllColumns();\r\n    }\r\n\r\n    // const user = this.getDecrypt('user');\r\n    // this.currencyFormat = user?.currency_format;\r\n    // this.currencySymbol = user?.currency_symbol;\r\n    // this.dateFormat = user?.date_format;\r\n    if (!this.dateFormat) {\r\n      const storedDateFormat = localStorage.getItem('dateformat');\r\n      this.dateFormat = storedDateFormat ? JSON.parse(storedDateFormat) : 'dd/MM/yyyy';\r\n    }\r\n\r\n    if (!this.currencyFormat) {\r\n      const storedCurrencyFormat = localStorage.getItem('currencyFormat');\r\n      this.currencyFormat = storedCurrencyFormat ? JSON.parse(storedCurrencyFormat) : '1,234,567.89';\r\n    }\r\n\r\n    if (!this.currencySymbol) {\r\n      const storedCurrencySymbol = localStorage.getItem('currencySymbol');\r\n      this.currencySymbol = storedCurrencySymbol ? JSON.parse(storedCurrencySymbol) : '$';\r\n    }\r\n\r\n  }\r\n\r\n  // private getDecrypt(key:string){\r\n  //     const value = localStorage.getItem(key)\r\n  //     try {\r\n  //       return JSON.parse(CryptoJS.AES.decrypt(value as string, this.secretKey).toString(CryptoJS.enc.Utf8))\r\n  //     } catch (e) {\r\n  //       return null;\r\n  //     }\r\n  //   }\r\n\r\n  dataSetLoading = false;\r\n  async ngOnChanges(changes: SimpleChanges) {\r\n    if (changes['columns']) {\r\n      await this.setColumnsColumnDropdownValus();\r\n\r\n    }\r\n\r\n    if (changes['tabs']) {\r\n      if (changes['tabs']) {\r\n        const allTabs = JSON.parse(localStorage.getItem('activeTabs') || '{}');\r\n        const savedTab = allTabs[this.tableType];\r\n        if(this.tabs.includes('Current Policy')){\r\n          this.activeTab = this.tabs?.[1] || 'Current Policy';\r\n        }else{\r\n          this.activeTab = savedTab || this.tabs?.[0];\r\n        }\r\n\r\n        // if (this.tableType) {\r\n        //   this.setActiveTab(this.activeTab);\r\n        // }\r\n      }\r\n    }\r\n    if (changes['filtersConfig']) {\r\n      this.checkFilterChangesEffect();\r\n      await this.applyFilteroptionList();\r\n    }\r\n\r\n    if (changes['columns']?.currentValue?.length) {\r\n\r\n      await this.applyFilteroptionList();\r\n\r\n      this.originalColumns = this.columns.map(col => ({\r\n        ...col,\r\n        query: col.query ? { ...col.query } : null,\r\n        column_dropdown_value: col.column_dropdown_value\r\n          ? [...col.column_dropdown_value]\r\n          : [],\r\n      }));\r\n\r\n\r\n      if (this.dataGridContainer?.nativeElement?.offsetWidth) {\r\n        await this.SetColumnsDefaultWidth();\r\n        await this.updateColumnWidthsAndGroups();\r\n        await this.refreshPreviewColumns();\r\n        this.setSectionsWidth();\r\n      }\r\n\r\n      this.ngZone.onStable.pipe(take(1)).subscribe(() => {\r\n        this.cdr.detectChanges();\r\n      });\r\n    }\r\n\r\n    if (changes['dataSet']) {\r\n      this.dataSet = this.dataSet?.map((row, i) => ({\r\n        ...row,\r\n        __virtualIndex: i + 1,\r\n      }));\r\n      this.originalDataSet = structuredClone(this.dataSet);\r\n      this.expandedCells.clear();\r\n      this.updateFlattenedData();\r\n\r\n      this.ngZone.onStable.pipe(take(1)).subscribe(() => {\r\n        this.computeViewportRows();\r\n        this.updateVisibleRows(0);\r\n\r\n        this.cdr.detectChanges();\r\n      });\r\n\r\n      if (this.centerPinnedHeader?.nativeElement) {\r\n        void this.centerPinnedHeader.nativeElement.offsetWidth;\r\n\r\n        this.dataSetLoading = true;\r\n        setTimeout(() => {\r\n          if (this.centerScrollableBody?.nativeElement) {\r\n            this.centerScrollableBody.nativeElement.scrollLeft =\r\n              this.centerPinnedHeader.nativeElement.scrollLeft;\r\n          }\r\n          this.dataSetLoading = false;\r\n          this.cdr.detectChanges();\r\n        }, 500);\r\n      }\r\n\r\n      this.applyRowsSelectionState();\r\n\r\n      if (this.groupedColumns?.length) {\r\n        const fields = this.groupedColumns.map((item) => item.field);\r\n        this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n\r\n        this.ngZone.onStable.pipe(take(1)).subscribe(() => {\r\n          this.updateFlattenedData();\r\n          this.updateColumnWidthsAndGroups();\r\n          this.refreshPreviewColumns();\r\n          this.updateVisibleRows(0);\r\n          this.loading = false;\r\n          this.groupBoxPadding = this.columnsGroupedBox?.nativeElement.offsetWidth;\r\n          this.cdr.detectChanges();\r\n        });\r\n      }\r\n    }\r\n\r\n    if (changes['checkboxState']?.currentValue?.reset) {\r\n      this.selectedRows.clear();\r\n      this.clearSelectionState(this.tableType);\r\n\r\n      const ids = Array.from(this.selectedRows);\r\n      const event = {\r\n        data: {\r\n          listingType: this.listingType,\r\n          obj: ids,\r\n        },\r\n        eventType: 'onSelectRow',\r\n      };\r\n\r\n      this.genericEvent.emit(event);\r\n\r\n      this.ngZone.onStable.pipe(take(1)).subscribe(() => {\r\n        this.cdr.detectChanges();\r\n      });\r\n    }\r\n\r\n    if (changes['closeDropdown'] && this.closeDropdown.preset.closed) {\r\n      this.activeTopButton = null;\r\n      this.presetFilter = false;\r\n      this.presetName = '';\r\n    }\r\n\r\n    // if (changes['oddRowsBackgroundColor']) {\r\n    //   this.rowShadingEnabled = !!this.oddRowsBackgroundColor;\r\n    // }\r\n\r\n    if (changes['resetAllFilters'] && this.resetAllFilters.resetAll) {\r\n      this.clearAllFilters();\r\n    }\r\n\r\n    if (changes['tableView']) {\r\n      setTimeout(() => {\r\n        const viewValue = this.tableView;\r\n        let temprorySelected = Array.isArray(viewValue)\r\n          ? viewValue.find(item => item.is_temp)\r\n          : null;\r\n\r\n        if (!temprorySelected) {\r\n          temprorySelected = Array.isArray(viewValue)\r\n            ? viewValue.find(item => item.is_default)\r\n            : null;\r\n        }\r\n\r\n        this.curretaTablePresetForUpdate = temprorySelected || null;\r\n        this.presetName = temprorySelected?.name || '';\r\n        this.presetFilter = temprorySelected?.activeFilters || false;\r\n        if (this.curretaTablePresetForUpdate) {\r\n          this.rowShadingEnabled = temprorySelected.config.rowShadingEnabled;\r\n          this.showVerticalBorder = temprorySelected.config.showVerticalBorder;\r\n          this.fontFaimly = temprorySelected.config.fontFaimly;\r\n          this.headerTextFontsSize = temprorySelected.config.headerTextFontsSize;\r\n          this.selectedTableLayout = temprorySelected.config.selectedTableLayout;\r\n          this.bodyTextFontsSize = temprorySelected.config.bodyTextFontsSize;\r\n          this.globalSearchText = temprorySelected.config.globalSearch;\r\n          this.setTableLayout(this.selectedTableLayout);\r\n          this.oddRowsBackgroundColor = temprorySelected?.config?.oddRowsBackgroundColor || '#f1f1f1';\r\n          this.cdr.detectChanges();\r\n        } else {\r\n          this.rowShadingEnabled = false;\r\n          this.showVerticalBorder = false;\r\n          this.fontFaimly = 'Inter';\r\n          this.headerTextFontsSize = 14;\r\n          this.selectedTableLayout = 'medium';\r\n          this.bodyTextFontsSize = 14;\r\n          this.globalSearchText = '';\r\n          this.autosizeAllColumns();\r\n        }\r\n        this.cdr.detectChanges();\r\n      }, 0);\r\n    }\r\n\r\n  }\r\n\r\n  async setColumnsColumnDropdownValus(): Promise<void> {\r\n    if (!this.columns) return;\r\n    // Just removed temporary for super admin will set it again\r\n    if(this.columns?.length){\r\n      this.columns = this.columns?.filter(c => c?.field?.trim() !== 'is_deleted')\r\n    }\r\n    this.columns = await this.commonSevice.copyDropdownDataRecursively(this.columns);\r\n  }\r\n\r\n\r\n\r\n\r\n  applyRowsSelectionState() {\r\n    const selectedIdsFromState = this.restoreSelection(this.tableType);\r\n    if (selectedIdsFromState.size > 0) {\r\n      const ids = Array.from(this.selectedRows);\r\n      const event = {\r\n        data: {\r\n          listingType: this.listingType,\r\n          obj: ids\r\n        },\r\n        eventType: \"onSelectRow\",\r\n      }\r\n      this.genericEvent.emit(event);\r\n    }\r\n  }\r\n\r\n  clearSelectionState(tableType: string): void {\r\n    const stored = JSON.parse(localStorage.getItem('datatableSelections') || '{\"selectedRows\": {}}');\r\n    if (stored.selectedRows && stored.selectedRows[tableType]) {\r\n      delete stored.selectedRows[tableType];\r\n    }\r\n    localStorage.setItem(\r\n      'datatableSelections',\r\n      JSON.stringify(stored)\r\n    );\r\n  }\r\n\r\n\r\n\r\n  async applyFilteroptionList() {\r\n    const updatedColumns = await this.commonSevice.applyFiltersToColumns(this.columns, this.filtersConfig);\r\n    this.columns = [...updatedColumns];\r\n    this.cdr.detectChanges();\r\n  }\r\n  leftPinnedColumns: any[] = [];\r\n  centerColumns: any[] = [];\r\n  rightPinnedColumns: any[] = [];\r\n\r\n  previewLeftPinnedColumns: any[] = [];\r\n  previewCenterColumns: any[] = [];\r\n  previewRightPinnedColumns: any[] = [];\r\n\r\n  // Main Container Template References\r\n  @ViewChild('dataGridContainer')\r\n  dataGridContainer!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('taskManagementContainer')\r\n  taskManagementContainer!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('nestedTableContainer')\r\n  nestedTableContainer!: ElementRef<HTMLDivElement>;\r\n\r\n  // Body Template References\r\n  @ViewChild('leftPinnedBody')\r\n  leftPinnedBody!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('centerPinnedBody')\r\n  centerPinnedBody!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('rightPinnedBody')\r\n  rightPinnedBody!: ElementRef<HTMLDivElement>;\r\n\r\n  // Headers Template References\r\n  @ViewChild('leftPinnedHeader')\r\n  leftPinnedHeader!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('centerPinnedHeader')\r\n  centerPinnedHeader!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('rightPinnedHeader')\r\n  rightPinnedHeader!: ElementRef<HTMLDivElement>;\r\n\r\n  @ViewChild('columnsGroupedBox')\r\n  columnsGroupedBox!: ElementRef<HTMLDivElement>;\r\n\r\n  // Center Fake scrollbard\r\n  @ViewChild('centerFakeScrollbar')\r\n  centerFakeScrollbar!: ElementRef<HTMLDivElement>;\r\n  async updateColumnWidthsAndGroups(columns: any = null) {\r\n    if (!this.dataGridContainer) return;\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n    // Wrap in a promise so we can await\r\n    const { left, center, right }: any = await new Promise(resolve => {\r\n      const prepared = this.columnService.prepareColumns(\r\n        columns ? columns : this.columns,\r\n        containerWidth\r\n      );\r\n      resolve(prepared);\r\n    });\r\n\r\n    this.leftPinnedColumns = left;\r\n    this.centerColumns = center;\r\n    this.rightPinnedColumns = right;\r\n    await new Promise(r => setTimeout(r, 0));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  async refreshPreviewColumns(columns: any = null) {\r\n    if (!this.dataGridContainer) return;\r\n\r\n    const containerWidth = this.dataGridContainer.nativeElement.offsetWidth;\r\n\r\n    // Wrap prepareColumns in a Promise to make it awaitable\r\n    const { left, center, right }: any = await new Promise(resolve => {\r\n      const prepared = this.columnService.prepareColumns(\r\n        columns ? columns : this.columns,\r\n        containerWidth\r\n      );\r\n      resolve(prepared);\r\n    });\r\n\r\n    this.previewLeftPinnedColumns = left;\r\n    this.previewCenterColumns = center;\r\n    this.previewRightPinnedColumns = right;\r\n    await new Promise(r => setTimeout(r, 10));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  async SetColumnsDefaultWidth() {\r\n    const visibleColumns = this.getVisibleLeafColumns(this.columns);\r\n    const visibleCount = visibleColumns.length;\r\n\r\n    if (visibleCount === 0) return;\r\n\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n    if (this.showSerialNumber) containerWidth -= 55;\r\n    if (this.showSideMenu) containerWidth -= 29;\r\n    // if (this.gridType == 'Assets' || this.gridType == 'Tasks') containerWidth -= 30;\r\n    // containerWidth -= 55;\r\n    // if (this.showSerialNumber) containerWidth -= 55;\r\n    // if (this.showSideMenu) containerWidth -= 29;\r\n    // if (this.gridType == 'Assets' || this.gridType == 'Tasks') containerWidth -= 30;\r\n    // containerWidth -= 5;\r\n    this.columns = this.columnService.assignDefaultWidths(\r\n      this.columns,\r\n      containerWidth\r\n    );\r\n    await new Promise(resolve => setTimeout(resolve, 0));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  setSectionsWidth() {\r\n    const left = document.querySelector('.left-pinned-body') as HTMLElement;\r\n    const center = document.querySelector(\r\n      '.center-scrollable-body'\r\n    ) as HTMLElement;\r\n    const right = document.querySelector('.right-pinned-body') as HTMLElement;\r\n    if (left) {\r\n      left.style.minWidth = `${this.leftPinnedHeader.nativeElement.offsetWidth}`;\r\n    }\r\n    if (center) {\r\n      left.style.minWidth = `${this.centerPinnedHeader.nativeElement.offsetWidth}`;\r\n    }\r\n    if (right) {\r\n      left.style.minWidth = `${this.rightPinnedHeader.nativeElement.offsetWidth}`;\r\n    }\r\n  }\r\n\r\n  // onCenterBodyScroll(): void {\r\n  //   const scrollTop = this.centerPinnedBody.nativeElement.scrollTop;\r\n  //   const scrollLeft = this.centerPinnedBody.nativeElement.scrollLeft;\r\n\r\n  //   // Sync vertical scroll with left & right pinned bodies\r\n  //   this.leftPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  //   this.rightPinnedBody.nativeElement.scrollTop = scrollTop;\r\n\r\n  //   // Sync horizontal scroll with center header\r\n  //   this.centerPinnedHeader.nativeElement.scrollLeft = scrollLeft;\r\n  //   this.centerFakeScrollbar.nativeElement.scrollLeft = scrollLeft;\r\n  // }\r\n\r\n  // onLeftBodyScroll(): void {\r\n  //   const scrollTop = this.leftPinnedBody.nativeElement.scrollTop;\r\n  //   this.centerPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  //   this.rightPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  // }\r\n  // onRightBodyScroll(): void {\r\n  //   const scrollTop = this.rightPinnedBody.nativeElement.scrollTop;\r\n  //   this.centerPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  //   this.leftPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  // }\r\n\r\n  fakeScrollbarScrollLeft = 0;\r\n  // onFakeScroll(event: Event) {\r\n  //   const target = event.target as HTMLElement;\r\n  //   this.fakeScrollbarScrollLeft = target.scrollLeft;\r\n  //   this.centerPinnedBody.nativeElement.scrollLeft = target.scrollLeft;\r\n  //   this.centerPinnedHeader.nativeElement.scrollLeft = target.scrollLeft;\r\n  // }\r\n\r\n\r\n\r\n\r\n  getNestedValue(obj: any, field: string): any {\r\n    return field?.split('.').reduce((acc, part) => acc && acc[part], obj);\r\n  }\r\n\r\n  isNestedValueArray(obj: any, field: string): boolean {\r\n    if (!obj || !field) return false;\r\n    const value = field\r\n      .split('.')\r\n      .reduce((acc, part) => (acc && acc[part] !== undefined ? acc[part] : undefined), obj);\r\n    return Array.isArray(value);\r\n  }\r\n\r\n  onResizeGroup(event: MouseEvent, col: any, isRightPinned?: boolean): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n\r\n    const startX = event.clientX;\r\n    const children = col.children || [];\r\n    if (!children.length) return;\r\n\r\n    const childWidths: { field: string; width: number }[] = children.map(\r\n      (child: any) => {\r\n        const el = document.querySelector(\r\n          `[field=\"${child.field}\"]`\r\n        ) as HTMLElement;\r\n        return {\r\n          field: child.field,\r\n          width: el?.offsetWidth || 0,\r\n        };\r\n      }\r\n    );\r\n\r\n    const totalInitialWidth = childWidths.reduce(\r\n      (sum, col) => sum + col.width,\r\n      0\r\n    );\r\n\r\n    const onMouseMove = (moveEvent: MouseEvent) => {\r\n      let deltaX = moveEvent.clientX - startX;\r\n\r\n      if (isRightPinned) {\r\n        deltaX = -deltaX;\r\n      }\r\n\r\n      // Prevent shrinking too small\r\n      if (totalInitialWidth + deltaX < children.length * 80) return;\r\n\r\n      let totalNewWidth = 0;\r\n\r\n      childWidths.forEach((child) => {\r\n        const ratio = child.width / totalInitialWidth;\r\n        const newWidth = Math.max(child.width + deltaX * ratio, 80);\r\n        totalNewWidth += newWidth;\r\n\r\n        const childEls = document.querySelectorAll(`[data-field=\"${child.field}\"]`);\r\n        childEls.forEach((el: Element) => {\r\n          const elHtml = el as HTMLElement;\r\n          elHtml.style.minWidth = `${newWidth}px`;\r\n          elHtml.style.width = `${newWidth}px`;\r\n        });\r\n\r\n        this.updateColumnWidthInSourceByField(child.field, newWidth);\r\n      });\r\n\r\n      // ✅ Update group header width in DOM\r\n      const groupHeaderEl = document.querySelector(\r\n        `[group=\"${col.header}\"]`\r\n      ) as HTMLElement;\r\n      if (groupHeaderEl) {\r\n        groupHeaderEl.style.width = `${totalNewWidth}px`;\r\n      }\r\n    };\r\n\r\n    const onMouseUp = () => {\r\n      if (this.tableFilterViewId) {\r\n        this.savePreset('mouseUp');\r\n      }\r\n      this.refreshHeaders();\r\n      window.removeEventListener('mousemove', onMouseMove);\r\n      window.removeEventListener('mouseup', onMouseUp);\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n    };\r\n\r\n    window.addEventListener('mousemove', onMouseMove);\r\n    window.addEventListener('mouseup', onMouseUp);\r\n  }\r\n\r\n  private updateColumnWidthInSourceByField(field: string, width: number): void {\r\n    const update = (columns: any[]) => {\r\n      for (const col of columns) {\r\n        if (col.children?.length) {\r\n          update(col.children);\r\n        } else if (col.field === field) {\r\n          col.width = width;\r\n        }\r\n      }\r\n    };\r\n\r\n    update(this.columns);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n   cleanColumns(columns: any[]): any[] {\r\n      return columns.map((col) => {\r\n        const {\r\n          __typename,\r\n          _id,\r\n          column_dropdown_value,\r\n          filterValue,\r\n          expandedFilter,\r\n          query,\r\n          isRowGrouped,\r\n          ...rest\r\n        } = col;\r\n\r\n        // Clean dropdown values (__typename removed)\r\n        const cleanedDropdown = Array.isArray(column_dropdown_value)\r\n          ? column_dropdown_value.map(({ __typename, ...dRest }) => dRest)\r\n          : column_dropdown_value\r\n            ? (({ __typename, ...dRest }) => dRest)(column_dropdown_value)\r\n            : null;\r\n\r\n        // Clean query (__typename removed)\r\n        const cleanedQuery = Array.isArray(query)\r\n          ? query.map(({ __typename, ...qRest }) => qRest)\r\n          : query\r\n            ? (({ __typename, _ids, ...qRest }) => qRest)(query)\r\n            : null;\r\n\r\n        return {\r\n          ...rest,\r\n          column_dropdown_value: cleanedDropdown,\r\n          query: cleanedQuery,\r\n        };\r\n      });\r\n    }\r\n\r\n  onResizeColumn(event: MouseEvent, col: any): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n\r\n    const startX = event.clientX;\r\n\r\n    const targetEl = document.querySelector(\r\n      `[field=\"${col.field}\"]`\r\n    ) as HTMLElement;\r\n    const initialWidth = targetEl?.offsetWidth || 150;\r\n\r\n    const matchingEls = document.querySelectorAll(`[data-field=\"${col.field}\"]`);\r\n\r\n    // 👉 Add highlight while resizing\r\n    if (col?.pinned == 'right') {\r\n      matchingEls.forEach((el: Element) => {\r\n        (el as HTMLElement).classList.add('resizing-highlight-right');\r\n      });\r\n    } else {\r\n      matchingEls.forEach((el: Element) => {\r\n        (el as HTMLElement).classList.add('resizing-highlight');\r\n      });\r\n    }\r\n\r\n    const onMouseMove = (moveEvent: MouseEvent) => {\r\n      let deltaX = moveEvent.clientX - startX;\r\n\r\n      // 👉 Reverse if the column is pinned to the right\r\n      if (col.pinned === 'right') {\r\n        deltaX = -deltaX;\r\n      }\r\n\r\n      let newWidth = initialWidth + deltaX;\r\n      if (newWidth < 80) return;\r\n\r\n      matchingEls.forEach((el: Element) => {\r\n        const element = el as HTMLElement;\r\n        element.style.minWidth = `${newWidth}px`;\r\n        element.style.width = `${newWidth}px`;\r\n      });\r\n\r\n      this.updateColumnWidthInSourceByField(col.field, newWidth);\r\n      col.width = newWidth;\r\n      this.hasScroll = this.hasHorizontalScrollbar();\r\n    };\r\n\r\n    const onMouseUp = () => {\r\n      if (this.tableFilterViewId) {\r\n        this.savePreset('mouseUp');\r\n      }\r\n      this.refreshHeaders();\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n\r\n      matchingEls.forEach((el: Element) => {\r\n        (el as HTMLElement).classList.remove('resizing-highlight');\r\n        (el as HTMLElement).classList.remove('resizing-highlight-right');\r\n      });\r\n\r\n      window.removeEventListener('mousemove', onMouseMove);\r\n      window.removeEventListener('mouseup', onMouseUp);\r\n    };\r\n\r\n    window.addEventListener('mousemove', onMouseMove);\r\n    window.addEventListener('mouseup', onMouseUp);\r\n  }\r\n\r\n\r\n\r\n  onResizeGroupBox(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n\r\n    const startX = event.clientX;\r\n\r\n    const targetEl = document.getElementById('groupBoxHeaderDiv');\r\n    const initialWidth = targetEl?.offsetWidth || 150;\r\n\r\n    const onMouseMove = (moveEvent: MouseEvent) => {\r\n      const deltaX = moveEvent.clientX - startX;\r\n\r\n      let newWidth = initialWidth + deltaX;\r\n      if (newWidth < 100) newWidth = 100;\r\n\r\n      if (targetEl) {\r\n        targetEl.style.width = `${newWidth}px`;\r\n        targetEl.style.minWidth = `${newWidth}px`;\r\n        this.groupBoxPadding = newWidth;\r\n      }\r\n    };\r\n\r\n    const onMouseUp = () => {\r\n      window.removeEventListener('mousemove', onMouseMove);\r\n      window.removeEventListener('mouseup', onMouseUp);\r\n    };\r\n\r\n    window.addEventListener('mousemove', onMouseMove);\r\n    window.addEventListener('mouseup', onMouseUp);\r\n  }\r\n\r\n  onPasteInFilterRowSearch(event: ClipboardEvent, col: any) {\r\n    setTimeout(() => {\r\n      this.onFilterChange(col);\r\n      this.applyDropdownFilter();\r\n    });\r\n  }\r\n\r\n  onFilterChange(col: any): void {\r\n    const filterValue = col.filterValue?.toLowerCase() || '';\r\n    this.selectedColumnForFilter = col;\r\n    if (!col?.query) {\r\n      col.query = {\r\n        first_condition: col.type == 'date' ? 'equal' : 'contain',\r\n        first_value: null,\r\n        second_condition: null,\r\n        second_value: null,\r\n        condition: null\r\n      }\r\n    }\r\n    col.query.first_value = filterValue;\r\n    this.firstValue = filterValue;\r\n  }\r\n\r\n  // Get Body Height\r\n  get bodyWrapperHeight(): string {\r\n    const rows = this.showColumnsGrouping && this.showFilterRow ? 3 : (this.showColumnsGrouping || this.showFilterRow ? 2 : 1);\r\n    const offset = this.headerRowHeight * rows + (this.hasScroll ? 17 : 0);\r\n    return `calc(100% - ${offset}px)`;\r\n  }\r\n\r\n  // Row Hover Logic Here\r\n  hoveredRowId: string | number | null = null;\r\n  onRowHover(row: any): void {\r\n    this.hoveredRowId = row._id || row.id;\r\n  }\r\n\r\n  onRowLeave(): void {\r\n    this.hoveredRowId = null;\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onDocumentClick(event: MouseEvent): void {\r\n    const target = event.target as HTMLElement;\r\n    this.isVisible = false;\r\n    this.openIndex = null;\r\n    if (\r\n      !this.hasParentWithClass(target, [\r\n        'three-dots',\r\n        'filter-icon-wrapper',\r\n        'column-menu',\r\n        'filter-menu',\r\n      ])\r\n    ) {\r\n      this.activeCol = null;\r\n      this.activeFilterCell = null;\r\n    }\r\n    if (!this.elementRef.nativeElement.contains(event.target)) {\r\n      this.showActionsDropDown = false;\r\n    }\r\n    const insideTopFilterRow = target.closest('.filter-tags') || target.closest('.add-filter-button-menu') ||\r\n      target.closest('.table-right-top-actions') || target.closest('.table-layout') || target.closest('.filter-row-filter-wrapper');\r\n    const isClickedInsideThreeDotsFilter = target.closest('.three-dots-filter') || target.closest('.filter-menu-container');\r\n    if (!isClickedInsideThreeDotsFilter) {\r\n      this.closeThreeDotsMenuFilter();\r\n    }\r\n    if (!insideTopFilterRow) {\r\n      this.closeFilterDropdowns(event);\r\n    }\r\n    if (!target.closest('.set-default-preset')) {\r\n      document.querySelector('.set-default-preset')?.classList?.remove('show');\r\n    }\r\n\r\n    if (!target.closest('.full-text-box') && !target.closest('.data-grid-header-wrapper')) {\r\n      this.collapseAllExpandedCells();\r\n    }\r\n\r\n    if (!target.closest('.data-grid-table-wrapper')) {\r\n      this.selectedKeys.clear();\r\n      this.activeCell = '';\r\n    }\r\n  }\r\n\r\n\r\n  closeThreeDotsMenuFilter() {\r\n    this.isThreeDotsFilterOpen = false;\r\n  }\r\n\r\n\r\n  closeFilterDropdowns(event: MouseEvent) {\r\n    this.isFilterOpen = false;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n    this.activeFilterCell = null;\r\n  }\r\n\r\n  private hasParentWithClass(\r\n    element: HTMLElement,\r\n    classList: string[]\r\n  ): boolean {\r\n    let el: HTMLElement | null = element;\r\n\r\n    while (el !== null) {\r\n      if (\r\n        el.classList &&\r\n        classList.some((className) => el!.classList.contains(className))\r\n      ) {\r\n        return true;\r\n      }\r\n      el = el.parentElement;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  isMenueHidden = false;\r\n  openThreeDotsMenu(event: MouseEvent, child: any, keepOriginalPosition = false) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isMenueHidden = true;\r\n    const containerWidth = this.dataGridContainer?.nativeElement?.offsetWidth;\r\n    this.activeCol = child;\r\n    this.activeFilterCell = null;\r\n    const x = event.clientX;\r\n    setTimeout(() => {\r\n      const element = document.querySelector('.column-menu') as HTMLElement;\r\n      if (element) {\r\n        if (x > (containerWidth / 2)) {\r\n          element.style.left = `${x - 240}px`;\r\n        } else {\r\n          element!.style.left = `${x}px`;\r\n        }\r\n      }\r\n      this.isMenueHidden = false;\r\n      this.cdr.detectChanges();\r\n    }, 0);\r\n  }\r\n  // ////////////////////////////////////////////////////////////////////////////////////////\r\n  // ////////////////////////////////////////////////////////////////////////////////////////\r\n  // Column Three Dots Actions\r\n  // //////////////////////////////////////////////////////////////////////////////////////\r\n  // //////////////////////////////////////////////////////////////////////////////////////\r\n  sortAsc(col: any) {\r\n    if (!col.is_sortable) return;\r\n    col!.order_by = 'asc';\r\n    const event = {\r\n      order: 'asc',\r\n      column: col\r\n    }\r\n    this.cdr.detectChanges();\r\n    this.sortingOrderOptions.emit(event);\r\n  }\r\n\r\n  sortDesc(col: any) {\r\n    if (!col.is_sortable) return;\r\n    col!.order_by = 'desc';\r\n    const event = {\r\n      order: 'desc',\r\n      column: col\r\n    }\r\n    this.cdr.detectChanges();\r\n    this.sortingOrderOptions.emit(event);\r\n  }\r\n\r\n  resetSort(col: any) {\r\n    this.sortingConfig = { field: '', order_by: '' };\r\n    const event = { field: null, order_by: null }\r\n    this.cdr.detectChanges();\r\n    this.sortingOrderOptions.emit(event);\r\n  }\r\n\r\n\r\n  async updateColumnPinInSourceByField(\r\n    column: any,\r\n    pinned: 'left' | 'right' | null,\r\n    isNestedTable: any = false,\r\n    columns?: any\r\n  ) {\r\n    debugger\r\n    if (isNestedTable) {\r\n      this.pinUnpinColum(column, pinned, columns);\r\n      return;\r\n    }\r\n    const update = (columns: any[]) => {\r\n      for (const col of columns) {\r\n        if (col.children?.length) {\r\n          update(col.children);\r\n        } else if (col.field === column.field) {\r\n          col.pinned = pinned;\r\n        }\r\n      }\r\n    };\r\n    this.activeCol = null;\r\n    update(this.columns);\r\n    this.updateColumnWidthsAndGroups();\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n  }\r\n\r\n  private getVisibleLeafColumns = (columns: any[]): any[] => {\r\n    const result: any[] = [];\r\n    for (const column of columns) {\r\n      if (column.children && Array.isArray(column.children)) {\r\n        result.push(...this.getVisibleLeafColumns(column.children));\r\n      } else if (column.is_visible) {\r\n        result.push(column);\r\n      }\r\n    }\r\n    return result;\r\n  };\r\n\r\n  autosizeColumn(cols: any | any[]): void {\r\n    this.activeCol = null;\r\n\r\n    // Normalize input to an array\r\n    const columnsToResize = Array.isArray(cols) ? cols : [cols];\r\n\r\n    // Helper: Flatten all visible leaf columns\r\n    const visibleColumns = this.getVisibleLeafColumns(this.columns);\r\n    const visibleCount = visibleColumns.length;\r\n\r\n    if (visibleCount === 0) return;\r\n\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n    if (this.showSerialNumber) containerWidth -= 55;\r\n    if (this.showSideMenu) containerWidth -= 29;\r\n    if (this.gridType == 'Assets' || this.gridType == 'Tasks') containerWidth -= 30;\r\n    containerWidth -= 55;\r\n    const equalWidth = Math.floor(containerWidth / visibleCount);\r\n\r\n    // Resize each passed column\r\n    for (const col of columnsToResize) {\r\n      if (col && col.field) {\r\n        col.width = equalWidth;\r\n        this.updateColumnWidthInSourceByField(col.field, equalWidth);\r\n      }\r\n    }\r\n\r\n    this.updateColumnWidthsAndGroups();\r\n\r\n    setTimeout(() => {\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n    }, 1000);\r\n    this.refreshPreviewColumns();\r\n  }\r\n\r\n  getGroupWidth(group: any): number {\r\n    return (\r\n      group?.children\r\n        ?.filter((col: any) => col?.is_visible)\r\n        ?.reduce((acc: number, col: any) => acc + (col?.width || 0), 0) || 0\r\n    );\r\n  }\r\n\r\n  autosizeAllColumns(): void {\r\n    this.activeCol = null;\r\n\r\n    const getVisibleLeafColumns = (columns: any[]): any[] => {\r\n      const result: any[] = [];\r\n\r\n      for (const column of columns) {\r\n        if (column.children && Array.isArray(column.children)) {\r\n          result.push(...getVisibleLeafColumns(column.children));\r\n        } else if (column.is_visible !== false) {\r\n          result.push(column);\r\n        }\r\n      }\r\n\r\n      return result;\r\n    };\r\n\r\n    const visibleColumns = getVisibleLeafColumns(this.columns);\r\n    const visibleCount = visibleColumns.length;\r\n\r\n    if (visibleCount === 0) return;\r\n\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n    if (this.showSerialNumber) containerWidth -= 55;\r\n    if (this.showSideMenu) containerWidth -= 29;\r\n    if (this.gridType == 'Assets' || this.gridType == 'Tasks') containerWidth -= 30;\r\n    containerWidth -= 55;\r\n    const equalWidth = Math.max(Math.floor(containerWidth / visibleCount), 150);\r\n\r\n    // Update widths for all visible columns\r\n    visibleColumns.forEach((col) => {\r\n      col.width = equalWidth;\r\n      this.updateColumnWidthInSourceByField(col.field, equalWidth);\r\n    });\r\n\r\n    this.refreshHeaders();\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n    setTimeout(() => {\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n    }, 1000);\r\n  }\r\n\r\n  private markColumnAsGrouped(columns: any[], field: string): void {\r\n    for (const col of columns) {\r\n      if (col.field === field) {\r\n        col.isRowGrouped = true;\r\n        return;\r\n      }\r\n      if (col.children?.length) {\r\n        this.markColumnAsGrouped(col.children, field);\r\n      }\r\n    }\r\n  }\r\n\r\n  async groupBy(col: any) {\r\n    this.mainScroll.nativeElement.scrollTop = 0;\r\n    this.translateY = 0;\r\n    this.cdr.detectChanges();\r\n    this.activeCol = null;\r\n    if (!col) return;\r\n    this.loading = true;\r\n    this.cdr.detectChanges();\r\n    if (col?.is_groupable) {\r\n      this.groupedColumns.push(col);\r\n      this.markColumnAsGrouped(this.columns, col.field);\r\n    }\r\n    const fields = this.groupedColumns.map((item) => item.field);\r\n    this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n    setTimeout(() => {\r\n      this.updateFlattenedData();\r\n      this.updateColumnWidthsAndGroups();\r\n      this.refreshPreviewColumns();\r\n      this.updateVisibleRows(0);\r\n      this.loading = false;\r\n      this.cdr.detectChanges();\r\n    }, 100);\r\n\r\n    setTimeout(() => {\r\n      this.groupBoxPadding = this.columnsGroupedBox?.nativeElement.offsetWidth;\r\n      this.cdr.detectChanges()\r\n    }, 10);\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  async groupDataAsync(data: any[], groupFields: string[]): Promise<any[]> {\r\n    return new Promise(resolve => {\r\n      setTimeout(() => {\r\n        const result = this.groupData(data, groupFields);\r\n        resolve(result);\r\n      }, 0);\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n  chooseColumns() {\r\n    this.activeCol = null;\r\n    this.showColumnPanel = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  resetColumns() {\r\n    this.activeCol = null;\r\n\r\n    // this.columns = structuredClone(this.originalColumns);\r\n    // Deep copy nested objects but keep class refs safe\r\n    this.originalColumns = this.columns.map(col => ({\r\n      ...col,\r\n      // Deep copy nested objects but keep class refs safe\r\n      query: col.query ? { ...col.query } : null,\r\n      column_dropdown_value: col.column_dropdown_value\r\n        ? [...col.column_dropdown_value]\r\n        : [],\r\n    }));\r\n\r\n    this.SetColumnsDefaultWidth();\r\n    setTimeout(() => {\r\n      this.updateColumnWidthsAndGroups();\r\n      this.refreshPreviewColumns();\r\n      this.cdr.detectChanges();\r\n    }, 100);\r\n  }\r\n\r\n  clearFilter(col: any) {\r\n    col.firstValue = '';\r\n    col.secondValue = '';\r\n    col.firstCondition = 'contain';\r\n    col.secondCondition = null;\r\n    col.logic = 'AND';\r\n    col.selectAll = false;\r\n    col.selectedOptions = {};\r\n    col.searchValue = '';\r\n\r\n  }\r\n\r\n\r\n  applyFilter(col: any) {\r\n    this.filterColumnsList.push(col);\r\n  }\r\n\r\n  // Rows Selection Logic Goes Here\r\n\r\n  selectedRows: Set<string> = new Set();\r\n\r\n  /**\r\n   * Get normalized ID from row.\r\n   */\r\n  private getRowId(row: any): string {\r\n    return row.id ?? row._id;\r\n  }\r\n\r\n  /**\r\n   * Toggle a single row selection.\r\n   */\r\n  toggleRowSelection(row: any): void {\r\n    const id = this.getRowId(row);\r\n\r\n    if (this.selectedRows.has(id)) {\r\n      this.selectedRows.delete(id);\r\n    } else {\r\n      this.selectedRows.add(id);\r\n    }\r\n\r\n    const ids = Array.from(this.selectedRows);\r\n\r\n    this.saveSelection(ids, this.tableType);\r\n\r\n    const event = {\r\n      data: {\r\n        listingType: this.listingType,\r\n        obj: ids\r\n      },\r\n      eventType: \"onSelectRow\",\r\n    };\r\n    this.genericEvent.emit(event);\r\n  }\r\n\r\n\r\n\r\n  toggleSelectAll(data: any[]): void {\r\n    const leafRows = this.getAllLeafRows(data);\r\n    const allIds = leafRows.map(r => this.getRowId(r));\r\n\r\n    const allSelected = allIds.every(id => this.selectedRows.has(id));\r\n\r\n    if (allSelected) {\r\n      allIds.forEach(id => this.selectedRows.delete(id));\r\n    } else {\r\n      allIds.forEach(id => this.selectedRows.add(id));\r\n    }\r\n    this.cdr.detectChanges();\r\n    const ids = Array.from(this.selectedRows);\r\n    const event = {\r\n      data: {\r\n        listingType: this.listingType,\r\n        obj: ids\r\n      },\r\n      eventType: \"onSelectRow\",\r\n    }\r\n    this.genericEvent.emit(event);\r\n    this.saveSelection(ids, this.tableType);\r\n  }\r\n\r\n  isRowSelected(row: any): boolean {\r\n    return this.selectedRows.has(this.getRowId(row));\r\n  }\r\n\r\n  isAllSelected(data: any[]): boolean {\r\n    const leafRows = this.getAllLeafRows(data);\r\n    return leafRows.length > 0 && leafRows.every(r => this.selectedRows.has(this.getRowId(r)));\r\n  }\r\n\r\n\r\n  isIndeterminateState(data: any[]): boolean {\r\n    const leafRows = this.getAllLeafRows(data);\r\n    const selectedCount = leafRows.filter(r => this.selectedRows.has(this.getRowId(r))).length;\r\n\r\n    return selectedCount > 0 && selectedCount < leafRows.length;\r\n  }\r\n\r\n\r\n  getAllLeafRows(data: any[]): any[] {\r\n    const leaf: any[] = [];\r\n\r\n    const traverse = (node: any) => {\r\n      if (!node) return;\r\n\r\n      if (node.isGroup) {\r\n        node.children?.forEach(traverse);\r\n      } else {\r\n        leaf.push(node);\r\n      }\r\n    };\r\n\r\n    data.forEach(traverse);\r\n    return leaf;\r\n  }\r\n\r\n\r\n\r\n\r\n  // Side Menu Working Goes Here\r\n  toggleSideMenu(clickedOn: 'cols' | 'filtrs') {\r\n    if (this.currentOpenedSideMenue == clickedOn) {\r\n      this.currentOpenedSideMenue = clickedOn;\r\n      this.sideMenuVisible = !this.sideMenuVisible;\r\n    } else if (\r\n      this.sideMenuVisible &&\r\n      clickedOn != this.currentOpenedSideMenue\r\n    ) {\r\n      this.currentOpenedSideMenue = clickedOn;\r\n      return;\r\n    } else {\r\n      this.currentOpenedSideMenue = clickedOn;\r\n      this.sideMenuVisible = !this.sideMenuVisible;\r\n    }\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  toggleGroupVisibility(col: any) {\r\n    const allVisible = col.children.every((child: any) => child.is_visible);\r\n    col.children.forEach((child: any) => (child.is_visible = !allVisible));\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      this.updateColumnWidthsAndGroups();\r\n      this.refreshPreviewColumns();\r\n      this.SetColumnsDefaultWidth();\r\n      this.cdr.detectChanges();\r\n    }, 10);\r\n  }\r\n\r\n  isColumnVisible(columns: any) {\r\n    if (columns?.children) {\r\n      return columns.children.every((element: any) => element.is_visible);\r\n    }\r\n\r\n    return columns?.is_visible;\r\n  }\r\n\r\n  allColumnsSelected(): boolean {\r\n    const flatten = this.flattenColumns(this.columns);\r\n    return flatten.every((col) => col.is_visible);\r\n  }\r\n\r\n\r\n  private findColumnByField(field: string, cols: any[]): any | null {\r\n    for (const col of cols) {\r\n      if (col.field === field) {\r\n        return col;\r\n      }\r\n      if (col.children && Array.isArray(col.children)) {\r\n        const found = this.findColumnByField(field, col.children);\r\n        if (found) return found;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n\r\n\r\n  async toggleColumnVisibility(column: any, isVisible: boolean) {\r\n    if (isVisible) {\r\n      if (this.visibleColumns()?.length <= 2 && column.is_visible || (column?.is_always_visible)) {\r\n        return;\r\n      }\r\n    }\r\n    const col = this.findColumnByField(column.field, this.columns);\r\n    if (col) {\r\n      col.is_visible = isVisible;\r\n    }\r\n    await this.refreshHeaders();\r\n    this.cdr.detectChanges();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    if (this.tableFilterViewId) {\r\n      this.savePreset('mouseUp');\r\n    }\r\n  }\r\n\r\n\r\n  async toggleAllColumnsVisibility(): Promise<void> {\r\n  this.loading = true;\r\n\r\n    try {\r\n      const flatten = this.flattenColumns(this.columns);\r\n      const visibleColumns = flatten.filter(col => col.is_visible);\r\n      if (visibleColumns.length <= 2) {\r\n        this.loading = false;\r\n        return;\r\n      }\r\n\r\n      const nonAlwaysVisible = flatten.filter(col => !col.is_always_visible);\r\n      const allNonAlwaysVisibleAreVisible = nonAlwaysVisible.every(col => col.is_visible);\r\n      if (allNonAlwaysVisibleAreVisible) {\r\n        flatten.forEach(col => {\r\n          col.is_visible = col.is_always_visible ? true : false;\r\n        });\r\n      } else {\r\n        flatten.forEach(col => (col.is_visible = true));\r\n      }\r\n      await this.wait(10);\r\n      this.updateColumnWidthsAndGroups();\r\n      await this.wait(10);\r\n      this.refreshPreviewColumns();\r\n      this.cdr.detectChanges();\r\n      await this.wait(100);\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n\r\n    } finally {\r\n      this.loading = false;\r\n    }\r\n  }\r\n\r\n  private wait(ms: number): Promise<void> {\r\n    return new Promise(resolve => setTimeout(resolve, ms));\r\n  }\r\n\r\n\r\n\r\n  visibleColumns() {\r\n    const flatten = this.flattenColumns(this.columns);\r\n    const visibleColumns = flatten.filter((c: any) => c.is_visible);\r\n    return visibleColumns;\r\n  }\r\n\r\n  flattenColumns(cols: any[]): any[] {\r\n    return cols.reduce((acc: any[], col: any) => {\r\n      if (col?.children && col.children.length) {\r\n        // recursively flatten children\r\n        return acc.concat(this.flattenColumns(col.children));\r\n      } else {\r\n        // leaf column\r\n        return acc.concat(col);\r\n      }\r\n    }, []);\r\n  }\r\n\r\n\r\n  filteredColumns(cols: any[]): any[] {\r\n    const search = this.columnSearch.toLowerCase();\r\n    return cols\r\n      .map((col) => {\r\n        if (col.children) {\r\n          const filteredChildren = this.filteredColumns(col.children);\r\n          if (\r\n            col.header.toLowerCase().includes(search) ||\r\n            filteredChildren.length\r\n          ) {\r\n            return { ...col, children: filteredChildren };\r\n          }\r\n          return null;\r\n        } else {\r\n          return col.header.toLowerCase().includes(search) ? col : null;\r\n        }\r\n      })\r\n      .filter(Boolean);\r\n  }\r\n\r\n  get accordionState(): 'all' | 'none' | 'some' {\r\n    const groups = this.getAllGroupColumns(this.columns);\r\n    const expandedCount = groups.filter((col) => col.expanded).length;\r\n\r\n    if (expandedCount === 0) return 'none';\r\n    if (expandedCount === groups.length) return 'all';\r\n    return 'some';\r\n  }\r\n\r\n  get filterAccordionState(): 'all' | 'none' | 'some' {\r\n    const groups = this.getAllGroupColumns(this.columns);\r\n    const expandedCount = groups.filter((col) => col.expandedFilter).length;\r\n\r\n    if (expandedCount === 0) return 'none';\r\n    if (expandedCount === groups.length) return 'all';\r\n    return 'some';\r\n  }\r\n\r\n  // Recursively collect all group columns\r\n  private getAllGroupColumns(cols: any[]): any[] {\r\n    let groups: any[] = [];\r\n    for (const col of cols) {\r\n      if (col.children?.length) {\r\n        groups.push(col);\r\n        groups = groups.concat(this.getAllGroupColumns(col.children));\r\n      }\r\n    }\r\n    return groups;\r\n  }\r\n\r\n  // Toggle based on current state\r\n  toggleAllAccordions(): void {\r\n    const nextState = this.accordionState === 'all' ? false : true;\r\n    this.setAccordionState(this.columns, nextState);\r\n  }\r\n\r\n  toggleAllFilterAccordions(): void {\r\n    const nextState = this.filterAccordionState === 'all' ? false : true;\r\n    this.setFilterAccordionState(this.columns, nextState);\r\n  }\r\n\r\n  private setAccordionState(cols: any[], state: boolean): void {\r\n    for (let col of cols) {\r\n      if (col.children?.length) {\r\n        col.expanded = state;\r\n        this.setAccordionState(col.children, state); // Recursively handle nested\r\n      }\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n  private setFilterAccordionState(cols: any[], state: boolean): void {\r\n    for (let col of cols) {\r\n      if (col.children?.length) {\r\n        col.expandedFilter = state;\r\n        this.setFilterAccordionState(col.children, state); // Recursively handle nested\r\n      }\r\n    }\r\n  }\r\n\r\n  showColumnPanel = false;\r\n\r\n  closeModalColumnPanel() {\r\n    this.showColumnPanel = false;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  @HostListener('document:keydown.escape', ['$event'])\r\n  onEscape(event: Event) {\r\n    this.closeModalColumnPanel();\r\n  }\r\n\r\n  // Check If  Any column have right pinned\r\n  get hasRightPinnedColumns() {\r\n    return this.commonSevice.gethasRightPinnedColumns(this.columns);\r\n  }\r\n\r\n  get hasLeftPinnedColumns() {\r\n    return this.commonSevice.gethasLeftPinnedColumns(this.columns);\r\n  }\r\n\r\n  get dataSetLength() {\r\n    return this.commonSevice.getExpandedRowCount(this.dataSet);\r\n  }\r\n\r\n\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: UIEvent) {\r\n    if (!this.curretaTablePresetForUpdate) this.autoSizeColumnsByRatio();\r\n    const h = this.mainScroll?.nativeElement?.clientHeight ?? 0;\r\n    this.viewportRows = Math.max(1, Math.ceil(h / this.rowHeight));\r\n    this.updateVisibleRows(this.mainScroll?.nativeElement?.scrollTop);\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n    setTimeout(() => { }, 100);\r\n  }\r\n\r\n  autoSizeColumnsByRatio(): void {\r\n    this.activeCol = null;\r\n\r\n    const getVisibleLeafColumns = (columns: any[]): any[] => {\r\n      const result: any[] = [];\r\n\r\n      for (const column of columns) {\r\n        if (column.children && Array.isArray(column.children)) {\r\n          result.push(...getVisibleLeafColumns(column.children));\r\n        } else if (column.is_visible !== false) {\r\n          result.push(column);\r\n        }\r\n      }\r\n      return result;\r\n    };\r\n\r\n    const visibleColumns = getVisibleLeafColumns(this.columns);\r\n\r\n    if (visibleColumns.length === 0) return;\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n\r\n    if (this.showSerialNumber) containerWidth -= 55;\r\n    if (this.showSideMenu) containerWidth -= 29;\r\n    if (this.gridType == 'Assets' || this.gridType == 'Tasks')\r\n      containerWidth -= 30;\r\n    containerWidth -= 55;\r\n    const totalOldWidth = visibleColumns.reduce(\r\n      (sum, col) => sum + (col.width || 0),\r\n      0\r\n    );\r\n    if (totalOldWidth === 0) return;\r\n    visibleColumns.forEach((col) => {\r\n      const ratio = col.width / totalOldWidth;\r\n      const newWidth = Math.max(Math.floor(containerWidth * ratio), 100);\r\n      col.width = newWidth;\r\n      this.updateColumnWidthInSourceByField(col.field, newWidth);\r\n    });\r\n\r\n    this.refreshHeaders();\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n    setTimeout(() => {\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n    }, 400);\r\n  }\r\n\r\n\r\n  async refreshHeaders() {\r\n    this.ngZone.runOutsideAngular(async () => {\r\n      await new Promise(r => setTimeout(r, 0));\r\n      await this.updateColumnWidthsAndGroups();\r\n      await this.refreshPreviewColumns();\r\n\r\n      this.ngZone.run(() => this.cdr.detectChanges());\r\n    });\r\n  }\r\n\r\n  get hasAnyVisibleColumn() {\r\n    return this.commonSevice.gethasVisibleColumns(this.columns);\r\n  }\r\n\r\n  get hasAnyInVisibleColumn() {\r\n    return this.commonSevice.gethasInVisibleColumns(this.columns);\r\n  }\r\n\r\n  get columnsCount() {\r\n    return this.commonSevice.getTotalColumnsLength(this.columns);\r\n  }\r\n\r\n  tableHeaderAndBodyHeight() {\r\n    return `calc(100% - ${this.footerRowHeight})`;\r\n  }\r\n\r\n  draggingInGroupArea = false;\r\n\r\n  @ViewChild('centerScroll') centerScroll!: ElementRef<HTMLDivElement>;\r\n  visibleRowCount = 25;\r\n  startIndex = 0;\r\n  visibleRows: any[] = [];\r\n\r\n  private flattenGroupedRows(\r\n    rows: any[] = [],\r\n    level = 0,\r\n    result: any[] = []\r\n  ): any[] {\r\n    for (const row of rows) {\r\n      result.push({ ...row, __depth: level });\r\n      if (row.isGroup && row.isExpand && row.children?.length) {\r\n        this.flattenGroupedRows(row.children, level + 1, []);\r\n      }\r\n    }\r\n    this.assignVirtualIndexes(this.visibleRows);\r\n    return result;\r\n  }\r\n\r\n  assignVirtualIndexes(data: any[]): any[] {\r\n    let currentIndex = 1;\r\n    const walk = (items: any[]): void => {\r\n      for (const item of items) {\r\n        item.__virtualIndex = currentIndex++;\r\n        if (item?.isGroup) {\r\n          const group = item;\r\n          if (group.isExpand && Array.isArray(group.children)) {\r\n            walk(group.children);\r\n          }\r\n        }\r\n      }\r\n    };\r\n    walk(data);\r\n    // console.log('This dataset: ', this.visibleRows)\r\n    return data;\r\n  }\r\n\r\n\r\n  updateVisibleRows(scrollTop: number) {\r\n\r\n    if (this.groupedColumns?.length) {\r\n      this.visibleRows = this.dataSet;\r\n      return;\r\n    }\r\n    const flatData = this.flattenGroupedRows(this.dataSet);\r\n\r\n    if (this.dataSet?.length <= 15) {\r\n      this.visibleRows = flatData;\r\n      this.firstIndex = 0;\r\n      this.startIndex = 0;\r\n      this.renderStart = 0;\r\n      this.cdr.detectChanges();\r\n      return;\r\n    }\r\n    const total = flatData.length;\r\n    const maxFirst = Math.max(0, total - this.viewportRows);\r\n    const first = Math.min(Math.floor(scrollTop / this.rowHeight), maxFirst);\r\n    const start = Math.max(0, first);\r\n    const end = Math.min(total, first + this.viewportRows);\r\n\r\n    this.firstIndex = first;\r\n    this.startIndex = first;\r\n    this.renderStart = start;\r\n    this.visibleRows = flatData.slice(start, end);\r\n    this.assignVirtualIndexes(this.visibleRows);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  trackByRenderedIndex = (i: number, _row: any) => this.renderStart + i;\r\n\r\n  private isSyncingFromMain = false;\r\n  private isSyncingFromFake = false;\r\n  private mainScrollRaf: number | null = null;\r\n\r\n  trackById(index: number, item: any) {\r\n    return item.id || item._id;\r\n  }\r\n\r\n  flattenedData: any[] = [];\r\n\r\n  updateFlattenedData(): void {\r\n    setTimeout(() => {\r\n      this.flattenedData = this.flattenGroupedRows(this.dataSet);\r\n      this.cdr.detectChanges();\r\n    }, 10);\r\n  }\r\n\r\n  // requestAnimationFrame IDs\r\n  private fakeScrollRaf: number | null = null;\r\n\r\n\r\n  // onMainScroll(event: Event) {\r\n  //   this.expandedCells.clear();\r\n  //   const scrollTop = (event.target as HTMLElement).scrollTop;\r\n  //     if (this.groupedColumns?.length > 0) {\r\n  //       this.startIndex = 0;\r\n  //       this.cdr.detectChanges();\r\n  //       return;\r\n  //     }\r\n  //     const overscan = this.overscan * 2;\r\n  //     this.startIndex = Math.floor(scrollTop / this.rowHeight);\r\n  //     const start = Math.max(0, this.startIndex - overscan);\r\n  //     const end = Math.min(this.flattenedData.length, this.startIndex + this.viewportRows + overscan);\r\n  //     this.visibleRows = this.flattenedData.slice(start, end);\r\n  //     this.cdr.detectChanges();\r\n  // }\r\n  translateY = 0;\r\n\r\n  lastScrollTop = 0;\r\n  pendingAnimationFrame: number | null = null;\r\n\r\n  onMainScroll(event: Event): void {\r\n    const scrollTop = (event.target as HTMLElement).scrollTop;\r\n    if (Math.abs(scrollTop - this.lastScrollTop) < (10)) return;\r\n    if (this.pendingAnimationFrame) cancelAnimationFrame(this.pendingAnimationFrame);\r\n    if (this.groupedColumns?.length > 0) {\r\n      this.startIndex = 0;\r\n      this.cdr.detectChanges();\r\n      return;\r\n    }\r\n    this.pendingAnimationFrame = requestAnimationFrame(() => {\r\n      const scrollingDown = scrollTop > this.lastScrollTop;\r\n      this.lastScrollTop = scrollTop;\r\n\r\n      const overscan = 5;\r\n      const newStartIndex = Math.floor(scrollTop / this.rowHeight);\r\n      const dynamicOverscan = scrollingDown ? overscan : overscan;\r\n\r\n      const start = Math.max(0, newStartIndex - dynamicOverscan);\r\n      const end = Math.min(\r\n        this.flattenedData.length,\r\n        newStartIndex + this.viewportRows + dynamicOverscan\r\n      );\r\n      this.translateY = start * this.rowHeight;\r\n      if (this.startIndex !== start || this.visibleRows.length !== end - start) {\r\n        this.startIndex = start;\r\n        this.visibleRows = this.dataSet.slice(start, end);\r\n        this.cdr.markForCheck();\r\n      }\r\n\r\n      this.pendingAnimationFrame = null;\r\n    });\r\n  }\r\n\r\n\r\n  // onMainScroll(event: Event): void {\r\n  //   this.expandedCells.clear();\r\n  //   if (this.isSyncingFromFake) {\r\n  //     this.isSyncingFromFake = false;\r\n  //     return;\r\n  //   }\r\n  //   const scrollTop = (event.target as HTMLElement).scrollTop;\r\n  //   if (Math.abs(scrollTop - this.lastScrollTop) < this.rowHeight / 2) return;\r\n  //   this.lastScrollTop = scrollTop;\r\n\r\n  //   if (this.fakeScrollRaf) cancelAnimationFrame(this.fakeScrollRaf);\r\n\r\n  //   this.fakeScrollRaf = requestAnimationFrame(() => {\r\n  //     if (this.groupedColumns?.length > 0) {\r\n  //       this.startIndex = 0;\r\n  //       this.cdr.detectChanges();\r\n  //       return;\r\n  //     }\r\n  //     const flatData = this.flattenGroupedRows(this.dataSet);\r\n  //     const totalRows = flatData.length;\r\n  //     const newStartIndex = Math.floor(scrollTop / this.rowHeight);\r\n  //     const start = Math.max(0, newStartIndex - (this.overscan * 2));\r\n  //     const end = Math.min(totalRows, newStartIndex + this.viewportRows + (this.overscan * 2));\r\n\r\n  //     this.translateY = start * this.rowHeight;\r\n  //     this.startIndex = start;\r\n  //     this.visibleRows = flatData.slice(start, end);\r\n  //     this.cdr.detectChanges();\r\n  //   });\r\n  // }\r\n\r\n\r\n  get isScrollbarVisible(): boolean {\r\n    if (!this.mainScroll) return false;\r\n    const el = this.mainScroll.nativeElement;\r\n    return el.scrollHeight > el.clientHeight;\r\n  }\r\n\r\n  toggleExpand(row: any) {\r\n    if (row.details) {\r\n      row.isDetailsExpand = !row.isDetailsExpand;\r\n    } else {\r\n      row.isExpand = !row.isExpand;\r\n    }\r\n    this.rowSelectedIndexes.clear();\r\n    this.updateFlattenedData();\r\n    // this.cdr.detectChanges();\r\n    // setTimeout(() => {\r\n    //   this.cdr.detectChanges();\r\n    // }, 100);\r\n  }\r\n\r\n  // onMainFakeScroll(event: Event) {\r\n  //   if (this.isSyncingFromMain) {\r\n  //     this.isSyncingFromMain = false;\r\n  //     return;\r\n  //   }\r\n  //   if (this.groupedColumns?.length > 0) {\r\n  //     this.startIndex = 0;\r\n  //     this.cdr.detectChanges();\r\n  //     return;\r\n  //   }\r\n  //   const scrollTop = (event.target as HTMLElement).scrollTop;\r\n  //   if (this.mainScrollRaf) cancelAnimationFrame(this.mainScrollRaf);\r\n  //   this.mainScrollRaf = requestAnimationFrame(() => {\r\n  //     this.isSyncingFromFake = true;\r\n  //     this.mainScroll.nativeElement.scrollTop = scrollTop;\r\n  //     const overscan = this.overscan ?? 0;\r\n  //     this.startIndex = Math.floor(scrollTop / this.rowHeight);\r\n  //     const start = Math.max(0, this.startIndex - overscan);\r\n  //     const end = Math.min(\r\n  //       this.flattenedData.length,\r\n  //       this.startIndex + this.viewportRows + overscan\r\n  //     );\r\n  //     this.visibleRows = this.flattenedData.slice(start, end);\r\n  //     this.cdr.detectChanges();\r\n  //   });\r\n  // }\r\n\r\n\r\n\r\n\r\n\r\n  viewportRows = 0; // how many rows fit in viewport (computed)\r\n  firstIndex = 0; // index of the first visible row (clamped)\r\n  renderStart = 0; // where the slice actually starts (firstIndex - overscan, clamped)\r\n\r\n  private scrollRaf: number | null = null;\r\n  private pendingScrollTop = 0;\r\n\r\n  @ViewChild('mainScroll') mainScroll!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('fakeScroll') fakeScroll!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('horizintalFakeScroll')\r\n  horizintalFakeScroll!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('centerScrollableBody')\r\n  centerScrollableBody!: ElementRef<HTMLDivElement>;\r\n  private overscan = 10; // buffer rows above and below\r\n\r\n  computeViewportRows() {\r\n    if (this.fakeScroll?.nativeElement) {\r\n      this.fakeScroll.nativeElement.scrollTop = 0;\r\n    }\r\n\r\n    if (this.mainScroll?.nativeElement) {\r\n      this.mainScroll.nativeElement.scrollTop = 0;\r\n      const h = this.mainScroll.nativeElement.clientHeight ?? 0;\r\n\r\n      // rows visible in viewport\r\n      const rowsInViewport = Math.max(1, Math.ceil(h / this.rowHeight));\r\n\r\n      // add buffer rows (overscan)\r\n      this.viewportRows = rowsInViewport + this.overscan;\r\n\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n\r\n  onHorizontalFakeScroll(event: Event) {\r\n    const scrollLeft = (event.target as HTMLElement).scrollLeft;\r\n    this.centerPinnedHeader.nativeElement.scrollLeft = scrollLeft;\r\n    if (this.centerScrollableBody?.nativeElement) {\r\n      this.centerScrollableBody.nativeElement.scrollLeft = scrollLeft;\r\n    }\r\n  }\r\n\r\n  onCenterBodyScroll(event: Event) {\r\n    const target = event.target as HTMLElement;\r\n    if (this.centerScrollableBody?.nativeElement) {\r\n      this.centerScrollableBody.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n    if (this.centerPinnedHeader) {\r\n      this.centerPinnedHeader.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n    if (this.horizintalFakeScroll?.nativeElement) {\r\n      this.horizintalFakeScroll.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n  }\r\n\r\n  onCenterHeaderScroll(event: Event) {\r\n    const target = event.target as HTMLElement;\r\n    if (this.horizintalFakeScroll?.nativeElement) {\r\n      this.horizintalFakeScroll.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n    if (this.centerScrollableBody?.nativeElement) {\r\n      this.centerScrollableBody.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n  }\r\n\r\n  // Dragging Logic is implemented here\r\n  // private initialIndex: number | null = null;\r\n\r\n  draggingColumn: any;\r\n  dragStartIndex: any = 0;\r\n  // onDragStart(data: any, index: number) {\r\n  //   this.draggingColumn = data.column;\r\n  //   this.dragStartIndex = index;\r\n  // }\r\n  // onDragMove(data: any) {\r\n  //   const { clientX, clientY } = data.event;\r\n  //   const headers = Array.from(\r\n  //     document.querySelectorAll('.one-row-header-cells')\r\n  //   ) as HTMLElement[];\r\n\r\n  //   headers.forEach((headerEl, idx) => {\r\n  //     const rect = headerEl.getBoundingClientRect();\r\n  //     if (\r\n  //       idx !== this.dragStartIndex &&\r\n  //       clientX > rect.left &&\r\n  //       clientX < rect.right &&\r\n  //       clientY > rect.top &&\r\n  //       clientY < rect.bottom\r\n  //     ) {\r\n  //       const otherIndex = idx;\r\n  //       console.log(`${this.dragStartIndex} --> ${otherIndex}`);\r\n  //       this.swapColumn(this.dragStartIndex, otherIndex);\r\n  //       console.log('Updated Columns: ', this.columns);\r\n  //       this.dragStartIndex = otherIndex; // update index\r\n  //     }\r\n  //   });\r\n  // }\r\n\r\n  // swapColumn(previusIndex: number, currentIndex: number) {\r\n  //   const columns = structuredClone(this.columns);\r\n  //   const flattenColumns = this.flattenColumns(columns);\r\n\r\n  //   const visibleFlattenColumns = flattenColumns.filter(\r\n  //     (col) => col.is_visible\r\n  //   );\r\n  //   const previusColumn = visibleFlattenColumns[previusIndex];\r\n  //   const currentColumn = visibleFlattenColumns[currentIndex];\r\n\r\n  //   console.log('Previus Column: ', previusColumn);\r\n  //   console.log('current clumn: ', currentColumn);\r\n  // }\r\n\r\n  // onDragEnd(data: any) {\r\n  //   this.draggingColumn = null;\r\n  //   this.dragStartIndex = null;\r\n  // }\r\n\r\n  // CDK DRAG DROP LOGIC GOES HERE\r\n\r\n\r\n  canEnterToRowsGrouping = (drag: CdkDrag<any>, drop: CdkDropList<any>) => {\r\n    // Example: Block if already pinned left\r\n    const data = drag.data;\r\n    if (data?.children && data?.children.length) {\r\n      return data.children.some(\r\n        (col: any) => col.is_visible && col.is_groupable\r\n      );\r\n    }\r\n    return data.is_visible && data.is_groupable;\r\n  };\r\n\r\n  // onDragMoved(event: CdkDragMove<any>) {\r\n  //   const pointerX = event.pointerPosition.x;\r\n  //   const pointerY = event.pointerPosition.y;\r\n\r\n  //   const targetElement = document.getElementById(\r\n  //     'rows-grouping-top-container'\r\n  //   );\r\n\r\n  //   if (targetElement) {\r\n  //     const rect = targetElement.getBoundingClientRect();\r\n\r\n  //     const isOverTarget =\r\n  //       pointerX >= rect.left &&\r\n  //       pointerX <= rect.right &&\r\n  //       pointerY >= rect.top &&\r\n  //       pointerY <= rect.bottom;\r\n\r\n  //     if (isOverTarget) {\r\n  //       this.draggingInGroupArea = true;\r\n  //     } else {\r\n  //       this.draggingInGroupArea = false;\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n  enterToTopRowGrouping(dropList: CdkDragEnter<any>) {\r\n    const draggingData = dropList.item.data;\r\n    this.draggingInGroupArea = true;\r\n    // console.log(\"Dragging in group area\")\r\n    this.cdr.detectChanges();\r\n\r\n    if (Array.isArray(draggingData?.children)) {\r\n      const targetGroup = this.columns.find(\r\n        (col) => col.header === draggingData.header\r\n      );\r\n      if (targetGroup) {\r\n        draggingData.children.forEach((draggedChild: any) => {\r\n          const matchingChild = targetGroup.children.find(\r\n            (child: any) => child.field === draggedChild.field\r\n          );\r\n          if (matchingChild) {\r\n            matchingChild.isRowGrouped = !!matchingChild.is_groupable;\r\n          }\r\n        });\r\n      }\r\n    }\r\n    else {\r\n      // Try finding it in top-level columns first\r\n      let targetColumn = this.columns.find(\r\n        (col: any) => col.field === draggingData.field\r\n      );\r\n\r\n      if (targetColumn) {\r\n        targetColumn.isRowGrouped = !!targetColumn.is_groupable;\r\n      } else {\r\n        for (let group of this.columns) {\r\n          if (Array.isArray(group.children)) {\r\n            const matchingChild = group.children.find(\r\n              (child: any) => child.field === draggingData.field\r\n            );\r\n            if (matchingChild) {\r\n              matchingChild.isRowGrouped = !!matchingChild.is_groupable;\r\n              break;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    // ✅ Refresh UI\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onDropListEnter(\r\n    dropList: CdkDragEnter<any>,\r\n    section: 'left' | 'center' | 'right'\r\n  ) {\r\n    const draggingData = dropList.item.data;\r\n\r\n    const targetColumn: any = this.columns.find(\r\n      (col) => col.header == draggingData.header\r\n    );\r\n\r\n    if (!targetColumn) return;\r\n\r\n    if (\r\n      Array.isArray(draggingData?.children) &&\r\n      Array.isArray(targetColumn?.children)\r\n    ) {\r\n      draggingData.children.forEach((draggedChild: any) => {\r\n        const matchingChild = targetColumn.children.find(\r\n          (child: any) => child.field === draggedChild.field\r\n        );\r\n        if (matchingChild) {\r\n          matchingChild.pinned = section === 'center' ? null : section;\r\n          matchingChild['isRowGrouped'] = false;\r\n        }\r\n      });\r\n    } else {\r\n      targetColumn.pinned = section === 'center' ? null : section;\r\n      targetColumn['isRowGrouped'] = false;\r\n    }\r\n\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  // enterToTopGroupingRow(dropList: CdkDragEnter<any>) {\r\n  //   this.shouldDisableDroplistSorting = this.isDisableColumnGrouping;\r\n  //   this.draggingInGroupArea = true;\r\n  //   this.cdr.detectChanges();\r\n  // const index = this.groupedColumns.findIndex(\r\n  //   (col) => col.field === column.field\r\n  // );\r\n  // if (index !== -1) {\r\n  //   this.groupedColumns.splice(index, 1);\r\n  // }\r\n\r\n  // // 2. Traverse this.columns to find and update the matching column\r\n  // this.columns.forEach((group) => {\r\n  //   if (group?.children && Array.isArray(group.children)) {\r\n  //     group.children.forEach((child) => {\r\n  //       if (child.field === column.field) {\r\n  //         child.isRowGrouped = false;\r\n  //       }\r\n  //     });\r\n  //   } else if (group.field === column.field) {\r\n  //     group.isRowGrouped = false;\r\n  //   }\r\n  // });\r\n  //   this.cdr.detectChanges();\r\n  // }\r\n\r\n  exitedFromTheTopRow(dropList: CdkDragExit<any>) {\r\n    this.draggingInGroupArea = false;\r\n    this.isDisableColumnGrouping = false;\r\n    this.shouldDisableDroplistSorting = false;\r\n    const draggingData = dropList.item.data;\r\n    if (Array.isArray(draggingData?.children)) {\r\n      const targetGroup = this.columns.find(\r\n        (col) => col.header === draggingData.header\r\n      );\r\n      if (targetGroup) {\r\n        draggingData.children.forEach((draggedChild: any) => {\r\n          const matchingChild = targetGroup.children.find(\r\n            (child: any) => child.field === draggedChild.field\r\n          );\r\n          if (matchingChild) {\r\n            matchingChild.isRowGrouped = false;\r\n          }\r\n        });\r\n      }\r\n    } else {\r\n      let targetColumn = this.columns.find(\r\n        (col: any) => col.field === draggingData.field\r\n      );\r\n\r\n      if (targetColumn) {\r\n        targetColumn.isRowGrouped = false;\r\n      } else {\r\n        for (let group of this.columns) {\r\n          if (Array.isArray(group.children)) {\r\n            const matchingChild = group.children.find(\r\n              (child: any) => child.field === draggingData.field\r\n            );\r\n            if (matchingChild) {\r\n              matchingChild.isRowGrouped = false;\r\n              break;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  shouldDisableDroplistSorting = false;\r\n  isDisableColumnGrouping = false;\r\n  checkColumnGroupingStatus(col: any) {\r\n    if (col?.children && Array.isArray(col.children)) {\r\n      const allChildrenDisabled = col.children.every(\r\n        (child: any) => child.is_groupable === false\r\n      );\r\n      this.isDisableColumnGrouping = allChildrenDisabled;\r\n    } else {\r\n      this.isDisableColumnGrouping = col.is_groupable === false;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  currentDraggingColumn: any = null;\r\n  dragStartOnGroup(col: any) {\r\n    this.currentDraggingColumn = col;\r\n  }\r\n\r\n  onSortGroup = async (event: CdkDragSortEvent<any>, section: string) => {\r\n    const columns = (this as any)[section];\r\n    if (event.previousIndex === event.currentIndex) return;\r\n    const visibleColumns = columns.filter((col: any) => {\r\n      if (col?.children && Array.isArray(col.children)) {\r\n        return col.children.some((child: any) => child.is_visible);\r\n      }\r\n      return col.is_visible;\r\n    });\r\n    const previousHeader = visibleColumns[event.previousIndex].header;\r\n    const currentHeader = visibleColumns[event.currentIndex].header;\r\n    const visiblePrevIndex = visibleColumns.findIndex(\r\n      (col: any) => col.header === previousHeader\r\n    );\r\n    const visibleCurrIndex = visibleColumns.findIndex(\r\n      (col: any) => col.header === currentHeader\r\n    );\r\n    const getFields = (item: any): string[] => {\r\n      if (item?.children && Array.isArray(item.children)) {\r\n        return item.children.map((child: any) => child.field);\r\n      }\r\n      return [item.field];\r\n    };\r\n    const prevFields = getFields(visibleColumns[visiblePrevIndex]);\r\n    const currFields = getFields(visibleColumns[visibleCurrIndex]);\r\n    const allFields = [...prevFields, ...currFields];\r\n    const cells = allFields.length\r\n      ? ([] as HTMLElement[]).concat(\r\n        ...allFields.map((field) =>\r\n          Array.from(document.querySelectorAll(`[data-field=\"${field}\"]`)) as HTMLElement[]\r\n        )\r\n      )\r\n      : [];\r\n    const firstPositions = new Map<HTMLElement, number>();\r\n    cells.forEach((el) => firstPositions.set(el, el.getBoundingClientRect().left));\r\n    // console.log(\"this .coluns\", this.columns);\r\n    moveItemInArray((this as any)[section], visiblePrevIndex, visibleCurrIndex);\r\n\r\n    const prevColIndexInColumns = this.columns.findIndex(item => item.header === previousHeader);\r\n    const currColIndexInColumns = this.columns.findIndex(item => item.header === currentHeader);\r\n    moveItemInArray(this.columns, prevColIndexInColumns, currColIndexInColumns);\r\n    // await this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n    await firstValueFrom(this.ngZone.onStable);\r\n    // this.ngZone.runOutsideAngular(() => {\r\n      // Wait a tick to make sure elements are rendered\r\n      requestAnimationFrame(() => {\r\n        allFields.forEach((field) => {\r\n          const updatedCells = Array.from(\r\n            document.querySelectorAll(`[data-field=\"${field}\"]`)\r\n          ) as HTMLElement[];\r\n\r\n          updatedCells.forEach((el) => {\r\n            const oldLeft = firstPositions.get(el);\r\n            if (oldLeft == null) return; // skip if old position not available\r\n\r\n            const newLeft = el.getBoundingClientRect().left;\r\n            const deltaX = oldLeft - newLeft;\r\n\r\n            if (deltaX !== 0) {\r\n              el.style.willChange = 'transform';\r\n              el.style.transition = 'none';\r\n              el.style.transform = `translateX(${deltaX}px)`;\r\n\r\n              // Force reflow\r\n              void el.offsetWidth;\r\n\r\n              el.style.transition = 'transform 250ms cubic-bezier(0.4, 0, 0.2, 1)';\r\n              el.style.transform = 'translateX(0)';\r\n\r\n              const handle = () => {\r\n                el.style.transition = '';\r\n                el.style.transform = '';\r\n                el.style.willChange = '';\r\n                el.removeEventListener('transitionend', handle);\r\n              };\r\n              el.addEventListener('transitionend', handle);\r\n            }\r\n          });\r\n        });\r\n      });\r\n    // });\r\n  }\r\n\r\n\r\n  onDropGroup() {\r\n    this.leftPinnedColumns = this.deepCloneColumns(this.previewLeftPinnedColumns);\r\n    this.centerColumns = this.deepCloneColumns(this.previewCenterColumns);\r\n    this.rightPinnedColumns = this.deepCloneColumns(this.previewRightPinnedColumns);\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private deepCloneColumns(columns: any[]): any[] {\r\n    if (!Array.isArray(columns)) return [];\r\n\r\n    return columns.map(col => ({\r\n      ...col,\r\n      query: col.query ? { ...col.query } : null,\r\n      column_dropdown_value: Array.isArray(col.column_dropdown_value)\r\n        ? [...col.column_dropdown_value]\r\n        : [],\r\n      // Recursively deep clone children if present\r\n      children: Array.isArray(col.children)\r\n        ? this.deepCloneColumns(col.children)\r\n        : undefined,\r\n    }));\r\n  }\r\n\r\n\r\n  async onDropTopGroup(event: CdkDragDrop<any>) {\r\n    if (this.isOutsideContainer) return;\r\n    this.mainScroll.nativeElement.scrollTop = 0;\r\n    this.loading = true;\r\n    this.translateY = 0;\r\n    this.cdr.detectChanges();\r\n    const draggedData = event.item.data;\r\n    if (draggedData?.children && Array.isArray(draggedData.children)) {\r\n      draggedData.children.forEach((col: any) => {\r\n        if (col.is_visible && col.is_groupable) {\r\n          this.groupedColumns.push(col);\r\n        }\r\n      });\r\n    } else {\r\n      if (draggedData.is_visible && draggedData.is_groupable) {\r\n        this.groupedColumns.push(draggedData);\r\n      }\r\n    }\r\n    this.draggingInGroupArea = false;\r\n    const fields = this.groupedColumns.map((item) => item.field);\r\n    this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n    this.updateFlattenedData();\r\n    this.updateColumnWidthsAndGroups();\r\n    this.refreshPreviewColumns();\r\n    this.updateVisibleRows(0);\r\n    this.loading = false;\r\n    this.cdr.detectChanges();\r\n    this.selectedCells = [];\r\n    setTimeout(() => {\r\n      this.rowSelectedIndexes.clear();\r\n      this.cdr.detectChanges();\r\n    }, 1000);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  async onGroupReorder(event: CdkDragDrop<any[]>) {\r\n    moveItemInArray(this.groupedColumns, event.previousIndex, event.currentIndex);\r\n    const fields = this.groupedColumns.map((item) => item.field);\r\n    this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n    setTimeout(() => {\r\n      this.updateFlattenedData();\r\n      this.updateColumnWidthsAndGroups();\r\n      this.refreshPreviewColumns();\r\n      this.updateVisibleRows(0);\r\n      this.loading = false;\r\n      this.cdr.detectChanges();\r\n    }, 100);\r\n\r\n    setTimeout(() => {\r\n      this.groupBoxPadding = this.columnsGroupedBox?.nativeElement.offsetWidth;\r\n      this.cdr.detectChanges()\r\n    }, 10);\r\n  }\r\n\r\n  async ungroupColumn(column: any) {\r\n    try {\r\n      this.loading = true;\r\n      this.cdr.detectChanges();\r\n      const index = this.groupedColumns.findIndex(\r\n        (col) => col.field === column.field\r\n      );\r\n      if (index !== -1) {\r\n        this.groupedColumns.splice(index, 1);\r\n      }\r\n      const fields = this.groupedColumns.map((item) => item.field);\r\n      this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n      this.columns.forEach((group) => {\r\n        if (group?.children && Array.isArray(group.children)) {\r\n          group.children.forEach((child: any) => {\r\n            if (child.field === column.field) {\r\n              child.isRowGrouped = false;\r\n            }\r\n          });\r\n        } else if (group.field === column.field) {\r\n          group.isRowGrouped = false;\r\n        }\r\n      });\r\n      setTimeout(() => {\r\n        this.updateFlattenedData();\r\n        this.updateColumnWidthsAndGroups();\r\n        this.refreshPreviewColumns();\r\n        this.updateVisibleRows(0);\r\n        this.loading = false;\r\n        this.cdr.detectChanges();\r\n      }, 1000);\r\n\r\n    } catch (err) {\r\n      console.error(\"Error in ungroupColumn:\", err);\r\n      this.loading = false;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  shouldTheGroupHeaderShow(group: any) {\r\n    if (group?.children && group.children.length) {\r\n      return group.children.some(\r\n        (col: any) => col.is_visible && !col?.isRowGrouped\r\n      );\r\n    }\r\n    return group?.is_visible && !group?.isRowGrouped;\r\n  }\r\n\r\n\r\n  // onChildDragStart() {\r\n  //   debugger;\r\n  // }\r\n\r\n  // dropListIds: string[] = [];\r\n\r\n  // generateDropListIds() {\r\n  //   this.dropListIds = [];\r\n\r\n  //   const sectionKeys = [\r\n  //     'leftPinnedColumns',\r\n  //     'centerColumns',\r\n  //     'rightPinnedColumns',\r\n  //   ];\r\n\r\n  //   sectionKeys.forEach((sectionKey) => {\r\n  //     const sectionCols = (this as any)[sectionKey];\r\n\r\n  //     this.columns.forEach((col: any, i: number) => {\r\n  //       if (col?.children?.length > 0) {\r\n  //         col.children.forEach((child: any, childIndex: number) => {\r\n  //           if (child?.is_visible && !child.isRowGrouped) {\r\n  //             const id = `${sectionKey}${i}`;\r\n  //             this.dropListIds.push(id);\r\n  //           }\r\n  //         });\r\n  //       } else if (col?.is_visible && !col.isRowGrouped) {\r\n  //         const id = `${sectionKey}${i}`;\r\n  //         this.dropListIds.push(id);\r\n  //       }\r\n  //     });\r\n  //   });\r\n  // }\r\n\r\n  onChildDroplistSorted = async (event: CdkDragSortEvent<any>, section: string) => {\r\n    if (event.previousIndex === event.currentIndex) return;\r\n\r\n    const pinned =\r\n      section == 'previewLeftPinnedColumns'\r\n        ? 'left'\r\n        : section == 'previewRightPinnedColumns'\r\n          ? 'right'\r\n          : \"\";\r\n\r\n    const column = event.item.data;\r\n    let group = this.columns.find(\r\n      (col: any) =>\r\n        Array.isArray(col.children) &&\r\n        col.children.some((child: any) => child?.field === column?.field)\r\n    );\r\n    const groupIndex = this.columns.findIndex(\r\n      (col) => col.header === group.header\r\n    );\r\n    const filteredGroup = group?.children.filter((col: any) => {\r\n      const isPinnedMatch =\r\n        (pinned === \"\" && (!col?.pinned || col?.pinned === \"\")) || col?.pinned === pinned;\r\n      return isPinnedMatch && col?.is_visible;\r\n    });\r\n\r\n    const previousField = filteredGroup[event.previousIndex].field;\r\n    const currentField = filteredGroup[event.currentIndex].field;\r\n    const visiblePrevIndex = group.children.findIndex(\r\n      (col: any) => col.field == previousField\r\n    );\r\n    const visibleCurrIndex = group.children.findIndex(\r\n      (col: any) => col.field == currentField\r\n    );\r\n    const allFields = [previousField, currentField];\r\n    const cells = allFields.length\r\n      ? ([] as HTMLElement[]).concat(\r\n        ...allFields.map((field) =>\r\n          Array.from(document.querySelectorAll(`[data-field=\"${field}\"]`)) as HTMLElement[]\r\n        )\r\n      )\r\n      : [];\r\n\r\n    const groupInSection = (this as any)[section].find(\r\n      (col: any) =>\r\n        Array.isArray(col.children) &&\r\n        col.children.some((child: any) => child?.field === column?.field)\r\n    );\r\n\r\n    const filterGroupInSection = (this as any)[section].find(\r\n      (col: any) =>\r\n        Array.isArray(col.children) &&\r\n        col.children.some((child: any) => child?.field === column?.field)\r\n    );\r\n\r\n    const groupInSectionIndex = (this as any)[section].findIndex(\r\n      (col: any) => col.header === groupInSection.header\r\n    );\r\n\r\n    const firstPositions = new Map<HTMLElement, number>();\r\n    cells.forEach((el) => firstPositions.set(el, el.getBoundingClientRect().left));\r\n    moveItemInArray(\r\n      this.columns[groupIndex]?.children,\r\n      visiblePrevIndex,\r\n      visibleCurrIndex\r\n    );\r\n\r\n    moveItemInArray(\r\n      (this as any)[section]?.[groupInSectionIndex].children,\r\n      event.previousIndex,\r\n      event.currentIndex\r\n    );\r\n\r\n    // await this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n\r\n    await firstValueFrom(this.ngZone.onStable);\r\n    // allFields.forEach((field) => {\r\n    //   const updatedCells = Array.from(\r\n    //     document.querySelectorAll(`[data-field=\"${field}\"]`)\r\n    //   ) as HTMLElement[];\r\n    //   updatedCells.forEach((el) => {\r\n    //     const newLeft = el.getBoundingClientRect().left;\r\n    //     const oldLeft = firstPositions.get(el)!;\r\n    //     const deltaX = oldLeft - newLeft;\r\n    //     if (deltaX !== 0) {\r\n    //       el.style.willChange = 'transform';\r\n    //       el.style.transition = 'none';\r\n    //       el.style.transform = `translateX(${deltaX}px)`;\r\n    //       void el.offsetWidth;\r\n    //       el.style.transition = 'transform 400ms cubic-bezier(0.4, 0, 0.2, 1)';\r\n    //       el.style.transform = 'translateX(0)';\r\n\r\n    //       const handle = () => {\r\n    //         el.style.transition = '';\r\n    //         el.style.transform = '';\r\n    //         el.style.willChange = '';\r\n    //         el.removeEventListener('transitionend', handle);\r\n    //       };\r\n    //       el.addEventListener('transitionend', handle);\r\n    //     }\r\n    //   });\r\n    // });\r\n\r\n    this.ngZone.runOutsideAngular(() => {\r\n      allFields.forEach((field) => {\r\n        const updatedCells = Array.from(\r\n          document.querySelectorAll(`[data-field=\"${field}\"]`)\r\n        ) as HTMLElement[];\r\n\r\n        updatedCells.forEach((el) => {\r\n          const oldLeft = firstPositions.get(el);\r\n          if (oldLeft == null) return; // safety check\r\n\r\n          const newLeft = el.getBoundingClientRect().left;\r\n          const deltaX = oldLeft - newLeft;\r\n\r\n          if (deltaX !== 0) {\r\n            el.style.willChange = 'transform';\r\n            el.style.transition = 'none';\r\n            el.style.transform = `translateX(${deltaX}px)`;\r\n\r\n            // Force reflow\r\n            void el.offsetWidth;\r\n\r\n            el.style.transition = 'transform 250ms cubic-bezier(0.4, 0, 0.2, 1)';\r\n            el.style.transform = 'translateX(0)';\r\n\r\n            const handle = () => {\r\n              el.style.transition = '';\r\n              el.style.transform = '';\r\n              el.style.willChange = '';\r\n              el.removeEventListener('transitionend', handle);\r\n            };\r\n            el.addEventListener('transitionend', handle);\r\n          }\r\n        });\r\n      });\r\n    });\r\n\r\n    // console.group('Group: ', group);\r\n  }\r\n\r\n\r\n  onChildDroplistDroped(cdkDragDropevent: CdkDragDrop<any>) {\r\n    this.updateColumnWidthsAndGroups();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    setTimeout(() => {\r\n      this.cdr.detectChanges();\r\n    }, 2);\r\n  }\r\n\r\n  // Rows Grouping Logic Goes Here\r\n\r\n  groupData(data: any[], groupFields: string[]): any[] {\r\n    let dataSet = structuredClone(data);\r\n    if (!groupFields.length) return data;\r\n    const [currentField, ...restFields] = groupFields;\r\n    const groupedMap = new Map<string, any[]>();\r\n    for (const item of dataSet) {\r\n      let keyValue = currentField.split('.').reduce((obj, k) => obj?.[k], item);\r\n      let groupKey: string;\r\n      if (Array.isArray(keyValue)) {\r\n        if (keyValue.length === 0) {\r\n          groupKey = \"_Blank\";\r\n        } else if (typeof keyValue[0] === \"object\") {\r\n          groupKey = keyValue\r\n            .map(obj => (obj?.department_name || obj.roleName || obj?.full_name) ?? \"_Blank\")\r\n            .join(\",\");\r\n        } else {\r\n          groupKey = keyValue\r\n            .map(val => val ?? \"_Blank\")\r\n            .join(\",\");\r\n        }\r\n      } else {\r\n        groupKey = keyValue ? keyValue : \"_Blank\";;\r\n      }\r\n      if (typeof keyValue === 'string' && !isNaN(Date.parse(keyValue))) {\r\n          const dateObj = new Date(keyValue);\r\n          groupKey = this.commonSevice.formatDateValue(dateObj, this.dateFormat || 'MM/dd/yyyy');\r\n      }\r\n\r\n      if (!groupedMap.has(groupKey)) groupedMap.set(groupKey, []);\r\n      groupedMap.get(groupKey)!.push(item);\r\n    }\r\n    return Array.from(groupedMap.entries()).map(([groupValue, groupItems]) => ({\r\n      isGroup: true,\r\n      groupField: currentField,\r\n      groupValue,\r\n      children: this.groupData(groupItems, restFields),\r\n      isExpand: false,\r\n    }));\r\n  }\r\n\r\n\r\n  countLeafRows(group: any): number {\r\n    if (!group.children || !group.children.length) return 0;\r\n\r\n    return group.children.reduce((count: number, child: any) => {\r\n      return count + (child.isGroup ? this.countLeafRows(child) : 1);\r\n    }, 0);\r\n  }\r\n\r\n  isActiveFilterOpen = false;\r\n  toggleActiveFilter() {\r\n    this.isActiveFilterOpen = !this.isActiveFilterOpen;\r\n  }\r\n\r\n  toggleActions(type: string) {\r\n    if (type === this.activeTopButton) this.activeTopButton = type;\r\n    else this.activeTopButton = type;\r\n    this.activeSubButton = '';\r\n    this.isFilterOpen = false;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  activeSubButton = '';\r\n  toggleSubActions(type: string) {\r\n    if (type === this.activeSubButton) this.activeSubButton = '';\r\n    else this.activeSubButton = type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  toggleActionsDropdown() {\r\n    this.showActionsDropDown = !this.showActionsDropDown;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n\r\n  async changeTableLayout(event: Event, layoutType: string) {\r\n    let target = event.target as HTMLInputElement;\r\n\r\n    if (target.checked) {\r\n      this.selectedTableLayout = layoutType;\r\n      this.setTableLayout(layoutType)\r\n      this.updateVisibleRows(this.mainScroll?.nativeElement?.scrollTop);\r\n      await this.refreshHeaders();\r\n    }\r\n    if (this.tableFilterViewId) {\r\n      this.savePreset('mouseUp');\r\n    }\r\n    this.onFontChange()\r\n  }\r\n\r\n  setTableLayout(layoutType: string) {\r\n    if(!layoutType) return;\r\n    if (layoutType === 'small') {\r\n      this.rowHeight = 36;\r\n      this.headerRowHeight = 40;\r\n      this.bodyTextFontsSize = 10;\r\n      this.headerTextFontsSize = 10;\r\n\r\n    } else if (layoutType === 'medium') {\r\n      this.rowHeight = 44;\r\n      this.headerRowHeight = 44;\r\n      this.bodyTextFontsSize = 14;\r\n      this.headerTextFontsSize = 14;\r\n\r\n    } else {\r\n      this.rowHeight = 60;\r\n      this.headerRowHeight = 52;\r\n      this.bodyTextFontsSize = 16;\r\n      this.headerTextFontsSize = 16;\r\n    }\r\n  }\r\n\r\n  get startIndexData() {\r\n    return (this.paginationConfig.page - 1) * this.paginationConfig.limit;\r\n  }\r\n\r\n  get endIndex() {\r\n    return Math.min(this.startIndex + this.paginationConfig.limit, this.paginationConfig.totalResults);\r\n  }\r\n\r\n  get visiblePages(): (number | string)[] {\r\n    const pages: (number | string)[] = [];\r\n\r\n    if (this.paginationConfig.totalPages <= 7) {\r\n      for (let i = 1; i <= this.paginationConfig.totalPages; i++) {\r\n        pages.push(i);\r\n      }\r\n    } else {\r\n      pages.push(1);\r\n      if (this.paginationConfig.page > 3) {\r\n        pages.push('...');\r\n      }\r\n      let start = Math.max(2, this.paginationConfig.page - 1);\r\n      let end = Math.min(this.paginationConfig.totalPages - 1, this.paginationConfig.page + 1);\r\n\r\n      for (let i = start; i <= end; i++) {\r\n        pages.push(i);\r\n      }\r\n\r\n      if (this.paginationConfig.page < this.paginationConfig.totalPages - 2) {\r\n        pages.push('...');\r\n      }\r\n      pages.push(this.paginationConfig.totalPages);\r\n    }\r\n\r\n    return pages;\r\n  }\r\n\r\n\r\n  searchTextForFilterDropDown = '';\r\n  toggleColumnInFilterDropdown(col: any) {\r\n\r\n  }\r\n\r\n  removeColumnFromFilter(option: any) {\r\n\r\n  }\r\n\r\n  handleBackspace(event: Event) {\r\n    // If search is empty, remove last tag\r\n    if (!this.searchTextForFilterDropDown && this.selectedFilterOptions.length) {\r\n      const last = this.selectedFilterOptions[this.selectedFilterOptions.length - 1];\r\n      this.toggleSelectionInFilter(last);\r\n    }\r\n  }\r\n\r\n  @ViewChild('filterMenueSearchInput') filterMenueSearchInput!: ElementRef<HTMLInputElement>\r\n  @ViewChild('filterMenueTextchInput') filterMenueTextchInput!: ElementRef<HTMLInputElement>\r\n\r\n  openFilteronThreeDotsClick(col: any) {\r\n    if (col.type == 'image' || !col?.type) return;\r\n    this.selectedColumnForFilter = col;\r\n    this.isThreeDotsFilterOpen = true;\r\n    this.addFilterColumnInput = '';\r\n    if (col.type === 'dropdown') {\r\n      this.currentFilterSelectedIds.clear();\r\n      const savedIds = col?.query?._ids || [];\r\n      savedIds.forEach((id: string) => this.currentFilterSelectedIds.add(id));\r\n\r\n      this.selectedFilterOptions = this.selectedColumnForFilter?.column_dropdown_value?.filter(\r\n        (option: any) => this.currentFilterSelectedIds.has(option?.id || option?._id || option)\r\n      );\r\n      setTimeout(() => {\r\n        if (this.filterMenueSearchInput) {\r\n          this.filterMenueSearchInput.nativeElement.focus();\r\n        }\r\n      }, 100);\r\n    } else if (['string', 'number', 'date'].includes(col.type)) {\r\n      this.firstCondition = col.query.first_condition ? col.query.first_condition : (col.type == 'date' ? 'equal' : 'contain');\r\n      this.firstValue = col?.query?.first_value || '';\r\n      this.condition = col?.query?.condition || 'none';\r\n      this.secondCondition = col.query.first_condition ? col.query.first_condition : (col.type == 'date' ? 'equal' : 'contain');\r\n      this.secondValue = col?.query?.second_value || '';\r\n      setTimeout(() => {\r\n        this.filterMenueTextchInput.nativeElement.focus();\r\n      }, 100);\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  isFilterOpen = false\r\n  selectedColumnForFilter: any;\r\n  showFilters = this.showSideMenu ? false : false;\r\n\r\n\r\n  openFilterFromDisabledSearchedInput(col: any) {\r\n    if (col.type !== 'dropdown') return;\r\n    this.openFilter(col);\r\n  }\r\n\r\n  openFilter(col: any) {\r\n    this.activeFilterCell = col;\r\n    this.activeCol = null\r\n    this.isFilterOpen = true;\r\n    this.searchTextForFilterDropDown = '';\r\n    this.addFilterColumnInput = '';\r\n    this.selectedColumnForFilter = col;\r\n\r\n    if (col.type === 'dropdown') {\r\n      this.currentFilterSelectedIds.clear();\r\n      const savedIds = col?.query?._ids || [];\r\n      savedIds.forEach((id: string) => this.currentFilterSelectedIds.add(id));\r\n\r\n      this.selectedFilterOptions = this.selectedColumnForFilter?.column_dropdown_value?.filter(\r\n        (option: any) => this.currentFilterSelectedIds.has(option?.id || option?._id || option)\r\n      );\r\n    } else if (['string', 'number', 'date'].includes(col.type)) {\r\n      this.firstCondition = col?.query?.first_condition || 'contain';\r\n      this.firstValue = col?.query?.first_value || '';\r\n      this.condition = col?.query?.condition || 'none';\r\n      this.secondCondition = col?.query?.second_condition || 'contain';\r\n      this.secondValue = col?.query?.second_value || '';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  firstValue: any = '';\r\n  firstCondition = '';\r\n  secondValue: any = '';\r\n  secondCondition = null;\r\n  condition = '';\r\n\r\n  resetTextFilterChanges() {\r\n    this.firstCondition = 'contain';\r\n    this.firstValue = '';\r\n    this.condition = 'none';\r\n    this.secondCondition = null;\r\n    this.secondValue = '';\r\n    this.isFilterOpen = false;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n  }\r\n\r\n  toggleAllValusSelectionInDropdownFilter(column: any) {\r\n\r\n  }\r\n\r\n\r\n  selectedFilterOptions: any[] = []\r\n\r\n  currentFilterSelectedIds = new Set<string>();\r\n\r\n  toggleSelectionInFilter(option: any) {\r\n    debugger\r\n    const id = option.id || option._id || option;\r\n    if (this.currentFilterSelectedIds.has(id)) {\r\n      this.currentFilterSelectedIds.delete(id);\r\n    } else {\r\n      this.currentFilterSelectedIds.add(id);\r\n    }\r\n    this.selectedFilterOptions = this.selectedColumnForFilter?.column_dropdown_value.filter((option: any) => this.currentFilterSelectedIds.has(option.id || option._id || option))\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  resetFilterChanges() {\r\n    this.isFilterOpen = false;\r\n    this.currentFilterSelectedIds.clear();\r\n    this.selectedFilterOptions!.length = 0;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n    // const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns);\r\n    // console.log(\"Filtered Columns Are: \", filteredColumns);\r\n  }\r\n\r\n  applyDropdownFilter() {\r\n    this.isFilterOpen = false;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n    this.activeFilterCell = null;\r\n    this.isThreeDotsFilterOpen = false;\r\n    const findColumn = (columns: any[], field: string): any => {\r\n      for (const col of columns) {\r\n        if (col.field === field) return col;\r\n        if (col.children && col.children.length) {\r\n          const found = findColumn(col.children, field);\r\n          if (found) return found;\r\n        }\r\n      }\r\n      return null;\r\n    };\r\n\r\n    const column = findColumn(this.columns, this.selectedColumnForFilter.field);\r\n    if (column) {\r\n      if (column.type === 'dropdown') {\r\n        column.query = column.query || {};\r\n        column.query._ids = column.query._ids || [];\r\n\r\n        // Remove stale IDs (not present in Set)\r\n        column.query._ids = column.query._ids.filter(\r\n          (id: any) => this.currentFilterSelectedIds.has(id)   // <-- use .has()\r\n        );\r\n\r\n        // Add new ones if missing\r\n        this.currentFilterSelectedIds.forEach(id => {\r\n          if (!column.query._ids.includes(id)) {\r\n            column.query._ids.push(id);\r\n          }\r\n        });\r\n\r\n      } else if (['string', 'number', 'date'].includes(column.type)) {\r\n        column.query = {\r\n          first_condition: this.firstCondition || 'contain',\r\n          first_value: this.firstValue || null,\r\n          condition: this.secondValue ? this.condition: 'none',\r\n          second_condition:  this.secondValue ? this.secondCondition : null,\r\n          second_value: this.secondValue || null,\r\n        };\r\n      }\r\n    }\r\n\r\n    const filter = {\r\n      field: column.field,\r\n      search: column.search,\r\n      query: column.query,\r\n      type: column.type,\r\n      _ids: column._ids\r\n    };\r\n\r\n    const existingIndex = this.filtersConfig.findIndex(f => f.field === column.field);\r\n\r\n    if (existingIndex !== -1) {\r\n      this.filtersConfig[existingIndex] = filter;\r\n    } else {\r\n      this.filtersConfig.push(filter);\r\n    }\r\n\r\n    this.isFilterOpen = false;\r\n    this.activeCol = null;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n    this.activeFilterCell = null;\r\n    this.isThreeDotsFilterOpen = false;\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    const filters = this.cleanFilterdColumns()\r\n    setTimeout(() => {\r\n      this.filterOptions.emit(filters);\r\n    }, 200);\r\n  }\r\n\r\n  // applyFilterFromFilterRow(column: any) {\r\n  //   const filter = {\r\n  //     field: column.field,\r\n  //     search: column.search,\r\n  //     query: column.query,\r\n  //     type: column.type,\r\n  //     _ids: column._ids\r\n  //   };\r\n  //   this.filtersConfig.push(filter);\r\n  //   this.isFilterOpen = false;\r\n  //   this.isActiveFilterOpen = false;\r\n  //   this.activeTopButton = '';\r\n  //   this.activeFilterCell = null;\r\n  //   this.isThreeDotsFilterOpen = false;\r\n  //   const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig);\r\n  //   this.filterOptions.emit(filteredColumns);\r\n  // }\r\n\r\n  isFilterAppliedOnColumn(column: any) {\r\n    return this.filtersConfig.some(col => col.field === column.field);\r\n  }\r\n\r\n  // Side Filters Logic is here\r\n\r\n  toggleSelectAllSideFilters(col: any, event: Event) {\r\n    const checked = (event?.target as HTMLInputElement)?.checked;\r\n\r\n    if (checked) {\r\n      col.query._ids = col?.column_dropdown_value?.map(\r\n        (opt: any) => opt.id || opt._id || opt\r\n      );\r\n      this.currentFilterSelectedIds = new Set<string>(col.query._ids);\r\n    } else {\r\n      col.query._ids = [];\r\n      this.currentFilterSelectedIds.clear();\r\n    }\r\n  }\r\n\r\n\r\n  isAllSideFilterOptionsSelected(col: any): boolean {\r\n    if (!col?.query?._ids || !Array.isArray(col.column_dropdown_value)) return false;\r\n    return col.query._ids.length === col.column_dropdown_value.length;\r\n  }\r\n\r\n  onOptionToggle(col: any, option: any) {\r\n    const optionId = option.id || option._id || option;\r\n    if (!col.query._ids) {\r\n      col.query._ids = [];\r\n    }\r\n    const idx = col.query._ids.indexOf(optionId);\r\n    if (idx > -1) {\r\n      col.query._ids.splice(idx, 1);\r\n    } else {\r\n      col.query._ids.push(optionId);\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n\r\n\r\n  resetSideFilter(col: any) {\r\n    const resetColumnRecursively = (columns: any[]): boolean => {\r\n      for (const column of columns) {\r\n        if (column.field === col.field) {\r\n          column.query = {\r\n            _ids: [],\r\n            first_condition: 'contain',\r\n            first_value: null,\r\n            condition: 'none',\r\n            second_condition: 'contain',\r\n            second_value: null\r\n          };\r\n          return true;\r\n        }\r\n        if (Array.isArray(column?.children) && column?.children?.length) {\r\n          if (resetColumnRecursively(column.children)) {\r\n            return true;\r\n          }\r\n        }\r\n      }\r\n      return false;\r\n    };\r\n    resetColumnRecursively(this.columns);\r\n    const index = this.filtersConfig.findIndex((f: any) => f.field === col.field);\r\n    if (index !== -1) {\r\n      this.filtersConfig.splice(index, 1);\r\n    }\r\n    this.activeFilterCell = null;\r\n    this.cdr.detectChanges();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    const filters = this.cleanFilterdColumns()\r\n    setTimeout(() => {\r\n      this.filterOptions.emit(filters);\r\n    }, 200);\r\n  }\r\n\r\n\r\n  clearAllFilters() {\r\n    this.tableView?.forEach((ele) => { ele.is_temp = false });\r\n    const resetAllRecursively = (columns: any[]) => {\r\n      for (const column of columns) {\r\n        if (column.query) {\r\n          column.query = {\r\n            _ids: [],\r\n            first_condition: 'contain',\r\n            first_value: null,\r\n            condition: 'none',\r\n            second_condition: 'contain',\r\n            second_value: null\r\n          };\r\n        }\r\n        if (Array.isArray(column?.children) && column.children.length) {\r\n          resetAllRecursively(column.children);\r\n        }\r\n      }\r\n    };\r\n    resetAllRecursively(this.columns);\r\n    this.activeFilterCell = null;\r\n    this.filtersConfig = [];\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n    this.rowShadingEnabled = false;\r\n    this.showVerticalBorder = false;\r\n    this.fontFaimly = 'Inter';\r\n    this.headerTextFontsSize = 14;\r\n    this.selectedTableLayout = 'mediumd';\r\n    this.bodyTextFontsSize = 14;\r\n    this.globalSearchText = '';\r\n    const event = { eventType: 'reset', data: { tableType: this.tableType } };\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: [],\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    setTimeout(() => {\r\n      const filteredColumns = this.cleanFilterdColumns();\r\n      this.genericEvent.emit(event);\r\n      this.filterOptions.emit(filteredColumns);\r\n    }, 300);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  applySideFilter(column: any) {\r\n    if (!column.query.first_value && !column?.query?._ids.length) return;\r\n    const filter = {\r\n      field: column.field,\r\n      search: column.search,\r\n      query: column.query,\r\n      type: column.type,\r\n      _ids: column._ids || []\r\n    };\r\n\r\n    const existingIndex = this.filtersConfig.findIndex(f => f.field === column.field);\r\n\r\n    if (existingIndex !== -1) {\r\n      // Replace the existing filter\r\n      this.filtersConfig[existingIndex] = filter;\r\n    } else {\r\n      // Add new filter\r\n      this.filtersConfig.push(filter);\r\n    }\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig).map(({ query, ...rest }) => {\r\n        if (query) {\r\n          delete query.__typename;\r\n        }\r\n        return {\r\n          query,\r\n          ...rest,\r\n        }\r\n      }),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    setTimeout(() => {\r\n      const filteredColumns = this.cleanFilterdColumns();\r\n      this.filterOptions.emit(filteredColumns);\r\n    }, 200);\r\n  }\r\n\r\n\r\n  removeSideFilter(column: any) {\r\n    if (!column.query.first_value && !column?.query?._ids.length) return;\r\n\r\n    const existingIndex = this.filtersConfig.findIndex(f => f.field === column.field);\r\n    if (existingIndex !== -1) {\r\n      this.filtersConfig.splice(existingIndex, 1);\r\n    }\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig).map(({ query, ...rest }) => {\r\n        if (query) {\r\n          delete query.__typename;\r\n        }\r\n        return {\r\n          query,\r\n          ...rest,\r\n        };\r\n      }),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      const filteredColumns = this.cleanFilterdColumns();\r\n      this.filterOptions.emit(filteredColumns);\r\n    }, 200);\r\n  }\r\n\r\n  collapseAllExpandedCells() {\r\n    if (this.expandedCells?.size > 0) {\r\n      this.expandedCells.clear();\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n\r\n\r\n  trackByField(index: number, col: any): string {\r\n    return col?.field;\r\n  }\r\n\r\n  get activeFilteredColumns(): any[] {\r\n    const collectFiltered = (columns: any[]): any[] => {\r\n      let result: any[] = [];\r\n\r\n      columns.forEach(col => {\r\n        if (col.children && col.children.length) {\r\n          result = result.concat(collectFiltered(col.children));\r\n        }\r\n\r\n        const isInFiltersConfig = this.filtersConfig.some(f => f.field === col.field);\r\n        if (isInFiltersConfig) {\r\n          result.push(col);\r\n        }\r\n      });\r\n\r\n      return result;\r\n    };\r\n\r\n    return collectFiltered(this.columns);\r\n  }\r\n\r\n\r\n\r\n\r\n  toggleOpenFilter() {\r\n    this.showFilters = !this.showFilters;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n\r\n\r\n  // Cell Editing Work start here\r\n\r\n  editingKey: string | null = null;\r\n  activeCell: string | null = null;\r\n\r\n  setActiveCell(row: any, column: any) {\r\n    this.activeCell = ((row.id || row._id) + '-' + column.field);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  isActiveCell(row: any, col: any): boolean {\r\n    return this.activeCell === ((row.id || row._id) + '-' + col.field);\r\n  }\r\n\r\n  @ViewChild('textAreadInput') textAreadInput!: ElementRef<HTMLTextAreaElement>;\r\n  enableEdit(row: any, column: any, clickedFromDetailsBox = false, cellContainer?: HTMLElement) {\r\n    this.editinDropdownSearch = '';\r\n    if (row?.__virtualIndex == 0) return;\r\n    if (column.type == 'image' || !column?.is_editable) return;\r\n    this.editingKey = ((row.id || row._id) + '-' + column.field);\r\n\r\n    if (column.type === 'dropdown') {\r\n      setTimeout(() => {\r\n        const dropdownMenu = document.querySelector('.cell-editing-dropdown-menu') as HTMLElement;\r\n        if (dropdownMenu) {\r\n          const rect = dropdownMenu.getBoundingClientRect();\r\n          const windowHeight = this.dataGridContainer.nativeElement?.offsetHeight;\r\n\r\n          if (rect.bottom > windowHeight) {\r\n            dropdownMenu.style.top = `-${rect.height}px`;\r\n          } else {\r\n            dropdownMenu.style.top = '100%';\r\n          }\r\n        }\r\n      });\r\n    }\r\n\r\n    if (!clickedFromDetailsBox && this.getNestedValue(row, column.field)?.length > 50) {\r\n      this.toggleExpandOfLongCellText(row, column, this.columns, false)\r\n    }\r\n    setTimeout(() => {\r\n      if (!cellContainer) return;\r\n\r\n      const focusable = cellContainer.querySelector(\r\n        'input, textarea, select, [contenteditable=\"true\"]'\r\n      ) as HTMLElement | null;\r\n\r\n      if (focusable) {\r\n        (focusable as HTMLElement).style.fontSize = '16px';\r\n        focusable.focus();\r\n\r\n        if (focusable instanceof HTMLInputElement || focusable instanceof HTMLTextAreaElement) {\r\n          focusable.select();\r\n        }\r\n      }\r\n\r\n    });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  disableEdit(row: any, column: any, control?: any) {\r\n    this.rowSelectedIndexes.clear();\r\n    if (!this.editingKey) return\r\n    this.checkRowEditAndEmitValue(row, column, row[column.field])\r\n    this.editingKey = null;\r\n    this.cdr.detectChanges();\r\n    const current = this.getNestedValue(row, column?.field);\r\n    if (!current || (column.type == 'email' && !this.validateEmail(current))) {\r\n      const originalRow = this.originalDataSet.find(item => item.id == row.id || item.id == row._id);\r\n      const original = this.getNestedValue(originalRow, column?.field);\r\n      this.setNestedValue(row, column, original);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n  validateEmail(value: string): boolean {\r\n    return this.emailRegex.test(value);\r\n  }\r\n  allowOnlyNumbers(event: KeyboardEvent) {\r\n    const charCode = event.which ? event.which : event.keyCode;\r\n    if (charCode < 48 || charCode > 57) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  checkRowEditAndEmitValue(row: any, column: any, value?: any) {\r\n    // setTimeout(() => {\r\n    const originalRow = this.originalDataSet?.find(\r\n      (r: any) => r.id === row.id || r._id === row._id\r\n    );\r\n    if (!originalRow) return;\r\n    // const clean = (obj: any) => JSON.parse(JSON.stringify(obj));\r\n    // const currentValue = this.getNestedValue(row, column.field);\r\n    // const originalValue = this.getNestedValue(originalRow, column.field);\r\n    const originValue = this.dataSet.find((r: any) => r.id === row.id);\r\n    const changedValue = originValue.verified == value;\r\n    // if (changedValue) return;\r\n    // const hasChanged = this.commonSevice.hasFieldChanged(currentValue, originalValue, column.type);\r\n    // if (!hasChanged) return;\r\n    // this.setNestedValue(originalRow, column, value);\r\n\r\n    const sendObj = {\r\n      data: { ...originValue },\r\n      eventType: 'onCellEdit',\r\n      value: value,\r\n      column: column\r\n    };\r\n    return this.genericEvent.emit(sendObj)\r\n    // }, 100);\r\n  }\r\n\r\n\r\n  isEditing(row: any, col: any): boolean {\r\n    return this.editingKey === ((row.id || row._id) + '-' + col.field);\r\n  }\r\n\r\n  setNestedValue(obj: any, column: any, option: any, calledFromInput = false): void {\r\n    const path = column.field;\r\n    const keys = path.split('.');\r\n    const lastKey = keys.pop();\r\n    const parent = keys.reduce((acc: { [x: string]: {}; }, key: string | number) => acc[key] ??= {}, obj);\r\n\r\n    if (parent && lastKey) {\r\n      if (typeof option === 'object' && option !== null) {\r\n        // case: dropdown object {id, value}\r\n        parent.id = option.id;\r\n        parent[lastKey] = option.value;\r\n      } else {\r\n        // case: plain string or number\r\n        parent[lastKey] = option;\r\n      }\r\n    }\r\n\r\n    const sendObj = {\r\n      data: { ...obj },\r\n      eventType: 'onCellEdit',\r\n    };\r\n\r\n    if (calledFromInput) {\r\n      this.checkRowEditAndEmitValue(obj, column, option);\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n  goToPage(page: any) {\r\n    if (this.paginationConfig?.page == page) return;\r\n    if (page < 1 || page > this.paginationConfig.totalPages) return;\r\n    this.paginationConfig.page = page;\r\n    const event = {\r\n      obj: {\r\n        limit: this.paginationConfig.limit,\r\n        page: page,\r\n      },\r\n      eventType: 'pageChange',\r\n    };\r\n    this.genericEvent.emit(event)\r\n  }\r\n\r\n  onPageSizeChange() {\r\n    this.paginationConfig.page = 1;\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig).map(({ query, ...rest }) => {\r\n        if (query) {\r\n          delete query.__typename;\r\n        }\r\n        return {\r\n          query,\r\n          ...rest,\r\n        }\r\n      }),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      const event = {\r\n        obj: {\r\n          limit: this.paginationConfig.limit,\r\n          page: this.paginationConfig.page,\r\n        },\r\n        eventType: 'pageChange',\r\n      };\r\n      this.genericEvent.emit(event)\r\n    }, 700);\r\n  }\r\n\r\n  actionPreset(data: any, type: any) {\r\n    data.columns = data.columns.map(({ _id, filterValue, search, column_dropdown_value, query, __typename, ...rest }: any) => rest);\r\n    this.tableView?.forEach((ele) => { ele.is_temp = false });\r\n\r\n    {\r\n      this.bodyTextFontsSize = data.config.bodyTextFontsSize,\r\n        this.fontFaimly = data.config.fontFaimly,\r\n        data.filters.forEach((element: any) => {\r\n          delete element.__typename;\r\n          if (element.query) {\r\n            delete element.query.__typename;\r\n            if (\r\n              typeof element.query === 'object' &&\r\n              element.query !== null &&\r\n              Object.keys(element.query).length === 0\r\n            ) {\r\n              element.query = null;\r\n            }\r\n          }\r\n        });\r\n      this.headerTextFontsSize = data.config.headerTextFontsSize,\r\n        this.selectedTableLayout = data.config.selectedTableLayout,\r\n        this.showVerticalBorder = data.config.showVerticalBorder,\r\n        this.currentIdForUpdatePreset = data.id;\r\n      this.filtersConfig = data.filters;\r\n    }\r\n    delete data?.__typename;\r\n    delete data?.is_temp;\r\n    delete data?.config.__typename;\r\n    const event = {\r\n      obj: {\r\n        data: data\r\n      },\r\n      eventType: type\r\n    }\r\n    this.genericEvent.emit(event)\r\n  }\r\n\r\n  currentIdForUpdatePreset = '';\r\n  curretaTablePresetForUpdate: any;\r\n  temp_state = {\r\n    id: '',\r\n    is_temp: false\r\n  }\r\n  async selectFilter(data: any) {\r\n    this.temp_state = {\r\n      id: data.id,\r\n      is_temp: true\r\n    }\r\n    this.tableView?.forEach((ele) => { ele.is_temp = false });\r\n    this.tableView = this.tableView.map(item => ({\r\n      ...item,\r\n      is_temp: item.id == data?.id\r\n    }));\r\n    this.columns = data.columns;\r\n    {\r\n      this.bodyTextFontsSize = data.config.bodyTextFontsSize,\r\n        this.fontFaimly = data.config.fontFaimly,\r\n        data.filters.forEach((element: any) => {\r\n          delete element.__typename;\r\n\r\n          if (element.query) {\r\n            delete element.query.__typename;\r\n            if (\r\n              typeof element.query === 'object' &&\r\n              element.query !== null &&\r\n              Object.keys(element.query).length === 0\r\n            ) {\r\n              element.query = null;\r\n            }\r\n          }\r\n        });\r\n\r\n      // this.globalSearch = data.config.bodyTextFontsSize,\r\n      this.headerTextFontsSize = data.config.headerTextFontsSize,\r\n        this.selectedTableLayout = data.config.selectedTableLayout,\r\n        this.showVerticalBorder = data.config.showVerticalBorder,\r\n        this.currentIdForUpdatePreset = data.id;\r\n      this.curretaTablePresetForUpdate = structuredClone(data);\r\n      this.presetName = data?.name;\r\n      this.presetFilter = data?.activeFilters || false;\r\n      this.filtersConfig = data.filters;\r\n      await this.applyFilteroptionList();\r\n      this.refreshHeaders();\r\n      this.cdr.detectChanges();\r\n      data.columns = this.cleanColumns(this.columns);\r\n      delete data?.__typename;\r\n      delete data?.is_temp;\r\n      delete data?.config.__typename;\r\n    }\r\n    if (data?.is_deafult) {\r\n      return this.actionPreset(data, 'setPreset')\r\n    }\r\n    const event = {\r\n      obj: {\r\n        data: data\r\n      },\r\n      eventType: 'select'\r\n    }\r\n    this.genericEvent.emit(event)\r\n  }\r\n\r\n  savePreset(control?: any) {\r\n    if (control?.invalid) {\r\n      control?.control.markAsTouched();\r\n      return;\r\n    }\r\n    let names = this.getFilterHeaders(this.filtersConfig, this.columns);\r\n    this.presetFilter = this.tableFilterViewId ? true : this.presetFilter;\r\n    let selectedData: any = this.tableView.find((ele) => ele.id == this.tableFilterViewId);\r\n    let config = {\r\n      fontFaimly: this.fontFaimly,\r\n      bodyTextFontsSize: +(this.bodyTextFontsSize || 14),\r\n      headerTextFontsSize: +(this.headerTextFontsSize || 14),\r\n      oddRowsBackgroundColor: this.rowShadingEnabled ? this.oddRowsBackgroundColor : undefined,\r\n      showVerticalBorder: this.showVerticalBorder,\r\n      selectedTableLayout: this.selectedTableLayout,\r\n      globalSearch: this.tableSearch,\r\n      filterNames: names,\r\n      totalCount: this.paginationConfig.totalResults,\r\n      rowShadingEnabled: this.rowShadingEnabled\r\n\r\n    }\r\n    const event = {\r\n      obj: {\r\n        name: this.tableFilterViewId ? selectedData?.name : this.presetName,\r\n        activeFilters: this.presetFilter,\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.presetFilter\r\n          ? this.filtersConfig?.map(({ __typename, query, ...rest }) => {\r\n            const { __typename: __inner, ...cleanQuery } = query || {};\r\n            return { ...rest, query: cleanQuery };\r\n          })\r\n          : [],\r\n        config: config,\r\n        id: this.tableFilterViewId || this.curretaTablePresetForUpdate?.id,\r\n        loadingCall: control == 'mouseUp' ? false : true,\r\n        type: this.tableType\r\n      },\r\n      eventType: this.tableFilterViewId || !this.isTablePresetNotChanged ? 'updatePreset' : 'createPreset'\r\n    }\r\n\r\n    const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig);\r\n    const cleanedFilteredColumns = filteredColumns.map(({ query, ...rest }) => {\r\n      if (query) {\r\n        delete query.__typename;\r\n      }\r\n      return {\r\n        query,\r\n        ...rest,\r\n      }\r\n    });\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: cleanedFilteredColumns,\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      this.genericEvent.emit(event)\r\n    }, 500);\r\n  }\r\n\r\n\r\n  getFilterHeaders(filters: any[], columns: any[]): string {\r\n    const matchedHeaders = filters\r\n      .map(f => {\r\n        const column = columns.find(c => c.field === f.field);\r\n        return column ? column.header : null;\r\n      })\r\n      .filter(header => !!header);\r\n\r\n    return matchedHeaders.join(', ');\r\n  }\r\n\r\n\r\n  toggleRowShading() {\r\n    this.oddRowsBackgroundColor = this.rowShadingEnabled ? '#f1f1f1' : undefined;\r\n    this.onFontChange();\r\n  }\r\n\r\n  trackByTable(index: number): number {\r\n    return index;\r\n  }\r\n  activeRow: any\r\n  activeRowCol: any;\r\n\r\n  // Track expanded cells as a Set of unique row+col identifiers\r\n\r\n  getCellKey(row: any, col: any): string {\r\n    return `${this.getRowId(row)}_${col?.field}`;\r\n  }\r\n\r\n  expandedCells = new Map<string, number>();\r\n  private zCounter = 21;\r\n\r\n  showDetailsBox = false;\r\n\r\n  toggleExpandOfLongCellText(\r\n    row: any,\r\n    col: any,\r\n    columns: any[],\r\n    expandWholeRow = false\r\n  ) {\r\n    const expandCells = (targetRow: any) => {\r\n      columns.forEach(c => {\r\n        if (c.type === 'image') return;\r\n        const text = targetRow[c.field];\r\n\r\n        if ((typeof text === 'string' && text.length > 50) || (Array.isArray(text) && text?.length > 1)) {\r\n          const key = this.getRowId(targetRow) + '-' + c.field;\r\n          this.zCounter++;\r\n          this.expandedCells.set(key, this.zCounter);\r\n        }\r\n      });\r\n    };\r\n\r\n\r\n    const collectKeysForRow = (targetRow: any) => {\r\n      const keys: string[] = [];\r\n      columns.forEach(c => {\r\n        if (c.type === 'image') return;\r\n\r\n        const text = targetRow[c.field];\r\n        if (typeof text === 'string' && text.length > 50 || (Array.isArray(text) && text?.length > 1)) {\r\n          keys.push(this.getRowId(targetRow) + '-' + c.field);\r\n        }\r\n      });\r\n      return keys;\r\n    };\r\n\r\n    if (expandWholeRow) {\r\n      let rowKeys: string[] = [];\r\n      const text = this.getNestedValue(row, col?.field);\r\n      if (Array.isArray(text) && text.length > 0) {\r\n        rowKeys = collectKeysForRow(row);\r\n        row?.children?.forEach((child: any) => {\r\n          rowKeys.push(...collectKeysForRow(child));\r\n        });\r\n      } else {\r\n        rowKeys = collectKeysForRow(row);\r\n      }\r\n      const allExpanded = rowKeys.every(k => this.expandedCells.has(k));\r\n      this.expandedCells.clear();\r\n      if (!allExpanded) {\r\n        if (Array.isArray(row.children) && row.children.length > 0) {\r\n          expandCells(row);\r\n          row?.children?.forEach((child: any) => expandCells(child));\r\n        } else {\r\n          expandCells(row);\r\n        }\r\n      }\r\n    } else {\r\n      const key = this.getRowId(row) + '-' + col.field;\r\n      if (col.type === 'image') return;\r\n\r\n      if (!this.expandedCells.has(key)) {\r\n        this.expandedCells.clear();\r\n        this.zCounter++;\r\n        this.expandedCells.set(key, this.zCounter);\r\n      } else {\r\n        this.expandedCells.delete(key);\r\n      }\r\n    }\r\n\r\n    this.showDetailsBox = false;\r\n    setTimeout(() => {\r\n      this.isOpenToTop(row)\r\n    }, 0);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  isOpenToTop(row: any) {\r\n    const wrapper = document.querySelector('.data-grid-body-wrapper') as HTMLElement | null;\r\n    if (!wrapper) return false;\r\n    this.columns.forEach((col: any) => {\r\n      const id = (row.id || row._id) + '-' + (col.id || col._id);\r\n      const box = document.getElementById(id);\r\n      if (!box) return false;\r\n      const boxRect = box.getBoundingClientRect();\r\n      const wrapperRect = wrapper.getBoundingClientRect();\r\n      const isOverflowingBottom = boxRect.bottom > wrapperRect.bottom;\r\n      const isOverflowingTop = boxRect.top < wrapperRect.top;\r\n      if (isOverflowingBottom && !isOverflowingTop) {\r\n        const boxHeight = box.offsetHeight || 0;\r\n        const offset = boxHeight + 4;\r\n        box.style.top = `${-offset}px`;\r\n\r\n      } else {\r\n        box.style.bottom = `auto`;\r\n        box.style.top = `100%`;\r\n        box.style.transform = `translateY(0)`;\r\n      }\r\n      return false;\r\n    })\r\n    this.showDetailsBox = true;\r\n    this.cdr.detectChanges();\r\n    return true;\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n  isExpanded(row: any, col: any): boolean {\r\n    return this.expandedCells.has(this.getRowId(row) + '-' + col.field);\r\n  }\r\n\r\n  getZIndex(row: any, col: any): number {\r\n    return this.expandedCells.get(this.getRowId(row) + '-' + col.field) ?? 21;\r\n  }\r\n\r\n  isOverflowing(element: HTMLElement | null): boolean {\r\n    if (!element) return false;\r\n    return element.scrollWidth > element.clientWidth;\r\n  }\r\n\r\n\r\n  // Picture cell Logic\r\n  colorCombination = ['pic-comb1', 'pic-comb2', 'pic-comb4'];\r\n  getDynamicClass(name: string): string {\r\n    if (!name) return this.colorCombination[0];\r\n    const hash = Array.from(name).reduce((acc, char) => acc + char.charCodeAt(0), 0);\r\n    const index = hash % this.colorCombination?.length;\r\n    return this.colorCombination[index];\r\n  }\r\n\r\n  getInitials(name: string): string {\r\n    if (!name) return 'NA';\r\n    const parts = name.trim().split(' ');\r\n    return (parts[0][0] + (parts[1]?.[0] || '')).toUpperCase();\r\n  }\r\n\r\n\r\n  actionHide: boolean = true;\r\n  xPos = 0;\r\n  yPos = 0;\r\n  isVisible = false;\r\n  deatilsList: any;\r\n  openExpendIndex: any;\r\n  positionedYet = false;\r\n\r\n  onRightClick(event: MouseEvent | TouchEvent | any, deatilsList: any): boolean {\r\n    if (deatilsList?.actions?.length) {\r\n      this.actions = deatilsList.actions;\r\n    }\r\n    if (!(event instanceof MouseEvent)) {\r\n      event.preventDefault();\r\n    }\r\n    if (deatilsList.__virtualIndex == 0) return false;\r\n    event.preventDefault();\r\n    this.xPos = (event instanceof MouseEvent) ? event.clientX : event.touches[0].clientX;\r\n    this.yPos = (event instanceof MouseEvent) ? event.clientY : event.touches[0].clientY;\r\n    // this.xPos = event.clientX;\r\n    // this.yPos = event.clientY;\r\n    this.isVisible = true;\r\n    this.positionedYet = false;\r\n    this.deatilsList = deatilsList;\r\n    setTimeout(() => {\r\n      const menuElement = document.querySelector('.context-menu') as HTMLElement;\r\n      if (!menuElement) return;\r\n      const menuWidth = menuElement.offsetWidth;\r\n      const menuHeight = menuElement.offsetHeight;\r\n      const viewportWidth = window.innerWidth;\r\n      const viewportHeight = window.innerHeight;\r\n      let x = (event instanceof MouseEvent) ? event.clientX : event.touches[0].clientX; //event.clientX;\r\n      let y = (event instanceof MouseEvent) ? event.clientY : event.touches[0].clientY; //event.clientY;\r\n      if (x + menuWidth > viewportWidth) {\r\n        x = viewportWidth - menuWidth - 10;\r\n      }\r\n      if (y + menuHeight > viewportHeight) {\r\n        y = viewportHeight - menuHeight - 10;\r\n      }\r\n      this.xPos = x;\r\n      this.yPos = y;\r\n      this.isVisible = true;\r\n\r\n      setTimeout(() => {\r\n        this.positionedYet = true;\r\n        this.cdr.detectChanges();\r\n      });\r\n\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.cdr.detectChanges()\r\n    return false;\r\n  }\r\n\r\n  onActionClick(action: string) {\r\n    const sendObj = {\r\n      obj: this.deatilsList,\r\n      eventType: action,\r\n    };\r\n    this.positionedYet = false;\r\n    this.cdr.detectChanges();\r\n    this.genericEvent.emit(sendObj);\r\n  }\r\n\r\n\r\n  onVerifyClick(type: string) {\r\n    const text = type?.toLowerCase();\r\n    if(text == 'archive' || text == 'unarchive'\r\n      // || text == 'delete' || text == 'restore' || text == 'remove' || text == 'deactivate' || text == 'activate' || text == 'block' || text == 'unblock'\r\n      // || text == 'enable' || text == 'disable' || text == 'approve' || text == 'reject' || text == 'publish' || text == 'unpublish' || text == 'lock' || text == 'unlock' || text == 'complete' || text == 'incomplete'\r\n      // || text == 'send to review' || text == 'mark as paid' || text == 'mark as unpaid' || text == 'fulfill' || text == 'unfulfill' || text == 'refund' || text == 'cancel' || text == 'resend' || text == 'chargeback'\r\n      // || text == 'dispute' || text == 'escalate' || text == 'deescalate' || text == 'flag' || text == 'unflag' || text == 'verify' || text == 'unverify' || text == 'subscribe' || text == 'unsubscribe' || text == 'follow' || text == 'unfollow'\r\n      // || text == 'like' || text == 'unlike' || text == 'share' || text == 'unshare' || text == 'comment' || text == 'uncomment' || text == 'tag' || text == 'untag' || text == 'assign' || text == 'unassign' || text == 'link' || text == 'unlink'\r\n      // || text == 'sync' || text == 'unsync' || text == 'backup' || text == 'restore backup' || text == 'migrate' || text == 'import' || text == 'export' || text == 'generate report' || text == 'download report' || text == 'view details'\r\n      // || text == 'edit details' || text == 'update details' || text == 'change status' || text == 'reset password' || text == 'send notification' || text == 'schedule' || text == 'reschedule' || text == 'cancel schedule' || text == 'start' || text == 'stop' || text == 'pause' || text == 'resume'\r\n    ){\r\n      this.clearSelectionState(this.tableType);\r\n      this.selectedRows.clear();\r\n    }\r\n    const idsArray = Array.from(this.selectedRows);\r\n    const arrayOfObjectsWithTableType: any[] = [];\r\n    this.selectedRows.forEach(id => {\r\n      arrayOfObjectsWithTableType.push({\r\n        id: id,\r\n        listingType: this.listingType,\r\n      });\r\n    });\r\n    const sendObj = {\r\n      data: {\r\n        obj: idsArray,\r\n        tableName: this.tableName,\r\n        listingType: this.listingType,\r\n      },\r\n      eventType: type,\r\n    };\r\n    this.genericEvent.emit(sendObj)\r\n  }\r\n\r\n\r\n\r\n  getCellClasses(column: any, value: any): string {\r\n    if (!value || !column?.field || column?.cellRenderer) return '';\r\n\r\n    let val: any = typeof value === 'object' ? value?.value ?? value : value;\r\n    const field = column.field.toLowerCase();\r\n\r\n    if (field === 'due_date') {\r\n      const dueDate = new Date(val);\r\n      const today = new Date();\r\n      const todayUTC = Date.UTC(today.getFullYear(), today.getMonth(), today.getDate());\r\n      const dueUTC = Date.UTC(dueDate.getFullYear(), dueDate.getMonth(), dueDate.getDate());\r\n\r\n      if (dueUTC < todayUTC) {\r\n        return 'text-danger';\r\n      }\r\n      // else if(dueUTC === todayUTC){\r\n      //   return 'text-warning';\r\n      // }\r\n\r\n      return '';\r\n    }\r\n\r\n\r\n    const status = val?.toString().toLowerCase();\r\n    if (\r\n      field === 'status' ||\r\n      field === 'account_status' ||\r\n      field === 'availstatus' ||\r\n      field === 'is_custom_grade'\r\n    ) {\r\n      return STATUSES_BADGE_MAP[status] || 'badge badge-secondary';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n\r\n  removeColumnFilterFromColumn(column: any) {\r\n    if (!column) return\r\n    if (column.type === 'dropdown') {\r\n      column.query._ids = [];\r\n    } else if (['string', 'number', 'date'].includes(column.type)) {\r\n      column.query = {\r\n        first_condition: 'contain',\r\n        first_value: null,\r\n        condition: 'none',\r\n        second_condition: null,\r\n        second_value: null,\r\n      }\r\n    }\r\n\r\n    const index = this.filtersConfig.findIndex((f: any) => f.field === column.field);\r\n    if (index !== -1) {\r\n      this.filtersConfig.splice(index, 1);\r\n    }\r\n\r\n    const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig);\r\n    const cleanedFilteredColumns = filteredColumns.map(({ query, ...rest }) => {\r\n      if (query) {\r\n        delete query.__typename;\r\n      }\r\n      return {\r\n        query,\r\n        ...rest,\r\n      }\r\n    });\r\n\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: cleanedFilteredColumns,\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      const filteredColumns = cleanedFilteredColumns;\r\n      this.filterOptions.emit(filteredColumns);\r\n    }, 200);\r\n  }\r\n\r\n  onSideMenuColumnsVisibilityChange() {\r\n    this.refreshHeaders();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig).map(({ query, ...rest }) => {\r\n        if (query) {\r\n          delete query.__typename;\r\n        }\r\n        return {\r\n          query,\r\n          ...rest,\r\n        }\r\n      }),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n  }\r\n\r\n  cleanFilterdColumns() {\r\n    const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig);\r\n    const cleanedFilteredColumns = filteredColumns.map(({ query, ...rest }) => {\r\n      if (query) {\r\n        delete query.__typename;\r\n      }\r\n      return {\r\n        query,\r\n        ...rest,\r\n      }\r\n    });\r\n    return cleanedFilteredColumns;\r\n  }\r\n\r\n  downloadCsv(type: 'csv' | 'xlsx') {\r\n    const config: any = {\r\n      headerBgColor: this.headerBackgroundColor,\r\n      headerTextColor: this.headerTextColor,\r\n      bodyTextColor: '#000000',\r\n      fontFamily: this.fontFaimly,\r\n      fontWeight: 'normal',\r\n      zoomScale: 125,\r\n      headerRowHeight: 30\r\n    }\r\n    if (this.enableExport) {\r\n      const now = new Date();\r\n      const dd = String(now.getDate()).padStart(2, '0');\r\n      const mm = String(now.getMonth() + 1).padStart(2, '0');\r\n      const yyyy = now.getFullYear();\r\n      const HH = String(now.getHours()).padStart(2, '0');\r\n      const MM = String(now.getMinutes()).padStart(2, '0');\r\n      const formatted =\r\n        `${this.tableType}_${dd}-${mm}-${yyyy}_${HH}-${MM}`;\r\n\r\n      console.log(formatted);\r\n\r\n      this.exportService.exportData(this.columns, this.dataSet, formatted, type, this.rowSelectedIndexes, config);\r\n    }\r\n    const event = {\r\n      obj: {\r\n        columns: this.columns,\r\n        filters: []\r\n      },\r\n      eventType: 'downloadCsv'\r\n    }\r\n    if (type == 'xlsx') {\r\n      return\r\n    }\r\n    this.genericEvent.emit(event)\r\n\r\n  }\r\n\r\n  onFontChange() {\r\n    this.headerTextFontsSize = this.bodyTextFontsSize;\r\n    const config = {\r\n      fontFaimly: this.fontFaimly,\r\n      bodyTextFontsSize: this.bodyTextFontsSize,\r\n      headerTextFontsSize: this.headerTextFontsSize,\r\n      oddRowsBackgroundColor: this.rowShadingEnabled ? this.oddRowsBackgroundColor : undefined,\r\n      showVerticalBorder: this.showVerticalBorder,\r\n      selectedTableLayout: this.selectedTableLayout,\r\n      globalSearch: this.tableSearch\r\n    }\r\n    const event = {\r\n      obj: {\r\n        data: config\r\n      },\r\n      eventType: 'config'\r\n    }\r\n    this.genericEvent.emit(event)\r\n  }\r\n\r\n  onGlobalSearch() {\r\n    const event = {\r\n      obj: {\r\n        tableSearch: this.tableSearch\r\n      },\r\n      eventType: 'search'\r\n    }\r\n    this.genericEvent.emit(event)\r\n    if (this.tableFilterViewId) {\r\n      this.savePreset('mouseUp');\r\n    }\r\n  }\r\n\r\n  onSearchInput(event: Event) {\r\n    const value = (event.target as HTMLInputElement).value;\r\n    // console.log('Search value:', value);\r\n\r\n    if (value === '') {\r\n      this.tableSearch = '';\r\n      this.onGlobalSearch();\r\n    }\r\n  }\r\n\r\n  checkFilterChangesEffect(): any {\r\n    if (!this.tableFilterViewId) return true\r\n    const findDefaultFilter = this.tableView?.find((ele: any) => ele?.id == this.tableFilterViewId);\r\n    const normalizeFilters = (filters: any[] | undefined): any[] => {\r\n      if (!Array.isArray(filters)) return [];\r\n      const cloned = filters.map(f => {\r\n        const item = JSON.parse(JSON.stringify(f ?? {}));\r\n        if (!Array.isArray(item._ids)) item._ids = [];\r\n        item._ids = item._ids.slice().sort((a: any, b: any) => {\r\n          if (typeof a === 'number' && typeof b === 'number') return a - b;\r\n          return ('' + a).localeCompare('' + b);\r\n        });\r\n\r\n        if (item.query === null) {\r\n        } else if (typeof item.query === 'object') {\r\n          if (!Array.isArray(item.query._ids)) item.query._ids = [];\r\n          item.query._ids = item.query._ids.slice().sort((a: any, b: any) => {\r\n            if (typeof a === 'number' && typeof b === 'number') return a - b;\r\n            return ('' + a).localeCompare('' + b);\r\n          });\r\n        }\r\n\r\n        return item;\r\n      });\r\n      cloned.sort((a: any, b: any) => {\r\n        const fa = (a.field || '') + '|' + (a.type || '');\r\n        const fb = (b.field || '') + '|' + (b.type || '');\r\n        return fa.localeCompare(fb);\r\n      });\r\n\r\n      return cloned;\r\n    };\r\n\r\n    const deepEqual = (a: any, b: any): boolean => {\r\n      if (a === b) return true;\r\n\r\n      if (typeof a !== 'object' || a === null || typeof b !== 'object' || b === null) {\r\n        return a === b;\r\n      }\r\n\r\n      if (Array.isArray(a) !== Array.isArray(b)) return false;\r\n\r\n      if (Array.isArray(a)) {\r\n        if (a.length !== b.length) return false;\r\n        for (let i = 0; i < a.length; i++) {\r\n          if (!deepEqual(a[i], b[i])) return false;\r\n        }\r\n        return true;\r\n      }\r\n\r\n      const keysA = Object.keys(a);\r\n      const keysB = Object.keys(b);\r\n      if (keysA.length !== keysB.length) return false;\r\n\r\n      for (const key of keysA) {\r\n        if (!keysB.includes(key)) return false;\r\n        if (!deepEqual(a[key], b[key])) return false;\r\n      }\r\n      return true;\r\n    };\r\n    const normalizedA = normalizeFilters(findDefaultFilter?.filters);\r\n    const normalizedB = normalizeFilters(this.filtersConfig);\r\n    const isSame = deepEqual(normalizedA, normalizedB);\r\n    return isSame;\r\n  }\r\n\r\n\r\n\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // Cell Selection Implemented Here Implemented Here\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n\r\n  selectedCells: any[] = [];\r\n  selectedKeys: Set<string> = new Set();\r\n  selectionStart: any = null;\r\n  isSelecting = false;\r\n  startSelection(\r\n    rowIndex: number,\r\n    colIndex: number,\r\n    subColIndex: number | null,\r\n    field: string,\r\n    event: MouseEvent,\r\n    section: string\r\n  ) {\r\n    // event.preventDefault();\r\n    this.rowSelectedIndexes.clear();\r\n    const safeSub = subColIndex ?? 0;\r\n    const key = `${rowIndex}-${colIndex}-${safeSub}-${field}`;\r\n\r\n    this.selectionStart = { rowIndex, colIndex, subColIndex: safeSub, field, key };\r\n    this.isSelecting = true;\r\n    this.selectedKeys.clear();\r\n    this.selectedKeys.add(key);\r\n    this.selectedCells = [this.selectionStart];\r\n    const mouseUpHandler = () => {\r\n      this.endSelection();\r\n      document.removeEventListener('mouseup', mouseUpHandler);\r\n    };\r\n    document.addEventListener('mouseup', mouseUpHandler);\r\n    this.updateSelectionBoundaries()\r\n  }\r\n\r\n\r\n  extendSelection(\r\n    rowIndex: number,\r\n    colIndex: number,\r\n    subColIndex: number | null,\r\n    field: string,\r\n    event: MouseEvent,\r\n    section: string\r\n  ) {\r\n    if (!this.isSelecting || !this.selectionStart) return;\r\n\r\n    const start = this.selectionStart;\r\n    const targetSubColIndex = subColIndex ?? 0;\r\n    const newKeys: Set<string> = new Set();\r\n    const newCells: any[] = [];\r\n    const minRow = Math.min(start.rowIndex, rowIndex);\r\n    const maxRow = Math.max(start.rowIndex, rowIndex);\r\n    const columnsToSelect = this.getColumnSelectionRange(start.colIndex, colIndex, start.subColIndex, targetSubColIndex);\r\n\r\n    for (let r = minRow; r <= maxRow; r++) {\r\n      for (const colInfo of columnsToSelect) {\r\n        const k = `${r}-${colInfo.colIndex}-${colInfo.subColIndex}-${section}`;\r\n        newKeys.add(k);\r\n        newCells.push({\r\n          rowIndex: r,\r\n          colIndex: colInfo.colIndex,\r\n          subColIndex: colInfo.subColIndex,\r\n          field,\r\n          key: k\r\n        });\r\n      }\r\n    }\r\n\r\n    this.selectedKeys = newKeys;\r\n    this.selectedCells = newCells;\r\n    this.updateSelectionBoundaries();\r\n    this.cdr.detectChanges();\r\n\r\n    // Add auto-scrolling logic\r\n    this.handleCellAutoScroll(event);\r\n  }\r\n\r\n\r\n\r\n\r\n  getColumnSelectionRange(\r\n    startCol: number,\r\n    endCol: number,\r\n    startSub: number,\r\n    endSub: number\r\n  ): { colIndex: number; subColIndex: number }[] {\r\n    const result: { colIndex: number; subColIndex: number }[] = [];\r\n    const minCol = Math.min(startCol, endCol);\r\n    const maxCol = Math.max(startCol, endCol);\r\n\r\n    const isLeftToRight = startCol <= endCol;\r\n    for (let c = minCol; c <= maxCol; c++) {\r\n      const subColCount = this.getSubColumnCount(c);\r\n\r\n      if (c === startCol && c === endCol) {\r\n        const minSub = Math.min(startSub, endSub);\r\n        const maxSub = Math.max(startSub, endSub);\r\n        for (let s = minSub; s <= maxSub && s < subColCount; s++) {\r\n          result.push({ colIndex: c, subColIndex: s });\r\n        }\r\n      }\r\n      else if (c === startCol) {\r\n        if (isLeftToRight) {\r\n          for (let s = startSub; s < subColCount; s++) {\r\n            result.push({ colIndex: c, subColIndex: s });\r\n          }\r\n        } else {\r\n          for (let s = 0; s <= startSub && s < subColCount; s++) {\r\n            result.push({ colIndex: c, subColIndex: s });\r\n          }\r\n        }\r\n      }\r\n      else if (c === endCol) {\r\n        if (isLeftToRight) {\r\n          for (let s = 0; s <= endSub && s < subColCount; s++) {\r\n            result.push({ colIndex: c, subColIndex: s });\r\n          }\r\n        } else {\r\n          for (let s = endSub; s < subColCount; s++) {\r\n            result.push({ colIndex: c, subColIndex: s });\r\n          }\r\n        }\r\n      }\r\n      else {\r\n        for (let s = 0; s < subColCount; s++) {\r\n          result.push({ colIndex: c, subColIndex: s });\r\n        }\r\n      }\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  getSubColumnCount(colIndex: number): number {\r\n    if (!this.columns || colIndex < 0 || colIndex >= this.columns.length) {\r\n      return 1;\r\n    }\r\n    const column = this.columns[colIndex];\r\n    if (column.children && Array.isArray(column.children)) {\r\n      return column.children.length;\r\n    }\r\n    return 1;\r\n  }\r\n  isGroupColumn(colIndex: number): boolean {\r\n    return this.getSubColumnCount(colIndex) > 1;\r\n  }\r\n  endSelection() {\r\n    this.isSelecting = false;\r\n    this.stopAutoScroll();\r\n    this.updateSelectionBoundaries();\r\n  }\r\n  isSelected(\r\n    rowIndex: number,\r\n    colIndex: number,\r\n    subColIndex: number | null,\r\n    field: string,\r\n    section: string\r\n  ) {\r\n    const safeSub = subColIndex ?? 0;\r\n    const key = `${rowIndex}-${colIndex}-${safeSub}-${section}`;\r\n    return this.selectedKeys.has(key);\r\n  }\r\n\r\n\r\n  private selectionBounds: {\r\n    top: number | null;\r\n    bottom: number | null;\r\n    left: { colIndex: number; subColIndex: number } | null;\r\n    right: { colIndex: number; subColIndex: number } | null;\r\n  } = { top: null, bottom: null, left: null, right: null };\r\n\r\n  updateSelectionBoundaries() {\r\n    if (this.selectedCells.length === 0) {\r\n      this.selectionBounds = { top: null, bottom: null, left: null, right: null };\r\n      return;\r\n    }\r\n\r\n    // Get all unique row indices and find min/max\r\n    const rowIndices = [...new Set(this.selectedCells.map(cell => cell.rowIndex))];\r\n    this.selectionBounds.top = Math.min(...rowIndices);\r\n    this.selectionBounds.bottom = Math.max(...rowIndices);\r\n\r\n    // For left/right boundaries, we need to consider both colIndex and subColIndex\r\n    const leftMost = this.findLeftMostCell();\r\n    const rightMost = this.findRightMostCell();\r\n\r\n    this.selectionBounds.left = leftMost;\r\n    this.selectionBounds.right = rightMost;\r\n  }\r\n  findLeftMostCell(): { colIndex: number; subColIndex: number } | null {\r\n    if (this.selectedCells.length === 0) return null;\r\n\r\n    const minColIndex = Math.min(...this.selectedCells.map(cell => cell.colIndex));\r\n    const leftColCells = this.selectedCells.filter(cell => cell.colIndex === minColIndex);\r\n    const minSubColIndex = Math.min(...leftColCells.map(cell => cell.subColIndex));\r\n\r\n    return { colIndex: minColIndex, subColIndex: minSubColIndex };\r\n  }\r\n  findRightMostCell(): { colIndex: number; subColIndex: number } | null {\r\n    if (this.selectedCells.length === 0) return null;\r\n\r\n    const maxColIndex = Math.max(...this.selectedCells.map(cell => cell.colIndex));\r\n    const rightColCells = this.selectedCells.filter(cell => cell.colIndex === maxColIndex);\r\n    const maxSubColIndex = Math.max(...rightColCells.map(cell => cell.subColIndex));\r\n\r\n    return { colIndex: maxColIndex, subColIndex: maxSubColIndex };\r\n  }\r\n  isTopBorder(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    const safeSub = subColIndex ?? 0;\r\n    const isSelected = this.selectedKeys.has(`${rowIndex}-${colIndex}-${safeSub}-${section}`);\r\n    return isSelected && this.selectionBounds.top !== null && rowIndex === this.selectionBounds.top;\r\n  }\r\n  isBottomBorder(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    const safeSub = subColIndex ?? 0;\r\n    const isSelected = this.selectedKeys.has(`${rowIndex}-${colIndex}-${safeSub}-${section}`);\r\n    return isSelected && this.selectionBounds.bottom !== null && rowIndex === this.selectionBounds.bottom;\r\n  }\r\n  isLeftBorder(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    const safeSub = subColIndex ?? 0;\r\n    const isSelected = this.selectedKeys.has(`${rowIndex}-${colIndex}-${safeSub}-${section}`);\r\n    return isSelected && this.selectionBounds.left !== null &&\r\n      colIndex === this.selectionBounds.left.colIndex &&\r\n      safeSub === this.selectionBounds.left.subColIndex;\r\n  }\r\n\r\n  isRightBorder(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    const safeSub = subColIndex ?? 0;\r\n    const isSelected = this.selectedKeys.has(`${rowIndex}-${colIndex}-${safeSub}-${section}`);\r\n    return isSelected && this.selectionBounds.right !== null &&\r\n      colIndex === this.selectionBounds.right.colIndex &&\r\n      safeSub === this.selectionBounds.right.subColIndex;\r\n  }\r\n\r\n  isTopLeftCorner(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    return this.isTopBorder(rowIndex, colIndex, subColIndex, section) && this.isLeftBorder(rowIndex, colIndex, subColIndex, section);\r\n  }\r\n\r\n  isTopRightCorner(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    return this.isTopBorder(rowIndex, colIndex, subColIndex, section) && this.isRightBorder(rowIndex, colIndex, subColIndex, section);\r\n  }\r\n\r\n  isBottomLeftCorner(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    return this.isBottomBorder(rowIndex, colIndex, subColIndex, section) && this.isLeftBorder(rowIndex, colIndex, subColIndex, section);\r\n  }\r\n\r\n  isBottomRightCorner(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    return this.isBottomBorder(rowIndex, colIndex, subColIndex, section) && this.isRightBorder(rowIndex, colIndex, subColIndex, section);\r\n  }\r\n\r\n\r\n  cellSelectionAutoScrollInterval: any = null;\r\n  private scrollSpeed = 150;\r\n  private scrollMargin = 30;\r\n  handleCellAutoScroll(event: MouseEvent) {\r\n    if (this.cellSelectionAutoScrollInterval) {\r\n      clearInterval(this.cellSelectionAutoScrollInterval);\r\n      this.cellSelectionAutoScrollInterval = null;\r\n    }\r\n    const horizontalContainer = this.centerScrollableBody.nativeElement;\r\n    const verticalContainer = this.mainScroll.nativeElement;\r\n    if (!horizontalContainer || !verticalContainer) return;\r\n    const horizontalRect = horizontalContainer.getBoundingClientRect();\r\n    const mouseX = event.clientX;\r\n    const verticalRect = verticalContainer.getBoundingClientRect();\r\n    const mouseY = event.clientY;\r\n    const nearTop = mouseY - verticalRect.top < this.scrollMargin;\r\n    const nearBottom = verticalRect.bottom - mouseY < this.scrollMargin;\r\n    const nearLeft = mouseX - horizontalRect.left < this.scrollMargin;\r\n    const nearRight = horizontalRect.right - mouseX < this.scrollMargin;\r\n    let scrollX = 0;\r\n    let scrollY = 0;\r\n    if (nearTop) scrollY = -this.scrollSpeed;\r\n    if (nearBottom) scrollY = this.scrollSpeed;\r\n    if (nearLeft) scrollX = -this.scrollSpeed;\r\n    if (nearRight) scrollX = this.scrollSpeed;\r\n    if (scrollX !== 0 || scrollY !== 0) {\r\n      this.cellSelectionAutoScrollInterval = setInterval(() => {\r\n        if (scrollX !== 0) {\r\n          horizontalContainer.scrollBy(scrollX, 0);\r\n        }\r\n        if (scrollY !== 0) {\r\n          verticalContainer.scrollBy(0, scrollY);\r\n        }\r\n      }, 8);\r\n    }\r\n  }\r\n\r\n  stopAutoScroll() {\r\n    if (this.cellSelectionAutoScrollInterval) {\r\n      clearInterval(this.cellSelectionAutoScrollInterval);\r\n      this.cellSelectionAutoScrollInterval = null;\r\n    }\r\n  }\r\n\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // Row Selection from the Indexing Implemented Here\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n\r\n  rowSelectedIndexes: Set<number> = new Set();\r\n  rowSelecting = false;\r\n  rowSelectionStartIndex: number | null = null;\r\n  autoScrollInterval: any = null;\r\n\r\n  get firstSelectedRow(): number | null {\r\n    if (this.rowSelectedIndexes.size === 0) return null;\r\n    return Math.min(...this.rowSelectedIndexes);\r\n  }\r\n\r\n  get lastSelectedRow(): number | null {\r\n    if (this.rowSelectedIndexes.size === 0) return null;\r\n    return Math.max(...this.rowSelectedIndexes);\r\n  }\r\n\r\n\r\n  onRowMouseDown(index: number, event: MouseEvent) {\r\n    event.preventDefault();\r\n    this.rowSelecting = true;\r\n    this.selectedKeys.clear();\r\n    this.rowSelectionStartIndex = index;\r\n    this.rowSelectedIndexes.clear();\r\n    this.rowSelectedIndexes.add(index);\r\n    this.activeCell = '';\r\n    this.cdr.detectChanges();\r\n\r\n    const mouseMoveHandler = (e: MouseEvent) => this.handleAutoScroll(e);\r\n    const mouseUpHandler = () => {\r\n      this.onRowMouseUp();\r\n      document.removeEventListener('mouseup', mouseUpHandler);\r\n      document.removeEventListener('mousemove', mouseMoveHandler);\r\n      if (this.autoScrollInterval) {\r\n        cancelAnimationFrame(this.autoScrollInterval);\r\n        this.autoScrollInterval = null;\r\n      }\r\n    };\r\n\r\n    document.addEventListener('mouseup', mouseUpHandler);\r\n    document.addEventListener('mousemove', mouseMoveHandler);\r\n  }\r\n\r\n  onRowMouseOver(index: number, event: MouseEvent) {\r\n    if (!this.rowSelecting || this.rowSelectionStartIndex === null) return;\r\n    this.rowSelectedIndexes.clear();\r\n    const start = Math.min(this.rowSelectionStartIndex, index);\r\n    const end = Math.max(this.rowSelectionStartIndex, index);\r\n    for (let i = start; i <= end; i++) {\r\n      this.rowSelectedIndexes.add(i);\r\n    }\r\n    // console.log([...this.rowSelectedIndexes]);\r\n  }\r\n\r\n  onRowMouseUp() {\r\n    this.rowSelecting = false;\r\n    this.rowSelectionStartIndex = null;\r\n  }\r\n  handleAutoScroll(e: MouseEvent) {\r\n    const container = this.mainScroll?.nativeElement as HTMLElement;\r\n    if (!container) return;\r\n\r\n    const rect = container.getBoundingClientRect();\r\n    const edgeSize = 40\r\n    let scrollAmount = 0;\r\n\r\n    if (e.clientY < rect.top + edgeSize) {\r\n      scrollAmount = -150;\r\n    } else if (e.clientY > rect.bottom - edgeSize) {\r\n      scrollAmount = 150;\r\n    }\r\n\r\n    if (scrollAmount !== 0) {\r\n      if (!this.autoScrollInterval) {\r\n        const step = () => {\r\n          container.scrollTop += scrollAmount;\r\n          this.autoScrollInterval = requestAnimationFrame(step);\r\n        };\r\n        this.autoScrollInterval = requestAnimationFrame(step);\r\n      }\r\n    } else {\r\n      if (this.autoScrollInterval) {\r\n        cancelAnimationFrame(this.autoScrollInterval);\r\n        this.autoScrollInterval = null;\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  // getSelectedDataForCopy(): any[][] {\r\n  //   const copiedRows: any[][] = [];\r\n  //   const findRowByVirtualIndex = (vIndex: number) =>\r\n  //     this.dataSet.find((r: any) => r.__virtualIndex === vIndex);\r\n  //   if (this.rowSelectedIndexes && this.rowSelectedIndexes.size > 0) {\r\n  //     const sortedIndexes = [...this.rowSelectedIndexes].sort((a, b) => a - b);\r\n  //     for (const vIndex of sortedIndexes) {\r\n  //       const row = findRowByVirtualIndex(vIndex);\r\n  //       if (!row) continue;\r\n  //       const rowValues = this.columns.flatMap(col =>\r\n  //         col.children && Array.isArray(col.children)\r\n  //           ? col.children.map((c: { field: string }) =>\r\n  //               this.getNestedValue(row, c.field) ?? ''\r\n  //             )\r\n  //           : this.getNestedValue(row, col.field) ?? ''\r\n  //       );\r\n  //       copiedRows.push(rowValues);\r\n  //     }\r\n  //   }\r\n\r\n  //   if (this.selectedCells && this.selectedCells.length > 0) {\r\n  //     const rowsMap = new Map<number, any[]>();\r\n  //     for (const cell of this.selectedCells) {\r\n  //       const row = findRowByVirtualIndex(cell.rowIndex);\r\n  //       if (!row) continue;\r\n\r\n  //       const col = this.columns[cell.colIndex];\r\n  //       let fieldName = col?.field;\r\n  //       if (col?.children && col.children[cell.subColIndex]) {\r\n  //         fieldName = col.children[cell.subColIndex].field;\r\n  //       }\r\n  //       const value = this.getNestedValue(row, fieldName) ?? '';\r\n\r\n  //       if (!rowsMap.has(cell.rowIndex)) rowsMap.set(cell.rowIndex, []);\r\n  //       rowsMap.get(cell.rowIndex)!.push(value);\r\n  //     }\r\n\r\n  //     const sortedCells = [...rowsMap.entries()]\r\n  //       .sort(([a], [b]) => a - b)\r\n  //       .map(([_, v]) => v);\r\n\r\n  //     copiedRows.push(...sortedCells);\r\n  //   }\r\n\r\n  //   if (copiedRows.length === 0) {\r\n  //     const activeCell = document.querySelector('.active-cell');\r\n  //     if (activeCell) return [[activeCell.textContent?.trim() || '']];\r\n  //   }\r\n  //   const maxCols = copiedRows.reduce((max, row) => Math.max(max, row.length), 0);\r\n  //   const normalized = copiedRows.map(row => {\r\n  //     const newRow = [...row];\r\n  //     while (newRow.length < maxCols) newRow.push(''); \r\n  //     return newRow;\r\n  //   });\r\n  //   return normalized;\r\n  // }\r\n\r\n\r\n  undoStack: any[][] = [];\r\n  redoStack: any[][] = [];\r\n\r\n  private cloneData(data: any[]): any[] {\r\n    return JSON.parse(JSON.stringify(data));\r\n  }\r\n\r\n  performCut(selectedData: any[][]) {\r\n    // Save current state for undo\r\n    this.undoStack.push(this.cloneData(this.visibleRows));\r\n    this.redoStack = []; // Clear redo stack on new action\r\n\r\n    // Perform cut\r\n    this.copyService.cutWithAnimation(selectedData);\r\n    const { updatedRows } = this.copyService.cutSelectedSelectedData(\r\n      this.visibleRows,\r\n      this.rowSelectedIndexes,\r\n      this.selectedCells,\r\n      this.columns,\r\n      this.setNestedValue.bind(this)\r\n    );\r\n\r\n    // console.log('Updated Rows: ', updatedRows);\r\n  }\r\n\r\n\r\n\r\n  getSelectedDataForCopy(): any[][] {\r\n    return this.copyService.getSelectedDataForCopy(\r\n      this.dataSet,\r\n      this.columns,\r\n      this.rowSelectedIndexes,\r\n      this.selectedCells,\r\n      this.getNestedValue.bind(this)\r\n    );\r\n  }\r\n\r\n  @HostListener('document:keydown', ['$event'])\r\n  onKeyDown(event: KeyboardEvent) {\r\n    const target = event.target as HTMLElement;\r\n    const isFormField =\r\n      target.tagName === 'INPUT' ||\r\n      target.tagName === 'TEXTAREA' ||\r\n      target.isContentEditable;\r\n    if (isFormField) return;\r\n\r\n    const tableContainer = document.querySelector('.data-grid-body-wrapper');\r\n    if (tableContainer && !tableContainer.contains(target)) return;\r\n    if ((event.ctrlKey || event.metaKey) && event.key.toLowerCase() === 'c') {\r\n      if (!this.selectedCells?.length && !this.rowSelectedIndexes.size) return\r\n      const selectedData = this.getSelectedDataForCopy();\r\n      // event.preventDefault();\r\n      this.copyService.copyToClipboard(selectedData);\r\n\r\n    } else if ((event.ctrlKey || event.metaKey) && event.key.toLowerCase() === 'x') {\r\n      if (!this.selectedCells?.length || !this.enableCut) return\r\n      const selectedData = this.getSelectedDataForCopy();\r\n      // event.preventDefault();\r\n      this.performCut(selectedData);\r\n\r\n    } else if ((event.ctrlKey || event.metaKey) && event.key.toLowerCase() === 'z') {\r\n      if (!this.selectedCells?.length) return\r\n      // event.preventDefault();\r\n      this.undo();\r\n\r\n    } else if ((event.ctrlKey || event.metaKey) && event.key.toLowerCase() === 'y') {\r\n      if (!this.selectedCells?.length) return\r\n      // event.preventDefault();\r\n      this.redo();\r\n    } else if ((event.ctrlKey || event.metaKey) && event.key === 'a') {\r\n      // ✅ Select all cells\r\n      event.preventDefault();\r\n      this.selectAllCells();\r\n    }\r\n  }\r\n\r\n\r\n  selectAllCells() {\r\n    this.selectedCells = [];\r\n    this.selectedKeys.clear();\r\n    this.rowSelectedIndexes.clear();\r\n\r\n    // Set selection start like single selection (first cell)\r\n    if (this.dataSet.length && this.columns.length) {\r\n      const firstField = this.columns[0].field || this.columns[0].name;\r\n      this.selectionStart = {\r\n        rowIndex: 0,\r\n        colIndex: 0,\r\n        subColIndex: 0,\r\n        field: firstField,\r\n        key: `0-0-0-${firstField}`,\r\n      };\r\n    }\r\n\r\n    this.isSelecting = true;\r\n\r\n    for (let rowIndex = 0; rowIndex <= this.dataSet?.length; rowIndex++) {\r\n      if (!rowIndex) continue;\r\n      const row = this.dataSet[rowIndex];\r\n      this.rowSelectedIndexes.add(rowIndex);\r\n\r\n      // for (let colIndex = 0; colIndex < this.columns.length; colIndex++) {\r\n      //   const col = this.columns[colIndex];\r\n      //   const field = col.field || col.name;\r\n      //   if(!col.is_visible) continue;\r\n\r\n      //   if (col.children?.length) {\r\n      //     col.children.forEach((sub: any, subColIndex: number) => {\r\n      //       const key = `${rowIndex}-${colIndex}-${subColIndex}-${field}`;\r\n      //       this.selectedKeys.add(key);\r\n      //       this.selectedCells.push({\r\n      //         rowIndex,\r\n      //         colIndex,\r\n      //         subColIndex,\r\n      //         field,\r\n      //         key,\r\n      //       });\r\n      //     });\r\n      //   } else {\r\n      //     const key = `${rowIndex}-${colIndex}-0-${field}`;\r\n      //     this.selectedKeys.add(key);\r\n      //     this.selectedCells.push({\r\n      //       rowIndex,\r\n      //       colIndex,\r\n      //       subColIndex: 0,\r\n      //       field,\r\n      //       key,\r\n      //     });\r\n      //   }\r\n      // }\r\n    }\r\n\r\n    // Update highlighting and UI\r\n    this.updateSelectionBoundaries();\r\n\r\n    // Stop \"selecting\" mode since it's a one-time select-all\r\n    this.isSelecting = false;\r\n  }\r\n\r\n\r\n\r\n  undo() {\r\n    if (this.undoStack.length > 0) {\r\n      const prevState = this.undoStack.pop()!;\r\n      this.redoStack.push(this.cloneData(this.visibleRows));\r\n      this.visibleRows = this.cloneData(prevState);\r\n    }\r\n  }\r\n\r\n  redo() {\r\n    if (this.redoStack.length > 0) {\r\n      const nextState = this.redoStack.pop()!;\r\n      this.undoStack.push(this.cloneData(this.visibleRows));\r\n      this.visibleRows = this.cloneData(nextState);\r\n    }\r\n  }\r\n\r\n\r\n\r\n  @HostListener('document:paste', ['$event'])\r\n  async onPaste(event: ClipboardEvent) {\r\n    const target = event.target as HTMLElement;\r\n    const tag = target?.tagName?.toLowerCase();\r\n    if (tag === 'input' || tag === 'textarea' || target?.getAttribute('contenteditable') === 'true') {\r\n      return;\r\n    }\r\n\r\n    if (!this.selectedCells?.length || !this.activeCell) return;\r\n\r\n    const text = event.clipboardData?.getData('text');\r\n    if (!text) return;\r\n    const userConfirmed = await this.showConfirmationModal(\r\n      'Are you sure you want to paste the copied data?'\r\n    );\r\n\r\n    if (!userConfirmed) {\r\n      event.preventDefault();\r\n      return;\r\n    }\r\n\r\n    const startCell = this.selectedCells?.[0];\r\n    if (!startCell) return;\r\n\r\n    const updatedRows = await this.copyService.pasteFromClipboardText(\r\n      text,\r\n      this.visibleRows,\r\n      this.columns,\r\n      startCell.rowIndex,\r\n      startCell.colIndex,\r\n      startCell.subColIndex\r\n    );\r\n\r\n    if (updatedRows?.updateRows?.length) {\r\n      this.genericEvent.emit({\r\n        data: updatedRows?.updateRows,\r\n        eventType: 'onCellEdit',\r\n        column: updatedRows?.currentColums\r\n      });\r\n    }\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  showConfirmationModal(message: string): Promise<boolean> {\r\n    return new Promise(resolve => {\r\n      const overlay = document.createElement('div');\r\n      overlay.classList.add('custom-overlay-wrapper');\r\n      overlay.innerHTML = `\r\n      <div class=\"custom-overlay\">\r\n        <div class=\"custom-modal\">\r\n          <div class=\"custom-modal-body\">\r\n            <p class=\"modal-message\">${message}</p>\r\n            <div class=\"modal-actions\">\r\n              <button class=\"btn-confirm\">Confirm</button>\r\n              <button class=\"btn-cancel\">Cancel</button>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    `;\r\n\r\n      document.body.appendChild(overlay);\r\n      const confirmBtn = overlay.querySelector('.btn-confirm') as HTMLElement;\r\n      const cancelBtn = overlay.querySelector('.btn-cancel') as HTMLElement;\r\n      const cleanup = () => {\r\n        document.body.removeChild(overlay);\r\n      };\r\n      confirmBtn.addEventListener('click', () => {\r\n        cleanup();\r\n        resolve(true);\r\n      });\r\n\r\n      cancelBtn.addEventListener('click', () => {\r\n        cleanup();\r\n        resolve(false);\r\n      });\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n  isDate(value: any): boolean {\r\n    return !isNaN(new Date(value)?.getTime());\r\n  }\r\n\r\n\r\n  // Hold expanded IDs (array for multiple, single value for single)\r\n  expandededDetailRows: (string | number)[] | string | number = '';\r\n\r\n  toggleDetailRowExpand(row: any) {\r\n    const id = row?.id || row?._id;\r\n    if (this.gridType === 'Assets' && row?.detail?.columns) {\r\n      row.detail.columns.forEach((item: any) => {\r\n        item.width = item?.width || (this.dataGridContainer.nativeElement.offsetWidth / row.detail.columns?.length)\r\n      });\r\n      this.previewNestedCols = this.deepCloneColumns(row.detail.columns);\r\n    }\r\n    if (this.keepMultipleExpandedDetails) {\r\n      if (!Array.isArray(this.expandededDetailRows)) {\r\n        this.expandededDetailRows = [];\r\n      }\r\n      const expanded = this.expandededDetailRows as (string | number)[];\r\n      const index = expanded.indexOf(id);\r\n\r\n      if (index > -1) {\r\n        expanded.splice(index, 1);\r\n      } else {\r\n        expanded.push(id);\r\n      }\r\n    } else {\r\n      if (this.expandededDetailRows === id) {\r\n        this.expandededDetailRows = '';\r\n      } else {\r\n        this.expandededDetailRows = id;\r\n      }\r\n    }\r\n\r\n    setTimeout(() => {\r\n      void this.rightPinnedHeader?.nativeElement.offsetWidth;\r\n      this.centerPinnedBody?.nativeElement.offsetWidth;\r\n      this.rightPinnedBody?.nativeElement.offsetWidth;\r\n      this.cdr.detectChanges();\r\n    }, 300)\r\n  }\r\n\r\n  isDetailsExpanded(row: any): boolean {\r\n    const id = row?.id || row?._id;\r\n\r\n    if (this.keepMultipleExpandedDetails) {\r\n      return Array.isArray(this.expandededDetailRows) &&\r\n        this.expandededDetailRows.includes(id);\r\n    } else {\r\n      return this.expandededDetailRows === id;\r\n    }\r\n  }\r\n\r\n  getFilterValue(option: any): any {\r\n    return option?.value ?? option;\r\n  }\r\n\r\n\r\n  openIndex: number | null = null;\r\n  toggleMenu(i: number, event?: MouseEvent) {\r\n    if (event) { event.stopPropagation(); }\r\n    this.openIndex = this.openIndex === i ? null : i;\r\n  }\r\n\r\n  @ViewChild('nestedTable')\r\n  nestedTable!: ElementRef<HTMLDivElement>;\r\n  get hasVerticalScroll(): boolean {\r\n    if (!this.nestedTable) return false;\r\n    return this.nestedTable.nativeElement.scrollHeight > this.nestedTable.nativeElement.clientHeight;\r\n  }\r\n\r\n  get hasHorizontalScroll(): boolean {\r\n    if (!this.nestedTable) return false;\r\n    const el = this.nestedTable.nativeElement;\r\n    return el.scrollWidth > el.clientWidth;\r\n  }\r\n\r\n\r\n  getTotalAmount(column: any) {\r\n    if (!column?.is_amount) return;\r\n    const total = this.originalDataSet.reduce((sum, row) => {\r\n      const value = row[column.field] || 0;\r\n      return sum + value;\r\n    }, 0);\r\n    if(!total) return `${this.currencySymbol} 0.00`\r\n    return `${this.currencySymbol} ${this.formatCurrency.transform(total, this.currencyFormat)}`;\r\n  }\r\n\r\n  dropColumn(event: CdkDragDrop<any[]>, row: any) {\r\n    // Reorder the columns array\r\n    moveItemInArray(row.detail.columns, event.previousIndex, event.currentIndex);\r\n  }\r\n\r\n  currentSubSortColumn: string | null = null; // active column\r\n  currentSortDirection: 'asc' | 'desc' = 'asc'; // active direction\r\n\r\n  sortNestedCol(col: any, row: any) {\r\n    const dataSet = row?.detail?.result;\r\n    if (this.currentSubSortColumn === col.field) {\r\n      this.currentSortDirection = this.currentSortDirection === 'asc' ? 'desc' : 'asc';\r\n    } else {\r\n      this.currentSubSortColumn = col.field;\r\n      this.currentSortDirection = 'asc';\r\n    }\r\n    col.order_by = this.currentSortDirection;\r\n\r\n    // Sort copy instead of mutating\r\n    const sorted = [...dataSet].sort((a, b) => {\r\n      let aVal = a[col.field];\r\n      let bVal = b[col.field];\r\n      aVal = aVal == null ? '' : aVal;\r\n      bVal = bVal == null ? '' : bVal;\r\n\r\n      if (col.type === 'date') {\r\n        aVal = new Date(aVal).getTime();\r\n        bVal = new Date(bVal).getTime();\r\n      }\r\n\r\n      const aNum = parseFloat(aVal);\r\n      const bNum = parseFloat(bVal);\r\n      const bothNumbers = !isNaN(aNum) && !isNaN(bNum);\r\n\r\n      if (bothNumbers) {\r\n        return this.currentSortDirection === 'asc' ? aNum - bNum : bNum - aNum;\r\n      } else {\r\n        const comp = String(aVal).localeCompare(String(bVal));\r\n        return this.currentSortDirection === 'asc' ? comp : -comp;\r\n      }\r\n    });\r\n\r\n    row.detail.result = sorted;\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  getColumnWidthPx(row: any, col: any): string {\r\n    if (col.width) return col.width + 'px';\r\n    const pixels = this.centerScrollableBody?.nativeElement?.offsetWidth / row.detail?.columns.length;\r\n    return pixels + 'px';\r\n  }\r\n\r\n  fullscreenImage: string | null = null;\r\n\r\n\r\n  // Assests Nested Table Work Implemented Here\r\n\r\n  pinUnpinColum(col: any, value: 'left' | 'right' | null, columns: any[]) {\r\n    col.pinned = value;\r\n    const left = columns.filter(c => c.pinned === 'left');\r\n    const middle = columns.filter(c => !c.pinned || c.pinned === null);\r\n    const right = columns.filter(c => c.pinned === 'right');\r\n    columns.length = 0;\r\n    columns.push(...left, ...middle, ...right);\r\n    this.activeCol = null;\r\n  }\r\n\r\n  getLeftPinnedCount(columns: any[]): number {\r\n    return columns.filter(c => c.pinned === 'left').length;\r\n  }\r\n\r\n  getRightPinnedCount(columns: any[]): number {\r\n    return columns.filter(c => c.pinned === 'right').length;\r\n  }\r\n\r\n  getStickyLeft(columns: any[], index: number): string {\r\n    let left = 0;\r\n    for (let i = 0; i < index; i++) {\r\n      const prevCol = columns[i];\r\n      if (prevCol.pinned === 'left') {\r\n        left += prevCol.width || 100;\r\n      }\r\n    }\r\n    return `${left}px`;\r\n  }\r\n\r\n  previewNestedCols: any[] = [];\r\n  onNestedColSort(event: CdkDragSortEvent<any[]>, columns: any[]): void {\r\n    if (!event || !columns) return;\r\n    const firstPositions = new Map<HTMLElement, number>();\r\n    columns.forEach((col) => {\r\n      const colCells = Array.from(document.querySelectorAll(`[data-field=\"${col.field}\"]`)) as HTMLElement[];\r\n      colCells.forEach((el) => firstPositions.set(el, el.getBoundingClientRect().left));\r\n    });\r\n    moveItemInArray(columns, event.previousIndex, event.currentIndex);\r\n    this.cdr.detectChanges();\r\n    requestAnimationFrame(() => {\r\n      columns.forEach((col) => {\r\n        const updatedCells = Array.from(document.querySelectorAll(`[data-field=\"${col.field}\"]`)) as HTMLElement[];\r\n        updatedCells.forEach((el) => {\r\n          const newLeft = el.getBoundingClientRect().left;\r\n          const oldLeft = firstPositions.get(el) ?? newLeft;\r\n          const deltaX = oldLeft - newLeft;\r\n\r\n          if (deltaX !== 0) {\r\n            el.style.transition = 'none';\r\n            el.style.transform = `translateX(${deltaX}px)`;\r\n            void el.offsetWidth;\r\n            el.style.transition = 'transform 250ms ease';\r\n            el.style.transform = 'translateX(0)';\r\n            const cleanup = () => {\r\n              el.style.transition = '';\r\n              el.style.transform = '';\r\n              el.removeEventListener('transitionend', cleanup);\r\n            };\r\n            el.addEventListener('transitionend', cleanup);\r\n          }\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n\r\n  saveSelection(selectedIds: string[], tableType: string) {\r\n    if (!tableType) return;\r\n    const stored = JSON.parse(localStorage.getItem('datatableSelections') || '{\"selectedRows\": {}}');\r\n    const allSelected = stored.selectedRows || {};\r\n    allSelected[tableType] = selectedIds;\r\n    localStorage.setItem(\r\n      'datatableSelections',\r\n      JSON.stringify({\r\n        selectedRows: allSelected,\r\n        listingType: tableType\r\n      })\r\n    );\r\n  }\r\n\r\n\r\n  restoreSelection(tableType: string) {\r\n    const stored = JSON.parse(localStorage.getItem('datatableSelections') || '{}');\r\n    const ids = stored.selectedRows?.[tableType] || [];\r\n    this.selectedRows = new Set(ids);\r\n    return this.selectedRows;\r\n  }\r\n\r\n\r\n\r\n  isOutsideContainer = false;\r\n  private containerRect: DOMRect | null = null;\r\n\r\n\r\n  onDragStarted(col: any): void {\r\n    this.currentDraggingColumn = col;\r\n    const container = document.getElementById('data-grid-main-container');\r\n    this.containerRect = container?.getBoundingClientRect() || null;\r\n  }\r\n\r\n  onDragMoved(event: CdkDragMove): void {\r\n    if (!this.containerRect) return;\r\n\r\n    const { x, y } = event.pointerPosition;\r\n    const isOutside =\r\n      x < this.containerRect.left ||\r\n      x > this.containerRect.right ||\r\n      y < this.containerRect.top ||\r\n      y > this.containerRect.bottom;\r\n\r\n    // if (isOutside !== this.isOutsideContainer) {\r\n    //   this.isOutsideContainer = isOutside;\r\n    // }\r\n  }\r\n\r\n  onDragEnded(): void {\r\n    setTimeout(() => {\r\n      // if (this.isOutsideContainer && this.currentDraggingColumn) {\r\n      //   this.currentDraggingColumn!.is_visible = false;\r\n        this.currentDraggingColumn = null;\r\n        this.isOutsideContainer = false;\r\n      //   this.cdr.detectChanges();\r\n      // }\r\n    }, 100);\r\n    this.containerRect = null;\r\n  }\r\n\r\n  getStartIndex(): number {\r\n    return this.paginationConfig.totalResults === 0\r\n      ? 0\r\n      : (this.paginationConfig.page - 1) * this.paginationConfig.limit + 1 || 0;\r\n  }\r\n\r\n  hasAnyDefaultView() {\r\n    return this.tableView?.some((x) => x.is_default || x.is_temp);\r\n  }\r\n\r\n\r\n  get isTablePresetNotChanged() {\r\n    if (this.tableFilterViewId) return false;\r\n    const currPreset = this.curretaTablePresetForUpdate;\r\n\r\n    const currentPresetColumns = currPreset?.columns?.map((col: { field: any; width: any; pinned: any; }) => {\r\n      return {\r\n        field: col.field,\r\n        width: col.width,\r\n        pinned: col.pinned\r\n      }\r\n    });\r\n    const columns = this.columns?.map(col => {\r\n      return {\r\n        field: col.field,\r\n        width: col.width,\r\n        pinned: col.pinned\r\n      }\r\n    });\r\n\r\n    const stringsCurrentPrestCols = JSON.stringify(currentPresetColumns);\r\n    const stringColumns = JSON.stringify(columns);\r\n    const filters = this.filtersConfig.map((filter) => {\r\n      return {\r\n        filed: filter.field,\r\n        query: {\r\n          condition: filter?.query?.condition,\r\n          first_condition: filter?.query?.first_condition,\r\n          first_value: filter?.query?.first_value,\r\n          second_condition: filter?.query?.second_condition,\r\n          second_value: filter?.query?.second_value,\r\n        },\r\n        _ids: filter?._ids\r\n      }\r\n    })\r\n\r\n    const currentPresetFilters = currPreset?.filters?.map((filter: any) => {\r\n      return {\r\n        filed: filter.field,\r\n        query: filter.query,\r\n        _ids: filter?._ids\r\n      }\r\n    })\r\n\r\n\r\n    // console.log(\"filter congig: \", filters);\r\n    // console.log(\"current preset filters: \", currentPresetFilters);\r\n\r\n    // console.log('isEqual', stringsCurrentPrestCols == stringColumns);\r\n    // console.log('Current Temp Preset : ', currPreset)\r\n    // console.log('Current Temp Preset Cols columns: ', currentPresetColumns)\r\n    // console.log('Current columns: ', columns);\r\n\r\n    if (!currentPresetColumns) return true;\r\n    return (currentPresetColumns && (stringsCurrentPrestCols == stringColumns) && (JSON.stringify(filters) == JSON.stringify(currentPresetFilters)) && (this.fontFaimly == currPreset.config.fontFaimly)\r\n      && (this.bodyTextFontsSize == currPreset.config.bodyTextFontsSize) &&\r\n      (this.headerTextFontsSize == this.headerTextFontsSize)\r\n      && this.curretaTablePresetForUpdate.config.showVerticalBorder == this.showVerticalBorder\r\n      && this.curretaTablePresetForUpdate.config.fontFaimly == this.fontFaimly\r\n      && this.curretaTablePresetForUpdate.config.selectedTableLayout == this.selectedTableLayout\r\n      && this.curretaTablePresetForUpdate.config.bodyTextFontsSize == this.bodyTextFontsSize\r\n      && this.curretaTablePresetForUpdate.config.rowShadingEnabled == this.rowShadingEnabled);\r\n\r\n    // return false\r\n  }\r\n\r\n  onActionButtonClick(button: string) {\r\n    const text = button?.toLocaleLowerCase();\r\n    if (text == 'active data' || text == 'active' || text == 'data active' || text == 'unarchived data' || text == 'unarchive data') this.clearSelectionState(this.tableType);\r\n    const event = {\r\n      data: {\r\n        listingType: this.listingType,\r\n        obj: button\r\n      },\r\n      eventType: \"onActionButtonClick\",\r\n    };\r\n    this.genericEvent.emit(event);\r\n  }\r\n\r\n\r\n  setActiveTab(tab: string | null): void {\r\n    this.activeTab = tab;\r\n    const allTabs = JSON.parse(localStorage.getItem('activeTabs') || '{}');\r\n    allTabs[this.tableType] = tab;\r\n    localStorage.setItem('activeTabs', JSON.stringify(allTabs));\r\n    this.cdr.detectChanges();\r\n    const event = {\r\n      data: {\r\n        tableType: this.tableType,\r\n        obj: tab\r\n      },\r\n      eventType: 'onTabChange',\r\n    };\r\n\r\n    this.genericEvent.emit(event);\r\n  }\r\n\r\n  getBackgroundColor(row: any, isEven: boolean, section: 'left' | 'center' | 'right'): string | undefined {\r\n    if (this.hoveredRowId === (row._id || row.id)) {\r\n      return this.rowHoverColor;\r\n    }\r\n    if (this.isRowSelected(row)) {\r\n      return this.checkedRowBackgroundColor;\r\n    }\r\n    let baseColor: string | undefined;\r\n\r\n    if (this.rowShadingEnabled) {\r\n      baseColor = isEven ? this.evenRowsBackgroundColor : this.oddRowsBackgroundColor;\r\n    } else {\r\n      baseColor = this.evenRowsBackgroundColor;\r\n    }\r\n    if (!baseColor) {\r\n      if (section === 'left') {\r\n        baseColor = this.leftPinnedBackgroundColor;\r\n      } else if (section === 'right') {\r\n        baseColor = this.rightPinnedBackgroundColor;\r\n      } else {\r\n        baseColor = this.bodyBackgroundColor;\r\n      }\r\n    }\r\n    return baseColor;\r\n  }\r\n\r\n  hasHorizontalScrollbar(): boolean {\r\n    if (!this.centerPinnedHeader?.nativeElement) return false;\r\n    const el = this.centerPinnedHeader.nativeElement;\r\n    return el.scrollWidth > el.clientWidth;\r\n  }\r\n\r\n\r\n  getSafeComment(description: string): SafeHtml {\r\n    return this.cleanEditorContent(description);\r\n  }\r\n  cleanEditorContent(content: string): SafeHtml {\r\n    if (!content) {\r\n      return '';\r\n    }\r\n    // 1. Decode HTML entities\r\n    const textarea = document.createElement('textarea');\r\n    textarea.innerHTML = content;\r\n    let decoded = textarea.value;\r\n\r\n    decoded = decoded\r\n      .replace(/<\\/?(span|p|thead|tbody|tfoot)[^>]*>/g, '')\r\n      .replace(/&nbsp;/g, ' ');\r\n\r\n    // Ensure clean table structure\r\n    decoded = decoded\r\n      .replace(/<table[^>]*>/g, '<table>')\r\n      .replace(/<tr[^>]*>/g, '<tr>')\r\n      .replace(/<th[^>]*>/g, '<th>')\r\n      .replace(/<td[^>]*>/g, '<td>');  // Remove <thead> and <tbody> tags\r\n\r\n    // 4. Add inline styles\r\n    decoded = decoded\r\n      // Add inline styles to <table>\r\n      .replace(/<table([^>]*)>/g, `<table style=\"width: 100%; border-collapse: collapse; padding: 20px; font-size: 14px; background-color: #ffffff;\"$1>`)\r\n      // Add inline styles to <tr>\r\n      .replace(/<tr([^>]*)>/g, `<tr style=\"border-bottom: 1px solid #ccc;\"$1>`)\r\n      // Add inline styles to <th>\r\n      .replace(/<th([^>]*)>/g, `<th style=\"background-color: #f0f0f0; font-weight: 600; font-size: 16px; color: #2A1F73; border: 1px solid #ccc; padding: 12px 20px; text-align: left;\"$1>`)\r\n      // Add inline styles to <td>\r\n      .replace(/<td([^>]*)>/g, `<td style=\"min-width:120px; border: 1px solid #ccc; padding: 12px 20px; text-align: left;\"$1>`);\r\n    decoded = decoded.replace(/<img([^>]*)>/g, (match, group1) => {\r\n      // Add style to <img> if not already specified\r\n      if (/style=/.test(group1)) {\r\n        return match;  // If style already exists, keep it\r\n      } else {\r\n        return `<img style=\"width: 30%; height: 30%;border-radius: 16px; padding-top: 15px;padding-bottom: 10px;\"${group1}>`;\r\n      }\r\n    });\r\n    // 5. Return safe HTML\r\n    return this.sanitizer.bypassSecurityTrustHtml(decoded);\r\n  }\r\n\r\n  getExtention(url: string | string[] | null | undefined) {\r\n    if (url !== '-') {\r\n      if (typeof (url) == 'string') {\r\n        return url.split('.').pop()\r\n      } else if (Array.isArray(url)) {\r\n        return url[0].split('.').pop()\r\n      } else return '-'\r\n    }\r\n    else return '-'\r\n  }\r\n\r\n  downloadAttchment(url: any, file?: any) {\r\n    // this.onEvent.emit({\r\n    //   download: true,\r\n    // });\r\n    // this.genericEvent.emit(data)\r\n    // event.preventDefault();\r\n    const link = document.createElement('a');\r\n    link.href = url;\r\n    link.download = '';\r\n    document.body.appendChild(link);\r\n    link.click();\r\n    document.body.removeChild(link);\r\n\r\n  }\r\n  fullImageSrc: string | null = '';\r\n  openFullImage(event: Event) {\r\n    const target = event.target as HTMLElement;\r\n    if (target.tagName === 'IMG') {\r\n      this.fullImageSrc = target.getAttribute('src');\r\n    }\r\n  }\r\n\r\n  addStylesToImages(): void {\r\n    const images = document.querySelectorAll('.comment-content img');\r\n    images.forEach((img) => {\r\n      // Apply inline styles directly\r\n      this.renderer.setStyle(img, 'width', '70px');\r\n      this.renderer.setStyle(img, 'border-radius', '16px');\r\n      this.renderer.setStyle(img, 'margin', '8px');\r\n      this.renderer.setStyle(img, 'cursor', 'pointer');\r\n\r\n      // Add click listener to show fullscreen image on click\r\n      this.renderer.listen(img, 'click', () => this.onImageClick((img as HTMLImageElement).src));\r\n    });\r\n  }\r\n\r\n  onImageClick(src: string): void {\r\n    this.fullscreenImage = src;\r\n  }\r\n\r\n  @ViewChild('fullscreenImageTemplate') fullscreenImageTemplate!: TemplateRef<any>;\r\n  private fullscreenViewRef: EmbeddedViewRef<any> | null = null;\r\n\r\n  iconMap: Record<string, (row: any, col: any) => string> = {\r\n    attachments_count: () => this.singleSpaAssetsPath + 'data-grid/icons/attachments.svg',\r\n    comment_count: () => this.singleSpaAssetsPath + 'data-grid/icons/comments.svg',\r\n    priority: (row, col) => {\r\n      const val =\r\n        this.getNestedValue(row, col.field)?.value ||\r\n        this.getNestedValue(row, col.field)?.name ||\r\n        this.getNestedValue(row, col.field);\r\n\r\n      return (\r\n        this.singleSpaAssetsPath +\r\n        'data-grid/icons/' +\r\n        (val ?? 'default') +\r\n        '.svg'\r\n      );\r\n    },\r\n  };\r\n\r\n  toggleFullscreen() {\r\n    this.isFullScreen = !this.isFullScreen;\r\n    const elem = document.documentElement as any;\r\n    if (!document.fullscreenElement) {\r\n      if (elem.requestFullscreen) {\r\n        elem.requestFullscreen();\r\n      } else if (elem.mozRequestFullScreen) {\r\n        elem.mozRequestFullScreen();\r\n      } else if (elem.webkitRequestFullscreen) {\r\n        elem.webkitRequestFullscreen();\r\n      } else if (elem.msRequestFullscreen) {\r\n        elem.msRequestFullscreen();\r\n      }\r\n    } else {\r\n      if (document.exitFullscreen) {\r\n        document.exitFullscreen();\r\n      } else if ((document as any).mozCancelFullScreen) {\r\n        (document as any).mozCancelFullScreen();\r\n      } else if ((document as any).webkitExitFullscreen) {\r\n        (document as any).webkitExitFullscreen();\r\n      } else if ((document as any).msExitFullscreen) {\r\n        (document as any).msExitFullscreen();\r\n      }\r\n    }\r\n  }\r\n\r\n  onCellEvent(event: any) {\r\n    this.customCellEvent.emit(event);\r\n  }\r\n\r\n  private flattenGroup(row: any): any[] {\r\n    const result: any[] = [];\r\n    const traverse = (node: any) => {\r\n      if (!node) return;\r\n      if (node.isGroup) {\r\n        node.children?.forEach((child: any) => traverse(child));\r\n      } else {\r\n        result.push(node);\r\n      }\r\n    };\r\n    traverse(row);\r\n    return result;\r\n  }\r\n\r\n  selectGroupRow(e: Event, row: any) {\r\n    const checkbox = e.target as HTMLInputElement;\r\n    const isChecked = checkbox.checked;\r\n    // Get all deep data rows (leaf rows)\r\n    const leafRows = this.flattenGroup(row);\r\n    if (isChecked) {\r\n      leafRows.forEach(r => {\r\n        const id = r._id || r.id;\r\n        if (id) this.selectedRows.add(id);\r\n      });\r\n    } else {\r\n      leafRows.forEach(r => {\r\n        const id = r._id || r.id;\r\n        if (id) this.selectedRows.delete(id);\r\n      });\r\n    }\r\n    const ids = Array.from(this.selectedRows);\r\n    const event = {\r\n      data: {\r\n        listingType: this.listingType,\r\n        obj: ids\r\n      },\r\n      eventType: \"onSelectRow\",\r\n    }\r\n    this.genericEvent.emit(event);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  getGroupCheckedState(row: any): boolean | undefined {\r\n    if (!row.isGroup) return false;\r\n    const leafRows = this.flattenGroup(row);\r\n    let checkedCount = 0;\r\n    leafRows.forEach(r => {\r\n      const id = r._id || r.id;\r\n      if (this.selectedRows.has(id)) checkedCount++;\r\n    });\r\n    if (checkedCount === 0) return false;\r\n    if (checkedCount === leafRows.length) return true;\r\n    return undefined;\r\n  }\r\n\r\n  getCellTitle(row: any, col: any): string {\r\n    const val = this.getNestedValue(row, col.field);\r\n\r\n    if (!this.isNestedValueArray(row, col.field)) {\r\n      if (col.type === 'date') {\r\n        return this.commonSevice.formatDateValue(val, this.dateFormat);\r\n      } else if (col?.is_amount) {\r\n        if(!val) return `0.00`\r\n        return this.formatCurrency.transform(val, this.currencyFormat);\r\n      }\r\n\r\n      return (\r\n        val?.value ??\r\n        val?.name ??\r\n        val ??\r\n        (col.is_amount ? '0' : '-')\r\n      ) + '';\r\n    }\r\n\r\n    const first = val?.[0];\r\n\r\n    return (\r\n      first?.department_name ??\r\n      first?.roleName ??\r\n      first?.full_name ??\r\n      '-'\r\n    );\r\n  }\r\n\r\n\r\n  finishEdit(event: any) {\r\n    console.log('cell editeddddddddddddddd: ', event)\r\n  }\r\n\r\n\r\n\r\n}","<div class=\"position-relative h-100\">\r\n  <div\r\n    class=\"d-flex justify-content-between mb-2 align-items-center position-relative\"\r\n  >\r\n    <div class=\"d-flex gap-2\">\r\n      <div class=\"nav nav-tabs\" *ngIf=\"true\">\r\n        <div class=\"nav nav-tabs\" id=\"nav-tab\" role=\"tablist\">\r\n          <span\r\n            *ngFor=\"let tab of tabs; let i = index\"\r\n            (click)=\"setActiveTab(tab)\"\r\n            class=\"nav-link cursor-pointer\"\r\n            [class.active]=\"activeTab == tab\"\r\n          >\r\n            {{ tab }}\r\n          </span>\r\n        </div>\r\n      </div>\r\n      <div class=\"global-search\" [style.width.px]=\"350\">\r\n        <span\r\n          *ngIf=\"enableGlobalSearch\"\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/search.svg'\"\r\n          class=\"data-grid-svg-icon mx-2 position-absolute icon\"\r\n        ></span>\r\n        <input\r\n          *ngIf=\"enableGlobalSearch\"\r\n          style=\"height: 36px\"\r\n          class=\"form-control\"\r\n          placeholder=\"Type to search, then press Enter\"\r\n          [(ngModel)]=\"tableSearch\"\r\n          (keydown.enter)=\"onGlobalSearch()\"\r\n          (input)=\"onSearchInput($event)\"\r\n          type=\"search\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div class=\"d-flex gap-2 align-items-center table-right-top-actions\">\r\n      <ng-container *ngFor=\"let button of buttons\">\r\n        <div\r\n          class=\"d-flex align-items-center gap-2 action-buttons-row\"\r\n          *ngIf=\"button?.has_permission\"\r\n        >\r\n          <a\r\n            href=\"JavaScript:void(0)\"\r\n            (click)=\"onActionButtonClick(button.name)\"\r\n            class=\"button button-small btn border border-primary btn-active-primary me-2 p-0 d-flex align-items-center justify-content-center px-3\"\r\n          >\r\n            <span\r\n              *ngIf=\"button.is_showIcon\"\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath + 'data-grid/icons/' + button.icon + '.svg'\r\n              \"\r\n              class=\"svg-icon svg-icon-2\"\r\n            ></span>\r\n            <span\r\n              class=\"label-hidden text-white\"\r\n              [class.ms-0]=\"button.is_showIcon\"\r\n              >{{ button?.name }}</span\r\n            >\r\n          </a>\r\n        </div>\r\n      </ng-container>\r\n      <div\r\n        *ngIf=\"!showFilterRow\"\r\n        class=\"cursor-pointer position-relative action-buttons-row\"\r\n        (click)=\"toggleOpenFilter()\"\r\n        [class.active]=\"showFilters\"\r\n      >\r\n        <a\r\n          href=\"JavaScript:void(0)\"\r\n          class=\"button button-small btn btn-active-primary border border-primary me-2 p-0 d-flex align-items-center justify-content-center px-3\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\"\r\n            class=\"svg-icon svg-icon-2\"\r\n          ></span>\r\n          <span class=\"label-hidden text-white\">Filters</span>\r\n        </a>\r\n        <span\r\n          *ngIf=\"activeFilteredColumns?.length\"\r\n          style=\"\r\n            width: 7px;\r\n            height: 7px;\r\n            box-shadow: 0px 0px 3px #0022ff;\r\n            background-color: rgb(0, 60, 255);\r\n            position: absolute;\r\n            right: 16px;\r\n            top: 10px;\r\n          \"\r\n          class=\"rounded-circle d-block\"\r\n        ></span>\r\n      </div>\r\n      <div\r\n        class=\"cursor-pointer d-none\"\r\n        (click)=\"toggleActions('advance-filter')\"\r\n        [class.active]=\"activeTopButton === 'advance-filter'\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/zoom-charge.svg'\"\r\n          class=\"data-grid-svg-icon top-icon me-2\"\r\n        ></span>\r\n      </div>\r\n      <div\r\n        class=\"cursor-pointer action-buttons-row\"\r\n        (click)=\"toggleActions('setting')\"\r\n        [class.active]=\"\r\n          activeTopButton === 'setting' ||\r\n          activeTopButton === 'table-layout' ||\r\n          activeTopButton === 'table-presets' ||\r\n          activeTopButton === 'show-hide-columns'\r\n        \"\r\n      >\r\n        <!-- <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/settings-2.svg'\"\r\n          class=\"data-grid-svg-icon top-icon me-2\"\r\n        ></span> -->\r\n        <a\r\n          href=\"JavaScript:void(0)\"\r\n          class=\"button button-small btn btn-active-primary border border-primary me-2 p-0 d-flex align-items-center justify-content-center px-3\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/settings-2.svg'\"\r\n            class=\"svg-icon svg-icon-2\"\r\n          ></span>\r\n          <span class=\"label-hidden text-white\">Setting</span>\r\n        </a>\r\n\r\n        <div\r\n          *ngIf=\"activeTopButton === 'setting'\"\r\n          class=\"actions-dropdown mt-1 actions-dropdown-setting\"\r\n          style=\"position: absolute\"\r\n        >\r\n          <div class=\"dropdown-menu show shadow custom-menu\">\r\n            <!-- Table Layout -->\r\n            <a\r\n              class=\"dropdown-item d-flex justify-content-between align-items-center cursor-pointer\"\r\n              (click)=\"$event.stopPropagation(); toggleActions('table-layout')\"\r\n            >\r\n              <span\r\n                ><span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/table-2.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon me-2\"\r\n                ></span>\r\n                Table Layout</span\r\n              >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2\"\r\n              ></span>\r\n            </a>\r\n            <!-- Table Presets -->\r\n            <a\r\n              (click)=\"$event.stopPropagation(); toggleActions('table-presets')\"\r\n              class=\"dropdown-item d-flex justify-content-between align-items-center cursor-pointer\"\r\n            >\r\n              <span\r\n                ><span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/list-details.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon me-2\"\r\n                ></span>\r\n                Table Presets</span\r\n              >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2\"\r\n              ></span>\r\n            </a>\r\n\r\n            <!-- Columns -->\r\n            <a\r\n              *ngIf=\"!showSideMenu\"\r\n              (click)=\"\r\n                $event.stopPropagation(); toggleActions('show-hide-columns')\r\n              \"\r\n              class=\"dropdown-item d-flex justify-content-between align-items-center cursor-pointer\"\r\n            >\r\n              <span\r\n                ><span\r\n                  [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/eye.svg'\"\r\n                  class=\"data-grid-svg-icon me-2\"\r\n                ></span>\r\n                Columns</span\r\n              >\r\n              <div class=\"d-flex gap-2\">\r\n                <span class=\"muted-text\">{{ columnsCount }}</span>\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon me-2\"\r\n                ></span>\r\n              </div>\r\n            </a>\r\n\r\n            <div class=\"dropdown-divider\"></div>\r\n\r\n            <!-- Filter -->\r\n            <a\r\n              class=\"dropdown-item cursor-pointer\"\r\n              (click)=\"toggleOpenFilter(); activeTopButton = '';\"\r\n              *ngIf=\"!showFilterRow\"\r\n            >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2 mt-1 cursor-pointer\"\r\n              ></span>\r\n              Filter\r\n            </a>\r\n\r\n            <!-- Download -->\r\n            <a\r\n              class=\"dropdown-item cursor-pointer\"\r\n              (click)=\"downloadCsv('csv')\"\r\n            >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/download.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2 cursor-pointer\"\r\n              ></span>\r\n              CSV Export\r\n            </a>\r\n            <a\r\n              *ngIf=\"enableExport\"\r\n              class=\"dropdown-item cursor-pointer\"\r\n              (click)=\"downloadCsv('xlsx')\"\r\n            >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/download.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2 cursor-pointer\"\r\n              ></span>\r\n              Excel Export\r\n            </a>\r\n            <!-- Font Family & Font Size -->\r\n            <div class=\"px-2 pb-2 pt-2\">\r\n              <div class=\"d-flex gap-2\">\r\n                <!-- Font Family -->\r\n                <select\r\n                  class=\"form-select form-select-sm\"\r\n                  [(ngModel)]=\"fontFaimly\"\r\n                  (change)=\"onFontChange()\"\r\n                >\r\n                  <option *ngFor=\"let font of fontFamilies\" [value]=\"font\">\r\n                    {{ font }}\r\n                  </option>\r\n                </select>\r\n\r\n                <!-- Font Size -->\r\n                <select\r\n                  class=\"form-select form-select-sm\"\r\n                  (change)=\"onFontChange()\"\r\n                  [(ngModel)]=\"bodyTextFontsSize\"\r\n                >\r\n                  <option *ngFor=\"let size of fontSizes\" [value]=\"size\">\r\n                    {{ size }}\r\n                  </option>\r\n                </select>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Table Layout -->\r\n\r\n        <ng-container *ngIf=\"activeTopButton === 'table-layout'\">\r\n          <div\r\n            *ngTemplateOutlet=\"tableLayout\"\r\n            class=\"actions-dropdown mt-1\"\r\n            style=\"position: absolute\"\r\n          ></div>\r\n        </ng-container>\r\n\r\n        <!-- Table Presets -->\r\n        <ng-container *ngIf=\"activeTopButton === 'table-presets'\">\r\n          <div\r\n            *ngTemplateOutlet=\"tablePreset\"\r\n            class=\"actions-dropdown mt-1\"\r\n            style=\"position: absolute\"\r\n          ></div>\r\n        </ng-container>\r\n\r\n        <!-- Table Presets -->\r\n        <ng-container *ngIf=\"activeTopButton === 'show-hide-columns'\">\r\n          <div\r\n            *ngTemplateOutlet=\"showHideColumns\"\r\n            class=\"actions-dropdown mt-1\"\r\n            style=\"position: absolute\"\r\n          ></div>\r\n        </ng-container>\r\n      </div>\r\n\r\n      <div class=\"action-buttons-row\" *ngIf=\"showFullScreenButton\">\r\n        <a\r\n          *ngIf=\"!isFullScreen\"\r\n          class=\"button button-small btn btn-active-primary border border-primary expend d-flex justify-content-center align-items-center\"\r\n          (click)=\"toggleFullscreen()\"\r\n          data-bs-toggle=\"tooltip\"\r\n          data-bs-placement=\"top\"\r\n          title=\"Minimise\"\r\n          [ngClass]=\"{ minArrow: !isFullScreen, maxArrow: isFullScreen }\"\r\n          style=\"transition: color 0.2s\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/expend.svg'\"\r\n            class=\"svg-icon svg-icon-2 mb-1\"\r\n          ></span>\r\n        </a>\r\n        <a\r\n          *ngIf=\"isFullScreen\"\r\n          class=\"button button-small btn btn-active-primary border border-primary expend d-flex justify-content-center align-items-center\"\r\n          (click)=\"toggleFullscreen()\"\r\n          data-bs-toggle=\"tooltip\"\r\n          data-bs-placement=\"top\"\r\n          title=\"Maximise\"\r\n          [ngClass]=\"{ minArrow: !isFullScreen, maxArrow: isFullScreen }\"\r\n          style=\"transition: color 0.2s\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/minimize.svg'\"\r\n            class=\"svg-icon svg-icon-2 mb-1\"\r\n          ></span>\r\n        </a>\r\n      </div>\r\n      <div>\r\n        <!-- Example single danger button -->\r\n\r\n        <!-- <button\r\n          type=\"button\"\r\n          class=\"btn btn-primary btn-sm d-flex gap-2 action-button\"\r\n          (click)=\"toggleActions('actions')\"\r\n        >\r\n          Action\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/Vector.svg'\"\r\n            class=\"data-grid-svg-icon\"\r\n          ></span>\r\n        </button>\r\n        <div\r\n          *ngIf=\"activeTopButton === 'actions'\"\r\n          class=\"actions-dropdown mt-1\"\r\n        >\r\n          <div class=\"dropdown-menu show\">\r\n            <a class=\"dropdown-item\" href=\"#\">Action</a>\r\n            <a class=\"dropdown-item\" href=\"#\">Another action</a>\r\n            <a class=\"dropdown-item\" href=\"#\">Something else here</a>\r\n            <div class=\"dropdown-divider\"></div>\r\n            <a class=\"dropdown-item\" href=\"#\">Separated link</a>\r\n          </div>\r\n        </div> -->\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div\r\n    *ngIf=\"showFilters && !showFilterRow\"\r\n    class=\"top-filter-row border-top py-2 d-flex justify-content-between align-items-center\"\r\n    [style.height.px]=\"topFilterRowHeight\"\r\n  >\r\n    <!-- LEFT SIDE (Filter tags + Filter button) -->\r\n    <div class=\"d-flex gap-2 align-items-center\">\r\n      <ng-container>\r\n        <div\r\n          *ngFor=\"let col of activeFilteredColumns; trackBy: trackByField\"\r\n          class=\"filter-tags\"\r\n        >\r\n          <div\r\n            (click)=\"\r\n              isActiveFilterOpen = true;\r\n              activeTopButton = 'filter-columns';\r\n              openFilter(col)\r\n            \"\r\n            class=\"d-flex justify-content-center align-items-center muted-text add-filter-button active-filters\"\r\n            style=\"white-space: nowrap\"\r\n            [class.active]=\"\r\n              col?.field == selectedColumnForFilter?.field &&\r\n              isActiveFilterOpen &&\r\n              activeTopButton == 'filter-columns'\r\n            \"\r\n          >\r\n            <span class=\"header-tag mt-0 d-flex align-items-center\">\r\n              <span\r\n                *ngIf=\"col?.pinned\"\r\n                [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/pin.svg'\"\r\n                class=\"data-grid-svg-icon me-2\"\r\n              ></span>\r\n              {{ col.header }}\r\n              <span\r\n                (click)=\"\r\n                  $event.stopPropagation(); removeColumnFilterFromColumn(col)\r\n                \"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/cross-primary.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon cross-secondary ms-2 mb-1\"\r\n              ></span>\r\n            </span>\r\n          </div>\r\n\r\n          <ng-container\r\n            *ngIf=\"\r\n              activeTopButton === 'filter-columns' &&\r\n              col?.field == selectedColumnForFilter?.field &&\r\n              isActiveFilterOpen\r\n            \"\r\n          >\r\n            <div\r\n              *ngTemplateOutlet=\"filterColumns; context: { column: col }\"\r\n              class=\"actions-dropdown mt-1\"\r\n            ></div>\r\n          </ng-container>\r\n        </div>\r\n      </ng-container>\r\n\r\n      <!-- Filter Button -->\r\n      <div class=\"add-filter-button-menu\">\r\n        <div\r\n          (click)=\"toggleActions('filter-columns'); isActiveFilterOpen = false\"\r\n          class=\"d-flex justify-content-center align-items-center muted-text add-filter-button button-filter\"\r\n          style=\"width: 70px\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/plus.svg'\"\r\n            class=\"me-2 data-grid-svg-icon\"\r\n          ></span>\r\n          Filter\r\n        </div>\r\n\r\n        <ng-container\r\n          *ngIf=\"activeTopButton === 'filter-columns' && !isActiveFilterOpen\"\r\n        >\r\n          <div\r\n            *ngTemplateOutlet=\"filterColumns\"\r\n            class=\"actions-dropdown mt-1\"\r\n          ></div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- RIGHT SIDE (Update + Reset) -->\r\n    <div class=\"d-flex gap-3 align-items-center\">\r\n      <div\r\n        (click)=\"savePreset()\"\r\n        class=\"text-primary cursor-pointer all-filters-reset-button\"\r\n        *ngIf=\"!checkFilterChangesEffect()\"\r\n      >\r\n        Update View\r\n      </div>\r\n\r\n      <div\r\n        class=\"text-primary cursor-pointer all-filters-reset-button\"\r\n        *ngIf=\"!tableFilterViewId && activeFilteredColumns?.length\"\r\n        (click)=\"clearAllFilters()\"\r\n      >\r\n        Reset\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div\r\n    [style.height]=\"\r\n      showFilters ? 'calc(100% - ' + topFilterRowHeight + 'px)' : '100%'\r\n    \"\r\n    cdkDropListGroup\r\n    class=\"data-grid-table-wrapper overflow-hidden\"\r\n    #dataGridContainer\r\n    [style.fontFamily]=\"fontFaimly\"\r\n    [style.backgroundColor]=\"bodyBackgroundColor\"\r\n    id=\"data-grid-main-container\"\r\n  >\r\n    <div\r\n      *ngIf=\"showRowsGrouping\"\r\n      [style.height.px]=\"headerRowHeight\"\r\n      [cdkDropListData]=\"columns\"\r\n      [style.backgroundColor]=\"\r\n        topGroupedBadgesBackgroundColor || headerBackgroundColor\r\n      \"\r\n      cdkDropList\r\n      (cdkDropListEntered)=\"enterToTopRowGrouping($event)\"\r\n      (cdkDropListExited)=\"exitedFromTheTopRow($event)\"\r\n      (cdkDropListDropped)=\"onDropTopGroup($event)\"\r\n      [cdkDropListEnterPredicate]=\"canEnterToRowsGrouping\"\r\n      id=\"rows-grouping-top-container\"\r\n      class=\"border-below d-flex px-4 align-items-center\"\r\n    >\r\n      <div\r\n        class=\"d-flex gap-2 align-items-center\"\r\n        [style.color]=\"headerTextColor\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/justify.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span>\r\n        <div *ngIf=\"!draggingInGroupArea && !groupedColumns?.length\">\r\n          Drag here to set row groups\r\n        </div>\r\n        <div\r\n          cdkDropListOrientation=\"horizontal\"\r\n          cdkDropList\r\n          (cdkDropListDropped)=\"onGroupReorder($event)\"\r\n          class=\"d-flex\"\r\n        >\r\n          <div\r\n            cdkDrag\r\n            [cdkDragLockAxis]=\"'x'\"\r\n            *ngFor=\"\r\n              let child of groupedColumns;\r\n              let i = index;\r\n              trackBy: trackByField\r\n            \"\r\n            class=\"d-flex align-items-center\"\r\n          >\r\n            <ng-container\r\n              *ngTemplateOutlet=\"\r\n                topGroupingRowPlaceholder;\r\n                context: {\r\n                  $implicit: child,\r\n                  showChevron:\r\n                    groupedColumns.length > 1 && i != groupedColumns.length - 1\r\n                }\r\n              \"\r\n            ></ng-container>\r\n            <ng-template cdkDragPreview\r\n              ><div class=\"p-2 border d-flex gap-2\">\r\n                <div>\r\n                  <span\r\n                    *ngIf=\"!draggingInGroupArea\"\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/arrows-move.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n                <div>{{ child.header }}</div>\r\n              </div>\r\n            </ng-template>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div\r\n      class=\"d-flex overflow-hidden\"\r\n      [style.height]=\"\r\n        'calc(100% - ' +\r\n        (showRowsGrouping\r\n          ? headerRowHeight + footerRowHeight\r\n          : footerRowHeight) +\r\n        'px)'\r\n      \"\r\n    >\r\n      <div\r\n        class=\"h-100\"\r\n        [style.width]=\"\r\n          !showSideMenu\r\n            ? '100%'\r\n            : sideMenuVisible\r\n            ? 'calc(100% - 280px)'\r\n            : 'calc(100% - 30px)'\r\n        \"\r\n      >\r\n        <div class=\"h-100 transition position-relative w-100\">\r\n          <!-- ##################################################################################################################################################################################### -->\r\n          <!-- ##################################################################################################################################################################################### -->\r\n          <!-- Data Grid Header starts here -->\r\n          <!-- ##################################################################################################################################################################################### -->\r\n          <!-- ##################################################################################################################################################################################### -->\r\n\r\n          <div\r\n            class=\"data-grid-header-wrapper w-100\"\r\n            [style.color]=\"headerTextColor\"\r\n            [style.fontSize.px]=\"headerTextFontsSize\"\r\n            [style.backgroundColor]=\"headerBackgroundColor\"\r\n            [class.border-below]=\"!hasAnyVisibleColumn\"\r\n            [style.height.px]=\"\r\n              showColumnsGrouping && showFilterRow\r\n                ? headerRowHeight * 3\r\n                : showColumnsGrouping || showFilterRow\r\n                ? headerRowHeight * 2\r\n                : headerRowHeight\r\n            \"\r\n          >\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- Data Grid Left Pinned Header starts here -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <div\r\n              class=\"data-grid-header left-pinned\"\r\n              #leftPinnedHeader\r\n              [class.border-right]=\"hasLeftPinnedColumns\"\r\n            >\r\n              <div\r\n                *ngIf=\"showSerialNumber\"\r\n                [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n                class=\"select-all-checkbox-cell border-below\"\r\n                [style.width.px]=\"55\"\r\n                [style.height.px]=\"\r\n                  showColumnsGrouping && showFilterRow\r\n                    ? headerRowHeight * 3\r\n                    : showColumnsGrouping || showFilterRow\r\n                    ? headerRowHeight * 2\r\n                    : headerRowHeight\r\n                \"\r\n              >\r\n                S.No\r\n              </div>\r\n              <div\r\n               *ngIf=\"showCheckboxes\"\r\n                [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n                class=\"select-all-checkbox-cell border-below\"\r\n                [style.height.px]=\"\r\n                  showColumnsGrouping && showFilterRow\r\n                    ? headerRowHeight * 3\r\n                    : showColumnsGrouping || showFilterRow\r\n                    ? headerRowHeight * 2\r\n                    : headerRowHeight\r\n                \"\r\n              >\r\n                <input\r\n                  *ngIf=\"hasAnyVisibleColumn\"\r\n                  style=\"width: 16px; height: 16px\"\r\n                  type=\"checkbox\"\r\n                  [indeterminate]=\"isIndeterminateState(dataSet)\"\r\n                  [checked]=\"isAllSelected(dataSet)\"\r\n                  (change)=\"toggleSelectAll(dataSet)\"\r\n                />\r\n              </div>\r\n              <div\r\n                [style.backgroundColor]=\"headerBackgroundColor\"\r\n                class=\"d-flex\"\r\n                cdkDropList\r\n                id=\"left-pinned-header\"\r\n                cdkDropListOrientation=\"horizontal\"\r\n                [cdkDropListData]=\"leftPinnedColumns\"\r\n                (cdkDropListEntered)=\"onDropListEnter($event, 'left')\"\r\n                (cdkDropListSorted)=\"\r\n                  onSortGroup($event, 'previewLeftPinnedColumns')\r\n                \"\r\n                (cdkDropListDropped)=\"onDropGroup()\"\r\n                style=\"min-width: 1px\"\r\n              >\r\n                <div\r\n                  class=\"dragable-header\"\r\n                  cdkDrag\r\n                  [cdkDragData]=\"col\"\r\n                  *ngFor=\"\r\n                    let col of leftPinnedColumns;\r\n                    let i = index;\r\n                    trackBy: trackByField\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      headerCell;\r\n                      context: {\r\n                        $implicit: col,\r\n                        index: i,\r\n                        section: 'previewLeftPinnedColumns'\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                  <ng-template cdkDragPreview\r\n                    ><div class=\"p-2 border d-flex gap-2\">\r\n                      <div>\r\n                        <span\r\n                          *ngIf=\"!draggingInGroupArea\"\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath +\r\n                            'data-grid/icons/arrows-move.svg'\r\n                          \"\r\n                          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                        ></span>\r\n                      </div>\r\n                      <div>{{ col.header }}</div>\r\n                    </div>\r\n                  </ng-template>\r\n                  <ng-template cdkDragPlaceholder>\r\n                    <div *ngIf=\"!draggingInGroupArea\">\r\n                      <div\r\n                        *ngTemplateOutlet=\"\r\n                          headerCell;\r\n                          context: {\r\n                            $implicit: col,\r\n                            index: i,\r\n                            section: ''\r\n                          }\r\n                        \"\r\n                      ></div>\r\n                    </div>\r\n                    <div\r\n                      *ngIf=\"draggingInGroupArea\"\r\n                      class=\"d-flex gap-2 ms-2\"\r\n                      style=\"opacity: 0.6\"\r\n                    >\r\n                      <ng-container\r\n                        *ngIf=\"col?.children?.length; else singleCol\"\r\n                      >\r\n                        <ng-container\r\n                          *ngFor=\"\r\n                            let child of col.children;\r\n                            let i = index;\r\n                            trackBy: trackByField\r\n                          \"\r\n                        >\r\n                          <ng-container\r\n                            *ngTemplateOutlet=\"\r\n                              topGroupingRowPlaceholder;\r\n                              context: {\r\n                                $implicit: child,\r\n                                showChevron:\r\n                                  col.children.length > 1 &&\r\n                                  i != col.children.length - 1\r\n                              }\r\n                            \"\r\n                          ></ng-container>\r\n                        </ng-container>\r\n                      </ng-container>\r\n\r\n                      <ng-template #singleCol>\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"\r\n                            topGroupingRowPlaceholder;\r\n                            context: {\r\n                              $implicit: col,\r\n                              showChevron: col?.children?.length > 1\r\n                            }\r\n                          \"\r\n                        ></ng-container>\r\n                      </ng-template>\r\n                    </div>\r\n                  </ng-template>\r\n                </div>\r\n              </div>\r\n            </div>\r\n\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- Data Grid Center Pinned Header starts here -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <div\r\n              class=\"data-grid-header center-scrollable\"\r\n              #centerPinnedHeader\r\n              (scroll)=\"onCenterBodyScroll($event)\"\r\n              id=\"center-pinned-header\"\r\n              cdkDropList\r\n              [cdkDropListConnectedTo]=\"\r\n                showRowsGrouping ? ['rows-grouping-top-container'] : []\r\n              \"\r\n              [cdkDropListData]=\"centerColumns\"\r\n              cdkDropListOrientation=\"horizontal\"\r\n              [cdkDropListSortingDisabled]=\"\r\n                isDisableColumnGrouping && draggingInGroupArea\r\n              \"\r\n              (cdkDropListEntered)=\"onDropListEnter($event, 'center')\"\r\n              (cdkDropListSorted)=\"onSortGroup($event, 'previewCenterColumns')\"\r\n              (cdkDropListDropped)=\"onDropGroup()\"\r\n              [style.maxWidth]=\"\r\n                'calc(100% - ' +\r\n                (rightPinnedHeader.offsetWidth + leftPinnedHeader.offsetWidth) +\r\n                'px)'\r\n              \"\r\n            >\r\n              <div\r\n                *ngIf=\"groupedColumns?.length\"\r\n                style=\"min-width: 200px\"\r\n                class=\"h-100 align-items-center\"\r\n                #columnsGroupedBox\r\n                id=\"groupBoxHeaderDiv\"\r\n              >\r\n                <div\r\n                  class=\"d-flex w-100 justify-content-between align-items-center border-below\"\r\n                  [style.height.px]=\"\r\n                    showFilterRow ? headerRowHeight * 2 : headerRowHeight\r\n                  \"\r\n                >\r\n                  <div class=\"ps-3\">Group</div>\r\n                  <div class=\"d-flex\">\r\n                    <div\r\n                      class=\"three-dots cursor-pointer\"\r\n                      (click)=\"\r\n                        openThreeDotsMenu($event, 'group');\r\n                        isThreeDotsFilterOpen = false\r\n                      \"\r\n                    >\r\n                      <span\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath +\r\n                          'data-grid/icons/three-dots-vertical.svg'\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      ></span>\r\n                    </div>\r\n                    <div\r\n                      (mousedown)=\"\r\n                        $event.stopPropagation(); onResizeGroupBox($event)\r\n                      \"\r\n                      class=\"resize-handle\"\r\n                      style=\"margin-right: -2px\"\r\n                    >\r\n                      <span\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath +\r\n                          'data-grid/icons/resize-handle.svg'\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      ></span>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <div\r\n                  [style.height.px]=\"headerRowHeight\"\r\n                  class=\"border-below\"\r\n                ></div>\r\n              </div>\r\n              <span\r\n                class=\"d-flex align-items-center justify-content-center cursor-pointer border-below\"\r\n                style=\"min-width: 30px; height: 100%\"\r\n                *ngIf=\"gridType === 'Assets' || gridType === 'Tasks'\"\r\n              >\r\n              </span>\r\n              <div\r\n                class=\"dragable-header\"\r\n                (cdkDragStarted)=\"\r\n                  checkColumnGroupingStatus(col);\r\n                  dragStartOnGroup(col);\r\n                  onDragStarted(col)\r\n                \"\r\n                (cdkDragMoved)=\"onDragMoved($event)\"\r\n                (cdkDragEnded)=\"onDragEnded()\"\r\n                cdkDrag\r\n                [cdkDragData]=\"col\"\r\n                *ngFor=\"\r\n                  let col of centerColumns;\r\n                  let i = index;\r\n                  trackBy: trackById\r\n                \"\r\n              >\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    headerCell;\r\n                    context: {\r\n                      $implicit: col,\r\n                      index: i,\r\n                      section: 'previewCenterColumns'\r\n                    }\r\n                  \"\r\n                >\r\n                </ng-container>\r\n                <ng-template cdkDragPreview\r\n                  ><div class=\"p-2 border d-flex gap-2\">\r\n                    <div>\r\n                      <span\r\n                        *ngIf=\"!isOutsideContainer\"\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath +\r\n                          (draggingInGroupArea\r\n                            ? 'data-grid/icons/justify.svg'\r\n                            : 'data-grid/icons/arrows-move.svg')\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      >\r\n                      </span>\r\n                      <span\r\n                        *ngIf=\"isOutsideContainer\"\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath + 'data-grid/icons/eye-cross.svg'\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      >\r\n                      </span>\r\n                    </div>\r\n                    <div>{{ col.header }}</div>\r\n                  </div>\r\n                </ng-template>\r\n                <ng-template cdkDragPlaceholder>\r\n                  <div *ngIf=\"!draggingInGroupArea\">\r\n                    <div\r\n                      *ngTemplateOutlet=\"\r\n                        headerCell;\r\n                        context: {\r\n                          $implicit: col,\r\n                          index: i,\r\n                          section: 'centerColumns'\r\n                        }\r\n                      \"\r\n                    ></div>\r\n                  </div>\r\n                  <div\r\n                    *ngIf=\"draggingInGroupArea && !isOutsideContainer\"\r\n                    class=\"d-flex gap-2 ms-2\"\r\n                    style=\"opacity: 0.6\"\r\n                  >\r\n                    <ng-container *ngIf=\"col?.children?.length; else singleCol\">\r\n                      <ng-container\r\n                        *ngFor=\"\r\n                          let child of col.children;\r\n                          let i = index;\r\n                          trackBy: trackById\r\n                        \"\r\n                      >\r\n                        <ng-container *ngIf=\"child?.is_groupable\">\r\n                          <ng-container\r\n                            *ngTemplateOutlet=\"\r\n                              topGroupingRowPlaceholder;\r\n                              context: {\r\n                                $implicit: child,\r\n                                showChevron:\r\n                                  col.children.length > 1 &&\r\n                                  i != col.children.length - 1\r\n                              }\r\n                            \"\r\n                          ></ng-container>\r\n                        </ng-container>\r\n                      </ng-container>\r\n                    </ng-container>\r\n\r\n                    <ng-template #singleCol>\r\n                      <ng-container *ngIf=\"col?.is_groupable\">\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"\r\n                            topGroupingRowPlaceholder;\r\n                            context: {\r\n                              $implicit: col,\r\n                              showChevron: col?.children?.length > 1\r\n                            }\r\n                          \"\r\n                        ></ng-container>\r\n                      </ng-container>\r\n                    </ng-template>\r\n                  </div>\r\n                </ng-template>\r\n              </div>\r\n            </div>\r\n\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- Data Grid Right Pinned Header starts here -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <div\r\n              [style.backgroundColor]=\"headerBackgroundColor\"\r\n              cdkDropList\r\n              id=\"right-pinned-header\"\r\n              [cdkDropListConnectedTo]=\"\r\n                showRowsGrouping ? ['rows-grouping-top-container'] : []\r\n              \"\r\n              cdkDropListOrientation=\"horizontal\"\r\n              class=\"data-grid-header right-pinned\"\r\n              (cdkDropListSorted)=\"\r\n                onSortGroup($event, 'previewRightPinnedColumns')\r\n              \"\r\n              (cdkDropListEntered)=\"onDropListEnter($event, 'right')\"\r\n              (cdkDropListDropped)=\"onDropGroup()\"\r\n              #rightPinnedHeader\r\n              class=\"right-pinned-header d-flex\"\r\n              style=\"min-width: 0.2px\"\r\n            >\r\n              <div\r\n                class=\"dragable-header\"\r\n                cdkDrag\r\n                [cdkDragData]=\"col\"\r\n                *ngFor=\"\r\n                  let col of rightPinnedColumns;\r\n                  let i = index;\r\n                  trackBy: trackById\r\n                \"\r\n              >\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    headerCell;\r\n                    context: {\r\n                      $implicit: col,\r\n                      pinnedRight: true,\r\n                      index: i,\r\n                      section: 'right'\r\n                    }\r\n                  \"\r\n                ></ng-container>\r\n                <ng-template cdkDragPreview\r\n                  ><div class=\"p-2 border d-flex gap-2\">\r\n                    <div>\r\n                      <span\r\n                        *ngIf=\"!draggingInGroupArea\"\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath +\r\n                          'data-grid/icons/arrows-move.svg'\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      ></span>\r\n                    </div>\r\n                    <div>{{ col.header }}</div>\r\n                  </div>\r\n                </ng-template>\r\n                <ng-template cdkDragPlaceholder>\r\n                  <div *ngIf=\"!draggingInGroupArea\">\r\n                    <div\r\n                      *ngTemplateOutlet=\"\r\n                        headerCell;\r\n                        context: {\r\n                          $implicit: col,\r\n                          index: i,\r\n                          section: 'right'\r\n                        }\r\n                      \"\r\n                    ></div>\r\n                  </div>\r\n                  <div\r\n                    *ngIf=\"draggingInGroupArea\"\r\n                    class=\"d-flex gap-2 ms-2\"\r\n                    style=\"opacity: 0.6\"\r\n                  >\r\n                    <ng-container *ngIf=\"col?.children?.length; else singleCol\">\r\n                      <ng-container\r\n                        *ngFor=\"\r\n                          let child of col.children;\r\n                          let i = index;\r\n                          trackBy: trackById\r\n                        \"\r\n                      >\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"\r\n                            topGroupingRowPlaceholder;\r\n                            context: {\r\n                              $implicit: child,\r\n                              showChevron:\r\n                                col.children.length > 1 &&\r\n                                i != col.children.length - 1\r\n                            }\r\n                          \"\r\n                        ></ng-container>\r\n                      </ng-container>\r\n                    </ng-container>\r\n\r\n                    <ng-template #singleCol>\r\n                      <ng-container\r\n                        *ngTemplateOutlet=\"\r\n                          topGroupingRowPlaceholder;\r\n                          context: {\r\n                            $implicit: col,\r\n                            showChevron: col?.children?.length > 1\r\n                          }\r\n                        \"\r\n                      ></ng-container>\r\n                    </ng-template>\r\n                  </div>\r\n                </ng-template>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <!--########################################################################################################################################################################################################################### -->\r\n          <!--########################################################################################################################################################################################################################### -->\r\n          <!-- Data Grid Body starts here -->\r\n          <!--########################################################################################################################################################################################################################### -->\r\n          <!--########################################################################################################################################################################################################################### -->\r\n          <div\r\n            class=\"h-100 d-flex justify-content-center align-items-center\"\r\n            *ngIf=\"!dataSet?.length && !loading && !dataSetLoading\"\r\n          >\r\n            <!-- <div\r\n            [inlineSVG]=\"\r\n              singleSpaAssetsPath + 'data-grid/icons/record-not-found.svg'\r\n            \"\r\n            class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n          ></div> -->\r\n            <div>No Record Found</div>\r\n          </div>\r\n\r\n          <div\r\n            class=\"position-absolute w-100 h-100 d-flex justify-content-center align-items-center loading-overlay\"\r\n            *ngIf=\"loading || dataSetLoading\"\r\n            style=\"\r\n              z-index: 999;\r\n              backdrop-filter: blur(1px);\r\n            \"\r\n            [style.backgroundColor]=\"bodyBackgroundColor\"\r\n          >\r\n            <div class=\"spinner-border text-primary\" role=\"status\">\r\n              <!-- <span class=\"loader\"></span> -->\r\n              <!-- <span class=\"visually-hidden\">Loading...</span> -->\r\n              <!-- </div> -->\r\n            </div>\r\n          </div>\r\n\r\n          <div\r\n            class=\"data-grid-body-wrapper position-relative d-flex\"\r\n            [style.height]=\"bodyWrapperHeight\"\r\n            style=\"overflow-y: auto; overflow-x: hidden\"\r\n            #mainScroll\r\n            (scroll)=\"onMainScroll($event)\"\r\n            [style.scrollbarWidth]=\"verticalScrollbarWidth\"\r\n          >\r\n            <!-- LEFT PINNED -->\r\n            <div\r\n              [style.height.px]=\"\r\n                !groupedColumns.length ? originalDataSet.length * rowHeight : 0\r\n              \"\r\n            ></div>\r\n            <div [class.h-100]=\"originalDataSet.length < 8\">\r\n              <div\r\n                class=\"data-grid-body left-pinned-body w-100\"\r\n                style=\"overflow-y: hidden\"\r\n                [class.border-right]=\"hasLeftPinnedColumns\"\r\n                [class.transparent-border-right]=\"!hasLeftPinnedColumns\"\r\n                [style.transform]=\"'translateY(' + translateY + 'px)'\"\r\n                [style.backgroundColor]=\"leftPinnedBackgroundColor\"\r\n                [class.h-100]=\"originalDataSet.length < 8\"\r\n               *ngIf=\"!loading && !dataSetLoading\"\r\n                [@rowDynamic]=\"rowAnimation\"\r\n\r\n                \r\n              >\r\n                <ng-container\r\n                  *ngFor=\"\r\n                    let row of visibleRows;\r\n                    let i = index;\r\n                    trackBy: trackById\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: row,\r\n                        columns: previewLeftPinnedColumns,\r\n                        isEven: (startIndex + i) % 2 === 0,\r\n                        isOdd: (startIndex + i) % 2 !== 0,\r\n                        isLeft: true,\r\n                        section: 'left',\r\n                        isTotalRow: false\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n                <ng-container *ngIf=\"showTotalAmountRow && originalDataSet?.length\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: { __virtualIndex: 0 },\r\n                        columns: previewLeftPinnedColumns,\r\n                        isEven: false,\r\n                        isOdd: false,\r\n                        section: 'left',\r\n                        isTotalRow: true\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n\r\n            <!-- CENTER -->\r\n            <div\r\n              class=\"h-100\"\r\n              [style.width.px]=\"centerPinnedHeader.clientWidth\"\r\n              [style.backgroundColor]=\"bodyBackgroundColor\"\r\n            >\r\n              <div\r\n                class=\"data-grid-body center-scrollable\"\r\n                [class.h-100]=\"originalDataSet.length < 8\"\r\n                style=\"overflow-y: hidden; overflow-x: auto\"\r\n                [style.transform]=\"'translateY(' + translateY + 'px)'\"\r\n                [style.backgroundColor]=\"bodyBackgroundColor\"\r\n                #centerScrollableBody\r\n                (scroll)=\"onCenterBodyScroll($event)\"\r\n                [style.boxShadow]=\"leftPinnedBoxshadow\"\r\n              >\r\n              <div [@rowDynamic]=\"rowAnimation\" *ngIf=\"!loading && !dataSetLoading\">\r\n                <ng-container\r\n                  *ngFor=\"\r\n                    let row of visibleRows;\r\n                    let i = index;\r\n                    trackBy: trackById\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: row,\r\n                        columns: previewCenterColumns,\r\n                        isEven: (startIndex + i) % 2 === 0,\r\n                        isOdd: (startIndex + i) % 2 !== 0,\r\n                        section: 'center',\r\n                        isTotalRow: false\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n                </div>\r\n                <ng-container *ngIf=\"showTotalAmountRow && originalDataSet?.length\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: { __virtualIndex: 0 },\r\n                        columns: previewCenterColumns,\r\n                        isEven: false,\r\n                        isOdd: false,\r\n                        section: 'center',\r\n                        isTotalRow: true\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n\r\n            <!-- RIGHT PINNED -->\r\n            <div\r\n              class=\"right-pinned-body-wrapper\"\r\n              *ngIf=\"hasRightPinnedColumns\"\r\n              [class.h-100]=\"originalDataSet.length < 8\"\r\n              [style.maxWidth.px]=\"\r\n                isScrollbarVisible\r\n                  ? rightPinnedHeader.offsetWidth - 15\r\n                  : rightPinnedHeader.offsetWidth\r\n              \"\r\n              [style.backgroundColor]=\"rightPinnedBackgroundColor\"\r\n            >\r\n              <div\r\n                class=\"data-grid-body right-pinned-body w-100 h-100\"\r\n                style=\"overflow-y: hidden\"\r\n                [style.transform]=\"'translateY(' + translateY + 'px)'\"\r\n                [style.boxShadow]=\"rightPinnedBoxshadow\"\r\n                [style.backgroundColor]=\"rightPinnedBackgroundColor\"\r\n                *ngIf=\"!loading && !dataSetLoading\"\r\n                [@rowDynamic]=\"rowAnimation\"\r\n              >\r\n                <ng-container\r\n                  *ngFor=\"\r\n                    let row of visibleRows;\r\n                    let i = index;\r\n                    trackBy: trackById\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: row,\r\n                        columns: previewRightPinnedColumns,\r\n                        isEven: (startIndex + i) % 2 === 0,\r\n                        isOdd: (startIndex + i) % 2 !== 0,\r\n                        section: 'right',\r\n                        isTotalRow: false\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n                <ng-container *ngIf=\"showTotalAmountRow && originalDataSet?.length\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: { __virtualIndex: 0 },\r\n                        columns: previewRightPinnedColumns,\r\n                        isEven: false,\r\n                        isOdd: false,\r\n                        section: 'right',\r\n                        isTotalRow: true\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n\r\n            <div\r\n              style=\"top: auto; left: auto\"\r\n              (click)=\"\r\n                $event.stopPropagation();\r\n                fullscreenImage = null;\r\n                cdr.detectChanges()\r\n              \"\r\n              [style.width.px]=\"dataGridContainer.offsetWidth\"\r\n              [style.height.px]=\"\r\n                dataGridContainer.offsetHeight - (footerRowHeight + 100)\r\n              \"\r\n              class=\"image-modal full-image-modal\"\r\n              *ngIf=\"fullscreenImage\"\r\n            >\r\n              <img\r\n                (click)=\"$event.stopPropagation()\"\r\n                [src]=\"fullscreenImage\"\r\n                alt=\"Fullscreen Image\"\r\n              />\r\n            </div>\r\n            <div\r\n              *ngIf=\"selectedRows.size > 0 && showTaskbar\"\r\n              class=\"taskbar w-100\"\r\n              [style.bottom.px]=\"85\"\r\n            >\r\n              <div class=\"selected-rows-action-bar\" [@slideUp]>\r\n                <span class=\"selected-count\">\r\n                  {{ selectedRows.size }} selected of\r\n                  {{\r\n                    paginationConfig.totalResults ||\r\n                      config?.paginationParams?.totalItems\r\n                  }}\r\n                  Total\r\n                </span>\r\n                <div class=\"action-buttons d-flex align-items-center\">\r\n                  <ng-container\r\n                    *ngFor=\"let action of taskbarActions; let i = index\"\r\n                  >\r\n                    <ng-container *ngIf=\"action?.has_permission\">\r\n                      <span\r\n                        class=\"action-btn verified btn {{ action }}\"\r\n                        (click)=\"onVerifyClick(action?.actionName)\"\r\n                        >{{ action?.actionName }}</span\r\n                      >\r\n                      <span\r\n                        *ngIf=\"\r\n                          taskbarActions.length > 1 &&\r\n                          i !== taskbarActions.length - 1 &&\r\n                          taskbarActions[i + 1]?.has_permission\r\n                        \"\r\n                        class=\"\"\r\n                        >|</span\r\n                      >\r\n                    </ng-container>\r\n                  </ng-container>\r\n                  <button (click)=\"clearSelectionState(tableType);selectedRows.clear();\" class=\"clear-btn ms-2 mt-2\">\r\n                    <i class=\"bi bi-x-circle\"></i> Clear Selection\r\n                  </button>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <!-- Vertical Fake scroll Bar -->\r\n          <!-- <div\r\n            (scroll)=\"onMainFakeScroll($event)\"\r\n            class=\"fake-scrollbar fake-scrollbar-vertical d-none\"\r\n            [style.scrollbarWidth]=\"verticalScrollbarWidth\"\r\n            [style.top.px]=\"\r\n              showColumnsGrouping && showFilterRow\r\n                ? headerRowHeight * 3\r\n                : showColumnsGrouping || showFilterRow\r\n                ? headerRowHeight * 2\r\n                : headerRowHeight\r\n            \"\r\n            #fakeScroll\r\n            [style.height]=\"bodyWrapperHeight\"\r\n            style=\"\r\n              overflow-y: auto;\r\n              overflow-x: hidden;\r\n              width: 17px;\r\n              position: absolute;\r\n              right: 0;\r\n              background-color: f1f2f3;\r\n              z-index: 10;\r\n            \"\r\n          >\r\n            <div [style.height.px]=\"rowHeight * dataSetLength\"></div>\r\n          </div> -->\r\n        </div>\r\n\r\n        <!-- Horizintal Fake Scrollbars -->\r\n        <div\r\n          class=\"d-flex justify-content-between\"\r\n          *ngIf=\"hasScroll\"\r\n        >\r\n          <div\r\n            [style.scrollbarWidth]=\"horizintalScrollbarWidth\"\r\n            class=\"fake-horizintal-scrollbar\"\r\n            #fakeScroll\r\n            [style.width.px]=\"leftPinnedHeader.offsetWidth\"\r\n            style=\"overflow-x: scroll\"\r\n          ></div>\r\n          <div\r\n            [style.scrollbarWidth]=\"horizintalScrollbarWidth\"\r\n            (scroll)=\"onCenterBodyScroll($event)\"\r\n            class=\"fake-horizintal-scrollbar\"\r\n            #horizintalFakeScroll\r\n            [style.width.px]=\"centerPinnedHeader.offsetWidth\"\r\n          >\r\n            <div [style.width.px]=\"centerPinnedHeader.scrollWidth - 10\"></div>\r\n          </div>\r\n          <div\r\n            [style.scrollbarWidth]=\"horizintalScrollbarWidth\"\r\n            class=\"fake-horizintal-scrollbar\"\r\n            #fakeScroll\r\n            [style.width.px]=\"rightPinnedHeader.offsetWidth\"\r\n            style=\"overflow-x: scroll\"\r\n          ></div>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- Side Menu Implemented Here -->\r\n      <div\r\n        *ngIf=\"showSideMenu\"\r\n        [style.width.px]=\"sideMenuVisible ? 280 : 30\"\r\n        class=\"right-menu h-100\"\r\n        [style.backgroundColor]=\"sidemenuBackgroundColor\"\r\n      >\r\n        <div class=\"h-100 d-flex flex-row-reverse\">\r\n          <div\r\n            style=\"width: 30px\"\r\n            class=\"d-flex flex-column align-items-center cursor-pointer\"\r\n            [class.border-start]=\"sideMenuVisible\"\r\n          >\r\n            <div\r\n              (click)=\"toggleSideMenu('cols')\"\r\n              [class.bg-fff]=\"\r\n                currentOpenedSideMenue == 'cols' && sideMenuVisible\r\n              \"\r\n              [class.border-below]=\"sideMenuVisible\"\r\n              class=\"columns-button d-flex flex-column align-items-center\"\r\n            >\r\n              <div>\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/ui-checks-grid.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div>\r\n              <div class=\"side-menue-text\">Columns</div>\r\n            </div>\r\n\r\n            <div\r\n              (click)=\"toggleSideMenu('filtrs')\"\r\n              [class.bg-fff]=\"\r\n                currentOpenedSideMenue == 'filtrs' && sideMenuVisible\r\n              \"\r\n              [class.border-below]=\"\r\n                sideMenuVisible && currentOpenedSideMenue == 'filtrs'\r\n              \"\r\n              class=\"columns-button d-flex flex-column align-items-center\"\r\n            >\r\n              <div>\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div>\r\n              <div class=\"side-menue-text\">Filter</div>\r\n            </div>\r\n          </div>\r\n          <div\r\n            class=\"h-100\"\r\n            *ngIf=\"sideMenuVisible\"\r\n            [ngStyle]=\"{ width: sideMenuVisible ? '250px' : '' }\"\r\n          >\r\n            <div class=\"h-100\">\r\n              <ng-container\r\n                *ngIf=\"currentOpenedSideMenue == 'cols' && sideMenuVisible\"\r\n              >\r\n                <ng-container *ngTemplateOutlet=\"columnPannel\"></ng-container>\r\n                <!-- Column Items -->\r\n                <div class=\"column-panel-body px-3\">\r\n                  <ng-container\r\n                    *ngFor=\"let col of columns; trackBy: trackByField\"\r\n                  >\r\n                    <ng-container\r\n                      *ngTemplateOutlet=\"columnPanelItem; context: { col: col }\"\r\n                    ></ng-container>\r\n                  </ng-container>\r\n                </div>\r\n                <hr />\r\n\r\n                <div class=\"side-menu-row-groups\" style=\"height: 30%\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"sideMenuRowGroups\"\r\n                  ></ng-container>\r\n                </div>\r\n              </ng-container>\r\n              <ng-container\r\n                *ngIf=\"currentOpenedSideMenue == 'filtrs' && sideMenuVisible\"\r\n              >\r\n                <ng-container *ngTemplateOutlet=\"sideFilters\"></ng-container>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div\r\n      [style.height.px]=\"footerRowHeight\"\r\n      class=\"border-top\"\r\n      [style.backgroundColor]=\"footerRowBackgroundColor\"\r\n    >\r\n      <!-- Rows: <span class=\"fw-500 ms-1\">{{ dataSet.length }}</span> -->\r\n\r\n      <div\r\n        class=\"pagination-container\"\r\n        [style.height.px]=\"footerRowHeight\"\r\n        [style.padding.px]=\"footerPadding\"\r\n      >\r\n        <div class=\"page-size\">\r\n          <select\r\n            [(ngModel)]=\"paginationConfig.limit\"\r\n            (change)=\"onPageSizeChange()\"\r\n          >\r\n            <option *ngFor=\"let size of pageSizeOptions\" [value]=\"size\">\r\n              {{ size }}\r\n            </option>\r\n          </select>\r\n          <span class=\"separator\"> per page </span>\r\n        </div>\r\n\r\n        <div class=\"page-info\">\r\n          Results:\r\n          {{ (paginationConfig.page - 1) * paginationConfig.limit + 1 }}-{{\r\n            paginationConfig.page * paginationConfig.limit <\r\n            paginationConfig.totalResults\r\n              ? paginationConfig.page * paginationConfig.limit\r\n              : paginationConfig.totalResults\r\n          }}\r\n          of\r\n          {{ paginationConfig.totalResults }}\r\n        </div>\r\n\r\n        <div class=\"page-buttons\">\r\n          <button\r\n            (click)=\"goToPage(paginationConfig.page - 1)\"\r\n            [disabled]=\"paginationConfig.page === 1\"\r\n          >\r\n            ‹\r\n          </button>\r\n\r\n          <ng-container *ngFor=\"let page of visiblePages\">\r\n            <button\r\n              *ngIf=\"page !== '...'\"\r\n              (click)=\"goToPage(page)\"\r\n              [class.active]=\"page === paginationConfig.page\"\r\n            >\r\n              {{ page }}\r\n            </button>\r\n            <span *ngIf=\"page === '...'\">...</span>\r\n          </ng-container>\r\n\r\n          <button\r\n            (click)=\"goToPage(paginationConfig.page + 1)\"\r\n            [disabled]=\"paginationConfig.page === paginationConfig.totalResults\"\r\n          >\r\n            ›\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!-- ------------------------------------------------------------------------------------------------------------------------ -->\r\n<!-- ------------------------------------------------------------------------------------------------------------------------ -->\r\n<!-- Header Cell Template -->\r\n<!-- ------------------------------------------------------------------------------------------------------------------------ -->\r\n<!-- ------------------------------------------------------------------------------------------------------------------------ -->\r\n\r\n<ng-template\r\n  #headerCell\r\n  let-col\r\n  let-pinnedRight=\"pinnedRight\"\r\n  let-i=\"index\"\r\n  let-sections=\"section\"\r\n  let-calledFromNestedPlaceholder=\"calledFromNestedPlaceholder\"\r\n>\r\n  <div>\r\n    <!-- Group Header -->\r\n    <ng-container *ngIf=\"col.children?.length > 0; else flatHeader\">\r\n      <div cdkDroplistGroup class=\"group-column-wrapper\">\r\n        <!-- Parent Header -->\r\n        <div\r\n          *ngIf=\"shouldTheGroupHeaderShow(col)\"\r\n          class=\"header-cell group-header\"\r\n          [style.height.px]=\"headerRowHeight\"\r\n          [style.min-height.px]=\"headerRowHeight\"\r\n          [style.max-height.px]=\"headerRowHeight\"\r\n          [class.border-right]=\"showVerticalBorder\"\r\n          [style.gridColumn]=\"'span ' + col.children.length\"\r\n          [style.fontWeight]=\"headerFontWeight\"\r\n          [class.flex-row-reverse]=\"pinnedRight\"\r\n          [class.justify-content-end]=\"pinnedRight\"\r\n          style=\"grid-row: 1\"\r\n        >\r\n          <div\r\n            class=\"group-header-content\"\r\n            [title]=\"col.header\"\r\n            [class.ms-2]=\"pinnedRight\"\r\n          >\r\n            {{ col.header }}\r\n          </div>\r\n          <div\r\n            class=\"resize-handle\"\r\n            (dblclick)=\"autosizeColumn(col.children)\"\r\n            (mousedown)=\"\r\n              $event.stopPropagation(); onResizeGroup($event, col, pinnedRight)\r\n            \"\r\n          >\r\n            <span\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath + 'data-grid/icons/resize-handle.svg'\r\n              \"\r\n              class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n            ></span>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Child Headers and Filters -->\r\n\r\n        <div\r\n          class=\"d-flex\"\r\n          cdkDropList\r\n          cdkDropListOrientation=\"horizontal\"\r\n          [cdkDropListData]=\"col.children\"\r\n          (cdkDropListSorted)=\"onChildDroplistSorted($event, sections)\"\r\n          (cdkDropListDropped)=\"onChildDroplistDroped($event)\"\r\n          [cdkDropListSortingDisabled]=\"false\"\r\n          [cdkDropListConnectedTo]=\"\r\n            showRowsGrouping ? ['rows-grouping-top-container'] : []\r\n          \"\r\n        >\r\n          <div\r\n            cdkDrag\r\n            [cdkDragData]=\"child\"\r\n            *ngFor=\"let child of col.children; let i = index\"\r\n          >\r\n            <!-- Child Header -->\r\n            <ng-container *ngIf=\"child.is_visible && !child['isRowGrouped']\">\r\n              <div\r\n                cdkDragHandle\r\n                class=\"header-cell one-row-header-cells cursor-pointer\"\r\n                [class.border-right]=\"showVerticalBorder\"\r\n                [attr.data-field]=\"child.field\"\r\n                [style.width.px]=\"child.width\"\r\n                [style.min-width.px]=\"child.width\"\r\n                [style.min-height.px]=\"headerRowHeight\"\r\n                [style.max-height.px]=\"headerRowHeight\"\r\n                [style.fontWeight]=\"headerFontWeight\"\r\n                style=\"grid-row: 2\"\r\n                [class.filter-applied-on-text]=\"isFilterAppliedOnColumn(child)\"\r\n              >\r\n                <div\r\n                  class=\"d-flex justify-content-between h-100 align-items-center w-100\"\r\n                >\r\n                  <div\r\n                    class=\"d-flex justify-content-between align-items-center w-100\"\r\n                    [class.flex-row-reverse]=\"pinnedRight\"\r\n                  >\r\n                    <div\r\n                      class=\"text-ellipsis h-100 d-flex align-items-center w-100\"\r\n                      [title]=\"col.header\"\r\n                      [class.w-100]=\"pinnedRight\"\r\n                    >\r\n                      <div\r\n                        class=\"text-ellipsis h-100\"\r\n                        [class.editable-header]=\"child?.is_editable\"\r\n                        (click)=\"\r\n                          openThreeDotsMenu($event, child);\r\n                          openFilteronThreeDotsClick(child)\r\n                        \"\r\n                      >\r\n                        {{ child.header }}\r\n                      </div>\r\n                    </div>\r\n\r\n                    <div\r\n                      class=\"position-relative d-flex\"\r\n                      [class.flex-row-reverse]=\"pinnedRight\"\r\n                    >\r\n                      <div\r\n                        [class.me-2]=\"pinnedRight\"\r\n                        class=\"d-flex align-items-center\"\r\n                        *ngIf=\"child.pinned\"\r\n                      >\r\n                        <span\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath + 'data-grid/icons/pin-blue.svg'\r\n                          \"\r\n                          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                        ></span>\r\n                      </div>\r\n                      <div\r\n                        class=\"three-dots p-1\"\r\n                        (click)=\"\r\n                          openThreeDotsMenu($event, child);\r\n                          isThreeDotsFilterOpen = false\r\n                        \"\r\n                        style=\"cursor: pointer\"\r\n                      >\r\n                        <span\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath +\r\n                            'data-grid/icons/three-dots-vertical.svg'\r\n                          \"\r\n                          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                        ></span>\r\n                      </div>\r\n\r\n                      <!-- Only show menu if this column is active -->\r\n                      <div\r\n                        class=\"position-absolute\"\r\n                        *ngIf=\"activeCol === child\"\r\n                        style=\"top: -50%; z-index: 21\"\r\n                        [style.left.px]=\"\r\n                          -(!child?.pinned ? centerPinnedHeader.scrollLeft : 0)\r\n                        \"\r\n                        [style.top.px]=\"\r\n                          isThreeDotsFilterOpen\r\n                            ? showFilterRow || showColumnsGrouping\r\n                              ? headerRowHeight * 2 - 10\r\n                              : headerRowHeight - 10\r\n                            : 0\r\n                        \"\r\n                      >\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"\r\n                            columnMenu;\r\n                            context: {\r\n                              col: child,\r\n                              isNestedTable: false,\r\n                              section: sections\r\n                            }\r\n                          \"\r\n                        ></ng-container>\r\n                      </div>\r\n\r\n                      <div\r\n                        class=\"resize-handle\"\r\n                        (dblclick)=\"autosizeColumn(child)\"\r\n                        (mousedown)=\"\r\n                          $event.stopPropagation();\r\n                          onResizeColumn($event, child)\r\n                        \"\r\n                      >\r\n                        <span\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath +\r\n                            'data-grid/icons/resize-handle.svg'\r\n                          \"\r\n                          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                        ></span>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Filter Cell -->\r\n              <div\r\n                *ngIf=\"showFilterRow\"\r\n                [style.backgroundColor]=\"headerBackgroundColor\"\r\n                class=\"header-cell filter-cell\"\r\n                [class.border-right]=\"showVerticalBorder\"\r\n                [attr.data-field]=\"child.field\"\r\n                [style.width.px]=\"child.width\"\r\n                [style.min-width.px]=\"child.width\"\r\n                [style.height.px]=\"headerRowHeight\"\r\n                [style.min-height.px]=\"headerRowHeight\"\r\n                [style.max-height.px]=\"headerRowHeight\"\r\n                [class.border-right]=\"showVerticalBorder\"\r\n                style=\"grid-row: 3\"\r\n              >\r\n                <div\r\n                  class=\"header-cell filter-cell\"\r\n                  [attr.data-field]=\"col.field\"\r\n                  [style.width.px]=\"col.width\"\r\n                  [style.min-width.px]=\"col.width\"\r\n                  [style.height.px]=\"headerRowHeight\"\r\n                  [style.min-height.px]=\"headerRowHeight\"\r\n                  [style.max-height.px]=\"headerRowHeight\"\r\n                >\r\n                  <input\r\n                    type=\"text\"\r\n                    class=\"form-control form-control-sm\"\r\n                    placeholder=\"Filter\"\r\n                    [(ngModel)]=\"child.filterValue\"\r\n                    (ngModelChange)=\"onFilterChange(child)\"\r\n                    (paste)=\"onFilterChange(child); applyDropdownFilter()\"\r\n                    [readonly]=\"\r\n                      child?.type == 'dropdown' || child?.type == 'image'\r\n                    \"\r\n                    [class.disabled-search-input]=\"\r\n                      child?.type == 'dropdown' || child?.type == 'image'\r\n                    \"\r\n                    (click)=\"\r\n                      $event.stopPropagation();\r\n                      openFilterFromDisabledSearchedInput(child)\r\n                    \"\r\n                    (keydown.enter)=\"applyDropdownFilter()\"\r\n                    (mousedown)=\"$event.stopPropagation()\"\r\n                  />\r\n                  <span\r\n                    class=\"filter-icon-wrapper\"\r\n                    (click)=\"$event.stopPropagation(); openFilter(child)\"\r\n                    [class.filter-applied]=\"isFilterAppliedOnColumn(child)\"\r\n                    [class.pe-none]=\"child?.type == 'image'\"\r\n                    ><span\r\n                      [inlineSVG]=\"\r\n                        singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\r\n                      \"\r\n                      class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                    ></span>\r\n                    <span\r\n                      *ngIf=\"isFilterAppliedOnColumn(child)\"\r\n                      style=\"\r\n                        width: 7px;\r\n                        height: 7px;\r\n                        box-shadow: 0px 0px 3px #7486ff;\r\n                        background-color: rgb(0 163 233);\r\n                        position: absolute;\r\n                        right: 4px;\r\n                        top: 12px;\r\n                      \"\r\n                      class=\"rounded-circle d-block\"\r\n                    ></span\r\n                  ></span>\r\n\r\n                  <div\r\n                    class=\"position-absolute filter-row-filter-wrapper\"\r\n                    *ngIf=\"activeFilterCell?.field == child?.field\"\r\n                    style=\"top: 100%; right: 0; z-index: 99\"\r\n                    [style.left.px]=\"\r\n                      child?.pinned ? 0 : -centerPinnedHeader.scrollLeft\r\n                    \"\r\n                  >\r\n                    <ng-container\r\n                      *ngTemplateOutlet=\"filterMenu; context: { col: child }\"\r\n                    ></ng-container>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n            </ng-container>\r\n            <ng-template cdkDragPreview\r\n              ><div class=\"p-2 border d-flex gap-2\">\r\n                <div\r\n                  *ngIf=\"\r\n                    !draggingInGroupArea ||\r\n                    (child.is_groupable && draggingInGroupArea)\r\n                  \"\r\n                >\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/arrows-move.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n                <div *ngIf=\"draggingInGroupArea && !child.is_groupable\">\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/ban.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n                <div>{{ child.header }}</div>\r\n              </div>\r\n            </ng-template>\r\n            <ng-template cdkDragPlaceholder>\r\n              <div *ngIf=\"!draggingInGroupArea\" class=\"position-relative\">\r\n                <div\r\n                  *ngTemplateOutlet=\"\r\n                  childHeaderPlaceholder;\r\n                  context: {\r\n                    $implicit: child,\r\n                    index: i,\r\n                    sections: sections,\r\n                    calledFromNestedPlaceholder: true,\r\n                  }\r\n                \"\r\n                ></div>\r\n              </div>\r\n              <div\r\n                *ngIf=\"draggingInGroupArea && child?.is_groupable\"\r\n                class=\"d-flex gap-2 ms-2\"\r\n                style=\"opacity: 0.6\"\r\n              >\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    topGroupingRowPlaceholder;\r\n                    context: {\r\n                      $implicit: child,\r\n                      showChevron: false,\r\n                      pinnedRight: pinnedRight,\r\n                      sections: sections,\r\n                      index: i\r\n                    }\r\n                  \"\r\n                ></ng-container>\r\n              </div>\r\n            </ng-template>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Flat Header || Single Header Cell-->\r\n    <ng-template #flatHeader>\r\n      <div\r\n        class=\"group-column-wrapper\"\r\n        *ngIf=\"col.is_visible && !col['isRowGrouped']\"\r\n      >\r\n        <!-- Full-height Header Cell (spans 2 rows visually) -->\r\n        <div\r\n          class=\"header-cell one-row-header-cells\"\r\n          [attr.data-field]=\"col.field\"\r\n          [style.width.px]=\"col.width\"\r\n          [style.min-width.px]=\"col.width\"\r\n          [class.border-right]=\"showVerticalBorder\"\r\n          [style.min-height.px]=\"\r\n            showColumnsGrouping ? headerRowHeight * 2 : headerRowHeight\r\n          \"\r\n          [style.height.px]=\"\r\n            showColumnsGrouping ? headerRowHeight * 2 : headerRowHeight\r\n          \"\r\n          [style.fontWeight]=\"headerFontWeight\"\r\n          style=\"grid-row: 1 / span 2\"\r\n        >\r\n          <div\r\n            class=\"d-flex justify-content-between h-100 align-items-center w-100\"\r\n          >\r\n            <div\r\n              class=\"d-flex justify-content-between w-100 align-items-center\"\r\n              [class.flex-row-reverse]=\"pinnedRight\"\r\n            >\r\n              <div\r\n                class=\"text-ellipsis h-100 d-flex align-items-center w-100\"\r\n                [title]=\"col.header\"\r\n              >\r\n                <div\r\n                  class=\"text-ellipsis h-100 cursor-pointer\"\r\n                  [class.editable-header]=\"col?.is_editable\"\r\n                  [class.filter-applied-on-text]=\"isFilterAppliedOnColumn(col)\"\r\n                  (click)=\"\r\n                    openThreeDotsMenu($event, col);\r\n                    openFilteronThreeDotsClick(col)\r\n                  \"\r\n                >\r\n                  {{ col.header }}\r\n                </div>\r\n              </div>\r\n\r\n              <div\r\n                class=\"position-relative d-flex\"\r\n                [class.flex-row-reverse]=\"pinnedRight\"\r\n              >\r\n                <div\r\n                  [class.me-2]=\"pinnedRight\"\r\n                  class=\"d-flex align-items-center\"\r\n                  *ngIf=\"col?.pinned\"\r\n                >\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/pin-blue.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n                <div\r\n                  [class.me-2]=\"col.order_by\"\r\n                  class=\"d-flex align-items-center\"\r\n                  *ngIf=\"sortingConfig?.field == col.field\"\r\n                >\r\n                  <!-- Ascending Sort Icon -->\r\n                  <span\r\n                    *ngIf=\"sortingConfig?.order_by == 'asc'\"\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/sort-asc.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center mt-1 cursor-pointer\"\r\n                    (click)=\"sortDesc(col)\"\r\n                    [class.active]=\"sortingConfig?.order_by === 'asc'\"\r\n                  ></span>\r\n\r\n                  <!-- Descending Sort Icon -->\r\n                  <span\r\n                    *ngIf=\"sortingConfig?.order_by == 'desc'\"\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/sort-desc.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center mt-1 cursor-pointer\"\r\n                    (click)=\"sortAsc(col)\"\r\n                    [class.active]=\"sortingConfig?.order_by === 'desc'\"\r\n                  ></span>\r\n                </div>\r\n                <div\r\n                  class=\"three-dots p-1\"\r\n                  (click)=\"\r\n                    openThreeDotsMenu($event, col);\r\n                    isThreeDotsFilterOpen = false\r\n                  \"\r\n                  style=\"cursor: pointer\"\r\n                >\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath +\r\n                      'data-grid/icons/three-dots-vertical.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n\r\n                <!-- Only show menu if this column is active -->\r\n                <div\r\n                  class=\"position-absolute\"\r\n                  *ngIf=\"activeCol === col\"\r\n                  style=\"top: -50%; z-index: 21\"\r\n                  [style.left.px]=\"\r\n                    -(!col?.pinned ? centerPinnedHeader.scrollLeft : 0)\r\n                  \"\r\n                  [style.top.px]=\"\r\n                    isThreeDotsFilterOpen\r\n                      ? showFilterRow || showColumnsGrouping\r\n                        ? headerRowHeight * 2 - 10\r\n                        : headerRowHeight - 10\r\n                      : 0\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      columnMenu;\r\n                      context: {\r\n                        col: col,\r\n                        isNestedTable: false,\r\n                        section: sections\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </div>\r\n\r\n                <div\r\n                  class=\"resize-handle\"\r\n                  [class.w-100]=\"col.pinned == 'right'\"\r\n                  (dblclick)=\"autosizeColumn(col)\"\r\n                  (mousedown)=\"\r\n                    $event.stopPropagation(); onResizeColumn($event, col)\r\n                  \"\r\n                >\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/resize-handle.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Filter Cell -->\r\n        <div\r\n          *ngIf=\"showFilterRow\"\r\n          [style.backgroundColor]=\"headerBackgroundColor\"\r\n          class=\"header-cell filter-cell\"\r\n          [class.border-right]=\"showVerticalBorder\"\r\n          [attr.data-field]=\"col.field\"\r\n          [style.width.px]=\"col.width\"\r\n          [style.min-width.px]=\"col.width\"\r\n          [style.height.px]=\"headerRowHeight\"\r\n          [style.min-height.px]=\"headerRowHeight\"\r\n          [style.max-height.px]=\"headerRowHeight\"\r\n        >\r\n          <input\r\n            type=\"text\"\r\n            class=\"form-control form-control-sm\"\r\n            placeholder=\"Filter\"\r\n            [(ngModel)]=\"col.filterValue\"\r\n            (ngModelChange)=\"onFilterChange(col)\"\r\n            [readonly]=\"col?.type == 'dropdown' || col?.type == 'image'\"\r\n            [class.disabled-search-input]=\"\r\n              col?.type == 'dropdown' || col?.type == 'image'\r\n            \"\r\n            (paste)=\"onPasteInFilterRowSearch($event, col)\"\r\n            (click)=\"\r\n              $event.stopPropagation(); openFilterFromDisabledSearchedInput(col)\r\n            \"\r\n            (keydown.enter)=\"applyDropdownFilter()\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n          <span\r\n            class=\"filter-icon-wrapper\"\r\n            (click)=\"$event.stopPropagation(); openFilter(col)\"\r\n            [class.filter-applied]=\"isFilterAppliedOnColumn(col)\"\r\n            [class.pe-none]=\"col?.type == 'image'\"\r\n            ><span\r\n              [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\"\r\n              class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n            ></span>\r\n            <span\r\n              *ngIf=\"isFilterAppliedOnColumn(col)\"\r\n              style=\"\r\n                width: 7px;\r\n                height: 7px;\r\n                box-shadow: 0px 0px 3px #7486ff;\r\n                background-color: rgb(0 163 233);\r\n                position: absolute;\r\n                right: 4px;\r\n                top: 12px;\r\n              \"\r\n              class=\"rounded-circle d-block\"\r\n            ></span\r\n          ></span>\r\n\r\n          <div\r\n            class=\"position-absolute filter-row-filter-wrapper\"\r\n            *ngIf=\"activeFilterCell === col\"\r\n            style=\"top: 100%; right: 0; z-index: 99\"\r\n            [style.left.px]=\"col?.pinned ? 0 : -centerPinnedHeader.scrollLeft\"\r\n          >\r\n            <ng-container\r\n              *ngTemplateOutlet=\"filterMenu; context: { col: col }\"\r\n            ></ng-container>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- -------------------------------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n<!-- -------------------------------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n<!-- Body Cell Template -->\r\n<!-- -------------------------------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n<!-- -------------------------------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n<ng-template\r\n  #rowCell\r\n  let-row\r\n  let-columns=\"columns\"\r\n  let-isEven=\"isEven\"\r\n  let-isOdd=\"isOdd\"\r\n  let-isLeftSection=\"isLeft\"\r\n  let-section=\"section\"\r\n  let-rowIndex=\"rowIndex\"\r\n  let-isTotalRow=\"isTotalRow\"\r\n>\r\n  <!-- Check if row is a group -->\r\n  <ng-container\r\n    *ngTemplateOutlet=\"groupRowTemplate; context: { $implicit: row, depth: 0 }\"\r\n  ></ng-container>\r\n  <ng-template #groupRowTemplate let-row let-depth=\"depth\">\r\n    <ng-container *ngIf=\"row.isGroup; else regularRow\">\r\n      <!-- Group Header -->\r\n      <div\r\n        class=\"group-header-row d-flex align-items-center\"\r\n        [style.height.px]=\"rowHeight\"\r\n        [class.border-below]=\"section !== 'center'\"\r\n        [style.width]=\"\r\n          section === 'center'\r\n            ? (centerScrollableBody?.scrollWidth ?? 0) + 'px'\r\n            : '100%'\r\n        \"\r\n      >\r\n        <div\r\n          *ngIf=\"section == 'left'\"\r\n          class=\"h-100 d-flex\"\r\n          [style.width.px]=\"leftPinnedHeader.offsetWidth - 1\"\r\n          [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n        >\r\n          <div\r\n            *ngIf=\"showSerialNumber\"\r\n            style=\"width: 50px\"\r\n            class=\"d-flex align-items-center h-100 border-right justify-content-end pe-2 s-no\"\r\n            [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n            [style.width.px]=\"55\"\r\n            [style.cursor]=\"\r\n              'url(' +\r\n              singleSpaAssetsPath +\r\n              'data-grid/icons/arrow-right.svg), auto'\r\n            \"\r\n            (mousedown)=\"onRowMouseDown(row.__virtualIndex, $event)\"\r\n            (mouseover)=\"onRowMouseOver(row.__virtualIndex, $event)\"\r\n            [style.color]=\"checkboxesColor\"\r\n          >\r\n            {{ getStartIndex() + (row.__virtualIndex - 1) || \"\" }}\r\n          </div>\r\n          <div\r\n          *ngIf=\"showCheckboxes\"\r\n            style=\"width: 50px\"\r\n            class=\"d-flex align-items-center justify-content-center h-100 border-right\"\r\n            [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n            [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n            [class.left-selection-border]=\"\r\n              rowSelectedIndexes.has(row.__virtualIndex)\r\n            \"\r\n            [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n            [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n            [style.color]=\"checkboxesColor\"\r\n          >\r\n            <input\r\n              style=\"width: 16px; height: 16px\"\r\n              type=\"checkbox\"\r\n              [checked]=\"getGroupCheckedState(row) === true\"\r\n              [indeterminate]=\"getGroupCheckedState(row) === undefined\"\r\n              (change)=\"selectGroupRow($event, row)\"\r\n            />\r\n\r\n          </div>\r\n        </div>\r\n\r\n        <div\r\n          *ngIf=\"section == 'center'\"\r\n          [style.width.px]=\"centerPinnedHeader.scrollWidth\"\r\n          [style.minWidth.px]=\"centerPinnedHeader.scrollWidth\"\r\n          class=\"d-flex align-items-center ps-2 h-100 border-below\"\r\n          [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n          [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n          [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n        >\r\n          <div\r\n            class=\"d-flex align-items-center justify-content-between\"\r\n            [style.paddingLeft.px]=\"depth > 0 ? depth * 30 : 0\"\r\n          >\r\n            <span class=\"me-2 filter-icon-wrapper\" (click)=\"toggleExpand(row)\">\r\n              <span\r\n                class=\"data-grid-svg-icon align-items-center d-flex\"\r\n                [inlineSVG]=\"\r\n                  row.isExpand\r\n                    ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n                    : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n                \"\r\n              ></span>\r\n            </span>\r\n            <strong (click)=\"toggleExpand(row)\" class=\"cursor-pointer\">\r\n              {{ row.groupValue }} ({{ countLeafRows(row) }})\r\n            </strong>\r\n          </div>\r\n        </div>\r\n\r\n        <div\r\n          *ngIf=\"section == 'right'\"\r\n          [style.width.px]=\"rightPinnedHeader.offsetWidth\"\r\n          [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n          [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n          [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n        ></div>\r\n      </div>\r\n\r\n      <!-- Recursive Children -->\r\n      <div class=\"group-children\" *ngIf=\"row.isExpand\" [@slideToggle]>\r\n        <ng-container\r\n          *ngFor=\"let child of row.children; let i = index; trackBy: trackById\"\r\n        >\r\n          <ng-container *ngIf=\"child.isGroup; else dataRow\">\r\n            <!-- Recursive call for nested group -->\r\n            <ng-container\r\n              *ngTemplateOutlet=\"\r\n                groupRowTemplate;\r\n                context: { $implicit: child, depth: depth + 1 }\r\n              \"\r\n            ></ng-container>\r\n          </ng-container>\r\n\r\n          <ng-template #dataRow>\r\n            <!-- Regular data row -->\r\n            <ng-container\r\n              *ngTemplateOutlet=\"\r\n                rowCell;\r\n                context: {\r\n                  $implicit: child,\r\n                  columns: columns,\r\n                  isEven: i % 2 === 0,\r\n                  isOdd: i % 2 !== 0,\r\n                  isLeft: isLeftSection,\r\n                  section: section,\r\n                  isTotalRow: isTotalRow\r\n                }\r\n              \"\r\n            ></ng-container>\r\n          </ng-template>\r\n        </ng-container>\r\n      </div>\r\n    </ng-container>\r\n  </ng-template>\r\n\r\n  <!-- Regular row (not a group) -->\r\n  <ng-template #regularRow>\r\n    <div\r\n      class=\"d-flex\"\r\n      [style.height.px]=\"rowHeight\"\r\n      [style.minHeight.px]=\"rowHeight\"\r\n      [style.maxHeight.px]=\"rowHeight\"\r\n    >\r\n      <span\r\n        class=\"d-flex align-items-center justify-content-center cursor-pointer border-below\"\r\n        style=\"min-width: 30px; height: 100%\"\r\n        *ngIf=\"\r\n          section == 'center' && (gridType === 'Assets' || gridType === 'Tasks')\r\n        \"\r\n        [ngStyle]=\"{\r\n          'background-color': rowSelectedIndexes.has(row.__virtualIndex)\r\n            ? null\r\n            : getBackgroundColor(row, isEven, section)\r\n        }\"\r\n        [class.selected-cell]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n        [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n        [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n      >\r\n        <span\r\n          (click)=\"toggleDetailRowExpand(row)\"\r\n          *ngIf=\"row?.detail?.result?.length || gridType === 'Tasks'\"\r\n          class=\"data-grid-svg-icon filter-icon-wrapper\"\r\n          [inlineSVG]=\"\r\n            isDetailsExpanded(row)\r\n              ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n              : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n        ></span>\r\n      </span>\r\n      <div\r\n        [style.min-width.px]=\"\r\n          section == 'center' && groupedColumns?.length ? groupBoxPadding : 0\r\n        \"\r\n        [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n        [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n        [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n        (contextmenu)=\"onRightClick($event, row)\"\r\n        [style.height.px]=\"rowHeight\"\r\n        class=\"data-grid-row h-100\"\r\n        [class.even-row]=\"isEven\"\r\n        [class.odd-row]=\"isOdd\"\r\n        [class.hovered-row]=\"hoveredRowId === (row._id || row.id)\"\r\n        (mouseenter)=\"onRowHover(row)\"\r\n        (mouseleave)=\"onRowLeave()\"\r\n        [ngStyle]=\"{\r\n          'background-color': getBackgroundColor(row, isEven, section)\r\n        }\"\r\n        [style.minHeight.px]=\"rowHeight\"\r\n        [style.maxHeight.px]=\"rowHeight\"\r\n      ></div>\r\n      <div\r\n        (contextmenu)=\"onRightClick($event, row)\"\r\n        [style.height.px]=\"rowHeight\"\r\n        class=\"data-grid-row\"\r\n        [class.even-row]=\"isEven\"\r\n        [class.odd-row]=\"isOdd\"\r\n        [class.hovered-row]=\"hoveredRowId === (row._id || row.id)\"\r\n        (mouseenter)=\"onRowHover(row)\"\r\n        (mouseleave)=\"onRowLeave()\"\r\n        [ngStyle]=\"{\r\n          'background-color': getBackgroundColor(row, isEven, section)\r\n        }\"\r\n      >\r\n        <div\r\n          [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n          class=\"select-all-checkbox-cell justify-content-end pe-2 s-no\"\r\n          [style.width.px]=\"55\"\r\n          *ngIf=\"isLeftSection && showSerialNumber\"\r\n          [style.cursor]=\"\r\n            'url(' +\r\n            singleSpaAssetsPath +\r\n            'data-grid/icons/arrow-right.svg), auto'\r\n          \"\r\n          (mousedown)=\"onRowMouseDown(row.__virtualIndex, $event)\"\r\n          (mouseover)=\"onRowMouseOver(row.__virtualIndex, $event)\"\r\n          [style.color]=\"checkboxesColor\"\r\n        >\r\n          {{ getStartIndex() + (row.__virtualIndex - 1) }}\r\n        </div>\r\n        <div\r\n        class=\"border-below\"\r\n          [style.backgroundColor]=\"\r\n            rowSelectedIndexes.has(row.__virtualIndex)\r\n              ? selectedRowsBackgroundColor\r\n              : checkboxesBackgroundColor\r\n          \"\r\n          class=\"select-all-checkbox-cell\"\r\n          *ngIf=\"isLeftSection && showCheckboxes\"\r\n          [class.left-selection-border]=\"\r\n            rowSelectedIndexes.has(row.__virtualIndex)\r\n          \"\r\n          [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n          [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n          [style.minHeight.px]=\"rowHeight - 1\"\r\n          [style.maxHeight.px]=\"rowHeight\"\r\n        >\r\n          <input\r\n            *ngIf=\"hasAnyVisibleColumn\"\r\n             style=\"width: 16px; height: 16px\"\r\n            type=\"checkbox\"\r\n            [checked]=\"isRowSelected(row)\"\r\n            (change)=\"toggleRowSelection(row)\"\r\n          />\r\n        </div>\r\n\r\n        <!-- Render all columns -->\r\n        <ng-container\r\n          *ngFor=\"\r\n            let col of columns;\r\n            trackBy: trackByField;\r\n            let colIndex = index\r\n          \"\r\n        >\r\n          <ng-container *ngIf=\"col.children?.length > 0; else flatColumn\">\r\n            <ng-container\r\n              *ngFor=\"\r\n                let child of col.children;\r\n                trackBy: trackByField;\r\n                let subColIndex = index\r\n              \"\r\n            >\r\n              <ng-container *ngIf=\"child?.is_visible && !child?.isRowGrouped\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    cellTemplate;\r\n                    context: {\r\n                      col: child,\r\n                      row: row,\r\n                      rowIndex: rowIndex,\r\n                      colIndex: colIndex,\r\n                      subColIndex: subColIndex,\r\n                      section: section,\r\n                      isTotalRow: isTotalRow\r\n                    }\r\n                  \"\r\n                ></ng-container>\r\n              </ng-container>\r\n            </ng-container>\r\n          </ng-container>\r\n\r\n          <ng-template #flatColumn>\r\n            <ng-container *ngIf=\"col?.is_visible && !col?.isRowGrouped\">\r\n              <ng-container\r\n                *ngTemplateOutlet=\"\r\n                  cellTemplate;\r\n                  context: {\r\n                    col: col,\r\n                    row: row,\r\n                    rowIndex: rowIndex,\r\n                    colIndex: colIndex,\r\n                    subColIndex: null,\r\n                    section: section,\r\n                    isTotalRow: isTotalRow\r\n                  }\r\n                \"\r\n              ></ng-container>\r\n            </ng-container>\r\n          </ng-template>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n\r\n    <div\r\n      [@slideToggle]\r\n      *ngIf=\"section === 'left' && isDetailsExpanded(row)\"\r\n      class=\"accordion-details\"\r\n      style=\"max-height: 350px; overflow: hidden\"\r\n      [style.maxHeight.px]=\"hasHorizontalScroll ? 339 : 341\"\r\n    >\r\n      <ng-container\r\n        *ngTemplateOutlet=\"\r\n          leftRightNestedPlaceholder;\r\n          context: { $implicit: row }\r\n        \"\r\n      >\r\n      </ng-container>\r\n    </div>\r\n\r\n    <div\r\n      [@slideToggle]\r\n      *ngIf=\"section === 'center' && isDetailsExpanded(row)\"\r\n      class=\"accordion-details center-section\"\r\n      style=\"\r\n        max-height: 350px;\r\n        overflow-y: hidden;\r\n        overflow-x: auto;\r\n        scrollbar-width: thin;\r\n      \"\r\n      #nestedTable\r\n      [style.width]=\"\r\n        hasRightPinnedColumns\r\n          ? '100%'\r\n          : hasVerticalScroll\r\n          ? 'calc(100% - 12px)'\r\n          : '100%'\r\n      \"\r\n    >\r\n      <ng-container *ngIf=\"gridType == 'Assets'\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"nestedTableTemplate; context: { $implicit: row }\"\r\n        ></ng-container>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"gridType == 'Tasks'\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"\r\n            taskManagementTemplate;\r\n            context: { taskDetails: row }\r\n          \"\r\n        ></ng-container>\r\n      </ng-container>\r\n    </div>\r\n\r\n    <div\r\n      [@slideToggle]\r\n      *ngIf=\"section === 'right' && isDetailsExpanded(row)\"\r\n      class=\"accordion-details\"\r\n      style=\"max-height: 350px; overflow: hidden\"\r\n      [style.maxHeight.px]=\"hasHorizontalScroll ? 339 : 341\"\r\n    >\r\n      <ng-container\r\n        *ngTemplateOutlet=\"\r\n          leftRightNestedPlaceholder;\r\n          context: { $implicit: row }\r\n        \"\r\n      >\r\n      </ng-container>\r\n    </div>\r\n  </ng-template>\r\n</ng-template>\r\n\r\n<!-- Actual Cell is Here -->\r\n<ng-template\r\n  #cellTemplate\r\n  let-col=\"col\"\r\n  let-row=\"row\"\r\n  let-section=\"section\"\r\n  let-subColIndex=\"subColIndex\"\r\n  let-rowIndex=\"rowIndex\"\r\n  let-colIndex=\"colIndex\"\r\n  let-isTotalRow=\"isTotalRow\"\r\n>\r\n  <div\r\n    #cellContainer\r\n    (click)=\"\r\n      editingKey = ''; setActiveCell(row, col); collapseAllExpandedCells()\r\n    \"\r\n    [style.fontWeight]=\"bodyFontWeight\"\r\n    [class.border-right]=\"showVerticalBorder\"\r\n    class=\"cell overflow-visible position-relative data-grid-cell\"\r\n    [attr.data-field]=\"col.field\"\r\n    [style.width.px]=\"col.width\"\r\n    [style.min-width.px]=\"col.width\"\r\n    [style.fontSize.px]=\"bodyTextFontsSize\"\r\n    [style.minHeight.px]=\"rowHeight\"\r\n    [style.maxHeight.px]=\"rowHeight\"\r\n    [class.active-cell]=\"\r\n      isActiveCell(row, col) && !isEditing(row, col) && selectedKeys.size == 1\r\n    \"\r\n    (dblclick)=\"\r\n      $event.stopPropagation();\r\n      $event.preventDefault();\r\n      enableEdit(row, col, false, cellContainer)\r\n    \"\r\n    [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n    [class.first-row-selected]=\"firstSelectedRow === row?.__virtualIndex\"\r\n    [class.last-row-selected]=\"lastSelectedRow === row?.__virtualIndex\"\r\n    tabindex=\"-1\"\r\n    (keydown.enter)=\"$event.preventDefault(); enableEdit(row, col)\"\r\n    (mousedown)=\"\r\n      startSelection(\r\n        row.__virtualIndex,\r\n        colIndex,\r\n        subColIndex ?? 0,\r\n        col.field,\r\n        $event,\r\n        section\r\n      )\r\n    \"\r\n    (mouseenter)=\"\r\n      extendSelection(\r\n        row.__virtualIndex,\r\n        colIndex,\r\n        subColIndex ?? 0,\r\n        col.field,\r\n        $event,\r\n        section\r\n      )\r\n    \"\r\n    (mouseup)=\"endSelection()\"\r\n    [class.selected-cell]=\"\r\n      isSelected(\r\n        row.__virtualIndex,\r\n        colIndex,\r\n        subColIndex ?? 0,\r\n        col.field,\r\n        section\r\n      )\r\n    \"\r\n    [class.top-border]=\"\r\n      isTopBorder(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.bottom-border]=\"\r\n      isBottomBorder(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.left-border]=\"\r\n      isLeftBorder(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.right-border]=\"\r\n      isRightBorder(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.top-left-corner]=\"\r\n      isTopLeftCorner(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.top-right-corner]=\"\r\n      isTopRightCorner(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.bottom-left-corner]=\"\r\n      isBottomLeftCorner(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.bottom-right-corner]=\"\r\n      isBottomRightCorner(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n  >\r\n    <!--  (mousedown)=\"startSelection(row.__virtualIndex, colIndex, subColIndex ?? 0, col.field, $event)\"\r\n  (mouseenter)=\"extendSelection(row.__virtualIndex, colIndex, subColIndex ?? 0, col.field, $event)\"\r\n  (mouseup)=\"endSelection()\"\r\n  [class.selected-cell]=\"isSelected(row.__virtualIndex, colIndex,  subColIndex ?? 0, col.field)\" -->\r\n    <div\r\n      class=\"table-cell\"\r\n      [class.active-for-editing]=\"\r\n        isEditing(row, col) &&\r\n        (getNestedValue(row, col.field)?.length === undefined ||\r\n          getNestedValue(row, col.field)?.length <= 50)\r\n      \"\r\n    >\r\n      <div\r\n        (click)=\"$event.stopPropagation()\"\r\n        *ngIf=\"\r\n          isEditing(row, col) &&\r\n            (getNestedValue(row, col.field)?.length === undefined ||\r\n              (getNestedValue(row, col.field)?.length <= 50 &&\r\n                !expandedCells.size));\r\n          else viewMode\r\n        \"\r\n      >\r\n\r\n       <ng-container *ngIf=\"col.cellEditor; else builtInEditors\">\r\n              <ng-container\r\n                [cellEditor]=\"col.cellEditor\"\r\n                [rowData]=\"row\"\r\n                [colData]=\"col\"\r\n                [cellValue]=\"getNestedValue(row, col.field)\"\r\n                (editorEvent)=\"finishEdit($event)\"\r\n              ></ng-container>\r\n        </ng-container>\r\n\r\n      <ng-template #builtInEditors>\r\n        <ng-container [ngSwitch]=\"col.type\">\r\n          <!-- Text Input -->\r\n          <input\r\n            [style.height.px]=\"rowHeight - 10\"\r\n            *ngSwitchCase=\"'input'\"\r\n            type=\"text\"\r\n            [(ngModel)]=\"row[col.field]\"\r\n            (blur)=\"disableEdit(row, col)\"\r\n            autofocus\r\n            class=\"form-control form-control-sm\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n\r\n          <!-- Number Input -->\r\n          <input\r\n            [style.height.px]=\"rowHeight - 8\"\r\n            *ngSwitchCase=\"'number'\"\r\n            #numberInput=\"ngModel\"\r\n            #numberRef\r\n            (keypress)=\"allowOnlyNumbers($event)\"\r\n            type=\"number\"\r\n            required\r\n            [(ngModel)]=\"row[col.field]\"\r\n            (blur)=\"disableEdit(row, col)\"\r\n            autofocus\r\n            (keydown.enter)=\"numberRef.blur()\"\r\n            class=\"form-control form-control-sm\"\r\n            [ngClass]=\"{\r\n              'is-invalid': numberInput.invalid\r\n            }\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n\r\n          <!-- Date Input -->\r\n          <input\r\n            [style.height.px]=\"rowHeight - 8\"\r\n            *ngSwitchCase=\"'date'\"\r\n            type=\"date\"\r\n            [(ngModel)]=\"row[col.field]\"\r\n            (blur)=\"disableEdit(row, col)\"\r\n            autofocus\r\n            class=\"form-control form-control-sm\"\r\n            #dateInput=\"ngModel\"\r\n            [ngClass]=\"{\r\n              'is-invalid': dateInput.invalid\r\n            }\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n\r\n          <!-- Dropdown -->\r\n          <!-- ng-select like dropdown -->\r\n          <div\r\n            *ngSwitchCase=\"'dropdown'\"\r\n            class=\"dropdown w-100\"\r\n            (blur)=\"disableEdit(row, col)\"\r\n          >\r\n            <!-- Trigger -->\r\n            <button\r\n              class=\"form-select form-select-sm text-start w-100 text-ellipsis\"\r\n              type=\"button\"\r\n              data-bs-toggle=\"dropdown\"\r\n              aria-expanded=\"false\"\r\n              [style.minHeight.px]=\"rowHeight - 10\"\r\n              data-bs-display=\"static\"\r\n              (mousedown)=\"$event.stopPropagation()\"\r\n            >\r\n              <ng-container>\r\n                {{\r\n                  getNestedValue(row, col.field)?.value ||\r\n                    getNestedValue(row, col.field)?.name ||\r\n                    getNestedValue(row, col.field)\r\n                }}\r\n              </ng-container>\r\n              <ng-template #placeholder> Select options... </ng-template>\r\n            </button>\r\n\r\n            <!-- Menu -->\r\n            <div\r\n              class=\"dropdown-menu w-100 p-0 cell-editing-dropdown-menu rounded-3\"\r\n              [class.show]=\"isEditing(row, col)\"\r\n            >\r\n              <!-- Search -->\r\n              <div class=\"px-2 py-1 editing-dropdown-search-input\" *ngIf=\"col?.column_dropdown_value?.length > 5\">\r\n                <input\r\n                  type=\"text\"\r\n                  class=\"form-control form-control-sm\"\r\n                  placeholder=\"Search...\"\r\n                  [(ngModel)]=\"editinDropdownSearch\"\r\n                  (mousedown)=\"$event.stopPropagation()\"\r\n                />\r\n              </div>\r\n              <cdk-virtual-scroll-viewport \r\n                    itemSize=\"35\" \r\n                    class=\"dropdown-viewport\"\r\n                    style=\"height: 120px\"\r\n                  >\r\n                    <div\r\n                    [class.selected]=\"getNestedValue(row, col.field) == option?.value || getNestedValue(row, col.field) == option\"\r\n                      class=\"px-2 py-1 d-flex align-items-center dropdown-item\"\r\n                      *cdkVirtualFor=\"\r\n                        let option of col.column_dropdown_value \r\n                          | filter : editinDropdownSearch : 'value'\r\n                      \"\r\n                      (click)=\"setNestedValue(row, col, option, true); editingKey = null\"\r\n                    >\r\n                      <label\r\n                        \r\n                        class=\"form-check-label d-flex align-items-center mb-0 cursor-pointer\"\r\n                        [for]=\"col.field + '-' + (option.value || option)\"\r\n                      >\r\n                        {{ option.value || option }}\r\n                      </label>\r\n                    </div>\r\n                </cdk-virtual-scroll-viewport>\r\n\r\n            </div>\r\n          </div>\r\n\r\n          <input\r\n            *ngSwitchCase=\"'email'\"\r\n            [style.height.px]=\"rowHeight - 10\"\r\n            [style.maxHeight.px]=\"rowHeight - 10\"\r\n            #emailModel=\"ngModel\"\r\n            #emailInput\r\n            type=\"email\"\r\n            [(ngModel)]=\"row[col.field]\"\r\n            name=\"{{ col.field }}\"\r\n            required\r\n            pattern=\"^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$\"\r\n            (blur)=\"disableEdit(row, col, emailModel)\"\r\n            (keydown.enter)=\"\r\n              emailModel.control.markAsTouched(); emailInput.blur()\r\n            \"\r\n            autofocus\r\n            class=\"form-control form-control-sm\"\r\n            [ngClass]=\"{\r\n              'is-invalid': emailModel.invalid\r\n            }\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n          <!-- Default fallback -->\r\n          <input\r\n            *ngSwitchDefault\r\n            [style.height.px]=\"rowHeight - 10\"\r\n            [style.maxHeight.px]=\"rowHeight - 10\"\r\n            #textModel=\"ngModel\"\r\n            #textInput\r\n            type=\"text\"\r\n            [(ngModel)]=\"row[col.field]\"\r\n            name=\"{{ col.field }}\"\r\n            required\r\n            (blur)=\"disableEdit(row, col, textModel)\"\r\n            (keydown.enter)=\"\r\n              textModel.control.markAsTouched(); textInput.blur()\r\n            \"\r\n            autofocus\r\n            class=\"form-control form-control-sm\"\r\n            [ngClass]=\"{\r\n              'is-invalid': textModel.invalid\r\n            }\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n        </ng-container>\r\n      </ng-template>\r\n\r\n      </div>\r\n\r\n      <!-- Display mode -->\r\n      <ng-template #viewMode>\r\n        <div\r\n          class=\"d-flex justify-content-between align-items-center w-100 overflow-hidden\"\r\n          [ngClass]=\"getCellClasses(col, getNestedValue(row, col.field))\"\r\n        >\r\n          <!-- Field icon (for Tasks grid) -->\r\n          <ng-container\r\n            *ngIf=\"gridType === 'Tasks' && iconMap[col.field] && !isTotalRow\"\r\n          >\r\n            <span\r\n              class=\"cursor-pointer me-2\"\r\n              (click)=\"$event.preventDefault(); $event.stopPropagation()\"\r\n              [inlineSVG]=\"iconMap[col.field](row, col)\"\r\n            ></span>\r\n          </ng-container>\r\n\r\n          <!-- ✅ Custom cell renderer support -->\r\n          <ng-container *ngIf=\"col.cellRenderer; else defaultCell\">\r\n            <ng-container\r\n              [cellRenderInit]=\"col.cellRenderer\"\r\n              [rowData]=\"row\"\r\n              [colData]=\"col\"\r\n              [cellValue]=\"getNestedValue(row, col?.field)\"\r\n              (cellEvent)=\"onCellEvent($event)\"\r\n            >\r\n            </ng-container>\r\n          </ng-container>\r\n\r\n          <!-- 🧾 Default text-based cell rendering -->\r\n          <ng-template #defaultCell>\r\n            <div\r\n              #cellText\r\n              class=\"text-ellipsis flex-grow-1\"\r\n              [title]=\"getCellTitle(row, col)\"\r\n            >\r\n              <!-- Normal cell -->\r\n              <ng-container\r\n                *ngIf=\"\r\n                  col.type !== 'image' &&\r\n                  col.field != 'image' &&\r\n                  col.field != 'invoice.invoice_image' &&\r\n                  !isTotalRow\r\n                \"\r\n              >\r\n                <ng-container *ngIf=\"col.is_amount\">{{\r\n                  currencySymbol\r\n                }}</ng-container>\r\n                {{getCellTitle(row, col)}}\r\n              </ng-container>\r\n\r\n              <!-- Total row -->\r\n              <ng-container *ngIf=\"isTotalRow\">\r\n                {{ getTotalAmount(col) }}\r\n              </ng-container>\r\n\r\n              <!-- Invoice Image -->\r\n              <ng-container *ngIf=\"col.field == 'invoice.invoice_image'\">\r\n                <div style=\"display: flex; align-items: center; zoom: 0.7\">\r\n                  <span\r\n                    title=\"{{ getNestedValue(row, col.field) || 'Attachment' }}\"\r\n                    (click)=\"downloadAttchment(getNestedValue(row, col.field))\"\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath +\r\n                      'data-grid/document-icons/' +\r\n                      getExtention(getNestedValue(row, col.field)) +\r\n                      '.svg'\r\n                    \"\r\n                  ></span>\r\n                </div>\r\n              </ng-container>\r\n\r\n              <!-- Image cell -->\r\n              <ng-container *ngIf=\"col.type == 'image' && !isTotalRow\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    defaultImagePlaceholder;\r\n                    context: { row: row, col: col }\r\n                  \"\r\n                ></ng-container>\r\n              </ng-container>\r\n            </div>\r\n            <span\r\n            *ngIf=\"\r\n              (!col?.cellRenderer && showCellDetailsBox &&\r\n                getNestedValue(row, col.field)?.length > 50 && col.type !== 'image') ||\r\n              (isNestedValueArray(row, col.field) &&\r\n                getNestedValue(row, col.field)?.length > 1)\r\n            \"\r\n            class=\"toggle-icon data-grid-svg-icon ms-2 cursor-pointer\"\r\n            [inlineSVG]=\"\r\n              isExpanded(row, col)\r\n                ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n                : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n            \"\r\n            (click)=\"\r\n              $event.stopPropagation();\r\n              toggleExpandOfLongCellText(row, col, columns, true)\r\n            \"\r\n            (dblclick)=\"$event.preventDefault(); $event.stopPropagation()\"\r\n          ></span>\r\n          </ng-template>\r\n          <!-- Expand / Collapse icon -->\r\n        </div>\r\n\r\n        <!-- Expanded text -->\r\n        <div\r\n          class=\"position-absolute w-100 expanded-box\"\r\n          *ngIf=\"isExpanded(row, col)\"\r\n          [style.zIndex]=\"getZIndex(row, col)\"\r\n          style=\"top: 100%; left: 0\"\r\n          [attr.id]=\"(row.id || row._id) + '-' + (col.id || col._id)\"\r\n          [class.invisible]=\"!showDetailsBox\"\r\n        >\r\n          <ng-container\r\n            *ngTemplateOutlet=\"\r\n              fullTextTemplate;\r\n              context: {\r\n                row: row,\r\n                col: col,\r\n                isArray: isNestedValueArray(row, col.field)\r\n              }\r\n            \"\r\n          ></ng-container>\r\n        </div>\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Headers Action List On clicking three dots -->\r\n\r\n<ng-template\r\n  #columnMenu\r\n  let-col=\"col\"\r\n  let-isNestedTable=\"isNestedTable\"\r\n  let-columns=\"columns\"\r\n  let-section=\"section\"\r\n>\r\n  <div\r\n    class=\"column-menu three-dots-col-menu\"\r\n    [class.visually-hidden]=\"isMenueHidden\"\r\n    *ngIf=\"activeCol && !isThreeDotsFilterOpen\"\r\n    [style.backgroundColor]=\"dropdownsBackgroundColor\"\r\n    (click)=\"$event.stopPropagation()\"\r\n    [style.color]=\"headerTextColor\"\r\n  >\r\n    <!-- Sort Ascending -->\r\n    <div class=\"border-below pb-2\" [class.disable-sorting]=\"!col.is_sortable\">\r\n      <span class=\"muted-text fs-7\" style=\"margin-left: 12px\">Sort</span>\r\n      <div\r\n        *ngIf=\"\r\n          columnThreedotsMunuConfig?.showAscending &&\r\n          (sortingConfig?.field != col.field ||\r\n            sortingConfig?.order_by == 'desc')\r\n        \"\r\n        class=\"column-menu-item\"\r\n        (click)=\"sortAsc(activeCol)\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-up.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n        Sort Ascending\r\n      </div>\r\n\r\n      <!-- Sort Descending -->\r\n      <div\r\n        *ngIf=\"\r\n          columnThreedotsMunuConfig?.showDescending &&\r\n          (sortingConfig?.field != col.field ||\r\n            sortingConfig?.order_by == 'asc')\r\n        \"\r\n        class=\"column-menu-item\"\r\n        (click)=\"sortDesc(activeCol)\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-down.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n        Sort Descending\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"\r\n          sortingConfig?.field === col.field &&\r\n          (sortingConfig?.order_by === 'asc' ||\r\n            sortingConfig?.order_by === 'desc')\r\n        \"\r\n        class=\"column-menu-item\"\r\n        (click)=\"resetSort(activeCol)\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/arrow-counterclockwise.svg'\r\n          \"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n        Reset Sort\r\n      </div>\r\n    </div>\r\n    <div class=\"py-2 border-below three-dots-filter\" [class.disable-sorting]=\"col.type == 'image'\">\r\n      <div\r\n        *ngIf=\"columnThreedotsMunuConfig?.showFilter\"\r\n        class=\"column-menu-item three-dots-filter\"\r\n        (click)=\"openFilteronThreeDotsClick(col)\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n        Filter\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"py-2 border-below\">\r\n      <span class=\"muted-text fs-7\" style=\"margin-left: 12px\">Pin</span>\r\n      <div\r\n        *ngIf=\"columnThreedotsMunuConfig?.showPinleft && col?.pinned !== 'left'\"\r\n        class=\"column-menu-item\"\r\n        (click)=\"\r\n          $event.stopPropagation();\r\n          updateColumnPinInSourceByField(\r\n            activeCol,\r\n            'left',\r\n            isNestedTable,\r\n            columns\r\n          )\r\n        \"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/pin-left.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span\r\n        >Pin Left\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"\r\n          columnThreedotsMunuConfig?.showPinright && col?.pinned !== 'right'\r\n        \"\r\n        class=\"column-menu-item\"\r\n        (click)=\"\r\n          $event.stopPropagation();\r\n          updateColumnPinInSourceByField(\r\n            activeCol,\r\n            'right',\r\n            isNestedTable,\r\n            columns\r\n          )\r\n        \"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/pin-right.svg'\"\r\n          class=\"data-grid-svg-icon data-grid-svg-icon me-2\"\r\n        ></span\r\n        >Pin Right\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"col?.pinned\"\r\n        class=\"column-menu-item\"\r\n        (click)=\"\r\n          $event.stopPropagation();\r\n          updateColumnPinInSourceByField(\r\n            activeCol,\r\n            null,\r\n            isNestedTable,\r\n            columns\r\n          )\r\n        \"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/layout-three-columns.svg'\r\n          \"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span\r\n        >Unpin\r\n      </div>\r\n    </div>\r\n\r\n    <div\r\n      *ngIf=\"columnThreedotsMunuConfig?.showAutosizeThisColumn\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"autosizeColumn(activeCol)\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"\r\n          singleSpaAssetsPath + 'data-grid/icons/arrows-expand-vertical.svg'\r\n        \"\r\n        class=\"me-2\"\r\n      ></span>\r\n      Autosize This Column\r\n    </div>\r\n\r\n    <!-- Autosize All Columns -->\r\n    <div\r\n      *ngIf=\"columnThreedotsMunuConfig?.showAutosizeAllColumns\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"autosizeAllColumns()\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"\r\n          singleSpaAssetsPath + 'data-grid/icons/arrows-angle-expand.svg'\r\n        \"\r\n        class=\"data-grid-svg-icon me-2\"\r\n      ></span\r\n      >Autosize All Columns\r\n    </div>\r\n\r\n    <!-- Group By -->\r\n    <div\r\n      *ngIf=\"showRowsGrouping\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"groupBy(activeCol)\"\r\n      [class.disable-sorting]=\"!col.is_groupable\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/diagram-3.svg'\"\r\n        class=\"data-grid-svg-icon me-2\"\r\n      ></span>\r\n      Group by {{ col.header }}\r\n    </div>\r\n\r\n    <!-- Choose Columns -->\r\n    <div\r\n      *ngIf=\"columnThreedotsMunuConfig?.showChoseColumns\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"chooseColumns()\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/ui-checks-grid.svg'\"\r\n        class=\"data-grid-svg-icon me-2\"\r\n      ></span>\r\n      Choose Columns\r\n    </div>\r\n\r\n    <!-- Reset Columns -->\r\n    <div\r\n      *ngIf=\"columnThreedotsMunuConfig?.showResetColumns\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"resetColumns()\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"\r\n          singleSpaAssetsPath + 'data-grid/icons/arrow-counterclockwise.svg'\r\n        \"\r\n        class=\"data-grid-svg-icon me-2\"\r\n      ></span\r\n      >Reset Columns\r\n    </div>\r\n  </div>\r\n  <div\r\n    @slideToggle\r\n    *ngIf=\"isThreeDotsFilterOpen\"\r\n    class=\"three-dots-col-menu position-relative\"\r\n    [style.right.px]=\"section == 'right' ? null : col.width - 45\"\r\n    [class.visually-hidden]=\"isMenueHidden\"\r\n  >\r\n    <ng-container\r\n      *ngTemplateOutlet=\"filterMenu; context: { col: col }\"\r\n    ></ng-container>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Filter Menue -->\r\n<ng-template #filterMenu let-col=\"col\">\r\n  <div\r\n    class=\"filter-menu-container filter-menu\"\r\n    [style.backgroundColor]=\"dropdownsBackgroundColor\"\r\n  >\r\n    <!-- Dropdown Type -->\r\n    <ng-container *ngIf=\"col.type === 'dropdown'; else textFilter\">\r\n      <div class=\"filter-dropdown-section p-1\">\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Search...\"\r\n          type=\"search\"\r\n          [(ngModel)]=\"addFilterColumnInput\"\r\n        />\r\n\r\n        <div class=\"form-check mb-1 mt-2 ms-1 select-all-filter\">\r\n          <input\r\n            class=\"form-check-input\"\r\n            type=\"checkbox\"\r\n            [checked]=\"isAllSideFilterOptionsSelected(col)\"\r\n            (change)=\"toggleSelectAllSideFilters(col, $event)\"\r\n            id=\"selectAll_{{ col.field }}\"\r\n          />\r\n          <label class=\"form-check-label\" for=\"selectAll_{{ col.field }}\">\r\n            Select All\r\n          </label>\r\n        </div>\r\n\r\n        <!-- <div class=\"dropdown-options ps-1\">\r\n          <div\r\n            class=\"form-check mb-1\"\r\n            *ngFor=\"\r\n              let option of selectedColumnForFilter?.column_dropdown_value\r\n                | filter : addFilterColumnInput : 'value';\r\n              trackBy: trackById;\r\n              let i = index\r\n            \"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              [id]=\"i\"\r\n              [checked]=\"\r\n                currentFilterSelectedIds.has(option?.id ?? option?._id ?? option)\r\n              \"\r\n              (change)=\"toggleSelectionInFilter(option)\"\r\n            />\r\n            <label class=\"form-check-label fw-semibold\" [for]=\"i\">\r\n              {{ option?.value ?? option?.name ?? option }}\r\n            </label>\r\n          </div>\r\n        </div> -->\r\n        <cdk-virtual-scroll-viewport\r\n              itemSize=\"32\"\r\n              class=\"filter-viewport\"\r\n              style=\"height: 120px\"\r\n            >\r\n              <div\r\n                class=\"form-check mb-1 ms-1\"\r\n                *cdkVirtualFor=\"\r\n                  let option of selectedColumnForFilter?.column_dropdown_value\r\n                    | filter : addFilterColumnInput : 'value';\r\n                  trackBy: trackById\r\n                \"\r\n              >\r\n                <input\r\n                  class=\"form-check-input\"\r\n                  type=\"checkbox\"\r\n                  [id]=\"option?.id ?? option?._id ?? option\"\r\n                  [checked]=\"\r\n                    currentFilterSelectedIds.has(option?.id ?? option?._id ?? option)\r\n                  \"\r\n                  (change)=\"toggleSelectionInFilter(option)\"\r\n                />\r\n\r\n                <label\r\n                  class=\"form-check-label fw-semibold\"\r\n                  [for]=\"option?.id ?? option?._id ?? option\"\r\n                >\r\n                  {{ option?.value ?? option?.name ?? option }}\r\n                </label>\r\n              </div>\r\n          </cdk-virtual-scroll-viewport>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Text Filter Section -->\r\n    <ng-template #textFilter>\r\n      <div class=\"filter-text-section\">\r\n        <div class=\"form-group mb-2\">\r\n          <select\r\n            class=\"form-select form-select-sm custom-select\"\r\n            [(ngModel)]=\"firstCondition\"\r\n          >\r\n            <ng-container *ngIf=\"selectedColumnForFilter.type !== 'date'\">\r\n              <option value=\"contain\">Contains</option>\r\n              <option value=\"does_not_contain\">Does Not Contain</option>\r\n              <option value=\"equal\">Equals</option>\r\n              <option value=\"before\">Starts With</option>\r\n              <option value=\"after\">Ends With</option>\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"selectedColumnForFilter.type == 'date'\">\r\n              <option value=\"equal\">Equals To</option>\r\n              <option value=\"not_equal\">Not Equal</option>\r\n              <option value=\"after\">After</option>\r\n              <option value=\"before\">Before</option>\r\n            </ng-container>\r\n          </select>\r\n        </div>\r\n\r\n        <input\r\n          [type]=\"col.type == 'string' ? 'text' : col.type\"\r\n          class=\"form-control form-control-sm mb-3\"\r\n          placeholder=\"Value\"\r\n          [(ngModel)]=\"firstValue\"\r\n          #filterMenueTextchInput\r\n          (keydown.enter)=\"applyDropdownFilter()\"\r\n        />\r\n\r\n        <div class=\"form-group mb-3 d-flex flex-row\">\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"condition\"\r\n              value=\"and\"\r\n              id=\"and_{{ col.field }}\"\r\n              (change)=\"cdr.detectChanges()\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"and_{{ col.field }}\"\r\n              >AND</label\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1 gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"condition\"\r\n              value=\"or\"\r\n              id=\"or_{{ col.field }}\"\r\n              (change)=\"cdr.detectChanges()\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"or_{{ col.field }}\"\r\n              >OR</label\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1 gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"condition\"\r\n              value=\"none\"\r\n              id=\"none_{{ col.field }}\"\r\n              (change)=\"cdr.detectChanges()\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"none_{{ col.field }}\"\r\n              >None</label\r\n            >\r\n          </div>\r\n        </div>\r\n        <div @slideToggle *ngIf=\"firstValue && condition != 'none'\">\r\n          <div class=\"form-group mb-2\">\r\n            <select\r\n              class=\"form-select form-select-sm custom-select\"\r\n              [(ngModel)]=\"secondCondition\"\r\n            >\r\n              <ng-container *ngIf=\"selectedColumnForFilter.type !== 'date'\">\r\n                <option value=\"contain\">Contains</option>\r\n                <option value=\"does_not_contain\">Does Not Contain</option>\r\n                <option value=\"equal\">Equals</option>\r\n                <option value=\"before\">Starts With</option>\r\n                <option value=\"after\">Ends With</option>\r\n              </ng-container>\r\n\r\n              <ng-container *ngIf=\"selectedColumnForFilter.type == 'date'\">\r\n                <option value=\"equal\">Equals To</option>\r\n                <option value=\"not_equal\">Not Equal</option>\r\n                <option value=\"after\">After</option>\r\n                <option value=\"before\">Before</option>\r\n              </ng-container>\r\n            </select>\r\n          </div>\r\n\r\n          <input\r\n            [type]=\"col.type == 'string' ? 'text' : col.type\"\r\n            class=\"form-control form-control-sm mb-3\"\r\n            placeholder=\"Second Value\"\r\n            [(ngModel)]=\"secondValue\"\r\n          />\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <!-- Actions -->\r\n    <div class=\"d-flex gap-2 mt-2\">\r\n      <div\r\n        class=\"btn btn-sm btn-primary d-flex justify-content-center align-items-center w-100\"\r\n        style=\"height: 30px\"\r\n        (click)=\"applyDropdownFilter()\"\r\n      >\r\n        Apply\r\n      </div>\r\n      <div\r\n        class=\"btn btn-sm btn-secondary d-flex justify-content-center align-items-center w-100\"\r\n        style=\"height: 30px\"\r\n        (click)=\"resetSideFilter(col)\"\r\n      >\r\n        Reset\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Side Menue -->\r\n\r\n<!-- Column Pannel / Pivot Mode / Searching -->\r\n\r\n<ng-template #columnPannel>\r\n  <div class=\"column-panel-header\">\r\n    <!-- Pivot Toggle -->\r\n    <div\r\n      class=\"form-check form-switch d-flex align-items-center mb-2 pivot-mode px-5 ms-2 d-none\"\r\n    >\r\n      <input\r\n        class=\"form-check-input me-2\"\r\n        type=\"checkbox\"\r\n        id=\"pivotToggle\"\r\n        [(ngModel)]=\"pivotMode\"\r\n      />\r\n      <label class=\"form-check-label\" for=\"pivotToggle\">Pivot Mode</label>\r\n    </div>\r\n\r\n    <!-- Select All & Search -->\r\n    <div class=\"d-flex align-items-center mb-2 px-3 mt-3\">\r\n      <span class=\"filter-icon-wrapper me-2\" *ngIf=\"showColumnsGrouping\">\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            accordionState === 'all'\r\n              ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n              : accordionState === 'some'\r\n              ? singleSpaAssetsPath + 'data-grid/icons/dash.svg'\r\n              : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          (click)=\"toggleAllAccordions()\"\r\n        ></span>\r\n      </span>\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input me-2\"\r\n        [checked]=\"allColumnsSelected()\"\r\n        (change)=\"toggleAllColumnsVisibility()\"\r\n      />\r\n      <input\r\n        type=\"text\"\r\n        class=\"form-control form-control-sm\"\r\n        placeholder=\"Search columns...\"\r\n        [(ngModel)]=\"columnSearch\"\r\n      />\r\n    </div>\r\n\r\n    <!-- Separator -->\r\n    <hr class=\"my-2\" />\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Right Columns Menue -->\r\n\r\n<!-- Column Panel Item Template -->\r\n<ng-template #columnPanelItem let-col=\"col\">\r\n  <!-- Group Column -->\r\n  <ng-container *ngIf=\"col.children?.length\">\r\n    <div class=\"column-group d-flex align-items-center mb-2\">\r\n      <span class=\"filter-icon-wrapper me-2\">\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          [class.rotate]=\"col.expanded\"\r\n          (click)=\"col.expanded = !col.expanded\"\r\n        ></span>\r\n      </span>\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input me-2\"\r\n        [id]=\"'group_' + col.header\"\r\n        [checked]=\"isColumnVisible(col)\"\r\n        (change)=\"toggleGroupVisibility(col)\"\r\n      />\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/grid-3x2-gap.svg'\"\r\n        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center me-2\"\r\n      ></span>\r\n      <label\r\n        class=\"d-flex align-items-center mb-0 w-100\"\r\n        [for]=\"'group_' + col.header\"\r\n        style=\"cursor: pointer\"\r\n      >\r\n        <span class=\"text-truncate\">{{ col.header }}</span>\r\n      </label>\r\n    </div>\r\n    <div *ngIf=\"col.expanded\" class=\"ps-4\">\r\n      <ng-container *ngFor=\"let child of col.children; trackBy: trackByField\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"columnPanelItem; context: { col: child }\"\r\n        ></ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <!-- Leaf Column -->\r\n  <ng-container *ngIf=\"!col.children?.length\">\r\n    <div class=\"d-flex align-items-center mb-2\">\r\n      <span class=\"me-2\" style=\"width: 1.5rem\"></span>\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input me-2\"\r\n        [(ngModel)]=\"col.is_visible\"\r\n        [id]=\"'col_' + col.field\"\r\n        (change)=\"onSideMenuColumnsVisibilityChange()\"\r\n      />\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/grid-3x2-gap.svg'\"\r\n        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center me-2\"\r\n      ></span>\r\n      <label\r\n        class=\"d-flex align-items-center mb-0 w-100\"\r\n        [for]=\"'col_' + col.field\"\r\n        style=\"cursor: pointer\"\r\n      >\r\n        <span class=\"text-truncate\">{{ col.header }}</span>\r\n      </label>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<!-- Columns Side Filter -->\r\n<ng-template #sideFilters>\r\n  <div class=\"py-3 px-2 pe-3 h-100\">\r\n    <div class=\"d-flex align-items-center mb-2\">\r\n      <span class=\"filter-icon-wrapper me-2\" *ngIf=\"showColumnsGrouping\">\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            filterAccordionState === 'all'\r\n              ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n              : filterAccordionState === 'some'\r\n              ? singleSpaAssetsPath + 'data-grid/icons/dash.svg'\r\n              : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          (click)=\"toggleAllFilterAccordions()\"\r\n        ></span>\r\n      </span>\r\n      <input\r\n        type=\"text\"\r\n        class=\"form-control form-control-sm\"\r\n        placeholder=\"Search...\"\r\n        [(ngModel)]=\"columnSearch\"\r\n      />\r\n    </div>\r\n    <div\r\n      class=\"overflow-auto side-filter-columns-wrapper\"\r\n      style=\"height: calc(100% - 70px); scrollbar-width: thin\"\r\n    >\r\n      <ng-container\r\n        *ngFor=\"\r\n          let col of columns | filter : columnSearch : 'header';\r\n          trackBy: trackByField\r\n        \"\r\n      >\r\n        <ng-container\r\n          *ngTemplateOutlet=\"filterPannelItem; context: { col: col }\"\r\n        ></ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #filterPannelItem let-col=\"col\">\r\n  <!-- Group Column -->\r\n  <ng-container *ngIf=\"col.children?.length\">\r\n    <div\r\n      class=\"column-group d-flex align-items-center mb-2\"\r\n      *ngIf=\"col.type !== 'image'\"\r\n    >\r\n      <!-- Chevron toggle -->\r\n      <span class=\"filter-icon-wrapper me-2\">\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          [class.rotate]=\"col.expandedFilter\"\r\n          (click)=\"col.expandedFilter = !col.expandedFilter\"\r\n        ></span>\r\n      </span>\r\n\r\n      <!-- Group label toggle -->\r\n      <label\r\n        class=\"d-flex align-items-center mb-0 w-100\"\r\n        style=\"cursor: pointer\"\r\n        (click)=\"col.expandedFilter = !col.expandedFilter\"\r\n      >\r\n        <span class=\"fw-bold text-truncate\"\r\n          >{{ col.header }}\r\n          <span\r\n            class=\"text-primary ms-1\"\r\n            *ngIf=\"col?.query?._ids?.length || col?.query?._first_value\"\r\n            >*</span\r\n          >\r\n        </span>\r\n      </label>\r\n    </div>\r\n\r\n    <!-- Children columns -->\r\n    <div *ngIf=\"col.expandedFilter\" class=\"ps-4\">\r\n      <ng-container *ngFor=\"let child of col.children; trackBy: trackByField\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"filterPannelItem; context: { col: child }\"\r\n        ></ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <!-- Leaf Column -->\r\n  <ng-container *ngIf=\"!col.children?.length\">\r\n    <div class=\"d-flex align-items-center mb-2\" *ngIf=\"col.type !== 'image'\">\r\n      <span\r\n        class=\"me-2 filter-icon-wrapper me-2\"\r\n        (click)=\"col.expandedFilter = !col.expandedFilter\"\r\n      >\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          [class.rotate]=\"col.expandedFilter\"\r\n        ></span>\r\n      </span>\r\n\r\n      <label\r\n        class=\"d-flex align-items-center mb-0 w-100\"\r\n        style=\"cursor: pointer\"\r\n        (click)=\"col.expandedFilter = !col.expandedFilter\"\r\n      >\r\n        <span class=\"text-truncate fw-bold\">{{ col.header }}</span>\r\n      </label>\r\n    </div>\r\n\r\n    <!-- Show filter when expanded -->\r\n    <div *ngIf=\"col.expandedFilter\" class=\"ps-4 pe-3\">\r\n      <ng-container\r\n        *ngTemplateOutlet=\"sideNestedFilter; context: { col: col }\"\r\n      ></ng-container>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<!-- Side Nested Filters -->\r\n<ng-template #sideNestedFilter let-col=\"col\">\r\n  <div class=\"\">\r\n    <!-- Dropdown Type -->\r\n    <ng-container *ngIf=\"col.type === 'dropdown'; else textFilter\">\r\n      <div class=\"p-1\">\r\n        <!-- Search -->\r\n        <input\r\n          type=\"text\"\r\n          class=\"form-control form-control-sm mb-2\"\r\n          placeholder=\"Search...\"\r\n          [(ngModel)]=\"sideNestedFilterSearch\"\r\n        />\r\n\r\n        <!-- Select All -->\r\n        <div class=\"form-check mb-1 ms-1 select-all-filter\">\r\n          <input\r\n            class=\"form-check-input\"\r\n            type=\"checkbox\"\r\n            [checked]=\"\r\n              col.query?._ids?.length == col?.column_dropdown_value?.length\r\n            \"\r\n            (change)=\"toggleSelectAllSideFilters(col, $event)\"\r\n            id=\"selectAll_{{ col.field }}\"\r\n          />\r\n          <label class=\"form-check-label\" for=\"selectAll_{{ col.field }}\">\r\n            Select All\r\n          </label>\r\n        </div>\r\n\r\n        <!-- Options -->\r\n        <!-- <div class=\"dropdown-options\">\r\n          <div\r\n            class=\"form-check mb-1 ms-1\"\r\n            *ngFor=\"\r\n              let option of col?.column_dropdown_value\r\n                | filter : sideNestedFilterSearch : 'value'\r\n            \"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              [value]=\"option\"\r\n              [checked]=\"\r\n                col.query?._ids?.includes(option?._id || option?.id || option)\r\n              \"\r\n              (change)=\"onOptionToggle(col, option)\"\r\n              id=\"option_{{ col.field }}_{{\r\n                option?.id || option?._id || option\r\n              }}\"\r\n            />\r\n            <label\r\n              class=\"form-check-label\"\r\n              [for]=\"\r\n                'option_' +\r\n                col.field +\r\n                '_' +\r\n                (option?.id || option?._id || option)\r\n              \"\r\n            >\r\n              {{ option.value || option }}\r\n            </label>\r\n          </div>\r\n        </div> -->\r\n        <cdk-virtual-scroll-viewport\r\n            itemSize=\"32\"\r\n            class=\"dropdown-viewport\"\r\n            style=\"height: 120px\"\r\n          >\r\n            <div\r\n              class=\"form-check mb-1 ms-1\"\r\n              *cdkVirtualFor=\"\r\n                let option of col?.column_dropdown_value\r\n                  | filter : sideNestedFilterSearch : 'value'\r\n              \"\r\n            >\r\n              <input\r\n                class=\"form-check-input\"\r\n                type=\"checkbox\"\r\n                [value]=\"option\"\r\n                [checked]=\"\r\n                  col.query?._ids?.includes(option?._id || option?.id || option)\r\n                \"\r\n                (change)=\"onOptionToggle(col, option)\"\r\n                id=\"option_{{ col.field }}_{{\r\n                  option?.id || option?._id || option\r\n                }}\"\r\n              />\r\n\r\n              <label\r\n                class=\"form-check-label\"\r\n                [for]=\"\r\n                  'option_' +\r\n                  col.field +\r\n                  '_' +\r\n                  (option?.id || option?._id || option)\r\n                \"\r\n              >\r\n                {{ option.value || option }}\r\n              </label>\r\n            </div>\r\n          </cdk-virtual-scroll-viewport>\r\n\r\n\r\n        <!-- Actions -->\r\n        <!-- <div class=\"d-flex gap-2 mt-2\">\r\n      <div\r\n        class=\"btn btn-sm btn-primary d-flex justify-content-center align-items-center\"\r\n        style=\"height: 22px;\"\r\n        (click)=\"applySideFilter(col)\"\r\n      >\r\n        Apply\r\n      </div>\r\n      <div\r\n        class=\"btn btn-sm btn-secondary d-flex justify-content-center align-items-center\" \r\n        style=\"height: 22px;\"\r\n        (click)=\"resetSideFilter(col)\"\r\n      >\r\n        Reset\r\n      </div>\r\n    </div> -->\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Text Filter Section -->\r\n    <ng-template #textFilter>\r\n      <div class=\"filter-text-section\">\r\n        <div class=\"form-group mb-2\">\r\n          <select\r\n            class=\"form-select form-select-sm\"\r\n            [(ngModel)]=\"col.query.first_condition\"\r\n          >\r\n            <ng-container *ngIf=\"col.type !== 'date'\">\r\n              <option value=\"contain\">Contains</option>\r\n               <option value=\"does_not_contain\">Does Not Contain</option>\r\n              <option value=\"equal\">Equals</option>\r\n              <option value=\"before\">Starts With</option>\r\n              <option value=\"after\">Ends With</option>\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"col.type == 'date'\">\r\n              <option value=\"equal\">Equals To</option>\r\n               <option value=\"not_equal\">Not Equal</option>\r\n              <option value=\"after\">After</option>\r\n              <option value=\"before\">Before</option>\r\n            </ng-container>\r\n          </select>\r\n        </div>\r\n\r\n        <input\r\n          [type]=\"col.type == 'date' ? 'date' : 'text'\"\r\n          class=\"form-control form-control-sm mb-3\"\r\n          placeholder=\"Value\"\r\n          [(ngModel)]=\"col!.query!.first_value\"\r\n        />\r\n\r\n        <div\r\n          class=\"form-group mb-3 d-flex flex-row muted\"\r\n          style=\"font-size: 14px\"\r\n        >\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"col!.query.condition\"\r\n              value=\"and\"\r\n              id=\"and_{{ col.field }}\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"and_{{ col.field }}\"\r\n              >AND</label\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"col!.query.condition\"\r\n              value=\"or\"\r\n              id=\"or_{{ col.field }}\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"or_{{ col.field }}\"\r\n              >OR</label\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"col!.query.condition\"\r\n              value=\"none\"\r\n              id=\"none_{{ col.field }}\"\r\n            />\r\n            <label\r\n              class=\"nnonem-check-label mb-0 mt-1\"\r\n              for=\"none_{{ col.field }}\"\r\n              >None</label\r\n            >\r\n          </div>\r\n        </div>\r\n        <ng-container\r\n          *ngIf=\"col?.query?.first_value && col?.query?.condition !== 'none'\"\r\n        >\r\n          <div class=\"form-group mb-2\">\r\n            <select\r\n              class=\"form-select form-select-sm\"\r\n              [(ngModel)]=\"col!.query.second_condition\"\r\n            >\r\n              <ng-container *ngIf=\"col.type !== 'date'\">\r\n                <option value=\"contain\">Contains</option>\r\n                <option value=\"does_not_contain\">Does Not Contain</option>\r\n                <option value=\"equal\">Equals</option>\r\n                <option value=\"before\">Starts With</option>\r\n                <option value=\"after\">Ends With</option>\r\n              </ng-container>\r\n\r\n              <ng-container *ngIf=\"col.type == 'date'\">\r\n                <option value=\"equal\">Equals To</option>\r\n                 <option value=\"not_equal\">Not Equal</option>\r\n                <option value=\"after\">After</option>\r\n                <option value=\"before\">Before</option>\r\n              </ng-container>\r\n            </select>\r\n          </div>\r\n\r\n          <input\r\n            [type]=\"col.type == 'date' ? 'date' : 'text'\"\r\n            class=\"form-control form-control-sm mb-3\"\r\n            placeholder=\"Second Value\"\r\n            [(ngModel)]=\"col!.query.second_value\"\r\n          />\r\n        </ng-container>\r\n        <!-- <div class=\"d-flex gap-2\">\r\n          <div class=\"btn btn-sm btn-primary d-flex justify-content-center align-items-center\" style=\"height: 22px;\" (click)=\"applyDropdownFilter()\">apply</div>\r\n          <div class=\"btn btn-sm btn-secondary d-flex justify-content-center align-items-center\" style=\"height: 22px;\" (click)=\"applyDropdownFilter()\">reset</div>\r\n\r\n        </div> -->\r\n      </div>\r\n    </ng-template>\r\n    <div\r\n      class=\"d-flex justify-content-center gap-2 border-top\"\r\n      style=\"height: 38px\"\r\n    >\r\n      <button\r\n        type=\"button\"\r\n        style=\"max-height: 30px\"\r\n        class=\"btn btn-outline-secondary btn-light border w-100 d-flex align-items-center justify-content-center mt-1 btn-light\"\r\n        (click)=\"$event.stopPropagation(); removeSideFilter(col)\"\r\n      >\r\n        <span>Clear</span>\r\n      </button>\r\n      <button\r\n        type=\"button\"\r\n        style=\"max-height: 30px\"\r\n        class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center mt-1\"\r\n        (click)=\"applySideFilter(col)\"\r\n        [class.disabled]=\"(col?.query.condition !== 'none' && !col?.query?.second_value)\"\r\n        [class.pe-none]=\"(col!?.query.condition !== 'none' && !col?.query?.second_value)\"\r\n      >\r\n        <span style=\"margin-top: -1px\">Apply</span>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Centr Overlay for showing the chose columns -->\r\n\r\n<div *ngIf=\"showColumnPanel\" class=\"custom-modal-overlay\">\r\n  <div\r\n    class=\"custom-modal-content\"\r\n    [style.backgroundColor]=\"dropdownsBackgroundColor\"\r\n    (click)=\"$event.stopPropagation()\"\r\n  >\r\n    <ng-container *ngTemplateOutlet=\"modalColumnPannel\"></ng-container>\r\n  </div>\r\n</div>\r\n\r\n<!-- The existing ng-template you provided -->\r\n<ng-template #modalColumnPannel>\r\n  <div class=\"column-panel-header\">\r\n    <div\r\n      class=\"d-flex justify-content-between align-items-center px-2 ps-3 rounded-top-2 moda-header\"\r\n      [style.height.px]=\"48\"\r\n    >\r\n      Choose Columns\r\n      <span class=\"filter-icon-wrapper\" (click)=\"closeModalColumnPanel()\"\r\n        ><span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/x.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span\r\n      ></span>\r\n    </div>\r\n    <hr class=\"my-0\" />\r\n    <div>\r\n      <div class=\"d-flex align-items-center px-2 pe-3\" [style.height.px]=\"48\">\r\n        <span class=\"filter-icon-wrapper me-2\" *ngIf=\"showColumnsGrouping\">\r\n          <span\r\n            class=\"toggle-icon data-grid-svg-icon\"\r\n            [inlineSVG]=\"\r\n              accordionState === 'all'\r\n                ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n                : accordionState === 'some'\r\n                ? singleSpaAssetsPath + 'data-grid/icons/dash.svg'\r\n                : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n            \"\r\n            (click)=\"toggleAllAccordions()\"\r\n          ></span>\r\n        </span>\r\n        <input\r\n          type=\"checkbox\"\r\n          class=\"form-check-input me-2\"\r\n          [checked]=\"allColumnsSelected()\"\r\n          (change)=\"toggleAllColumnsVisibility()\"\r\n        />\r\n        <input\r\n          type=\"text\"\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Search columns...\"\r\n          [(ngModel)]=\"choseColumnsSearch\"\r\n        />\r\n      </div>\r\n\r\n      <hr class=\"mt-0 mb-1\" />\r\n      <div class=\"px-2 overlay-scrollable\">\r\n        <ng-container\r\n          *ngFor=\"\r\n            let col of columns | filter : choseColumnsSearch : 'header';\r\n            trackBy: trackByField\r\n          \"\r\n        >\r\n          <ng-container\r\n            *ngTemplateOutlet=\"columnPanelItem; context: { col: col }\"\r\n          ></ng-container>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #sideMenuRowGroups>\r\n  <div class=\"d-flex flex-column h-100 d-none\">\r\n    <div class=\"px-3 h-100\">\r\n      <div class=\"d-flex gap-3 mb-4\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/justify.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span>\r\n        <span>Row Groups</span>\r\n      </div>\r\n      <div class=\"h-50\">\r\n        <div\r\n          class=\"px-3 py-2 border-dashed h-100 d-flex justify-content-center align-items-center\"\r\n          style=\"font-size: 14px\"\r\n        >\r\n          Drag here to set row Groups\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <hr class=\"mt-4\" />\r\n\r\n    <div class=\"px-3 h-100\">\r\n      <div class=\"d-flex gap-3 mb-4\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/justify.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span>\r\n        <span>Values</span>\r\n      </div>\r\n      <div class=\"h-50 d-flex\">\r\n        <div\r\n          class=\"px-3 py-2 border-dashed h-100 d-flex justify-content-center align-items-center\"\r\n          style=\"font-size: 14px\"\r\n        >\r\n          Drag here aggregate\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- *************************************************** -->\r\n<!-- *************************************************** -->\r\n<!-- *************************************************** -->\r\n<!-- Drag Preview Template -->\r\n<!-- *************************************************** -->\r\n<!-- *************************************************** -->\r\n<ng-template #dragPreview let-col>\r\n  <div class=\"p-2 border d-flex gap-2\">\r\n    <div>\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrows-move.svg'\"\r\n        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n      ></span>\r\n    </div>\r\n    <div>{{ col.header }}</div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Drag Placeholder Template -->\r\n<ng-template\r\n  #dragPlaceholder\r\n  let-col\r\n  let-i=\"index\"\r\n  let-section=\"section\"\r\n  let-draggingInGroupArea=\"draggingInGroupArea\"\r\n>\r\n  <div *ngIf=\"!draggingInGroupArea\">\r\n    <div\r\n      *ngTemplateOutlet=\"\r\n        headerCell;\r\n        context: { $implicit: col, index: i, section: section }\r\n      \"\r\n    ></div>\r\n  </div>\r\n  <div *ngIf=\"draggingInGroupArea\">New Placeholder</div>\r\n</ng-template>\r\n\r\n<!-- Top Group Row Placeholder -->\r\n<ng-template #topGroupingRowPlaceholder let-col let-showChevron=\"showChevron\">\r\n  <div class=\"d-flex gap-2\">\r\n    <div\r\n      class=\"d-flex gap-2 top-row-grouping-placeholder\"\r\n      [style.backgroundColor]=\"topGroupedBadgesBackgroundColor\"\r\n    >\r\n      <span\r\n        cdkDragHandle\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/grid-3x2-gap.svg'\"\r\n        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n      ></span>\r\n      <span>{{ col.header }}</span>\r\n      <span\r\n        (click)=\"ungroupColumn(col)\"\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/x.svg'\"\r\n        class=\"cursor-pointer data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n      ></span>\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"showChevron\" style=\"opacity: 0.6; font-size: 14px\">\r\n    <span\r\n      [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\"\r\n      class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n    ></span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #childHeaderPlaceholder\r\n  let-col\r\n  let-pinnedRight=\"pinnedRight\"\r\n  let-i=\"index\"\r\n  let-sections=\"sections\"\r\n>\r\n  <div\r\n    class=\"header-cell one-row-header-cells\"\r\n    [class.border-right]=\"showVerticalBorder\"\r\n    [style.width.px]=\"col.width\"\r\n    [style.min-width.px]=\"col.width\"\r\n    [style.min-height.px]=\"headerRowHeight\"\r\n    [style.max-height.px]=\"headerRowHeight\"\r\n    [style.fontWeight]=\"headerFontWeight\"\r\n  >\r\n    <div class=\"d-flex justify-content-between h-100 align-items-center w-100\">\r\n      <div\r\n        class=\"d-flex justify-content-between align-items-center w-100\"\r\n        [class.flex-row-reverse]=\"pinnedRight\"\r\n      >\r\n        <div\r\n          class=\"text-ellipsis h-100 d-flex align-items-center\"\r\n          [title]=\"col.header\"\r\n          [class.w-100]=\"pinnedRight\"\r\n        >\r\n          {{ col.header }}\r\n        </div>\r\n\r\n        <div\r\n          class=\"position-relative d-flex\"\r\n          [class.flex-row-reverse]=\"pinnedRight\"\r\n        >\r\n          <div class=\"three-dots p-1\" style=\"cursor: pointer\">\r\n            <span\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath + 'data-grid/icons/three-dots-vertical.svg'\r\n              \"\r\n              class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n            ></span>\r\n          </div>\r\n\r\n          <div class=\"resize-handle\">\r\n            <span\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath + 'data-grid/icons/resize-handle.svg'\r\n              \"\r\n              class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n            ></span>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div\r\n    *ngIf=\"showFilterRow\"\r\n    [style.backgroundColor]=\"headerBackgroundColor\"\r\n    class=\"header-cell filter-cell\"\r\n    [class.border-right]=\"showVerticalBorder\"\r\n    [style.width.px]=\"col.width\"\r\n    [style.min-width.px]=\"col.width\"\r\n    [style.height.px]=\"headerRowHeight\"\r\n    [style.min-height.px]=\"headerRowHeight\"\r\n    [style.max-height.px]=\"headerRowHeight\"\r\n    [class.border-right]=\"showVerticalBorder\"\r\n    style=\"grid-row: 3\"\r\n  >\r\n    <div\r\n      class=\"header-cell filter-cell\"\r\n      [style.backgroundColor]=\"headerBackgroundColor\"\r\n      [style.width.px]=\"col.width\"\r\n      [style.min-width.px]=\"col.width\"\r\n      [style.height.px]=\"headerRowHeight\"\r\n      [style.min-height.px]=\"headerRowHeight\"\r\n      [style.max-height.px]=\"headerRowHeight\"\r\n    >\r\n      <input\r\n        type=\"text\"\r\n        class=\"form-control form-control-sm\"\r\n        placeholder=\"Filter\"\r\n        [(ngModel)]=\"col.filterValue\"\r\n        [readonly]=\"col?.type == 'dropdown' || col?.type == 'image'\"\r\n        [class.disabled-search-input]=\"\r\n          col?.type == 'dropdown' || col?.type == 'image'\r\n        \"\r\n      />\r\n      <span\r\n        class=\"filter-icon-wrapper\"\r\n        (click)=\"activeFilterCell = col; activeCol = null\"\r\n        ><span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span\r\n      ></span>\r\n\r\n      <div\r\n        class=\"position-absolute\"\r\n        *ngIf=\"activeFilterCell === col\"\r\n        style=\"top: 100%; right: 0; z-index: 10; left: 0\"\r\n      ></div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #tableLayout>\r\n  <div\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"p-3 shadow actions-dropdown mt-1 dropdown-menu show shadow custom-menu table-layout\"\r\n    style=\"width: 320px\"\r\n  >\r\n    <div class=\"d-flex align-items-center mb-3\">\r\n      <button\r\n        class=\"btn btn-link p-0\"\r\n        style=\"margin-left: -10px\"\r\n        (click)=\"toggleActions('setting')\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n      </button>\r\n      <h6 class=\"mb-0 ms-2\" style=\"font-weight: 500\">Table Layout</h6>\r\n    </div>\r\n    <hr class=\"my-2\" />\r\n    <div class=\"w-100 mb-3 d-flex\" role=\"group\">\r\n      <input\r\n        type=\"radio\"\r\n        class=\"btn-check layout-button-check\"\r\n        name=\"layoutSize\"\r\n        id=\"small\"\r\n        autocomplete=\"off\"\r\n        (change)=\"changeTableLayout($event, 'small')\"\r\n        [checked]=\"selectedTableLayout == 'small'\"\r\n      />\r\n      <label\r\n        class=\"border d-flex flex-column align-items-center layout-button\"\r\n        for=\"small\"\r\n        [ngStyle]=\"{\r\n          color: selectedTableLayout == 'small' ? '#000' : '#727272'\r\n        }\"\r\n      >\r\n        <div class=\"preview-box border mb-1\" style=\"height: 8px\"></div>\r\n        Small\r\n      </label>\r\n\r\n      <input\r\n        type=\"radio\"\r\n        class=\"btn-check layout-button-check\"\r\n        name=\"layoutSize\"\r\n        id=\"medium\"\r\n        autocomplete=\"off\"\r\n        [checked]=\"selectedTableLayout == 'medium'\"\r\n        (change)=\"changeTableLayout($event, 'medium')\"\r\n      />\r\n      <label\r\n        class=\"border mx-3 d-flex flex-column align-items-center layout-button\"\r\n        for=\"medium\"\r\n        [ngStyle]=\"{\r\n          color: selectedTableLayout == 'medium' ? '#000' : '#727272'\r\n        }\"\r\n      >\r\n        <div class=\"preview-box border mb-1\" style=\"height: 12px\"></div>\r\n        Medium\r\n      </label>\r\n\r\n      <input\r\n        type=\"radio\"\r\n        class=\"btn-check layout-button-check\"\r\n        name=\"layoutSize\"\r\n        id=\"large\"\r\n        autocomplete=\"off\"\r\n        (change)=\"changeTableLayout($event, 'large')\"\r\n        [checked]=\"selectedTableLayout == 'large'\"\r\n      />\r\n      <label\r\n        class=\"border d-flex flex-column align-items-center layout-button\"\r\n        for=\"large\"\r\n        [ngStyle]=\"{\r\n          color: selectedTableLayout == 'large' ? '#000' : '#727272'\r\n        }\"\r\n      >\r\n        <div class=\"preview-box border mb-1\" style=\"height: 16px\"></div>\r\n        Large\r\n      </label>\r\n    </div>\r\n\r\n    <hr class=\"my-2\" />\r\n    <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n      <span>Show separators</span>\r\n      <div class=\"form-check form-switch m-0\">\r\n        <input\r\n          class=\"form-check-input\"\r\n          type=\"checkbox\"\r\n          id=\"separators\"\r\n          [(ngModel)]=\"showVerticalBorder\"\r\n          (change)=\"onFontChange()\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div class=\"d-flex justify-content-between align-items-center\">\r\n      <span>Row shading</span>\r\n      <div class=\"form-check form-switch m-0\">\r\n        <input\r\n          class=\"form-check-input\"\r\n          [(ngModel)]=\"rowShadingEnabled\"\r\n          (change)=\"toggleRowShading()\"\r\n          type=\"checkbox\"\r\n          id=\"rowShading\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <!-- <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n      <span>Show Side Menu</span>\r\n      <div class=\"form-check form-switch m-0\">\r\n        <input\r\n          class=\"form-check-input\"\r\n          [(ngModel)]=\"showSideMenu\"\r\n          type=\"checkbox\"\r\n          id=\"rowShading\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n      <span>Show Filter Row</span>\r\n      <div class=\"form-check form-switch m-0\">\r\n        <input\r\n          class=\"form-check-input\"\r\n          [(ngModel)]=\"showFilterRow\"\r\n          type=\"checkbox\"\r\n          id=\"rowShading\"\r\n        />\r\n      </div>\r\n    </div> -->\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #tablePreset>\r\n  <div\r\n    *ngIf=\"activeSubButton !== 'save-preset'\"\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"p-3 shadow actions-dropdown mt-1 dropdown-menu show shadow custom-menu table-layout\"\r\n    style=\"width: 280px\"\r\n  >\r\n    <!-- Header -->\r\n    <div class=\"d-flex justify-content-between align-items-center mb-3\">\r\n      <div class=\"d-flex align-items-center\">\r\n        <button\r\n          class=\"btn btn-link p-0\"\r\n          style=\"margin-left: -10px\"\r\n          (click)=\"toggleActions('setting')\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n            class=\"data-grid-svg-icon\"\r\n          ></span>\r\n        </button>\r\n        <h6 class=\"mb-0 ms-2\" style=\"font-weight: 500\">Table Presets</h6>\r\n      </div>\r\n      <!-- Save Preset Button with Dropdown -->\r\n      <div>\r\n        <a\r\n          class=\"text-decoration-none text-primary\"\r\n          type=\"button\"\r\n          id=\"savePresetDropdown\"\r\n          (click)=\"$event.stopPropagation(); toggleSubActions('save-preset')\"\r\n        >\r\n          {{ isTablePresetNotChanged ? \"Save preset\" : \"Update Preset\" }}\r\n        </a>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Search -->\r\n    <div class=\"mb-3\">\r\n      <div class=\"col-12 global-search\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/search.svg'\"\r\n          class=\"data-grid-svg-icon mx-2 position-absolute icon\"\r\n        ></span>\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Search...\"\r\n          [(ngModel)]=\"searchTextPresetTable\"\r\n          type=\"search\"\r\n        />\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Preset List -->\r\n    <ng-container\r\n      *ngIf=\"\r\n        tableView | filter : searchTextPresetTable : 'name' as filteredList\r\n      \"\r\n    >\r\n      <!-- If filteredList exists and none is default -> show fallback -->\r\n      <div\r\n        class=\" pb-5 overflow-auto\"\r\n        [style.maxHeight.px]=\"dataGridContainer.offsetHeight - 250\"\r\n      >\r\n        <div\r\n          class=\"cursor-pointer\"\r\n          (click)=\"\r\n            clearAllFilters();\r\n            openIndex = null;\r\n            temp_state.id = '';\r\n            activeTopButton = '';\r\n            curretaTablePresetForUpdate = null\r\n          \"\r\n        >\r\n          <div class=\"fw-semibold\">Default View</div>\r\n        </div>\r\n        <div class=\"d-flex justify-content-between\">\r\n          <small class=\"text-dark\">Created by system</small>\r\n          <span\r\n            *ngIf=\"!tableFilterViewId && !hasAnyDefaultView()\"\r\n            class=\"badge bg-light text-primary ms-2\"\r\n            >Default</span\r\n          >\r\n          <span\r\n            *ngIf=\"!tableFilterViewId && !hasAnyDefaultView()\"\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/check-blue.svg'\"\r\n            class=\"me-2\"\r\n          ></span>\r\n          <div\r\n            class=\"dropdown d-flex justify-content-end\"\r\n            *ngIf=\"tableFilterViewId\"\r\n          ></div>\r\n        </div>\r\n\r\n        <!-- The list: render each table from filteredList -->\r\n        <div\r\n          class=\"list-group list-group-flush\"\r\n          *ngFor=\"\r\n            let table of filteredList;\r\n            let i = index;\r\n            trackBy: trackByTable\r\n          \"\r\n        >\r\n          <!-- Item -->\r\n          <div\r\n            (click)=\"\r\n              $event.stopPropagation(); openIndex = null; activeTopButton = ''\r\n            \"\r\n            class=\"list-group-item px-0 d-flex justify-content-between align-items-center\"\r\n          >\r\n            <div (click)=\"selectFilter(table); openIndex = null\">\r\n              <div class=\"fw-semibold\" style=\"cursor: pointer\">\r\n                {{ table?.name }}\r\n                <!-- {{table?.is_temp}} -->\r\n                <span\r\n                  *ngIf=\"\r\n                    (table?.is_temp && !temp_state.id) ||\r\n                    temp_state.id == table.id\r\n                  \"\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/check-blue.svg'\r\n                  \"\r\n                  class=\"me-2\"\r\n                ></span>\r\n                <span\r\n                  *ngIf=\"table?.is_default\"\r\n                  class=\"badge bg-light text-primary ms-2\"\r\n                  >Default</span\r\n                >\r\n              </div>\r\n              <small class=\"text-dark\" *ngIf=\"table?.config?.filterNames\" [title]=\"table?.config?.filterNames\">\r\n              {{\r\n              table?.config?.filterNames?.length > 25 \r\n              ? (table?.config?.filterNames | slice:0:25) + '...'\r\n              : table?.config?.filterNames\r\n              }}\r\n              ({{ table?.config?.totalCount }})\r\n            </small>\r\n             <small class=\"text-dark\" *ngIf=\"!table?.config?.filterNames\">{{ table?.createdAt | date : \"MMM d, y\" }}</small>\r\n            </div>\r\n\r\n            <div class=\"d-flex align-items-center\">\r\n              <span\r\n                *ngIf=\"table?.is_default\"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/check-blue.svg'\r\n                \"\r\n                class=\"me-2\"\r\n              ></span>\r\n\r\n              <div class=\"dropdown\" *ngIf=\"!table?.is_default\">\r\n                <div\r\n                  class=\"dropdown-wrapper\"\r\n                  (click)=\"$event.stopPropagation()\"\r\n                >\r\n                  <button\r\n                    type=\"button\"\r\n                    class=\"btn-icon muted-text\"\r\n                    (click)=\"toggleMenu(i, $event)\"\r\n                    aria-haspopup=\"true\"\r\n                    [attr.aria-expanded]=\"openIndex === i\"\r\n                  >\r\n                    <span\r\n                      [inlineSVG]=\"\r\n                        singleSpaAssetsPath +\r\n                        'data-grid/icons/horizontal-dots.svg'\r\n                      \"\r\n                      class=\"me-2\"\r\n                    ></span>\r\n                  </button>\r\n\r\n                  <!-- menu -->\r\n                 <ul\r\n                    *ngIf=\"openIndex === i\"\r\n                    class=\"custom-dropdown-menu position-fixed top-auto\"\r\n                    role=\"menu\"\r\n                    [style.right.px]=\"'auto'\"\r\n                    [style.left.px]=\"dataGridContainer.offsetWidth - 100\"\r\n                    style=\"top: unset; right: unset\"\r\n                  >\r\n                    <li role=\"none\">\r\n                      <button\r\n                        role=\"menuitem\"\r\n                        class=\"dropdown-item\"\r\n                        (click)=\"\r\n                          actionPreset(table, 'setPreset'); temp_state.id = ''\r\n                        \"\r\n                      >\r\n                        <span\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath + 'data-grid/icons/star.svg'\r\n                          \"\r\n                          class=\"me-2\"\r\n                        ></span>\r\n                        Set as default\r\n                      </button>\r\n                    </li>\r\n\r\n                    <li role=\"none\" *ngIf=\"!table.confirmDelete\">\r\n                      <button\r\n                        role=\"menuitem\"\r\n                        class=\"dropdown-item text-danger\"\r\n                        (click)=\"table.confirmDelete = true\"\r\n                      >\r\n                        <span\r\n                          style=\"margin-top: -4px\"\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath +\r\n                            'data-grid/icons/trash-red.svg'\r\n                          \"\r\n                          class=\"me-2\"\r\n                        ></span>\r\n                        Delete\r\n                      </button>\r\n                    </li>\r\n\r\n                    <li\r\n                      role=\"none\"\r\n                      *ngIf=\"table.confirmDelete\"\r\n                      class=\"confirm-block\"\r\n                    >\r\n                      <div class=\"px-3 py-2 text-center\">\r\n                        <div class=\"mb-2\">\r\n                          Are you sure you want to delete <br /><b\r\n                            >“{{ table?.name }}”</b\r\n                          >?\r\n                        </div>\r\n                        <div class=\"d-flex gap-2\">\r\n                          <button\r\n                            class=\"btn btn-sm btn-light me-2\"\r\n                            (click)=\"table.confirmDelete = false\"\r\n                          >\r\n                            Cancel\r\n                          </button>\r\n                          <button\r\n                            class=\"btn btn-sm btn-danger\"\r\n                            (click)=\"actionPreset(table, 'deletePreset')\"\r\n                          >\r\n                            Delete\r\n                          </button>\r\n                        </div>\r\n                      </div>\r\n                    </li>\r\n                  </ul>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <!-- Item End Here -->\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n\r\n  <div\r\n    (click)=\"$event.stopPropagation()\"\r\n    *ngIf=\"activeSubButton == 'save-preset'\"\r\n    class=\"dropdown-menu p-3 badge mt-4 save-preset-dropdown mt-1\"\r\n    aria-labelledby=\"savePresetDropdown\"\r\n    style=\"min-width: 250px\"\r\n  >\r\n    <div class=\"fw-bold fs-14px mb-2\">\r\n      {{ isTablePresetNotChanged ? \"Save preset\" : \"Update Preset\" }}\r\n    </div>\r\n    <div class=\"fs-14px mb-2\" style=\"line-height: 20px\">\r\n      This will save the current table adjustments as a preset.\r\n    </div>\r\n    <!-- Input -->\r\n    <div class=\"mb-2\">\r\n      <label for=\"presetName\" class=\"form-label fs-12px fw-bold\"\r\n        >Preset Name</label\r\n      >\r\n      <div class=\"col-12 global-search\">\r\n        <input\r\n          #presetNameCtrl=\"ngModel\"\r\n          required\r\n          [(ngModel)]=\"presetName\"\r\n          [ngClass]=\"{\r\n            'is-invalid':\r\n              presetNameCtrl.invalid &&\r\n              (presetNameCtrl.dirty || presetNameCtrl.touched)\r\n          }\"\r\n          class=\"form-control form-control-sm ps-2\"\r\n          placeholder=\"Enter preset name\"\r\n          type=\"text\"\r\n        />\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Checkbox -->\r\n    <div class=\"form-check mb-2\">\r\n      <input\r\n        class=\"form-check-input\"\r\n        [(ngModel)]=\"presetFilter\"\r\n        type=\"checkbox\"\r\n        id=\"saveFilters\"\r\n      />\r\n      <label class=\"form-check-label mt-1\" for=\"saveFilters\">\r\n        Save active filters\r\n      </label>\r\n    </div>\r\n\r\n    <!-- Save Button -->\r\n    <div class=\"d-flex justify-content-center gap-2\" style=\"height: 32px\">\r\n      <button\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn border w-100 d-flex align-items-center justify-content-center btn-light\"\r\n        (click)=\"$event.stopPropagation(); toggleActions('table-presets')\"\r\n        style=\"margin-top: -2px\"\r\n      >\r\n        <span>Cancel</span>\r\n      </button>\r\n      <button\r\n        [disabled]=\"closeDropdown.preset.loading\"\r\n        (click)=\"savePreset(presetNameCtrl)\"\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center\"\r\n      >\r\n        <span style=\"margin-top: -2px\" *ngIf=\"isTablePresetNotChanged\">\r\n          <ng-container *ngIf=\"!closeDropdown.preset.loading\"\r\n            >Save</ng-container\r\n          >\r\n          <ng-container *ngIf=\"closeDropdown.preset.loading\"\r\n            ><span class=\"spinner-border spinner-border-sm\"></span\r\n          ></ng-container>\r\n        </span>\r\n        <span style=\"white-space: nowrap\" *ngIf=\"!isTablePresetNotChanged\"\r\n          >Update Preset</span\r\n        >\r\n      </button>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #showHideColumns>\r\n  <div\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"p-3 shadow actions-dropdown mt-1 dropdown-menu show shadow custom-menu table-layout\"\r\n    style=\"width: 280px\"\r\n  >\r\n    <!-- Header -->\r\n    <div class=\"d-flex justify-content-between align-items-center mb-3\">\r\n      <div class=\"d-flex align-items-center\">\r\n        <button\r\n          class=\"btn btn-link p-0\"\r\n          style=\"margin-left: -10px\"\r\n          (click)=\"toggleActions('setting')\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n            class=\"data-grid-svg-icon\"\r\n          ></span>\r\n        </button>\r\n        <h6 class=\"mb-0 ms-2\" style=\"font-weight: 500\">Columns</h6>\r\n      </div>\r\n      <a\r\n        (click)=\"resetColumns()\"\r\n        href=\"javascript:void(0)\"\r\n        class=\"text-primary text-decoration-none d-none\"\r\n        >Reset</a\r\n      >\r\n    </div>\r\n\r\n    <!-- Search -->\r\n    <div class=\"mb-3\">\r\n      <div class=\"col-12 global-search\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/search.svg'\"\r\n          class=\"mx-2 position-absolute icon data-grid-svg-icon\"\r\n        ></span>\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Search column\"\r\n          type=\"search\"\r\n          [(ngModel)]=\"topShowHideColumns\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <!-- Preset List -->\r\n    <div\r\n      class=\"list-group list-group-flush\"\r\n      style=\"overflow: auto; scrollbar-width: thin\"\r\n      [style.maxHeight.px]=\"dataGridContainer.offsetHeight - 220\"\r\n    >\r\n      <div class=\"muted-text show-hide-table-label d-flex justify-content-between\" *ngIf=\"hasAnyVisibleColumn\">\r\n        Show in table\r\n         <div class=\"form-check\">\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              id=\"hide_all\"\r\n              [checked]=\"allColumnsSelected()\"\r\n              (change)=\"toggleAllColumnsVisibility()\"\r\n            />\r\n            <label class=\"form-check-label fw-semibold\" for=\"hide_all\">\r\n              Show/Hide All \r\n            </label>\r\n          </div>\r\n      </div>\r\n      <!-- Item -->\r\n      <ng-container\r\n        *ngFor=\"\r\n          let col of columns | filter : topShowHideColumns : 'header';\r\n          trackBy: trackByField\r\n        \"\r\n      >\r\n        <div\r\n          *ngIf=\"col.is_visible\"\r\n          class=\"list-group-item border-0 px-0 d-flex justify-content-between align-items-center\"\r\n        >\r\n          <div class=\"d-flex gap-1\">\r\n            <div>\r\n              <span\r\n                *ngIf=\"!col?.pinned\"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/grip-vertical.svg'\r\n                \"\r\n                class=\"cursor-grap data-grid-svg-icon\"\r\n                (mousedown)=\"$event.preventDefault()\"\r\n              ></span>\r\n              <span\r\n                *ngIf=\"col?.pinned\"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/pin-blue.svg'\r\n                \"\r\n                class=\"cursor-grap data-grid-svg-icon\"\r\n                (mousedown)=\"$event.preventDefault()\"\r\n              ></span>\r\n            </div>\r\n            <div class=\"fw-semibold\">\r\n              {{ col.header }}\r\n            </div>\r\n          </div>\r\n          <div\r\n            *ngIf=\"!col?.query?.first_value && !col?.query?._ids?.length\"\r\n            class=\"d-flex align-items-center cursor-pointer\"\r\n            (click)=\"toggleColumnVisibility(col, false)\"\r\n            [class.disabled]=\"visibleColumns().length <= 2 || col?.is_always_visible\"\r\n            [class.pe-none]=\"visibleColumns().length <= 2 || col?.is_always_visible\"\r\n            [class.opacity-50]=\"visibleColumns().length <= 2 || col?.is_always_visible\"\r\n          >\r\n            <span\r\n              [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/eye.svg'\"\r\n              class=\"data-grid-svg-icon me-2\"\r\n            ></span>\r\n          </div>\r\n          <div\r\n            *ngIf=\"col?.query?.first_value || col?.query?._ids?.length\"\r\n            class=\"d-flex align-items-center\"\r\n            style=\"opacity: 0.5\"\r\n          >\r\n            <span\r\n              [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/eye.svg'\"\r\n              class=\"data-grid-svg-icon me-2\"\r\n            ></span>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n\r\n      <!-- Item End Here -->\r\n\r\n      <div\r\n        class=\"dropdown-divider\"\r\n        *ngIf=\"hasAnyVisibleColumn && hasAnyInVisibleColumn\"\r\n      ></div>\r\n\r\n      <div\r\n        class=\"muted-text show-hide-table-label d-flex justify-content-between\"\r\n        *ngIf=\"hasAnyInVisibleColumn\"\r\n      >\r\n        Hide in table\r\n        <div class=\"form-check\">\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              id=\"show_all\"\r\n              [checked]=\"allColumnsSelected()\"\r\n              (change)=\"toggleAllColumnsVisibility()\"\r\n            />\r\n            <label class=\"form-check-label fw-semibold\" for=\"show_all\">\r\n              Show/Hide All \r\n            </label>\r\n          </div>\r\n      </div>\r\n      <div class=\"list-group list-group-flush\">\r\n        <ng-container *ngFor=\"let col of columns; trackBy: trackByField\">\r\n          <div\r\n            *ngIf=\"!col.is_visible\"\r\n            class=\"list-group-item border-0 px-0 d-flex justify-content-between align-items-center\"\r\n          >\r\n            <div class=\"d-flex gap-1\">\r\n              <div>\r\n                <span\r\n                  *ngIf=\"!col?.pinned\"\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/grip-vertical.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon cursor-grap\"\r\n                  (mousedown)=\"$event.preventDefault()\"\r\n                ></span>\r\n                <span\r\n                  *ngIf=\"col?.pinned\"\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/pin-blue.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon cursor-grap\"\r\n                  (mousedown)=\"$event.preventDefault()\"\r\n                ></span>\r\n              </div>\r\n              <div class=\"fw-semibold\">\r\n                {{ col.header }}\r\n              </div>\r\n            </div>\r\n            <div\r\n              class=\"d-flex align-items-center cursor-pointer\"\r\n              (click)=\"toggleColumnVisibility(col, true)\"\r\n            >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/eye-cross.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2\"\r\n              ></span>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n\r\n      <!-- Item End Here -->\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #filterColumns let-col=\"column\">\r\n  <div\r\n    @slideToggle\r\n    *ngIf=\"!isFilterOpen && activeTopButton == 'filter-columns'\"\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"shadow actions-dropdown mt-1 show shadow custom-menu table-layout filter-columns\"\r\n    style=\"width: 280px; right: unset; max-width: 230px\"\r\n    [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n  >\r\n    <div class=\"mb-2 px-3\">\r\n      <div class=\"col-12 global-search\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/search.svg'\"\r\n          class=\"data-grid-svg-icon mx-2 position-absolute icon\"\r\n        ></span>\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Filter by\"\r\n          type=\"search\"\r\n          [(ngModel)]=\"addFilterColumnInput\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div\r\n      class=\"list-group list-group-flush\"\r\n      style=\"max-height: calc(100vh - 500px); overflow: auto\"\r\n    >\r\n      <ng-container\r\n        *ngFor=\"\r\n          let col of columns | filter : addFilterColumnInput : 'header';\r\n          trackBy: trackByField\r\n        \"\r\n      >\r\n        <div\r\n          (click)=\"openFilter(col)\"\r\n          *ngIf=\"\r\n            col.is_visible &&\r\n            !col?.query?.first_value &&\r\n            !col?.query?._ids?.length && col.type !== 'image'\r\n          \"\r\n          class=\"list-group-item border-0 px-0 d-flex justify-content-between align-items-center dropdown-item cursor-pointer\"\r\n        >\r\n          <div class=\"d-flex gap-1\">\r\n            <div style=\"margin-top: -3px\"></div>\r\n            <div class=\"fw-semibold\">\r\n              {{ col.header }}\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Dropdown -->\r\n  <div\r\n    @slideToggle\r\n    *ngIf=\"isFilterOpen && selectedColumnForFilter.type == 'dropdown'\"\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"shadow actions-dropdown mt-1 show shadow custom-menu table-layout filter-columns pb-2\"\r\n    style=\"width: 280px; right: unset; max-width: 230px\"\r\n    [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n  >\r\n    <div class=\"px-3 my-2 border-below py-1 pb-2 mb-3 d-flex ps-1\">\r\n      <span\r\n        (click)=\"toggleActions('filter-columns'); isActiveFilterOpen = false\"\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n        class=\"data-grid-svg-icon me-2 cursor-pointer\"\r\n      ></span\r\n      ><b>{{ selectedColumnForFilter?.header }}</b>\r\n    </div>\r\n    <div class=\"mb-2 px-3\">\r\n      <div\r\n        class=\"col-12 global-search position-relative border rounded d-flex align-items-center flex-wrap px-2 filter-serach-inpt\"\r\n      >\r\n        <span\r\n          *ngFor=\"let selected of selectedFilterOptions\"\r\n          class=\"badge d-flex align-items-center gap-1 me-1 mb-1 top-row-filter-dropdown\"\r\n        >\r\n          {{ selected?.value ? selected.value : selected }}\r\n          <span\r\n            (click)=\"toggleSelectionInFilter(selected)\"\r\n            [inlineSVG]=\"\r\n              singleSpaAssetsPath + 'data-grid/icons/cross-primary.svg'\r\n            \"\r\n            class=\"me-2\"\r\n          ></span>\r\n        </span>\r\n        <input\r\n          class=\"form-control form-control-sm border-0 flex-grow-1\"\r\n          style=\"padding: 0\"\r\n          [placeholder]=\"selectedFilterOptions?.length ? '' : 'Filter by'\"\r\n          type=\"search\"\r\n          [(ngModel)]=\"searchTextForFilterDropDown\"\r\n          (keydown.backspace)=\"handleBackspace($event)\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div\r\n      class=\"list-group list-group-flush\"\r\n      style=\"max-height: calc(100vh - 600px); overflow: auto\"\r\n    >\r\n      <ng-container\r\n        *ngFor=\"\r\n          let col of selectedColumnForFilter.column_dropdown_value\r\n            | filter : searchTextForFilterDropDown : 'value';\r\n          let i = index\r\n        \"\r\n      >\r\n        <div\r\n          class=\"list-group-item border-0 px-2 d-flex justify-content-between align-items-center dropdown-item cursor-pointer\"\r\n        >\r\n          <div class=\"form-check\">\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              [id]=\"i\"\r\n              [checked]=\"currentFilterSelectedIds.has(col.id || col._id || col)\"\r\n              (change)=\"toggleSelectionInFilter(col)\"\r\n            />\r\n            <label class=\"form-check-label fw-semibold\" [for]=\"i\">\r\n              {{ col?.value || col?.name || col }}\r\n            </label>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n    <div\r\n      class=\"d-flex justify-content-center gap-2 px-2 border-top\"\r\n      style=\"height: 38px\"\r\n    >\r\n      <button\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-outline-secondary btn-light border w-100 d-flex align-items-center justify-content-center mt-1 btn-light\"\r\n        (click)=\"$event.stopPropagation(); resetFilterChanges()\"\r\n      >\r\n        <span>Cancel</span>\r\n      </button>\r\n      <button\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center mt-1\"\r\n        (click)=\"applyDropdownFilter()\"\r\n      >\r\n        <span style=\"margin-top: -2px\">Save</span>\r\n      </button>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- For Text fields and number fields-->\r\n\r\n  <div\r\n    @slideToggle\r\n    *ngIf=\"\r\n      isFilterOpen &&\r\n      (selectedColumnForFilter.type == 'string' ||\r\n        selectedColumnForFilter.type == 'number' ||\r\n        selectedColumnForFilter.type == 'date')\r\n    \"\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"shadow actions-dropdown mt-1 show shadow custom-menu table-layout filter-columns pb-2\"\r\n    style=\"width: 210px; right: unset; max-width: 230px\"\r\n    [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n  >\r\n    <div class=\"px-3 border-below py-1 pb-2 d-flex ps-1\">\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n        (click)=\"toggleActions('filter-columns'); isActiveFilterOpen = false\"\r\n        class=\"data-grid-svg-icon me-2 cursor-pointer\"\r\n      ></span\r\n      ><b>{{ selectedColumnForFilter?.header }}</b>\r\n    </div>\r\n    <div class=\"col-12 position-relative p-2 text-filter\">\r\n      <div class=\"mb-2\">\r\n        <select\r\n          class=\"form-select form-select-sm custom-select border\"\r\n          [(ngModel)]=\"firstCondition\"\r\n        >\r\n          <ng-container *ngIf=\"selectedColumnForFilter.type !== 'date'\">\r\n            <option value=\"contain\">Contains</option>\r\n             <option value=\"does_not_contain\">Does Not Contain</option>\r\n            <option value=\"equal\">Equals</option>\r\n            <option value=\"before\">Starts With</option>\r\n            <option value=\"after\">Ends With</option>\r\n          </ng-container>\r\n\r\n          <ng-container *ngIf=\"selectedColumnForFilter.type == 'date'\">\r\n            <option value=\"equal\">Equals To</option>\r\n             <option value=\"not_equal\">Not Equal</option>\r\n            <option value=\"after\">After</option>\r\n            <option value=\"before\">Before</option>\r\n          </ng-container>\r\n        </select>\r\n      </div>\r\n      <div class=\"mb-2\">\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Enter first value\"\r\n          type=\"search\"\r\n          [type]=\"\r\n            selectedColumnForFilter.type == 'string'\r\n              ? 'text'\r\n              : selectedColumnForFilter.type\r\n          \"\r\n          [(ngModel)]=\"firstValue\"\r\n          (keydown.enter)=\"applyDropdownFilter()\"\r\n        />\r\n      </div>\r\n      <div>\r\n        <div class=\"d-flex my-3 d-flex flex-row\" style=\"font-size: 14px\">\r\n          <div\r\n            class=\"form-check form-check-inline col-4 m-0 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"radio\"\r\n              id=\"logicalAnd\"\r\n              name=\"logicalOperator\"\r\n              value=\"and\"\r\n              [(ngModel)]=\"condition\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"logicalAnd\"\r\n              >AND</label\r\n            >\r\n          </div>\r\n\r\n          <div\r\n            class=\"form-check form-check-inline col-4 m-0 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"radio\"\r\n              id=\"logicalOr\"\r\n              name=\"logicalOperator\"\r\n              value=\"or\"\r\n              [(ngModel)]=\"condition\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"logicalOr\">OR</label>\r\n          </div>\r\n\r\n          <div\r\n            class=\"form-check form-check-inline col-4 m-0 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"radio\"\r\n              id=\"logicalNone\"\r\n              name=\"logicalOperator\"\r\n              value=\"none\"\r\n              [(ngModel)]=\"condition\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"logicalNone\"\r\n              >None</label\r\n            >\r\n          </div>\r\n        </div>\r\n\r\n        <ng-container *ngIf=\"condition !== 'none' && firstValue\">\r\n          <div class=\"mb-2 mt-3\">\r\n            <!-- Second condition select -->\r\n            <select\r\n              class=\"form-select form-select-sm border\"\r\n              [(ngModel)]=\"secondCondition\"\r\n            >\r\n              <ng-container *ngIf=\"selectedColumnForFilter.type !== 'date'\">\r\n                <option value=\"contain\">Contains</option>\r\n                <option value=\"does_not_contain\">Does Not Contain</option>\r\n                <option value=\"equal\">Equals</option>\r\n                <option value=\"before\">Starts With</option>\r\n                <option value=\"after\">Ends With</option>\r\n              </ng-container>\r\n\r\n              <ng-container *ngIf=\"selectedColumnForFilter.type == 'date'\">\r\n                <option value=\"equal\">Equals To</option>\r\n                <option value=\"not_equal\">Not Equal</option>\r\n                <option value=\"after\">After</option>\r\n                <option value=\"before\">Before</option>\r\n              </ng-container>\r\n            </select>\r\n          </div>\r\n\r\n          <div class=\"mb-2\">\r\n            <!-- Second value input -->\r\n            <input\r\n              [type]=\"\r\n                selectedColumnForFilter.type == 'string'\r\n                  ? 'text'\r\n                  : selectedColumnForFilter.type\r\n              \"\r\n              class=\"form-control form-control-sm\"\r\n              placeholder=\"Enter second value\"\r\n              type=\"search\"\r\n              [(ngModel)]=\"secondValue\"\r\n              (keydown.enter)=\"applyDropdownFilter()\"\r\n            />\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n\r\n    <div\r\n      class=\"d-flex justify-content-center gap-2 px-2 border-top\"\r\n      style=\"height: 38px\"\r\n    >\r\n      <button\r\n        [disabled]=\"!currentFilterSelectedIds?.size && !firstValue\"\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-outline-secondary btn-light border w-100 d-flex align-items-center justify-content-center mt-1 btn-light\"\r\n        (click)=\"$event.stopPropagation(); resetTextFilterChanges()\"\r\n      >\r\n        <span>Cancel</span>\r\n      </button>\r\n      <button\r\n        [disabled]=\"(currentFilterSelectedIds?.size === 0 && !firstValue) || (condition !== 'none' && !secondValue)\"\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center mt-1\"\r\n        (click)=\"applyDropdownFilter()\"\r\n      >\r\n        <span style=\"margin-top: -2px\">Apply</span>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Edit dropdown here -->\r\n<ng-template let-col>\r\n  <div class=\"drop-down-edit\"></div>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #fullTextTemplate\r\n  let-row=\"row\"\r\n  let-col=\"col\"\r\n  let-isArray=\"isArray\"\r\n>\r\n  <div\r\n    class=\"full-text-box\"\r\n    (dblclick)=\"$event.stopPropagation(); $event.preventDefault()\"\r\n    (click)=\"$event.stopPropagation(); $event.preventDefault()\"\r\n    [style.maxHeight.px]=\"dataGridContainer.offsetHeight / 2\"\r\n  >\r\n    <ng-container *ngIf=\"!isEditing(row, col)\">\r\n      <div\r\n        *ngIf=\"!isArray\"\r\n        class=\"full-text-content\"\r\n        [style.maxHeight.px]=\"dataGridContainer.offsetHeight / 2\"\r\n        (dblclick)=\"\r\n          $event.stopPropagation();\r\n          $event.preventDefault();\r\n          enableEdit(row, col, true)\r\n        \"\r\n        (click)=\"$event.stopPropagation(); $event.preventDefault()\"\r\n      >\r\n        {{\r\n          getNestedValue(row, col.field)?.value ||\r\n            getNestedValue(row, col.field)?.name ||\r\n            getNestedValue(row, col.field)\r\n        }}\r\n      </div>\r\n      <div *ngIf=\"isArray\">\r\n        <ul>\r\n          <ng-container\r\n            *ngFor=\"let item of getNestedValue(row, col.field); let i = index\"\r\n          >\r\n            <li *ngIf=\"i !== 0\">\r\n              <ng-container>\r\n                {{\r\n                  item?.department_name ||\r\n                    item?.roleName ||\r\n                    item?.full_name ||\r\n                    \"-\"\r\n                }}\r\n              </ng-container>\r\n            </li>\r\n          </ng-container>\r\n        </ul>\r\n      </div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"isEditing(row, col)\">\r\n      <textarea\r\n        (dblclick)=\"\r\n          $event.stopPropagation();\r\n          $event.preventDefault();\r\n          enableEdit(row, col, true)\r\n        \"\r\n        #textModel=\"ngModel\"\r\n        rows=\"4\"\r\n        #textAreadInput\r\n        [(ngModel)]=\"row[col.field]\"\r\n        name=\"{{ col.field }}\"\r\n        required\r\n        (blur)=\"disableEdit(row, col, textModel)\"\r\n        (keydown.enter)=\"textAreadInput.blur()\"\r\n        autofocus\r\n        class=\"form-control\"\r\n        [ngClass]=\"{\r\n          'is-invalid': textModel.invalid\r\n        }\"\r\n        (mousedown)=\"$event.stopPropagation()\"\r\n      ></textarea>\r\n    </ng-container>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #defaultImagePlaceholder let-row=\"row\" let-col=\"col\">\r\n  <span\r\n    class=\"px-2 d-flex w-100 cell-content image-placeholder\"\r\n    [title]=\"row?.full_name || row?.name || 'N/A'\"\r\n  >\r\n    <ng-container\r\n      *ngIf=\"\r\n        row?.logo ||\r\n          row?.assetImage ||\r\n          row?.invoice?.invoice_image ||\r\n          row?.invoice_image;\r\n        else placeholder\r\n      \"\r\n    >\r\n      <span\r\n        (click)=\"fullscreenImage = row?.profile_pictures?.[4]?.path ||\r\n            row?.logo ||\r\n            row?.assetImage ||\r\n            row?.invoice_image\"\r\n        class=\"pic\"\r\n        [style.width.px]=\"rowHeight - 10\"\r\n        [style.height.px]=\"rowHeight - 10\"\r\n        [class.assets-pic]=\"gridType == 'Assets'\"\r\n      >\r\n        <img\r\n          [width]=\"rowHeight - 12\"\r\n          [height]=\"rowHeight - 12\"\r\n          [style.width.px]=\"rowHeight - 10\"\r\n          [style.height.px]=\"rowHeight - 10\"\r\n          [src]=\"\r\n            row?.profile_pictures?.[4]?.path ||\r\n            row?.logo ||\r\n            row?.assetImage ||\r\n            row?.invoice_image\r\n          \"\r\n          alt=\"icon\"\r\n          class=\"option-icon\"\r\n          loading=\"lazy\"\r\n        />\r\n      </span>\r\n    </ng-container>\r\n    <!-- <div\r\n      class=\"fullscreen-overlay\"\r\n      *ngIf=\"fullscreenImage\"\r\n      (click)=\"fullscreenImage = null\"\r\n    >\r\n      <img [src]=\"fullscreenImage\" class=\"fullscreen-img\" />\r\n    </div> -->\r\n\r\n    <ng-template #placeholder>\r\n      <span\r\n        [ngClass]=\"getDynamicClass(row?.full_name || row?.name)\"\r\n        class=\"pic d-flex align-items-center rounded-circle\"\r\n        [style.width.px]=\"rowHeight - 12\"\r\n        [style.height.px]=\"rowHeight - 12\"\r\n        [style.fontSize.px]=\"rowHeight / 3\"\r\n        [class.assets-pic]=\"gridType == 'Assets'\"\r\n      >\r\n        {{ getInitials(row?.full_name) }}\r\n      </span>\r\n    </ng-template>\r\n  </span>\r\n</ng-template>\r\n\r\n<!-- Right Click Menue -->\r\n<div\r\n  [class.invisible]=\"!positionedYet\"\r\n  class=\"context-menu p-2\"\r\n  *ngIf=\"actionHide && actions?.length\"\r\n  [ngStyle]=\"{ 'top.px': yPos, 'left.px': xPos }\"\r\n  [class.show]=\"isVisible\"\r\n  appendTo=\"body\"\r\n>\r\n  <ul>\r\n    <li\r\n      *ngFor=\"let action of actions\"\r\n      class=\"rounded d-flex align-items-center\"\r\n      (click)=\"onActionClick(action)\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/' + action + '.svg'\"\r\n        class=\"data-grid-svg-icon right-click-menu-icons me-2\"\r\n      ></span>\r\n      <span class=\"text-capitalize fw-500\">{{ action }}</span>\r\n    </li>\r\n  </ul>\r\n</div>\r\n\r\n<!-- Details Toggle from bottom -->\r\n\r\n<ng-template #nestedTableTemplate let-row>\r\n  <div\r\n    class=\"nested-table table table-sm w-100 mb-0 center-nested-table w-100\"\r\n    style=\"table-layout: fixed !important\"\r\n    #nestedTableContainer\r\n  >\r\n    <thead\r\n      #nestedHeader\r\n      [style.backgroundColor]=\"nestedTableHeaderBackgroundColor\"\r\n    >\r\n      <div\r\n        cdkDropList\r\n        [cdkDropListData]=\"row?.detail.columns\"\r\n        cdkDropListOrientation=\"horizontal\"\r\n        (cdkDropListDropped)=\"dropColumn($event, row)\"\r\n        (cdkDropListSorted)=\"onNestedColSort($event, previewNestedCols)\"\r\n        [style.height.px]=\"nestedTableHeaderRowHeight\"\r\n        class=\"d-flex tr border-below\"\r\n      >\r\n        <div\r\n          *ngFor=\"let col of row.detail.columns; let i = index\"\r\n          [style.width.px]=\"col?.width || 250\"\r\n          [style.minWidth.px]=\"col?.width || 250\"\r\n          [style.maxWidth.px]=\"col?.width || 250\"\r\n          class=\"px-4 th\"\r\n          [attr.data-field]=\"col.field\"\r\n          [style.backgroundColor]=\"nestedTableHeaderBackgroundColor\"\r\n          cdkDrag\r\n        >\r\n          <div\r\n            class=\"d-flex h-100 justify-content-between position-relative align-items-center\"\r\n          >\r\n            <div class=\"text-ellipsis\" (click)=\"sortNestedCol(col, row)\">\r\n              {{ col.header }}\r\n            </div>\r\n            <div class=\"d-flex gap-2\">\r\n              <span\r\n                *ngIf=\"currentSubSortColumn == col.field\"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath +\r\n                  (col?.order_by == 'desc'\r\n                    ? 'data-grid/icons/sort-desc.svg'\r\n                    : 'data-grid/icons/sort-asc.svg')\r\n                \"\r\n                class=\"data-grid-svg-icon d-flex justify-content-center align-items-center ms-2 start-50\"\r\n              >\r\n              </span>\r\n              <!-- <div\r\n                class=\"three-dots p-1\"\r\n                (click)=\"openThreeDotsMenu($event, col)\"\r\n                style=\"cursor: pointer\"\r\n              >\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath +\r\n                    'data-grid/icons/three-dots-vertical.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div> -->\r\n\r\n              <!-- Only show menu if this column is active -->\r\n              <div\r\n                class=\"position-absolute\"\r\n                *ngIf=\"activeCol === col\"\r\n                style=\"top: -50%; z-index: 21; left: 0\"\r\n              >\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    columnMenu;\r\n                    context: {\r\n                      col: col,\r\n                      isNestedTable: true,\r\n                      columns: row?.detail.columns\r\n                    }\r\n                  \"\r\n                ></ng-container>\r\n              </div>\r\n              <div\r\n                class=\"resize-handle\"\r\n                (click)=\"$event.stopPropagation()\"\r\n                (mousedown)=\"\r\n                  $event.preventDefault();\r\n                  onResizeColumn($event, col);\r\n                  $event.stopPropagation()\r\n                \"\r\n              >\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/resize-handle.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <ng-template cdkDragPreview>\r\n            <div class=\"p-2 border d-flex gap-2\">\r\n              <div>\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/arrows-move.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div>\r\n              <div>{{ col.header }}</div>\r\n            </div>\r\n          </ng-template>\r\n        </div>\r\n      </div>\r\n    </thead>\r\n    <div\r\n      [style.width.px]=\"nestedHeader.offsetWidth - 10\"\r\n      [style.minWidth.px]=\"nestedHeader.offsetWidth - 10\"\r\n    >\r\n      <cdk-virtual-scroll-viewport\r\n        [itemSize]=\"nestedTablerowHeight\"\r\n        class=\"viewport\"\r\n        [style.height.px]=\"\r\n          (row?.detail?.result?.length < 5\r\n            ? nestedTablerowHeight * row?.detail?.result?.length + 40\r\n            : 300) + (hasHorizontalScroll ? -12 : 1)\r\n        \"\r\n        [style.width.px]=\"nestedHeader.offsetWidth - 10\"\r\n        [style.minWidth.px]=\"nestedHeader.offsetWidth - 10\"\r\n      >\r\n        <div\r\n          class=\"cursor-pointer border-below d-flex tr\"\r\n          *cdkVirtualFor=\"let d of row?.detail?.result; trackBy: trackById\"\r\n          [style.height.px]=\"nestedTablerowHeight\"\r\n          [style.width.px]=\"nestedHeader?.offsetWidth\"\r\n          [style.minWidth.px]=\"nestedHeader?.offsetWidth\"\r\n          [style.backgroundColor]=\"bodyBackgroundColor\"\r\n          (contextmenu)=\"onRightClick($event, d)\"\r\n        >\r\n          <div\r\n            class=\"px-4 py-0 td\"\r\n            *ngFor=\"let col of previewNestedCols; let j = index\"\r\n            [style.fontSize.px]=\"nestedTablerowFontsize\"\r\n            [attr.data-field]=\"col.field\"\r\n            [style.width.px]=\"col?.width || 250\"\r\n            [style.minWidth.px]=\"col?.width || 250\"\r\n            [style.maxWidth.px]=\"col?.width || 250\"\r\n          >\r\n            <div\r\n              [style.height.px]=\"nestedTablerowHeight - 1\"\r\n              [style.max-width.px]=\"col?.width\"\r\n              class=\"d-flex align-items-center\"\r\n            >\r\n              <!-- {{ d[col.field] || (col.is_amount ? 0 : \"-\") }} -->\r\n              <div\r\n                #cellText\r\n                class=\"text-ellipsis flex-grow-1\"\r\n                [title]=\"\r\n                  col.type === 'date'\r\n                    ? (getNestedValue(d, col.field) | date : dateFormat)\r\n                    : getNestedValue(d, col.field) || '-'\r\n                \"\r\n              >\r\n                <ng-container *ngIf=\"col.type !== 'image'\">\r\n                  <ng-container *ngIf=\"col.is_amount\">{{\r\n                    currencySymbol\r\n                  }}</ng-container>\r\n                  {{\r\n                          !isNestedValueArray(d, col.field)\r\n                            ? col.type === 'date'\r\n                              ? (isDate(getNestedValue(d, col.field))\r\n                                  ? (getNestedValue(d, col.field) | date: dateFormat)\r\n                                  : (getNestedValue(d, col.field)?.value ||\r\n                                    getNestedValue(d, col.field)?.name ||\r\n                                    getNestedValue(d, col.field) ||\r\n                                    '-'))\r\n                              : (getNestedValue(d, col.field)?.value ||\r\n                                getNestedValue(d, col.field)?.name ||\r\n                                getNestedValue(d, col.field) ||\r\n                                (col.is_amount ? 0: '-'))\r\n                            : (getNestedValue(d, col.field)?.[0]?.department_name ||\r\n                              getNestedValue(d, col.field)?.[0]?.roleName || getNestedValue(d, col.field)?.[0]?.full_name ||\r\n                              '-')\r\n                  }}\r\n                </ng-container>\r\n                <ng-container *ngIf=\"false\">\r\n                  {{ getTotalAmount(col) }}\r\n                </ng-container>\r\n                <ng-container *ngIf=\"col.type == 'image'\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      defaultImagePlaceholder;\r\n                      context: {\r\n                        row: d,\r\n                        col: col,\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </cdk-virtual-scroll-viewport>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #leftRightNestedPlaceholder let-row>\r\n  <table\r\n    class=\"nested-table table table-sm w-100 mb-0\"\r\n    [style.backgroundColor]=\"bodyBackgroundColor\"\r\n    [style.height.px]=\"\r\n      gridType == 'Assets'\r\n        ? (nestedTableContainer?.nativeElement?.offsetHeight ?? 0) + 12\r\n        : (taskManagementContainer?.nativeElement?.offsetHeight ?? 0)\r\n    \"\r\n  >\r\n    <!-- <div class=\"thead\">\r\n      <div\r\n        class=\"tr d-flex border-below\"\r\n        [style.height.px]=\"nestedTableHeaderRowHeight\"\r\n        [style.backgroundColor]=\"headerBackgroundColor\"\r\n      >\r\n        <div class=\"th\" *ngFor=\"let _ of [1, 2, 3, 4, 5]\"></div>\r\n      </div>\r\n    </div> -->\r\n    <!-- <div class=\"tbody\">\r\n      <div\r\n        class=\"tr border-below\"\r\n        [style.height.px]=\"nestedTablerowHeight\"\r\n        *ngFor=\"let _ of row?.detail?.result\"\r\n        [style.backgroundColor]=\"headerBackgroundColor\"\r\n      >\r\n        <div class=\"td\" *ngFor=\"let __ of [1, 2, 3, 4, 5]\" class=\"py-0\">\r\n          <span\r\n            [style.height.px]=\"nestedTablerowHeight\"\r\n            [style.max-width.px]=\"nestedTablerowHeight\"\r\n          ></span>\r\n        </div>\r\n      </div>\r\n    </div> -->\r\n  </table>\r\n</ng-template>\r\n\r\n<ng-template #taskManagementTemplate let-taskDetails=\"taskDetails\">\r\n  <div\r\n    class=\"p-4\"\r\n    #taskManagementContainer\r\n    [style.backgroundColor]=\"nestedTableHeaderBackgroundColor\"\r\n    [style.fontFaimly]=\"fontFaimly\"\r\n  >\r\n    <div class=\"d-flex justify-content-between\">\r\n      <div class=\"col-4\">\r\n        <div class=\"item-title\">Description</div>\r\n        <!-- <div class=\"item-content firstDiv\">\r\n        {{ taskDetails.description }}\r\n      </div> -->\r\n        <p\r\n          [style.fontSize]=\"bodyTextFontsSize\"\r\n          class=\"item-content firstDiv taskDescription pe-4\"\r\n          [innerHTML]=\"getSafeComment(taskDetails?.editor_description)\"\r\n          (click)=\"openFullImage($event)\"\r\n        ></p>\r\n      </div>\r\n      <div class=\"col-4\">\r\n        <div class=\"item-title\">Attachments</div>\r\n        <h5 *ngIf=\"taskDetails?.attachments?.length == 0\">\r\n          No Attachments found\r\n        </h5>\r\n        <div\r\n          *ngIf=\"taskDetails?.attachments?.length\"\r\n          class=\"item-content d-flex flex-wrap\"\r\n          style=\"gap: 10px\"\r\n        >\r\n          <a\r\n            *ngFor=\"let attachement of taskDetails?.attachments; let i = index\"\r\n            class=\"symbol-label fs-2 fw-semibold text-success cursor-pointer\"\r\n          >\r\n            <span\r\n              title=\"{{ taskDetails?.attachments_name[i] || 'Attachment' }}\"\r\n              (click)=\"downloadAttchment(attachement)\"\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath +\r\n                'data-grid/document-icons/' +\r\n                getExtention(attachement) +\r\n                '.svg'\r\n              \"\r\n            >\r\n            </span>\r\n          </a>\r\n        </div>\r\n      </div>\r\n      <div class=\"col-4\">\r\n        <div class=\"item-title\">\r\n          Comments ({{ taskDetails?.comments?.length }})\r\n        </div>\r\n        <h5 *ngIf=\"taskDetails?.comments?.length == 0\">No Comments found</h5>\r\n        <div *ngIf=\"taskDetails?.comments?.length\" class=\"item-content\">\r\n          <div class=\"comment\" *ngFor=\"let comment of taskDetails.comments\">\r\n            <div class=\"d-flex align-items-center pe-3\">\r\n              <img\r\n                class=\"pic image-input-wrapper\"\r\n                [style.width.px]=\"rowHeight - 12\"\r\n                [style.height.px]=\"rowHeight - 12\"\r\n                *ngIf=\"comment?.comment_by.logo\"\r\n                src=\"{{ comment?.comment_by.logo }}\"\r\n                alt=\"{{ comment.comment_by.full_name }}\"\r\n              />\r\n              <!-- <app-default-image-placeholder *ngIf=\"!comment?.comment_by.logo\" title=\"{{ comment.comment_by.full_name }}\" [name]=\"comment.comment_by.full_name\"></app-default-image-placeholder> -->\r\n              <span\r\n                *ngIf=\"!comment?.comment_by.logo\"\r\n                [ngClass]=\"getDynamicClass(comment.comment_by.full_name)\"\r\n                class=\"pic d-flex align-items-center rounded-circle\"\r\n                [style.width.px]=\"rowHeight - 12\"\r\n                [style.height.px]=\"rowHeight - 12\"\r\n                [style.fontSize.px]=\"rowHeight / 3\"\r\n                title=\"{{ comment.comment_by.full_name }}\"\r\n              >\r\n                {{ getInitials(comment.comment_by.full_name) }}\r\n              </span>\r\n            </div>\r\n            <div>\r\n              <div class=\"comment-author fs-14px\">\r\n                {{ comment?.comment_by.full_name }}\r\n              </div>\r\n              <div\r\n                class=\"comment-content forCommentImg\"\r\n                [innerHTML]=\"getSafeComment(comment.comment)\"\r\n              ></div>\r\n              <div class=\"comment-timestamp\">\r\n                {{ comment.comment_date | date }}\r\n              </div>\r\n              <div class=\"comment-timestamp\">\r\n                Replies: ({{ comment.replies.length }})\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}
5413
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.component.js","sourceRoot":"","sources":["../../../../../projects/data-grid/src/lib/data-grid/data-grid.component.ts","../../../../../projects/data-grid/src/lib/data-grid/data-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  Input,\r\n  Output,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  ElementRef,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  HostListener,\r\n  ChangeDetectorRef,\r\n  EventEmitter,\r\n  NgZone,\r\n  Renderer2,\r\n  AfterViewChecked,\r\n  EmbeddedViewRef,\r\n  TemplateRef,\r\n  ChangeDetectionStrategy,\r\n  QueryList,\r\n  ViewChildren,\r\n  inject,\r\n  Injector\r\n} from '@angular/core';\r\nimport { SplitColumnsService } from '../services/split-columns.service';\r\nimport { CommonService } from '../services/common.service';\r\nimport {\r\n  CdkDrag,\r\n  CdkDragDrop,\r\n  CdkDragEnd,\r\n  CdkDragEnter,\r\n  CdkDragExit,\r\n  CdkDragMove,\r\n  CdkDragSortEvent,\r\n  CdkDragStart,\r\n  DragDrop,\r\n  moveItemInArray,\r\n} from '@angular/cdk/drag-drop';\r\nimport {\r\n  trigger,\r\n  state,\r\n  style,\r\n  transition,\r\n  animate,\r\n  query,\r\n  stagger,\r\n} from '@angular/animations';\r\nimport { CdkDropList } from '@angular/cdk/drag-drop';\r\nimport { STATUSES_BADGE_MAP } from './statuses';\r\nimport { CopyServiceService } from '../services/copy-service.service';\r\nimport { firstValueFrom, take } from 'rxjs';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { ExportService } from '../services/export.service';\r\nimport { CellHostDirective } from '../directives/cellHost.directive';\r\nimport { DatePipe } from '@angular/common';\r\nimport { FormatCurrencyPipe } from '../pipes/format-currency.pipe';\r\n\r\ninterface CellPosition {\r\n  rowIndex: number;\r\n  colIndex: number;\r\n  subColIndex: number;\r\n  field: string;\r\n  key: string;\r\n}\r\nexport enum RowAnimationType {\r\n  None = 'none',\r\n  Spread = 'spreadAnimation',\r\n  Bounce = 'bounceAnimation',\r\n  SlideUp = 'slideUpFromBottom',\r\n  Flip = 'flipAnimation',\r\n  Skew = 'skewAnimation',\r\n  SlideRight = 'slideFromRight',\r\n}\r\n\r\n\r\nexport const sortingAnimation = trigger('listSort', [\r\n  transition('* => *', [\r\n    // Query all elements entering or leaving\r\n    query(':enter, :leave', style({ position: 'absolute', width: '100%' }), { optional: true }),\r\n\r\n    // Animate leaving elements upward with fade out\r\n    query(':leave', [\r\n      animate('300ms ease-in', style({ transform: 'translateY(-20px)', opacity: 0 }))\r\n    ], { optional: true }),\r\n\r\n    // Stagger the entering elements for a smoother effect\r\n    query(':enter', [\r\n      style({ transform: 'translateY(20px)', opacity: 0 }),\r\n      stagger(50, [\r\n        animate('300ms ease-out', style({ transform: 'translateY(0)', opacity: 1 }))\r\n      ])\r\n    ], { optional: true })\r\n  ])\r\n]);\r\n@Component({\r\n  selector: 'data-grid',\r\n  templateUrl: './data-grid.component.html',\r\n  styleUrls: ['./data-grid.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [\r\n    trigger('accordionToggle', [\r\n      state(\r\n        'collapsed',\r\n        style({ height: '0px', overflow: 'unset' })\r\n      ),\r\n      state('expanded', style({ height: '*', overflow: 'unset' })),\r\n      transition('collapsed <=> expanded', animate('300ms ease-in')),\r\n    ]),\r\n    trigger('slideToggle', [\r\n      transition(':enter', [\r\n        style({ height: '0px', opacity: 0, overflow: 'hidden' }),\r\n        animate('300ms ease-out', style({ height: '*', opacity: 1 }))\r\n      ]),\r\n      transition(':leave', [\r\n        style({ height: '*', opacity: 1, overflow: 'hidden' }),\r\n        animate('300ms ease-in', style({ height: '0px', opacity: 0 }))\r\n      ])\r\n    ]),\r\n    trigger('slideUp', [\r\n      state('void', style({ transform: 'translateY(100%)', opacity: 0 })),\r\n      state('*', style({ transform: 'translateY(0)', opacity: 1 })),\r\n      transition('void => *', animate('300ms ease-out')),\r\n      transition('* => void', animate('300ms ease-in')),\r\n    ]),\r\n    trigger('rowDynamic', [\r\n\r\n      /* -------------------- SPREAD -------------------- */\r\n      transition('* => spreadAnimation', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'scaleX(0.7)' }),\r\n          stagger(60, [\r\n            animate('350ms ease-out',\r\n              style({ opacity: 1, transform: 'scaleX(1)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('220ms ease-in',\r\n              style({ opacity: 0, transform: 'scaleX(0.7)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n      /* -------------------- BOUNCE -------------------- */\r\n      transition('* => bounceAnimation', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'translateY(-10px)' }),\r\n          stagger(45, [\r\n            animate(\r\n              '500ms cubic-bezier(.68,-0.55,.27,1.55)',\r\n              style({ opacity: 1, transform: 'translateY(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('200ms ease-in',\r\n              style({ opacity: 0, transform: 'translateY(10px)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n      /* -------------------- NEW 1: FLIP -------------------- */\r\n      transition('* => flipAnimation', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'rotateX(-80deg)' }),\r\n          stagger(70, [\r\n            animate('450ms ease-out',\r\n              style({ opacity: 1, transform: 'rotateX(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(50, [\r\n            animate('250ms ease-in',\r\n              style({ opacity: 0, transform: 'rotateX(80deg)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n      /* -------------------- NEW 2: SKEW -------------------- */\r\n      transition('* => skewAnimation', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'skewY(6deg) translateY(8px)' }),\r\n          stagger(60, [\r\n            animate('320ms ease-out',\r\n              style({ opacity: 1, transform: 'skewY(0deg) translateY(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('220ms ease-in',\r\n              style({ opacity: 0, transform: 'skewY(-6deg) translateY(-8px)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n      transition('* => slideUpFromBottom', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'translateY(100vh)' }),\r\n          stagger(60, [\r\n            animate('500ms cubic-bezier(0.25, 0.8, 0.25, 1)',\r\n              style({ opacity: 1, transform: 'translateY(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('300ms ease-in',\r\n              style({ opacity: 0, transform: 'translateY(-50px)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n      transition('* => slideFromRight', [\r\n        query(':enter', [\r\n          style({ opacity: 0, transform: 'translateX(100vw)' }),\r\n          stagger(60, [\r\n            animate('500ms cubic-bezier(0.25, 0.8, 0.25, 1)',\r\n              style({ opacity: 1, transform: 'translateX(0)' })\r\n            )\r\n          ])\r\n        ], { optional: true }),\r\n\r\n        query(':leave', [\r\n          stagger(40, [\r\n            animate('300ms ease-in',\r\n              style({ opacity: 0, transform: 'translateX(50px)' })\r\n            )\r\n          ])\r\n        ], { optional: true })\r\n      ]),\r\n\r\n\r\n\r\n    ])\r\n\r\n\r\n  ],\r\n\r\n})\r\nexport class DataGridComponent implements OnChanges, AfterViewInit, OnInit, AfterViewChecked {\r\n  //  **************************************//\r\n  //  **************************************//\r\n  // **********  Input Goes Here *********** //\r\n  //  **************************************//\r\n  //  **************************************//\r\n\r\n\r\n  @Input() rowAnimation: RowAnimationType = RowAnimationType.None;\r\n\r\n  // Pagination Config Store Here\r\n  @Input() paginationConfig: any = {};\r\n\r\n  // The dataset store here;\r\n  @Input() dataSet: any[] = [];\r\n\r\n  // The columns Store Here\r\n  @Input() columns: any[] = [];\r\n\r\n  // Row Height;\r\n  @Input() rowHeight: number = 44;\r\n\r\n  // Header Row Height;\r\n  @Input() headerRowHeight: number = 50;\r\n\r\n  // Show Vertical Borders;\r\n  @Input() showVerticalBorder: boolean = false;\r\n\r\n  // Even Rows Background Color;\r\n  @Input() evenRowsBackgroundColor: string | undefined = '';\r\n\r\n  // Even Rows Background Color;\r\n  @Input() oddRowsBackgroundColor: string | undefined = '#f2f2f2';\r\n\r\n  // Header Rows Background Color;\r\n  @Input() headerBackgroundColor: string = '#f6f8ff';\r\n\r\n  // Header Rows Background Color;\r\n  @Input() checkboxesBackgroundColor: string = '#f6f8ff';\r\n\r\n  // Show Columns Grouping;\r\n  @Input() showColumnsGrouping: boolean = false;\r\n\r\n  // Row Hovered Background color;\r\n  @Input() rowHoverColor: string | undefined = 'rgba(0, 123, 255, 0.1)';\r\n\r\n  // Left PinnedBackground color;\r\n  @Input() leftPinnedBackgroundColor: string | undefined = '#f6f8ff';\r\n\r\n  // Body Background color;\r\n  @Input() bodyBackgroundColor: string | undefined = '#f6f8ff';\r\n\r\n  // Right Pinned Background color;\r\n  @Input() rightPinnedBackgroundColor: string | undefined = '#f6f8ff';\r\n\r\n  // Side Menu Background color;\r\n  @Input() sidemenuBackgroundColor: string | undefined = '#f6f8ff';\r\n\r\n  // Body text color;\r\n  @Input() bodyTextColor: string | undefined = '#0c112b';\r\n\r\n  // Header text color;\r\n  @Input() headerTextColor: string | undefined = '#2a1f73';\r\n\r\n  // Header text color;\r\n  @Input() checkboxesColor: string | undefined = '#2a1f73';\r\n\r\n  // Header text size;\r\n  @Input() headerTextFontsSize: number | undefined = 14;\r\n\r\n  // Body text color;\r\n  @Input() bodyTextFontsSize: number | undefined = 14;\r\n\r\n  // Header font weight;\r\n  @Input() headerFontWeight: number | undefined = 500;\r\n\r\n  // Body Font Weight;\r\n  @Input() bodyFontWeight: number | undefined = 400;\r\n\r\n  // Checked Row Background Color;\r\n  @Input() checkedRowBackgroundColor: string | undefined = 'aliceblue';\r\n\r\n  // dropdowns Background Color;\r\n  @Input() dropdownsBackgroundColor: string | undefined = '#f6f8f8';\r\n\r\n\r\n  @Input() footerRowBackgroundColor: string | undefined = '';\r\n\r\n  // Footer row Height;\r\n  @Input() footerRowHeight: number = 46;\r\n\r\n  // Footer row Height;\r\n  @Input() topGroupedBadgesBackgroundColor: string | undefined = '';\r\n\r\n  // Show Row wise grouping;\r\n  @Input() showRowsGrouping: boolean | undefined = false;\r\n\r\n  // Show Row wise grouping;\r\n  @Input() showFilterRow: boolean | undefined = false;\r\n\r\n  // Show Row wise grouping;\r\n  @Input() fontFaimly: string | undefined = 'sans-serif';\r\n\r\n  // Show SideColumn;\r\n  @Input() showSideMenu: boolean = false;\r\n\r\n  // Footer Padding\r\n  @Input() footerPadding: number = 3\r\n\r\n\r\n  // Footer Padding\r\n  @Input() topFilterRowHeight: number = 50;\r\n\r\n  // Show Rows shading\r\n  @Input() rowShadingEnabled: boolean = false;\r\n\r\n  // Show Rows shading\r\n  @Input() showSerialNumber: boolean = false;\r\n\r\n  // Single Spa Url Attach to icons\r\n  @Input() singleSpaAssetsPath: string = 'assets/';\r\n\r\n\r\n  // Applied Filters\r\n  @Input() filtersConfig: any[] = [];\r\n\r\n\r\n  // Applied Filters\r\n  @Input() loading: boolean = false;\r\n\r\n  //Vertical Scrollbar style\r\n  @Input() verticalScrollbarWidth: 'auto' | 'thin' = 'auto';\r\n\r\n  //Horizintal Scrollbar style\r\n  @Input() horizintalScrollbarWidth: 'auto' | 'thin' = 'auto';\r\n\r\n  // Show Cell details box\r\n  @Input() showCellDetailsBox: boolean = false;\r\n\r\n  //Date format\r\n\r\n  @Input() dateFormat: string = ''\r\n\r\n  //Date format\r\n  @Input() tableSearch: string = '';\r\n\r\n\r\n  //Date format\r\n  @Input() actions: any[] = ['edit', 'delete'];\r\n\r\n\r\n  // Table Config for paginations is here\r\n  @Input() config: any;\r\n\r\n\r\n  // Selection task bar\r\n  @Input() showTaskbar = false\r\n\r\n  // Table Name for state manage\r\n  @Input() tableName = true\r\n\r\n\r\n  // Listing type\r\n  @Input() listingType: string | boolean = '';\r\n\r\n  // Listing type\r\n\r\n  @Input() checkboxState: { reset: boolean } = {\r\n    reset: true\r\n  }\r\n\r\n  // Taskbar actions\r\n  @Input() taskbarActions: any[] = []\r\n\r\n\r\n  // Sorting Config to show sort icons\r\n  @Input() sortingConfig: { field: string, order_by: string } | null = null;\r\n\r\n\r\n  @Input() tableFilterViewId: any = '';\r\n\r\n\r\n  @Input() selectedTableLayout: any = 'medium'\r\n\r\n  @Input() closeDropdown: { preset: { closed: boolean, loading: boolean } } = { preset: { closed: false, loading: false } };\r\n\r\n  // Table View\r\n\r\n  // GlobalSearch\r\n  @Input() globalSearchText: string = '';\r\n\r\n  // Nested Table Row Fontsize\r\n  @Input() nestedTablerowFontsize = 14;\r\n\r\n  // Nested table row Header row Height\r\n  @Input() nestedTableHeaderRowHeight = 40;\r\n\r\n  // Nested Table row height\r\n  @Input() nestedTablerowHeight = 45;\r\n\r\n\r\n  @Input() gridType: string = '';\r\n\r\n  @Input() currencySymbol: string = '';\r\n\r\n  @Input() currencyFormat: string = '';\r\n\r\n  @Input() leftPinnedBoxshadow: string = '';\r\n\r\n  @Input() rightPinnedBoxshadow: string = '';\r\n\r\n  // GlobalSearch\r\n  @Input() selectedRowsBackgroundColor: string = '#8ac5ff';\r\n\r\n  // GlobalSearch\r\n  @Input() nestedTableHeaderBackgroundColor: string = '#f6f8ff';\r\n\r\n\r\n  @Input() nestedTableRowBackgroundColor: string = '#eaeaea';\r\n\r\n  @Input() tableView: any[] = [];\r\n\r\n  @Input() buttons: { name: string; is_showIcon: boolean; icon: string, has_permission: boolean }[] = [];\r\n\r\n  @Input() keepMultipleExpandedDetails = false;\r\n\r\n\r\n  @Input() showTotalAmountRow = false;\r\n\r\n\r\n  @Input() enableGlobalSearch = true;\r\n\r\n\r\n  @Input() tableType = '';\r\n\r\n\r\n  @Input() enableExport = false;\r\n\r\n\r\n  @Input() showFullScreenButton = false;\r\n\r\n\r\n  @Input() enableCut = false;\r\n\r\n\r\n  @Input() tabs: string[] = [];\r\n\r\n  @Input() showCheckboxes = true;\r\n\r\n\r\n  @Input() pageSizeOptions = [10, 25, 50, 75, 100, 150, 200, 250, 300, 500];\r\n\r\n\r\n  @Input() resetAllFilters = { resetAll: false };\r\n\r\n\r\n  @Input() columnThreedotsMunuConfig = {\r\n    showPinleft: true,\r\n    showPinright: true,\r\n    showAscending: true,\r\n    showDescending: true,\r\n    showFilter: true,\r\n    showRowsGrouping: this.showRowsGrouping,\r\n    showAutosizeAllColumns: true,\r\n    showAutosizeThisColumn: false,\r\n    showChoseColumns: false,\r\n    showResetColumns: false,\r\n  };\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  // ///////////////////////////////////////////////////////////////////////////////////////////\r\n  // ///////////////////////////////////////////////////////////////////////////////////////////\r\n  //                         Out Put Events\r\n  // ///////////////////////////////////////////////////////////////////////////////////////////\r\n  // ///////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n\r\n\r\n  //Change Table Layout\r\n  @ViewChildren(CellHostDirective) cellHosts!: QueryList<CellHostDirective>;\r\n\r\n  @Output() public changeLayout = new EventEmitter<any>();\r\n\r\n  @Output() public customCellEvent = new EventEmitter<any>();\r\n\r\n  // Filter Apply event;\r\n  @Output() public filterOptions = new EventEmitter<any>();\r\n\r\n  @Output() genericEvent: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() tablePresetConfig: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() sortingOrderOptions: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output() createUpdateConfigListing: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  isFullScreen = false;\r\n  activeTab: string | null = null;\r\n  groupedColumns: any[] = [];\r\n  activeCol: any = null;\r\n  activeFilterCell: any = null;\r\n  showActionsDropDown = false;\r\n  sideMenuVisible = false;\r\n  pivotMode: boolean = false;\r\n  columnSearch: string = '';\r\n  expandAllAccordians = true;\r\n  currentOpenedSideMenue: 'cols' | 'filtrs' | null = null;\r\n  originalColumns: any[] = [];\r\n  originalDataSet: any[] = [];\r\n  activeTopButton: string | null = '';\r\n  filterColumnsList: any[] = [];\r\n  groupBoxPadding = 200;\r\n  presetName: string = '';\r\n  presetFilter: boolean = false;\r\n  searchTextPresetTable = '';\r\n  addFilterColumnInput = '';\r\n  searchInDropdown = '';\r\n  private secretKey = 'tb-super-admin'\r\n  addFilterDropdownSearch = ''\r\n  topShowHideColumns = '';\r\n  choseColumnsSearch = ''\r\n  sideNestedFilterSearch = ''\r\n  editinDropdownSearch = '';\r\n  isThreeDotsFilterOpen = false;\r\n  confirmDelete = false;\r\n  fontFamilies: string[] = [\r\n    // Common Excel fonts\r\n    'Arial',\r\n    'Arial Black',\r\n    'Bahnschrift',\r\n    'Calibri',\r\n    'Cambria',\r\n    'Cambria Math',\r\n    'math',\r\n    'Candara',\r\n    'Comic Sans MS',\r\n    'Consolas',\r\n    'Constantia',\r\n    'Corbel',\r\n    'Courier New',\r\n    'Ebrima',\r\n    'Franklin Gothic Medium',\r\n    'Gabriola',\r\n    'Gadugi',\r\n    'Georgia',\r\n    'Impact',\r\n    'Ink Free',\r\n    'Javanese Text',\r\n    'Leelawadee UI',\r\n    'Lucida Console',\r\n    'Lucida Sans Unicode',\r\n    'Malgun Gothic',\r\n    'Microsoft Himalaya',\r\n    'Microsoft JhengHei',\r\n    'Microsoft New Tai Lue',\r\n    'Microsoft PhagsPa',\r\n    'Microsoft Sans Serif',\r\n    'Microsoft Tai Le',\r\n    'Microsoft YaHei',\r\n    'Microsoft Yi Baiti',\r\n    'Mongolian Baiti',\r\n    'MS Gothic',\r\n    'MS PGothic',\r\n    'MS UI Gothic',\r\n    'MV Boli',\r\n    'Nirmala UI',\r\n    'Palatino Linotype',\r\n    'Segoe Print',\r\n    'Segoe Script',\r\n    'Segoe UI',\r\n    'Segoe UI Historic',\r\n    'Segoe UI Emoji',\r\n    'Segoe UI Symbol',\r\n    'SimSun',\r\n    'Sitka Small',\r\n    'Sylfaen',\r\n    'Symbol',\r\n    'Tahoma',\r\n    'Times New Roman',\r\n    'Trebuchet MS',\r\n    'Verdana',\r\n    'Webdings',\r\n    'Wingdings',\r\n    'Yu Gothic',\r\n    'sans-serif',\r\n    'serif',\r\n    'monospace',\r\n    'Inter'\r\n  ];\r\n\r\n  fontSizes: string[] = [\r\n    '8', '9', '10', '11', '12', '14', '16', '18', '20', '24', '28', '32'\r\n  ];\r\n\r\n  hasScroll = false;\r\n\r\n\r\n\r\n\r\n  constructor(\r\n    private columnService: SplitColumnsService,\r\n    public cdr: ChangeDetectorRef,\r\n    public commonSevice: CommonService,\r\n    private elementRef: ElementRef,\r\n    private ngZone: NgZone,\r\n    private copyService: CopyServiceService,\r\n    private renderer: Renderer2,\r\n    private sanitizer: DomSanitizer,\r\n    private exportService: ExportService,\r\n    private datePipe: DatePipe,\r\n    private formatCurrency: FormatCurrencyPipe,\r\n\r\n  ) { }\r\n\r\n  @ViewChild('cellText', { static: false }) cellText!: any;\r\n  @ViewChild('nestedHeader', { static: false }) nestedHeader!: ElementRef;\r\n  ngAfterViewInit() {\r\n    this.ngZone.onStable.pipe(take(1)).subscribe(async () => {\r\n      await this.SetColumnsDefaultWidth();\r\n      await this.refreshHeaders();\r\n      this.updateFlattenedData();\r\n      this.computeViewportRows();\r\n      this.updateVisibleRows(0);\r\n      this.hasScroll = this.hasHorizontalScrollbar();\r\n\r\n      if (this.cellText) {\r\n        const observer = new ResizeObserver(() => {\r\n          this.cdr.detectChanges();\r\n        });\r\n        observer.observe(this.cellText.nativeElement);\r\n      }\r\n\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.renderCustomCells();\r\n  }\r\n\r\n  private injector = inject(Injector);\r\n\r\n  createCellInjector(row: any, col: any): Injector {\r\n    return Injector.create({\r\n      providers: [\r\n        { provide: 'rowData', useValue: row },\r\n        { provide: 'colData', useValue: col }\r\n      ],\r\n      parent: this.injector\r\n    });\r\n  }\r\n\r\n\r\n  private renderCustomCells(): void {\r\n    const hosts = this.cellHosts.toArray();\r\n    let hostIndex = 0;\r\n\r\n    for (const row of this.visibleRows) {\r\n      for (const col of this.columns) {\r\n        const host = hosts[hostIndex++];\r\n        if (!host || !col.cellRenderer) continue;\r\n\r\n        const viewContainer = host.viewContainerRef;\r\n        viewContainer.clear();\r\n\r\n        const compRef = viewContainer.createComponent(col.cellRenderer);\r\n\r\n        const params = {\r\n          row,\r\n          col,\r\n          value: this.getNestedValue(row, col.field),\r\n          api: this,\r\n        };\r\n\r\n        if ((compRef.instance as any).gridInit) {\r\n          (compRef.instance as any).gridInit(params);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewChecked(): void {\r\n    this.addStylesToImages();\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  ngOnInit() {\r\n    //  if (this.tabs?.length) {\r\n    //   this.activeTab = this.tabs[0];\r\n    // }\r\n    // this.autosizeAllColumns();\r\n    if (!this.curretaTablePresetForUpdate) {\r\n      this.autosizeAllColumns();\r\n    }\r\n\r\n    // const user = this.getDecrypt('user');\r\n    // this.currencyFormat = user?.currency_format;\r\n    // this.currencySymbol = user?.currency_symbol;\r\n    // this.dateFormat = user?.date_format;\r\n    if (!this.dateFormat) {\r\n      const storedDateFormat = localStorage.getItem('dateformat');\r\n      if(storedDateFormat){\r\n        this.dateFormat = storedDateFormat ? JSON.parse(storedDateFormat) : 'dd/MM/yyyy';\r\n      }\r\n    }\r\n\r\n    if (!this.currencyFormat) {\r\n      const storedCurrencyFormat = localStorage.getItem('currencyFormat');\r\n      if(storedCurrencyFormat){\r\n        this.currencyFormat = storedCurrencyFormat ? JSON.parse(storedCurrencyFormat) : '1,234,567.89';\r\n      }\r\n    }\r\n\r\n    if (!this.currencySymbol) {\r\n      const storedCurrencySymbol = localStorage.getItem('currencySymbol');\r\n      if (storedCurrencySymbol){\r\n        this.currencySymbol = storedCurrencySymbol ? JSON.parse(storedCurrencySymbol) : '$';\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  // private getDecrypt(key:string){\r\n  //     const value = localStorage.getItem(key)\r\n  //     try {\r\n  //       return JSON.parse(CryptoJS.AES.decrypt(value as string, this.secretKey).toString(CryptoJS.enc.Utf8))\r\n  //     } catch (e) {\r\n  //       return null;\r\n  //     }\r\n  //   }\r\n\r\n  dataSetLoading = false;\r\n  async ngOnChanges(changes: SimpleChanges) {\r\n    if (changes['columns']) {\r\n      await this.setColumnsColumnDropdownValus();\r\n\r\n    }\r\n\r\n    if (changes['tabs']) {\r\n      if (changes['tabs']) {\r\n        const allTabs = JSON.parse(localStorage.getItem('activeTabs') || '{}');\r\n        const savedTab = allTabs[this.tableType];\r\n        if(this.tabs.includes('Current Policy')){\r\n          this.activeTab = this.tabs?.[1] || 'Current Policy';\r\n        }else{\r\n          this.activeTab = savedTab || this.tabs?.[0];\r\n        }\r\n\r\n        // if (this.tableType) {\r\n        //   this.setActiveTab(this.activeTab);\r\n        // }\r\n      }\r\n    }\r\n    if (changes['filtersConfig']) {\r\n      this.checkFilterChangesEffect();\r\n      await this.applyFilteroptionList();\r\n    }\r\n\r\n    if (changes['columns']?.currentValue?.length) {\r\n\r\n      await this.applyFilteroptionList();\r\n\r\n      this.originalColumns = this.columns.map(col => ({\r\n        ...col,\r\n        query: col.query ? { ...col.query } : null,\r\n        column_dropdown_value: col.column_dropdown_value\r\n          ? [...col.column_dropdown_value]\r\n          : [],\r\n      }));\r\n\r\n\r\n      if (this.dataGridContainer?.nativeElement?.offsetWidth) {\r\n        await this.SetColumnsDefaultWidth();\r\n        await this.updateColumnWidthsAndGroups();\r\n        await this.refreshPreviewColumns();\r\n        this.setSectionsWidth();\r\n      }\r\n\r\n      this.ngZone.onStable.pipe(take(1)).subscribe(() => {\r\n        this.cdr.detectChanges();\r\n      });\r\n    }\r\n\r\n    if (changes['dataSet']) {\r\n      this.dataSet = this.dataSet?.map((row, i) => ({\r\n        ...row,\r\n        __virtualIndex: i + 1,\r\n      }));\r\n      this.originalDataSet = structuredClone(this.dataSet);\r\n      this.expandedCells.clear();\r\n      this.updateFlattenedData();\r\n\r\n      this.ngZone.onStable.pipe(take(1)).subscribe(() => {\r\n        this.computeViewportRows();\r\n        this.updateVisibleRows(0);\r\n\r\n        this.cdr.detectChanges();\r\n      });\r\n\r\n      if (this.centerPinnedHeader?.nativeElement) {\r\n        void this.centerPinnedHeader.nativeElement.offsetWidth;\r\n\r\n        this.dataSetLoading = true;\r\n        setTimeout(() => {\r\n          if (this.centerScrollableBody?.nativeElement) {\r\n            this.centerScrollableBody.nativeElement.scrollLeft =\r\n              this.centerPinnedHeader.nativeElement.scrollLeft;\r\n          }\r\n          this.dataSetLoading = false;\r\n          this.cdr.detectChanges();\r\n        }, 500);\r\n      }\r\n\r\n      this.applyRowsSelectionState();\r\n\r\n      if (this.groupedColumns?.length) {\r\n        const fields = this.groupedColumns.map((item) => item.field);\r\n        this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n\r\n        this.ngZone.onStable.pipe(take(1)).subscribe(() => {\r\n          this.updateFlattenedData();\r\n          this.updateColumnWidthsAndGroups();\r\n          this.refreshPreviewColumns();\r\n          this.updateVisibleRows(0);\r\n          this.loading = false;\r\n          this.groupBoxPadding = this.columnsGroupedBox?.nativeElement.offsetWidth;\r\n          this.cdr.detectChanges();\r\n        });\r\n      }\r\n    }\r\n\r\n    if (changes['checkboxState']?.currentValue?.reset) {\r\n      this.selectedRows.clear();\r\n      this.clearSelectionState(this.tableType);\r\n\r\n      const ids = Array.from(this.selectedRows);\r\n      const event = {\r\n        data: {\r\n          listingType: this.listingType,\r\n          obj: ids,\r\n        },\r\n        eventType: 'onSelectRow',\r\n      };\r\n\r\n      this.genericEvent.emit(event);\r\n\r\n      this.ngZone.onStable.pipe(take(1)).subscribe(() => {\r\n        this.cdr.detectChanges();\r\n      });\r\n    }\r\n\r\n    if (changes['closeDropdown'] && this.closeDropdown.preset.closed) {\r\n      this.activeTopButton = null;\r\n      this.presetFilter = false;\r\n      this.presetName = '';\r\n    }\r\n\r\n    // if (changes['oddRowsBackgroundColor']) {\r\n    //   this.rowShadingEnabled = !!this.oddRowsBackgroundColor;\r\n    // }\r\n\r\n    if (changes['resetAllFilters'] && this.resetAllFilters.resetAll) {\r\n      this.clearAllFilters();\r\n    }\r\n\r\n    if (changes['tableView']) {\r\n      setTimeout(() => {\r\n        const viewValue = this.tableView;\r\n        let temprorySelected = Array.isArray(viewValue)\r\n          ? viewValue.find(item => item.is_temp)\r\n          : null;\r\n\r\n        if (!temprorySelected) {\r\n          temprorySelected = Array.isArray(viewValue)\r\n            ? viewValue.find(item => item.is_default)\r\n            : null;\r\n        }\r\n\r\n        this.curretaTablePresetForUpdate = temprorySelected || null;\r\n        this.presetName = temprorySelected?.name || '';\r\n        this.presetFilter = temprorySelected?.activeFilters || false;\r\n        if (this.curretaTablePresetForUpdate) {\r\n          this.rowShadingEnabled = temprorySelected.config.rowShadingEnabled;\r\n          this.showVerticalBorder = temprorySelected.config.showVerticalBorder;\r\n          this.fontFaimly = temprorySelected.config.fontFaimly;\r\n          this.headerTextFontsSize = temprorySelected.config.headerTextFontsSize;\r\n          this.selectedTableLayout = temprorySelected.config.selectedTableLayout;\r\n          this.bodyTextFontsSize = temprorySelected.config.bodyTextFontsSize;\r\n          this.globalSearchText = temprorySelected.config.globalSearch;\r\n          this.setTableLayout(this.selectedTableLayout);\r\n          this.oddRowsBackgroundColor = temprorySelected?.config?.oddRowsBackgroundColor || '#f1f1f1';\r\n          this.cdr.detectChanges();\r\n        } else {\r\n          this.rowShadingEnabled = false;\r\n          this.showVerticalBorder = false;\r\n          this.fontFaimly = 'Inter';\r\n          this.headerTextFontsSize = 14;\r\n          this.selectedTableLayout = 'medium';\r\n          this.bodyTextFontsSize = 14;\r\n          this.globalSearchText = '';\r\n          this.autosizeAllColumns();\r\n        }\r\n        this.cdr.detectChanges();\r\n      }, 0);\r\n    }\r\n\r\n  }\r\n\r\n  async setColumnsColumnDropdownValus(): Promise<void> {\r\n    if (!this.columns) return;\r\n    // Just removed temporary for super admin will set it again\r\n    if(this.columns?.length){\r\n      this.columns = this.columns?.filter(c => c?.field?.trim() !== 'is_deleted')\r\n    }\r\n    this.columns = await this.commonSevice.copyDropdownDataRecursively(this.columns);\r\n  }\r\n\r\n\r\n\r\n\r\n  applyRowsSelectionState() {\r\n    const selectedIdsFromState = this.restoreSelection(this.tableType);\r\n    if (selectedIdsFromState.size > 0) {\r\n      const ids = Array.from(this.selectedRows);\r\n      const event = {\r\n        data: {\r\n          listingType: this.listingType,\r\n          obj: ids\r\n        },\r\n        eventType: \"onSelectRow\",\r\n      }\r\n      this.genericEvent.emit(event);\r\n    }\r\n  }\r\n\r\n  clearSelectionState(tableType: string): void {\r\n    const stored = JSON.parse(localStorage.getItem('datatableSelections') || '{\"selectedRows\": {}}');\r\n    if (stored.selectedRows && stored.selectedRows[tableType]) {\r\n      delete stored.selectedRows[tableType];\r\n    }\r\n    localStorage.setItem(\r\n      'datatableSelections',\r\n      JSON.stringify(stored)\r\n    );\r\n  }\r\n\r\n\r\n\r\n  async applyFilteroptionList() {\r\n    const updatedColumns = await this.commonSevice.applyFiltersToColumns(this.columns, this.filtersConfig);\r\n    this.columns = [...updatedColumns];\r\n    this.cdr.detectChanges();\r\n  }\r\n  leftPinnedColumns: any[] = [];\r\n  centerColumns: any[] = [];\r\n  rightPinnedColumns: any[] = [];\r\n\r\n  previewLeftPinnedColumns: any[] = [];\r\n  previewCenterColumns: any[] = [];\r\n  previewRightPinnedColumns: any[] = [];\r\n\r\n  // Main Container Template References\r\n  @ViewChild('dataGridContainer')\r\n  dataGridContainer!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('taskManagementContainer')\r\n  taskManagementContainer!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('nestedTableContainer')\r\n  nestedTableContainer!: ElementRef<HTMLDivElement>;\r\n\r\n  // Body Template References\r\n  @ViewChild('leftPinnedBody')\r\n  leftPinnedBody!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('centerPinnedBody')\r\n  centerPinnedBody!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('rightPinnedBody')\r\n  rightPinnedBody!: ElementRef<HTMLDivElement>;\r\n\r\n  // Headers Template References\r\n  @ViewChild('leftPinnedHeader')\r\n  leftPinnedHeader!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('centerPinnedHeader')\r\n  centerPinnedHeader!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('rightPinnedHeader')\r\n  rightPinnedHeader!: ElementRef<HTMLDivElement>;\r\n\r\n  @ViewChild('columnsGroupedBox')\r\n  columnsGroupedBox!: ElementRef<HTMLDivElement>;\r\n\r\n  // Center Fake scrollbard\r\n  @ViewChild('centerFakeScrollbar')\r\n  centerFakeScrollbar!: ElementRef<HTMLDivElement>;\r\n  async updateColumnWidthsAndGroups(columns: any = null) {\r\n    if (!this.dataGridContainer) return;\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n    // Wrap in a promise so we can await\r\n    const { left, center, right }: any = await new Promise(resolve => {\r\n      const prepared = this.columnService.prepareColumns(\r\n        columns ? columns : this.columns,\r\n        containerWidth\r\n      );\r\n      resolve(prepared);\r\n    });\r\n\r\n    this.leftPinnedColumns = left;\r\n    this.centerColumns = center;\r\n    this.rightPinnedColumns = right;\r\n    await new Promise(r => setTimeout(r, 0));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  async refreshPreviewColumns(columns: any = null) {\r\n    if (!this.dataGridContainer) return;\r\n\r\n    const containerWidth = this.dataGridContainer.nativeElement.offsetWidth;\r\n\r\n    // Wrap prepareColumns in a Promise to make it awaitable\r\n    const { left, center, right }: any = await new Promise(resolve => {\r\n      const prepared = this.columnService.prepareColumns(\r\n        columns ? columns : this.columns,\r\n        containerWidth\r\n      );\r\n      resolve(prepared);\r\n    });\r\n\r\n    this.previewLeftPinnedColumns = left;\r\n    this.previewCenterColumns = center;\r\n    this.previewRightPinnedColumns = right;\r\n    await new Promise(r => setTimeout(r, 10));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  async SetColumnsDefaultWidth() {\r\n    const visibleColumns = this.getVisibleLeafColumns(this.columns);\r\n    const visibleCount = visibleColumns.length;\r\n\r\n    if (visibleCount === 0) return;\r\n\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n    if (this.showSerialNumber) containerWidth -= 55;\r\n    if (this.showSideMenu) containerWidth -= 29;\r\n    // if (this.gridType == 'Assets' || this.gridType == 'Tasks') containerWidth -= 30;\r\n    // containerWidth -= 55;\r\n    // if (this.showSerialNumber) containerWidth -= 55;\r\n    // if (this.showSideMenu) containerWidth -= 29;\r\n    // if (this.gridType == 'Assets' || this.gridType == 'Tasks') containerWidth -= 30;\r\n    // containerWidth -= 5;\r\n    this.columns = this.columnService.assignDefaultWidths(\r\n      this.columns,\r\n      containerWidth\r\n    );\r\n    await new Promise(resolve => setTimeout(resolve, 0));\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  setSectionsWidth() {\r\n    const left = document.querySelector('.left-pinned-body') as HTMLElement;\r\n    const center = document.querySelector(\r\n      '.center-scrollable-body'\r\n    ) as HTMLElement;\r\n    const right = document.querySelector('.right-pinned-body') as HTMLElement;\r\n    if (left) {\r\n      left.style.minWidth = `${this.leftPinnedHeader.nativeElement.offsetWidth}`;\r\n    }\r\n    if (center) {\r\n      left.style.minWidth = `${this.centerPinnedHeader.nativeElement.offsetWidth}`;\r\n    }\r\n    if (right) {\r\n      left.style.minWidth = `${this.rightPinnedHeader.nativeElement.offsetWidth}`;\r\n    }\r\n  }\r\n\r\n  // onCenterBodyScroll(): void {\r\n  //   const scrollTop = this.centerPinnedBody.nativeElement.scrollTop;\r\n  //   const scrollLeft = this.centerPinnedBody.nativeElement.scrollLeft;\r\n\r\n  //   // Sync vertical scroll with left & right pinned bodies\r\n  //   this.leftPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  //   this.rightPinnedBody.nativeElement.scrollTop = scrollTop;\r\n\r\n  //   // Sync horizontal scroll with center header\r\n  //   this.centerPinnedHeader.nativeElement.scrollLeft = scrollLeft;\r\n  //   this.centerFakeScrollbar.nativeElement.scrollLeft = scrollLeft;\r\n  // }\r\n\r\n  // onLeftBodyScroll(): void {\r\n  //   const scrollTop = this.leftPinnedBody.nativeElement.scrollTop;\r\n  //   this.centerPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  //   this.rightPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  // }\r\n  // onRightBodyScroll(): void {\r\n  //   const scrollTop = this.rightPinnedBody.nativeElement.scrollTop;\r\n  //   this.centerPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  //   this.leftPinnedBody.nativeElement.scrollTop = scrollTop;\r\n  // }\r\n\r\n  fakeScrollbarScrollLeft = 0;\r\n  // onFakeScroll(event: Event) {\r\n  //   const target = event.target as HTMLElement;\r\n  //   this.fakeScrollbarScrollLeft = target.scrollLeft;\r\n  //   this.centerPinnedBody.nativeElement.scrollLeft = target.scrollLeft;\r\n  //   this.centerPinnedHeader.nativeElement.scrollLeft = target.scrollLeft;\r\n  // }\r\n\r\n\r\n\r\n\r\n  getNestedValue(obj: any, field: string): any {\r\n    return field?.split('.').reduce((acc, part) => acc && acc[part], obj);\r\n  }\r\n\r\n  isNestedValueArray(obj: any, field: string): boolean {\r\n    if (!obj || !field) return false;\r\n    const value = field\r\n      .split('.')\r\n      .reduce((acc, part) => (acc && acc[part] !== undefined ? acc[part] : undefined), obj);\r\n    return Array.isArray(value);\r\n  }\r\n\r\n  onResizeGroup(event: MouseEvent, col: any, isRightPinned?: boolean): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n\r\n    const startX = event.clientX;\r\n    const children = col.children || [];\r\n    if (!children.length) return;\r\n\r\n    const childWidths: { field: string; width: number }[] = children.map(\r\n      (child: any) => {\r\n        const el = document.querySelector(\r\n          `[field=\"${child.field}\"]`\r\n        ) as HTMLElement;\r\n        return {\r\n          field: child.field,\r\n          width: el?.offsetWidth || 0,\r\n        };\r\n      }\r\n    );\r\n\r\n    const totalInitialWidth = childWidths.reduce(\r\n      (sum, col) => sum + col.width,\r\n      0\r\n    );\r\n\r\n    const onMouseMove = (moveEvent: MouseEvent) => {\r\n      let deltaX = moveEvent.clientX - startX;\r\n\r\n      if (isRightPinned) {\r\n        deltaX = -deltaX;\r\n      }\r\n\r\n      // Prevent shrinking too small\r\n      if (totalInitialWidth + deltaX < children.length * 80) return;\r\n\r\n      let totalNewWidth = 0;\r\n\r\n      childWidths.forEach((child) => {\r\n        const ratio = child.width / totalInitialWidth;\r\n        const newWidth = Math.max(child.width + deltaX * ratio, 80);\r\n        totalNewWidth += newWidth;\r\n\r\n        const childEls = document.querySelectorAll(`[data-field=\"${child.field}\"]`);\r\n        childEls.forEach((el: Element) => {\r\n          const elHtml = el as HTMLElement;\r\n          elHtml.style.minWidth = `${newWidth}px`;\r\n          elHtml.style.width = `${newWidth}px`;\r\n        });\r\n\r\n        this.updateColumnWidthInSourceByField(child.field, newWidth);\r\n      });\r\n\r\n      // ✅ Update group header width in DOM\r\n      const groupHeaderEl = document.querySelector(\r\n        `[group=\"${col.header}\"]`\r\n      ) as HTMLElement;\r\n      if (groupHeaderEl) {\r\n        groupHeaderEl.style.width = `${totalNewWidth}px`;\r\n      }\r\n    };\r\n\r\n    const onMouseUp = () => {\r\n      if (this.tableFilterViewId) {\r\n        this.savePreset('mouseUp');\r\n      }\r\n      this.refreshHeaders();\r\n      window.removeEventListener('mousemove', onMouseMove);\r\n      window.removeEventListener('mouseup', onMouseUp);\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n    };\r\n\r\n    window.addEventListener('mousemove', onMouseMove);\r\n    window.addEventListener('mouseup', onMouseUp);\r\n  }\r\n\r\n  private updateColumnWidthInSourceByField(field: string, width: number): void {\r\n    const update = (columns: any[]) => {\r\n      for (const col of columns) {\r\n        if (col.children?.length) {\r\n          update(col.children);\r\n        } else if (col.field === field) {\r\n          col.width = width;\r\n        }\r\n      }\r\n    };\r\n\r\n    update(this.columns);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n   cleanColumns(columns: any[]): any[] {\r\n      return columns.map((col) => {\r\n        const {\r\n          __typename,\r\n          _id,\r\n          column_dropdown_value,\r\n          filterValue,\r\n          expandedFilter,\r\n          query,\r\n          isRowGrouped,\r\n          ...rest\r\n        } = col;\r\n\r\n        // Clean dropdown values (__typename removed)\r\n        const cleanedDropdown = Array.isArray(column_dropdown_value)\r\n          ? column_dropdown_value.map(({ __typename, ...dRest }) => dRest)\r\n          : column_dropdown_value\r\n            ? (({ __typename, ...dRest }) => dRest)(column_dropdown_value)\r\n            : null;\r\n\r\n        // Clean query (__typename removed)\r\n        const cleanedQuery = Array.isArray(query)\r\n          ? query.map(({ __typename, ...qRest }) => qRest)\r\n          : query\r\n            ? (({ __typename, _ids, ...qRest }) => qRest)(query)\r\n            : null;\r\n\r\n        return {\r\n          ...rest,\r\n          column_dropdown_value: cleanedDropdown,\r\n          query: cleanedQuery,\r\n        };\r\n      });\r\n    }\r\n\r\n  onResizeColumn(event: MouseEvent, col: any): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n\r\n    const startX = event.clientX;\r\n\r\n    const targetEl = document.querySelector(\r\n      `[field=\"${col.field}\"]`\r\n    ) as HTMLElement;\r\n    const initialWidth = targetEl?.offsetWidth || 150;\r\n\r\n    const matchingEls = document.querySelectorAll(`[data-field=\"${col.field}\"]`);\r\n\r\n    // 👉 Add highlight while resizing\r\n    if (col?.pinned == 'right') {\r\n      matchingEls.forEach((el: Element) => {\r\n        (el as HTMLElement).classList.add('resizing-highlight-right');\r\n      });\r\n    } else {\r\n      matchingEls.forEach((el: Element) => {\r\n        (el as HTMLElement).classList.add('resizing-highlight');\r\n      });\r\n    }\r\n\r\n    const onMouseMove = (moveEvent: MouseEvent) => {\r\n      let deltaX = moveEvent.clientX - startX;\r\n\r\n      // 👉 Reverse if the column is pinned to the right\r\n      if (col.pinned === 'right') {\r\n        deltaX = -deltaX;\r\n      }\r\n\r\n      let newWidth = initialWidth + deltaX;\r\n      if (newWidth < 80) return;\r\n\r\n      matchingEls.forEach((el: Element) => {\r\n        const element = el as HTMLElement;\r\n        element.style.minWidth = `${newWidth}px`;\r\n        element.style.width = `${newWidth}px`;\r\n      });\r\n\r\n      this.updateColumnWidthInSourceByField(col.field, newWidth);\r\n      col.width = newWidth;\r\n      this.hasScroll = this.hasHorizontalScrollbar();\r\n    };\r\n\r\n    const onMouseUp = () => {\r\n      if (this.tableFilterViewId) {\r\n        this.savePreset('mouseUp');\r\n      }\r\n      this.refreshHeaders();\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n\r\n      matchingEls.forEach((el: Element) => {\r\n        (el as HTMLElement).classList.remove('resizing-highlight');\r\n        (el as HTMLElement).classList.remove('resizing-highlight-right');\r\n      });\r\n\r\n      window.removeEventListener('mousemove', onMouseMove);\r\n      window.removeEventListener('mouseup', onMouseUp);\r\n    };\r\n\r\n    window.addEventListener('mousemove', onMouseMove);\r\n    window.addEventListener('mouseup', onMouseUp);\r\n  }\r\n\r\n\r\n\r\n  onResizeGroupBox(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n\r\n    const startX = event.clientX;\r\n\r\n    const targetEl = document.getElementById('groupBoxHeaderDiv');\r\n    const initialWidth = targetEl?.offsetWidth || 150;\r\n\r\n    const onMouseMove = (moveEvent: MouseEvent) => {\r\n      const deltaX = moveEvent.clientX - startX;\r\n\r\n      let newWidth = initialWidth + deltaX;\r\n      if (newWidth < 100) newWidth = 100;\r\n\r\n      if (targetEl) {\r\n        targetEl.style.width = `${newWidth}px`;\r\n        targetEl.style.minWidth = `${newWidth}px`;\r\n        this.groupBoxPadding = newWidth;\r\n      }\r\n    };\r\n\r\n    const onMouseUp = () => {\r\n      window.removeEventListener('mousemove', onMouseMove);\r\n      window.removeEventListener('mouseup', onMouseUp);\r\n    };\r\n\r\n    window.addEventListener('mousemove', onMouseMove);\r\n    window.addEventListener('mouseup', onMouseUp);\r\n  }\r\n\r\n  onPasteInFilterRowSearch(event: ClipboardEvent, col: any) {\r\n    setTimeout(() => {\r\n      this.onFilterChange(col);\r\n      this.applyDropdownFilter();\r\n    });\r\n  }\r\n\r\n  onFilterChange(col: any): void {\r\n    const filterValue = col.filterValue?.toLowerCase() || '';\r\n    this.selectedColumnForFilter = col;\r\n    if (!col?.query) {\r\n      col.query = {\r\n        first_condition: col.type == 'date' ? 'equal' : 'contain',\r\n        first_value: null,\r\n        second_condition: null,\r\n        second_value: null,\r\n        condition: null\r\n      }\r\n    }\r\n    col.query.first_value = filterValue;\r\n    this.firstValue = filterValue;\r\n  }\r\n\r\n  // Get Body Height\r\n  get bodyWrapperHeight(): string {\r\n    const rows = this.showColumnsGrouping && this.showFilterRow ? 3 : (this.showColumnsGrouping || this.showFilterRow ? 2 : 1);\r\n    const offset = this.headerRowHeight * rows + (this.hasScroll ? 17 : 0);\r\n    return `calc(100% - ${offset}px)`;\r\n  }\r\n\r\n  // Row Hover Logic Here\r\n  hoveredRowId: string | number | null = null;\r\n  onRowHover(row: any): void {\r\n    this.hoveredRowId = row._id || row.id;\r\n  }\r\n\r\n  onRowLeave(): void {\r\n    this.hoveredRowId = null;\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onDocumentClick(event: MouseEvent): void {\r\n    const target = event.target as HTMLElement;\r\n    this.isVisible = false;\r\n    this.openIndex = null;\r\n    if (\r\n      !this.hasParentWithClass(target, [\r\n        'three-dots',\r\n        'filter-icon-wrapper',\r\n        'column-menu',\r\n        'filter-menu',\r\n      ])\r\n    ) {\r\n      this.activeCol = null;\r\n      this.activeFilterCell = null;\r\n    }\r\n    if (!this.elementRef.nativeElement.contains(event.target)) {\r\n      this.showActionsDropDown = false;\r\n    }\r\n    const insideTopFilterRow = target.closest('.filter-tags') || target.closest('.add-filter-button-menu') ||\r\n      target.closest('.table-right-top-actions') || target.closest('.table-layout') || target.closest('.filter-row-filter-wrapper');\r\n    const isClickedInsideThreeDotsFilter = target.closest('.three-dots-filter') || target.closest('.filter-menu-container');\r\n    if (!isClickedInsideThreeDotsFilter) {\r\n      this.closeThreeDotsMenuFilter();\r\n    }\r\n    if (!insideTopFilterRow) {\r\n      this.closeFilterDropdowns(event);\r\n    }\r\n    if (!target.closest('.set-default-preset')) {\r\n      document.querySelector('.set-default-preset')?.classList?.remove('show');\r\n    }\r\n\r\n    if (!target.closest('.full-text-box') && !target.closest('.data-grid-header-wrapper')) {\r\n      this.collapseAllExpandedCells();\r\n    }\r\n\r\n    if (!target.closest('.data-grid-table-wrapper')) {\r\n      this.selectedKeys.clear();\r\n      this.activeCell = '';\r\n    }\r\n  }\r\n\r\n\r\n  closeThreeDotsMenuFilter() {\r\n    this.isThreeDotsFilterOpen = false;\r\n  }\r\n\r\n\r\n  closeFilterDropdowns(event: MouseEvent) {\r\n    this.isFilterOpen = false;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n    this.activeFilterCell = null;\r\n  }\r\n\r\n  private hasParentWithClass(\r\n    element: HTMLElement,\r\n    classList: string[]\r\n  ): boolean {\r\n    let el: HTMLElement | null = element;\r\n\r\n    while (el !== null) {\r\n      if (\r\n        el.classList &&\r\n        classList.some((className) => el!.classList.contains(className))\r\n      ) {\r\n        return true;\r\n      }\r\n      el = el.parentElement;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  isMenueHidden = false;\r\n  openThreeDotsMenu(event: MouseEvent, child: any, keepOriginalPosition = false) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.isMenueHidden = true;\r\n    const containerWidth = this.dataGridContainer?.nativeElement?.offsetWidth;\r\n    this.activeCol = child;\r\n    this.activeFilterCell = null;\r\n    const x = event.clientX;\r\n    setTimeout(() => {\r\n      const element = document.querySelector('.column-menu') as HTMLElement;\r\n      if (element) {\r\n        if (x > (containerWidth / 2)) {\r\n          element.style.left = `${x - 240}px`;\r\n        } else {\r\n          element!.style.left = `${x}px`;\r\n        }\r\n      }\r\n      this.isMenueHidden = false;\r\n      this.cdr.detectChanges();\r\n    }, 0);\r\n  }\r\n  // ////////////////////////////////////////////////////////////////////////////////////////\r\n  // ////////////////////////////////////////////////////////////////////////////////////////\r\n  // Column Three Dots Actions\r\n  // //////////////////////////////////////////////////////////////////////////////////////\r\n  // //////////////////////////////////////////////////////////////////////////////////////\r\n  sortAsc(col: any) {\r\n    if (!col.is_sortable) return;\r\n    col!.order_by = 'asc';\r\n    const event = {\r\n      order: 'asc',\r\n      column: col\r\n    }\r\n    this.cdr.detectChanges();\r\n    this.sortingOrderOptions.emit(event);\r\n  }\r\n\r\n  sortDesc(col: any) {\r\n    if (!col.is_sortable) return;\r\n    col!.order_by = 'desc';\r\n    const event = {\r\n      order: 'desc',\r\n      column: col\r\n    }\r\n    this.cdr.detectChanges();\r\n    this.sortingOrderOptions.emit(event);\r\n  }\r\n\r\n  resetSort(col: any) {\r\n    this.sortingConfig = { field: '', order_by: '' };\r\n    const event = { field: null, order_by: null }\r\n    this.cdr.detectChanges();\r\n    this.sortingOrderOptions.emit(event);\r\n  }\r\n\r\n\r\n  async updateColumnPinInSourceByField(\r\n    column: any,\r\n    pinned: 'left' | 'right' | null,\r\n    isNestedTable: any = false,\r\n    columns?: any\r\n  ) {\r\n    debugger\r\n    if (isNestedTable) {\r\n      this.pinUnpinColum(column, pinned, columns);\r\n      return;\r\n    }\r\n    const update = (columns: any[]) => {\r\n      for (const col of columns) {\r\n        if (col.children?.length) {\r\n          update(col.children);\r\n        } else if (col.field === column.field) {\r\n          col.pinned = pinned;\r\n        }\r\n      }\r\n    };\r\n    this.activeCol = null;\r\n    update(this.columns);\r\n    this.updateColumnWidthsAndGroups();\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n  }\r\n\r\n  private getVisibleLeafColumns = (columns: any[]): any[] => {\r\n    const result: any[] = [];\r\n    for (const column of columns) {\r\n      if (column.children && Array.isArray(column.children)) {\r\n        result.push(...this.getVisibleLeafColumns(column.children));\r\n      } else if (column.is_visible) {\r\n        result.push(column);\r\n      }\r\n    }\r\n    return result;\r\n  };\r\n\r\n  autosizeColumn(cols: any | any[]): void {\r\n    this.activeCol = null;\r\n\r\n    // Normalize input to an array\r\n    const columnsToResize = Array.isArray(cols) ? cols : [cols];\r\n\r\n    // Helper: Flatten all visible leaf columns\r\n    const visibleColumns = this.getVisibleLeafColumns(this.columns);\r\n    const visibleCount = visibleColumns.length;\r\n\r\n    if (visibleCount === 0) return;\r\n\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n    if (this.showSerialNumber) containerWidth -= 55;\r\n    if (this.showSideMenu) containerWidth -= 29;\r\n    if (this.gridType == 'Assets' || this.gridType == 'Tasks') containerWidth -= 30;\r\n    containerWidth -= 55;\r\n    const equalWidth = Math.floor(containerWidth / visibleCount);\r\n\r\n    // Resize each passed column\r\n    for (const col of columnsToResize) {\r\n      if (col && col.field) {\r\n        col.width = equalWidth;\r\n        this.updateColumnWidthInSourceByField(col.field, equalWidth);\r\n      }\r\n    }\r\n\r\n    this.updateColumnWidthsAndGroups();\r\n\r\n    setTimeout(() => {\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n    }, 1000);\r\n    this.refreshPreviewColumns();\r\n  }\r\n\r\n  getGroupWidth(group: any): number {\r\n    return (\r\n      group?.children\r\n        ?.filter((col: any) => col?.is_visible)\r\n        ?.reduce((acc: number, col: any) => acc + (col?.width || 0), 0) || 0\r\n    );\r\n  }\r\n\r\n  autosizeAllColumns(): void {\r\n    this.activeCol = null;\r\n\r\n    const getVisibleLeafColumns = (columns: any[]): any[] => {\r\n      const result: any[] = [];\r\n\r\n      for (const column of columns) {\r\n        if (column.children && Array.isArray(column.children)) {\r\n          result.push(...getVisibleLeafColumns(column.children));\r\n        } else if (column.is_visible !== false) {\r\n          result.push(column);\r\n        }\r\n      }\r\n\r\n      return result;\r\n    };\r\n\r\n    const visibleColumns = getVisibleLeafColumns(this.columns);\r\n    const visibleCount = visibleColumns.length;\r\n\r\n    if (visibleCount === 0) return;\r\n\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n    if (this.showSerialNumber) containerWidth -= 55;\r\n    if (this.showSideMenu) containerWidth -= 29;\r\n    if (this.gridType == 'Assets' || this.gridType == 'Tasks') containerWidth -= 30;\r\n    containerWidth -= 55;\r\n    const equalWidth = Math.max(Math.floor(containerWidth / visibleCount), 150);\r\n\r\n    // Update widths for all visible columns\r\n    visibleColumns.forEach((col) => {\r\n      col.width = equalWidth;\r\n      this.updateColumnWidthInSourceByField(col.field, equalWidth);\r\n    });\r\n\r\n    this.refreshHeaders();\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n    setTimeout(() => {\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n    }, 1000);\r\n  }\r\n\r\n  private markColumnAsGrouped(columns: any[], field: string): void {\r\n    for (const col of columns) {\r\n      if (col.field === field) {\r\n        col.isRowGrouped = true;\r\n        return;\r\n      }\r\n      if (col.children?.length) {\r\n        this.markColumnAsGrouped(col.children, field);\r\n      }\r\n    }\r\n  }\r\n\r\n  async groupBy(col: any) {\r\n    this.mainScroll.nativeElement.scrollTop = 0;\r\n    this.translateY = 0;\r\n    this.cdr.detectChanges();\r\n    this.activeCol = null;\r\n    if (!col) return;\r\n    this.loading = true;\r\n    this.cdr.detectChanges();\r\n    if (col?.is_groupable) {\r\n      this.groupedColumns.push(col);\r\n      this.markColumnAsGrouped(this.columns, col.field);\r\n    }\r\n    const fields = this.groupedColumns.map((item) => item.field);\r\n    this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n    setTimeout(() => {\r\n      this.updateFlattenedData();\r\n      this.updateColumnWidthsAndGroups();\r\n      this.refreshPreviewColumns();\r\n      this.updateVisibleRows(0);\r\n      this.loading = false;\r\n      this.cdr.detectChanges();\r\n    }, 100);\r\n\r\n    setTimeout(() => {\r\n      this.groupBoxPadding = this.columnsGroupedBox?.nativeElement.offsetWidth;\r\n      this.cdr.detectChanges()\r\n    }, 10);\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  async groupDataAsync(data: any[], groupFields: string[]): Promise<any[]> {\r\n    return new Promise(resolve => {\r\n      setTimeout(() => {\r\n        const result = this.groupData(data, groupFields);\r\n        resolve(result);\r\n      }, 0);\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n  chooseColumns() {\r\n    this.activeCol = null;\r\n    this.showColumnPanel = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  resetColumns() {\r\n    this.activeCol = null;\r\n\r\n    // this.columns = structuredClone(this.originalColumns);\r\n    // Deep copy nested objects but keep class refs safe\r\n    this.originalColumns = this.columns.map(col => ({\r\n      ...col,\r\n      // Deep copy nested objects but keep class refs safe\r\n      query: col.query ? { ...col.query } : null,\r\n      column_dropdown_value: col.column_dropdown_value\r\n        ? [...col.column_dropdown_value]\r\n        : [],\r\n    }));\r\n\r\n    this.SetColumnsDefaultWidth();\r\n    setTimeout(() => {\r\n      this.updateColumnWidthsAndGroups();\r\n      this.refreshPreviewColumns();\r\n      this.cdr.detectChanges();\r\n    }, 100);\r\n  }\r\n\r\n  clearFilter(col: any) {\r\n    col.firstValue = '';\r\n    col.secondValue = '';\r\n    col.firstCondition = 'contain';\r\n    col.secondCondition = null;\r\n    col.logic = 'AND';\r\n    col.selectAll = false;\r\n    col.selectedOptions = {};\r\n    col.searchValue = '';\r\n\r\n  }\r\n\r\n\r\n  applyFilter(col: any) {\r\n    this.filterColumnsList.push(col);\r\n  }\r\n\r\n  // Rows Selection Logic Goes Here\r\n\r\n  selectedRows: Set<string> = new Set();\r\n\r\n  /**\r\n   * Get normalized ID from row.\r\n   */\r\n  private getRowId(row: any): string {\r\n    return row.id ?? row._id;\r\n  }\r\n\r\n  /**\r\n   * Toggle a single row selection.\r\n   */\r\n  toggleRowSelection(row: any): void {\r\n    const id = this.getRowId(row);\r\n\r\n    if (this.selectedRows.has(id)) {\r\n      this.selectedRows.delete(id);\r\n    } else {\r\n      this.selectedRows.add(id);\r\n    }\r\n\r\n    const ids = Array.from(this.selectedRows);\r\n\r\n    this.saveSelection(ids, this.tableType);\r\n\r\n    const event = {\r\n      data: {\r\n        listingType: this.listingType,\r\n        obj: ids\r\n      },\r\n      eventType: \"onSelectRow\",\r\n    };\r\n    this.genericEvent.emit(event);\r\n  }\r\n\r\n\r\n\r\n  toggleSelectAll(data: any[]): void {\r\n    const leafRows = this.getAllLeafRows(data);\r\n    const allIds = leafRows.map(r => this.getRowId(r));\r\n\r\n    const allSelected = allIds.every(id => this.selectedRows.has(id));\r\n\r\n    if (allSelected) {\r\n      allIds.forEach(id => this.selectedRows.delete(id));\r\n    } else {\r\n      allIds.forEach(id => this.selectedRows.add(id));\r\n    }\r\n    this.cdr.detectChanges();\r\n    const ids = Array.from(this.selectedRows);\r\n    const event = {\r\n      data: {\r\n        listingType: this.listingType,\r\n        obj: ids\r\n      },\r\n      eventType: \"onSelectRow\",\r\n    }\r\n    this.genericEvent.emit(event);\r\n    this.saveSelection(ids, this.tableType);\r\n  }\r\n\r\n  isRowSelected(row: any): boolean {\r\n    return this.selectedRows.has(this.getRowId(row));\r\n  }\r\n\r\n  isAllSelected(data: any[]): boolean {\r\n    const leafRows = this.getAllLeafRows(data);\r\n    return leafRows.length > 0 && leafRows.every(r => this.selectedRows.has(this.getRowId(r)));\r\n  }\r\n\r\n\r\n  isIndeterminateState(data: any[]): boolean {\r\n    const leafRows = this.getAllLeafRows(data);\r\n    const selectedCount = leafRows.filter(r => this.selectedRows.has(this.getRowId(r))).length;\r\n\r\n    return selectedCount > 0 && selectedCount < leafRows.length;\r\n  }\r\n\r\n\r\n  getAllLeafRows(data: any[]): any[] {\r\n    const leaf: any[] = [];\r\n\r\n    const traverse = (node: any) => {\r\n      if (!node) return;\r\n\r\n      if (node.isGroup) {\r\n        node.children?.forEach(traverse);\r\n      } else {\r\n        leaf.push(node);\r\n      }\r\n    };\r\n\r\n    data.forEach(traverse);\r\n    return leaf;\r\n  }\r\n\r\n\r\n\r\n\r\n  // Side Menu Working Goes Here\r\n  toggleSideMenu(clickedOn: 'cols' | 'filtrs') {\r\n    if (this.currentOpenedSideMenue == clickedOn) {\r\n      this.currentOpenedSideMenue = clickedOn;\r\n      this.sideMenuVisible = !this.sideMenuVisible;\r\n    } else if (\r\n      this.sideMenuVisible &&\r\n      clickedOn != this.currentOpenedSideMenue\r\n    ) {\r\n      this.currentOpenedSideMenue = clickedOn;\r\n      return;\r\n    } else {\r\n      this.currentOpenedSideMenue = clickedOn;\r\n      this.sideMenuVisible = !this.sideMenuVisible;\r\n    }\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  toggleGroupVisibility(col: any) {\r\n    const allVisible = col.children.every((child: any) => child.is_visible);\r\n    col.children.forEach((child: any) => (child.is_visible = !allVisible));\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      this.updateColumnWidthsAndGroups();\r\n      this.refreshPreviewColumns();\r\n      this.SetColumnsDefaultWidth();\r\n      this.cdr.detectChanges();\r\n    }, 10);\r\n  }\r\n\r\n  isColumnVisible(columns: any) {\r\n    if (columns?.children) {\r\n      return columns.children.every((element: any) => element.is_visible);\r\n    }\r\n\r\n    return columns?.is_visible;\r\n  }\r\n\r\n  allColumnsSelected(): boolean {\r\n    const flatten = this.flattenColumns(this.columns);\r\n    return flatten.every((col) => col.is_visible);\r\n  }\r\n\r\n\r\n  private findColumnByField(field: string, cols: any[]): any | null {\r\n    for (const col of cols) {\r\n      if (col.field === field) {\r\n        return col;\r\n      }\r\n      if (col.children && Array.isArray(col.children)) {\r\n        const found = this.findColumnByField(field, col.children);\r\n        if (found) return found;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n\r\n\r\n  async toggleColumnVisibility(column: any, isVisible: boolean) {\r\n    if (isVisible) {\r\n      if (this.visibleColumns()?.length <= 2 && column.is_visible || (column?.is_always_visible)) {\r\n        return;\r\n      }\r\n    }\r\n    const col = this.findColumnByField(column.field, this.columns);\r\n    if (col) {\r\n      col.is_visible = isVisible;\r\n    }\r\n    await this.refreshHeaders();\r\n    this.cdr.detectChanges();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    if (this.tableFilterViewId) {\r\n      this.savePreset('mouseUp');\r\n    }\r\n  }\r\n\r\n\r\n  async toggleAllColumnsVisibility(): Promise<void> {\r\n  this.loading = true;\r\n\r\n    try {\r\n      const flatten = this.flattenColumns(this.columns);\r\n      const visibleColumns = flatten.filter(col => col.is_visible);\r\n      if (visibleColumns.length <= 2) {\r\n        this.loading = false;\r\n        return;\r\n      }\r\n\r\n      const nonAlwaysVisible = flatten.filter(col => !col.is_always_visible);\r\n      const allNonAlwaysVisibleAreVisible = nonAlwaysVisible.every(col => col.is_visible);\r\n      if (allNonAlwaysVisibleAreVisible) {\r\n        flatten.forEach(col => {\r\n          col.is_visible = col.is_always_visible ? true : false;\r\n        });\r\n      } else {\r\n        flatten.forEach(col => (col.is_visible = true));\r\n      }\r\n      await this.wait(10);\r\n      this.updateColumnWidthsAndGroups();\r\n      await this.wait(10);\r\n      this.refreshPreviewColumns();\r\n      this.cdr.detectChanges();\r\n      await this.wait(100);\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n\r\n    } finally {\r\n      this.loading = false;\r\n    }\r\n  }\r\n\r\n  private wait(ms: number): Promise<void> {\r\n    return new Promise(resolve => setTimeout(resolve, ms));\r\n  }\r\n\r\n\r\n\r\n  visibleColumns() {\r\n    const flatten = this.flattenColumns(this.columns);\r\n    const visibleColumns = flatten.filter((c: any) => c.is_visible);\r\n    return visibleColumns;\r\n  }\r\n\r\n  flattenColumns(cols: any[]): any[] {\r\n    return cols.reduce((acc: any[], col: any) => {\r\n      if (col?.children && col.children.length) {\r\n        // recursively flatten children\r\n        return acc.concat(this.flattenColumns(col.children));\r\n      } else {\r\n        // leaf column\r\n        return acc.concat(col);\r\n      }\r\n    }, []);\r\n  }\r\n\r\n\r\n  filteredColumns(cols: any[]): any[] {\r\n    const search = this.columnSearch.toLowerCase();\r\n    return cols\r\n      .map((col) => {\r\n        if (col.children) {\r\n          const filteredChildren = this.filteredColumns(col.children);\r\n          if (\r\n            col.header.toLowerCase().includes(search) ||\r\n            filteredChildren.length\r\n          ) {\r\n            return { ...col, children: filteredChildren };\r\n          }\r\n          return null;\r\n        } else {\r\n          return col.header.toLowerCase().includes(search) ? col : null;\r\n        }\r\n      })\r\n      .filter(Boolean);\r\n  }\r\n\r\n  get accordionState(): 'all' | 'none' | 'some' {\r\n    const groups = this.getAllGroupColumns(this.columns);\r\n    const expandedCount = groups.filter((col) => col.expanded).length;\r\n\r\n    if (expandedCount === 0) return 'none';\r\n    if (expandedCount === groups.length) return 'all';\r\n    return 'some';\r\n  }\r\n\r\n  get filterAccordionState(): 'all' | 'none' | 'some' {\r\n    const groups = this.getAllGroupColumns(this.columns);\r\n    const expandedCount = groups.filter((col) => col.expandedFilter).length;\r\n\r\n    if (expandedCount === 0) return 'none';\r\n    if (expandedCount === groups.length) return 'all';\r\n    return 'some';\r\n  }\r\n\r\n  // Recursively collect all group columns\r\n  private getAllGroupColumns(cols: any[]): any[] {\r\n    let groups: any[] = [];\r\n    for (const col of cols) {\r\n      if (col.children?.length) {\r\n        groups.push(col);\r\n        groups = groups.concat(this.getAllGroupColumns(col.children));\r\n      }\r\n    }\r\n    return groups;\r\n  }\r\n\r\n  // Toggle based on current state\r\n  toggleAllAccordions(): void {\r\n    const nextState = this.accordionState === 'all' ? false : true;\r\n    this.setAccordionState(this.columns, nextState);\r\n  }\r\n\r\n  toggleAllFilterAccordions(): void {\r\n    const nextState = this.filterAccordionState === 'all' ? false : true;\r\n    this.setFilterAccordionState(this.columns, nextState);\r\n  }\r\n\r\n  private setAccordionState(cols: any[], state: boolean): void {\r\n    for (let col of cols) {\r\n      if (col.children?.length) {\r\n        col.expanded = state;\r\n        this.setAccordionState(col.children, state); // Recursively handle nested\r\n      }\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n  private setFilterAccordionState(cols: any[], state: boolean): void {\r\n    for (let col of cols) {\r\n      if (col.children?.length) {\r\n        col.expandedFilter = state;\r\n        this.setFilterAccordionState(col.children, state); // Recursively handle nested\r\n      }\r\n    }\r\n  }\r\n\r\n  showColumnPanel = false;\r\n\r\n  closeModalColumnPanel() {\r\n    this.showColumnPanel = false;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  @HostListener('document:keydown.escape', ['$event'])\r\n  onEscape(event: Event) {\r\n    this.closeModalColumnPanel();\r\n  }\r\n\r\n  // Check If  Any column have right pinned\r\n  get hasRightPinnedColumns() {\r\n    return this.commonSevice.gethasRightPinnedColumns(this.columns);\r\n  }\r\n\r\n  get hasLeftPinnedColumns() {\r\n    return this.commonSevice.gethasLeftPinnedColumns(this.columns);\r\n  }\r\n\r\n  get dataSetLength() {\r\n    return this.commonSevice.getExpandedRowCount(this.dataSet);\r\n  }\r\n\r\n\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: UIEvent) {\r\n    if (!this.curretaTablePresetForUpdate) this.autoSizeColumnsByRatio();\r\n    const h = this.mainScroll?.nativeElement?.clientHeight ?? 0;\r\n    this.viewportRows = Math.max(1, Math.ceil(h / this.rowHeight));\r\n    this.updateVisibleRows(this.mainScroll?.nativeElement?.scrollTop);\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n    setTimeout(() => { }, 100);\r\n  }\r\n\r\n  autoSizeColumnsByRatio(): void {\r\n    this.activeCol = null;\r\n\r\n    const getVisibleLeafColumns = (columns: any[]): any[] => {\r\n      const result: any[] = [];\r\n\r\n      for (const column of columns) {\r\n        if (column.children && Array.isArray(column.children)) {\r\n          result.push(...getVisibleLeafColumns(column.children));\r\n        } else if (column.is_visible !== false) {\r\n          result.push(column);\r\n        }\r\n      }\r\n      return result;\r\n    };\r\n\r\n    const visibleColumns = getVisibleLeafColumns(this.columns);\r\n\r\n    if (visibleColumns.length === 0) return;\r\n    let containerWidth =\r\n      this.dataGridContainer?.nativeElement?.offsetWidth ?? 0;\r\n\r\n    if (this.showSerialNumber) containerWidth -= 55;\r\n    if (this.showSideMenu) containerWidth -= 29;\r\n    if (this.gridType == 'Assets' || this.gridType == 'Tasks')\r\n      containerWidth -= 30;\r\n    containerWidth -= 55;\r\n    const totalOldWidth = visibleColumns.reduce(\r\n      (sum, col) => sum + (col.width || 0),\r\n      0\r\n    );\r\n    if (totalOldWidth === 0) return;\r\n    visibleColumns.forEach((col) => {\r\n      const ratio = col.width / totalOldWidth;\r\n      const newWidth = Math.max(Math.floor(containerWidth * ratio), 100);\r\n      col.width = newWidth;\r\n      this.updateColumnWidthInSourceByField(col.field, newWidth);\r\n    });\r\n\r\n    this.refreshHeaders();\r\n    this.hasScroll = this.hasHorizontalScrollbar();\r\n    this.cdr.detectChanges();\r\n    setTimeout(() => {\r\n      const sendData = {\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.cleanFilterdColumns(),\r\n        no_of_records: this.paginationConfig.pageSize,\r\n        type: this.tableType,\r\n      };\r\n      this.createUpdateConfigListing.emit(sendData);\r\n    }, 400);\r\n  }\r\n\r\n\r\n  async refreshHeaders() {\r\n    this.ngZone.runOutsideAngular(async () => {\r\n      await new Promise(r => setTimeout(r, 0));\r\n      await this.updateColumnWidthsAndGroups();\r\n      await this.refreshPreviewColumns();\r\n\r\n      this.ngZone.run(() => this.cdr.detectChanges());\r\n    });\r\n  }\r\n\r\n  get hasAnyVisibleColumn() {\r\n    return this.commonSevice.gethasVisibleColumns(this.columns);\r\n  }\r\n\r\n  get hasAnyInVisibleColumn() {\r\n    return this.commonSevice.gethasInVisibleColumns(this.columns);\r\n  }\r\n\r\n  get columnsCount() {\r\n    return this.commonSevice.getTotalColumnsLength(this.columns);\r\n  }\r\n\r\n  tableHeaderAndBodyHeight() {\r\n    return `calc(100% - ${this.footerRowHeight})`;\r\n  }\r\n\r\n  draggingInGroupArea = false;\r\n\r\n  @ViewChild('centerScroll') centerScroll!: ElementRef<HTMLDivElement>;\r\n  visibleRowCount = 25;\r\n  startIndex = 0;\r\n  visibleRows: any[] = [];\r\n\r\n  private flattenGroupedRows(\r\n    rows: any[] = [],\r\n    level = 0,\r\n    result: any[] = []\r\n  ): any[] {\r\n    for (const row of rows) {\r\n      result.push({ ...row, __depth: level });\r\n      if (row.isGroup && row.isExpand && row.children?.length) {\r\n        this.flattenGroupedRows(row.children, level + 1, []);\r\n      }\r\n    }\r\n    this.assignVirtualIndexes(this.visibleRows);\r\n    return result;\r\n  }\r\n\r\n  assignVirtualIndexes(data: any[]): any[] {\r\n    let currentIndex = 1;\r\n    const walk = (items: any[]): void => {\r\n      for (const item of items) {\r\n        item.__virtualIndex = currentIndex++;\r\n        if (item?.isGroup) {\r\n          const group = item;\r\n          if (group.isExpand && Array.isArray(group.children)) {\r\n            walk(group.children);\r\n          }\r\n        }\r\n      }\r\n    };\r\n    walk(data);\r\n    // console.log('This dataset: ', this.visibleRows)\r\n    return data;\r\n  }\r\n\r\n\r\n  updateVisibleRows(scrollTop: number) {\r\n\r\n    if (this.groupedColumns?.length) {\r\n      this.visibleRows = this.dataSet;\r\n      return;\r\n    }\r\n    const flatData = this.flattenGroupedRows(this.dataSet);\r\n\r\n    if (this.dataSet?.length <= 15) {\r\n      this.visibleRows = flatData;\r\n      this.firstIndex = 0;\r\n      this.startIndex = 0;\r\n      this.renderStart = 0;\r\n      this.cdr.detectChanges();\r\n      return;\r\n    }\r\n    const total = flatData.length;\r\n    const maxFirst = Math.max(0, total - this.viewportRows);\r\n    const first = Math.min(Math.floor(scrollTop / this.rowHeight), maxFirst);\r\n    const start = Math.max(0, first);\r\n    const end = Math.min(total, first + this.viewportRows);\r\n\r\n    this.firstIndex = first;\r\n    this.startIndex = first;\r\n    this.renderStart = start;\r\n    this.visibleRows = flatData.slice(start, end);\r\n    this.assignVirtualIndexes(this.visibleRows);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  trackByRenderedIndex = (i: number, _row: any) => this.renderStart + i;\r\n\r\n  private isSyncingFromMain = false;\r\n  private isSyncingFromFake = false;\r\n  private mainScrollRaf: number | null = null;\r\n\r\n  trackById(index: number, item: any) {\r\n    return item.id || item._id;\r\n  }\r\n\r\n  flattenedData: any[] = [];\r\n\r\n  updateFlattenedData(): void {\r\n    setTimeout(() => {\r\n      this.flattenedData = this.flattenGroupedRows(this.dataSet);\r\n      this.cdr.detectChanges();\r\n    }, 10);\r\n  }\r\n\r\n  // requestAnimationFrame IDs\r\n  private fakeScrollRaf: number | null = null;\r\n\r\n\r\n  // onMainScroll(event: Event) {\r\n  //   this.expandedCells.clear();\r\n  //   const scrollTop = (event.target as HTMLElement).scrollTop;\r\n  //     if (this.groupedColumns?.length > 0) {\r\n  //       this.startIndex = 0;\r\n  //       this.cdr.detectChanges();\r\n  //       return;\r\n  //     }\r\n  //     const overscan = this.overscan * 2;\r\n  //     this.startIndex = Math.floor(scrollTop / this.rowHeight);\r\n  //     const start = Math.max(0, this.startIndex - overscan);\r\n  //     const end = Math.min(this.flattenedData.length, this.startIndex + this.viewportRows + overscan);\r\n  //     this.visibleRows = this.flattenedData.slice(start, end);\r\n  //     this.cdr.detectChanges();\r\n  // }\r\n  translateY = 0;\r\n\r\n  lastScrollTop = 0;\r\n  pendingAnimationFrame: number | null = null;\r\n\r\n  onMainScroll(event: Event): void {\r\n    const scrollTop = (event.target as HTMLElement).scrollTop;\r\n    if (Math.abs(scrollTop - this.lastScrollTop) < (10)) return;\r\n    if (this.pendingAnimationFrame) cancelAnimationFrame(this.pendingAnimationFrame);\r\n    if (this.groupedColumns?.length > 0) {\r\n      this.startIndex = 0;\r\n      this.cdr.detectChanges();\r\n      return;\r\n    }\r\n    this.pendingAnimationFrame = requestAnimationFrame(() => {\r\n      const scrollingDown = scrollTop > this.lastScrollTop;\r\n      this.lastScrollTop = scrollTop;\r\n\r\n      const overscan = 5;\r\n      const newStartIndex = Math.floor(scrollTop / this.rowHeight);\r\n      const dynamicOverscan = scrollingDown ? overscan : overscan;\r\n\r\n      const start = Math.max(0, newStartIndex - dynamicOverscan);\r\n      const end = Math.min(\r\n        this.flattenedData.length,\r\n        newStartIndex + this.viewportRows + dynamicOverscan\r\n      );\r\n      this.translateY = start * this.rowHeight;\r\n      if (this.startIndex !== start || this.visibleRows.length !== end - start) {\r\n        this.startIndex = start;\r\n        this.visibleRows = this.dataSet.slice(start, end);\r\n        this.cdr.markForCheck();\r\n      }\r\n\r\n      this.pendingAnimationFrame = null;\r\n    });\r\n  }\r\n\r\n\r\n  // onMainScroll(event: Event): void {\r\n  //   this.expandedCells.clear();\r\n  //   if (this.isSyncingFromFake) {\r\n  //     this.isSyncingFromFake = false;\r\n  //     return;\r\n  //   }\r\n  //   const scrollTop = (event.target as HTMLElement).scrollTop;\r\n  //   if (Math.abs(scrollTop - this.lastScrollTop) < this.rowHeight / 2) return;\r\n  //   this.lastScrollTop = scrollTop;\r\n\r\n  //   if (this.fakeScrollRaf) cancelAnimationFrame(this.fakeScrollRaf);\r\n\r\n  //   this.fakeScrollRaf = requestAnimationFrame(() => {\r\n  //     if (this.groupedColumns?.length > 0) {\r\n  //       this.startIndex = 0;\r\n  //       this.cdr.detectChanges();\r\n  //       return;\r\n  //     }\r\n  //     const flatData = this.flattenGroupedRows(this.dataSet);\r\n  //     const totalRows = flatData.length;\r\n  //     const newStartIndex = Math.floor(scrollTop / this.rowHeight);\r\n  //     const start = Math.max(0, newStartIndex - (this.overscan * 2));\r\n  //     const end = Math.min(totalRows, newStartIndex + this.viewportRows + (this.overscan * 2));\r\n\r\n  //     this.translateY = start * this.rowHeight;\r\n  //     this.startIndex = start;\r\n  //     this.visibleRows = flatData.slice(start, end);\r\n  //     this.cdr.detectChanges();\r\n  //   });\r\n  // }\r\n\r\n\r\n  get isScrollbarVisible(): boolean {\r\n    if (!this.mainScroll) return false;\r\n    const el = this.mainScroll.nativeElement;\r\n    return el.scrollHeight > el.clientHeight;\r\n  }\r\n\r\n  toggleExpand(row: any) {\r\n    if (row.details) {\r\n      row.isDetailsExpand = !row.isDetailsExpand;\r\n    } else {\r\n      row.isExpand = !row.isExpand;\r\n    }\r\n    this.rowSelectedIndexes.clear();\r\n    this.updateFlattenedData();\r\n    // this.cdr.detectChanges();\r\n    // setTimeout(() => {\r\n    //   this.cdr.detectChanges();\r\n    // }, 100);\r\n  }\r\n\r\n  // onMainFakeScroll(event: Event) {\r\n  //   if (this.isSyncingFromMain) {\r\n  //     this.isSyncingFromMain = false;\r\n  //     return;\r\n  //   }\r\n  //   if (this.groupedColumns?.length > 0) {\r\n  //     this.startIndex = 0;\r\n  //     this.cdr.detectChanges();\r\n  //     return;\r\n  //   }\r\n  //   const scrollTop = (event.target as HTMLElement).scrollTop;\r\n  //   if (this.mainScrollRaf) cancelAnimationFrame(this.mainScrollRaf);\r\n  //   this.mainScrollRaf = requestAnimationFrame(() => {\r\n  //     this.isSyncingFromFake = true;\r\n  //     this.mainScroll.nativeElement.scrollTop = scrollTop;\r\n  //     const overscan = this.overscan ?? 0;\r\n  //     this.startIndex = Math.floor(scrollTop / this.rowHeight);\r\n  //     const start = Math.max(0, this.startIndex - overscan);\r\n  //     const end = Math.min(\r\n  //       this.flattenedData.length,\r\n  //       this.startIndex + this.viewportRows + overscan\r\n  //     );\r\n  //     this.visibleRows = this.flattenedData.slice(start, end);\r\n  //     this.cdr.detectChanges();\r\n  //   });\r\n  // }\r\n\r\n\r\n\r\n\r\n\r\n  viewportRows = 0; // how many rows fit in viewport (computed)\r\n  firstIndex = 0; // index of the first visible row (clamped)\r\n  renderStart = 0; // where the slice actually starts (firstIndex - overscan, clamped)\r\n\r\n  private scrollRaf: number | null = null;\r\n  private pendingScrollTop = 0;\r\n\r\n  @ViewChild('mainScroll') mainScroll!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('fakeScroll') fakeScroll!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('horizintalFakeScroll')\r\n  horizintalFakeScroll!: ElementRef<HTMLDivElement>;\r\n  @ViewChild('centerScrollableBody')\r\n  centerScrollableBody!: ElementRef<HTMLDivElement>;\r\n  private overscan = 10; // buffer rows above and below\r\n\r\n  computeViewportRows() {\r\n    if (this.fakeScroll?.nativeElement) {\r\n      this.fakeScroll.nativeElement.scrollTop = 0;\r\n    }\r\n\r\n    if (this.mainScroll?.nativeElement) {\r\n      this.mainScroll.nativeElement.scrollTop = 0;\r\n      const h = this.mainScroll.nativeElement.clientHeight ?? 0;\r\n\r\n      // rows visible in viewport\r\n      const rowsInViewport = Math.max(1, Math.ceil(h / this.rowHeight));\r\n\r\n      // add buffer rows (overscan)\r\n      this.viewportRows = rowsInViewport + this.overscan;\r\n\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n\r\n  onHorizontalFakeScroll(event: Event) {\r\n    const scrollLeft = (event.target as HTMLElement).scrollLeft;\r\n    this.centerPinnedHeader.nativeElement.scrollLeft = scrollLeft;\r\n    if (this.centerScrollableBody?.nativeElement) {\r\n      this.centerScrollableBody.nativeElement.scrollLeft = scrollLeft;\r\n    }\r\n  }\r\n\r\n  onCenterBodyScroll(event: Event) {\r\n    const target = event.target as HTMLElement;\r\n    if (this.centerScrollableBody?.nativeElement) {\r\n      this.centerScrollableBody.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n    if (this.centerPinnedHeader) {\r\n      this.centerPinnedHeader.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n    if (this.horizintalFakeScroll?.nativeElement) {\r\n      this.horizintalFakeScroll.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n  }\r\n\r\n  onCenterHeaderScroll(event: Event) {\r\n    const target = event.target as HTMLElement;\r\n    if (this.horizintalFakeScroll?.nativeElement) {\r\n      this.horizintalFakeScroll.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n    if (this.centerScrollableBody?.nativeElement) {\r\n      this.centerScrollableBody.nativeElement.scrollLeft = target.scrollLeft;\r\n    }\r\n  }\r\n\r\n  // Dragging Logic is implemented here\r\n  // private initialIndex: number | null = null;\r\n\r\n  draggingColumn: any;\r\n  dragStartIndex: any = 0;\r\n  // onDragStart(data: any, index: number) {\r\n  //   this.draggingColumn = data.column;\r\n  //   this.dragStartIndex = index;\r\n  // }\r\n  // onDragMove(data: any) {\r\n  //   const { clientX, clientY } = data.event;\r\n  //   const headers = Array.from(\r\n  //     document.querySelectorAll('.one-row-header-cells')\r\n  //   ) as HTMLElement[];\r\n\r\n  //   headers.forEach((headerEl, idx) => {\r\n  //     const rect = headerEl.getBoundingClientRect();\r\n  //     if (\r\n  //       idx !== this.dragStartIndex &&\r\n  //       clientX > rect.left &&\r\n  //       clientX < rect.right &&\r\n  //       clientY > rect.top &&\r\n  //       clientY < rect.bottom\r\n  //     ) {\r\n  //       const otherIndex = idx;\r\n  //       console.log(`${this.dragStartIndex} --> ${otherIndex}`);\r\n  //       this.swapColumn(this.dragStartIndex, otherIndex);\r\n  //       console.log('Updated Columns: ', this.columns);\r\n  //       this.dragStartIndex = otherIndex; // update index\r\n  //     }\r\n  //   });\r\n  // }\r\n\r\n  // swapColumn(previusIndex: number, currentIndex: number) {\r\n  //   const columns = structuredClone(this.columns);\r\n  //   const flattenColumns = this.flattenColumns(columns);\r\n\r\n  //   const visibleFlattenColumns = flattenColumns.filter(\r\n  //     (col) => col.is_visible\r\n  //   );\r\n  //   const previusColumn = visibleFlattenColumns[previusIndex];\r\n  //   const currentColumn = visibleFlattenColumns[currentIndex];\r\n\r\n  //   console.log('Previus Column: ', previusColumn);\r\n  //   console.log('current clumn: ', currentColumn);\r\n  // }\r\n\r\n  // onDragEnd(data: any) {\r\n  //   this.draggingColumn = null;\r\n  //   this.dragStartIndex = null;\r\n  // }\r\n\r\n  // CDK DRAG DROP LOGIC GOES HERE\r\n\r\n\r\n  canEnterToRowsGrouping = (drag: CdkDrag<any>, drop: CdkDropList<any>) => {\r\n    // Example: Block if already pinned left\r\n    const data = drag.data;\r\n    if (data?.children && data?.children.length) {\r\n      return data.children.some(\r\n        (col: any) => col.is_visible && col.is_groupable\r\n      );\r\n    }\r\n    return data.is_visible && data.is_groupable;\r\n  };\r\n\r\n  // onDragMoved(event: CdkDragMove<any>) {\r\n  //   const pointerX = event.pointerPosition.x;\r\n  //   const pointerY = event.pointerPosition.y;\r\n\r\n  //   const targetElement = document.getElementById(\r\n  //     'rows-grouping-top-container'\r\n  //   );\r\n\r\n  //   if (targetElement) {\r\n  //     const rect = targetElement.getBoundingClientRect();\r\n\r\n  //     const isOverTarget =\r\n  //       pointerX >= rect.left &&\r\n  //       pointerX <= rect.right &&\r\n  //       pointerY >= rect.top &&\r\n  //       pointerY <= rect.bottom;\r\n\r\n  //     if (isOverTarget) {\r\n  //       this.draggingInGroupArea = true;\r\n  //     } else {\r\n  //       this.draggingInGroupArea = false;\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n  enterToTopRowGrouping(dropList: CdkDragEnter<any>) {\r\n    const draggingData = dropList.item.data;\r\n    this.draggingInGroupArea = true;\r\n    // console.log(\"Dragging in group area\")\r\n    this.cdr.detectChanges();\r\n\r\n    if (Array.isArray(draggingData?.children)) {\r\n      const targetGroup = this.columns.find(\r\n        (col) => col.header === draggingData.header\r\n      );\r\n      if (targetGroup) {\r\n        draggingData.children.forEach((draggedChild: any) => {\r\n          const matchingChild = targetGroup.children.find(\r\n            (child: any) => child.field === draggedChild.field\r\n          );\r\n          if (matchingChild) {\r\n            matchingChild.isRowGrouped = !!matchingChild.is_groupable;\r\n          }\r\n        });\r\n      }\r\n    }\r\n    else {\r\n      // Try finding it in top-level columns first\r\n      let targetColumn = this.columns.find(\r\n        (col: any) => col.field === draggingData.field\r\n      );\r\n\r\n      if (targetColumn) {\r\n        targetColumn.isRowGrouped = !!targetColumn.is_groupable;\r\n      } else {\r\n        for (let group of this.columns) {\r\n          if (Array.isArray(group.children)) {\r\n            const matchingChild = group.children.find(\r\n              (child: any) => child.field === draggingData.field\r\n            );\r\n            if (matchingChild) {\r\n              matchingChild.isRowGrouped = !!matchingChild.is_groupable;\r\n              break;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    // ✅ Refresh UI\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  onDropListEnter(\r\n    dropList: CdkDragEnter<any>,\r\n    section: 'left' | 'center' | 'right'\r\n  ) {\r\n    const draggingData = dropList.item.data;\r\n\r\n    const targetColumn: any = this.columns.find(\r\n      (col) => col.header == draggingData.header\r\n    );\r\n\r\n    if (!targetColumn) return;\r\n\r\n    if (\r\n      Array.isArray(draggingData?.children) &&\r\n      Array.isArray(targetColumn?.children)\r\n    ) {\r\n      draggingData.children.forEach((draggedChild: any) => {\r\n        const matchingChild = targetColumn.children.find(\r\n          (child: any) => child.field === draggedChild.field\r\n        );\r\n        if (matchingChild) {\r\n          matchingChild.pinned = section === 'center' ? null : section;\r\n          matchingChild['isRowGrouped'] = false;\r\n        }\r\n      });\r\n    } else {\r\n      targetColumn.pinned = section === 'center' ? null : section;\r\n      targetColumn['isRowGrouped'] = false;\r\n    }\r\n\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  // enterToTopGroupingRow(dropList: CdkDragEnter<any>) {\r\n  //   this.shouldDisableDroplistSorting = this.isDisableColumnGrouping;\r\n  //   this.draggingInGroupArea = true;\r\n  //   this.cdr.detectChanges();\r\n  // const index = this.groupedColumns.findIndex(\r\n  //   (col) => col.field === column.field\r\n  // );\r\n  // if (index !== -1) {\r\n  //   this.groupedColumns.splice(index, 1);\r\n  // }\r\n\r\n  // // 2. Traverse this.columns to find and update the matching column\r\n  // this.columns.forEach((group) => {\r\n  //   if (group?.children && Array.isArray(group.children)) {\r\n  //     group.children.forEach((child) => {\r\n  //       if (child.field === column.field) {\r\n  //         child.isRowGrouped = false;\r\n  //       }\r\n  //     });\r\n  //   } else if (group.field === column.field) {\r\n  //     group.isRowGrouped = false;\r\n  //   }\r\n  // });\r\n  //   this.cdr.detectChanges();\r\n  // }\r\n\r\n  exitedFromTheTopRow(dropList: CdkDragExit<any>) {\r\n    this.draggingInGroupArea = false;\r\n    this.isDisableColumnGrouping = false;\r\n    this.shouldDisableDroplistSorting = false;\r\n    const draggingData = dropList.item.data;\r\n    if (Array.isArray(draggingData?.children)) {\r\n      const targetGroup = this.columns.find(\r\n        (col) => col.header === draggingData.header\r\n      );\r\n      if (targetGroup) {\r\n        draggingData.children.forEach((draggedChild: any) => {\r\n          const matchingChild = targetGroup.children.find(\r\n            (child: any) => child.field === draggedChild.field\r\n          );\r\n          if (matchingChild) {\r\n            matchingChild.isRowGrouped = false;\r\n          }\r\n        });\r\n      }\r\n    } else {\r\n      let targetColumn = this.columns.find(\r\n        (col: any) => col.field === draggingData.field\r\n      );\r\n\r\n      if (targetColumn) {\r\n        targetColumn.isRowGrouped = false;\r\n      } else {\r\n        for (let group of this.columns) {\r\n          if (Array.isArray(group.children)) {\r\n            const matchingChild = group.children.find(\r\n              (child: any) => child.field === draggingData.field\r\n            );\r\n            if (matchingChild) {\r\n              matchingChild.isRowGrouped = false;\r\n              break;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  shouldDisableDroplistSorting = false;\r\n  isDisableColumnGrouping = false;\r\n  checkColumnGroupingStatus(col: any) {\r\n    if (col?.children && Array.isArray(col.children)) {\r\n      const allChildrenDisabled = col.children.every(\r\n        (child: any) => child.is_groupable === false\r\n      );\r\n      this.isDisableColumnGrouping = allChildrenDisabled;\r\n    } else {\r\n      this.isDisableColumnGrouping = col.is_groupable === false;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  currentDraggingColumn: any = null;\r\n  dragStartOnGroup(col: any) {\r\n    this.currentDraggingColumn = col;\r\n  }\r\n\r\n  onSortGroup = async (event: CdkDragSortEvent<any>, section: string) => {\r\n    const columns = (this as any)[section];\r\n    if (event.previousIndex === event.currentIndex) return;\r\n    const visibleColumns = columns.filter((col: any) => {\r\n      if (col?.children && Array.isArray(col.children)) {\r\n        return col.children.some((child: any) => child.is_visible);\r\n      }\r\n      return col.is_visible;\r\n    });\r\n    const previousHeader = visibleColumns[event.previousIndex].header;\r\n    const currentHeader = visibleColumns[event.currentIndex].header;\r\n    const visiblePrevIndex = visibleColumns.findIndex(\r\n      (col: any) => col.header === previousHeader\r\n    );\r\n    const visibleCurrIndex = visibleColumns.findIndex(\r\n      (col: any) => col.header === currentHeader\r\n    );\r\n    const getFields = (item: any): string[] => {\r\n      if (item?.children && Array.isArray(item.children)) {\r\n        return item.children.map((child: any) => child.field);\r\n      }\r\n      return [item.field];\r\n    };\r\n    const prevFields = getFields(visibleColumns[visiblePrevIndex]);\r\n    const currFields = getFields(visibleColumns[visibleCurrIndex]);\r\n    const allFields = [...prevFields, ...currFields];\r\n    const cells = allFields.length\r\n      ? ([] as HTMLElement[]).concat(\r\n        ...allFields.map((field) =>\r\n          Array.from(document.querySelectorAll(`[data-field=\"${field}\"]`)) as HTMLElement[]\r\n        )\r\n      )\r\n      : [];\r\n    const firstPositions = new Map<HTMLElement, number>();\r\n    cells.forEach((el) => firstPositions.set(el, el.getBoundingClientRect().left));\r\n    // console.log(\"this .coluns\", this.columns);\r\n    moveItemInArray((this as any)[section], visiblePrevIndex, visibleCurrIndex);\r\n\r\n    const prevColIndexInColumns = this.columns.findIndex(item => item.header === previousHeader);\r\n    const currColIndexInColumns = this.columns.findIndex(item => item.header === currentHeader);\r\n    moveItemInArray(this.columns, prevColIndexInColumns, currColIndexInColumns);\r\n    // await this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n    await firstValueFrom(this.ngZone.onStable);\r\n    // this.ngZone.runOutsideAngular(() => {\r\n      // Wait a tick to make sure elements are rendered\r\n      requestAnimationFrame(() => {\r\n        allFields.forEach((field) => {\r\n          const updatedCells = Array.from(\r\n            document.querySelectorAll(`[data-field=\"${field}\"]`)\r\n          ) as HTMLElement[];\r\n\r\n          updatedCells.forEach((el) => {\r\n            const oldLeft = firstPositions.get(el);\r\n            if (oldLeft == null) return; // skip if old position not available\r\n\r\n            const newLeft = el.getBoundingClientRect().left;\r\n            const deltaX = oldLeft - newLeft;\r\n\r\n            if (deltaX !== 0) {\r\n              el.style.willChange = 'transform';\r\n              el.style.transition = 'none';\r\n              el.style.transform = `translateX(${deltaX}px)`;\r\n\r\n              // Force reflow\r\n              void el.offsetWidth;\r\n\r\n              el.style.transition = 'transform 250ms cubic-bezier(0.4, 0, 0.2, 1)';\r\n              el.style.transform = 'translateX(0)';\r\n\r\n              const handle = () => {\r\n                el.style.transition = '';\r\n                el.style.transform = '';\r\n                el.style.willChange = '';\r\n                el.removeEventListener('transitionend', handle);\r\n              };\r\n              el.addEventListener('transitionend', handle);\r\n            }\r\n          });\r\n        });\r\n      });\r\n    // });\r\n  }\r\n\r\n\r\n  onDropGroup() {\r\n    this.leftPinnedColumns = this.deepCloneColumns(this.previewLeftPinnedColumns);\r\n    this.centerColumns = this.deepCloneColumns(this.previewCenterColumns);\r\n    this.rightPinnedColumns = this.deepCloneColumns(this.previewRightPinnedColumns);\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private deepCloneColumns(columns: any[]): any[] {\r\n    if (!Array.isArray(columns)) return [];\r\n\r\n    return columns.map(col => ({\r\n      ...col,\r\n      query: col.query ? { ...col.query } : null,\r\n      column_dropdown_value: Array.isArray(col.column_dropdown_value)\r\n        ? [...col.column_dropdown_value]\r\n        : [],\r\n      // Recursively deep clone children if present\r\n      children: Array.isArray(col.children)\r\n        ? this.deepCloneColumns(col.children)\r\n        : undefined,\r\n    }));\r\n  }\r\n\r\n\r\n  async onDropTopGroup(event: CdkDragDrop<any>) {\r\n    if (this.isOutsideContainer) return;\r\n    this.mainScroll.nativeElement.scrollTop = 0;\r\n    this.loading = true;\r\n    this.translateY = 0;\r\n    this.cdr.detectChanges();\r\n    const draggedData = event.item.data;\r\n    if (draggedData?.children && Array.isArray(draggedData.children)) {\r\n      draggedData.children.forEach((col: any) => {\r\n        if (col.is_visible && col.is_groupable) {\r\n          this.groupedColumns.push(col);\r\n        }\r\n      });\r\n    } else {\r\n      if (draggedData.is_visible && draggedData.is_groupable) {\r\n        this.groupedColumns.push(draggedData);\r\n      }\r\n    }\r\n    this.draggingInGroupArea = false;\r\n    const fields = this.groupedColumns.map((item) => item.field);\r\n    this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n    this.updateFlattenedData();\r\n    this.updateColumnWidthsAndGroups();\r\n    this.refreshPreviewColumns();\r\n    this.updateVisibleRows(0);\r\n    this.loading = false;\r\n    this.cdr.detectChanges();\r\n    this.selectedCells = [];\r\n    setTimeout(() => {\r\n      this.rowSelectedIndexes.clear();\r\n      this.cdr.detectChanges();\r\n    }, 1000);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  async onGroupReorder(event: CdkDragDrop<any[]>) {\r\n    moveItemInArray(this.groupedColumns, event.previousIndex, event.currentIndex);\r\n    const fields = this.groupedColumns.map((item) => item.field);\r\n    this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n    setTimeout(() => {\r\n      this.updateFlattenedData();\r\n      this.updateColumnWidthsAndGroups();\r\n      this.refreshPreviewColumns();\r\n      this.updateVisibleRows(0);\r\n      this.loading = false;\r\n      this.cdr.detectChanges();\r\n    }, 100);\r\n\r\n    setTimeout(() => {\r\n      this.groupBoxPadding = this.columnsGroupedBox?.nativeElement.offsetWidth;\r\n      this.cdr.detectChanges()\r\n    }, 10);\r\n  }\r\n\r\n  async ungroupColumn(column: any) {\r\n    try {\r\n      this.loading = true;\r\n      this.cdr.detectChanges();\r\n      const index = this.groupedColumns.findIndex(\r\n        (col) => col.field === column.field\r\n      );\r\n      if (index !== -1) {\r\n        this.groupedColumns.splice(index, 1);\r\n      }\r\n      const fields = this.groupedColumns.map((item) => item.field);\r\n      this.dataSet = await this.groupDataAsync(this.originalDataSet, fields);\r\n      this.columns.forEach((group) => {\r\n        if (group?.children && Array.isArray(group.children)) {\r\n          group.children.forEach((child: any) => {\r\n            if (child.field === column.field) {\r\n              child.isRowGrouped = false;\r\n            }\r\n          });\r\n        } else if (group.field === column.field) {\r\n          group.isRowGrouped = false;\r\n        }\r\n      });\r\n      setTimeout(() => {\r\n        this.updateFlattenedData();\r\n        this.updateColumnWidthsAndGroups();\r\n        this.refreshPreviewColumns();\r\n        this.updateVisibleRows(0);\r\n        this.loading = false;\r\n        this.cdr.detectChanges();\r\n      }, 1000);\r\n\r\n    } catch (err) {\r\n      console.error(\"Error in ungroupColumn:\", err);\r\n      this.loading = false;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  shouldTheGroupHeaderShow(group: any) {\r\n    if (group?.children && group.children.length) {\r\n      return group.children.some(\r\n        (col: any) => col.is_visible && !col?.isRowGrouped\r\n      );\r\n    }\r\n    return group?.is_visible && !group?.isRowGrouped;\r\n  }\r\n\r\n\r\n  // onChildDragStart() {\r\n  //   debugger;\r\n  // }\r\n\r\n  // dropListIds: string[] = [];\r\n\r\n  // generateDropListIds() {\r\n  //   this.dropListIds = [];\r\n\r\n  //   const sectionKeys = [\r\n  //     'leftPinnedColumns',\r\n  //     'centerColumns',\r\n  //     'rightPinnedColumns',\r\n  //   ];\r\n\r\n  //   sectionKeys.forEach((sectionKey) => {\r\n  //     const sectionCols = (this as any)[sectionKey];\r\n\r\n  //     this.columns.forEach((col: any, i: number) => {\r\n  //       if (col?.children?.length > 0) {\r\n  //         col.children.forEach((child: any, childIndex: number) => {\r\n  //           if (child?.is_visible && !child.isRowGrouped) {\r\n  //             const id = `${sectionKey}${i}`;\r\n  //             this.dropListIds.push(id);\r\n  //           }\r\n  //         });\r\n  //       } else if (col?.is_visible && !col.isRowGrouped) {\r\n  //         const id = `${sectionKey}${i}`;\r\n  //         this.dropListIds.push(id);\r\n  //       }\r\n  //     });\r\n  //   });\r\n  // }\r\n\r\n  onChildDroplistSorted = async (event: CdkDragSortEvent<any>, section: string) => {\r\n    if (event.previousIndex === event.currentIndex) return;\r\n\r\n    const pinned =\r\n      section == 'previewLeftPinnedColumns'\r\n        ? 'left'\r\n        : section == 'previewRightPinnedColumns'\r\n          ? 'right'\r\n          : \"\";\r\n\r\n    const column = event.item.data;\r\n    let group = this.columns.find(\r\n      (col: any) =>\r\n        Array.isArray(col.children) &&\r\n        col.children.some((child: any) => child?.field === column?.field)\r\n    );\r\n    const groupIndex = this.columns.findIndex(\r\n      (col) => col.header === group.header\r\n    );\r\n    const filteredGroup = group?.children.filter((col: any) => {\r\n      const isPinnedMatch =\r\n        (pinned === \"\" && (!col?.pinned || col?.pinned === \"\")) || col?.pinned === pinned;\r\n      return isPinnedMatch && col?.is_visible;\r\n    });\r\n\r\n    const previousField = filteredGroup[event.previousIndex].field;\r\n    const currentField = filteredGroup[event.currentIndex].field;\r\n    const visiblePrevIndex = group.children.findIndex(\r\n      (col: any) => col.field == previousField\r\n    );\r\n    const visibleCurrIndex = group.children.findIndex(\r\n      (col: any) => col.field == currentField\r\n    );\r\n    const allFields = [previousField, currentField];\r\n    const cells = allFields.length\r\n      ? ([] as HTMLElement[]).concat(\r\n        ...allFields.map((field) =>\r\n          Array.from(document.querySelectorAll(`[data-field=\"${field}\"]`)) as HTMLElement[]\r\n        )\r\n      )\r\n      : [];\r\n\r\n    const groupInSection = (this as any)[section].find(\r\n      (col: any) =>\r\n        Array.isArray(col.children) &&\r\n        col.children.some((child: any) => child?.field === column?.field)\r\n    );\r\n\r\n    const filterGroupInSection = (this as any)[section].find(\r\n      (col: any) =>\r\n        Array.isArray(col.children) &&\r\n        col.children.some((child: any) => child?.field === column?.field)\r\n    );\r\n\r\n    const groupInSectionIndex = (this as any)[section].findIndex(\r\n      (col: any) => col.header === groupInSection.header\r\n    );\r\n\r\n    const firstPositions = new Map<HTMLElement, number>();\r\n    cells.forEach((el) => firstPositions.set(el, el.getBoundingClientRect().left));\r\n    moveItemInArray(\r\n      this.columns[groupIndex]?.children,\r\n      visiblePrevIndex,\r\n      visibleCurrIndex\r\n    );\r\n\r\n    moveItemInArray(\r\n      (this as any)[section]?.[groupInSectionIndex].children,\r\n      event.previousIndex,\r\n      event.currentIndex\r\n    );\r\n\r\n    // await this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n\r\n    await firstValueFrom(this.ngZone.onStable);\r\n    // allFields.forEach((field) => {\r\n    //   const updatedCells = Array.from(\r\n    //     document.querySelectorAll(`[data-field=\"${field}\"]`)\r\n    //   ) as HTMLElement[];\r\n    //   updatedCells.forEach((el) => {\r\n    //     const newLeft = el.getBoundingClientRect().left;\r\n    //     const oldLeft = firstPositions.get(el)!;\r\n    //     const deltaX = oldLeft - newLeft;\r\n    //     if (deltaX !== 0) {\r\n    //       el.style.willChange = 'transform';\r\n    //       el.style.transition = 'none';\r\n    //       el.style.transform = `translateX(${deltaX}px)`;\r\n    //       void el.offsetWidth;\r\n    //       el.style.transition = 'transform 400ms cubic-bezier(0.4, 0, 0.2, 1)';\r\n    //       el.style.transform = 'translateX(0)';\r\n\r\n    //       const handle = () => {\r\n    //         el.style.transition = '';\r\n    //         el.style.transform = '';\r\n    //         el.style.willChange = '';\r\n    //         el.removeEventListener('transitionend', handle);\r\n    //       };\r\n    //       el.addEventListener('transitionend', handle);\r\n    //     }\r\n    //   });\r\n    // });\r\n\r\n    this.ngZone.runOutsideAngular(() => {\r\n      allFields.forEach((field) => {\r\n        const updatedCells = Array.from(\r\n          document.querySelectorAll(`[data-field=\"${field}\"]`)\r\n        ) as HTMLElement[];\r\n\r\n        updatedCells.forEach((el) => {\r\n          const oldLeft = firstPositions.get(el);\r\n          if (oldLeft == null) return; // safety check\r\n\r\n          const newLeft = el.getBoundingClientRect().left;\r\n          const deltaX = oldLeft - newLeft;\r\n\r\n          if (deltaX !== 0) {\r\n            el.style.willChange = 'transform';\r\n            el.style.transition = 'none';\r\n            el.style.transform = `translateX(${deltaX}px)`;\r\n\r\n            // Force reflow\r\n            void el.offsetWidth;\r\n\r\n            el.style.transition = 'transform 250ms cubic-bezier(0.4, 0, 0.2, 1)';\r\n            el.style.transform = 'translateX(0)';\r\n\r\n            const handle = () => {\r\n              el.style.transition = '';\r\n              el.style.transform = '';\r\n              el.style.willChange = '';\r\n              el.removeEventListener('transitionend', handle);\r\n            };\r\n            el.addEventListener('transitionend', handle);\r\n          }\r\n        });\r\n      });\r\n    });\r\n\r\n    // console.group('Group: ', group);\r\n  }\r\n\r\n\r\n  onChildDroplistDroped(cdkDragDropevent: CdkDragDrop<any>) {\r\n    this.updateColumnWidthsAndGroups();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    setTimeout(() => {\r\n      this.cdr.detectChanges();\r\n    }, 2);\r\n  }\r\n\r\n  // Rows Grouping Logic Goes Here\r\n\r\n  groupData(data: any[], groupFields: string[]): any[] {\r\n    let dataSet = structuredClone(data);\r\n    if (!groupFields.length) return data;\r\n    const [currentField, ...restFields] = groupFields;\r\n    const groupedMap = new Map<string, any[]>();\r\n    for (const item of dataSet) {\r\n      let keyValue = currentField.split('.').reduce((obj, k) => obj?.[k], item);\r\n      let groupKey: string;\r\n      if (Array.isArray(keyValue)) {\r\n        if (keyValue.length === 0) {\r\n          groupKey = \"_Blank\";\r\n        } else if (typeof keyValue[0] === \"object\") {\r\n          groupKey = keyValue\r\n            .map(obj => (obj?.department_name || obj.roleName || obj?.full_name) ?? \"_Blank\")\r\n            .join(\",\");\r\n        } else {\r\n          groupKey = keyValue\r\n            .map(val => val ?? \"_Blank\")\r\n            .join(\",\");\r\n        }\r\n      } else {\r\n        groupKey = keyValue ? keyValue : \"_Blank\";;\r\n      }\r\n      if (typeof keyValue === 'string' && !isNaN(Date.parse(keyValue))) {\r\n          const dateObj = new Date(keyValue);\r\n          groupKey = this.commonSevice.formatDateValue(dateObj, this.dateFormat || 'MM/dd/yyyy');\r\n      }\r\n\r\n      if (!groupedMap.has(groupKey)) groupedMap.set(groupKey, []);\r\n      groupedMap.get(groupKey)!.push(item);\r\n    }\r\n    return Array.from(groupedMap.entries()).map(([groupValue, groupItems]) => ({\r\n      isGroup: true,\r\n      groupField: currentField,\r\n      groupValue,\r\n      children: this.groupData(groupItems, restFields),\r\n      isExpand: false,\r\n    }));\r\n  }\r\n\r\n\r\n  countLeafRows(group: any): number {\r\n    if (!group.children || !group.children.length) return 0;\r\n\r\n    return group.children.reduce((count: number, child: any) => {\r\n      return count + (child.isGroup ? this.countLeafRows(child) : 1);\r\n    }, 0);\r\n  }\r\n\r\n  isActiveFilterOpen = false;\r\n  toggleActiveFilter() {\r\n    this.isActiveFilterOpen = !this.isActiveFilterOpen;\r\n  }\r\n\r\n  toggleActions(type: string) {\r\n    if (type === this.activeTopButton) this.activeTopButton = type;\r\n    else this.activeTopButton = type;\r\n    this.activeSubButton = '';\r\n    this.isFilterOpen = false;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  activeSubButton = '';\r\n  toggleSubActions(type: string) {\r\n    if (type === this.activeSubButton) this.activeSubButton = '';\r\n    else this.activeSubButton = type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  toggleActionsDropdown() {\r\n    this.showActionsDropDown = !this.showActionsDropDown;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n\r\n  async changeTableLayout(event: Event, layoutType: string) {\r\n    let target = event.target as HTMLInputElement;\r\n\r\n    if (target.checked) {\r\n      this.selectedTableLayout = layoutType;\r\n      this.setTableLayout(layoutType)\r\n      this.updateVisibleRows(this.mainScroll?.nativeElement?.scrollTop);\r\n      await this.refreshHeaders();\r\n    }\r\n    if (this.tableFilterViewId) {\r\n      this.savePreset('mouseUp');\r\n    }\r\n    this.onFontChange()\r\n  }\r\n\r\n  setTableLayout(layoutType: string) {\r\n    if(!layoutType) return;\r\n    if (layoutType === 'small') {\r\n      this.rowHeight = 36;\r\n      this.headerRowHeight = 40;\r\n      this.bodyTextFontsSize = 10;\r\n      this.headerTextFontsSize = 10;\r\n\r\n    } else if (layoutType === 'medium') {\r\n      this.rowHeight = 44;\r\n      this.headerRowHeight = 44;\r\n      this.bodyTextFontsSize = 14;\r\n      this.headerTextFontsSize = 14;\r\n\r\n    } else {\r\n      this.rowHeight = 60;\r\n      this.headerRowHeight = 52;\r\n      this.bodyTextFontsSize = 16;\r\n      this.headerTextFontsSize = 16;\r\n    }\r\n  }\r\n\r\n  get startIndexData() {\r\n    return (this.paginationConfig.page - 1) * this.paginationConfig.limit;\r\n  }\r\n\r\n  get endIndex() {\r\n    return Math.min(this.startIndex + this.paginationConfig.limit, this.paginationConfig.totalResults);\r\n  }\r\n\r\n  get visiblePages(): (number | string)[] {\r\n    const pages: (number | string)[] = [];\r\n\r\n    if (this.paginationConfig.totalPages <= 7) {\r\n      for (let i = 1; i <= this.paginationConfig.totalPages; i++) {\r\n        pages.push(i);\r\n      }\r\n    } else {\r\n      pages.push(1);\r\n      if (this.paginationConfig.page > 3) {\r\n        pages.push('...');\r\n      }\r\n      let start = Math.max(2, this.paginationConfig.page - 1);\r\n      let end = Math.min(this.paginationConfig.totalPages - 1, this.paginationConfig.page + 1);\r\n\r\n      for (let i = start; i <= end; i++) {\r\n        pages.push(i);\r\n      }\r\n\r\n      if (this.paginationConfig.page < this.paginationConfig.totalPages - 2) {\r\n        pages.push('...');\r\n      }\r\n      pages.push(this.paginationConfig.totalPages);\r\n    }\r\n\r\n    return pages;\r\n  }\r\n\r\n\r\n  searchTextForFilterDropDown = '';\r\n  toggleColumnInFilterDropdown(col: any) {\r\n\r\n  }\r\n\r\n  removeColumnFromFilter(option: any) {\r\n\r\n  }\r\n\r\n  handleBackspace(event: Event) {\r\n    // If search is empty, remove last tag\r\n    if (!this.searchTextForFilterDropDown && this.selectedFilterOptions.length) {\r\n      const last = this.selectedFilterOptions[this.selectedFilterOptions.length - 1];\r\n      this.toggleSelectionInFilter(last);\r\n    }\r\n  }\r\n\r\n  @ViewChild('filterMenueSearchInput') filterMenueSearchInput!: ElementRef<HTMLInputElement>\r\n  @ViewChild('filterMenueTextchInput') filterMenueTextchInput!: ElementRef<HTMLInputElement>\r\n\r\n  openFilteronThreeDotsClick(col: any) {\r\n    if (col.type == 'image' || !col?.type) return;\r\n    this.selectedColumnForFilter = col;\r\n    this.isThreeDotsFilterOpen = true;\r\n    this.addFilterColumnInput = '';\r\n    if (col.type === 'dropdown') {\r\n      this.currentFilterSelectedIds.clear();\r\n      const savedIds = col?.query?._ids || [];\r\n      savedIds.forEach((id: string) => this.currentFilterSelectedIds.add(id));\r\n\r\n      this.selectedFilterOptions = this.selectedColumnForFilter?.column_dropdown_value?.filter(\r\n        (option: any) => this.currentFilterSelectedIds.has(option?.id || option?._id || option)\r\n      );\r\n      setTimeout(() => {\r\n        if (this.filterMenueSearchInput) {\r\n          this.filterMenueSearchInput.nativeElement.focus();\r\n        }\r\n      }, 100);\r\n    } else if (['string', 'number', 'date'].includes(col.type)) {\r\n      this.firstCondition = col.query.first_condition ? col.query.first_condition : (col.type == 'date' ? 'equal' : 'contain');\r\n      this.firstValue = col?.query?.first_value || '';\r\n      this.condition = col?.query?.condition || 'none';\r\n      this.secondCondition = col.query.first_condition ? col.query.first_condition : (col.type == 'date' ? 'equal' : 'contain');\r\n      this.secondValue = col?.query?.second_value || '';\r\n      setTimeout(() => {\r\n        this.filterMenueTextchInput.nativeElement.focus();\r\n      }, 100);\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  isFilterOpen = false\r\n  selectedColumnForFilter: any;\r\n  showFilters = this.showSideMenu ? false : false;\r\n\r\n\r\n  openFilterFromDisabledSearchedInput(col: any) {\r\n    if (col.type !== 'dropdown') return;\r\n    this.openFilter(col);\r\n  }\r\n\r\n  openFilter(col: any) {\r\n    this.activeFilterCell = col;\r\n    this.activeCol = null\r\n    this.isFilterOpen = true;\r\n    this.searchTextForFilterDropDown = '';\r\n    this.addFilterColumnInput = '';\r\n    this.selectedColumnForFilter = col;\r\n\r\n    if (col.type === 'dropdown') {\r\n      this.currentFilterSelectedIds.clear();\r\n      const savedIds = col?.query?._ids || [];\r\n      savedIds.forEach((id: string) => this.currentFilterSelectedIds.add(id));\r\n\r\n      this.selectedFilterOptions = this.selectedColumnForFilter?.column_dropdown_value?.filter(\r\n        (option: any) => this.currentFilterSelectedIds.has(option?.id || option?._id || option)\r\n      );\r\n    } else if (['string', 'number', 'date'].includes(col.type)) {\r\n      this.firstCondition = col?.query?.first_condition || 'contain';\r\n      this.firstValue = col?.query?.first_value || '';\r\n      this.condition = col?.query?.condition || 'none';\r\n      this.secondCondition = col?.query?.second_condition || 'contain';\r\n      this.secondValue = col?.query?.second_value || '';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  firstValue: any = '';\r\n  firstCondition = '';\r\n  secondValue: any = '';\r\n  secondCondition = null;\r\n  condition = '';\r\n\r\n  resetTextFilterChanges() {\r\n    this.firstCondition = 'contain';\r\n    this.firstValue = '';\r\n    this.condition = 'none';\r\n    this.secondCondition = null;\r\n    this.secondValue = '';\r\n    this.isFilterOpen = false;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n  }\r\n\r\n  toggleAllValusSelectionInDropdownFilter(column: any) {\r\n\r\n  }\r\n\r\n\r\n  selectedFilterOptions: any[] = []\r\n\r\n  currentFilterSelectedIds = new Set<string>();\r\n\r\n  toggleSelectionInFilter(option: any) {\r\n    debugger\r\n    const id = option.id || option._id || option;\r\n    if (this.currentFilterSelectedIds.has(id)) {\r\n      this.currentFilterSelectedIds.delete(id);\r\n    } else {\r\n      this.currentFilterSelectedIds.add(id);\r\n    }\r\n    this.selectedFilterOptions = this.selectedColumnForFilter?.column_dropdown_value.filter((option: any) => this.currentFilterSelectedIds.has(option.id || option._id || option))\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  resetFilterChanges() {\r\n    this.isFilterOpen = false;\r\n    this.currentFilterSelectedIds.clear();\r\n    this.selectedFilterOptions!.length = 0;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n    // const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns);\r\n    // console.log(\"Filtered Columns Are: \", filteredColumns);\r\n  }\r\n\r\n  applyDropdownFilter() {\r\n    this.isFilterOpen = false;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n    this.activeFilterCell = null;\r\n    this.isThreeDotsFilterOpen = false;\r\n    const findColumn = (columns: any[], field: string): any => {\r\n      for (const col of columns) {\r\n        if (col.field === field) return col;\r\n        if (col.children && col.children.length) {\r\n          const found = findColumn(col.children, field);\r\n          if (found) return found;\r\n        }\r\n      }\r\n      return null;\r\n    };\r\n\r\n    const column = findColumn(this.columns, this.selectedColumnForFilter.field);\r\n    if (column) {\r\n      if (column.type === 'dropdown') {\r\n        column.query = column.query || {};\r\n        column.query._ids = column.query._ids || [];\r\n\r\n        // Remove stale IDs (not present in Set)\r\n        column.query._ids = column.query._ids.filter(\r\n          (id: any) => this.currentFilterSelectedIds.has(id)   // <-- use .has()\r\n        );\r\n\r\n        // Add new ones if missing\r\n        this.currentFilterSelectedIds.forEach(id => {\r\n          if (!column.query._ids.includes(id)) {\r\n            column.query._ids.push(id);\r\n          }\r\n        });\r\n\r\n      } else if (['string', 'number', 'date'].includes(column.type)) {\r\n        column.query = {\r\n          first_condition: this.firstCondition || 'contain',\r\n          first_value: this.firstValue || null,\r\n          condition: this.secondValue ? this.condition: 'none',\r\n          second_condition:  this.secondValue ? this.secondCondition : null,\r\n          second_value: this.secondValue || null,\r\n        };\r\n      }\r\n    }\r\n\r\n    const filter = {\r\n      field: column.field,\r\n      search: column.search,\r\n      query: column.query,\r\n      type: column.type,\r\n      _ids: column._ids\r\n    };\r\n\r\n    const existingIndex = this.filtersConfig.findIndex(f => f.field === column.field);\r\n\r\n    if (existingIndex !== -1) {\r\n      this.filtersConfig[existingIndex] = filter;\r\n    } else {\r\n      this.filtersConfig.push(filter);\r\n    }\r\n\r\n    this.isFilterOpen = false;\r\n    this.activeCol = null;\r\n    this.isActiveFilterOpen = false;\r\n    this.activeTopButton = '';\r\n    this.activeFilterCell = null;\r\n    this.isThreeDotsFilterOpen = false;\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    const filters = this.cleanFilterdColumns()\r\n    setTimeout(() => {\r\n      this.filterOptions.emit(filters);\r\n    }, 200);\r\n  }\r\n\r\n  // applyFilterFromFilterRow(column: any) {\r\n  //   const filter = {\r\n  //     field: column.field,\r\n  //     search: column.search,\r\n  //     query: column.query,\r\n  //     type: column.type,\r\n  //     _ids: column._ids\r\n  //   };\r\n  //   this.filtersConfig.push(filter);\r\n  //   this.isFilterOpen = false;\r\n  //   this.isActiveFilterOpen = false;\r\n  //   this.activeTopButton = '';\r\n  //   this.activeFilterCell = null;\r\n  //   this.isThreeDotsFilterOpen = false;\r\n  //   const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig);\r\n  //   this.filterOptions.emit(filteredColumns);\r\n  // }\r\n\r\n  isFilterAppliedOnColumn(column: any) {\r\n    return this.filtersConfig.some(col => col.field === column.field);\r\n  }\r\n\r\n  // Side Filters Logic is here\r\n\r\n  toggleSelectAllSideFilters(col: any, event: Event) {\r\n    const checked = (event?.target as HTMLInputElement)?.checked;\r\n\r\n    if (checked) {\r\n      col.query._ids = col?.column_dropdown_value?.map(\r\n        (opt: any) => opt.id || opt._id || opt\r\n      );\r\n      this.currentFilterSelectedIds = new Set<string>(col.query._ids);\r\n    } else {\r\n      col.query._ids = [];\r\n      this.currentFilterSelectedIds.clear();\r\n    }\r\n  }\r\n\r\n\r\n  isAllSideFilterOptionsSelected(col: any): boolean {\r\n    if (!col?.query?._ids || !Array.isArray(col.column_dropdown_value)) return false;\r\n    return col.query._ids.length === col.column_dropdown_value.length;\r\n  }\r\n\r\n  onOptionToggle(col: any, option: any) {\r\n    const optionId = option.id || option._id || option;\r\n    if (!col.query._ids) {\r\n      col.query._ids = [];\r\n    }\r\n    const idx = col.query._ids.indexOf(optionId);\r\n    if (idx > -1) {\r\n      col.query._ids.splice(idx, 1);\r\n    } else {\r\n      col.query._ids.push(optionId);\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n\r\n\r\n  resetSideFilter(col: any) {\r\n    const resetColumnRecursively = (columns: any[]): boolean => {\r\n      for (const column of columns) {\r\n        if (column.field === col.field) {\r\n          column.query = {\r\n            _ids: [],\r\n            first_condition: 'contain',\r\n            first_value: null,\r\n            condition: 'none',\r\n            second_condition: 'contain',\r\n            second_value: null\r\n          };\r\n          return true;\r\n        }\r\n        if (Array.isArray(column?.children) && column?.children?.length) {\r\n          if (resetColumnRecursively(column.children)) {\r\n            return true;\r\n          }\r\n        }\r\n      }\r\n      return false;\r\n    };\r\n    resetColumnRecursively(this.columns);\r\n    const index = this.filtersConfig.findIndex((f: any) => f.field === col.field);\r\n    if (index !== -1) {\r\n      this.filtersConfig.splice(index, 1);\r\n    }\r\n    this.activeFilterCell = null;\r\n    this.cdr.detectChanges();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.cleanFilterdColumns(),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    const filters = this.cleanFilterdColumns()\r\n    setTimeout(() => {\r\n      this.filterOptions.emit(filters);\r\n    }, 200);\r\n  }\r\n\r\n\r\n  clearAllFilters() {\r\n    this.tableView?.forEach((ele) => { ele.is_temp = false });\r\n    const resetAllRecursively = (columns: any[]) => {\r\n      for (const column of columns) {\r\n        if (column.query) {\r\n          column.query = {\r\n            _ids: [],\r\n            first_condition: 'contain',\r\n            first_value: null,\r\n            condition: 'none',\r\n            second_condition: 'contain',\r\n            second_value: null\r\n          };\r\n        }\r\n        if (Array.isArray(column?.children) && column.children.length) {\r\n          resetAllRecursively(column.children);\r\n        }\r\n      }\r\n    };\r\n    resetAllRecursively(this.columns);\r\n    this.activeFilterCell = null;\r\n    this.filtersConfig = [];\r\n    this.refreshPreviewColumns();\r\n    this.cdr.detectChanges();\r\n    this.rowShadingEnabled = false;\r\n    this.showVerticalBorder = false;\r\n    this.fontFaimly = 'Inter';\r\n    this.headerTextFontsSize = 14;\r\n    this.selectedTableLayout = 'mediumd';\r\n    this.bodyTextFontsSize = 14;\r\n    this.globalSearchText = '';\r\n    const event = { eventType: 'reset', data: { tableType: this.tableType } };\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: [],\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    setTimeout(() => {\r\n      const filteredColumns = this.cleanFilterdColumns();\r\n      this.genericEvent.emit(event);\r\n      this.filterOptions.emit(filteredColumns);\r\n    }, 300);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  applySideFilter(column: any) {\r\n    if (!column.query.first_value && !column?.query?._ids.length) return;\r\n    const filter = {\r\n      field: column.field,\r\n      search: column.search,\r\n      query: column.query,\r\n      type: column.type,\r\n      _ids: column._ids || []\r\n    };\r\n\r\n    const existingIndex = this.filtersConfig.findIndex(f => f.field === column.field);\r\n\r\n    if (existingIndex !== -1) {\r\n      // Replace the existing filter\r\n      this.filtersConfig[existingIndex] = filter;\r\n    } else {\r\n      // Add new filter\r\n      this.filtersConfig.push(filter);\r\n    }\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig).map(({ query, ...rest }) => {\r\n        if (query) {\r\n          delete query.__typename;\r\n        }\r\n        return {\r\n          query,\r\n          ...rest,\r\n        }\r\n      }),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n\r\n    setTimeout(() => {\r\n      const filteredColumns = this.cleanFilterdColumns();\r\n      this.filterOptions.emit(filteredColumns);\r\n    }, 200);\r\n  }\r\n\r\n\r\n  removeSideFilter(column: any) {\r\n    if (!column.query.first_value && !column?.query?._ids.length) return;\r\n\r\n    const existingIndex = this.filtersConfig.findIndex(f => f.field === column.field);\r\n    if (existingIndex !== -1) {\r\n      this.filtersConfig.splice(existingIndex, 1);\r\n    }\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig).map(({ query, ...rest }) => {\r\n        if (query) {\r\n          delete query.__typename;\r\n        }\r\n        return {\r\n          query,\r\n          ...rest,\r\n        };\r\n      }),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      const filteredColumns = this.cleanFilterdColumns();\r\n      this.filterOptions.emit(filteredColumns);\r\n    }, 200);\r\n  }\r\n\r\n  collapseAllExpandedCells() {\r\n    if (this.expandedCells?.size > 0) {\r\n      this.expandedCells.clear();\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n\r\n\r\n  trackByField(index: number, col: any): string {\r\n    return col?.field;\r\n  }\r\n\r\n  get activeFilteredColumns(): any[] {\r\n    const collectFiltered = (columns: any[]): any[] => {\r\n      let result: any[] = [];\r\n\r\n      columns.forEach(col => {\r\n        if (col.children && col.children.length) {\r\n          result = result.concat(collectFiltered(col.children));\r\n        }\r\n\r\n        const isInFiltersConfig = this.filtersConfig.some(f => f.field === col.field);\r\n        if (isInFiltersConfig) {\r\n          result.push(col);\r\n        }\r\n      });\r\n\r\n      return result;\r\n    };\r\n\r\n    return collectFiltered(this.columns);\r\n  }\r\n\r\n\r\n\r\n\r\n  toggleOpenFilter() {\r\n    this.showFilters = !this.showFilters;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n\r\n\r\n  // Cell Editing Work start here\r\n\r\n  editingKey: string | null = null;\r\n  activeCell: string | null = null;\r\n\r\n  setActiveCell(row: any, column: any) {\r\n    this.activeCell = ((row.id || row._id) + '-' + column.field);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  isActiveCell(row: any, col: any): boolean {\r\n    return this.activeCell === ((row.id || row._id) + '-' + col.field);\r\n  }\r\n\r\n  @ViewChild('textAreadInput') textAreadInput!: ElementRef<HTMLTextAreaElement>;\r\n  enableEdit(row: any, column: any, clickedFromDetailsBox = false, cellContainer?: HTMLElement) {\r\n    this.editinDropdownSearch = '';\r\n    if (row?.__virtualIndex == 0) return;\r\n    if (column.type == 'image' || !column?.is_editable) return;\r\n    this.editingKey = ((row.id || row._id) + '-' + column.field);\r\n\r\n    if (column.type === 'dropdown') {\r\n      setTimeout(() => {\r\n        const dropdownMenu = document.querySelector('.cell-editing-dropdown-menu') as HTMLElement;\r\n        if (dropdownMenu) {\r\n          const rect = dropdownMenu.getBoundingClientRect();\r\n          const windowHeight = this.dataGridContainer.nativeElement?.offsetHeight;\r\n\r\n          if (rect.bottom > windowHeight) {\r\n            dropdownMenu.style.top = `-${rect.height}px`;\r\n          } else {\r\n            dropdownMenu.style.top = '100%';\r\n          }\r\n        }\r\n      });\r\n    }\r\n\r\n    if (!clickedFromDetailsBox && this.getNestedValue(row, column.field)?.length > 50) {\r\n      this.toggleExpandOfLongCellText(row, column, this.columns, false)\r\n    }\r\n    setTimeout(() => {\r\n      if (!cellContainer) return;\r\n\r\n      const focusable = cellContainer.querySelector(\r\n        'input, textarea, select, [contenteditable=\"true\"]'\r\n      ) as HTMLElement | null;\r\n\r\n      if (focusable) {\r\n        (focusable as HTMLElement).style.fontSize = '16px';\r\n        focusable.focus();\r\n\r\n        if (focusable instanceof HTMLInputElement || focusable instanceof HTMLTextAreaElement) {\r\n          focusable.select();\r\n        }\r\n      }\r\n\r\n    });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  disableEdit(row: any, column: any, control?: any) {\r\n    this.rowSelectedIndexes.clear();\r\n    if (!this.editingKey) return\r\n    this.checkRowEditAndEmitValue(row, column, row[column.field])\r\n    this.editingKey = null;\r\n    this.cdr.detectChanges();\r\n    const current = this.getNestedValue(row, column?.field);\r\n    if (!current || (column.type == 'email' && !this.validateEmail(current))) {\r\n      const originalRow = this.originalDataSet.find(item => item.id == row.id || item.id == row._id);\r\n      const original = this.getNestedValue(originalRow, column?.field);\r\n      this.setNestedValue(row, column, original);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n  validateEmail(value: string): boolean {\r\n    return this.emailRegex.test(value);\r\n  }\r\n  allowOnlyNumbers(event: KeyboardEvent) {\r\n    const charCode = event.which ? event.which : event.keyCode;\r\n    if (charCode < 48 || charCode > 57) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  checkRowEditAndEmitValue(row: any, column: any, value?: any) {\r\n    // setTimeout(() => {\r\n    const originalRow = this.originalDataSet?.find(\r\n      (r: any) => r.id === row.id || r._id === row._id\r\n    );\r\n    if (!originalRow) return;\r\n    // const clean = (obj: any) => JSON.parse(JSON.stringify(obj));\r\n    // const currentValue = this.getNestedValue(row, column.field);\r\n    // const originalValue = this.getNestedValue(originalRow, column.field);\r\n    const originValue = this.dataSet.find((r: any) => r.id === row.id);\r\n    const changedValue = originValue.verified == value;\r\n    // if (changedValue) return;\r\n    // const hasChanged = this.commonSevice.hasFieldChanged(currentValue, originalValue, column.type);\r\n    // if (!hasChanged) return;\r\n    // this.setNestedValue(originalRow, column, value);\r\n\r\n    const sendObj = {\r\n      data: { ...originValue },\r\n      eventType: 'onCellEdit',\r\n      value: value,\r\n      column: column\r\n    };\r\n    return this.genericEvent.emit(sendObj)\r\n    // }, 100);\r\n  }\r\n\r\n\r\n  isEditing(row: any, col: any): boolean {\r\n    return this.editingKey === ((row.id || row._id) + '-' + col.field);\r\n  }\r\n\r\n  setNestedValue(obj: any, column: any, option: any, calledFromInput = false): void {\r\n    const path = column.field;\r\n    const keys = path.split('.');\r\n    const lastKey = keys.pop();\r\n    const parent = keys.reduce((acc: { [x: string]: {}; }, key: string | number) => acc[key] ??= {}, obj);\r\n\r\n    if (parent && lastKey) {\r\n      if (typeof option === 'object' && option !== null) {\r\n        // case: dropdown object {id, value}\r\n        parent.id = option.id;\r\n        parent[lastKey] = option.value;\r\n      } else {\r\n        // case: plain string or number\r\n        parent[lastKey] = option;\r\n      }\r\n    }\r\n\r\n    const sendObj = {\r\n      data: { ...obj },\r\n      eventType: 'onCellEdit',\r\n    };\r\n\r\n    if (calledFromInput) {\r\n      this.checkRowEditAndEmitValue(obj, column, option);\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n  goToPage(page: any) {\r\n    if (this.paginationConfig?.page == page) return;\r\n    if (page < 1 || page > this.paginationConfig.totalPages) return;\r\n    this.paginationConfig.page = page;\r\n    const event = {\r\n      obj: {\r\n        limit: this.paginationConfig.limit,\r\n        page: page,\r\n      },\r\n      eventType: 'pageChange',\r\n    };\r\n    this.genericEvent.emit(event)\r\n  }\r\n\r\n  onPageSizeChange() {\r\n    this.paginationConfig.page = 1;\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig).map(({ query, ...rest }) => {\r\n        if (query) {\r\n          delete query.__typename;\r\n        }\r\n        return {\r\n          query,\r\n          ...rest,\r\n        }\r\n      }),\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      const event = {\r\n        obj: {\r\n          limit: this.paginationConfig.limit,\r\n          page: this.paginationConfig.page,\r\n        },\r\n        eventType: 'pageChange',\r\n      };\r\n      this.genericEvent.emit(event)\r\n    }, 700);\r\n  }\r\n\r\n  actionPreset(data: any, type: any) {\r\n    data.columns = data.columns.map(({ _id, filterValue, search, column_dropdown_value, query, __typename, ...rest }: any) => rest);\r\n    this.tableView?.forEach((ele) => { ele.is_temp = false });\r\n\r\n    {\r\n      this.bodyTextFontsSize = data.config.bodyTextFontsSize,\r\n        this.fontFaimly = data.config.fontFaimly,\r\n        data.filters.forEach((element: any) => {\r\n          delete element.__typename;\r\n          if (element.query) {\r\n            delete element.query.__typename;\r\n            if (\r\n              typeof element.query === 'object' &&\r\n              element.query !== null &&\r\n              Object.keys(element.query).length === 0\r\n            ) {\r\n              element.query = null;\r\n            }\r\n          }\r\n        });\r\n      this.headerTextFontsSize = data.config.headerTextFontsSize,\r\n        this.selectedTableLayout = data.config.selectedTableLayout,\r\n        this.showVerticalBorder = data.config.showVerticalBorder,\r\n        this.currentIdForUpdatePreset = data.id;\r\n      this.filtersConfig = data.filters;\r\n    }\r\n    delete data?.__typename;\r\n    delete data?.is_temp;\r\n    delete data?.config.__typename;\r\n    const event = {\r\n      obj: {\r\n        data: data\r\n      },\r\n      eventType: type\r\n    }\r\n    this.genericEvent.emit(event)\r\n  }\r\n\r\n  currentIdForUpdatePreset = '';\r\n  curretaTablePresetForUpdate: any;\r\n  temp_state = {\r\n    id: '',\r\n    is_temp: false\r\n  }\r\n  async selectFilter(data: any) {\r\n    this.temp_state = {\r\n      id: data.id,\r\n      is_temp: true\r\n    }\r\n    this.tableView?.forEach((ele) => { ele.is_temp = false });\r\n    this.tableView = this.tableView.map(item => ({\r\n      ...item,\r\n      is_temp: item.id == data?.id\r\n    }));\r\n    this.columns = data.columns;\r\n    {\r\n      this.bodyTextFontsSize = data.config.bodyTextFontsSize,\r\n        this.fontFaimly = data.config.fontFaimly,\r\n        data.filters.forEach((element: any) => {\r\n          delete element.__typename;\r\n\r\n          if (element.query) {\r\n            delete element.query.__typename;\r\n            if (\r\n              typeof element.query === 'object' &&\r\n              element.query !== null &&\r\n              Object.keys(element.query).length === 0\r\n            ) {\r\n              element.query = null;\r\n            }\r\n          }\r\n        });\r\n\r\n      // this.globalSearch = data.config.bodyTextFontsSize,\r\n      this.headerTextFontsSize = data.config.headerTextFontsSize,\r\n        this.selectedTableLayout = data.config.selectedTableLayout,\r\n        this.showVerticalBorder = data.config.showVerticalBorder,\r\n        this.currentIdForUpdatePreset = data.id;\r\n      this.curretaTablePresetForUpdate = structuredClone(data);\r\n      this.presetName = data?.name;\r\n      this.presetFilter = data?.activeFilters || false;\r\n      this.filtersConfig = data.filters;\r\n      await this.applyFilteroptionList();\r\n      this.refreshHeaders();\r\n      this.cdr.detectChanges();\r\n      data.columns = this.cleanColumns(this.columns);\r\n      delete data?.__typename;\r\n      delete data?.is_temp;\r\n      delete data?.config.__typename;\r\n    }\r\n    if (data?.is_deafult) {\r\n      return this.actionPreset(data, 'setPreset')\r\n    }\r\n    const event = {\r\n      obj: {\r\n        data: data\r\n      },\r\n      eventType: 'select'\r\n    }\r\n    this.genericEvent.emit(event)\r\n  }\r\n\r\n  savePreset(control?: any) {\r\n    if (control?.invalid) {\r\n      control?.control.markAsTouched();\r\n      return;\r\n    }\r\n    let names = this.getFilterHeaders(this.filtersConfig, this.columns);\r\n    this.presetFilter = this.tableFilterViewId ? true : this.presetFilter;\r\n    let selectedData: any = this.tableView.find((ele) => ele.id == this.tableFilterViewId);\r\n    let config = {\r\n      fontFaimly: this.fontFaimly,\r\n      bodyTextFontsSize: +(this.bodyTextFontsSize || 14),\r\n      headerTextFontsSize: +(this.headerTextFontsSize || 14),\r\n      oddRowsBackgroundColor: this.rowShadingEnabled ? this.oddRowsBackgroundColor : undefined,\r\n      showVerticalBorder: this.showVerticalBorder,\r\n      selectedTableLayout: this.selectedTableLayout,\r\n      globalSearch: this.tableSearch,\r\n      filterNames: names,\r\n      totalCount: this.paginationConfig.totalResults,\r\n      rowShadingEnabled: this.rowShadingEnabled\r\n\r\n    }\r\n    const event = {\r\n      obj: {\r\n        name: this.tableFilterViewId ? selectedData?.name : this.presetName,\r\n        activeFilters: this.presetFilter,\r\n        columns: this.cleanColumns(this.columns),\r\n        filters: this.presetFilter\r\n          ? this.filtersConfig?.map(({ __typename, query, ...rest }) => {\r\n            const { __typename: __inner, ...cleanQuery } = query || {};\r\n            return { ...rest, query: cleanQuery };\r\n          })\r\n          : [],\r\n        config: config,\r\n        id: this.tableFilterViewId || this.curretaTablePresetForUpdate?.id,\r\n        loadingCall: control == 'mouseUp' ? false : true,\r\n        type: this.tableType\r\n      },\r\n      eventType: this.tableFilterViewId || !this.isTablePresetNotChanged ? 'updatePreset' : 'createPreset'\r\n    }\r\n\r\n    const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig);\r\n    const cleanedFilteredColumns = filteredColumns.map(({ query, ...rest }) => {\r\n      if (query) {\r\n        delete query.__typename;\r\n      }\r\n      return {\r\n        query,\r\n        ...rest,\r\n      }\r\n    });\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: cleanedFilteredColumns,\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      this.genericEvent.emit(event)\r\n    }, 500);\r\n  }\r\n\r\n\r\n  getFilterHeaders(filters: any[], columns: any[]): string {\r\n    const matchedHeaders = filters\r\n      .map(f => {\r\n        const column = columns.find(c => c.field === f.field);\r\n        return column ? column.header : null;\r\n      })\r\n      .filter(header => !!header);\r\n\r\n    return matchedHeaders.join(', ');\r\n  }\r\n\r\n\r\n  toggleRowShading() {\r\n    this.oddRowsBackgroundColor = this.rowShadingEnabled ? '#f1f1f1' : undefined;\r\n    this.onFontChange();\r\n  }\r\n\r\n  trackByTable(index: number): number {\r\n    return index;\r\n  }\r\n  activeRow: any\r\n  activeRowCol: any;\r\n\r\n  // Track expanded cells as a Set of unique row+col identifiers\r\n\r\n  getCellKey(row: any, col: any): string {\r\n    return `${this.getRowId(row)}_${col?.field}`;\r\n  }\r\n\r\n  expandedCells = new Map<string, number>();\r\n  private zCounter = 21;\r\n\r\n  showDetailsBox = false;\r\n\r\n  toggleExpandOfLongCellText(\r\n    row: any,\r\n    col: any,\r\n    columns: any[],\r\n    expandWholeRow = false\r\n  ) {\r\n    const expandCells = (targetRow: any) => {\r\n      columns.forEach(c => {\r\n        if (c.type === 'image') return;\r\n        const text = targetRow[c.field];\r\n\r\n        if ((typeof text === 'string' && text.length > 50) || (Array.isArray(text) && text?.length > 1)) {\r\n          const key = this.getRowId(targetRow) + '-' + c.field;\r\n          this.zCounter++;\r\n          this.expandedCells.set(key, this.zCounter);\r\n        }\r\n      });\r\n    };\r\n\r\n\r\n    const collectKeysForRow = (targetRow: any) => {\r\n      const keys: string[] = [];\r\n      columns.forEach(c => {\r\n        if (c.type === 'image') return;\r\n\r\n        const text = targetRow[c.field];\r\n        if (typeof text === 'string' && text.length > 50 || (Array.isArray(text) && text?.length > 1)) {\r\n          keys.push(this.getRowId(targetRow) + '-' + c.field);\r\n        }\r\n      });\r\n      return keys;\r\n    };\r\n\r\n    if (expandWholeRow) {\r\n      let rowKeys: string[] = [];\r\n      const text = this.getNestedValue(row, col?.field);\r\n      if (Array.isArray(text) && text.length > 0) {\r\n        rowKeys = collectKeysForRow(row);\r\n        row?.children?.forEach((child: any) => {\r\n          rowKeys.push(...collectKeysForRow(child));\r\n        });\r\n      } else {\r\n        rowKeys = collectKeysForRow(row);\r\n      }\r\n      const allExpanded = rowKeys.every(k => this.expandedCells.has(k));\r\n      this.expandedCells.clear();\r\n      if (!allExpanded) {\r\n        if (Array.isArray(row.children) && row.children.length > 0) {\r\n          expandCells(row);\r\n          row?.children?.forEach((child: any) => expandCells(child));\r\n        } else {\r\n          expandCells(row);\r\n        }\r\n      }\r\n    } else {\r\n      const key = this.getRowId(row) + '-' + col.field;\r\n      if (col.type === 'image') return;\r\n\r\n      if (!this.expandedCells.has(key)) {\r\n        this.expandedCells.clear();\r\n        this.zCounter++;\r\n        this.expandedCells.set(key, this.zCounter);\r\n      } else {\r\n        this.expandedCells.delete(key);\r\n      }\r\n    }\r\n\r\n    this.showDetailsBox = false;\r\n    setTimeout(() => {\r\n      this.isOpenToTop(row)\r\n    }, 0);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  isOpenToTop(row: any) {\r\n    const wrapper = document.querySelector('.data-grid-body-wrapper') as HTMLElement | null;\r\n    if (!wrapper) return false;\r\n    this.columns.forEach((col: any) => {\r\n      const id = (row.id || row._id) + '-' + (col.id || col._id);\r\n      const box = document.getElementById(id);\r\n      if (!box) return false;\r\n      const boxRect = box.getBoundingClientRect();\r\n      const wrapperRect = wrapper.getBoundingClientRect();\r\n      const isOverflowingBottom = boxRect.bottom > wrapperRect.bottom;\r\n      const isOverflowingTop = boxRect.top < wrapperRect.top;\r\n      if (isOverflowingBottom && !isOverflowingTop) {\r\n        const boxHeight = box.offsetHeight || 0;\r\n        const offset = boxHeight + 4;\r\n        box.style.top = `${-offset}px`;\r\n\r\n      } else {\r\n        box.style.bottom = `auto`;\r\n        box.style.top = `100%`;\r\n        box.style.transform = `translateY(0)`;\r\n      }\r\n      return false;\r\n    })\r\n    this.showDetailsBox = true;\r\n    this.cdr.detectChanges();\r\n    return true;\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n  isExpanded(row: any, col: any): boolean {\r\n    return this.expandedCells.has(this.getRowId(row) + '-' + col.field);\r\n  }\r\n\r\n  getZIndex(row: any, col: any): number {\r\n    return this.expandedCells.get(this.getRowId(row) + '-' + col.field) ?? 21;\r\n  }\r\n\r\n  isOverflowing(element: HTMLElement | null): boolean {\r\n    if (!element) return false;\r\n    return element.scrollWidth > element.clientWidth;\r\n  }\r\n\r\n\r\n  // Picture cell Logic\r\n  colorCombination = ['pic-comb1', 'pic-comb2', 'pic-comb4'];\r\n  getDynamicClass(name: string): string {\r\n    if (!name) return this.colorCombination[0];\r\n    const hash = Array.from(name).reduce((acc, char) => acc + char.charCodeAt(0), 0);\r\n    const index = hash % this.colorCombination?.length;\r\n    return this.colorCombination[index];\r\n  }\r\n\r\n  getInitials(name: string): string {\r\n    if (!name) return 'NA';\r\n    const parts = name.trim().split(' ');\r\n    return (parts[0][0] + (parts[1]?.[0] || '')).toUpperCase();\r\n  }\r\n\r\n\r\n  actionHide: boolean = true;\r\n  xPos = 0;\r\n  yPos = 0;\r\n  isVisible = false;\r\n  deatilsList: any;\r\n  openExpendIndex: any;\r\n  positionedYet = false;\r\n\r\n  onRightClick(event: MouseEvent | TouchEvent | any, deatilsList: any): boolean {\r\n    if (deatilsList?.actions?.length) {\r\n      this.actions = deatilsList.actions;\r\n    }\r\n    if (!(event instanceof MouseEvent)) {\r\n      event.preventDefault();\r\n    }\r\n    if (deatilsList.__virtualIndex == 0) return false;\r\n    event.preventDefault();\r\n    this.xPos = (event instanceof MouseEvent) ? event.clientX : event.touches[0].clientX;\r\n    this.yPos = (event instanceof MouseEvent) ? event.clientY : event.touches[0].clientY;\r\n    // this.xPos = event.clientX;\r\n    // this.yPos = event.clientY;\r\n    this.isVisible = true;\r\n    this.positionedYet = false;\r\n    this.deatilsList = deatilsList;\r\n    setTimeout(() => {\r\n      const menuElement = document.querySelector('.context-menu') as HTMLElement;\r\n      if (!menuElement) return;\r\n      const menuWidth = menuElement.offsetWidth;\r\n      const menuHeight = menuElement.offsetHeight;\r\n      const viewportWidth = window.innerWidth;\r\n      const viewportHeight = window.innerHeight;\r\n      let x = (event instanceof MouseEvent) ? event.clientX : event.touches[0].clientX; //event.clientX;\r\n      let y = (event instanceof MouseEvent) ? event.clientY : event.touches[0].clientY; //event.clientY;\r\n      if (x + menuWidth > viewportWidth) {\r\n        x = viewportWidth - menuWidth - 10;\r\n      }\r\n      if (y + menuHeight > viewportHeight) {\r\n        y = viewportHeight - menuHeight - 10;\r\n      }\r\n      this.xPos = x;\r\n      this.yPos = y;\r\n      this.isVisible = true;\r\n\r\n      setTimeout(() => {\r\n        this.positionedYet = true;\r\n        this.cdr.detectChanges();\r\n      });\r\n\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.cdr.detectChanges()\r\n    return false;\r\n  }\r\n\r\n  onActionClick(action: string) {\r\n    const sendObj = {\r\n      obj: this.deatilsList,\r\n      eventType: action,\r\n    };\r\n    this.positionedYet = false;\r\n    this.cdr.detectChanges();\r\n    this.genericEvent.emit(sendObj);\r\n  }\r\n\r\n\r\n  onVerifyClick(type: string) {\r\n    const text = type?.toLowerCase();\r\n    if(text == 'archive' || text == 'unarchive'\r\n      // || text == 'delete' || text == 'restore' || text == 'remove' || text == 'deactivate' || text == 'activate' || text == 'block' || text == 'unblock'\r\n      // || text == 'enable' || text == 'disable' || text == 'approve' || text == 'reject' || text == 'publish' || text == 'unpublish' || text == 'lock' || text == 'unlock' || text == 'complete' || text == 'incomplete'\r\n      // || text == 'send to review' || text == 'mark as paid' || text == 'mark as unpaid' || text == 'fulfill' || text == 'unfulfill' || text == 'refund' || text == 'cancel' || text == 'resend' || text == 'chargeback'\r\n      // || text == 'dispute' || text == 'escalate' || text == 'deescalate' || text == 'flag' || text == 'unflag' || text == 'verify' || text == 'unverify' || text == 'subscribe' || text == 'unsubscribe' || text == 'follow' || text == 'unfollow'\r\n      // || text == 'like' || text == 'unlike' || text == 'share' || text == 'unshare' || text == 'comment' || text == 'uncomment' || text == 'tag' || text == 'untag' || text == 'assign' || text == 'unassign' || text == 'link' || text == 'unlink'\r\n      // || text == 'sync' || text == 'unsync' || text == 'backup' || text == 'restore backup' || text == 'migrate' || text == 'import' || text == 'export' || text == 'generate report' || text == 'download report' || text == 'view details'\r\n      // || text == 'edit details' || text == 'update details' || text == 'change status' || text == 'reset password' || text == 'send notification' || text == 'schedule' || text == 'reschedule' || text == 'cancel schedule' || text == 'start' || text == 'stop' || text == 'pause' || text == 'resume'\r\n    ){\r\n      this.clearSelectionState(this.tableType);\r\n      this.selectedRows.clear();\r\n    }\r\n    const idsArray = Array.from(this.selectedRows);\r\n    const arrayOfObjectsWithTableType: any[] = [];\r\n    this.selectedRows.forEach(id => {\r\n      arrayOfObjectsWithTableType.push({\r\n        id: id,\r\n        listingType: this.listingType,\r\n      });\r\n    });\r\n    const sendObj = {\r\n      data: {\r\n        obj: idsArray,\r\n        tableName: this.tableName,\r\n        listingType: this.listingType,\r\n      },\r\n      eventType: type,\r\n    };\r\n    this.genericEvent.emit(sendObj)\r\n  }\r\n\r\n\r\n\r\n  getCellClasses(column: any, value: any): string {\r\n    if (!value || !column?.field || column?.cellRenderer) return '';\r\n\r\n    let val: any = typeof value === 'object' ? value?.value ?? value : value;\r\n    const field = column.field.toLowerCase();\r\n\r\n    if (field === 'due_date') {\r\n      const dueDate = new Date(val);\r\n      const today = new Date();\r\n      const todayUTC = Date.UTC(today.getFullYear(), today.getMonth(), today.getDate());\r\n      const dueUTC = Date.UTC(dueDate.getFullYear(), dueDate.getMonth(), dueDate.getDate());\r\n\r\n      if (dueUTC < todayUTC) {\r\n        return 'text-danger';\r\n      }\r\n      // else if(dueUTC === todayUTC){\r\n      //   return 'text-warning';\r\n      // }\r\n\r\n      return '';\r\n    }\r\n\r\n\r\n    const status = val?.toString().toLowerCase();\r\n    if (\r\n      field === 'status' ||\r\n      field === 'account_status' ||\r\n      field === 'availstatus' ||\r\n      field === 'is_custom_grade'\r\n    ) {\r\n      return STATUSES_BADGE_MAP[status] || 'badge badge-secondary';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n\r\n  removeColumnFilterFromColumn(column: any) {\r\n    if (!column) return\r\n    if (column.type === 'dropdown') {\r\n      column.query._ids = [];\r\n    } else if (['string', 'number', 'date'].includes(column.type)) {\r\n      column.query = {\r\n        first_condition: 'contain',\r\n        first_value: null,\r\n        condition: 'none',\r\n        second_condition: null,\r\n        second_value: null,\r\n      }\r\n    }\r\n\r\n    const index = this.filtersConfig.findIndex((f: any) => f.field === column.field);\r\n    if (index !== -1) {\r\n      this.filtersConfig.splice(index, 1);\r\n    }\r\n\r\n    const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig);\r\n    const cleanedFilteredColumns = filteredColumns.map(({ query, ...rest }) => {\r\n      if (query) {\r\n        delete query.__typename;\r\n      }\r\n      return {\r\n        query,\r\n        ...rest,\r\n      }\r\n    });\r\n\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: cleanedFilteredColumns,\r\n      no_of_records: Number(this.paginationConfig.limit),\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n    setTimeout(() => {\r\n      const filteredColumns = cleanedFilteredColumns;\r\n      this.filterOptions.emit(filteredColumns);\r\n    }, 200);\r\n  }\r\n\r\n  onSideMenuColumnsVisibilityChange() {\r\n    this.refreshHeaders();\r\n    const sendData = {\r\n      columns: this.cleanColumns(this.columns),\r\n      filters: this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig).map(({ query, ...rest }) => {\r\n        if (query) {\r\n          delete query.__typename;\r\n        }\r\n        return {\r\n          query,\r\n          ...rest,\r\n        }\r\n      }),\r\n      no_of_records: this.paginationConfig.pageSize,\r\n      type: this.tableType,\r\n    };\r\n    this.createUpdateConfigListing.emit(sendData);\r\n  }\r\n\r\n  cleanFilterdColumns() {\r\n    const filteredColumns = this.commonSevice.getFiltersFromColumns(this.columns, this.filtersConfig);\r\n    const cleanedFilteredColumns = filteredColumns.map(({ query, ...rest }) => {\r\n      if (query) {\r\n        delete query.__typename;\r\n      }\r\n      return {\r\n        query,\r\n        ...rest,\r\n      }\r\n    });\r\n    return cleanedFilteredColumns;\r\n  }\r\n\r\n  downloadCsv(type: 'csv' | 'xlsx') {\r\n    const config: any = {\r\n      headerBgColor: this.headerBackgroundColor,\r\n      headerTextColor: this.headerTextColor,\r\n      bodyTextColor: '#000000',\r\n      fontFamily: this.fontFaimly,\r\n      fontWeight: 'normal',\r\n      zoomScale: 125,\r\n      headerRowHeight: 30\r\n    }\r\n    if (this.enableExport) {\r\n      const now = new Date();\r\n      const dd = String(now.getDate()).padStart(2, '0');\r\n      const mm = String(now.getMonth() + 1).padStart(2, '0');\r\n      const yyyy = now.getFullYear();\r\n      const HH = String(now.getHours()).padStart(2, '0');\r\n      const MM = String(now.getMinutes()).padStart(2, '0');\r\n      const formatted =\r\n        `${this.tableType}_${dd}-${mm}-${yyyy}_${HH}-${MM}`;\r\n\r\n      console.log(formatted);\r\n\r\n      this.exportService.exportData(this.columns, this.dataSet, formatted, type, this.rowSelectedIndexes, config);\r\n    }\r\n    const event = {\r\n      obj: {\r\n        columns: this.columns,\r\n        filters: []\r\n      },\r\n      eventType: 'downloadCsv'\r\n    }\r\n    if (type == 'xlsx') {\r\n      return\r\n    }\r\n    this.genericEvent.emit(event)\r\n\r\n  }\r\n\r\n  onFontChange() {\r\n    this.headerTextFontsSize = this.bodyTextFontsSize;\r\n    const config = {\r\n      fontFaimly: this.fontFaimly,\r\n      bodyTextFontsSize: this.bodyTextFontsSize,\r\n      headerTextFontsSize: this.headerTextFontsSize,\r\n      oddRowsBackgroundColor: this.rowShadingEnabled ? this.oddRowsBackgroundColor : undefined,\r\n      showVerticalBorder: this.showVerticalBorder,\r\n      selectedTableLayout: this.selectedTableLayout,\r\n      globalSearch: this.tableSearch\r\n    }\r\n    const event = {\r\n      obj: {\r\n        data: config\r\n      },\r\n      eventType: 'config'\r\n    }\r\n    this.genericEvent.emit(event)\r\n  }\r\n\r\n  onGlobalSearch() {\r\n    const event = {\r\n      obj: {\r\n        tableSearch: this.tableSearch\r\n      },\r\n      eventType: 'search'\r\n    }\r\n    this.genericEvent.emit(event)\r\n    if (this.tableFilterViewId) {\r\n      this.savePreset('mouseUp');\r\n    }\r\n  }\r\n\r\n  onSearchInput(event: Event) {\r\n    const value = (event.target as HTMLInputElement).value;\r\n    // console.log('Search value:', value);\r\n\r\n    if (value === '') {\r\n      this.tableSearch = '';\r\n      this.onGlobalSearch();\r\n    }\r\n  }\r\n\r\n  checkFilterChangesEffect(): any {\r\n    if (!this.tableFilterViewId) return true\r\n    const findDefaultFilter = this.tableView?.find((ele: any) => ele?.id == this.tableFilterViewId);\r\n    const normalizeFilters = (filters: any[] | undefined): any[] => {\r\n      if (!Array.isArray(filters)) return [];\r\n      const cloned = filters.map(f => {\r\n        const item = JSON.parse(JSON.stringify(f ?? {}));\r\n        if (!Array.isArray(item._ids)) item._ids = [];\r\n        item._ids = item._ids.slice().sort((a: any, b: any) => {\r\n          if (typeof a === 'number' && typeof b === 'number') return a - b;\r\n          return ('' + a).localeCompare('' + b);\r\n        });\r\n\r\n        if (item.query === null) {\r\n        } else if (typeof item.query === 'object') {\r\n          if (!Array.isArray(item.query._ids)) item.query._ids = [];\r\n          item.query._ids = item.query._ids.slice().sort((a: any, b: any) => {\r\n            if (typeof a === 'number' && typeof b === 'number') return a - b;\r\n            return ('' + a).localeCompare('' + b);\r\n          });\r\n        }\r\n\r\n        return item;\r\n      });\r\n      cloned.sort((a: any, b: any) => {\r\n        const fa = (a.field || '') + '|' + (a.type || '');\r\n        const fb = (b.field || '') + '|' + (b.type || '');\r\n        return fa.localeCompare(fb);\r\n      });\r\n\r\n      return cloned;\r\n    };\r\n\r\n    const deepEqual = (a: any, b: any): boolean => {\r\n      if (a === b) return true;\r\n\r\n      if (typeof a !== 'object' || a === null || typeof b !== 'object' || b === null) {\r\n        return a === b;\r\n      }\r\n\r\n      if (Array.isArray(a) !== Array.isArray(b)) return false;\r\n\r\n      if (Array.isArray(a)) {\r\n        if (a.length !== b.length) return false;\r\n        for (let i = 0; i < a.length; i++) {\r\n          if (!deepEqual(a[i], b[i])) return false;\r\n        }\r\n        return true;\r\n      }\r\n\r\n      const keysA = Object.keys(a);\r\n      const keysB = Object.keys(b);\r\n      if (keysA.length !== keysB.length) return false;\r\n\r\n      for (const key of keysA) {\r\n        if (!keysB.includes(key)) return false;\r\n        if (!deepEqual(a[key], b[key])) return false;\r\n      }\r\n      return true;\r\n    };\r\n    const normalizedA = normalizeFilters(findDefaultFilter?.filters);\r\n    const normalizedB = normalizeFilters(this.filtersConfig);\r\n    const isSame = deepEqual(normalizedA, normalizedB);\r\n    return isSame;\r\n  }\r\n\r\n\r\n\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // Cell Selection Implemented Here Implemented Here\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n\r\n  selectedCells: any[] = [];\r\n  selectedKeys: Set<string> = new Set();\r\n  selectionStart: any = null;\r\n  isSelecting = false;\r\n  startSelection(\r\n    rowIndex: number,\r\n    colIndex: number,\r\n    subColIndex: number | null,\r\n    field: string,\r\n    event: MouseEvent,\r\n    section: string\r\n  ) {\r\n    // event.preventDefault();\r\n    this.rowSelectedIndexes.clear();\r\n    const safeSub = subColIndex ?? 0;\r\n    const key = `${rowIndex}-${colIndex}-${safeSub}-${field}`;\r\n\r\n    this.selectionStart = { rowIndex, colIndex, subColIndex: safeSub, field, key };\r\n    this.isSelecting = true;\r\n    this.selectedKeys.clear();\r\n    this.selectedKeys.add(key);\r\n    this.selectedCells = [this.selectionStart];\r\n    const mouseUpHandler = () => {\r\n      this.endSelection();\r\n      document.removeEventListener('mouseup', mouseUpHandler);\r\n    };\r\n    document.addEventListener('mouseup', mouseUpHandler);\r\n    this.updateSelectionBoundaries()\r\n  }\r\n\r\n\r\n  extendSelection(\r\n    rowIndex: number,\r\n    colIndex: number,\r\n    subColIndex: number | null,\r\n    field: string,\r\n    event: MouseEvent,\r\n    section: string\r\n  ) {\r\n    if (!this.isSelecting || !this.selectionStart) return;\r\n\r\n    const start = this.selectionStart;\r\n    const targetSubColIndex = subColIndex ?? 0;\r\n    const newKeys: Set<string> = new Set();\r\n    const newCells: any[] = [];\r\n    const minRow = Math.min(start.rowIndex, rowIndex);\r\n    const maxRow = Math.max(start.rowIndex, rowIndex);\r\n    const columnsToSelect = this.getColumnSelectionRange(start.colIndex, colIndex, start.subColIndex, targetSubColIndex);\r\n\r\n    for (let r = minRow; r <= maxRow; r++) {\r\n      for (const colInfo of columnsToSelect) {\r\n        const k = `${r}-${colInfo.colIndex}-${colInfo.subColIndex}-${section}`;\r\n        newKeys.add(k);\r\n        newCells.push({\r\n          rowIndex: r,\r\n          colIndex: colInfo.colIndex,\r\n          subColIndex: colInfo.subColIndex,\r\n          field,\r\n          key: k\r\n        });\r\n      }\r\n    }\r\n\r\n    this.selectedKeys = newKeys;\r\n    this.selectedCells = newCells;\r\n    this.updateSelectionBoundaries();\r\n    this.cdr.detectChanges();\r\n\r\n    // Add auto-scrolling logic\r\n    this.handleCellAutoScroll(event);\r\n  }\r\n\r\n\r\n\r\n\r\n  getColumnSelectionRange(\r\n    startCol: number,\r\n    endCol: number,\r\n    startSub: number,\r\n    endSub: number\r\n  ): { colIndex: number; subColIndex: number }[] {\r\n    const result: { colIndex: number; subColIndex: number }[] = [];\r\n    const minCol = Math.min(startCol, endCol);\r\n    const maxCol = Math.max(startCol, endCol);\r\n\r\n    const isLeftToRight = startCol <= endCol;\r\n    for (let c = minCol; c <= maxCol; c++) {\r\n      const subColCount = this.getSubColumnCount(c);\r\n\r\n      if (c === startCol && c === endCol) {\r\n        const minSub = Math.min(startSub, endSub);\r\n        const maxSub = Math.max(startSub, endSub);\r\n        for (let s = minSub; s <= maxSub && s < subColCount; s++) {\r\n          result.push({ colIndex: c, subColIndex: s });\r\n        }\r\n      }\r\n      else if (c === startCol) {\r\n        if (isLeftToRight) {\r\n          for (let s = startSub; s < subColCount; s++) {\r\n            result.push({ colIndex: c, subColIndex: s });\r\n          }\r\n        } else {\r\n          for (let s = 0; s <= startSub && s < subColCount; s++) {\r\n            result.push({ colIndex: c, subColIndex: s });\r\n          }\r\n        }\r\n      }\r\n      else if (c === endCol) {\r\n        if (isLeftToRight) {\r\n          for (let s = 0; s <= endSub && s < subColCount; s++) {\r\n            result.push({ colIndex: c, subColIndex: s });\r\n          }\r\n        } else {\r\n          for (let s = endSub; s < subColCount; s++) {\r\n            result.push({ colIndex: c, subColIndex: s });\r\n          }\r\n        }\r\n      }\r\n      else {\r\n        for (let s = 0; s < subColCount; s++) {\r\n          result.push({ colIndex: c, subColIndex: s });\r\n        }\r\n      }\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  getSubColumnCount(colIndex: number): number {\r\n    if (!this.columns || colIndex < 0 || colIndex >= this.columns.length) {\r\n      return 1;\r\n    }\r\n    const column = this.columns[colIndex];\r\n    if (column.children && Array.isArray(column.children)) {\r\n      return column.children.length;\r\n    }\r\n    return 1;\r\n  }\r\n  isGroupColumn(colIndex: number): boolean {\r\n    return this.getSubColumnCount(colIndex) > 1;\r\n  }\r\n  endSelection() {\r\n    this.isSelecting = false;\r\n    this.stopAutoScroll();\r\n    this.updateSelectionBoundaries();\r\n  }\r\n  isSelected(\r\n    rowIndex: number,\r\n    colIndex: number,\r\n    subColIndex: number | null,\r\n    field: string,\r\n    section: string\r\n  ) {\r\n    const safeSub = subColIndex ?? 0;\r\n    const key = `${rowIndex}-${colIndex}-${safeSub}-${section}`;\r\n    return this.selectedKeys.has(key);\r\n  }\r\n\r\n\r\n  private selectionBounds: {\r\n    top: number | null;\r\n    bottom: number | null;\r\n    left: { colIndex: number; subColIndex: number } | null;\r\n    right: { colIndex: number; subColIndex: number } | null;\r\n  } = { top: null, bottom: null, left: null, right: null };\r\n\r\n  updateSelectionBoundaries() {\r\n    if (this.selectedCells.length === 0) {\r\n      this.selectionBounds = { top: null, bottom: null, left: null, right: null };\r\n      return;\r\n    }\r\n\r\n    // Get all unique row indices and find min/max\r\n    const rowIndices = [...new Set(this.selectedCells.map(cell => cell.rowIndex))];\r\n    this.selectionBounds.top = Math.min(...rowIndices);\r\n    this.selectionBounds.bottom = Math.max(...rowIndices);\r\n\r\n    // For left/right boundaries, we need to consider both colIndex and subColIndex\r\n    const leftMost = this.findLeftMostCell();\r\n    const rightMost = this.findRightMostCell();\r\n\r\n    this.selectionBounds.left = leftMost;\r\n    this.selectionBounds.right = rightMost;\r\n  }\r\n  findLeftMostCell(): { colIndex: number; subColIndex: number } | null {\r\n    if (this.selectedCells.length === 0) return null;\r\n\r\n    const minColIndex = Math.min(...this.selectedCells.map(cell => cell.colIndex));\r\n    const leftColCells = this.selectedCells.filter(cell => cell.colIndex === minColIndex);\r\n    const minSubColIndex = Math.min(...leftColCells.map(cell => cell.subColIndex));\r\n\r\n    return { colIndex: minColIndex, subColIndex: minSubColIndex };\r\n  }\r\n  findRightMostCell(): { colIndex: number; subColIndex: number } | null {\r\n    if (this.selectedCells.length === 0) return null;\r\n\r\n    const maxColIndex = Math.max(...this.selectedCells.map(cell => cell.colIndex));\r\n    const rightColCells = this.selectedCells.filter(cell => cell.colIndex === maxColIndex);\r\n    const maxSubColIndex = Math.max(...rightColCells.map(cell => cell.subColIndex));\r\n\r\n    return { colIndex: maxColIndex, subColIndex: maxSubColIndex };\r\n  }\r\n  isTopBorder(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    const safeSub = subColIndex ?? 0;\r\n    const isSelected = this.selectedKeys.has(`${rowIndex}-${colIndex}-${safeSub}-${section}`);\r\n    return isSelected && this.selectionBounds.top !== null && rowIndex === this.selectionBounds.top;\r\n  }\r\n  isBottomBorder(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    const safeSub = subColIndex ?? 0;\r\n    const isSelected = this.selectedKeys.has(`${rowIndex}-${colIndex}-${safeSub}-${section}`);\r\n    return isSelected && this.selectionBounds.bottom !== null && rowIndex === this.selectionBounds.bottom;\r\n  }\r\n  isLeftBorder(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    const safeSub = subColIndex ?? 0;\r\n    const isSelected = this.selectedKeys.has(`${rowIndex}-${colIndex}-${safeSub}-${section}`);\r\n    return isSelected && this.selectionBounds.left !== null &&\r\n      colIndex === this.selectionBounds.left.colIndex &&\r\n      safeSub === this.selectionBounds.left.subColIndex;\r\n  }\r\n\r\n  isRightBorder(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    const safeSub = subColIndex ?? 0;\r\n    const isSelected = this.selectedKeys.has(`${rowIndex}-${colIndex}-${safeSub}-${section}`);\r\n    return isSelected && this.selectionBounds.right !== null &&\r\n      colIndex === this.selectionBounds.right.colIndex &&\r\n      safeSub === this.selectionBounds.right.subColIndex;\r\n  }\r\n\r\n  isTopLeftCorner(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    return this.isTopBorder(rowIndex, colIndex, subColIndex, section) && this.isLeftBorder(rowIndex, colIndex, subColIndex, section);\r\n  }\r\n\r\n  isTopRightCorner(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    return this.isTopBorder(rowIndex, colIndex, subColIndex, section) && this.isRightBorder(rowIndex, colIndex, subColIndex, section);\r\n  }\r\n\r\n  isBottomLeftCorner(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    return this.isBottomBorder(rowIndex, colIndex, subColIndex, section) && this.isLeftBorder(rowIndex, colIndex, subColIndex, section);\r\n  }\r\n\r\n  isBottomRightCorner(rowIndex: number, colIndex: number, subColIndex: number | null, section: string): boolean {\r\n    return this.isBottomBorder(rowIndex, colIndex, subColIndex, section) && this.isRightBorder(rowIndex, colIndex, subColIndex, section);\r\n  }\r\n\r\n\r\n  cellSelectionAutoScrollInterval: any = null;\r\n  private scrollSpeed = 150;\r\n  private scrollMargin = 30;\r\n  handleCellAutoScroll(event: MouseEvent) {\r\n    if (this.cellSelectionAutoScrollInterval) {\r\n      clearInterval(this.cellSelectionAutoScrollInterval);\r\n      this.cellSelectionAutoScrollInterval = null;\r\n    }\r\n    const horizontalContainer = this.centerScrollableBody.nativeElement;\r\n    const verticalContainer = this.mainScroll.nativeElement;\r\n    if (!horizontalContainer || !verticalContainer) return;\r\n    const horizontalRect = horizontalContainer.getBoundingClientRect();\r\n    const mouseX = event.clientX;\r\n    const verticalRect = verticalContainer.getBoundingClientRect();\r\n    const mouseY = event.clientY;\r\n    const nearTop = mouseY - verticalRect.top < this.scrollMargin;\r\n    const nearBottom = verticalRect.bottom - mouseY < this.scrollMargin;\r\n    const nearLeft = mouseX - horizontalRect.left < this.scrollMargin;\r\n    const nearRight = horizontalRect.right - mouseX < this.scrollMargin;\r\n    let scrollX = 0;\r\n    let scrollY = 0;\r\n    if (nearTop) scrollY = -this.scrollSpeed;\r\n    if (nearBottom) scrollY = this.scrollSpeed;\r\n    if (nearLeft) scrollX = -this.scrollSpeed;\r\n    if (nearRight) scrollX = this.scrollSpeed;\r\n    if (scrollX !== 0 || scrollY !== 0) {\r\n      this.cellSelectionAutoScrollInterval = setInterval(() => {\r\n        if (scrollX !== 0) {\r\n          horizontalContainer.scrollBy(scrollX, 0);\r\n        }\r\n        if (scrollY !== 0) {\r\n          verticalContainer.scrollBy(0, scrollY);\r\n        }\r\n      }, 8);\r\n    }\r\n  }\r\n\r\n  stopAutoScroll() {\r\n    if (this.cellSelectionAutoScrollInterval) {\r\n      clearInterval(this.cellSelectionAutoScrollInterval);\r\n      this.cellSelectionAutoScrollInterval = null;\r\n    }\r\n  }\r\n\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // Row Selection from the Indexing Implemented Here\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n  // *************************************************************************\r\n\r\n  rowSelectedIndexes: Set<number> = new Set();\r\n  rowSelecting = false;\r\n  rowSelectionStartIndex: number | null = null;\r\n  autoScrollInterval: any = null;\r\n\r\n  get firstSelectedRow(): number | null {\r\n    if (this.rowSelectedIndexes.size === 0) return null;\r\n    return Math.min(...this.rowSelectedIndexes);\r\n  }\r\n\r\n  get lastSelectedRow(): number | null {\r\n    if (this.rowSelectedIndexes.size === 0) return null;\r\n    return Math.max(...this.rowSelectedIndexes);\r\n  }\r\n\r\n\r\n  onRowMouseDown(index: number, event: MouseEvent) {\r\n    event.preventDefault();\r\n    this.rowSelecting = true;\r\n    this.selectedKeys.clear();\r\n    this.rowSelectionStartIndex = index;\r\n    this.rowSelectedIndexes.clear();\r\n    this.rowSelectedIndexes.add(index);\r\n    this.activeCell = '';\r\n    this.cdr.detectChanges();\r\n\r\n    const mouseMoveHandler = (e: MouseEvent) => this.handleAutoScroll(e);\r\n    const mouseUpHandler = () => {\r\n      this.onRowMouseUp();\r\n      document.removeEventListener('mouseup', mouseUpHandler);\r\n      document.removeEventListener('mousemove', mouseMoveHandler);\r\n      if (this.autoScrollInterval) {\r\n        cancelAnimationFrame(this.autoScrollInterval);\r\n        this.autoScrollInterval = null;\r\n      }\r\n    };\r\n\r\n    document.addEventListener('mouseup', mouseUpHandler);\r\n    document.addEventListener('mousemove', mouseMoveHandler);\r\n  }\r\n\r\n  onRowMouseOver(index: number, event: MouseEvent) {\r\n    if (!this.rowSelecting || this.rowSelectionStartIndex === null) return;\r\n    this.rowSelectedIndexes.clear();\r\n    const start = Math.min(this.rowSelectionStartIndex, index);\r\n    const end = Math.max(this.rowSelectionStartIndex, index);\r\n    for (let i = start; i <= end; i++) {\r\n      this.rowSelectedIndexes.add(i);\r\n    }\r\n    // console.log([...this.rowSelectedIndexes]);\r\n  }\r\n\r\n  onRowMouseUp() {\r\n    this.rowSelecting = false;\r\n    this.rowSelectionStartIndex = null;\r\n  }\r\n  handleAutoScroll(e: MouseEvent) {\r\n    const container = this.mainScroll?.nativeElement as HTMLElement;\r\n    if (!container) return;\r\n\r\n    const rect = container.getBoundingClientRect();\r\n    const edgeSize = 40\r\n    let scrollAmount = 0;\r\n\r\n    if (e.clientY < rect.top + edgeSize) {\r\n      scrollAmount = -150;\r\n    } else if (e.clientY > rect.bottom - edgeSize) {\r\n      scrollAmount = 150;\r\n    }\r\n\r\n    if (scrollAmount !== 0) {\r\n      if (!this.autoScrollInterval) {\r\n        const step = () => {\r\n          container.scrollTop += scrollAmount;\r\n          this.autoScrollInterval = requestAnimationFrame(step);\r\n        };\r\n        this.autoScrollInterval = requestAnimationFrame(step);\r\n      }\r\n    } else {\r\n      if (this.autoScrollInterval) {\r\n        cancelAnimationFrame(this.autoScrollInterval);\r\n        this.autoScrollInterval = null;\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  // getSelectedDataForCopy(): any[][] {\r\n  //   const copiedRows: any[][] = [];\r\n  //   const findRowByVirtualIndex = (vIndex: number) =>\r\n  //     this.dataSet.find((r: any) => r.__virtualIndex === vIndex);\r\n  //   if (this.rowSelectedIndexes && this.rowSelectedIndexes.size > 0) {\r\n  //     const sortedIndexes = [...this.rowSelectedIndexes].sort((a, b) => a - b);\r\n  //     for (const vIndex of sortedIndexes) {\r\n  //       const row = findRowByVirtualIndex(vIndex);\r\n  //       if (!row) continue;\r\n  //       const rowValues = this.columns.flatMap(col =>\r\n  //         col.children && Array.isArray(col.children)\r\n  //           ? col.children.map((c: { field: string }) =>\r\n  //               this.getNestedValue(row, c.field) ?? ''\r\n  //             )\r\n  //           : this.getNestedValue(row, col.field) ?? ''\r\n  //       );\r\n  //       copiedRows.push(rowValues);\r\n  //     }\r\n  //   }\r\n\r\n  //   if (this.selectedCells && this.selectedCells.length > 0) {\r\n  //     const rowsMap = new Map<number, any[]>();\r\n  //     for (const cell of this.selectedCells) {\r\n  //       const row = findRowByVirtualIndex(cell.rowIndex);\r\n  //       if (!row) continue;\r\n\r\n  //       const col = this.columns[cell.colIndex];\r\n  //       let fieldName = col?.field;\r\n  //       if (col?.children && col.children[cell.subColIndex]) {\r\n  //         fieldName = col.children[cell.subColIndex].field;\r\n  //       }\r\n  //       const value = this.getNestedValue(row, fieldName) ?? '';\r\n\r\n  //       if (!rowsMap.has(cell.rowIndex)) rowsMap.set(cell.rowIndex, []);\r\n  //       rowsMap.get(cell.rowIndex)!.push(value);\r\n  //     }\r\n\r\n  //     const sortedCells = [...rowsMap.entries()]\r\n  //       .sort(([a], [b]) => a - b)\r\n  //       .map(([_, v]) => v);\r\n\r\n  //     copiedRows.push(...sortedCells);\r\n  //   }\r\n\r\n  //   if (copiedRows.length === 0) {\r\n  //     const activeCell = document.querySelector('.active-cell');\r\n  //     if (activeCell) return [[activeCell.textContent?.trim() || '']];\r\n  //   }\r\n  //   const maxCols = copiedRows.reduce((max, row) => Math.max(max, row.length), 0);\r\n  //   const normalized = copiedRows.map(row => {\r\n  //     const newRow = [...row];\r\n  //     while (newRow.length < maxCols) newRow.push(''); \r\n  //     return newRow;\r\n  //   });\r\n  //   return normalized;\r\n  // }\r\n\r\n\r\n  undoStack: any[][] = [];\r\n  redoStack: any[][] = [];\r\n\r\n  private cloneData(data: any[]): any[] {\r\n    return JSON.parse(JSON.stringify(data));\r\n  }\r\n\r\n  performCut(selectedData: any[][]) {\r\n    // Save current state for undo\r\n    this.undoStack.push(this.cloneData(this.visibleRows));\r\n    this.redoStack = []; // Clear redo stack on new action\r\n\r\n    // Perform cut\r\n    this.copyService.cutWithAnimation(selectedData);\r\n    const { updatedRows } = this.copyService.cutSelectedSelectedData(\r\n      this.visibleRows,\r\n      this.rowSelectedIndexes,\r\n      this.selectedCells,\r\n      this.columns,\r\n      this.setNestedValue.bind(this)\r\n    );\r\n\r\n    // console.log('Updated Rows: ', updatedRows);\r\n  }\r\n\r\n\r\n\r\n  getSelectedDataForCopy(): any[][] {\r\n    return this.copyService.getSelectedDataForCopy(\r\n      this.dataSet,\r\n      this.columns,\r\n      this.rowSelectedIndexes,\r\n      this.selectedCells,\r\n      this.getNestedValue.bind(this)\r\n    );\r\n  }\r\n\r\n  @HostListener('document:keydown', ['$event'])\r\n  onKeyDown(event: KeyboardEvent) {\r\n    const target = event.target as HTMLElement;\r\n    const isFormField =\r\n      target.tagName === 'INPUT' ||\r\n      target.tagName === 'TEXTAREA' ||\r\n      target.isContentEditable;\r\n    if (isFormField) return;\r\n\r\n    const tableContainer = document.querySelector('.data-grid-body-wrapper');\r\n    if (tableContainer && !tableContainer.contains(target)) return;\r\n    if ((event.ctrlKey || event.metaKey) && event.key.toLowerCase() === 'c') {\r\n      if (!this.selectedCells?.length && !this.rowSelectedIndexes.size) return\r\n      const selectedData = this.getSelectedDataForCopy();\r\n      // event.preventDefault();\r\n      this.copyService.copyToClipboard(selectedData);\r\n\r\n    } else if ((event.ctrlKey || event.metaKey) && event.key.toLowerCase() === 'x') {\r\n      if (!this.selectedCells?.length || !this.enableCut) return\r\n      const selectedData = this.getSelectedDataForCopy();\r\n      // event.preventDefault();\r\n      this.performCut(selectedData);\r\n\r\n    } else if ((event.ctrlKey || event.metaKey) && event.key.toLowerCase() === 'z') {\r\n      if (!this.selectedCells?.length) return\r\n      // event.preventDefault();\r\n      this.undo();\r\n\r\n    } else if ((event.ctrlKey || event.metaKey) && event.key.toLowerCase() === 'y') {\r\n      if (!this.selectedCells?.length) return\r\n      // event.preventDefault();\r\n      this.redo();\r\n    } else if ((event.ctrlKey || event.metaKey) && event.key === 'a') {\r\n      // ✅ Select all cells\r\n      event.preventDefault();\r\n      this.selectAllCells();\r\n    }\r\n  }\r\n\r\n\r\n  selectAllCells() {\r\n    this.selectedCells = [];\r\n    this.selectedKeys.clear();\r\n    this.rowSelectedIndexes.clear();\r\n\r\n    // Set selection start like single selection (first cell)\r\n    if (this.dataSet.length && this.columns.length) {\r\n      const firstField = this.columns[0].field || this.columns[0].name;\r\n      this.selectionStart = {\r\n        rowIndex: 0,\r\n        colIndex: 0,\r\n        subColIndex: 0,\r\n        field: firstField,\r\n        key: `0-0-0-${firstField}`,\r\n      };\r\n    }\r\n\r\n    this.isSelecting = true;\r\n\r\n    for (let rowIndex = 0; rowIndex <= this.dataSet?.length; rowIndex++) {\r\n      if (!rowIndex) continue;\r\n      const row = this.dataSet[rowIndex];\r\n      this.rowSelectedIndexes.add(rowIndex);\r\n\r\n      // for (let colIndex = 0; colIndex < this.columns.length; colIndex++) {\r\n      //   const col = this.columns[colIndex];\r\n      //   const field = col.field || col.name;\r\n      //   if(!col.is_visible) continue;\r\n\r\n      //   if (col.children?.length) {\r\n      //     col.children.forEach((sub: any, subColIndex: number) => {\r\n      //       const key = `${rowIndex}-${colIndex}-${subColIndex}-${field}`;\r\n      //       this.selectedKeys.add(key);\r\n      //       this.selectedCells.push({\r\n      //         rowIndex,\r\n      //         colIndex,\r\n      //         subColIndex,\r\n      //         field,\r\n      //         key,\r\n      //       });\r\n      //     });\r\n      //   } else {\r\n      //     const key = `${rowIndex}-${colIndex}-0-${field}`;\r\n      //     this.selectedKeys.add(key);\r\n      //     this.selectedCells.push({\r\n      //       rowIndex,\r\n      //       colIndex,\r\n      //       subColIndex: 0,\r\n      //       field,\r\n      //       key,\r\n      //     });\r\n      //   }\r\n      // }\r\n    }\r\n\r\n    // Update highlighting and UI\r\n    this.updateSelectionBoundaries();\r\n\r\n    // Stop \"selecting\" mode since it's a one-time select-all\r\n    this.isSelecting = false;\r\n  }\r\n\r\n\r\n\r\n  undo() {\r\n    if (this.undoStack.length > 0) {\r\n      const prevState = this.undoStack.pop()!;\r\n      this.redoStack.push(this.cloneData(this.visibleRows));\r\n      this.visibleRows = this.cloneData(prevState);\r\n    }\r\n  }\r\n\r\n  redo() {\r\n    if (this.redoStack.length > 0) {\r\n      const nextState = this.redoStack.pop()!;\r\n      this.undoStack.push(this.cloneData(this.visibleRows));\r\n      this.visibleRows = this.cloneData(nextState);\r\n    }\r\n  }\r\n\r\n\r\n\r\n  @HostListener('document:paste', ['$event'])\r\n  async onPaste(event: ClipboardEvent) {\r\n    const target = event.target as HTMLElement;\r\n    const tag = target?.tagName?.toLowerCase();\r\n    if (tag === 'input' || tag === 'textarea' || target?.getAttribute('contenteditable') === 'true') {\r\n      return;\r\n    }\r\n\r\n    if (!this.selectedCells?.length || !this.activeCell) return;\r\n\r\n    const text = event.clipboardData?.getData('text');\r\n    if (!text) return;\r\n    const userConfirmed = await this.showConfirmationModal(\r\n      'Are you sure you want to paste the copied data?'\r\n    );\r\n\r\n    if (!userConfirmed) {\r\n      event.preventDefault();\r\n      return;\r\n    }\r\n\r\n    const startCell = this.selectedCells?.[0];\r\n    if (!startCell) return;\r\n\r\n    const updatedRows = await this.copyService.pasteFromClipboardText(\r\n      text,\r\n      this.visibleRows,\r\n      this.columns,\r\n      startCell.rowIndex,\r\n      startCell.colIndex,\r\n      startCell.subColIndex\r\n    );\r\n\r\n    if (updatedRows?.updateRows?.length) {\r\n      this.genericEvent.emit({\r\n        data: updatedRows?.updateRows,\r\n        eventType: 'onCellEdit',\r\n        column: updatedRows?.currentColums\r\n      });\r\n    }\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  showConfirmationModal(message: string): Promise<boolean> {\r\n    return new Promise(resolve => {\r\n      const overlay = document.createElement('div');\r\n      overlay.classList.add('custom-overlay-wrapper');\r\n      overlay.innerHTML = `\r\n      <div class=\"custom-overlay\">\r\n        <div class=\"custom-modal\">\r\n          <div class=\"custom-modal-body\">\r\n            <p class=\"modal-message\">${message}</p>\r\n            <div class=\"modal-actions\">\r\n              <button class=\"btn-confirm\">Confirm</button>\r\n              <button class=\"btn-cancel\">Cancel</button>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    `;\r\n\r\n      document.body.appendChild(overlay);\r\n      const confirmBtn = overlay.querySelector('.btn-confirm') as HTMLElement;\r\n      const cancelBtn = overlay.querySelector('.btn-cancel') as HTMLElement;\r\n      const cleanup = () => {\r\n        document.body.removeChild(overlay);\r\n      };\r\n      confirmBtn.addEventListener('click', () => {\r\n        cleanup();\r\n        resolve(true);\r\n      });\r\n\r\n      cancelBtn.addEventListener('click', () => {\r\n        cleanup();\r\n        resolve(false);\r\n      });\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n  isDate(value: any): boolean {\r\n    return !isNaN(new Date(value)?.getTime());\r\n  }\r\n\r\n\r\n  // Hold expanded IDs (array for multiple, single value for single)\r\n  expandededDetailRows: (string | number)[] | string | number = '';\r\n\r\n  toggleDetailRowExpand(row: any) {\r\n    const id = row?.id || row?._id;\r\n    if (this.gridType === 'Assets' && row?.detail?.columns) {\r\n      row.detail.columns.forEach((item: any) => {\r\n        item.width = item?.width || (this.dataGridContainer.nativeElement.offsetWidth / row.detail.columns?.length)\r\n      });\r\n      this.previewNestedCols = this.deepCloneColumns(row.detail.columns);\r\n    }\r\n    if (this.keepMultipleExpandedDetails) {\r\n      if (!Array.isArray(this.expandededDetailRows)) {\r\n        this.expandededDetailRows = [];\r\n      }\r\n      const expanded = this.expandededDetailRows as (string | number)[];\r\n      const index = expanded.indexOf(id);\r\n\r\n      if (index > -1) {\r\n        expanded.splice(index, 1);\r\n      } else {\r\n        expanded.push(id);\r\n      }\r\n    } else {\r\n      if (this.expandededDetailRows === id) {\r\n        this.expandededDetailRows = '';\r\n      } else {\r\n        this.expandededDetailRows = id;\r\n      }\r\n    }\r\n\r\n    setTimeout(() => {\r\n      void this.rightPinnedHeader?.nativeElement.offsetWidth;\r\n      this.centerPinnedBody?.nativeElement.offsetWidth;\r\n      this.rightPinnedBody?.nativeElement.offsetWidth;\r\n      this.cdr.detectChanges();\r\n    }, 300)\r\n  }\r\n\r\n  isDetailsExpanded(row: any): boolean {\r\n    const id = row?.id || row?._id;\r\n\r\n    if (this.keepMultipleExpandedDetails) {\r\n      return Array.isArray(this.expandededDetailRows) &&\r\n        this.expandededDetailRows.includes(id);\r\n    } else {\r\n      return this.expandededDetailRows === id;\r\n    }\r\n  }\r\n\r\n  getFilterValue(option: any): any {\r\n    return option?.value ?? option;\r\n  }\r\n\r\n\r\n  openIndex: number | null = null;\r\n  toggleMenu(i: number, event?: MouseEvent) {\r\n    if (event) { event.stopPropagation(); }\r\n    this.openIndex = this.openIndex === i ? null : i;\r\n  }\r\n\r\n  @ViewChild('nestedTable')\r\n  nestedTable!: ElementRef<HTMLDivElement>;\r\n  get hasVerticalScroll(): boolean {\r\n    if (!this.nestedTable) return false;\r\n    return this.nestedTable.nativeElement.scrollHeight > this.nestedTable.nativeElement.clientHeight;\r\n  }\r\n\r\n  get hasHorizontalScroll(): boolean {\r\n    if (!this.nestedTable) return false;\r\n    const el = this.nestedTable.nativeElement;\r\n    return el.scrollWidth > el.clientWidth;\r\n  }\r\n\r\n\r\n  getTotalAmount(column: any) {\r\n    if (!column?.is_amount) return;\r\n    const total = this.originalDataSet.reduce((sum, row) => {\r\n      const value = row[column.field] || 0;\r\n      return sum + value;\r\n    }, 0);\r\n    if(!total) return `${this.currencySymbol} 0.00`\r\n    return `${this.currencySymbol} ${this.formatCurrency.transform(total, this.currencyFormat)}`;\r\n  }\r\n\r\n  dropColumn(event: CdkDragDrop<any[]>, row: any) {\r\n    // Reorder the columns array\r\n    moveItemInArray(row.detail.columns, event.previousIndex, event.currentIndex);\r\n  }\r\n\r\n  currentSubSortColumn: string | null = null; // active column\r\n  currentSortDirection: 'asc' | 'desc' = 'asc'; // active direction\r\n\r\n  sortNestedCol(col: any, row: any) {\r\n    const dataSet = row?.detail?.result;\r\n    if (this.currentSubSortColumn === col.field) {\r\n      this.currentSortDirection = this.currentSortDirection === 'asc' ? 'desc' : 'asc';\r\n    } else {\r\n      this.currentSubSortColumn = col.field;\r\n      this.currentSortDirection = 'asc';\r\n    }\r\n    col.order_by = this.currentSortDirection;\r\n\r\n    // Sort copy instead of mutating\r\n    const sorted = [...dataSet].sort((a, b) => {\r\n      let aVal = a[col.field];\r\n      let bVal = b[col.field];\r\n      aVal = aVal == null ? '' : aVal;\r\n      bVal = bVal == null ? '' : bVal;\r\n\r\n      if (col.type === 'date') {\r\n        aVal = new Date(aVal).getTime();\r\n        bVal = new Date(bVal).getTime();\r\n      }\r\n\r\n      const aNum = parseFloat(aVal);\r\n      const bNum = parseFloat(bVal);\r\n      const bothNumbers = !isNaN(aNum) && !isNaN(bNum);\r\n\r\n      if (bothNumbers) {\r\n        return this.currentSortDirection === 'asc' ? aNum - bNum : bNum - aNum;\r\n      } else {\r\n        const comp = String(aVal).localeCompare(String(bVal));\r\n        return this.currentSortDirection === 'asc' ? comp : -comp;\r\n      }\r\n    });\r\n\r\n    row.detail.result = sorted;\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n\r\n  getColumnWidthPx(row: any, col: any): string {\r\n    if (col.width) return col.width + 'px';\r\n    const pixels = this.centerScrollableBody?.nativeElement?.offsetWidth / row.detail?.columns.length;\r\n    return pixels + 'px';\r\n  }\r\n\r\n  fullscreenImage: string | null = null;\r\n\r\n\r\n  // Assests Nested Table Work Implemented Here\r\n\r\n  pinUnpinColum(col: any, value: 'left' | 'right' | null, columns: any[]) {\r\n    col.pinned = value;\r\n    const left = columns.filter(c => c.pinned === 'left');\r\n    const middle = columns.filter(c => !c.pinned || c.pinned === null);\r\n    const right = columns.filter(c => c.pinned === 'right');\r\n    columns.length = 0;\r\n    columns.push(...left, ...middle, ...right);\r\n    this.activeCol = null;\r\n  }\r\n\r\n  getLeftPinnedCount(columns: any[]): number {\r\n    return columns.filter(c => c.pinned === 'left').length;\r\n  }\r\n\r\n  getRightPinnedCount(columns: any[]): number {\r\n    return columns.filter(c => c.pinned === 'right').length;\r\n  }\r\n\r\n  getStickyLeft(columns: any[], index: number): string {\r\n    let left = 0;\r\n    for (let i = 0; i < index; i++) {\r\n      const prevCol = columns[i];\r\n      if (prevCol.pinned === 'left') {\r\n        left += prevCol.width || 100;\r\n      }\r\n    }\r\n    return `${left}px`;\r\n  }\r\n\r\n  previewNestedCols: any[] = [];\r\n  onNestedColSort(event: CdkDragSortEvent<any[]>, columns: any[]): void {\r\n    if (!event || !columns) return;\r\n    const firstPositions = new Map<HTMLElement, number>();\r\n    columns.forEach((col) => {\r\n      const colCells = Array.from(document.querySelectorAll(`[data-field=\"${col.field}\"]`)) as HTMLElement[];\r\n      colCells.forEach((el) => firstPositions.set(el, el.getBoundingClientRect().left));\r\n    });\r\n    moveItemInArray(columns, event.previousIndex, event.currentIndex);\r\n    this.cdr.detectChanges();\r\n    requestAnimationFrame(() => {\r\n      columns.forEach((col) => {\r\n        const updatedCells = Array.from(document.querySelectorAll(`[data-field=\"${col.field}\"]`)) as HTMLElement[];\r\n        updatedCells.forEach((el) => {\r\n          const newLeft = el.getBoundingClientRect().left;\r\n          const oldLeft = firstPositions.get(el) ?? newLeft;\r\n          const deltaX = oldLeft - newLeft;\r\n\r\n          if (deltaX !== 0) {\r\n            el.style.transition = 'none';\r\n            el.style.transform = `translateX(${deltaX}px)`;\r\n            void el.offsetWidth;\r\n            el.style.transition = 'transform 250ms ease';\r\n            el.style.transform = 'translateX(0)';\r\n            const cleanup = () => {\r\n              el.style.transition = '';\r\n              el.style.transform = '';\r\n              el.removeEventListener('transitionend', cleanup);\r\n            };\r\n            el.addEventListener('transitionend', cleanup);\r\n          }\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n\r\n  saveSelection(selectedIds: string[], tableType: string) {\r\n    if (!tableType) return;\r\n    const stored = JSON.parse(localStorage.getItem('datatableSelections') || '{\"selectedRows\": {}}');\r\n    const allSelected = stored.selectedRows || {};\r\n    allSelected[tableType] = selectedIds;\r\n    localStorage.setItem(\r\n      'datatableSelections',\r\n      JSON.stringify({\r\n        selectedRows: allSelected,\r\n        listingType: tableType\r\n      })\r\n    );\r\n  }\r\n\r\n\r\n  restoreSelection(tableType: string) {\r\n    const stored = JSON.parse(localStorage.getItem('datatableSelections') || '{}');\r\n    const ids = stored.selectedRows?.[tableType] || [];\r\n    this.selectedRows = new Set(ids);\r\n    return this.selectedRows;\r\n  }\r\n\r\n\r\n\r\n  isOutsideContainer = false;\r\n  private containerRect: DOMRect | null = null;\r\n\r\n\r\n  onDragStarted(col: any): void {\r\n    this.currentDraggingColumn = col;\r\n    const container = document.getElementById('data-grid-main-container');\r\n    this.containerRect = container?.getBoundingClientRect() || null;\r\n  }\r\n\r\n  onDragMoved(event: CdkDragMove): void {\r\n    if (!this.containerRect) return;\r\n\r\n    const { x, y } = event.pointerPosition;\r\n    const isOutside =\r\n      x < this.containerRect.left ||\r\n      x > this.containerRect.right ||\r\n      y < this.containerRect.top ||\r\n      y > this.containerRect.bottom;\r\n\r\n    // if (isOutside !== this.isOutsideContainer) {\r\n    //   this.isOutsideContainer = isOutside;\r\n    // }\r\n  }\r\n\r\n  onDragEnded(): void {\r\n    setTimeout(() => {\r\n      // if (this.isOutsideContainer && this.currentDraggingColumn) {\r\n      //   this.currentDraggingColumn!.is_visible = false;\r\n        this.currentDraggingColumn = null;\r\n        this.isOutsideContainer = false;\r\n      //   this.cdr.detectChanges();\r\n      // }\r\n    }, 100);\r\n    this.containerRect = null;\r\n  }\r\n\r\n  getStartIndex(): number {\r\n    return this.paginationConfig.totalResults === 0\r\n      ? 0\r\n      : (this.paginationConfig.page - 1) * this.paginationConfig.limit + 1 || 0;\r\n  }\r\n\r\n  hasAnyDefaultView() {\r\n    return this.tableView?.some((x) => x.is_default || x.is_temp);\r\n  }\r\n\r\n\r\n  get isTablePresetNotChanged() {\r\n    if (this.tableFilterViewId) return false;\r\n    const currPreset = this.curretaTablePresetForUpdate;\r\n\r\n    const currentPresetColumns = currPreset?.columns?.map((col: { field: any; width: any; pinned: any; }) => {\r\n      return {\r\n        field: col.field,\r\n        width: col.width,\r\n        pinned: col.pinned\r\n      }\r\n    });\r\n    const columns = this.columns?.map(col => {\r\n      return {\r\n        field: col.field,\r\n        width: col.width,\r\n        pinned: col.pinned\r\n      }\r\n    });\r\n\r\n    const stringsCurrentPrestCols = JSON.stringify(currentPresetColumns);\r\n    const stringColumns = JSON.stringify(columns);\r\n    const filters = this.filtersConfig.map((filter) => {\r\n      return {\r\n        filed: filter.field,\r\n        query: {\r\n          condition: filter?.query?.condition,\r\n          first_condition: filter?.query?.first_condition,\r\n          first_value: filter?.query?.first_value,\r\n          second_condition: filter?.query?.second_condition,\r\n          second_value: filter?.query?.second_value,\r\n        },\r\n        _ids: filter?._ids\r\n      }\r\n    })\r\n\r\n    const currentPresetFilters = currPreset?.filters?.map((filter: any) => {\r\n      return {\r\n        filed: filter.field,\r\n        query: filter.query,\r\n        _ids: filter?._ids\r\n      }\r\n    })\r\n\r\n\r\n    // console.log(\"filter congig: \", filters);\r\n    // console.log(\"current preset filters: \", currentPresetFilters);\r\n\r\n    // console.log('isEqual', stringsCurrentPrestCols == stringColumns);\r\n    // console.log('Current Temp Preset : ', currPreset)\r\n    // console.log('Current Temp Preset Cols columns: ', currentPresetColumns)\r\n    // console.log('Current columns: ', columns);\r\n\r\n    if (!currentPresetColumns) return true;\r\n    return (currentPresetColumns && (stringsCurrentPrestCols == stringColumns) && (JSON.stringify(filters) == JSON.stringify(currentPresetFilters)) && (this.fontFaimly == currPreset.config.fontFaimly)\r\n      && (this.bodyTextFontsSize == currPreset.config.bodyTextFontsSize) &&\r\n      (this.headerTextFontsSize == this.headerTextFontsSize)\r\n      && this.curretaTablePresetForUpdate.config.showVerticalBorder == this.showVerticalBorder\r\n      && this.curretaTablePresetForUpdate.config.fontFaimly == this.fontFaimly\r\n      && this.curretaTablePresetForUpdate.config.selectedTableLayout == this.selectedTableLayout\r\n      && this.curretaTablePresetForUpdate.config.bodyTextFontsSize == this.bodyTextFontsSize\r\n      && this.curretaTablePresetForUpdate.config.rowShadingEnabled == this.rowShadingEnabled);\r\n\r\n    // return false\r\n  }\r\n\r\n  onActionButtonClick(button: string) {\r\n    const text = button?.toLocaleLowerCase();\r\n    if (text == 'active data' || text == 'active' || text == 'data active' || text == 'unarchived data' || text == 'unarchive data') this.clearSelectionState(this.tableType);\r\n    const event = {\r\n      data: {\r\n        listingType: this.listingType,\r\n        obj: button\r\n      },\r\n      eventType: \"onActionButtonClick\",\r\n    };\r\n    this.genericEvent.emit(event);\r\n  }\r\n\r\n\r\n  setActiveTab(tab: string | null): void {\r\n    this.activeTab = tab;\r\n    const allTabs = JSON.parse(localStorage.getItem('activeTabs') || '{}');\r\n    allTabs[this.tableType] = tab;\r\n    localStorage.setItem('activeTabs', JSON.stringify(allTabs));\r\n    this.cdr.detectChanges();\r\n    const event = {\r\n      data: {\r\n        tableType: this.tableType,\r\n        obj: tab\r\n      },\r\n      eventType: 'onTabChange',\r\n    };\r\n\r\n    this.genericEvent.emit(event);\r\n  }\r\n\r\n  getBackgroundColor(row: any, isEven: boolean, section: 'left' | 'center' | 'right'): string | undefined {\r\n    if (this.hoveredRowId === (row._id || row.id)) {\r\n      return this.rowHoverColor;\r\n    }\r\n    if (this.isRowSelected(row)) {\r\n      return this.checkedRowBackgroundColor;\r\n    }\r\n    let baseColor: string | undefined;\r\n\r\n    if (this.rowShadingEnabled) {\r\n      baseColor = isEven ? this.evenRowsBackgroundColor : this.oddRowsBackgroundColor;\r\n    } else {\r\n      baseColor = this.evenRowsBackgroundColor;\r\n    }\r\n    if (!baseColor) {\r\n      if (section === 'left') {\r\n        baseColor = this.leftPinnedBackgroundColor;\r\n      } else if (section === 'right') {\r\n        baseColor = this.rightPinnedBackgroundColor;\r\n      } else {\r\n        baseColor = this.bodyBackgroundColor;\r\n      }\r\n    }\r\n    return baseColor;\r\n  }\r\n\r\n  hasHorizontalScrollbar(): boolean {\r\n    if (!this.centerPinnedHeader?.nativeElement) return false;\r\n    const el = this.centerPinnedHeader.nativeElement;\r\n    return el.scrollWidth > el.clientWidth;\r\n  }\r\n\r\n\r\n  getSafeComment(description: string): SafeHtml {\r\n    return this.cleanEditorContent(description);\r\n  }\r\n  cleanEditorContent(content: string): SafeHtml {\r\n    if (!content) {\r\n      return '';\r\n    }\r\n    // 1. Decode HTML entities\r\n    const textarea = document.createElement('textarea');\r\n    textarea.innerHTML = content;\r\n    let decoded = textarea.value;\r\n\r\n    decoded = decoded\r\n      .replace(/<\\/?(span|p|thead|tbody|tfoot)[^>]*>/g, '')\r\n      .replace(/&nbsp;/g, ' ');\r\n\r\n    // Ensure clean table structure\r\n    decoded = decoded\r\n      .replace(/<table[^>]*>/g, '<table>')\r\n      .replace(/<tr[^>]*>/g, '<tr>')\r\n      .replace(/<th[^>]*>/g, '<th>')\r\n      .replace(/<td[^>]*>/g, '<td>');  // Remove <thead> and <tbody> tags\r\n\r\n    // 4. Add inline styles\r\n    decoded = decoded\r\n      // Add inline styles to <table>\r\n      .replace(/<table([^>]*)>/g, `<table style=\"width: 100%; border-collapse: collapse; padding: 20px; font-size: 14px; background-color: #ffffff;\"$1>`)\r\n      // Add inline styles to <tr>\r\n      .replace(/<tr([^>]*)>/g, `<tr style=\"border-bottom: 1px solid #ccc;\"$1>`)\r\n      // Add inline styles to <th>\r\n      .replace(/<th([^>]*)>/g, `<th style=\"background-color: #f0f0f0; font-weight: 600; font-size: 16px; color: #2A1F73; border: 1px solid #ccc; padding: 12px 20px; text-align: left;\"$1>`)\r\n      // Add inline styles to <td>\r\n      .replace(/<td([^>]*)>/g, `<td style=\"min-width:120px; border: 1px solid #ccc; padding: 12px 20px; text-align: left;\"$1>`);\r\n    decoded = decoded.replace(/<img([^>]*)>/g, (match, group1) => {\r\n      // Add style to <img> if not already specified\r\n      if (/style=/.test(group1)) {\r\n        return match;  // If style already exists, keep it\r\n      } else {\r\n        return `<img style=\"width: 30%; height: 30%;border-radius: 16px; padding-top: 15px;padding-bottom: 10px;\"${group1}>`;\r\n      }\r\n    });\r\n    // 5. Return safe HTML\r\n    return this.sanitizer.bypassSecurityTrustHtml(decoded);\r\n  }\r\n\r\n  getExtention(url: string | string[] | null | undefined) {\r\n    if (url !== '-') {\r\n      if (typeof (url) == 'string') {\r\n        return url.split('.').pop()\r\n      } else if (Array.isArray(url)) {\r\n        return url[0].split('.').pop()\r\n      } else return '-'\r\n    }\r\n    else return '-'\r\n  }\r\n\r\n  downloadAttchment(url: any, file?: any) {\r\n    // this.onEvent.emit({\r\n    //   download: true,\r\n    // });\r\n    // this.genericEvent.emit(data)\r\n    // event.preventDefault();\r\n    const link = document.createElement('a');\r\n    link.href = url;\r\n    link.download = '';\r\n    document.body.appendChild(link);\r\n    link.click();\r\n    document.body.removeChild(link);\r\n\r\n  }\r\n  fullImageSrc: string | null = '';\r\n  openFullImage(event: Event) {\r\n    const target = event.target as HTMLElement;\r\n    if (target.tagName === 'IMG') {\r\n      this.fullImageSrc = target.getAttribute('src');\r\n    }\r\n  }\r\n\r\n  addStylesToImages(): void {\r\n    const images = document.querySelectorAll('.comment-content img');\r\n    images.forEach((img) => {\r\n      // Apply inline styles directly\r\n      this.renderer.setStyle(img, 'width', '70px');\r\n      this.renderer.setStyle(img, 'border-radius', '16px');\r\n      this.renderer.setStyle(img, 'margin', '8px');\r\n      this.renderer.setStyle(img, 'cursor', 'pointer');\r\n\r\n      // Add click listener to show fullscreen image on click\r\n      this.renderer.listen(img, 'click', () => this.onImageClick((img as HTMLImageElement).src));\r\n    });\r\n  }\r\n\r\n  onImageClick(src: string): void {\r\n    this.fullscreenImage = src;\r\n  }\r\n\r\n  @ViewChild('fullscreenImageTemplate') fullscreenImageTemplate!: TemplateRef<any>;\r\n  private fullscreenViewRef: EmbeddedViewRef<any> | null = null;\r\n\r\n  iconMap: Record<string, (row: any, col: any) => string> = {\r\n    attachments_count: () => this.singleSpaAssetsPath + 'data-grid/icons/attachments.svg',\r\n    comment_count: () => this.singleSpaAssetsPath + 'data-grid/icons/comments.svg',\r\n    priority: (row, col) => {\r\n      const val =\r\n        this.getNestedValue(row, col.field)?.value ||\r\n        this.getNestedValue(row, col.field)?.name ||\r\n        this.getNestedValue(row, col.field);\r\n\r\n      return (\r\n        this.singleSpaAssetsPath +\r\n        'data-grid/icons/' +\r\n        (val ?? 'default') +\r\n        '.svg'\r\n      );\r\n    },\r\n  };\r\n\r\n  toggleFullscreen() {\r\n    this.isFullScreen = !this.isFullScreen;\r\n    const elem = document.documentElement as any;\r\n    if (!document.fullscreenElement) {\r\n      if (elem.requestFullscreen) {\r\n        elem.requestFullscreen();\r\n      } else if (elem.mozRequestFullScreen) {\r\n        elem.mozRequestFullScreen();\r\n      } else if (elem.webkitRequestFullscreen) {\r\n        elem.webkitRequestFullscreen();\r\n      } else if (elem.msRequestFullscreen) {\r\n        elem.msRequestFullscreen();\r\n      }\r\n    } else {\r\n      if (document.exitFullscreen) {\r\n        document.exitFullscreen();\r\n      } else if ((document as any).mozCancelFullScreen) {\r\n        (document as any).mozCancelFullScreen();\r\n      } else if ((document as any).webkitExitFullscreen) {\r\n        (document as any).webkitExitFullscreen();\r\n      } else if ((document as any).msExitFullscreen) {\r\n        (document as any).msExitFullscreen();\r\n      }\r\n    }\r\n  }\r\n\r\n  onCellEvent(event: any) {\r\n    this.customCellEvent.emit(event);\r\n  }\r\n\r\n  private flattenGroup(row: any): any[] {\r\n    const result: any[] = [];\r\n    const traverse = (node: any) => {\r\n      if (!node) return;\r\n      if (node.isGroup) {\r\n        node.children?.forEach((child: any) => traverse(child));\r\n      } else {\r\n        result.push(node);\r\n      }\r\n    };\r\n    traverse(row);\r\n    return result;\r\n  }\r\n\r\n  selectGroupRow(e: Event, row: any) {\r\n    const checkbox = e.target as HTMLInputElement;\r\n    const isChecked = checkbox.checked;\r\n    // Get all deep data rows (leaf rows)\r\n    const leafRows = this.flattenGroup(row);\r\n    if (isChecked) {\r\n      leafRows.forEach(r => {\r\n        const id = r._id || r.id;\r\n        if (id) this.selectedRows.add(id);\r\n      });\r\n    } else {\r\n      leafRows.forEach(r => {\r\n        const id = r._id || r.id;\r\n        if (id) this.selectedRows.delete(id);\r\n      });\r\n    }\r\n    const ids = Array.from(this.selectedRows);\r\n    const event = {\r\n      data: {\r\n        listingType: this.listingType,\r\n        obj: ids\r\n      },\r\n      eventType: \"onSelectRow\",\r\n    }\r\n    this.genericEvent.emit(event);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  getGroupCheckedState(row: any): boolean | undefined {\r\n    if (!row.isGroup) return false;\r\n    const leafRows = this.flattenGroup(row);\r\n    let checkedCount = 0;\r\n    leafRows.forEach(r => {\r\n      const id = r._id || r.id;\r\n      if (this.selectedRows.has(id)) checkedCount++;\r\n    });\r\n    if (checkedCount === 0) return false;\r\n    if (checkedCount === leafRows.length) return true;\r\n    return undefined;\r\n  }\r\n\r\n  getCellTitle(row: any, col: any): string {\r\n    const val = this.getNestedValue(row, col.field);\r\n\r\n    if (!this.isNestedValueArray(row, col.field)) {\r\n      if (col.type === 'date') {\r\n        return this.commonSevice.formatDateValue(val, this.dateFormat);\r\n      } else if (col?.is_amount) {\r\n        if(!val) return `0.00`\r\n        return this.formatCurrency.transform(val, this.currencyFormat);\r\n      }\r\n\r\n      return (\r\n        val?.value ??\r\n        val?.name ??\r\n        val ??\r\n        (col.is_amount ? '0' : '-')\r\n      ) + '';\r\n    }\r\n\r\n    const first = val?.[0];\r\n\r\n    return (\r\n      first?.department_name ??\r\n      first?.roleName ??\r\n      first?.full_name ??\r\n      '-'\r\n    );\r\n  }\r\n\r\n\r\n  finishEdit(event: any) {\r\n    console.log('cell editeddddddddddddddd: ', event)\r\n  }\r\n\r\n\r\n\r\n}","<div class=\"position-relative h-100\">\r\n  <div\r\n    class=\"d-flex justify-content-between mb-2 align-items-center position-relative\"\r\n  >\r\n    <div class=\"d-flex gap-2\">\r\n      <div class=\"nav nav-tabs\" *ngIf=\"true\">\r\n        <div class=\"nav nav-tabs\" id=\"nav-tab\" role=\"tablist\">\r\n          <span\r\n            *ngFor=\"let tab of tabs; let i = index\"\r\n            (click)=\"setActiveTab(tab)\"\r\n            class=\"nav-link cursor-pointer\"\r\n            [class.active]=\"activeTab == tab\"\r\n          >\r\n            {{ tab }}\r\n          </span>\r\n        </div>\r\n      </div>\r\n      <div class=\"global-search\" [style.width.px]=\"350\">\r\n        <span\r\n          *ngIf=\"enableGlobalSearch\"\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/search.svg'\"\r\n          class=\"data-grid-svg-icon mx-2 position-absolute icon\"\r\n        ></span>\r\n        <input\r\n          *ngIf=\"enableGlobalSearch\"\r\n          style=\"height: 36px\"\r\n          class=\"form-control\"\r\n          placeholder=\"Type to search, then press Enter\"\r\n          [(ngModel)]=\"tableSearch\"\r\n          (keydown.enter)=\"onGlobalSearch()\"\r\n          (input)=\"onSearchInput($event)\"\r\n          type=\"search\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div class=\"d-flex gap-2 align-items-center table-right-top-actions\">\r\n      <ng-container *ngFor=\"let button of buttons\">\r\n        <div\r\n          class=\"d-flex align-items-center gap-2 action-buttons-row\"\r\n          *ngIf=\"button?.has_permission\"\r\n        >\r\n          <a\r\n            href=\"JavaScript:void(0)\"\r\n            (click)=\"onActionButtonClick(button.name)\"\r\n            class=\"button button-small btn border border-primary btn-active-primary me-2 p-0 d-flex align-items-center justify-content-center px-3\"\r\n          >\r\n            <span\r\n              *ngIf=\"button.is_showIcon\"\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath + 'data-grid/icons/' + button.icon + '.svg'\r\n              \"\r\n              class=\"svg-icon svg-icon-2\"\r\n            ></span>\r\n            <span\r\n              class=\"label-hidden text-white\"\r\n              [class.ms-0]=\"button.is_showIcon\"\r\n              >{{ button?.name }}</span\r\n            >\r\n          </a>\r\n        </div>\r\n      </ng-container>\r\n      <div\r\n        *ngIf=\"!showFilterRow\"\r\n        class=\"cursor-pointer position-relative action-buttons-row\"\r\n        (click)=\"toggleOpenFilter()\"\r\n        [class.active]=\"showFilters\"\r\n      >\r\n        <a\r\n          href=\"JavaScript:void(0)\"\r\n          class=\"button button-small btn btn-active-primary border border-primary me-2 p-0 d-flex align-items-center justify-content-center px-3\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\"\r\n            class=\"svg-icon svg-icon-2\"\r\n          ></span>\r\n          <span class=\"label-hidden text-white\">Filters</span>\r\n        </a>\r\n        <span\r\n          *ngIf=\"activeFilteredColumns?.length\"\r\n          style=\"\r\n            width: 7px;\r\n            height: 7px;\r\n            box-shadow: 0px 0px 3px #0022ff;\r\n            background-color: rgb(0, 60, 255);\r\n            position: absolute;\r\n            right: 16px;\r\n            top: 10px;\r\n          \"\r\n          class=\"rounded-circle d-block\"\r\n        ></span>\r\n      </div>\r\n      <div\r\n        class=\"cursor-pointer d-none\"\r\n        (click)=\"toggleActions('advance-filter')\"\r\n        [class.active]=\"activeTopButton === 'advance-filter'\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/zoom-charge.svg'\"\r\n          class=\"data-grid-svg-icon top-icon me-2\"\r\n        ></span>\r\n      </div>\r\n      <div\r\n        class=\"cursor-pointer action-buttons-row\"\r\n        (click)=\"toggleActions('setting')\"\r\n        [class.active]=\"\r\n          activeTopButton === 'setting' ||\r\n          activeTopButton === 'table-layout' ||\r\n          activeTopButton === 'table-presets' ||\r\n          activeTopButton === 'show-hide-columns'\r\n        \"\r\n      >\r\n        <!-- <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/settings-2.svg'\"\r\n          class=\"data-grid-svg-icon top-icon me-2\"\r\n        ></span> -->\r\n        <a\r\n          href=\"JavaScript:void(0)\"\r\n          class=\"button button-small btn btn-active-primary border border-primary me-2 p-0 d-flex align-items-center justify-content-center px-3\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/settings-2.svg'\"\r\n            class=\"svg-icon svg-icon-2\"\r\n          ></span>\r\n          <span class=\"label-hidden text-white\">Setting</span>\r\n        </a>\r\n\r\n        <div\r\n          *ngIf=\"activeTopButton === 'setting'\"\r\n          class=\"actions-dropdown mt-1 actions-dropdown-setting\"\r\n          style=\"position: absolute\"\r\n        >\r\n          <div class=\"dropdown-menu show shadow custom-menu\">\r\n            <!-- Table Layout -->\r\n            <a\r\n              class=\"dropdown-item d-flex justify-content-between align-items-center cursor-pointer\"\r\n              (click)=\"$event.stopPropagation(); toggleActions('table-layout')\"\r\n            >\r\n              <span\r\n                ><span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/table-2.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon me-2\"\r\n                ></span>\r\n                Table Layout</span\r\n              >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2\"\r\n              ></span>\r\n            </a>\r\n            <!-- Table Presets -->\r\n            <a\r\n              (click)=\"$event.stopPropagation(); toggleActions('table-presets')\"\r\n              class=\"dropdown-item d-flex justify-content-between align-items-center cursor-pointer\"\r\n            >\r\n              <span\r\n                ><span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/list-details.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon me-2\"\r\n                ></span>\r\n                Table Presets</span\r\n              >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2\"\r\n              ></span>\r\n            </a>\r\n\r\n            <!-- Columns -->\r\n            <a\r\n              *ngIf=\"!showSideMenu\"\r\n              (click)=\"\r\n                $event.stopPropagation(); toggleActions('show-hide-columns')\r\n              \"\r\n              class=\"dropdown-item d-flex justify-content-between align-items-center cursor-pointer\"\r\n            >\r\n              <span\r\n                ><span\r\n                  [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/eye.svg'\"\r\n                  class=\"data-grid-svg-icon me-2\"\r\n                ></span>\r\n                Columns</span\r\n              >\r\n              <div class=\"d-flex gap-2\">\r\n                <span class=\"muted-text\">{{ columnsCount }}</span>\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon me-2\"\r\n                ></span>\r\n              </div>\r\n            </a>\r\n\r\n            <div class=\"dropdown-divider\"></div>\r\n\r\n            <!-- Filter -->\r\n            <a\r\n              class=\"dropdown-item cursor-pointer\"\r\n              (click)=\"toggleOpenFilter(); activeTopButton = '';\"\r\n              *ngIf=\"!showFilterRow\"\r\n            >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2 mt-1 cursor-pointer\"\r\n              ></span>\r\n              Filter\r\n            </a>\r\n\r\n            <!-- Download -->\r\n            <a\r\n              class=\"dropdown-item cursor-pointer\"\r\n              (click)=\"downloadCsv('csv')\"\r\n            >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/download.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2 cursor-pointer\"\r\n              ></span>\r\n              CSV Export\r\n            </a>\r\n            <a\r\n              *ngIf=\"enableExport\"\r\n              class=\"dropdown-item cursor-pointer\"\r\n              (click)=\"downloadCsv('xlsx')\"\r\n            >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/download.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2 cursor-pointer\"\r\n              ></span>\r\n              Excel Export\r\n            </a>\r\n            <!-- Font Family & Font Size -->\r\n            <div class=\"px-2 pb-2 pt-2\">\r\n              <div class=\"d-flex gap-2\">\r\n                <!-- Font Family -->\r\n                <select\r\n                  class=\"form-select form-select-sm\"\r\n                  [(ngModel)]=\"fontFaimly\"\r\n                  (change)=\"onFontChange()\"\r\n                >\r\n                  <option *ngFor=\"let font of fontFamilies\" [value]=\"font\">\r\n                    {{ font }}\r\n                  </option>\r\n                </select>\r\n\r\n                <!-- Font Size -->\r\n                <select\r\n                  class=\"form-select form-select-sm\"\r\n                  (change)=\"onFontChange()\"\r\n                  [(ngModel)]=\"bodyTextFontsSize\"\r\n                >\r\n                  <option *ngFor=\"let size of fontSizes\" [value]=\"size\">\r\n                    {{ size }}\r\n                  </option>\r\n                </select>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Table Layout -->\r\n\r\n        <ng-container *ngIf=\"activeTopButton === 'table-layout'\">\r\n          <div\r\n            *ngTemplateOutlet=\"tableLayout\"\r\n            class=\"actions-dropdown mt-1\"\r\n            style=\"position: absolute\"\r\n          ></div>\r\n        </ng-container>\r\n\r\n        <!-- Table Presets -->\r\n        <ng-container *ngIf=\"activeTopButton === 'table-presets'\">\r\n          <div\r\n            *ngTemplateOutlet=\"tablePreset\"\r\n            class=\"actions-dropdown mt-1\"\r\n            style=\"position: absolute\"\r\n          ></div>\r\n        </ng-container>\r\n\r\n        <!-- Table Presets -->\r\n        <ng-container *ngIf=\"activeTopButton === 'show-hide-columns'\">\r\n          <div\r\n            *ngTemplateOutlet=\"showHideColumns\"\r\n            class=\"actions-dropdown mt-1\"\r\n            style=\"position: absolute\"\r\n          ></div>\r\n        </ng-container>\r\n      </div>\r\n\r\n      <div class=\"action-buttons-row\" *ngIf=\"showFullScreenButton\">\r\n        <a\r\n          *ngIf=\"!isFullScreen\"\r\n          class=\"button button-small btn btn-active-primary border border-primary expend d-flex justify-content-center align-items-center\"\r\n          (click)=\"toggleFullscreen()\"\r\n          data-bs-toggle=\"tooltip\"\r\n          data-bs-placement=\"top\"\r\n          title=\"Minimise\"\r\n          [ngClass]=\"{ minArrow: !isFullScreen, maxArrow: isFullScreen }\"\r\n          style=\"transition: color 0.2s\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/expend.svg'\"\r\n            class=\"svg-icon svg-icon-2 mb-1\"\r\n          ></span>\r\n        </a>\r\n        <a\r\n          *ngIf=\"isFullScreen\"\r\n          class=\"button button-small btn btn-active-primary border border-primary expend d-flex justify-content-center align-items-center\"\r\n          (click)=\"toggleFullscreen()\"\r\n          data-bs-toggle=\"tooltip\"\r\n          data-bs-placement=\"top\"\r\n          title=\"Maximise\"\r\n          [ngClass]=\"{ minArrow: !isFullScreen, maxArrow: isFullScreen }\"\r\n          style=\"transition: color 0.2s\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/minimize.svg'\"\r\n            class=\"svg-icon svg-icon-2 mb-1\"\r\n          ></span>\r\n        </a>\r\n      </div>\r\n      <div>\r\n        <!-- Example single danger button -->\r\n\r\n        <!-- <button\r\n          type=\"button\"\r\n          class=\"btn btn-primary btn-sm d-flex gap-2 action-button\"\r\n          (click)=\"toggleActions('actions')\"\r\n        >\r\n          Action\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/Vector.svg'\"\r\n            class=\"data-grid-svg-icon\"\r\n          ></span>\r\n        </button>\r\n        <div\r\n          *ngIf=\"activeTopButton === 'actions'\"\r\n          class=\"actions-dropdown mt-1\"\r\n        >\r\n          <div class=\"dropdown-menu show\">\r\n            <a class=\"dropdown-item\" href=\"#\">Action</a>\r\n            <a class=\"dropdown-item\" href=\"#\">Another action</a>\r\n            <a class=\"dropdown-item\" href=\"#\">Something else here</a>\r\n            <div class=\"dropdown-divider\"></div>\r\n            <a class=\"dropdown-item\" href=\"#\">Separated link</a>\r\n          </div>\r\n        </div> -->\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div\r\n    *ngIf=\"showFilters && !showFilterRow\"\r\n    class=\"top-filter-row border-top py-2 d-flex justify-content-between align-items-center\"\r\n    [style.height.px]=\"topFilterRowHeight\"\r\n  >\r\n    <!-- LEFT SIDE (Filter tags + Filter button) -->\r\n    <div class=\"d-flex gap-2 align-items-center\">\r\n      <ng-container>\r\n        <div\r\n          *ngFor=\"let col of activeFilteredColumns; trackBy: trackByField\"\r\n          class=\"filter-tags\"\r\n        >\r\n          <div\r\n            (click)=\"\r\n              isActiveFilterOpen = true;\r\n              activeTopButton = 'filter-columns';\r\n              openFilter(col)\r\n            \"\r\n            class=\"d-flex justify-content-center align-items-center muted-text add-filter-button active-filters\"\r\n            style=\"white-space: nowrap\"\r\n            [class.active]=\"\r\n              col?.field == selectedColumnForFilter?.field &&\r\n              isActiveFilterOpen &&\r\n              activeTopButton == 'filter-columns'\r\n            \"\r\n          >\r\n            <span class=\"header-tag mt-0 d-flex align-items-center\">\r\n              <span\r\n                *ngIf=\"col?.pinned\"\r\n                [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/pin.svg'\"\r\n                class=\"data-grid-svg-icon me-2\"\r\n              ></span>\r\n              {{ col.header }}\r\n              <span\r\n                (click)=\"\r\n                  $event.stopPropagation(); removeColumnFilterFromColumn(col)\r\n                \"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/cross-primary.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon cross-secondary ms-2 mb-1\"\r\n              ></span>\r\n            </span>\r\n          </div>\r\n\r\n          <ng-container\r\n            *ngIf=\"\r\n              activeTopButton === 'filter-columns' &&\r\n              col?.field == selectedColumnForFilter?.field &&\r\n              isActiveFilterOpen\r\n            \"\r\n          >\r\n            <div\r\n              *ngTemplateOutlet=\"filterColumns; context: { column: col }\"\r\n              class=\"actions-dropdown mt-1\"\r\n            ></div>\r\n          </ng-container>\r\n        </div>\r\n      </ng-container>\r\n\r\n      <!-- Filter Button -->\r\n      <div class=\"add-filter-button-menu\">\r\n        <div\r\n          (click)=\"toggleActions('filter-columns'); isActiveFilterOpen = false\"\r\n          class=\"d-flex justify-content-center align-items-center muted-text add-filter-button button-filter\"\r\n          style=\"width: 70px\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/plus.svg'\"\r\n            class=\"me-2 data-grid-svg-icon\"\r\n          ></span>\r\n          Filter\r\n        </div>\r\n\r\n        <ng-container\r\n          *ngIf=\"activeTopButton === 'filter-columns' && !isActiveFilterOpen\"\r\n        >\r\n          <div\r\n            *ngTemplateOutlet=\"filterColumns\"\r\n            class=\"actions-dropdown mt-1\"\r\n          ></div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- RIGHT SIDE (Update + Reset) -->\r\n    <div class=\"d-flex gap-3 align-items-center\">\r\n      <div\r\n        (click)=\"savePreset()\"\r\n        class=\"text-primary cursor-pointer all-filters-reset-button\"\r\n        *ngIf=\"!checkFilterChangesEffect()\"\r\n      >\r\n        Update View\r\n      </div>\r\n\r\n      <div\r\n        class=\"text-primary cursor-pointer all-filters-reset-button\"\r\n        *ngIf=\"!tableFilterViewId && activeFilteredColumns?.length\"\r\n        (click)=\"clearAllFilters()\"\r\n      >\r\n        Reset\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div\r\n    [style.height]=\"\r\n      showFilters ? 'calc(100% - ' + topFilterRowHeight + 'px)' : '100%'\r\n    \"\r\n    cdkDropListGroup\r\n    class=\"data-grid-table-wrapper overflow-hidden\"\r\n    #dataGridContainer\r\n    [style.fontFamily]=\"fontFaimly\"\r\n    [style.backgroundColor]=\"bodyBackgroundColor\"\r\n    id=\"data-grid-main-container\"\r\n  >\r\n    <div\r\n      *ngIf=\"showRowsGrouping\"\r\n      [style.height.px]=\"headerRowHeight\"\r\n      [cdkDropListData]=\"columns\"\r\n      [style.backgroundColor]=\"\r\n        topGroupedBadgesBackgroundColor || headerBackgroundColor\r\n      \"\r\n      cdkDropList\r\n      (cdkDropListEntered)=\"enterToTopRowGrouping($event)\"\r\n      (cdkDropListExited)=\"exitedFromTheTopRow($event)\"\r\n      (cdkDropListDropped)=\"onDropTopGroup($event)\"\r\n      [cdkDropListEnterPredicate]=\"canEnterToRowsGrouping\"\r\n      id=\"rows-grouping-top-container\"\r\n      class=\"border-below d-flex px-4 align-items-center\"\r\n    >\r\n      <div\r\n        class=\"d-flex gap-2 align-items-center\"\r\n        [style.color]=\"headerTextColor\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/justify.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span>\r\n        <div *ngIf=\"!draggingInGroupArea && !groupedColumns?.length\">\r\n          Drag here to set row groups\r\n        </div>\r\n        <div\r\n          cdkDropListOrientation=\"horizontal\"\r\n          cdkDropList\r\n          (cdkDropListDropped)=\"onGroupReorder($event)\"\r\n          class=\"d-flex\"\r\n        >\r\n          <div\r\n            cdkDrag\r\n            [cdkDragLockAxis]=\"'x'\"\r\n            *ngFor=\"\r\n              let child of groupedColumns;\r\n              let i = index;\r\n              trackBy: trackByField\r\n            \"\r\n            class=\"d-flex align-items-center\"\r\n          >\r\n            <ng-container\r\n              *ngTemplateOutlet=\"\r\n                topGroupingRowPlaceholder;\r\n                context: {\r\n                  $implicit: child,\r\n                  showChevron:\r\n                    groupedColumns.length > 1 && i != groupedColumns.length - 1\r\n                }\r\n              \"\r\n            ></ng-container>\r\n            <ng-template cdkDragPreview\r\n              ><div class=\"p-2 border d-flex gap-2\">\r\n                <div>\r\n                  <span\r\n                    *ngIf=\"!draggingInGroupArea\"\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/arrows-move.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n                <div>{{ child.header }}</div>\r\n              </div>\r\n            </ng-template>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div\r\n      class=\"d-flex overflow-hidden\"\r\n      [style.height]=\"\r\n        'calc(100% - ' +\r\n        (showRowsGrouping\r\n          ? headerRowHeight + footerRowHeight\r\n          : footerRowHeight) +\r\n        'px)'\r\n      \"\r\n    >\r\n      <div\r\n        class=\"h-100\"\r\n        [style.width]=\"\r\n          !showSideMenu\r\n            ? '100%'\r\n            : sideMenuVisible\r\n            ? 'calc(100% - 280px)'\r\n            : 'calc(100% - 30px)'\r\n        \"\r\n      >\r\n        <div class=\"h-100 transition position-relative w-100\">\r\n          <!-- ##################################################################################################################################################################################### -->\r\n          <!-- ##################################################################################################################################################################################### -->\r\n          <!-- Data Grid Header starts here -->\r\n          <!-- ##################################################################################################################################################################################### -->\r\n          <!-- ##################################################################################################################################################################################### -->\r\n\r\n          <div\r\n            class=\"data-grid-header-wrapper w-100\"\r\n            [style.color]=\"headerTextColor\"\r\n            [style.fontSize.px]=\"headerTextFontsSize\"\r\n            [style.backgroundColor]=\"headerBackgroundColor\"\r\n            [class.border-below]=\"!hasAnyVisibleColumn\"\r\n            [style.height.px]=\"\r\n              showColumnsGrouping && showFilterRow\r\n                ? headerRowHeight * 3\r\n                : showColumnsGrouping || showFilterRow\r\n                ? headerRowHeight * 2\r\n                : headerRowHeight\r\n            \"\r\n          >\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- Data Grid Left Pinned Header starts here -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <div\r\n              class=\"data-grid-header left-pinned\"\r\n              #leftPinnedHeader\r\n              [class.border-right]=\"hasLeftPinnedColumns\"\r\n            >\r\n              <div\r\n                *ngIf=\"showSerialNumber\"\r\n                [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n                class=\"select-all-checkbox-cell border-below\"\r\n                [style.width.px]=\"55\"\r\n                [style.height.px]=\"\r\n                  showColumnsGrouping && showFilterRow\r\n                    ? headerRowHeight * 3\r\n                    : showColumnsGrouping || showFilterRow\r\n                    ? headerRowHeight * 2\r\n                    : headerRowHeight\r\n                \"\r\n              >\r\n                S.No\r\n              </div>\r\n              <div\r\n               *ngIf=\"showCheckboxes\"\r\n                [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n                class=\"select-all-checkbox-cell border-below\"\r\n                [style.height.px]=\"\r\n                  showColumnsGrouping && showFilterRow\r\n                    ? headerRowHeight * 3\r\n                    : showColumnsGrouping || showFilterRow\r\n                    ? headerRowHeight * 2\r\n                    : headerRowHeight\r\n                \"\r\n              >\r\n                <input\r\n                  *ngIf=\"hasAnyVisibleColumn\"\r\n                  style=\"width: 16px; height: 16px\"\r\n                  type=\"checkbox\"\r\n                  [indeterminate]=\"isIndeterminateState(dataSet)\"\r\n                  [checked]=\"isAllSelected(dataSet)\"\r\n                  (change)=\"toggleSelectAll(dataSet)\"\r\n                />\r\n              </div>\r\n              <div\r\n                [style.backgroundColor]=\"headerBackgroundColor\"\r\n                class=\"d-flex\"\r\n                cdkDropList\r\n                id=\"left-pinned-header\"\r\n                cdkDropListOrientation=\"horizontal\"\r\n                [cdkDropListData]=\"leftPinnedColumns\"\r\n                (cdkDropListEntered)=\"onDropListEnter($event, 'left')\"\r\n                (cdkDropListSorted)=\"\r\n                  onSortGroup($event, 'previewLeftPinnedColumns')\r\n                \"\r\n                (cdkDropListDropped)=\"onDropGroup()\"\r\n                style=\"min-width: 1px\"\r\n              >\r\n                <div\r\n                  class=\"dragable-header\"\r\n                  cdkDrag\r\n                  [cdkDragData]=\"col\"\r\n                  *ngFor=\"\r\n                    let col of leftPinnedColumns;\r\n                    let i = index;\r\n                    trackBy: trackByField\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      headerCell;\r\n                      context: {\r\n                        $implicit: col,\r\n                        index: i,\r\n                        section: 'previewLeftPinnedColumns'\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                  <ng-template cdkDragPreview\r\n                    ><div class=\"p-2 border d-flex gap-2\">\r\n                      <div>\r\n                        <span\r\n                          *ngIf=\"!draggingInGroupArea\"\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath +\r\n                            'data-grid/icons/arrows-move.svg'\r\n                          \"\r\n                          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                        ></span>\r\n                      </div>\r\n                      <div>{{ col.header }}</div>\r\n                    </div>\r\n                  </ng-template>\r\n                  <ng-template cdkDragPlaceholder>\r\n                    <div *ngIf=\"!draggingInGroupArea\">\r\n                      <div\r\n                        *ngTemplateOutlet=\"\r\n                          headerCell;\r\n                          context: {\r\n                            $implicit: col,\r\n                            index: i,\r\n                            section: ''\r\n                          }\r\n                        \"\r\n                      ></div>\r\n                    </div>\r\n                    <div\r\n                      *ngIf=\"draggingInGroupArea\"\r\n                      class=\"d-flex gap-2 ms-2\"\r\n                      style=\"opacity: 0.6\"\r\n                    >\r\n                      <ng-container\r\n                        *ngIf=\"col?.children?.length; else singleCol\"\r\n                      >\r\n                        <ng-container\r\n                          *ngFor=\"\r\n                            let child of col.children;\r\n                            let i = index;\r\n                            trackBy: trackByField\r\n                          \"\r\n                        >\r\n                          <ng-container\r\n                            *ngTemplateOutlet=\"\r\n                              topGroupingRowPlaceholder;\r\n                              context: {\r\n                                $implicit: child,\r\n                                showChevron:\r\n                                  col.children.length > 1 &&\r\n                                  i != col.children.length - 1\r\n                              }\r\n                            \"\r\n                          ></ng-container>\r\n                        </ng-container>\r\n                      </ng-container>\r\n\r\n                      <ng-template #singleCol>\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"\r\n                            topGroupingRowPlaceholder;\r\n                            context: {\r\n                              $implicit: col,\r\n                              showChevron: col?.children?.length > 1\r\n                            }\r\n                          \"\r\n                        ></ng-container>\r\n                      </ng-template>\r\n                    </div>\r\n                  </ng-template>\r\n                </div>\r\n              </div>\r\n            </div>\r\n\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- Data Grid Center Pinned Header starts here -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <div\r\n              class=\"data-grid-header center-scrollable\"\r\n              #centerPinnedHeader\r\n              (scroll)=\"onCenterBodyScroll($event)\"\r\n              id=\"center-pinned-header\"\r\n              cdkDropList\r\n              [cdkDropListConnectedTo]=\"\r\n                showRowsGrouping ? ['rows-grouping-top-container'] : []\r\n              \"\r\n              [cdkDropListData]=\"centerColumns\"\r\n              cdkDropListOrientation=\"horizontal\"\r\n              [cdkDropListSortingDisabled]=\"\r\n                isDisableColumnGrouping && draggingInGroupArea\r\n              \"\r\n              (cdkDropListEntered)=\"onDropListEnter($event, 'center')\"\r\n              (cdkDropListSorted)=\"onSortGroup($event, 'previewCenterColumns')\"\r\n              (cdkDropListDropped)=\"onDropGroup()\"\r\n              [style.maxWidth]=\"\r\n                'calc(100% - ' +\r\n                (rightPinnedHeader.offsetWidth + leftPinnedHeader.offsetWidth) +\r\n                'px)'\r\n              \"\r\n            >\r\n              <div\r\n                *ngIf=\"groupedColumns?.length\"\r\n                style=\"min-width: 200px\"\r\n                class=\"h-100 align-items-center\"\r\n                #columnsGroupedBox\r\n                id=\"groupBoxHeaderDiv\"\r\n              >\r\n                <div\r\n                  class=\"d-flex w-100 justify-content-between align-items-center border-below\"\r\n                  [style.height.px]=\"\r\n                    showFilterRow ? headerRowHeight * 2 : headerRowHeight\r\n                  \"\r\n                >\r\n                  <div class=\"ps-3\">Group</div>\r\n                  <div class=\"d-flex\">\r\n                    <div\r\n                      class=\"three-dots cursor-pointer\"\r\n                      (click)=\"\r\n                        openThreeDotsMenu($event, 'group');\r\n                        isThreeDotsFilterOpen = false\r\n                      \"\r\n                    >\r\n                      <span\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath +\r\n                          'data-grid/icons/three-dots-vertical.svg'\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      ></span>\r\n                    </div>\r\n                    <div\r\n                      (mousedown)=\"\r\n                        $event.stopPropagation(); onResizeGroupBox($event)\r\n                      \"\r\n                      class=\"resize-handle\"\r\n                      style=\"margin-right: -2px\"\r\n                    >\r\n                      <span\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath +\r\n                          'data-grid/icons/resize-handle.svg'\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      ></span>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n\r\n                <div\r\n                  [style.height.px]=\"headerRowHeight\"\r\n                  class=\"border-below\"\r\n                ></div>\r\n              </div>\r\n              <span\r\n                class=\"d-flex align-items-center justify-content-center cursor-pointer border-below\"\r\n                style=\"min-width: 30px; height: 100%\"\r\n                *ngIf=\"gridType === 'Assets' || gridType === 'Tasks'\"\r\n              >\r\n              </span>\r\n              <div\r\n                class=\"dragable-header\"\r\n                (cdkDragStarted)=\"\r\n                  checkColumnGroupingStatus(col);\r\n                  dragStartOnGroup(col);\r\n                  onDragStarted(col)\r\n                \"\r\n                (cdkDragMoved)=\"onDragMoved($event)\"\r\n                (cdkDragEnded)=\"onDragEnded()\"\r\n                cdkDrag\r\n                [cdkDragData]=\"col\"\r\n                *ngFor=\"\r\n                  let col of centerColumns;\r\n                  let i = index;\r\n                  trackBy: trackById\r\n                \"\r\n              >\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    headerCell;\r\n                    context: {\r\n                      $implicit: col,\r\n                      index: i,\r\n                      section: 'previewCenterColumns'\r\n                    }\r\n                  \"\r\n                >\r\n                </ng-container>\r\n                <ng-template cdkDragPreview\r\n                  ><div class=\"p-2 border d-flex gap-2\">\r\n                    <div>\r\n                      <span\r\n                        *ngIf=\"!isOutsideContainer\"\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath +\r\n                          (draggingInGroupArea\r\n                            ? 'data-grid/icons/justify.svg'\r\n                            : 'data-grid/icons/arrows-move.svg')\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      >\r\n                      </span>\r\n                      <span\r\n                        *ngIf=\"isOutsideContainer\"\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath + 'data-grid/icons/eye-cross.svg'\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      >\r\n                      </span>\r\n                    </div>\r\n                    <div>{{ col.header }}</div>\r\n                  </div>\r\n                </ng-template>\r\n                <ng-template cdkDragPlaceholder>\r\n                  <div *ngIf=\"!draggingInGroupArea\">\r\n                    <div\r\n                      *ngTemplateOutlet=\"\r\n                        headerCell;\r\n                        context: {\r\n                          $implicit: col,\r\n                          index: i,\r\n                          section: 'centerColumns'\r\n                        }\r\n                      \"\r\n                    ></div>\r\n                  </div>\r\n                  <div\r\n                    *ngIf=\"draggingInGroupArea && !isOutsideContainer\"\r\n                    class=\"d-flex gap-2 ms-2\"\r\n                    style=\"opacity: 0.6\"\r\n                  >\r\n                    <ng-container *ngIf=\"col?.children?.length; else singleCol\">\r\n                      <ng-container\r\n                        *ngFor=\"\r\n                          let child of col.children;\r\n                          let i = index;\r\n                          trackBy: trackById\r\n                        \"\r\n                      >\r\n                        <ng-container *ngIf=\"child?.is_groupable\">\r\n                          <ng-container\r\n                            *ngTemplateOutlet=\"\r\n                              topGroupingRowPlaceholder;\r\n                              context: {\r\n                                $implicit: child,\r\n                                showChevron:\r\n                                  col.children.length > 1 &&\r\n                                  i != col.children.length - 1\r\n                              }\r\n                            \"\r\n                          ></ng-container>\r\n                        </ng-container>\r\n                      </ng-container>\r\n                    </ng-container>\r\n\r\n                    <ng-template #singleCol>\r\n                      <ng-container *ngIf=\"col?.is_groupable\">\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"\r\n                            topGroupingRowPlaceholder;\r\n                            context: {\r\n                              $implicit: col,\r\n                              showChevron: col?.children?.length > 1\r\n                            }\r\n                          \"\r\n                        ></ng-container>\r\n                      </ng-container>\r\n                    </ng-template>\r\n                  </div>\r\n                </ng-template>\r\n              </div>\r\n            </div>\r\n\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- Data Grid Right Pinned Header starts here -->\r\n            <!-- ********************************************************************************* -->\r\n            <!-- ********************************************************************************* -->\r\n            <div\r\n              [style.backgroundColor]=\"headerBackgroundColor\"\r\n              cdkDropList\r\n              id=\"right-pinned-header\"\r\n              [cdkDropListConnectedTo]=\"\r\n                showRowsGrouping ? ['rows-grouping-top-container'] : []\r\n              \"\r\n              cdkDropListOrientation=\"horizontal\"\r\n              class=\"data-grid-header right-pinned\"\r\n              (cdkDropListSorted)=\"\r\n                onSortGroup($event, 'previewRightPinnedColumns')\r\n              \"\r\n              (cdkDropListEntered)=\"onDropListEnter($event, 'right')\"\r\n              (cdkDropListDropped)=\"onDropGroup()\"\r\n              #rightPinnedHeader\r\n              class=\"right-pinned-header d-flex\"\r\n              style=\"min-width: 0.2px\"\r\n            >\r\n              <div\r\n                class=\"dragable-header\"\r\n                cdkDrag\r\n                [cdkDragData]=\"col\"\r\n                *ngFor=\"\r\n                  let col of rightPinnedColumns;\r\n                  let i = index;\r\n                  trackBy: trackById\r\n                \"\r\n              >\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    headerCell;\r\n                    context: {\r\n                      $implicit: col,\r\n                      pinnedRight: true,\r\n                      index: i,\r\n                      section: 'right'\r\n                    }\r\n                  \"\r\n                ></ng-container>\r\n                <ng-template cdkDragPreview\r\n                  ><div class=\"p-2 border d-flex gap-2\">\r\n                    <div>\r\n                      <span\r\n                        *ngIf=\"!draggingInGroupArea\"\r\n                        [inlineSVG]=\"\r\n                          singleSpaAssetsPath +\r\n                          'data-grid/icons/arrows-move.svg'\r\n                        \"\r\n                        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                      ></span>\r\n                    </div>\r\n                    <div>{{ col.header }}</div>\r\n                  </div>\r\n                </ng-template>\r\n                <ng-template cdkDragPlaceholder>\r\n                  <div *ngIf=\"!draggingInGroupArea\">\r\n                    <div\r\n                      *ngTemplateOutlet=\"\r\n                        headerCell;\r\n                        context: {\r\n                          $implicit: col,\r\n                          index: i,\r\n                          section: 'right'\r\n                        }\r\n                      \"\r\n                    ></div>\r\n                  </div>\r\n                  <div\r\n                    *ngIf=\"draggingInGroupArea\"\r\n                    class=\"d-flex gap-2 ms-2\"\r\n                    style=\"opacity: 0.6\"\r\n                  >\r\n                    <ng-container *ngIf=\"col?.children?.length; else singleCol\">\r\n                      <ng-container\r\n                        *ngFor=\"\r\n                          let child of col.children;\r\n                          let i = index;\r\n                          trackBy: trackById\r\n                        \"\r\n                      >\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"\r\n                            topGroupingRowPlaceholder;\r\n                            context: {\r\n                              $implicit: child,\r\n                              showChevron:\r\n                                col.children.length > 1 &&\r\n                                i != col.children.length - 1\r\n                            }\r\n                          \"\r\n                        ></ng-container>\r\n                      </ng-container>\r\n                    </ng-container>\r\n\r\n                    <ng-template #singleCol>\r\n                      <ng-container\r\n                        *ngTemplateOutlet=\"\r\n                          topGroupingRowPlaceholder;\r\n                          context: {\r\n                            $implicit: col,\r\n                            showChevron: col?.children?.length > 1\r\n                          }\r\n                        \"\r\n                      ></ng-container>\r\n                    </ng-template>\r\n                  </div>\r\n                </ng-template>\r\n              </div>\r\n            </div>\r\n          </div>\r\n\r\n          <!--########################################################################################################################################################################################################################### -->\r\n          <!--########################################################################################################################################################################################################################### -->\r\n          <!-- Data Grid Body starts here -->\r\n          <!--########################################################################################################################################################################################################################### -->\r\n          <!--########################################################################################################################################################################################################################### -->\r\n          <div\r\n            class=\"h-100 d-flex justify-content-center align-items-center\"\r\n            *ngIf=\"!dataSet?.length && !loading && !dataSetLoading\"\r\n          >\r\n            <!-- <div\r\n            [inlineSVG]=\"\r\n              singleSpaAssetsPath + 'data-grid/icons/record-not-found.svg'\r\n            \"\r\n            class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n          ></div> -->\r\n            <div>No Record Found</div>\r\n          </div>\r\n\r\n          <div\r\n            class=\"position-absolute w-100 h-100 d-flex justify-content-center align-items-center loading-overlay\"\r\n            *ngIf=\"loading || dataSetLoading\"\r\n            style=\"\r\n              z-index: 999;\r\n              backdrop-filter: blur(1px);\r\n            \"\r\n            [style.backgroundColor]=\"bodyBackgroundColor\"\r\n          >\r\n            <div class=\"spinner-border text-primary\" role=\"status\">\r\n              <!-- <span class=\"loader\"></span> -->\r\n              <!-- <span class=\"visually-hidden\">Loading...</span> -->\r\n              <!-- </div> -->\r\n            </div>\r\n          </div>\r\n\r\n          <div\r\n            class=\"data-grid-body-wrapper position-relative d-flex\"\r\n            [style.height]=\"bodyWrapperHeight\"\r\n            style=\"overflow-y: auto; overflow-x: hidden\"\r\n            #mainScroll\r\n            (scroll)=\"onMainScroll($event)\"\r\n            [style.scrollbarWidth]=\"verticalScrollbarWidth\"\r\n          >\r\n            <!-- LEFT PINNED -->\r\n            <div\r\n              [style.height.px]=\"\r\n                !groupedColumns.length ? originalDataSet.length * rowHeight : 0\r\n              \"\r\n            ></div>\r\n            <div [class.h-100]=\"originalDataSet.length < 8\">\r\n              <div\r\n                class=\"data-grid-body left-pinned-body w-100\"\r\n                style=\"overflow-y: hidden\"\r\n                [class.border-right]=\"hasLeftPinnedColumns\"\r\n                [class.transparent-border-right]=\"!hasLeftPinnedColumns\"\r\n                [style.transform]=\"'translateY(' + translateY + 'px)'\"\r\n                [style.backgroundColor]=\"leftPinnedBackgroundColor\"\r\n                [class.h-100]=\"originalDataSet.length < 8\"\r\n               *ngIf=\"!loading && !dataSetLoading\"\r\n                [@rowDynamic]=\"rowAnimation\"\r\n\r\n                \r\n              >\r\n                <ng-container\r\n                  *ngFor=\"\r\n                    let row of visibleRows;\r\n                    let i = index;\r\n                    trackBy: trackById\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: row,\r\n                        columns: previewLeftPinnedColumns,\r\n                        isEven: (startIndex + i) % 2 === 0,\r\n                        isOdd: (startIndex + i) % 2 !== 0,\r\n                        isLeft: true,\r\n                        section: 'left',\r\n                        isTotalRow: false\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n                <ng-container *ngIf=\"showTotalAmountRow && originalDataSet?.length\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: { __virtualIndex: 0 },\r\n                        columns: previewLeftPinnedColumns,\r\n                        isEven: false,\r\n                        isOdd: false,\r\n                        section: 'left',\r\n                        isTotalRow: true\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n\r\n            <!-- CENTER -->\r\n            <div\r\n              class=\"h-100\"\r\n              [style.width.px]=\"centerPinnedHeader.clientWidth\"\r\n              [style.backgroundColor]=\"bodyBackgroundColor\"\r\n            >\r\n              <div\r\n                class=\"data-grid-body center-scrollable\"\r\n                [class.h-100]=\"originalDataSet.length < 8\"\r\n                style=\"overflow-y: hidden; overflow-x: auto\"\r\n                [style.transform]=\"'translateY(' + translateY + 'px)'\"\r\n                [style.backgroundColor]=\"bodyBackgroundColor\"\r\n                #centerScrollableBody\r\n                (scroll)=\"onCenterBodyScroll($event)\"\r\n                [style.boxShadow]=\"leftPinnedBoxshadow\"\r\n              >\r\n              <div [@rowDynamic]=\"rowAnimation\" *ngIf=\"!loading && !dataSetLoading\">\r\n                <ng-container\r\n                  *ngFor=\"\r\n                    let row of visibleRows;\r\n                    let i = index;\r\n                    trackBy: trackById\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: row,\r\n                        columns: previewCenterColumns,\r\n                        isEven: (startIndex + i) % 2 === 0,\r\n                        isOdd: (startIndex + i) % 2 !== 0,\r\n                        section: 'center',\r\n                        isTotalRow: false\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n                </div>\r\n                <ng-container *ngIf=\"showTotalAmountRow && originalDataSet?.length\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: { __virtualIndex: 0 },\r\n                        columns: previewCenterColumns,\r\n                        isEven: false,\r\n                        isOdd: false,\r\n                        section: 'center',\r\n                        isTotalRow: true\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n\r\n            <!-- RIGHT PINNED -->\r\n            <div\r\n              class=\"right-pinned-body-wrapper\"\r\n              *ngIf=\"hasRightPinnedColumns\"\r\n              [class.h-100]=\"originalDataSet.length < 8\"\r\n              [style.maxWidth.px]=\"\r\n                isScrollbarVisible\r\n                  ? rightPinnedHeader.offsetWidth - 15\r\n                  : rightPinnedHeader.offsetWidth\r\n              \"\r\n              [style.backgroundColor]=\"rightPinnedBackgroundColor\"\r\n            >\r\n              <div\r\n                class=\"data-grid-body right-pinned-body w-100 h-100\"\r\n                style=\"overflow-y: hidden\"\r\n                [style.transform]=\"'translateY(' + translateY + 'px)'\"\r\n                [style.boxShadow]=\"rightPinnedBoxshadow\"\r\n                [style.backgroundColor]=\"rightPinnedBackgroundColor\"\r\n                *ngIf=\"!loading && !dataSetLoading\"\r\n                [@rowDynamic]=\"rowAnimation\"\r\n              >\r\n                <ng-container\r\n                  *ngFor=\"\r\n                    let row of visibleRows;\r\n                    let i = index;\r\n                    trackBy: trackById\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: row,\r\n                        columns: previewRightPinnedColumns,\r\n                        isEven: (startIndex + i) % 2 === 0,\r\n                        isOdd: (startIndex + i) % 2 !== 0,\r\n                        section: 'right',\r\n                        isTotalRow: false\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n                <ng-container *ngIf=\"showTotalAmountRow && originalDataSet?.length\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      rowCell;\r\n                      context: {\r\n                        $implicit: { __virtualIndex: 0 },\r\n                        columns: previewRightPinnedColumns,\r\n                        isEven: false,\r\n                        isOdd: false,\r\n                        section: 'right',\r\n                        isTotalRow: true\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n\r\n            <div\r\n              style=\"top: auto; left: auto\"\r\n              (click)=\"\r\n                $event.stopPropagation();\r\n                fullscreenImage = null;\r\n                cdr.detectChanges()\r\n              \"\r\n              [style.width.px]=\"dataGridContainer.offsetWidth\"\r\n              [style.height.px]=\"\r\n                dataGridContainer.offsetHeight - (footerRowHeight + 100)\r\n              \"\r\n              class=\"image-modal full-image-modal\"\r\n              *ngIf=\"fullscreenImage\"\r\n            >\r\n              <img\r\n                (click)=\"$event.stopPropagation()\"\r\n                [src]=\"fullscreenImage\"\r\n                alt=\"Fullscreen Image\"\r\n              />\r\n            </div>\r\n            <div\r\n              *ngIf=\"selectedRows.size > 0 && showTaskbar\"\r\n              class=\"taskbar w-100\"\r\n              [style.bottom.px]=\"85\"\r\n            >\r\n              <div class=\"selected-rows-action-bar\" [@slideUp]>\r\n                <span class=\"selected-count\">\r\n                  {{ selectedRows.size }} selected of\r\n                  {{\r\n                    paginationConfig.totalResults ||\r\n                      config?.paginationParams?.totalItems\r\n                  }}\r\n                  Total\r\n                </span>\r\n                <div class=\"action-buttons d-flex align-items-center\">\r\n                  <ng-container\r\n                    *ngFor=\"let action of taskbarActions; let i = index\"\r\n                  >\r\n                    <ng-container *ngIf=\"action?.has_permission\">\r\n                      <span\r\n                        class=\"action-btn verified btn {{ action }}\"\r\n                        (click)=\"onVerifyClick(action?.actionName)\"\r\n                        >{{ action?.actionName }}</span\r\n                      >\r\n                      <span\r\n                        *ngIf=\"\r\n                          taskbarActions.length > 1 &&\r\n                          i !== taskbarActions.length - 1 &&\r\n                          taskbarActions[i + 1]?.has_permission\r\n                        \"\r\n                        class=\"\"\r\n                        >|</span\r\n                      >\r\n                    </ng-container>\r\n                  </ng-container>\r\n                  <button (click)=\"clearSelectionState(tableType);selectedRows.clear();\" class=\"clear-btn ms-2 mt-2\">\r\n                    <i class=\"bi bi-x-circle\"></i> Clear Selection\r\n                  </button>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <!-- Vertical Fake scroll Bar -->\r\n          <!-- <div\r\n            (scroll)=\"onMainFakeScroll($event)\"\r\n            class=\"fake-scrollbar fake-scrollbar-vertical d-none\"\r\n            [style.scrollbarWidth]=\"verticalScrollbarWidth\"\r\n            [style.top.px]=\"\r\n              showColumnsGrouping && showFilterRow\r\n                ? headerRowHeight * 3\r\n                : showColumnsGrouping || showFilterRow\r\n                ? headerRowHeight * 2\r\n                : headerRowHeight\r\n            \"\r\n            #fakeScroll\r\n            [style.height]=\"bodyWrapperHeight\"\r\n            style=\"\r\n              overflow-y: auto;\r\n              overflow-x: hidden;\r\n              width: 17px;\r\n              position: absolute;\r\n              right: 0;\r\n              background-color: f1f2f3;\r\n              z-index: 10;\r\n            \"\r\n          >\r\n            <div [style.height.px]=\"rowHeight * dataSetLength\"></div>\r\n          </div> -->\r\n        </div>\r\n\r\n        <!-- Horizintal Fake Scrollbars -->\r\n        <div\r\n          class=\"d-flex justify-content-between\"\r\n          *ngIf=\"hasScroll\"\r\n        >\r\n          <div\r\n            [style.scrollbarWidth]=\"horizintalScrollbarWidth\"\r\n            class=\"fake-horizintal-scrollbar\"\r\n            #fakeScroll\r\n            [style.width.px]=\"leftPinnedHeader.offsetWidth\"\r\n            style=\"overflow-x: scroll\"\r\n          ></div>\r\n          <div\r\n            [style.scrollbarWidth]=\"horizintalScrollbarWidth\"\r\n            (scroll)=\"onCenterBodyScroll($event)\"\r\n            class=\"fake-horizintal-scrollbar\"\r\n            #horizintalFakeScroll\r\n            [style.width.px]=\"centerPinnedHeader.offsetWidth\"\r\n          >\r\n            <div [style.width.px]=\"centerPinnedHeader.scrollWidth - 10\"></div>\r\n          </div>\r\n          <div\r\n            [style.scrollbarWidth]=\"horizintalScrollbarWidth\"\r\n            class=\"fake-horizintal-scrollbar\"\r\n            #fakeScroll\r\n            [style.width.px]=\"rightPinnedHeader.offsetWidth\"\r\n            style=\"overflow-x: scroll\"\r\n          ></div>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- Side Menu Implemented Here -->\r\n      <div\r\n        *ngIf=\"showSideMenu\"\r\n        [style.width.px]=\"sideMenuVisible ? 280 : 30\"\r\n        class=\"right-menu h-100\"\r\n        [style.backgroundColor]=\"sidemenuBackgroundColor\"\r\n      >\r\n        <div class=\"h-100 d-flex flex-row-reverse\">\r\n          <div\r\n            style=\"width: 30px\"\r\n            class=\"d-flex flex-column align-items-center cursor-pointer\"\r\n            [class.border-start]=\"sideMenuVisible\"\r\n          >\r\n            <div\r\n              (click)=\"toggleSideMenu('cols')\"\r\n              [class.bg-fff]=\"\r\n                currentOpenedSideMenue == 'cols' && sideMenuVisible\r\n              \"\r\n              [class.border-below]=\"sideMenuVisible\"\r\n              class=\"columns-button d-flex flex-column align-items-center\"\r\n            >\r\n              <div>\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/ui-checks-grid.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div>\r\n              <div class=\"side-menue-text\">Columns</div>\r\n            </div>\r\n\r\n            <div\r\n              (click)=\"toggleSideMenu('filtrs')\"\r\n              [class.bg-fff]=\"\r\n                currentOpenedSideMenue == 'filtrs' && sideMenuVisible\r\n              \"\r\n              [class.border-below]=\"\r\n                sideMenuVisible && currentOpenedSideMenue == 'filtrs'\r\n              \"\r\n              class=\"columns-button d-flex flex-column align-items-center\"\r\n            >\r\n              <div>\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div>\r\n              <div class=\"side-menue-text\">Filter</div>\r\n            </div>\r\n          </div>\r\n          <div\r\n            class=\"h-100\"\r\n            *ngIf=\"sideMenuVisible\"\r\n            [ngStyle]=\"{ width: sideMenuVisible ? '250px' : '' }\"\r\n          >\r\n            <div class=\"h-100\">\r\n              <ng-container\r\n                *ngIf=\"currentOpenedSideMenue == 'cols' && sideMenuVisible\"\r\n              >\r\n                <ng-container *ngTemplateOutlet=\"columnPannel\"></ng-container>\r\n                <!-- Column Items -->\r\n                <div class=\"column-panel-body px-3\">\r\n                  <ng-container\r\n                    *ngFor=\"let col of columns; trackBy: trackByField\"\r\n                  >\r\n                    <ng-container\r\n                      *ngTemplateOutlet=\"columnPanelItem; context: { col: col }\"\r\n                    ></ng-container>\r\n                  </ng-container>\r\n                </div>\r\n                <hr />\r\n\r\n                <div class=\"side-menu-row-groups\" style=\"height: 30%\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"sideMenuRowGroups\"\r\n                  ></ng-container>\r\n                </div>\r\n              </ng-container>\r\n              <ng-container\r\n                *ngIf=\"currentOpenedSideMenue == 'filtrs' && sideMenuVisible\"\r\n              >\r\n                <ng-container *ngTemplateOutlet=\"sideFilters\"></ng-container>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div\r\n      [style.height.px]=\"footerRowHeight\"\r\n      class=\"border-top\"\r\n      [style.backgroundColor]=\"footerRowBackgroundColor\"\r\n    >\r\n      <!-- Rows: <span class=\"fw-500 ms-1\">{{ dataSet.length }}</span> -->\r\n\r\n      <div\r\n        class=\"pagination-container\"\r\n        [style.height.px]=\"footerRowHeight\"\r\n        [style.padding.px]=\"footerPadding\"\r\n      >\r\n        <div class=\"page-size\">\r\n          <select\r\n            [(ngModel)]=\"paginationConfig.limit\"\r\n            (change)=\"onPageSizeChange()\"\r\n          >\r\n            <option *ngFor=\"let size of pageSizeOptions\" [value]=\"size\">\r\n              {{ size }}\r\n            </option>\r\n          </select>\r\n          <span class=\"separator\"> per page </span>\r\n        </div>\r\n\r\n        <div class=\"page-info\">\r\n          Results:\r\n          {{ (paginationConfig.page - 1) * paginationConfig.limit + 1 }}-{{\r\n            paginationConfig.page * paginationConfig.limit <\r\n            paginationConfig.totalResults\r\n              ? paginationConfig.page * paginationConfig.limit\r\n              : paginationConfig.totalResults\r\n          }}\r\n          of\r\n          {{ paginationConfig.totalResults }}\r\n        </div>\r\n\r\n        <div class=\"page-buttons\">\r\n          <button\r\n            (click)=\"goToPage(paginationConfig.page - 1)\"\r\n            [disabled]=\"paginationConfig.page === 1\"\r\n          >\r\n            ‹\r\n          </button>\r\n\r\n          <ng-container *ngFor=\"let page of visiblePages\">\r\n            <button\r\n              *ngIf=\"page !== '...'\"\r\n              (click)=\"goToPage(page)\"\r\n              [class.active]=\"page === paginationConfig.page\"\r\n            >\r\n              {{ page }}\r\n            </button>\r\n            <span *ngIf=\"page === '...'\">...</span>\r\n          </ng-container>\r\n\r\n          <button\r\n            (click)=\"goToPage(paginationConfig.page + 1)\"\r\n            [disabled]=\"paginationConfig.page === paginationConfig.totalResults\"\r\n          >\r\n            ›\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!-- ------------------------------------------------------------------------------------------------------------------------ -->\r\n<!-- ------------------------------------------------------------------------------------------------------------------------ -->\r\n<!-- Header Cell Template -->\r\n<!-- ------------------------------------------------------------------------------------------------------------------------ -->\r\n<!-- ------------------------------------------------------------------------------------------------------------------------ -->\r\n\r\n<ng-template\r\n  #headerCell\r\n  let-col\r\n  let-pinnedRight=\"pinnedRight\"\r\n  let-i=\"index\"\r\n  let-sections=\"section\"\r\n  let-calledFromNestedPlaceholder=\"calledFromNestedPlaceholder\"\r\n>\r\n  <div>\r\n    <!-- Group Header -->\r\n    <ng-container *ngIf=\"col.children?.length > 0; else flatHeader\">\r\n      <div cdkDroplistGroup class=\"group-column-wrapper\">\r\n        <!-- Parent Header -->\r\n        <div\r\n          *ngIf=\"shouldTheGroupHeaderShow(col)\"\r\n          class=\"header-cell group-header\"\r\n          [style.height.px]=\"headerRowHeight\"\r\n          [style.min-height.px]=\"headerRowHeight\"\r\n          [style.max-height.px]=\"headerRowHeight\"\r\n          [class.border-right]=\"showVerticalBorder\"\r\n          [style.gridColumn]=\"'span ' + col.children.length\"\r\n          [style.fontWeight]=\"headerFontWeight\"\r\n          [class.flex-row-reverse]=\"pinnedRight\"\r\n          [class.justify-content-end]=\"pinnedRight\"\r\n          style=\"grid-row: 1\"\r\n        >\r\n          <div\r\n            class=\"group-header-content\"\r\n            [title]=\"col.header\"\r\n            [class.ms-2]=\"pinnedRight\"\r\n          >\r\n            {{ col.header }}\r\n          </div>\r\n          <div\r\n            class=\"resize-handle\"\r\n            (dblclick)=\"autosizeColumn(col.children)\"\r\n            (mousedown)=\"\r\n              $event.stopPropagation(); onResizeGroup($event, col, pinnedRight)\r\n            \"\r\n          >\r\n            <span\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath + 'data-grid/icons/resize-handle.svg'\r\n              \"\r\n              class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n            ></span>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Child Headers and Filters -->\r\n\r\n        <div\r\n          class=\"d-flex\"\r\n          cdkDropList\r\n          cdkDropListOrientation=\"horizontal\"\r\n          [cdkDropListData]=\"col.children\"\r\n          (cdkDropListSorted)=\"onChildDroplistSorted($event, sections)\"\r\n          (cdkDropListDropped)=\"onChildDroplistDroped($event)\"\r\n          [cdkDropListSortingDisabled]=\"false\"\r\n          [cdkDropListConnectedTo]=\"\r\n            showRowsGrouping ? ['rows-grouping-top-container'] : []\r\n          \"\r\n        >\r\n          <div\r\n            cdkDrag\r\n            [cdkDragData]=\"child\"\r\n            *ngFor=\"let child of col.children; let i = index\"\r\n          >\r\n            <!-- Child Header -->\r\n            <ng-container *ngIf=\"child.is_visible && !child['isRowGrouped']\">\r\n              <div\r\n                cdkDragHandle\r\n                class=\"header-cell one-row-header-cells cursor-pointer\"\r\n                [class.border-right]=\"showVerticalBorder\"\r\n                [attr.data-field]=\"child.field\"\r\n                [style.width.px]=\"child.width\"\r\n                [style.min-width.px]=\"child.width\"\r\n                [style.min-height.px]=\"headerRowHeight\"\r\n                [style.max-height.px]=\"headerRowHeight\"\r\n                [style.fontWeight]=\"headerFontWeight\"\r\n                style=\"grid-row: 2\"\r\n                [class.filter-applied-on-text]=\"isFilterAppliedOnColumn(child)\"\r\n              >\r\n                <div\r\n                  class=\"d-flex justify-content-between h-100 align-items-center w-100\"\r\n                >\r\n                  <div\r\n                    class=\"d-flex justify-content-between align-items-center w-100\"\r\n                    [class.flex-row-reverse]=\"pinnedRight\"\r\n                  >\r\n                    <div\r\n                      class=\"text-ellipsis h-100 d-flex align-items-center w-100\"\r\n                      [title]=\"col.header\"\r\n                      [class.w-100]=\"pinnedRight\"\r\n                    >\r\n                      <div\r\n                        class=\"text-ellipsis h-100\"\r\n                        [class.editable-header]=\"child?.is_editable\"\r\n                        (click)=\"\r\n                          openThreeDotsMenu($event, child);\r\n                          openFilteronThreeDotsClick(child)\r\n                        \"\r\n                      >\r\n                        {{ child.header }}\r\n                      </div>\r\n                    </div>\r\n\r\n                    <div\r\n                      class=\"position-relative d-flex\"\r\n                      [class.flex-row-reverse]=\"pinnedRight\"\r\n                    >\r\n                      <div\r\n                        [class.me-2]=\"pinnedRight\"\r\n                        class=\"d-flex align-items-center\"\r\n                        *ngIf=\"child.pinned\"\r\n                      >\r\n                        <span\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath + 'data-grid/icons/pin-blue.svg'\r\n                          \"\r\n                          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                        ></span>\r\n                      </div>\r\n                      <div\r\n                        class=\"three-dots p-1\"\r\n                        (click)=\"\r\n                          openThreeDotsMenu($event, child);\r\n                          isThreeDotsFilterOpen = false\r\n                        \"\r\n                        style=\"cursor: pointer\"\r\n                      >\r\n                        <span\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath +\r\n                            'data-grid/icons/three-dots-vertical.svg'\r\n                          \"\r\n                          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                        ></span>\r\n                      </div>\r\n\r\n                      <!-- Only show menu if this column is active -->\r\n                      <div\r\n                        class=\"position-absolute\"\r\n                        *ngIf=\"activeCol === child\"\r\n                        style=\"top: -50%; z-index: 21\"\r\n                        [style.left.px]=\"\r\n                          -(!child?.pinned ? centerPinnedHeader.scrollLeft : 0)\r\n                        \"\r\n                        [style.top.px]=\"\r\n                          isThreeDotsFilterOpen\r\n                            ? showFilterRow || showColumnsGrouping\r\n                              ? headerRowHeight * 2 - 10\r\n                              : headerRowHeight - 10\r\n                            : 0\r\n                        \"\r\n                      >\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"\r\n                            columnMenu;\r\n                            context: {\r\n                              col: child,\r\n                              isNestedTable: false,\r\n                              section: sections\r\n                            }\r\n                          \"\r\n                        ></ng-container>\r\n                      </div>\r\n\r\n                      <div\r\n                        class=\"resize-handle\"\r\n                        (dblclick)=\"autosizeColumn(child)\"\r\n                        (mousedown)=\"\r\n                          $event.stopPropagation();\r\n                          onResizeColumn($event, child)\r\n                        \"\r\n                      >\r\n                        <span\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath +\r\n                            'data-grid/icons/resize-handle.svg'\r\n                          \"\r\n                          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                        ></span>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n\r\n              <!-- Filter Cell -->\r\n              <div\r\n                *ngIf=\"showFilterRow\"\r\n                [style.backgroundColor]=\"headerBackgroundColor\"\r\n                class=\"header-cell filter-cell\"\r\n                [class.border-right]=\"showVerticalBorder\"\r\n                [attr.data-field]=\"child.field\"\r\n                [style.width.px]=\"child.width\"\r\n                [style.min-width.px]=\"child.width\"\r\n                [style.height.px]=\"headerRowHeight\"\r\n                [style.min-height.px]=\"headerRowHeight\"\r\n                [style.max-height.px]=\"headerRowHeight\"\r\n                [class.border-right]=\"showVerticalBorder\"\r\n                style=\"grid-row: 3\"\r\n              >\r\n                <div\r\n                  class=\"header-cell filter-cell\"\r\n                  [attr.data-field]=\"col.field\"\r\n                  [style.width.px]=\"col.width\"\r\n                  [style.min-width.px]=\"col.width\"\r\n                  [style.height.px]=\"headerRowHeight\"\r\n                  [style.min-height.px]=\"headerRowHeight\"\r\n                  [style.max-height.px]=\"headerRowHeight\"\r\n                >\r\n                  <input\r\n                    type=\"text\"\r\n                    class=\"form-control form-control-sm\"\r\n                    placeholder=\"Filter\"\r\n                    [(ngModel)]=\"child.filterValue\"\r\n                    (ngModelChange)=\"onFilterChange(child)\"\r\n                    (paste)=\"onFilterChange(child); applyDropdownFilter()\"\r\n                    [readonly]=\"\r\n                      child?.type == 'dropdown' || child?.type == 'image'\r\n                    \"\r\n                    [class.disabled-search-input]=\"\r\n                      child?.type == 'dropdown' || child?.type == 'image'\r\n                    \"\r\n                    (click)=\"\r\n                      $event.stopPropagation();\r\n                      openFilterFromDisabledSearchedInput(child)\r\n                    \"\r\n                    (keydown.enter)=\"applyDropdownFilter()\"\r\n                    (mousedown)=\"$event.stopPropagation()\"\r\n                  />\r\n                  <span\r\n                    class=\"filter-icon-wrapper\"\r\n                    (click)=\"$event.stopPropagation(); openFilter(child)\"\r\n                    [class.filter-applied]=\"isFilterAppliedOnColumn(child)\"\r\n                    [class.pe-none]=\"child?.type == 'image'\"\r\n                    ><span\r\n                      [inlineSVG]=\"\r\n                        singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\r\n                      \"\r\n                      class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                    ></span>\r\n                    <span\r\n                      *ngIf=\"isFilterAppliedOnColumn(child)\"\r\n                      style=\"\r\n                        width: 7px;\r\n                        height: 7px;\r\n                        box-shadow: 0px 0px 3px #7486ff;\r\n                        background-color: rgb(0 163 233);\r\n                        position: absolute;\r\n                        right: 4px;\r\n                        top: 12px;\r\n                      \"\r\n                      class=\"rounded-circle d-block\"\r\n                    ></span\r\n                  ></span>\r\n\r\n                  <div\r\n                    class=\"position-absolute filter-row-filter-wrapper\"\r\n                    *ngIf=\"activeFilterCell?.field == child?.field\"\r\n                    style=\"top: 100%; right: 0; z-index: 99\"\r\n                    [style.left.px]=\"\r\n                      child?.pinned ? 0 : -centerPinnedHeader.scrollLeft\r\n                    \"\r\n                  >\r\n                    <ng-container\r\n                      *ngTemplateOutlet=\"filterMenu; context: { col: child }\"\r\n                    ></ng-container>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n            </ng-container>\r\n            <ng-template cdkDragPreview\r\n              ><div class=\"p-2 border d-flex gap-2\">\r\n                <div\r\n                  *ngIf=\"\r\n                    !draggingInGroupArea ||\r\n                    (child.is_groupable && draggingInGroupArea)\r\n                  \"\r\n                >\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/arrows-move.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n                <div *ngIf=\"draggingInGroupArea && !child.is_groupable\">\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/ban.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n                <div>{{ child.header }}</div>\r\n              </div>\r\n            </ng-template>\r\n            <ng-template cdkDragPlaceholder>\r\n              <div *ngIf=\"!draggingInGroupArea\" class=\"position-relative\">\r\n                <div\r\n                  *ngTemplateOutlet=\"\r\n                  childHeaderPlaceholder;\r\n                  context: {\r\n                    $implicit: child,\r\n                    index: i,\r\n                    sections: sections,\r\n                    calledFromNestedPlaceholder: true,\r\n                  }\r\n                \"\r\n                ></div>\r\n              </div>\r\n              <div\r\n                *ngIf=\"draggingInGroupArea && child?.is_groupable\"\r\n                class=\"d-flex gap-2 ms-2\"\r\n                style=\"opacity: 0.6\"\r\n              >\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    topGroupingRowPlaceholder;\r\n                    context: {\r\n                      $implicit: child,\r\n                      showChevron: false,\r\n                      pinnedRight: pinnedRight,\r\n                      sections: sections,\r\n                      index: i\r\n                    }\r\n                  \"\r\n                ></ng-container>\r\n              </div>\r\n            </ng-template>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Flat Header || Single Header Cell-->\r\n    <ng-template #flatHeader>\r\n      <div\r\n        class=\"group-column-wrapper\"\r\n        *ngIf=\"col.is_visible && !col['isRowGrouped']\"\r\n      >\r\n        <!-- Full-height Header Cell (spans 2 rows visually) -->\r\n        <div\r\n          class=\"header-cell one-row-header-cells\"\r\n          [attr.data-field]=\"col.field\"\r\n          [style.width.px]=\"col.width\"\r\n          [style.min-width.px]=\"col.width\"\r\n          [class.border-right]=\"showVerticalBorder\"\r\n          [style.min-height.px]=\"\r\n            showColumnsGrouping ? headerRowHeight * 2 : headerRowHeight\r\n          \"\r\n          [style.height.px]=\"\r\n            showColumnsGrouping ? headerRowHeight * 2 : headerRowHeight\r\n          \"\r\n          [style.fontWeight]=\"headerFontWeight\"\r\n          style=\"grid-row: 1 / span 2\"\r\n        >\r\n          <div\r\n            class=\"d-flex justify-content-between h-100 align-items-center w-100\"\r\n          >\r\n            <div\r\n              class=\"d-flex justify-content-between w-100 align-items-center\"\r\n              [class.flex-row-reverse]=\"pinnedRight\"\r\n            >\r\n              <div\r\n                class=\"text-ellipsis h-100 d-flex align-items-center w-100\"\r\n                [title]=\"col.header\"\r\n              >\r\n                <div\r\n                  class=\"text-ellipsis h-100 cursor-pointer\"\r\n                  [class.editable-header]=\"col?.is_editable\"\r\n                  [class.filter-applied-on-text]=\"isFilterAppliedOnColumn(col)\"\r\n                  (click)=\"\r\n                    openThreeDotsMenu($event, col);\r\n                    openFilteronThreeDotsClick(col)\r\n                  \"\r\n                >\r\n                  {{ col.header }}\r\n                </div>\r\n              </div>\r\n\r\n              <div\r\n                class=\"position-relative d-flex\"\r\n                [class.flex-row-reverse]=\"pinnedRight\"\r\n              >\r\n                <div\r\n                  [class.me-2]=\"pinnedRight\"\r\n                  class=\"d-flex align-items-center\"\r\n                  *ngIf=\"col?.pinned\"\r\n                >\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/pin-blue.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n                <div\r\n                  [class.me-2]=\"col.order_by\"\r\n                  class=\"d-flex align-items-center\"\r\n                  *ngIf=\"sortingConfig?.field == col.field\"\r\n                >\r\n                  <!-- Ascending Sort Icon -->\r\n                  <span\r\n                    *ngIf=\"sortingConfig?.order_by == 'asc'\"\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/sort-asc.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center mt-1 cursor-pointer\"\r\n                    (click)=\"sortDesc(col)\"\r\n                    [class.active]=\"sortingConfig?.order_by === 'asc'\"\r\n                  ></span>\r\n\r\n                  <!-- Descending Sort Icon -->\r\n                  <span\r\n                    *ngIf=\"sortingConfig?.order_by == 'desc'\"\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/sort-desc.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center mt-1 cursor-pointer\"\r\n                    (click)=\"sortAsc(col)\"\r\n                    [class.active]=\"sortingConfig?.order_by === 'desc'\"\r\n                  ></span>\r\n                </div>\r\n                <div\r\n                  class=\"three-dots p-1\"\r\n                  (click)=\"\r\n                    openThreeDotsMenu($event, col);\r\n                    isThreeDotsFilterOpen = false\r\n                  \"\r\n                  style=\"cursor: pointer\"\r\n                >\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath +\r\n                      'data-grid/icons/three-dots-vertical.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n\r\n                <!-- Only show menu if this column is active -->\r\n                <div\r\n                  class=\"position-absolute\"\r\n                  *ngIf=\"activeCol === col\"\r\n                  style=\"top: -50%; z-index: 21\"\r\n                  [style.left.px]=\"\r\n                    -(!col?.pinned ? centerPinnedHeader.scrollLeft : 0)\r\n                  \"\r\n                  [style.top.px]=\"\r\n                    isThreeDotsFilterOpen\r\n                      ? showFilterRow || showColumnsGrouping\r\n                        ? headerRowHeight * 2 - 10\r\n                        : headerRowHeight - 10\r\n                      : 0\r\n                  \"\r\n                >\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      columnMenu;\r\n                      context: {\r\n                        col: col,\r\n                        isNestedTable: false,\r\n                        section: sections\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </div>\r\n\r\n                <div\r\n                  class=\"resize-handle\"\r\n                  [class.w-100]=\"col.pinned == 'right'\"\r\n                  (dblclick)=\"autosizeColumn(col)\"\r\n                  (mousedown)=\"\r\n                    $event.stopPropagation(); onResizeColumn($event, col)\r\n                  \"\r\n                >\r\n                  <span\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath + 'data-grid/icons/resize-handle.svg'\r\n                    \"\r\n                    class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                  ></span>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Filter Cell -->\r\n        <div\r\n          *ngIf=\"showFilterRow\"\r\n          [style.backgroundColor]=\"headerBackgroundColor\"\r\n          class=\"header-cell filter-cell\"\r\n          [class.border-right]=\"showVerticalBorder\"\r\n          [attr.data-field]=\"col.field\"\r\n          [style.width.px]=\"col.width\"\r\n          [style.min-width.px]=\"col.width\"\r\n          [style.height.px]=\"headerRowHeight\"\r\n          [style.min-height.px]=\"headerRowHeight\"\r\n          [style.max-height.px]=\"headerRowHeight\"\r\n        >\r\n          <input\r\n            type=\"text\"\r\n            class=\"form-control form-control-sm\"\r\n            placeholder=\"Filter\"\r\n            [(ngModel)]=\"col.filterValue\"\r\n            (ngModelChange)=\"onFilterChange(col)\"\r\n            [readonly]=\"col?.type == 'dropdown' || col?.type == 'image'\"\r\n            [class.disabled-search-input]=\"\r\n              col?.type == 'dropdown' || col?.type == 'image'\r\n            \"\r\n            (paste)=\"onPasteInFilterRowSearch($event, col)\"\r\n            (click)=\"\r\n              $event.stopPropagation(); openFilterFromDisabledSearchedInput(col)\r\n            \"\r\n            (keydown.enter)=\"applyDropdownFilter()\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n          <span\r\n            class=\"filter-icon-wrapper\"\r\n            (click)=\"$event.stopPropagation(); openFilter(col)\"\r\n            [class.filter-applied]=\"isFilterAppliedOnColumn(col)\"\r\n            [class.pe-none]=\"col?.type == 'image'\"\r\n            ><span\r\n              [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\"\r\n              class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n            ></span>\r\n            <span\r\n              *ngIf=\"isFilterAppliedOnColumn(col)\"\r\n              style=\"\r\n                width: 7px;\r\n                height: 7px;\r\n                box-shadow: 0px 0px 3px #7486ff;\r\n                background-color: rgb(0 163 233);\r\n                position: absolute;\r\n                right: 4px;\r\n                top: 12px;\r\n              \"\r\n              class=\"rounded-circle d-block\"\r\n            ></span\r\n          ></span>\r\n\r\n          <div\r\n            class=\"position-absolute filter-row-filter-wrapper\"\r\n            *ngIf=\"activeFilterCell === col\"\r\n            style=\"top: 100%; right: 0; z-index: 99\"\r\n            [style.left.px]=\"col?.pinned ? 0 : -centerPinnedHeader.scrollLeft\"\r\n          >\r\n            <ng-container\r\n              *ngTemplateOutlet=\"filterMenu; context: { col: col }\"\r\n            ></ng-container>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- -------------------------------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n<!-- -------------------------------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n<!-- Body Cell Template -->\r\n<!-- -------------------------------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n<!-- -------------------------------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n<ng-template\r\n  #rowCell\r\n  let-row\r\n  let-columns=\"columns\"\r\n  let-isEven=\"isEven\"\r\n  let-isOdd=\"isOdd\"\r\n  let-isLeftSection=\"isLeft\"\r\n  let-section=\"section\"\r\n  let-rowIndex=\"rowIndex\"\r\n  let-isTotalRow=\"isTotalRow\"\r\n>\r\n  <!-- Check if row is a group -->\r\n  <ng-container\r\n    *ngTemplateOutlet=\"groupRowTemplate; context: { $implicit: row, depth: 0 }\"\r\n  ></ng-container>\r\n  <ng-template #groupRowTemplate let-row let-depth=\"depth\">\r\n    <ng-container *ngIf=\"row.isGroup; else regularRow\">\r\n      <!-- Group Header -->\r\n      <div\r\n        class=\"group-header-row d-flex align-items-center\"\r\n        [style.height.px]=\"rowHeight\"\r\n        [class.border-below]=\"section !== 'center'\"\r\n        [style.width]=\"\r\n          section === 'center'\r\n            ? (centerScrollableBody?.scrollWidth ?? 0) + 'px'\r\n            : '100%'\r\n        \"\r\n      >\r\n        <div\r\n          *ngIf=\"section == 'left'\"\r\n          class=\"h-100 d-flex\"\r\n          [style.width.px]=\"leftPinnedHeader.offsetWidth - 1\"\r\n          [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n        >\r\n          <div\r\n            *ngIf=\"showSerialNumber\"\r\n            style=\"width: 50px\"\r\n            class=\"d-flex align-items-center h-100 border-right justify-content-end pe-2 s-no\"\r\n            [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n            [style.width.px]=\"55\"\r\n            [style.cursor]=\"\r\n              'url(' +\r\n              singleSpaAssetsPath +\r\n              'data-grid/icons/arrow-right.svg), auto'\r\n            \"\r\n            (mousedown)=\"onRowMouseDown(row.__virtualIndex, $event)\"\r\n            (mouseover)=\"onRowMouseOver(row.__virtualIndex, $event)\"\r\n            [style.color]=\"checkboxesColor\"\r\n          >\r\n            {{ getStartIndex() + (row.__virtualIndex - 1) || \"\" }}\r\n          </div>\r\n          <div\r\n          *ngIf=\"showCheckboxes\"\r\n            style=\"width: 50px\"\r\n            class=\"d-flex align-items-center justify-content-center h-100 border-right\"\r\n            [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n            [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n            [class.left-selection-border]=\"\r\n              rowSelectedIndexes.has(row.__virtualIndex)\r\n            \"\r\n            [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n            [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n            [style.color]=\"checkboxesColor\"\r\n          >\r\n            <input\r\n              style=\"width: 16px; height: 16px\"\r\n              type=\"checkbox\"\r\n              [checked]=\"getGroupCheckedState(row) === true\"\r\n              [indeterminate]=\"getGroupCheckedState(row) === undefined\"\r\n              (change)=\"selectGroupRow($event, row)\"\r\n            />\r\n\r\n          </div>\r\n        </div>\r\n\r\n        <div\r\n          *ngIf=\"section == 'center'\"\r\n          [style.width.px]=\"centerPinnedHeader.scrollWidth\"\r\n          [style.minWidth.px]=\"centerPinnedHeader.scrollWidth\"\r\n          class=\"d-flex align-items-center ps-2 h-100 border-below\"\r\n          [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n          [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n          [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n        >\r\n          <div\r\n            class=\"d-flex align-items-center justify-content-between\"\r\n            [style.paddingLeft.px]=\"depth > 0 ? depth * 30 : 0\"\r\n          >\r\n            <span class=\"me-2 filter-icon-wrapper\" (click)=\"toggleExpand(row)\">\r\n              <span\r\n                class=\"data-grid-svg-icon align-items-center d-flex\"\r\n                [inlineSVG]=\"\r\n                  row.isExpand\r\n                    ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n                    : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n                \"\r\n              ></span>\r\n            </span>\r\n            <strong (click)=\"toggleExpand(row)\" class=\"cursor-pointer\">\r\n              {{ row.groupValue }} ({{ countLeafRows(row) }})\r\n            </strong>\r\n          </div>\r\n        </div>\r\n\r\n        <div\r\n          *ngIf=\"section == 'right'\"\r\n          [style.width.px]=\"rightPinnedHeader.offsetWidth\"\r\n          [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n          [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n          [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n        ></div>\r\n      </div>\r\n\r\n      <!-- Recursive Children -->\r\n      <div class=\"group-children\" *ngIf=\"row.isExpand\" [@slideToggle]>\r\n        <ng-container\r\n          *ngFor=\"let child of row.children; let i = index; trackBy: trackById\"\r\n        >\r\n          <ng-container *ngIf=\"child.isGroup; else dataRow\">\r\n            <!-- Recursive call for nested group -->\r\n            <ng-container\r\n              *ngTemplateOutlet=\"\r\n                groupRowTemplate;\r\n                context: { $implicit: child, depth: depth + 1 }\r\n              \"\r\n            ></ng-container>\r\n          </ng-container>\r\n\r\n          <ng-template #dataRow>\r\n            <!-- Regular data row -->\r\n            <ng-container\r\n              *ngTemplateOutlet=\"\r\n                rowCell;\r\n                context: {\r\n                  $implicit: child,\r\n                  columns: columns,\r\n                  isEven: i % 2 === 0,\r\n                  isOdd: i % 2 !== 0,\r\n                  isLeft: isLeftSection,\r\n                  section: section,\r\n                  isTotalRow: isTotalRow\r\n                }\r\n              \"\r\n            ></ng-container>\r\n          </ng-template>\r\n        </ng-container>\r\n      </div>\r\n    </ng-container>\r\n  </ng-template>\r\n\r\n  <!-- Regular row (not a group) -->\r\n  <ng-template #regularRow>\r\n    <div\r\n      class=\"d-flex\"\r\n      [style.height.px]=\"rowHeight\"\r\n      [style.minHeight.px]=\"rowHeight\"\r\n      [style.maxHeight.px]=\"rowHeight\"\r\n    >\r\n      <span\r\n        class=\"d-flex align-items-center justify-content-center cursor-pointer border-below\"\r\n        style=\"min-width: 30px; height: 100%\"\r\n        *ngIf=\"\r\n          section == 'center' && (gridType === 'Assets' || gridType === 'Tasks')\r\n        \"\r\n        [ngStyle]=\"{\r\n          'background-color': rowSelectedIndexes.has(row.__virtualIndex)\r\n            ? null\r\n            : getBackgroundColor(row, isEven, section)\r\n        }\"\r\n        [class.selected-cell]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n        [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n        [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n      >\r\n        <span\r\n          (click)=\"toggleDetailRowExpand(row)\"\r\n          *ngIf=\"row?.detail?.result?.length || gridType === 'Tasks'\"\r\n          class=\"data-grid-svg-icon filter-icon-wrapper\"\r\n          [inlineSVG]=\"\r\n            isDetailsExpanded(row)\r\n              ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n              : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n        ></span>\r\n      </span>\r\n      <div\r\n        [style.min-width.px]=\"\r\n          section == 'center' && groupedColumns?.length ? groupBoxPadding : 0\r\n        \"\r\n        [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n        [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n        [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n        (contextmenu)=\"onRightClick($event, row)\"\r\n        [style.height.px]=\"rowHeight\"\r\n        class=\"data-grid-row h-100\"\r\n        [class.even-row]=\"isEven\"\r\n        [class.odd-row]=\"isOdd\"\r\n        [class.hovered-row]=\"hoveredRowId === (row._id || row.id)\"\r\n        (mouseenter)=\"onRowHover(row)\"\r\n        (mouseleave)=\"onRowLeave()\"\r\n        [ngStyle]=\"{\r\n          'background-color': getBackgroundColor(row, isEven, section)\r\n        }\"\r\n        [style.minHeight.px]=\"rowHeight\"\r\n        [style.maxHeight.px]=\"rowHeight\"\r\n      ></div>\r\n      <div\r\n        (contextmenu)=\"onRightClick($event, row)\"\r\n        [style.height.px]=\"rowHeight\"\r\n        class=\"data-grid-row\"\r\n        [class.even-row]=\"isEven\"\r\n        [class.odd-row]=\"isOdd\"\r\n        [class.hovered-row]=\"hoveredRowId === (row._id || row.id)\"\r\n        (mouseenter)=\"onRowHover(row)\"\r\n        (mouseleave)=\"onRowLeave()\"\r\n        [ngStyle]=\"{\r\n          'background-color': getBackgroundColor(row, isEven, section)\r\n        }\"\r\n      >\r\n        <div\r\n          [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n          class=\"select-all-checkbox-cell justify-content-end pe-2 s-no\"\r\n          [style.width.px]=\"55\"\r\n          *ngIf=\"isLeftSection && showSerialNumber\"\r\n          [style.cursor]=\"\r\n            'url(' +\r\n            singleSpaAssetsPath +\r\n            'data-grid/icons/arrow-right.svg), auto'\r\n          \"\r\n          (mousedown)=\"onRowMouseDown(row.__virtualIndex, $event)\"\r\n          (mouseover)=\"onRowMouseOver(row.__virtualIndex, $event)\"\r\n          [style.color]=\"checkboxesColor\"\r\n        >\r\n          {{ getStartIndex() + (row.__virtualIndex - 1) }}\r\n        </div>\r\n        <div\r\n        class=\"border-below\"\r\n          [style.backgroundColor]=\"\r\n            rowSelectedIndexes.has(row.__virtualIndex)\r\n              ? selectedRowsBackgroundColor\r\n              : checkboxesBackgroundColor\r\n          \"\r\n          class=\"select-all-checkbox-cell\"\r\n          *ngIf=\"isLeftSection && showCheckboxes\"\r\n          [class.left-selection-border]=\"\r\n            rowSelectedIndexes.has(row.__virtualIndex)\r\n          \"\r\n          [class.first-row-selected]=\"firstSelectedRow === row.__virtualIndex\"\r\n          [class.last-row-selected]=\"lastSelectedRow === row.__virtualIndex\"\r\n          [style.minHeight.px]=\"rowHeight - 1\"\r\n          [style.maxHeight.px]=\"rowHeight\"\r\n        >\r\n          <input\r\n            *ngIf=\"hasAnyVisibleColumn\"\r\n             style=\"width: 16px; height: 16px\"\r\n            type=\"checkbox\"\r\n            [checked]=\"isRowSelected(row)\"\r\n            (change)=\"toggleRowSelection(row)\"\r\n          />\r\n        </div>\r\n\r\n        <!-- Render all columns -->\r\n        <ng-container\r\n          *ngFor=\"\r\n            let col of columns;\r\n            trackBy: trackByField;\r\n            let colIndex = index\r\n          \"\r\n        >\r\n          <ng-container *ngIf=\"col.children?.length > 0; else flatColumn\">\r\n            <ng-container\r\n              *ngFor=\"\r\n                let child of col.children;\r\n                trackBy: trackByField;\r\n                let subColIndex = index\r\n              \"\r\n            >\r\n              <ng-container *ngIf=\"child?.is_visible && !child?.isRowGrouped\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    cellTemplate;\r\n                    context: {\r\n                      col: child,\r\n                      row: row,\r\n                      rowIndex: rowIndex,\r\n                      colIndex: colIndex,\r\n                      subColIndex: subColIndex,\r\n                      section: section,\r\n                      isTotalRow: isTotalRow\r\n                    }\r\n                  \"\r\n                ></ng-container>\r\n              </ng-container>\r\n            </ng-container>\r\n          </ng-container>\r\n\r\n          <ng-template #flatColumn>\r\n            <ng-container *ngIf=\"col?.is_visible && !col?.isRowGrouped\">\r\n              <ng-container\r\n                *ngTemplateOutlet=\"\r\n                  cellTemplate;\r\n                  context: {\r\n                    col: col,\r\n                    row: row,\r\n                    rowIndex: rowIndex,\r\n                    colIndex: colIndex,\r\n                    subColIndex: null,\r\n                    section: section,\r\n                    isTotalRow: isTotalRow\r\n                  }\r\n                \"\r\n              ></ng-container>\r\n            </ng-container>\r\n          </ng-template>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n\r\n    <div\r\n      [@slideToggle]\r\n      *ngIf=\"section === 'left' && isDetailsExpanded(row)\"\r\n      class=\"accordion-details\"\r\n      style=\"max-height: 350px; overflow: hidden\"\r\n      [style.maxHeight.px]=\"hasHorizontalScroll ? 339 : 341\"\r\n    >\r\n      <ng-container\r\n        *ngTemplateOutlet=\"\r\n          leftRightNestedPlaceholder;\r\n          context: { $implicit: row }\r\n        \"\r\n      >\r\n      </ng-container>\r\n    </div>\r\n\r\n    <div\r\n      [@slideToggle]\r\n      *ngIf=\"section === 'center' && isDetailsExpanded(row)\"\r\n      class=\"accordion-details center-section\"\r\n      style=\"\r\n        max-height: 350px;\r\n        overflow-y: hidden;\r\n        overflow-x: auto;\r\n        scrollbar-width: thin;\r\n      \"\r\n      #nestedTable\r\n      [style.width]=\"\r\n        hasRightPinnedColumns\r\n          ? '100%'\r\n          : hasVerticalScroll\r\n          ? 'calc(100% - 12px)'\r\n          : '100%'\r\n      \"\r\n    >\r\n      <ng-container *ngIf=\"gridType == 'Assets'\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"nestedTableTemplate; context: { $implicit: row }\"\r\n        ></ng-container>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"gridType == 'Tasks'\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"\r\n            taskManagementTemplate;\r\n            context: { taskDetails: row }\r\n          \"\r\n        ></ng-container>\r\n      </ng-container>\r\n    </div>\r\n\r\n    <div\r\n      [@slideToggle]\r\n      *ngIf=\"section === 'right' && isDetailsExpanded(row)\"\r\n      class=\"accordion-details\"\r\n      style=\"max-height: 350px; overflow: hidden\"\r\n      [style.maxHeight.px]=\"hasHorizontalScroll ? 339 : 341\"\r\n    >\r\n      <ng-container\r\n        *ngTemplateOutlet=\"\r\n          leftRightNestedPlaceholder;\r\n          context: { $implicit: row }\r\n        \"\r\n      >\r\n      </ng-container>\r\n    </div>\r\n  </ng-template>\r\n</ng-template>\r\n\r\n<!-- Actual Cell is Here -->\r\n<ng-template\r\n  #cellTemplate\r\n  let-col=\"col\"\r\n  let-row=\"row\"\r\n  let-section=\"section\"\r\n  let-subColIndex=\"subColIndex\"\r\n  let-rowIndex=\"rowIndex\"\r\n  let-colIndex=\"colIndex\"\r\n  let-isTotalRow=\"isTotalRow\"\r\n>\r\n  <div\r\n    #cellContainer\r\n    (click)=\"\r\n      editingKey = ''; setActiveCell(row, col); collapseAllExpandedCells()\r\n    \"\r\n    [style.fontWeight]=\"bodyFontWeight\"\r\n    [class.border-right]=\"showVerticalBorder\"\r\n    class=\"cell overflow-visible position-relative data-grid-cell\"\r\n    [attr.data-field]=\"col.field\"\r\n    [style.width.px]=\"col.width\"\r\n    [style.min-width.px]=\"col.width\"\r\n    [style.fontSize.px]=\"bodyTextFontsSize\"\r\n    [style.minHeight.px]=\"rowHeight\"\r\n    [style.maxHeight.px]=\"rowHeight\"\r\n    [class.active-cell]=\"\r\n      isActiveCell(row, col) && !isEditing(row, col) && selectedKeys.size == 1\r\n    \"\r\n    (dblclick)=\"\r\n      $event.stopPropagation();\r\n      $event.preventDefault();\r\n      enableEdit(row, col, false, cellContainer)\r\n    \"\r\n    [class.row-selected]=\"rowSelectedIndexes.has(row.__virtualIndex)\"\r\n    [class.first-row-selected]=\"firstSelectedRow === row?.__virtualIndex\"\r\n    [class.last-row-selected]=\"lastSelectedRow === row?.__virtualIndex\"\r\n    tabindex=\"-1\"\r\n    (keydown.enter)=\"$event.preventDefault(); enableEdit(row, col)\"\r\n    (mousedown)=\"\r\n      startSelection(\r\n        row.__virtualIndex,\r\n        colIndex,\r\n        subColIndex ?? 0,\r\n        col.field,\r\n        $event,\r\n        section\r\n      )\r\n    \"\r\n    (mouseenter)=\"\r\n      extendSelection(\r\n        row.__virtualIndex,\r\n        colIndex,\r\n        subColIndex ?? 0,\r\n        col.field,\r\n        $event,\r\n        section\r\n      )\r\n    \"\r\n    (mouseup)=\"endSelection()\"\r\n    [class.selected-cell]=\"\r\n      isSelected(\r\n        row.__virtualIndex,\r\n        colIndex,\r\n        subColIndex ?? 0,\r\n        col.field,\r\n        section\r\n      )\r\n    \"\r\n    [class.top-border]=\"\r\n      isTopBorder(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.bottom-border]=\"\r\n      isBottomBorder(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.left-border]=\"\r\n      isLeftBorder(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.right-border]=\"\r\n      isRightBorder(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.top-left-corner]=\"\r\n      isTopLeftCorner(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.top-right-corner]=\"\r\n      isTopRightCorner(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.bottom-left-corner]=\"\r\n      isBottomLeftCorner(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n    [class.bottom-right-corner]=\"\r\n      isBottomRightCorner(row.__virtualIndex, colIndex, subColIndex, section)\r\n    \"\r\n  >\r\n    <!--  (mousedown)=\"startSelection(row.__virtualIndex, colIndex, subColIndex ?? 0, col.field, $event)\"\r\n  (mouseenter)=\"extendSelection(row.__virtualIndex, colIndex, subColIndex ?? 0, col.field, $event)\"\r\n  (mouseup)=\"endSelection()\"\r\n  [class.selected-cell]=\"isSelected(row.__virtualIndex, colIndex,  subColIndex ?? 0, col.field)\" -->\r\n    <div\r\n      class=\"table-cell\"\r\n      [class.active-for-editing]=\"\r\n        isEditing(row, col) &&\r\n        (getNestedValue(row, col.field)?.length === undefined ||\r\n          getNestedValue(row, col.field)?.length <= 50)\r\n      \"\r\n    >\r\n      <div\r\n        (click)=\"$event.stopPropagation()\"\r\n        *ngIf=\"\r\n          isEditing(row, col) &&\r\n            (getNestedValue(row, col.field)?.length === undefined ||\r\n              (getNestedValue(row, col.field)?.length <= 50 &&\r\n                !expandedCells.size));\r\n          else viewMode\r\n        \"\r\n      >\r\n\r\n       <ng-container *ngIf=\"col.cellEditor; else builtInEditors\">\r\n              <ng-container\r\n                [cellEditor]=\"col.cellEditor\"\r\n                [rowData]=\"row\"\r\n                [colData]=\"col\"\r\n                [cellValue]=\"getNestedValue(row, col.field)\"\r\n                (editorEvent)=\"finishEdit($event)\"\r\n              ></ng-container>\r\n        </ng-container>\r\n\r\n      <ng-template #builtInEditors>\r\n        <ng-container [ngSwitch]=\"col.type\">\r\n          <!-- Text Input -->\r\n          <input\r\n            [style.height.px]=\"rowHeight - 10\"\r\n            *ngSwitchCase=\"'input'\"\r\n            type=\"text\"\r\n            [(ngModel)]=\"row[col.field]\"\r\n            (blur)=\"disableEdit(row, col)\"\r\n            autofocus\r\n            class=\"form-control form-control-sm\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n\r\n          <!-- Number Input -->\r\n          <input\r\n            [style.height.px]=\"rowHeight - 8\"\r\n            *ngSwitchCase=\"'number'\"\r\n            #numberInput=\"ngModel\"\r\n            #numberRef\r\n            (keypress)=\"allowOnlyNumbers($event)\"\r\n            type=\"number\"\r\n            required\r\n            [(ngModel)]=\"row[col.field]\"\r\n            (blur)=\"disableEdit(row, col)\"\r\n            autofocus\r\n            (keydown.enter)=\"numberRef.blur()\"\r\n            class=\"form-control form-control-sm\"\r\n            [ngClass]=\"{\r\n              'is-invalid': numberInput.invalid\r\n            }\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n\r\n          <!-- Date Input -->\r\n          <input\r\n            [style.height.px]=\"rowHeight - 8\"\r\n            *ngSwitchCase=\"'date'\"\r\n            type=\"date\"\r\n            [(ngModel)]=\"row[col.field]\"\r\n            (blur)=\"disableEdit(row, col)\"\r\n            autofocus\r\n            class=\"form-control form-control-sm\"\r\n            #dateInput=\"ngModel\"\r\n            [ngClass]=\"{\r\n              'is-invalid': dateInput.invalid\r\n            }\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n\r\n          <!-- Dropdown -->\r\n          <!-- ng-select like dropdown -->\r\n          <div\r\n            *ngSwitchCase=\"'dropdown'\"\r\n            class=\"dropdown w-100\"\r\n            (blur)=\"disableEdit(row, col)\"\r\n          >\r\n            <!-- Trigger -->\r\n            <button\r\n              class=\"form-select form-select-sm text-start w-100 text-ellipsis\"\r\n              type=\"button\"\r\n              data-bs-toggle=\"dropdown\"\r\n              aria-expanded=\"false\"\r\n              [style.minHeight.px]=\"rowHeight - 10\"\r\n              data-bs-display=\"static\"\r\n              (mousedown)=\"$event.stopPropagation()\"\r\n            >\r\n              <ng-container>\r\n                {{\r\n                  getNestedValue(row, col.field)?.value ||\r\n                    getNestedValue(row, col.field)?.name ||\r\n                    getNestedValue(row, col.field)\r\n                }}\r\n              </ng-container>\r\n              <ng-template #placeholder> Select options... </ng-template>\r\n            </button>\r\n\r\n            <!-- Menu -->\r\n            <div\r\n              class=\"dropdown-menu w-100 p-0 cell-editing-dropdown-menu rounded-3\"\r\n              [class.show]=\"isEditing(row, col)\"\r\n            >\r\n              <!-- Search -->\r\n              <div class=\"px-2 py-1 editing-dropdown-search-input\" *ngIf=\"col?.column_dropdown_value?.length > 5\">\r\n                <input\r\n                  type=\"text\"\r\n                  class=\"form-control form-control-sm\"\r\n                  placeholder=\"Search...\"\r\n                  [(ngModel)]=\"editinDropdownSearch\"\r\n                  (mousedown)=\"$event.stopPropagation()\"\r\n                />\r\n              </div>\r\n              <cdk-virtual-scroll-viewport \r\n                    itemSize=\"35\" \r\n                    class=\"dropdown-viewport\"\r\n                    style=\"height: 120px\"\r\n                  >\r\n                    <div\r\n                    [class.selected]=\"getNestedValue(row, col.field) == option?.value || getNestedValue(row, col.field) == option\"\r\n                      class=\"px-2 py-1 d-flex align-items-center dropdown-item\"\r\n                      *cdkVirtualFor=\"\r\n                        let option of col.column_dropdown_value \r\n                          | filter : editinDropdownSearch : 'value'\r\n                      \"\r\n                      (click)=\"setNestedValue(row, col, option, true); editingKey = null\"\r\n                    >\r\n                      <label\r\n                        \r\n                        class=\"form-check-label d-flex align-items-center mb-0 cursor-pointer\"\r\n                        [for]=\"col.field + '-' + (option.value || option)\"\r\n                      >\r\n                        {{ option.value || option }}\r\n                      </label>\r\n                    </div>\r\n                </cdk-virtual-scroll-viewport>\r\n\r\n            </div>\r\n          </div>\r\n\r\n          <input\r\n            *ngSwitchCase=\"'email'\"\r\n            [style.height.px]=\"rowHeight - 10\"\r\n            [style.maxHeight.px]=\"rowHeight - 10\"\r\n            #emailModel=\"ngModel\"\r\n            #emailInput\r\n            type=\"email\"\r\n            [(ngModel)]=\"row[col.field]\"\r\n            name=\"{{ col.field }}\"\r\n            required\r\n            pattern=\"^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$\"\r\n            (blur)=\"disableEdit(row, col, emailModel)\"\r\n            (keydown.enter)=\"\r\n              emailModel.control.markAsTouched(); emailInput.blur()\r\n            \"\r\n            autofocus\r\n            class=\"form-control form-control-sm\"\r\n            [ngClass]=\"{\r\n              'is-invalid': emailModel.invalid\r\n            }\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n          <!-- Default fallback -->\r\n          <input\r\n            *ngSwitchDefault\r\n            [style.height.px]=\"rowHeight - 10\"\r\n            [style.maxHeight.px]=\"rowHeight - 10\"\r\n            #textModel=\"ngModel\"\r\n            #textInput\r\n            type=\"text\"\r\n            [(ngModel)]=\"row[col.field]\"\r\n            name=\"{{ col.field }}\"\r\n            required\r\n            (blur)=\"disableEdit(row, col, textModel)\"\r\n            (keydown.enter)=\"\r\n              textModel.control.markAsTouched(); textInput.blur()\r\n            \"\r\n            autofocus\r\n            class=\"form-control form-control-sm\"\r\n            [ngClass]=\"{\r\n              'is-invalid': textModel.invalid\r\n            }\"\r\n            (mousedown)=\"$event.stopPropagation()\"\r\n          />\r\n        </ng-container>\r\n      </ng-template>\r\n\r\n      </div>\r\n\r\n      <!-- Display mode -->\r\n      <ng-template #viewMode>\r\n        <div\r\n          class=\"d-flex justify-content-between align-items-center w-100 overflow-hidden\"\r\n          [ngClass]=\"getCellClasses(col, getNestedValue(row, col.field))\"\r\n        >\r\n          <!-- Field icon (for Tasks grid) -->\r\n          <ng-container\r\n            *ngIf=\"gridType === 'Tasks' && iconMap[col.field] && !isTotalRow\"\r\n          >\r\n            <span\r\n              class=\"cursor-pointer me-2\"\r\n              (click)=\"$event.preventDefault(); $event.stopPropagation()\"\r\n              [inlineSVG]=\"iconMap[col.field](row, col)\"\r\n            ></span>\r\n          </ng-container>\r\n\r\n          <!-- ✅ Custom cell renderer support -->\r\n          <ng-container *ngIf=\"col.cellRenderer; else defaultCell\">\r\n            <ng-container\r\n              [cellRenderInit]=\"col.cellRenderer\"\r\n              [rowData]=\"row\"\r\n              [colData]=\"col\"\r\n              [cellValue]=\"getNestedValue(row, col?.field)\"\r\n              (cellEvent)=\"onCellEvent($event)\"\r\n            >\r\n            </ng-container>\r\n          </ng-container>\r\n\r\n          <!-- 🧾 Default text-based cell rendering -->\r\n          <ng-template #defaultCell>\r\n            <div\r\n              #cellText\r\n              class=\"text-ellipsis flex-grow-1\"\r\n              [title]=\"getCellTitle(row, col)\"\r\n            >\r\n              <!-- Normal cell -->\r\n              <ng-container\r\n                *ngIf=\"\r\n                  col.type !== 'image' &&\r\n                  col.field != 'image' &&\r\n                  col.field != 'invoice.invoice_image' &&\r\n                  !isTotalRow\r\n                \"\r\n              >\r\n                <ng-container *ngIf=\"col.is_amount\">{{\r\n                  currencySymbol\r\n                }}</ng-container>\r\n                {{getCellTitle(row, col)}}\r\n              </ng-container>\r\n\r\n              <!-- Total row -->\r\n              <ng-container *ngIf=\"isTotalRow\">\r\n                {{ getTotalAmount(col) }}\r\n              </ng-container>\r\n\r\n              <!-- Invoice Image -->\r\n              <ng-container *ngIf=\"col.field == 'invoice.invoice_image'\">\r\n                <div style=\"display: flex; align-items: center; zoom: 0.7\">\r\n                  <span\r\n                    title=\"{{ getNestedValue(row, col.field) || 'Attachment' }}\"\r\n                    (click)=\"downloadAttchment(getNestedValue(row, col.field))\"\r\n                    [inlineSVG]=\"\r\n                      singleSpaAssetsPath +\r\n                      'data-grid/document-icons/' +\r\n                      getExtention(getNestedValue(row, col.field)) +\r\n                      '.svg'\r\n                    \"\r\n                  ></span>\r\n                </div>\r\n              </ng-container>\r\n\r\n              <!-- Image cell -->\r\n              <ng-container *ngIf=\"col.type == 'image' && !isTotalRow\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    defaultImagePlaceholder;\r\n                    context: { row: row, col: col }\r\n                  \"\r\n                ></ng-container>\r\n              </ng-container>\r\n            </div>\r\n            <span\r\n            *ngIf=\"\r\n              (!col?.cellRenderer && showCellDetailsBox &&\r\n                getNestedValue(row, col.field)?.length > 50 && col.type !== 'image') ||\r\n              (isNestedValueArray(row, col.field) &&\r\n                getNestedValue(row, col.field)?.length > 1)\r\n            \"\r\n            class=\"toggle-icon data-grid-svg-icon ms-2 cursor-pointer\"\r\n            [inlineSVG]=\"\r\n              isExpanded(row, col)\r\n                ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n                : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n            \"\r\n            (click)=\"\r\n              $event.stopPropagation();\r\n              toggleExpandOfLongCellText(row, col, columns, true)\r\n            \"\r\n            (dblclick)=\"$event.preventDefault(); $event.stopPropagation()\"\r\n          ></span>\r\n          </ng-template>\r\n          <!-- Expand / Collapse icon -->\r\n        </div>\r\n\r\n        <!-- Expanded text -->\r\n        <div\r\n          class=\"position-absolute w-100 expanded-box\"\r\n          *ngIf=\"isExpanded(row, col)\"\r\n          [style.zIndex]=\"getZIndex(row, col)\"\r\n          style=\"top: 100%; left: 0\"\r\n          [attr.id]=\"(row.id || row._id) + '-' + (col.id || col._id)\"\r\n          [class.invisible]=\"!showDetailsBox\"\r\n        >\r\n          <ng-container\r\n            *ngTemplateOutlet=\"\r\n              fullTextTemplate;\r\n              context: {\r\n                row: row,\r\n                col: col,\r\n                isArray: isNestedValueArray(row, col.field)\r\n              }\r\n            \"\r\n          ></ng-container>\r\n        </div>\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Headers Action List On clicking three dots -->\r\n\r\n<ng-template\r\n  #columnMenu\r\n  let-col=\"col\"\r\n  let-isNestedTable=\"isNestedTable\"\r\n  let-columns=\"columns\"\r\n  let-section=\"section\"\r\n>\r\n  <div\r\n    class=\"column-menu three-dots-col-menu\"\r\n    [class.visually-hidden]=\"isMenueHidden\"\r\n    *ngIf=\"activeCol && !isThreeDotsFilterOpen\"\r\n    [style.backgroundColor]=\"dropdownsBackgroundColor\"\r\n    (click)=\"$event.stopPropagation()\"\r\n    [style.color]=\"headerTextColor\"\r\n  >\r\n    <!-- Sort Ascending -->\r\n    <div class=\"border-below pb-2\" [class.disable-sorting]=\"!col.is_sortable\">\r\n      <span class=\"muted-text fs-7\" style=\"margin-left: 12px\">Sort</span>\r\n      <div\r\n        *ngIf=\"\r\n          columnThreedotsMunuConfig?.showAscending &&\r\n          (sortingConfig?.field != col.field ||\r\n            sortingConfig?.order_by == 'desc')\r\n        \"\r\n        class=\"column-menu-item\"\r\n        (click)=\"sortAsc(activeCol)\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-up.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n        Sort Ascending\r\n      </div>\r\n\r\n      <!-- Sort Descending -->\r\n      <div\r\n        *ngIf=\"\r\n          columnThreedotsMunuConfig?.showDescending &&\r\n          (sortingConfig?.field != col.field ||\r\n            sortingConfig?.order_by == 'asc')\r\n        \"\r\n        class=\"column-menu-item\"\r\n        (click)=\"sortDesc(activeCol)\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-down.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n        Sort Descending\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"\r\n          sortingConfig?.field === col.field &&\r\n          (sortingConfig?.order_by === 'asc' ||\r\n            sortingConfig?.order_by === 'desc')\r\n        \"\r\n        class=\"column-menu-item\"\r\n        (click)=\"resetSort(activeCol)\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/arrow-counterclockwise.svg'\r\n          \"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n        Reset Sort\r\n      </div>\r\n    </div>\r\n    <div class=\"py-2 border-below three-dots-filter\" [class.disable-sorting]=\"col.type == 'image'\">\r\n      <div\r\n        *ngIf=\"columnThreedotsMunuConfig?.showFilter\"\r\n        class=\"column-menu-item three-dots-filter\"\r\n        (click)=\"openFilteronThreeDotsClick(col)\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n        Filter\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"py-2 border-below\">\r\n      <span class=\"muted-text fs-7\" style=\"margin-left: 12px\">Pin</span>\r\n      <div\r\n        *ngIf=\"columnThreedotsMunuConfig?.showPinleft && col?.pinned !== 'left'\"\r\n        class=\"column-menu-item\"\r\n        (click)=\"\r\n          $event.stopPropagation();\r\n          updateColumnPinInSourceByField(\r\n            activeCol,\r\n            'left',\r\n            isNestedTable,\r\n            columns\r\n          )\r\n        \"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/pin-left.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span\r\n        >Pin Left\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"\r\n          columnThreedotsMunuConfig?.showPinright && col?.pinned !== 'right'\r\n        \"\r\n        class=\"column-menu-item\"\r\n        (click)=\"\r\n          $event.stopPropagation();\r\n          updateColumnPinInSourceByField(\r\n            activeCol,\r\n            'right',\r\n            isNestedTable,\r\n            columns\r\n          )\r\n        \"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/pin-right.svg'\"\r\n          class=\"data-grid-svg-icon data-grid-svg-icon me-2\"\r\n        ></span\r\n        >Pin Right\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"col?.pinned\"\r\n        class=\"column-menu-item\"\r\n        (click)=\"\r\n          $event.stopPropagation();\r\n          updateColumnPinInSourceByField(\r\n            activeCol,\r\n            null,\r\n            isNestedTable,\r\n            columns\r\n          )\r\n        \"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/layout-three-columns.svg'\r\n          \"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span\r\n        >Unpin\r\n      </div>\r\n    </div>\r\n\r\n    <div\r\n      *ngIf=\"columnThreedotsMunuConfig?.showAutosizeThisColumn\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"autosizeColumn(activeCol)\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"\r\n          singleSpaAssetsPath + 'data-grid/icons/arrows-expand-vertical.svg'\r\n        \"\r\n        class=\"me-2\"\r\n      ></span>\r\n      Autosize This Column\r\n    </div>\r\n\r\n    <!-- Autosize All Columns -->\r\n    <div\r\n      *ngIf=\"columnThreedotsMunuConfig?.showAutosizeAllColumns\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"autosizeAllColumns()\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"\r\n          singleSpaAssetsPath + 'data-grid/icons/arrows-angle-expand.svg'\r\n        \"\r\n        class=\"data-grid-svg-icon me-2\"\r\n      ></span\r\n      >Autosize All Columns\r\n    </div>\r\n\r\n    <!-- Group By -->\r\n    <div\r\n      *ngIf=\"showRowsGrouping\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"groupBy(activeCol)\"\r\n      [class.disable-sorting]=\"!col.is_groupable\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/diagram-3.svg'\"\r\n        class=\"data-grid-svg-icon me-2\"\r\n      ></span>\r\n      Group by {{ col.header }}\r\n    </div>\r\n\r\n    <!-- Choose Columns -->\r\n    <div\r\n      *ngIf=\"columnThreedotsMunuConfig?.showChoseColumns\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"chooseColumns()\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/ui-checks-grid.svg'\"\r\n        class=\"data-grid-svg-icon me-2\"\r\n      ></span>\r\n      Choose Columns\r\n    </div>\r\n\r\n    <!-- Reset Columns -->\r\n    <div\r\n      *ngIf=\"columnThreedotsMunuConfig?.showResetColumns\"\r\n      class=\"column-menu-item\"\r\n      (click)=\"resetColumns()\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"\r\n          singleSpaAssetsPath + 'data-grid/icons/arrow-counterclockwise.svg'\r\n        \"\r\n        class=\"data-grid-svg-icon me-2\"\r\n      ></span\r\n      >Reset Columns\r\n    </div>\r\n  </div>\r\n  <div\r\n    @slideToggle\r\n    *ngIf=\"isThreeDotsFilterOpen\"\r\n    class=\"three-dots-col-menu position-relative\"\r\n    [style.right.px]=\"section == 'right' ? null : col.width - 45\"\r\n    [class.visually-hidden]=\"isMenueHidden\"\r\n  >\r\n    <ng-container\r\n      *ngTemplateOutlet=\"filterMenu; context: { col: col }\"\r\n    ></ng-container>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Filter Menue -->\r\n<ng-template #filterMenu let-col=\"col\">\r\n  <div\r\n    class=\"filter-menu-container filter-menu\"\r\n    [style.backgroundColor]=\"dropdownsBackgroundColor\"\r\n  >\r\n    <!-- Dropdown Type -->\r\n    <ng-container *ngIf=\"col.type === 'dropdown'; else textFilter\">\r\n      <div class=\"filter-dropdown-section p-1\">\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Search...\"\r\n          type=\"search\"\r\n          [(ngModel)]=\"addFilterColumnInput\"\r\n        />\r\n\r\n        <div class=\"form-check mb-1 mt-2 ms-1 select-all-filter\">\r\n          <input\r\n            class=\"form-check-input\"\r\n            type=\"checkbox\"\r\n            [checked]=\"isAllSideFilterOptionsSelected(col)\"\r\n            (change)=\"toggleSelectAllSideFilters(col, $event)\"\r\n            id=\"selectAll_{{ col.field }}\"\r\n          />\r\n          <label class=\"form-check-label\" for=\"selectAll_{{ col.field }}\">\r\n            Select All\r\n          </label>\r\n        </div>\r\n\r\n        <!-- <div class=\"dropdown-options ps-1\">\r\n          <div\r\n            class=\"form-check mb-1\"\r\n            *ngFor=\"\r\n              let option of selectedColumnForFilter?.column_dropdown_value\r\n                | filter : addFilterColumnInput : 'value';\r\n              trackBy: trackById;\r\n              let i = index\r\n            \"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              [id]=\"i\"\r\n              [checked]=\"\r\n                currentFilterSelectedIds.has(option?.id ?? option?._id ?? option)\r\n              \"\r\n              (change)=\"toggleSelectionInFilter(option)\"\r\n            />\r\n            <label class=\"form-check-label fw-semibold\" [for]=\"i\">\r\n              {{ option?.value ?? option?.name ?? option }}\r\n            </label>\r\n          </div>\r\n        </div> -->\r\n        <cdk-virtual-scroll-viewport\r\n              itemSize=\"32\"\r\n              class=\"filter-viewport\"\r\n              style=\"height: 120px\"\r\n            >\r\n              <div\r\n                class=\"form-check mb-1 ms-1\"\r\n                *cdkVirtualFor=\"\r\n                  let option of selectedColumnForFilter?.column_dropdown_value\r\n                    | filter : addFilterColumnInput : 'value';\r\n                  trackBy: trackById\r\n                \"\r\n              >\r\n                <input\r\n                  class=\"form-check-input\"\r\n                  type=\"checkbox\"\r\n                  [id]=\"option?.id ?? option?._id ?? option\"\r\n                  [checked]=\"\r\n                    currentFilterSelectedIds.has(option?.id ?? option?._id ?? option)\r\n                  \"\r\n                  (change)=\"toggleSelectionInFilter(option)\"\r\n                />\r\n\r\n                <label\r\n                  class=\"form-check-label fw-semibold\"\r\n                  [for]=\"option?.id ?? option?._id ?? option\"\r\n                >\r\n                  {{ option?.value ?? option?.name ?? option }}\r\n                </label>\r\n              </div>\r\n          </cdk-virtual-scroll-viewport>\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Text Filter Section -->\r\n    <ng-template #textFilter>\r\n      <div class=\"filter-text-section\">\r\n        <div class=\"form-group mb-2\">\r\n          <select\r\n            class=\"form-select form-select-sm custom-select\"\r\n            [(ngModel)]=\"firstCondition\"\r\n          >\r\n            <ng-container *ngIf=\"selectedColumnForFilter.type !== 'date'\">\r\n              <option value=\"contain\">Contains</option>\r\n              <option value=\"does_not_contain\">Does Not Contain</option>\r\n              <option value=\"equal\">Equals</option>\r\n              <option value=\"before\">Starts With</option>\r\n              <option value=\"after\">Ends With</option>\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"selectedColumnForFilter.type == 'date'\">\r\n              <option value=\"equal\">Equals To</option>\r\n              <option value=\"not_equal\">Not Equal</option>\r\n              <option value=\"after\">After</option>\r\n              <option value=\"before\">Before</option>\r\n            </ng-container>\r\n          </select>\r\n        </div>\r\n\r\n        <input\r\n          [type]=\"col.type == 'string' ? 'text' : col.type\"\r\n          class=\"form-control form-control-sm mb-3\"\r\n          placeholder=\"Value\"\r\n          [(ngModel)]=\"firstValue\"\r\n          #filterMenueTextchInput\r\n          (keydown.enter)=\"applyDropdownFilter()\"\r\n        />\r\n\r\n        <div class=\"form-group mb-3 d-flex flex-row\">\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"condition\"\r\n              value=\"and\"\r\n              id=\"and_{{ col.field }}\"\r\n              (change)=\"cdr.detectChanges()\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"and_{{ col.field }}\"\r\n              >AND</label\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1 gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"condition\"\r\n              value=\"or\"\r\n              id=\"or_{{ col.field }}\"\r\n              (change)=\"cdr.detectChanges()\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"or_{{ col.field }}\"\r\n              >OR</label\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1 gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"condition\"\r\n              value=\"none\"\r\n              id=\"none_{{ col.field }}\"\r\n              (change)=\"cdr.detectChanges()\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"none_{{ col.field }}\"\r\n              >None</label\r\n            >\r\n          </div>\r\n        </div>\r\n        <div @slideToggle *ngIf=\"firstValue && condition != 'none'\">\r\n          <div class=\"form-group mb-2\">\r\n            <select\r\n              class=\"form-select form-select-sm custom-select\"\r\n              [(ngModel)]=\"secondCondition\"\r\n            >\r\n              <ng-container *ngIf=\"selectedColumnForFilter.type !== 'date'\">\r\n                <option value=\"contain\">Contains</option>\r\n                <option value=\"does_not_contain\">Does Not Contain</option>\r\n                <option value=\"equal\">Equals</option>\r\n                <option value=\"before\">Starts With</option>\r\n                <option value=\"after\">Ends With</option>\r\n              </ng-container>\r\n\r\n              <ng-container *ngIf=\"selectedColumnForFilter.type == 'date'\">\r\n                <option value=\"equal\">Equals To</option>\r\n                <option value=\"not_equal\">Not Equal</option>\r\n                <option value=\"after\">After</option>\r\n                <option value=\"before\">Before</option>\r\n              </ng-container>\r\n            </select>\r\n          </div>\r\n\r\n          <input\r\n            [type]=\"col.type == 'string' ? 'text' : col.type\"\r\n            class=\"form-control form-control-sm mb-3\"\r\n            placeholder=\"Second Value\"\r\n            [(ngModel)]=\"secondValue\"\r\n          />\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <!-- Actions -->\r\n    <div class=\"d-flex gap-2 mt-2\">\r\n      <div\r\n        class=\"btn btn-sm btn-primary d-flex justify-content-center align-items-center w-100\"\r\n        style=\"height: 30px\"\r\n        (click)=\"applyDropdownFilter()\"\r\n      >\r\n        Apply\r\n      </div>\r\n      <div\r\n        class=\"btn btn-sm btn-secondary d-flex justify-content-center align-items-center w-100\"\r\n        style=\"height: 30px\"\r\n        (click)=\"resetSideFilter(col)\"\r\n      >\r\n        Reset\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Side Menue -->\r\n\r\n<!-- Column Pannel / Pivot Mode / Searching -->\r\n\r\n<ng-template #columnPannel>\r\n  <div class=\"column-panel-header\">\r\n    <!-- Pivot Toggle -->\r\n    <div\r\n      class=\"form-check form-switch d-flex align-items-center mb-2 pivot-mode px-5 ms-2 d-none\"\r\n    >\r\n      <input\r\n        class=\"form-check-input me-2\"\r\n        type=\"checkbox\"\r\n        id=\"pivotToggle\"\r\n        [(ngModel)]=\"pivotMode\"\r\n      />\r\n      <label class=\"form-check-label\" for=\"pivotToggle\">Pivot Mode</label>\r\n    </div>\r\n\r\n    <!-- Select All & Search -->\r\n    <div class=\"d-flex align-items-center mb-2 px-3 mt-3\">\r\n      <span class=\"filter-icon-wrapper me-2\" *ngIf=\"showColumnsGrouping\">\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            accordionState === 'all'\r\n              ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n              : accordionState === 'some'\r\n              ? singleSpaAssetsPath + 'data-grid/icons/dash.svg'\r\n              : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          (click)=\"toggleAllAccordions()\"\r\n        ></span>\r\n      </span>\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input me-2\"\r\n        [checked]=\"allColumnsSelected()\"\r\n        (change)=\"toggleAllColumnsVisibility()\"\r\n      />\r\n      <input\r\n        type=\"text\"\r\n        class=\"form-control form-control-sm\"\r\n        placeholder=\"Search columns...\"\r\n        [(ngModel)]=\"columnSearch\"\r\n      />\r\n    </div>\r\n\r\n    <!-- Separator -->\r\n    <hr class=\"my-2\" />\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Right Columns Menue -->\r\n\r\n<!-- Column Panel Item Template -->\r\n<ng-template #columnPanelItem let-col=\"col\">\r\n  <!-- Group Column -->\r\n  <ng-container *ngIf=\"col.children?.length\">\r\n    <div class=\"column-group d-flex align-items-center mb-2\">\r\n      <span class=\"filter-icon-wrapper me-2\">\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          [class.rotate]=\"col.expanded\"\r\n          (click)=\"col.expanded = !col.expanded\"\r\n        ></span>\r\n      </span>\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input me-2\"\r\n        [id]=\"'group_' + col.header\"\r\n        [checked]=\"isColumnVisible(col)\"\r\n        (change)=\"toggleGroupVisibility(col)\"\r\n      />\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/grid-3x2-gap.svg'\"\r\n        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center me-2\"\r\n      ></span>\r\n      <label\r\n        class=\"d-flex align-items-center mb-0 w-100\"\r\n        [for]=\"'group_' + col.header\"\r\n        style=\"cursor: pointer\"\r\n      >\r\n        <span class=\"text-truncate\">{{ col.header }}</span>\r\n      </label>\r\n    </div>\r\n    <div *ngIf=\"col.expanded\" class=\"ps-4\">\r\n      <ng-container *ngFor=\"let child of col.children; trackBy: trackByField\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"columnPanelItem; context: { col: child }\"\r\n        ></ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <!-- Leaf Column -->\r\n  <ng-container *ngIf=\"!col.children?.length\">\r\n    <div class=\"d-flex align-items-center mb-2\">\r\n      <span class=\"me-2\" style=\"width: 1.5rem\"></span>\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input me-2\"\r\n        [(ngModel)]=\"col.is_visible\"\r\n        [id]=\"'col_' + col.field\"\r\n        (change)=\"onSideMenuColumnsVisibilityChange()\"\r\n      />\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/grid-3x2-gap.svg'\"\r\n        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center me-2\"\r\n      ></span>\r\n      <label\r\n        class=\"d-flex align-items-center mb-0 w-100\"\r\n        [for]=\"'col_' + col.field\"\r\n        style=\"cursor: pointer\"\r\n      >\r\n        <span class=\"text-truncate\">{{ col.header }}</span>\r\n      </label>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<!-- Columns Side Filter -->\r\n<ng-template #sideFilters>\r\n  <div class=\"py-3 px-2 pe-3 h-100\">\r\n    <div class=\"d-flex align-items-center mb-2\">\r\n      <span class=\"filter-icon-wrapper me-2\" *ngIf=\"showColumnsGrouping\">\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            filterAccordionState === 'all'\r\n              ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n              : filterAccordionState === 'some'\r\n              ? singleSpaAssetsPath + 'data-grid/icons/dash.svg'\r\n              : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          (click)=\"toggleAllFilterAccordions()\"\r\n        ></span>\r\n      </span>\r\n      <input\r\n        type=\"text\"\r\n        class=\"form-control form-control-sm\"\r\n        placeholder=\"Search...\"\r\n        [(ngModel)]=\"columnSearch\"\r\n      />\r\n    </div>\r\n    <div\r\n      class=\"overflow-auto side-filter-columns-wrapper\"\r\n      style=\"height: calc(100% - 70px); scrollbar-width: thin\"\r\n    >\r\n      <ng-container\r\n        *ngFor=\"\r\n          let col of columns | filter : columnSearch : 'header';\r\n          trackBy: trackByField\r\n        \"\r\n      >\r\n        <ng-container\r\n          *ngTemplateOutlet=\"filterPannelItem; context: { col: col }\"\r\n        ></ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #filterPannelItem let-col=\"col\">\r\n  <!-- Group Column -->\r\n  <ng-container *ngIf=\"col.children?.length\">\r\n    <div\r\n      class=\"column-group d-flex align-items-center mb-2\"\r\n      *ngIf=\"col.type !== 'image'\"\r\n    >\r\n      <!-- Chevron toggle -->\r\n      <span class=\"filter-icon-wrapper me-2\">\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          [class.rotate]=\"col.expandedFilter\"\r\n          (click)=\"col.expandedFilter = !col.expandedFilter\"\r\n        ></span>\r\n      </span>\r\n\r\n      <!-- Group label toggle -->\r\n      <label\r\n        class=\"d-flex align-items-center mb-0 w-100\"\r\n        style=\"cursor: pointer\"\r\n        (click)=\"col.expandedFilter = !col.expandedFilter\"\r\n      >\r\n        <span class=\"fw-bold text-truncate\"\r\n          >{{ col.header }}\r\n          <span\r\n            class=\"text-primary ms-1\"\r\n            *ngIf=\"col?.query?._ids?.length || col?.query?._first_value\"\r\n            >*</span\r\n          >\r\n        </span>\r\n      </label>\r\n    </div>\r\n\r\n    <!-- Children columns -->\r\n    <div *ngIf=\"col.expandedFilter\" class=\"ps-4\">\r\n      <ng-container *ngFor=\"let child of col.children; trackBy: trackByField\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"filterPannelItem; context: { col: child }\"\r\n        ></ng-container>\r\n      </ng-container>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <!-- Leaf Column -->\r\n  <ng-container *ngIf=\"!col.children?.length\">\r\n    <div class=\"d-flex align-items-center mb-2\" *ngIf=\"col.type !== 'image'\">\r\n      <span\r\n        class=\"me-2 filter-icon-wrapper me-2\"\r\n        (click)=\"col.expandedFilter = !col.expandedFilter\"\r\n      >\r\n        <span\r\n          class=\"toggle-icon data-grid-svg-icon\"\r\n          [inlineSVG]=\"\r\n            singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n          \"\r\n          [class.rotate]=\"col.expandedFilter\"\r\n        ></span>\r\n      </span>\r\n\r\n      <label\r\n        class=\"d-flex align-items-center mb-0 w-100\"\r\n        style=\"cursor: pointer\"\r\n        (click)=\"col.expandedFilter = !col.expandedFilter\"\r\n      >\r\n        <span class=\"text-truncate fw-bold\">{{ col.header }}</span>\r\n      </label>\r\n    </div>\r\n\r\n    <!-- Show filter when expanded -->\r\n    <div *ngIf=\"col.expandedFilter\" class=\"ps-4 pe-3\">\r\n      <ng-container\r\n        *ngTemplateOutlet=\"sideNestedFilter; context: { col: col }\"\r\n      ></ng-container>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<!-- Side Nested Filters -->\r\n<ng-template #sideNestedFilter let-col=\"col\">\r\n  <div class=\"\">\r\n    <!-- Dropdown Type -->\r\n    <ng-container *ngIf=\"col.type === 'dropdown'; else textFilter\">\r\n      <div class=\"p-1\">\r\n        <!-- Search -->\r\n        <input\r\n          type=\"text\"\r\n          class=\"form-control form-control-sm mb-2\"\r\n          placeholder=\"Search...\"\r\n          [(ngModel)]=\"sideNestedFilterSearch\"\r\n        />\r\n\r\n        <!-- Select All -->\r\n        <div class=\"form-check mb-1 ms-1 select-all-filter\">\r\n          <input\r\n            class=\"form-check-input\"\r\n            type=\"checkbox\"\r\n            [checked]=\"\r\n              col.query?._ids?.length == col?.column_dropdown_value?.length\r\n            \"\r\n            (change)=\"toggleSelectAllSideFilters(col, $event)\"\r\n            id=\"selectAll_{{ col.field }}\"\r\n          />\r\n          <label class=\"form-check-label\" for=\"selectAll_{{ col.field }}\">\r\n            Select All\r\n          </label>\r\n        </div>\r\n\r\n        <!-- Options -->\r\n        <!-- <div class=\"dropdown-options\">\r\n          <div\r\n            class=\"form-check mb-1 ms-1\"\r\n            *ngFor=\"\r\n              let option of col?.column_dropdown_value\r\n                | filter : sideNestedFilterSearch : 'value'\r\n            \"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              [value]=\"option\"\r\n              [checked]=\"\r\n                col.query?._ids?.includes(option?._id || option?.id || option)\r\n              \"\r\n              (change)=\"onOptionToggle(col, option)\"\r\n              id=\"option_{{ col.field }}_{{\r\n                option?.id || option?._id || option\r\n              }}\"\r\n            />\r\n            <label\r\n              class=\"form-check-label\"\r\n              [for]=\"\r\n                'option_' +\r\n                col.field +\r\n                '_' +\r\n                (option?.id || option?._id || option)\r\n              \"\r\n            >\r\n              {{ option.value || option }}\r\n            </label>\r\n          </div>\r\n        </div> -->\r\n        <cdk-virtual-scroll-viewport\r\n            itemSize=\"32\"\r\n            class=\"dropdown-viewport\"\r\n            style=\"height: 120px\"\r\n          >\r\n            <div\r\n              class=\"form-check mb-1 ms-1\"\r\n              *cdkVirtualFor=\"\r\n                let option of col?.column_dropdown_value\r\n                  | filter : sideNestedFilterSearch : 'value'\r\n              \"\r\n            >\r\n              <input\r\n                class=\"form-check-input\"\r\n                type=\"checkbox\"\r\n                [value]=\"option\"\r\n                [checked]=\"\r\n                  col.query?._ids?.includes(option?._id || option?.id || option)\r\n                \"\r\n                (change)=\"onOptionToggle(col, option)\"\r\n                id=\"option_{{ col.field }}_{{\r\n                  option?.id || option?._id || option\r\n                }}\"\r\n              />\r\n\r\n              <label\r\n                class=\"form-check-label\"\r\n                [for]=\"\r\n                  'option_' +\r\n                  col.field +\r\n                  '_' +\r\n                  (option?.id || option?._id || option)\r\n                \"\r\n              >\r\n                {{ option.value || option }}\r\n              </label>\r\n            </div>\r\n          </cdk-virtual-scroll-viewport>\r\n\r\n\r\n        <!-- Actions -->\r\n        <!-- <div class=\"d-flex gap-2 mt-2\">\r\n      <div\r\n        class=\"btn btn-sm btn-primary d-flex justify-content-center align-items-center\"\r\n        style=\"height: 22px;\"\r\n        (click)=\"applySideFilter(col)\"\r\n      >\r\n        Apply\r\n      </div>\r\n      <div\r\n        class=\"btn btn-sm btn-secondary d-flex justify-content-center align-items-center\" \r\n        style=\"height: 22px;\"\r\n        (click)=\"resetSideFilter(col)\"\r\n      >\r\n        Reset\r\n      </div>\r\n    </div> -->\r\n      </div>\r\n    </ng-container>\r\n\r\n    <!-- Text Filter Section -->\r\n    <ng-template #textFilter>\r\n      <div class=\"filter-text-section\">\r\n        <div class=\"form-group mb-2\">\r\n          <select\r\n            class=\"form-select form-select-sm\"\r\n            [(ngModel)]=\"col.query.first_condition\"\r\n          >\r\n            <ng-container *ngIf=\"col.type !== 'date'\">\r\n              <option value=\"contain\">Contains</option>\r\n               <option value=\"does_not_contain\">Does Not Contain</option>\r\n              <option value=\"equal\">Equals</option>\r\n              <option value=\"before\">Starts With</option>\r\n              <option value=\"after\">Ends With</option>\r\n            </ng-container>\r\n\r\n            <ng-container *ngIf=\"col.type == 'date'\">\r\n              <option value=\"equal\">Equals To</option>\r\n               <option value=\"not_equal\">Not Equal</option>\r\n              <option value=\"after\">After</option>\r\n              <option value=\"before\">Before</option>\r\n            </ng-container>\r\n          </select>\r\n        </div>\r\n\r\n        <input\r\n          [type]=\"col.type == 'date' ? 'date' : 'text'\"\r\n          class=\"form-control form-control-sm mb-3\"\r\n          placeholder=\"Value\"\r\n          [(ngModel)]=\"col!.query!.first_value\"\r\n        />\r\n\r\n        <div\r\n          class=\"form-group mb-3 d-flex flex-row muted\"\r\n          style=\"font-size: 14px\"\r\n        >\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"col!.query.condition\"\r\n              value=\"and\"\r\n              id=\"and_{{ col.field }}\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"and_{{ col.field }}\"\r\n              >AND</label\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"col!.query.condition\"\r\n              value=\"or\"\r\n              id=\"or_{{ col.field }}\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"or_{{ col.field }}\"\r\n              >OR</label\r\n            >\r\n          </div>\r\n          <div\r\n            class=\"form-check form-check-inline m-0 col-4 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input filter-radio-inputs\"\r\n              type=\"radio\"\r\n              name=\"condition\"\r\n              [(ngModel)]=\"col!.query.condition\"\r\n              value=\"none\"\r\n              id=\"none_{{ col.field }}\"\r\n            />\r\n            <label\r\n              class=\"nnonem-check-label mb-0 mt-1\"\r\n              for=\"none_{{ col.field }}\"\r\n              >None</label\r\n            >\r\n          </div>\r\n        </div>\r\n        <ng-container\r\n          *ngIf=\"col?.query?.first_value && col?.query?.condition !== 'none'\"\r\n        >\r\n          <div class=\"form-group mb-2\">\r\n            <select\r\n              class=\"form-select form-select-sm\"\r\n              [(ngModel)]=\"col!.query.second_condition\"\r\n            >\r\n              <ng-container *ngIf=\"col.type !== 'date'\">\r\n                <option value=\"contain\">Contains</option>\r\n                <option value=\"does_not_contain\">Does Not Contain</option>\r\n                <option value=\"equal\">Equals</option>\r\n                <option value=\"before\">Starts With</option>\r\n                <option value=\"after\">Ends With</option>\r\n              </ng-container>\r\n\r\n              <ng-container *ngIf=\"col.type == 'date'\">\r\n                <option value=\"equal\">Equals To</option>\r\n                 <option value=\"not_equal\">Not Equal</option>\r\n                <option value=\"after\">After</option>\r\n                <option value=\"before\">Before</option>\r\n              </ng-container>\r\n            </select>\r\n          </div>\r\n\r\n          <input\r\n            [type]=\"col.type == 'date' ? 'date' : 'text'\"\r\n            class=\"form-control form-control-sm mb-3\"\r\n            placeholder=\"Second Value\"\r\n            [(ngModel)]=\"col!.query.second_value\"\r\n          />\r\n        </ng-container>\r\n        <!-- <div class=\"d-flex gap-2\">\r\n          <div class=\"btn btn-sm btn-primary d-flex justify-content-center align-items-center\" style=\"height: 22px;\" (click)=\"applyDropdownFilter()\">apply</div>\r\n          <div class=\"btn btn-sm btn-secondary d-flex justify-content-center align-items-center\" style=\"height: 22px;\" (click)=\"applyDropdownFilter()\">reset</div>\r\n\r\n        </div> -->\r\n      </div>\r\n    </ng-template>\r\n    <div\r\n      class=\"d-flex justify-content-center gap-2 border-top\"\r\n      style=\"height: 38px\"\r\n    >\r\n      <button\r\n        type=\"button\"\r\n        style=\"max-height: 30px\"\r\n        class=\"btn btn-outline-secondary btn-light border w-100 d-flex align-items-center justify-content-center mt-1 btn-light\"\r\n        (click)=\"$event.stopPropagation(); removeSideFilter(col)\"\r\n      >\r\n        <span>Clear</span>\r\n      </button>\r\n      <button\r\n        type=\"button\"\r\n        style=\"max-height: 30px\"\r\n        class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center mt-1\"\r\n        (click)=\"applySideFilter(col)\"\r\n        [class.disabled]=\"(col?.query.condition !== 'none' && !col?.query?.second_value)\"\r\n        [class.pe-none]=\"(col!?.query.condition !== 'none' && !col?.query?.second_value)\"\r\n      >\r\n        <span style=\"margin-top: -1px\">Apply</span>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Centr Overlay for showing the chose columns -->\r\n\r\n<div *ngIf=\"showColumnPanel\" class=\"custom-modal-overlay\">\r\n  <div\r\n    class=\"custom-modal-content\"\r\n    [style.backgroundColor]=\"dropdownsBackgroundColor\"\r\n    (click)=\"$event.stopPropagation()\"\r\n  >\r\n    <ng-container *ngTemplateOutlet=\"modalColumnPannel\"></ng-container>\r\n  </div>\r\n</div>\r\n\r\n<!-- The existing ng-template you provided -->\r\n<ng-template #modalColumnPannel>\r\n  <div class=\"column-panel-header\">\r\n    <div\r\n      class=\"d-flex justify-content-between align-items-center px-2 ps-3 rounded-top-2 moda-header\"\r\n      [style.height.px]=\"48\"\r\n    >\r\n      Choose Columns\r\n      <span class=\"filter-icon-wrapper\" (click)=\"closeModalColumnPanel()\"\r\n        ><span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/x.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span\r\n      ></span>\r\n    </div>\r\n    <hr class=\"my-0\" />\r\n    <div>\r\n      <div class=\"d-flex align-items-center px-2 pe-3\" [style.height.px]=\"48\">\r\n        <span class=\"filter-icon-wrapper me-2\" *ngIf=\"showColumnsGrouping\">\r\n          <span\r\n            class=\"toggle-icon data-grid-svg-icon\"\r\n            [inlineSVG]=\"\r\n              accordionState === 'all'\r\n                ? singleSpaAssetsPath + 'data-grid/icons/chevron-down.svg'\r\n                : accordionState === 'some'\r\n                ? singleSpaAssetsPath + 'data-grid/icons/dash.svg'\r\n                : singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\r\n            \"\r\n            (click)=\"toggleAllAccordions()\"\r\n          ></span>\r\n        </span>\r\n        <input\r\n          type=\"checkbox\"\r\n          class=\"form-check-input me-2\"\r\n          [checked]=\"allColumnsSelected()\"\r\n          (change)=\"toggleAllColumnsVisibility()\"\r\n        />\r\n        <input\r\n          type=\"text\"\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Search columns...\"\r\n          [(ngModel)]=\"choseColumnsSearch\"\r\n        />\r\n      </div>\r\n\r\n      <hr class=\"mt-0 mb-1\" />\r\n      <div class=\"px-2 overlay-scrollable\">\r\n        <ng-container\r\n          *ngFor=\"\r\n            let col of columns | filter : choseColumnsSearch : 'header';\r\n            trackBy: trackByField\r\n          \"\r\n        >\r\n          <ng-container\r\n            *ngTemplateOutlet=\"columnPanelItem; context: { col: col }\"\r\n          ></ng-container>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #sideMenuRowGroups>\r\n  <div class=\"d-flex flex-column h-100 d-none\">\r\n    <div class=\"px-3 h-100\">\r\n      <div class=\"d-flex gap-3 mb-4\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/justify.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span>\r\n        <span>Row Groups</span>\r\n      </div>\r\n      <div class=\"h-50\">\r\n        <div\r\n          class=\"px-3 py-2 border-dashed h-100 d-flex justify-content-center align-items-center\"\r\n          style=\"font-size: 14px\"\r\n        >\r\n          Drag here to set row Groups\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <hr class=\"mt-4\" />\r\n\r\n    <div class=\"px-3 h-100\">\r\n      <div class=\"d-flex gap-3 mb-4\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/justify.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span>\r\n        <span>Values</span>\r\n      </div>\r\n      <div class=\"h-50 d-flex\">\r\n        <div\r\n          class=\"px-3 py-2 border-dashed h-100 d-flex justify-content-center align-items-center\"\r\n          style=\"font-size: 14px\"\r\n        >\r\n          Drag here aggregate\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- *************************************************** -->\r\n<!-- *************************************************** -->\r\n<!-- *************************************************** -->\r\n<!-- Drag Preview Template -->\r\n<!-- *************************************************** -->\r\n<!-- *************************************************** -->\r\n<ng-template #dragPreview let-col>\r\n  <div class=\"p-2 border d-flex gap-2\">\r\n    <div>\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrows-move.svg'\"\r\n        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n      ></span>\r\n    </div>\r\n    <div>{{ col.header }}</div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Drag Placeholder Template -->\r\n<ng-template\r\n  #dragPlaceholder\r\n  let-col\r\n  let-i=\"index\"\r\n  let-section=\"section\"\r\n  let-draggingInGroupArea=\"draggingInGroupArea\"\r\n>\r\n  <div *ngIf=\"!draggingInGroupArea\">\r\n    <div\r\n      *ngTemplateOutlet=\"\r\n        headerCell;\r\n        context: { $implicit: col, index: i, section: section }\r\n      \"\r\n    ></div>\r\n  </div>\r\n  <div *ngIf=\"draggingInGroupArea\">New Placeholder</div>\r\n</ng-template>\r\n\r\n<!-- Top Group Row Placeholder -->\r\n<ng-template #topGroupingRowPlaceholder let-col let-showChevron=\"showChevron\">\r\n  <div class=\"d-flex gap-2\">\r\n    <div\r\n      class=\"d-flex gap-2 top-row-grouping-placeholder\"\r\n      [style.backgroundColor]=\"topGroupedBadgesBackgroundColor\"\r\n    >\r\n      <span\r\n        cdkDragHandle\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/grid-3x2-gap.svg'\"\r\n        class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n      ></span>\r\n      <span>{{ col.header }}</span>\r\n      <span\r\n        (click)=\"ungroupColumn(col)\"\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/x.svg'\"\r\n        class=\"cursor-pointer data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n      ></span>\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"showChevron\" style=\"opacity: 0.6; font-size: 14px\">\r\n    <span\r\n      [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/chevron-right.svg'\"\r\n      class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n    ></span>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #childHeaderPlaceholder\r\n  let-col\r\n  let-pinnedRight=\"pinnedRight\"\r\n  let-i=\"index\"\r\n  let-sections=\"sections\"\r\n>\r\n  <div\r\n    class=\"header-cell one-row-header-cells\"\r\n    [class.border-right]=\"showVerticalBorder\"\r\n    [style.width.px]=\"col.width\"\r\n    [style.min-width.px]=\"col.width\"\r\n    [style.min-height.px]=\"headerRowHeight\"\r\n    [style.max-height.px]=\"headerRowHeight\"\r\n    [style.fontWeight]=\"headerFontWeight\"\r\n  >\r\n    <div class=\"d-flex justify-content-between h-100 align-items-center w-100\">\r\n      <div\r\n        class=\"d-flex justify-content-between align-items-center w-100\"\r\n        [class.flex-row-reverse]=\"pinnedRight\"\r\n      >\r\n        <div\r\n          class=\"text-ellipsis h-100 d-flex align-items-center\"\r\n          [title]=\"col.header\"\r\n          [class.w-100]=\"pinnedRight\"\r\n        >\r\n          {{ col.header }}\r\n        </div>\r\n\r\n        <div\r\n          class=\"position-relative d-flex\"\r\n          [class.flex-row-reverse]=\"pinnedRight\"\r\n        >\r\n          <div class=\"three-dots p-1\" style=\"cursor: pointer\">\r\n            <span\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath + 'data-grid/icons/three-dots-vertical.svg'\r\n              \"\r\n              class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n            ></span>\r\n          </div>\r\n\r\n          <div class=\"resize-handle\">\r\n            <span\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath + 'data-grid/icons/resize-handle.svg'\r\n              \"\r\n              class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n            ></span>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div\r\n    *ngIf=\"showFilterRow\"\r\n    [style.backgroundColor]=\"headerBackgroundColor\"\r\n    class=\"header-cell filter-cell\"\r\n    [class.border-right]=\"showVerticalBorder\"\r\n    [style.width.px]=\"col.width\"\r\n    [style.min-width.px]=\"col.width\"\r\n    [style.height.px]=\"headerRowHeight\"\r\n    [style.min-height.px]=\"headerRowHeight\"\r\n    [style.max-height.px]=\"headerRowHeight\"\r\n    [class.border-right]=\"showVerticalBorder\"\r\n    style=\"grid-row: 3\"\r\n  >\r\n    <div\r\n      class=\"header-cell filter-cell\"\r\n      [style.backgroundColor]=\"headerBackgroundColor\"\r\n      [style.width.px]=\"col.width\"\r\n      [style.min-width.px]=\"col.width\"\r\n      [style.height.px]=\"headerRowHeight\"\r\n      [style.min-height.px]=\"headerRowHeight\"\r\n      [style.max-height.px]=\"headerRowHeight\"\r\n    >\r\n      <input\r\n        type=\"text\"\r\n        class=\"form-control form-control-sm\"\r\n        placeholder=\"Filter\"\r\n        [(ngModel)]=\"col.filterValue\"\r\n        [readonly]=\"col?.type == 'dropdown' || col?.type == 'image'\"\r\n        [class.disabled-search-input]=\"\r\n          col?.type == 'dropdown' || col?.type == 'image'\r\n        \"\r\n      />\r\n      <span\r\n        class=\"filter-icon-wrapper\"\r\n        (click)=\"activeFilterCell = col; activeCol = null\"\r\n        ><span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/filter-2.svg'\"\r\n          class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n        ></span\r\n      ></span>\r\n\r\n      <div\r\n        class=\"position-absolute\"\r\n        *ngIf=\"activeFilterCell === col\"\r\n        style=\"top: 100%; right: 0; z-index: 10; left: 0\"\r\n      ></div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #tableLayout>\r\n  <div\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"p-3 shadow actions-dropdown mt-1 dropdown-menu show shadow custom-menu table-layout\"\r\n    style=\"width: 320px\"\r\n  >\r\n    <div class=\"d-flex align-items-center mb-3\">\r\n      <button\r\n        class=\"btn btn-link p-0\"\r\n        style=\"margin-left: -10px\"\r\n        (click)=\"toggleActions('setting')\"\r\n      >\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n          class=\"data-grid-svg-icon me-2\"\r\n        ></span>\r\n      </button>\r\n      <h6 class=\"mb-0 ms-2\" style=\"font-weight: 500\">Table Layout</h6>\r\n    </div>\r\n    <hr class=\"my-2\" />\r\n    <div class=\"w-100 mb-3 d-flex\" role=\"group\">\r\n      <input\r\n        type=\"radio\"\r\n        class=\"btn-check layout-button-check\"\r\n        name=\"layoutSize\"\r\n        id=\"small\"\r\n        autocomplete=\"off\"\r\n        (change)=\"changeTableLayout($event, 'small')\"\r\n        [checked]=\"selectedTableLayout == 'small'\"\r\n      />\r\n      <label\r\n        class=\"border d-flex flex-column align-items-center layout-button\"\r\n        for=\"small\"\r\n        [ngStyle]=\"{\r\n          color: selectedTableLayout == 'small' ? '#000' : '#727272'\r\n        }\"\r\n      >\r\n        <div class=\"preview-box border mb-1\" style=\"height: 8px\"></div>\r\n        Small\r\n      </label>\r\n\r\n      <input\r\n        type=\"radio\"\r\n        class=\"btn-check layout-button-check\"\r\n        name=\"layoutSize\"\r\n        id=\"medium\"\r\n        autocomplete=\"off\"\r\n        [checked]=\"selectedTableLayout == 'medium'\"\r\n        (change)=\"changeTableLayout($event, 'medium')\"\r\n      />\r\n      <label\r\n        class=\"border mx-3 d-flex flex-column align-items-center layout-button\"\r\n        for=\"medium\"\r\n        [ngStyle]=\"{\r\n          color: selectedTableLayout == 'medium' ? '#000' : '#727272'\r\n        }\"\r\n      >\r\n        <div class=\"preview-box border mb-1\" style=\"height: 12px\"></div>\r\n        Medium\r\n      </label>\r\n\r\n      <input\r\n        type=\"radio\"\r\n        class=\"btn-check layout-button-check\"\r\n        name=\"layoutSize\"\r\n        id=\"large\"\r\n        autocomplete=\"off\"\r\n        (change)=\"changeTableLayout($event, 'large')\"\r\n        [checked]=\"selectedTableLayout == 'large'\"\r\n      />\r\n      <label\r\n        class=\"border d-flex flex-column align-items-center layout-button\"\r\n        for=\"large\"\r\n        [ngStyle]=\"{\r\n          color: selectedTableLayout == 'large' ? '#000' : '#727272'\r\n        }\"\r\n      >\r\n        <div class=\"preview-box border mb-1\" style=\"height: 16px\"></div>\r\n        Large\r\n      </label>\r\n    </div>\r\n\r\n    <hr class=\"my-2\" />\r\n    <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n      <span>Show separators</span>\r\n      <div class=\"form-check form-switch m-0\">\r\n        <input\r\n          class=\"form-check-input\"\r\n          type=\"checkbox\"\r\n          id=\"separators\"\r\n          [(ngModel)]=\"showVerticalBorder\"\r\n          (change)=\"onFontChange()\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div class=\"d-flex justify-content-between align-items-center\">\r\n      <span>Row shading</span>\r\n      <div class=\"form-check form-switch m-0\">\r\n        <input\r\n          class=\"form-check-input\"\r\n          [(ngModel)]=\"rowShadingEnabled\"\r\n          (change)=\"toggleRowShading()\"\r\n          type=\"checkbox\"\r\n          id=\"rowShading\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <!-- <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n      <span>Show Side Menu</span>\r\n      <div class=\"form-check form-switch m-0\">\r\n        <input\r\n          class=\"form-check-input\"\r\n          [(ngModel)]=\"showSideMenu\"\r\n          type=\"checkbox\"\r\n          id=\"rowShading\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n      <span>Show Filter Row</span>\r\n      <div class=\"form-check form-switch m-0\">\r\n        <input\r\n          class=\"form-check-input\"\r\n          [(ngModel)]=\"showFilterRow\"\r\n          type=\"checkbox\"\r\n          id=\"rowShading\"\r\n        />\r\n      </div>\r\n    </div> -->\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #tablePreset>\r\n  <div\r\n    *ngIf=\"activeSubButton !== 'save-preset'\"\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"p-3 shadow actions-dropdown mt-1 dropdown-menu show shadow custom-menu table-layout\"\r\n    style=\"width: 280px\"\r\n  >\r\n    <!-- Header -->\r\n    <div class=\"d-flex justify-content-between align-items-center mb-3\">\r\n      <div class=\"d-flex align-items-center\">\r\n        <button\r\n          class=\"btn btn-link p-0\"\r\n          style=\"margin-left: -10px\"\r\n          (click)=\"toggleActions('setting')\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n            class=\"data-grid-svg-icon\"\r\n          ></span>\r\n        </button>\r\n        <h6 class=\"mb-0 ms-2\" style=\"font-weight: 500\">Table Presets</h6>\r\n      </div>\r\n      <!-- Save Preset Button with Dropdown -->\r\n      <div>\r\n        <a\r\n          class=\"text-decoration-none text-primary\"\r\n          type=\"button\"\r\n          id=\"savePresetDropdown\"\r\n          (click)=\"$event.stopPropagation(); toggleSubActions('save-preset')\"\r\n        >\r\n          {{ isTablePresetNotChanged ? \"Save preset\" : \"Update Preset\" }}\r\n        </a>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Search -->\r\n    <div class=\"mb-3\">\r\n      <div class=\"col-12 global-search\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/search.svg'\"\r\n          class=\"data-grid-svg-icon mx-2 position-absolute icon\"\r\n        ></span>\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Search...\"\r\n          [(ngModel)]=\"searchTextPresetTable\"\r\n          type=\"search\"\r\n        />\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Preset List -->\r\n    <ng-container\r\n      *ngIf=\"\r\n        tableView | filter : searchTextPresetTable : 'name' as filteredList\r\n      \"\r\n    >\r\n      <!-- If filteredList exists and none is default -> show fallback -->\r\n      <div\r\n        class=\" pb-5 overflow-auto\"\r\n        [style.maxHeight.px]=\"dataGridContainer.offsetHeight - 250\"\r\n      >\r\n        <div\r\n          class=\"cursor-pointer\"\r\n          (click)=\"\r\n            clearAllFilters();\r\n            openIndex = null;\r\n            temp_state.id = '';\r\n            activeTopButton = '';\r\n            curretaTablePresetForUpdate = null\r\n          \"\r\n        >\r\n          <div class=\"fw-semibold\">Default View</div>\r\n        </div>\r\n        <div class=\"d-flex justify-content-between\">\r\n          <small class=\"text-dark\">Created by system</small>\r\n          <span\r\n            *ngIf=\"!tableFilterViewId && !hasAnyDefaultView()\"\r\n            class=\"badge bg-light text-primary ms-2\"\r\n            >Default</span\r\n          >\r\n          <span\r\n            *ngIf=\"!tableFilterViewId && !hasAnyDefaultView()\"\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/check-blue.svg'\"\r\n            class=\"me-2\"\r\n          ></span>\r\n          <div\r\n            class=\"dropdown d-flex justify-content-end\"\r\n            *ngIf=\"tableFilterViewId\"\r\n          ></div>\r\n        </div>\r\n\r\n        <!-- The list: render each table from filteredList -->\r\n        <div\r\n          class=\"list-group list-group-flush\"\r\n          *ngFor=\"\r\n            let table of filteredList;\r\n            let i = index;\r\n            trackBy: trackByTable\r\n          \"\r\n        >\r\n          <!-- Item -->\r\n          <div\r\n            (click)=\"\r\n              $event.stopPropagation(); openIndex = null; activeTopButton = ''\r\n            \"\r\n            class=\"list-group-item px-0 d-flex justify-content-between align-items-center\"\r\n          >\r\n            <div (click)=\"selectFilter(table); openIndex = null\">\r\n              <div class=\"fw-semibold\" style=\"cursor: pointer\">\r\n                {{ table?.name }}\r\n                <!-- {{table?.is_temp}} -->\r\n                <span\r\n                  *ngIf=\"\r\n                    (table?.is_temp && !temp_state.id) ||\r\n                    temp_state.id == table.id\r\n                  \"\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/check-blue.svg'\r\n                  \"\r\n                  class=\"me-2\"\r\n                ></span>\r\n                <span\r\n                  *ngIf=\"table?.is_default\"\r\n                  class=\"badge bg-light text-primary ms-2\"\r\n                  >Default</span\r\n                >\r\n              </div>\r\n              <small class=\"text-dark\" *ngIf=\"table?.config?.filterNames\" [title]=\"table?.config?.filterNames\">\r\n              {{\r\n              table?.config?.filterNames?.length > 25 \r\n              ? (table?.config?.filterNames | slice:0:25) + '...'\r\n              : table?.config?.filterNames\r\n              }}\r\n              ({{ table?.config?.totalCount }})\r\n            </small>\r\n             <small class=\"text-dark\" *ngIf=\"!table?.config?.filterNames\">{{ table?.createdAt | date : \"MMM d, y\" }}</small>\r\n            </div>\r\n\r\n            <div class=\"d-flex align-items-center\">\r\n              <span\r\n                *ngIf=\"table?.is_default\"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/check-blue.svg'\r\n                \"\r\n                class=\"me-2\"\r\n              ></span>\r\n\r\n              <div class=\"dropdown\" *ngIf=\"!table?.is_default\">\r\n                <div\r\n                  class=\"dropdown-wrapper\"\r\n                  (click)=\"$event.stopPropagation()\"\r\n                >\r\n                  <button\r\n                    type=\"button\"\r\n                    class=\"btn-icon muted-text\"\r\n                    (click)=\"toggleMenu(i, $event)\"\r\n                    aria-haspopup=\"true\"\r\n                    [attr.aria-expanded]=\"openIndex === i\"\r\n                  >\r\n                    <span\r\n                      [inlineSVG]=\"\r\n                        singleSpaAssetsPath +\r\n                        'data-grid/icons/horizontal-dots.svg'\r\n                      \"\r\n                      class=\"me-2\"\r\n                    ></span>\r\n                  </button>\r\n\r\n                  <!-- menu -->\r\n                 <ul\r\n                    *ngIf=\"openIndex === i\"\r\n                    class=\"custom-dropdown-menu position-fixed top-auto\"\r\n                    role=\"menu\"\r\n                    [style.right.px]=\"'auto'\"\r\n                    [style.left.px]=\"dataGridContainer.offsetWidth - 100\"\r\n                    style=\"top: unset; right: unset\"\r\n                  >\r\n                    <li role=\"none\">\r\n                      <button\r\n                        role=\"menuitem\"\r\n                        class=\"dropdown-item\"\r\n                        (click)=\"\r\n                          actionPreset(table, 'setPreset'); temp_state.id = ''\r\n                        \"\r\n                      >\r\n                        <span\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath + 'data-grid/icons/star.svg'\r\n                          \"\r\n                          class=\"me-2\"\r\n                        ></span>\r\n                        Set as default\r\n                      </button>\r\n                    </li>\r\n\r\n                    <li role=\"none\" *ngIf=\"!table.confirmDelete\">\r\n                      <button\r\n                        role=\"menuitem\"\r\n                        class=\"dropdown-item text-danger\"\r\n                        (click)=\"table.confirmDelete = true\"\r\n                      >\r\n                        <span\r\n                          style=\"margin-top: -4px\"\r\n                          [inlineSVG]=\"\r\n                            singleSpaAssetsPath +\r\n                            'data-grid/icons/trash-red.svg'\r\n                          \"\r\n                          class=\"me-2\"\r\n                        ></span>\r\n                        Delete\r\n                      </button>\r\n                    </li>\r\n\r\n                    <li\r\n                      role=\"none\"\r\n                      *ngIf=\"table.confirmDelete\"\r\n                      class=\"confirm-block\"\r\n                    >\r\n                      <div class=\"px-3 py-2 text-center\">\r\n                        <div class=\"mb-2\">\r\n                          Are you sure you want to delete <br /><b\r\n                            >“{{ table?.name }}”</b\r\n                          >?\r\n                        </div>\r\n                        <div class=\"d-flex gap-2\">\r\n                          <button\r\n                            class=\"btn btn-sm btn-light me-2\"\r\n                            (click)=\"table.confirmDelete = false\"\r\n                          >\r\n                            Cancel\r\n                          </button>\r\n                          <button\r\n                            class=\"btn btn-sm btn-danger\"\r\n                            (click)=\"actionPreset(table, 'deletePreset')\"\r\n                          >\r\n                            Delete\r\n                          </button>\r\n                        </div>\r\n                      </div>\r\n                    </li>\r\n                  </ul>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <!-- Item End Here -->\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n\r\n  <div\r\n    (click)=\"$event.stopPropagation()\"\r\n    *ngIf=\"activeSubButton == 'save-preset'\"\r\n    class=\"dropdown-menu p-3 badge mt-4 save-preset-dropdown mt-1\"\r\n    aria-labelledby=\"savePresetDropdown\"\r\n    style=\"min-width: 250px\"\r\n  >\r\n    <div class=\"fw-bold fs-14px mb-2\">\r\n      {{ isTablePresetNotChanged ? \"Save preset\" : \"Update Preset\" }}\r\n    </div>\r\n    <div class=\"fs-14px mb-2\" style=\"line-height: 20px\">\r\n      This will save the current table adjustments as a preset.\r\n    </div>\r\n    <!-- Input -->\r\n    <div class=\"mb-2\">\r\n      <label for=\"presetName\" class=\"form-label fs-12px fw-bold\"\r\n        >Preset Name</label\r\n      >\r\n      <div class=\"col-12 global-search\">\r\n        <input\r\n          #presetNameCtrl=\"ngModel\"\r\n          required\r\n          [(ngModel)]=\"presetName\"\r\n          [ngClass]=\"{\r\n            'is-invalid':\r\n              presetNameCtrl.invalid &&\r\n              (presetNameCtrl.dirty || presetNameCtrl.touched)\r\n          }\"\r\n          class=\"form-control form-control-sm ps-2\"\r\n          placeholder=\"Enter preset name\"\r\n          type=\"text\"\r\n        />\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Checkbox -->\r\n    <div class=\"form-check mb-2\">\r\n      <input\r\n        class=\"form-check-input\"\r\n        [(ngModel)]=\"presetFilter\"\r\n        type=\"checkbox\"\r\n        id=\"saveFilters\"\r\n      />\r\n      <label class=\"form-check-label mt-1\" for=\"saveFilters\">\r\n        Save active filters\r\n      </label>\r\n    </div>\r\n\r\n    <!-- Save Button -->\r\n    <div class=\"d-flex justify-content-center gap-2\" style=\"height: 32px\">\r\n      <button\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn border w-100 d-flex align-items-center justify-content-center btn-light\"\r\n        (click)=\"$event.stopPropagation(); toggleActions('table-presets')\"\r\n        style=\"margin-top: -2px\"\r\n      >\r\n        <span>Cancel</span>\r\n      </button>\r\n      <button\r\n        [disabled]=\"closeDropdown.preset.loading\"\r\n        (click)=\"savePreset(presetNameCtrl)\"\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center\"\r\n      >\r\n        <span style=\"margin-top: -2px\" *ngIf=\"isTablePresetNotChanged\">\r\n          <ng-container *ngIf=\"!closeDropdown.preset.loading\"\r\n            >Save</ng-container\r\n          >\r\n          <ng-container *ngIf=\"closeDropdown.preset.loading\"\r\n            ><span class=\"spinner-border spinner-border-sm\"></span\r\n          ></ng-container>\r\n        </span>\r\n        <span style=\"white-space: nowrap\" *ngIf=\"!isTablePresetNotChanged\"\r\n          >Update Preset</span\r\n        >\r\n      </button>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #showHideColumns>\r\n  <div\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"p-3 shadow actions-dropdown mt-1 dropdown-menu show shadow custom-menu table-layout\"\r\n    style=\"width: 280px\"\r\n  >\r\n    <!-- Header -->\r\n    <div class=\"d-flex justify-content-between align-items-center mb-3\">\r\n      <div class=\"d-flex align-items-center\">\r\n        <button\r\n          class=\"btn btn-link p-0\"\r\n          style=\"margin-left: -10px\"\r\n          (click)=\"toggleActions('setting')\"\r\n        >\r\n          <span\r\n            [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n            class=\"data-grid-svg-icon\"\r\n          ></span>\r\n        </button>\r\n        <h6 class=\"mb-0 ms-2\" style=\"font-weight: 500\">Columns</h6>\r\n      </div>\r\n      <a\r\n        (click)=\"resetColumns()\"\r\n        href=\"javascript:void(0)\"\r\n        class=\"text-primary text-decoration-none d-none\"\r\n        >Reset</a\r\n      >\r\n    </div>\r\n\r\n    <!-- Search -->\r\n    <div class=\"mb-3\">\r\n      <div class=\"col-12 global-search\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/search.svg'\"\r\n          class=\"mx-2 position-absolute icon data-grid-svg-icon\"\r\n        ></span>\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Search column\"\r\n          type=\"search\"\r\n          [(ngModel)]=\"topShowHideColumns\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <!-- Preset List -->\r\n    <div\r\n      class=\"list-group list-group-flush\"\r\n      style=\"overflow: auto; scrollbar-width: thin\"\r\n      [style.maxHeight.px]=\"dataGridContainer.offsetHeight - 220\"\r\n    >\r\n      <div class=\"muted-text show-hide-table-label d-flex justify-content-between\" *ngIf=\"hasAnyVisibleColumn\">\r\n        Show in table\r\n         <div class=\"form-check\">\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              id=\"hide_all\"\r\n              [checked]=\"allColumnsSelected()\"\r\n              (change)=\"toggleAllColumnsVisibility()\"\r\n            />\r\n            <label class=\"form-check-label fw-semibold\" for=\"hide_all\">\r\n              Show/Hide All \r\n            </label>\r\n          </div>\r\n      </div>\r\n      <!-- Item -->\r\n      <ng-container\r\n        *ngFor=\"\r\n          let col of columns | filter : topShowHideColumns : 'header';\r\n          trackBy: trackByField\r\n        \"\r\n      >\r\n        <div\r\n          *ngIf=\"col.is_visible\"\r\n          class=\"list-group-item border-0 px-0 d-flex justify-content-between align-items-center\"\r\n        >\r\n          <div class=\"d-flex gap-1\">\r\n            <div>\r\n              <span\r\n                *ngIf=\"!col?.pinned\"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/grip-vertical.svg'\r\n                \"\r\n                class=\"cursor-grap data-grid-svg-icon\"\r\n                (mousedown)=\"$event.preventDefault()\"\r\n              ></span>\r\n              <span\r\n                *ngIf=\"col?.pinned\"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/pin-blue.svg'\r\n                \"\r\n                class=\"cursor-grap data-grid-svg-icon\"\r\n                (mousedown)=\"$event.preventDefault()\"\r\n              ></span>\r\n            </div>\r\n            <div class=\"fw-semibold\">\r\n              {{ col.header }}\r\n            </div>\r\n          </div>\r\n          <div\r\n            *ngIf=\"!col?.query?.first_value && !col?.query?._ids?.length\"\r\n            class=\"d-flex align-items-center cursor-pointer\"\r\n            (click)=\"toggleColumnVisibility(col, false)\"\r\n            [class.disabled]=\"visibleColumns().length <= 2 || col?.is_always_visible\"\r\n            [class.pe-none]=\"visibleColumns().length <= 2 || col?.is_always_visible\"\r\n            [class.opacity-50]=\"visibleColumns().length <= 2 || col?.is_always_visible\"\r\n          >\r\n            <span\r\n              [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/eye.svg'\"\r\n              class=\"data-grid-svg-icon me-2\"\r\n            ></span>\r\n          </div>\r\n          <div\r\n            *ngIf=\"col?.query?.first_value || col?.query?._ids?.length\"\r\n            class=\"d-flex align-items-center\"\r\n            style=\"opacity: 0.5\"\r\n          >\r\n            <span\r\n              [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/eye.svg'\"\r\n              class=\"data-grid-svg-icon me-2\"\r\n            ></span>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n\r\n      <!-- Item End Here -->\r\n\r\n      <div\r\n        class=\"dropdown-divider\"\r\n        *ngIf=\"hasAnyVisibleColumn && hasAnyInVisibleColumn\"\r\n      ></div>\r\n\r\n      <div\r\n        class=\"muted-text show-hide-table-label d-flex justify-content-between\"\r\n        *ngIf=\"hasAnyInVisibleColumn\"\r\n      >\r\n        Hide in table\r\n        <div class=\"form-check\">\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              id=\"show_all\"\r\n              [checked]=\"allColumnsSelected()\"\r\n              (change)=\"toggleAllColumnsVisibility()\"\r\n            />\r\n            <label class=\"form-check-label fw-semibold\" for=\"show_all\">\r\n              Show/Hide All \r\n            </label>\r\n          </div>\r\n      </div>\r\n      <div class=\"list-group list-group-flush\">\r\n        <ng-container *ngFor=\"let col of columns; trackBy: trackByField\">\r\n          <div\r\n            *ngIf=\"!col.is_visible\"\r\n            class=\"list-group-item border-0 px-0 d-flex justify-content-between align-items-center\"\r\n          >\r\n            <div class=\"d-flex gap-1\">\r\n              <div>\r\n                <span\r\n                  *ngIf=\"!col?.pinned\"\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/grip-vertical.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon cursor-grap\"\r\n                  (mousedown)=\"$event.preventDefault()\"\r\n                ></span>\r\n                <span\r\n                  *ngIf=\"col?.pinned\"\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/pin-blue.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon cursor-grap\"\r\n                  (mousedown)=\"$event.preventDefault()\"\r\n                ></span>\r\n              </div>\r\n              <div class=\"fw-semibold\">\r\n                {{ col.header }}\r\n              </div>\r\n            </div>\r\n            <div\r\n              class=\"d-flex align-items-center cursor-pointer\"\r\n              (click)=\"toggleColumnVisibility(col, true)\"\r\n            >\r\n              <span\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath + 'data-grid/icons/eye-cross.svg'\r\n                \"\r\n                class=\"data-grid-svg-icon me-2\"\r\n              ></span>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n\r\n      <!-- Item End Here -->\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #filterColumns let-col=\"column\">\r\n  <div\r\n    @slideToggle\r\n    *ngIf=\"!isFilterOpen && activeTopButton == 'filter-columns'\"\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"shadow actions-dropdown mt-1 show shadow custom-menu table-layout filter-columns\"\r\n    style=\"width: 280px; right: unset; max-width: 230px\"\r\n    [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n  >\r\n    <div class=\"mb-2 px-3\">\r\n      <div class=\"col-12 global-search\">\r\n        <span\r\n          [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/search.svg'\"\r\n          class=\"data-grid-svg-icon mx-2 position-absolute icon\"\r\n        ></span>\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Filter by\"\r\n          type=\"search\"\r\n          [(ngModel)]=\"addFilterColumnInput\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div\r\n      class=\"list-group list-group-flush\"\r\n      style=\"max-height: calc(100vh - 500px); overflow: auto\"\r\n    >\r\n      <ng-container\r\n        *ngFor=\"\r\n          let col of columns | filter : addFilterColumnInput : 'header';\r\n          trackBy: trackByField\r\n        \"\r\n      >\r\n        <div\r\n          (click)=\"openFilter(col)\"\r\n          *ngIf=\"\r\n            col.is_visible &&\r\n            !col?.query?.first_value &&\r\n            !col?.query?._ids?.length && col.type !== 'image'\r\n          \"\r\n          class=\"list-group-item border-0 px-0 d-flex justify-content-between align-items-center dropdown-item cursor-pointer\"\r\n        >\r\n          <div class=\"d-flex gap-1\">\r\n            <div style=\"margin-top: -3px\"></div>\r\n            <div class=\"fw-semibold\">\r\n              {{ col.header }}\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Dropdown -->\r\n  <div\r\n    @slideToggle\r\n    *ngIf=\"isFilterOpen && selectedColumnForFilter.type == 'dropdown'\"\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"shadow actions-dropdown mt-1 show shadow custom-menu table-layout filter-columns pb-2\"\r\n    style=\"width: 280px; right: unset; max-width: 230px\"\r\n    [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n  >\r\n    <div class=\"px-3 my-2 border-below py-1 pb-2 mb-3 d-flex ps-1\">\r\n      <span\r\n        (click)=\"toggleActions('filter-columns'); isActiveFilterOpen = false\"\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n        class=\"data-grid-svg-icon me-2 cursor-pointer\"\r\n      ></span\r\n      ><b>{{ selectedColumnForFilter?.header }}</b>\r\n    </div>\r\n    <div class=\"mb-2 px-3\">\r\n      <div\r\n        class=\"col-12 global-search position-relative border rounded d-flex align-items-center flex-wrap px-2 filter-serach-inpt\"\r\n      >\r\n        <span\r\n          *ngFor=\"let selected of selectedFilterOptions\"\r\n          class=\"badge d-flex align-items-center gap-1 me-1 mb-1 top-row-filter-dropdown\"\r\n        >\r\n          {{ selected?.value ? selected.value : selected }}\r\n          <span\r\n            (click)=\"toggleSelectionInFilter(selected)\"\r\n            [inlineSVG]=\"\r\n              singleSpaAssetsPath + 'data-grid/icons/cross-primary.svg'\r\n            \"\r\n            class=\"me-2\"\r\n          ></span>\r\n        </span>\r\n        <input\r\n          class=\"form-control form-control-sm border-0 flex-grow-1\"\r\n          style=\"padding: 0\"\r\n          [placeholder]=\"selectedFilterOptions?.length ? '' : 'Filter by'\"\r\n          type=\"search\"\r\n          [(ngModel)]=\"searchTextForFilterDropDown\"\r\n          (keydown.backspace)=\"handleBackspace($event)\"\r\n        />\r\n      </div>\r\n    </div>\r\n    <div\r\n      class=\"list-group list-group-flush\"\r\n      style=\"max-height: calc(100vh - 600px); overflow: auto\"\r\n    >\r\n      <ng-container\r\n        *ngFor=\"\r\n          let col of selectedColumnForFilter.column_dropdown_value\r\n            | filter : searchTextForFilterDropDown : 'value';\r\n          let i = index\r\n        \"\r\n      >\r\n        <div\r\n          class=\"list-group-item border-0 px-2 d-flex justify-content-between align-items-center dropdown-item cursor-pointer\"\r\n        >\r\n          <div class=\"form-check\">\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"checkbox\"\r\n              [id]=\"i\"\r\n              [checked]=\"currentFilterSelectedIds.has(col.id || col._id || col)\"\r\n              (change)=\"toggleSelectionInFilter(col)\"\r\n            />\r\n            <label class=\"form-check-label fw-semibold\" [for]=\"i\">\r\n              {{ col?.value || col?.name || col }}\r\n            </label>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n    <div\r\n      class=\"d-flex justify-content-center gap-2 px-2 border-top\"\r\n      style=\"height: 38px\"\r\n    >\r\n      <button\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-outline-secondary btn-light border w-100 d-flex align-items-center justify-content-center mt-1 btn-light\"\r\n        (click)=\"$event.stopPropagation(); resetFilterChanges()\"\r\n      >\r\n        <span>Cancel</span>\r\n      </button>\r\n      <button\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center mt-1\"\r\n        (click)=\"applyDropdownFilter()\"\r\n      >\r\n        <span style=\"margin-top: -2px\">Save</span>\r\n      </button>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- For Text fields and number fields-->\r\n\r\n  <div\r\n    @slideToggle\r\n    *ngIf=\"\r\n      isFilterOpen &&\r\n      (selectedColumnForFilter.type == 'string' ||\r\n        selectedColumnForFilter.type == 'number' ||\r\n        selectedColumnForFilter.type == 'date')\r\n    \"\r\n    (click)=\"$event.stopPropagation()\"\r\n    class=\"shadow actions-dropdown mt-1 show shadow custom-menu table-layout filter-columns pb-2\"\r\n    style=\"width: 210px; right: unset; max-width: 230px\"\r\n    [style.backgroundColor]=\"checkboxesBackgroundColor\"\r\n  >\r\n    <div class=\"px-3 border-below py-1 pb-2 d-flex ps-1\">\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/arrow-left.svg'\"\r\n        (click)=\"toggleActions('filter-columns'); isActiveFilterOpen = false\"\r\n        class=\"data-grid-svg-icon me-2 cursor-pointer\"\r\n      ></span\r\n      ><b>{{ selectedColumnForFilter?.header }}</b>\r\n    </div>\r\n    <div class=\"col-12 position-relative p-2 text-filter\">\r\n      <div class=\"mb-2\">\r\n        <select\r\n          class=\"form-select form-select-sm custom-select border\"\r\n          [(ngModel)]=\"firstCondition\"\r\n        >\r\n          <ng-container *ngIf=\"selectedColumnForFilter.type !== 'date'\">\r\n            <option value=\"contain\">Contains</option>\r\n             <option value=\"does_not_contain\">Does Not Contain</option>\r\n            <option value=\"equal\">Equals</option>\r\n            <option value=\"before\">Starts With</option>\r\n            <option value=\"after\">Ends With</option>\r\n          </ng-container>\r\n\r\n          <ng-container *ngIf=\"selectedColumnForFilter.type == 'date'\">\r\n            <option value=\"equal\">Equals To</option>\r\n             <option value=\"not_equal\">Not Equal</option>\r\n            <option value=\"after\">After</option>\r\n            <option value=\"before\">Before</option>\r\n          </ng-container>\r\n        </select>\r\n      </div>\r\n      <div class=\"mb-2\">\r\n        <input\r\n          class=\"form-control form-control-sm\"\r\n          placeholder=\"Enter first value\"\r\n          type=\"search\"\r\n          [type]=\"\r\n            selectedColumnForFilter.type == 'string'\r\n              ? 'text'\r\n              : selectedColumnForFilter.type\r\n          \"\r\n          [(ngModel)]=\"firstValue\"\r\n          (keydown.enter)=\"applyDropdownFilter()\"\r\n        />\r\n      </div>\r\n      <div>\r\n        <div class=\"d-flex my-3 d-flex flex-row\" style=\"font-size: 14px\">\r\n          <div\r\n            class=\"form-check form-check-inline col-4 m-0 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"radio\"\r\n              id=\"logicalAnd\"\r\n              name=\"logicalOperator\"\r\n              value=\"and\"\r\n              [(ngModel)]=\"condition\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"logicalAnd\"\r\n              >AND</label\r\n            >\r\n          </div>\r\n\r\n          <div\r\n            class=\"form-check form-check-inline col-4 m-0 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"radio\"\r\n              id=\"logicalOr\"\r\n              name=\"logicalOperator\"\r\n              value=\"or\"\r\n              [(ngModel)]=\"condition\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"logicalOr\">OR</label>\r\n          </div>\r\n\r\n          <div\r\n            class=\"form-check form-check-inline col-4 m-0 d-flex align-items-center gap-1\"\r\n          >\r\n            <input\r\n              class=\"form-check-input\"\r\n              type=\"radio\"\r\n              id=\"logicalNone\"\r\n              name=\"logicalOperator\"\r\n              value=\"none\"\r\n              [(ngModel)]=\"condition\"\r\n            />\r\n            <label class=\"form-check-label mb-0 mt-1\" for=\"logicalNone\"\r\n              >None</label\r\n            >\r\n          </div>\r\n        </div>\r\n\r\n        <ng-container *ngIf=\"condition !== 'none' && firstValue\">\r\n          <div class=\"mb-2 mt-3\">\r\n            <!-- Second condition select -->\r\n            <select\r\n              class=\"form-select form-select-sm border\"\r\n              [(ngModel)]=\"secondCondition\"\r\n            >\r\n              <ng-container *ngIf=\"selectedColumnForFilter.type !== 'date'\">\r\n                <option value=\"contain\">Contains</option>\r\n                <option value=\"does_not_contain\">Does Not Contain</option>\r\n                <option value=\"equal\">Equals</option>\r\n                <option value=\"before\">Starts With</option>\r\n                <option value=\"after\">Ends With</option>\r\n              </ng-container>\r\n\r\n              <ng-container *ngIf=\"selectedColumnForFilter.type == 'date'\">\r\n                <option value=\"equal\">Equals To</option>\r\n                <option value=\"not_equal\">Not Equal</option>\r\n                <option value=\"after\">After</option>\r\n                <option value=\"before\">Before</option>\r\n              </ng-container>\r\n            </select>\r\n          </div>\r\n\r\n          <div class=\"mb-2\">\r\n            <!-- Second value input -->\r\n            <input\r\n              [type]=\"\r\n                selectedColumnForFilter.type == 'string'\r\n                  ? 'text'\r\n                  : selectedColumnForFilter.type\r\n              \"\r\n              class=\"form-control form-control-sm\"\r\n              placeholder=\"Enter second value\"\r\n              type=\"search\"\r\n              [(ngModel)]=\"secondValue\"\r\n              (keydown.enter)=\"applyDropdownFilter()\"\r\n            />\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n\r\n    <div\r\n      class=\"d-flex justify-content-center gap-2 px-2 border-top\"\r\n      style=\"height: 38px\"\r\n    >\r\n      <button\r\n        [disabled]=\"!currentFilterSelectedIds?.size && !firstValue\"\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-outline-secondary btn-light border w-100 d-flex align-items-center justify-content-center mt-1 btn-light\"\r\n        (click)=\"$event.stopPropagation(); resetTextFilterChanges()\"\r\n      >\r\n        <span>Cancel</span>\r\n      </button>\r\n      <button\r\n        [disabled]=\"(currentFilterSelectedIds?.size === 0 && !firstValue) || (condition !== 'none' && !secondValue)\"\r\n        type=\"button\"\r\n        style=\"height: 32px\"\r\n        class=\"btn btn-primary w-100 d-flex align-items-center justify-content-center mt-1\"\r\n        (click)=\"applyDropdownFilter()\"\r\n      >\r\n        <span style=\"margin-top: -2px\">Apply</span>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Edit dropdown here -->\r\n<ng-template let-col>\r\n  <div class=\"drop-down-edit\"></div>\r\n</ng-template>\r\n\r\n<ng-template\r\n  #fullTextTemplate\r\n  let-row=\"row\"\r\n  let-col=\"col\"\r\n  let-isArray=\"isArray\"\r\n>\r\n  <div\r\n    class=\"full-text-box\"\r\n    (dblclick)=\"$event.stopPropagation(); $event.preventDefault()\"\r\n    (click)=\"$event.stopPropagation(); $event.preventDefault()\"\r\n    [style.maxHeight.px]=\"dataGridContainer.offsetHeight / 2\"\r\n  >\r\n    <ng-container *ngIf=\"!isEditing(row, col)\">\r\n      <div\r\n        *ngIf=\"!isArray\"\r\n        class=\"full-text-content\"\r\n        [style.maxHeight.px]=\"dataGridContainer.offsetHeight / 2\"\r\n        (dblclick)=\"\r\n          $event.stopPropagation();\r\n          $event.preventDefault();\r\n          enableEdit(row, col, true)\r\n        \"\r\n        (click)=\"$event.stopPropagation(); $event.preventDefault()\"\r\n      >\r\n        {{\r\n          getNestedValue(row, col.field)?.value ||\r\n            getNestedValue(row, col.field)?.name ||\r\n            getNestedValue(row, col.field)\r\n        }}\r\n      </div>\r\n      <div *ngIf=\"isArray\">\r\n        <ul>\r\n          <ng-container\r\n            *ngFor=\"let item of getNestedValue(row, col.field); let i = index\"\r\n          >\r\n            <li *ngIf=\"i !== 0\">\r\n              <ng-container>\r\n                {{\r\n                  item?.department_name ||\r\n                    item?.roleName ||\r\n                    item?.full_name ||\r\n                    \"-\"\r\n                }}\r\n              </ng-container>\r\n            </li>\r\n          </ng-container>\r\n        </ul>\r\n      </div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"isEditing(row, col)\">\r\n      <textarea\r\n        (dblclick)=\"\r\n          $event.stopPropagation();\r\n          $event.preventDefault();\r\n          enableEdit(row, col, true)\r\n        \"\r\n        #textModel=\"ngModel\"\r\n        rows=\"4\"\r\n        #textAreadInput\r\n        [(ngModel)]=\"row[col.field]\"\r\n        name=\"{{ col.field }}\"\r\n        required\r\n        (blur)=\"disableEdit(row, col, textModel)\"\r\n        (keydown.enter)=\"textAreadInput.blur()\"\r\n        autofocus\r\n        class=\"form-control\"\r\n        [ngClass]=\"{\r\n          'is-invalid': textModel.invalid\r\n        }\"\r\n        (mousedown)=\"$event.stopPropagation()\"\r\n      ></textarea>\r\n    </ng-container>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #defaultImagePlaceholder let-row=\"row\" let-col=\"col\">\r\n  <span\r\n    class=\"px-2 d-flex w-100 cell-content image-placeholder\"\r\n    [title]=\"row?.full_name || row?.name || 'N/A'\"\r\n  >\r\n    <ng-container\r\n      *ngIf=\"\r\n        row?.logo ||\r\n          row?.assetImage ||\r\n          row?.invoice?.invoice_image ||\r\n          row?.invoice_image;\r\n        else placeholder\r\n      \"\r\n    >\r\n      <span\r\n        (click)=\"fullscreenImage = row?.profile_pictures?.[4]?.path ||\r\n            row?.logo ||\r\n            row?.assetImage ||\r\n            row?.invoice_image\"\r\n        class=\"pic\"\r\n        [style.width.px]=\"rowHeight - 10\"\r\n        [style.height.px]=\"rowHeight - 10\"\r\n        [class.assets-pic]=\"gridType == 'Assets'\"\r\n      >\r\n        <img\r\n          [width]=\"rowHeight - 12\"\r\n          [height]=\"rowHeight - 12\"\r\n          [style.width.px]=\"rowHeight - 10\"\r\n          [style.height.px]=\"rowHeight - 10\"\r\n          [src]=\"\r\n            row?.profile_pictures?.[4]?.path ||\r\n            row?.logo ||\r\n            row?.assetImage ||\r\n            row?.invoice_image\r\n          \"\r\n          alt=\"icon\"\r\n          class=\"option-icon\"\r\n          loading=\"lazy\"\r\n        />\r\n      </span>\r\n    </ng-container>\r\n    <!-- <div\r\n      class=\"fullscreen-overlay\"\r\n      *ngIf=\"fullscreenImage\"\r\n      (click)=\"fullscreenImage = null\"\r\n    >\r\n      <img [src]=\"fullscreenImage\" class=\"fullscreen-img\" />\r\n    </div> -->\r\n\r\n    <ng-template #placeholder>\r\n      <span\r\n        [ngClass]=\"getDynamicClass(row?.full_name || row?.name)\"\r\n        class=\"pic d-flex align-items-center rounded-circle\"\r\n        [style.width.px]=\"rowHeight - 12\"\r\n        [style.height.px]=\"rowHeight - 12\"\r\n        [style.fontSize.px]=\"rowHeight / 3\"\r\n        [class.assets-pic]=\"gridType == 'Assets'\"\r\n      >\r\n        {{ getInitials(row?.full_name) }}\r\n      </span>\r\n    </ng-template>\r\n  </span>\r\n</ng-template>\r\n\r\n<!-- Right Click Menue -->\r\n<div\r\n  [class.invisible]=\"!positionedYet\"\r\n  class=\"context-menu p-2\"\r\n  *ngIf=\"actionHide && actions?.length\"\r\n  [ngStyle]=\"{ 'top.px': yPos, 'left.px': xPos }\"\r\n  [class.show]=\"isVisible\"\r\n  appendTo=\"body\"\r\n>\r\n  <ul>\r\n    <li\r\n      *ngFor=\"let action of actions\"\r\n      class=\"rounded d-flex align-items-center\"\r\n      (click)=\"onActionClick(action)\"\r\n    >\r\n      <span\r\n        [inlineSVG]=\"singleSpaAssetsPath + 'data-grid/icons/' + action + '.svg'\"\r\n        class=\"data-grid-svg-icon right-click-menu-icons me-2\"\r\n      ></span>\r\n      <span class=\"text-capitalize fw-500\">{{ action }}</span>\r\n    </li>\r\n  </ul>\r\n</div>\r\n\r\n<!-- Details Toggle from bottom -->\r\n\r\n<ng-template #nestedTableTemplate let-row>\r\n  <div\r\n    class=\"nested-table table table-sm w-100 mb-0 center-nested-table w-100\"\r\n    style=\"table-layout: fixed !important\"\r\n    #nestedTableContainer\r\n  >\r\n    <thead\r\n      #nestedHeader\r\n      [style.backgroundColor]=\"nestedTableHeaderBackgroundColor\"\r\n    >\r\n      <div\r\n        cdkDropList\r\n        [cdkDropListData]=\"row?.detail.columns\"\r\n        cdkDropListOrientation=\"horizontal\"\r\n        (cdkDropListDropped)=\"dropColumn($event, row)\"\r\n        (cdkDropListSorted)=\"onNestedColSort($event, previewNestedCols)\"\r\n        [style.height.px]=\"nestedTableHeaderRowHeight\"\r\n        class=\"d-flex tr border-below\"\r\n      >\r\n        <div\r\n          *ngFor=\"let col of row.detail.columns; let i = index\"\r\n          [style.width.px]=\"col?.width || 250\"\r\n          [style.minWidth.px]=\"col?.width || 250\"\r\n          [style.maxWidth.px]=\"col?.width || 250\"\r\n          class=\"px-4 th\"\r\n          [attr.data-field]=\"col.field\"\r\n          [style.backgroundColor]=\"nestedTableHeaderBackgroundColor\"\r\n          cdkDrag\r\n        >\r\n          <div\r\n            class=\"d-flex h-100 justify-content-between position-relative align-items-center\"\r\n          >\r\n            <div class=\"text-ellipsis\" (click)=\"sortNestedCol(col, row)\">\r\n              {{ col.header }}\r\n            </div>\r\n            <div class=\"d-flex gap-2\">\r\n              <span\r\n                *ngIf=\"currentSubSortColumn == col.field\"\r\n                [inlineSVG]=\"\r\n                  singleSpaAssetsPath +\r\n                  (col?.order_by == 'desc'\r\n                    ? 'data-grid/icons/sort-desc.svg'\r\n                    : 'data-grid/icons/sort-asc.svg')\r\n                \"\r\n                class=\"data-grid-svg-icon d-flex justify-content-center align-items-center ms-2 start-50\"\r\n              >\r\n              </span>\r\n              <!-- <div\r\n                class=\"three-dots p-1\"\r\n                (click)=\"openThreeDotsMenu($event, col)\"\r\n                style=\"cursor: pointer\"\r\n              >\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath +\r\n                    'data-grid/icons/three-dots-vertical.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div> -->\r\n\r\n              <!-- Only show menu if this column is active -->\r\n              <div\r\n                class=\"position-absolute\"\r\n                *ngIf=\"activeCol === col\"\r\n                style=\"top: -50%; z-index: 21; left: 0\"\r\n              >\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    columnMenu;\r\n                    context: {\r\n                      col: col,\r\n                      isNestedTable: true,\r\n                      columns: row?.detail.columns\r\n                    }\r\n                  \"\r\n                ></ng-container>\r\n              </div>\r\n              <div\r\n                class=\"resize-handle\"\r\n                (click)=\"$event.stopPropagation()\"\r\n                (mousedown)=\"\r\n                  $event.preventDefault();\r\n                  onResizeColumn($event, col);\r\n                  $event.stopPropagation()\r\n                \"\r\n              >\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/resize-handle.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <ng-template cdkDragPreview>\r\n            <div class=\"p-2 border d-flex gap-2\">\r\n              <div>\r\n                <span\r\n                  [inlineSVG]=\"\r\n                    singleSpaAssetsPath + 'data-grid/icons/arrows-move.svg'\r\n                  \"\r\n                  class=\"data-grid-svg-icon d-flex justify-content-center align-items-center\"\r\n                ></span>\r\n              </div>\r\n              <div>{{ col.header }}</div>\r\n            </div>\r\n          </ng-template>\r\n        </div>\r\n      </div>\r\n    </thead>\r\n    <div\r\n      [style.width.px]=\"nestedHeader.offsetWidth - 10\"\r\n      [style.minWidth.px]=\"nestedHeader.offsetWidth - 10\"\r\n    >\r\n      <cdk-virtual-scroll-viewport\r\n        [itemSize]=\"nestedTablerowHeight\"\r\n        class=\"viewport\"\r\n        [style.height.px]=\"\r\n          (row?.detail?.result?.length < 5\r\n            ? nestedTablerowHeight * row?.detail?.result?.length + 40\r\n            : 300) + (hasHorizontalScroll ? -12 : 1)\r\n        \"\r\n        [style.width.px]=\"nestedHeader.offsetWidth - 10\"\r\n        [style.minWidth.px]=\"nestedHeader.offsetWidth - 10\"\r\n      >\r\n        <div\r\n          class=\"cursor-pointer border-below d-flex tr\"\r\n          *cdkVirtualFor=\"let d of row?.detail?.result; trackBy: trackById\"\r\n          [style.height.px]=\"nestedTablerowHeight\"\r\n          [style.width.px]=\"nestedHeader?.offsetWidth\"\r\n          [style.minWidth.px]=\"nestedHeader?.offsetWidth\"\r\n          [style.backgroundColor]=\"bodyBackgroundColor\"\r\n          (contextmenu)=\"onRightClick($event, d)\"\r\n        >\r\n          <div\r\n            class=\"px-4 py-0 td\"\r\n            *ngFor=\"let col of previewNestedCols; let j = index\"\r\n            [style.fontSize.px]=\"nestedTablerowFontsize\"\r\n            [attr.data-field]=\"col.field\"\r\n            [style.width.px]=\"col?.width || 250\"\r\n            [style.minWidth.px]=\"col?.width || 250\"\r\n            [style.maxWidth.px]=\"col?.width || 250\"\r\n          >\r\n            <div\r\n              [style.height.px]=\"nestedTablerowHeight - 1\"\r\n              [style.max-width.px]=\"col?.width\"\r\n              class=\"d-flex align-items-center\"\r\n            >\r\n              <!-- {{ d[col.field] || (col.is_amount ? 0 : \"-\") }} -->\r\n              <div\r\n                #cellText\r\n                class=\"text-ellipsis flex-grow-1\"\r\n                [title]=\"\r\n                  col.type === 'date'\r\n                    ? (getNestedValue(d, col.field) | date : dateFormat)\r\n                    : getNestedValue(d, col.field) || '-'\r\n                \"\r\n              >\r\n                <ng-container *ngIf=\"col.type !== 'image'\">\r\n                  <ng-container *ngIf=\"col.is_amount\">{{\r\n                    currencySymbol\r\n                  }}</ng-container>\r\n                  {{\r\n                          !isNestedValueArray(d, col.field)\r\n                            ? col.type === 'date'\r\n                              ? (isDate(getNestedValue(d, col.field))\r\n                                  ? (getNestedValue(d, col.field) | date: dateFormat)\r\n                                  : (getNestedValue(d, col.field)?.value ||\r\n                                    getNestedValue(d, col.field)?.name ||\r\n                                    getNestedValue(d, col.field) ||\r\n                                    '-'))\r\n                              : (getNestedValue(d, col.field)?.value ||\r\n                                getNestedValue(d, col.field)?.name ||\r\n                                getNestedValue(d, col.field) ||\r\n                                (col.is_amount ? 0: '-'))\r\n                            : (getNestedValue(d, col.field)?.[0]?.department_name ||\r\n                              getNestedValue(d, col.field)?.[0]?.roleName || getNestedValue(d, col.field)?.[0]?.full_name ||\r\n                              '-')\r\n                  }}\r\n                </ng-container>\r\n                <ng-container *ngIf=\"false\">\r\n                  {{ getTotalAmount(col) }}\r\n                </ng-container>\r\n                <ng-container *ngIf=\"col.type == 'image'\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      defaultImagePlaceholder;\r\n                      context: {\r\n                        row: d,\r\n                        col: col,\r\n                      }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </cdk-virtual-scroll-viewport>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #leftRightNestedPlaceholder let-row>\r\n  <table\r\n    class=\"nested-table table table-sm w-100 mb-0\"\r\n    [style.backgroundColor]=\"bodyBackgroundColor\"\r\n    [style.height.px]=\"\r\n      gridType == 'Assets'\r\n        ? (nestedTableContainer?.nativeElement?.offsetHeight ?? 0) + 12\r\n        : (taskManagementContainer?.nativeElement?.offsetHeight ?? 0)\r\n    \"\r\n  >\r\n    <!-- <div class=\"thead\">\r\n      <div\r\n        class=\"tr d-flex border-below\"\r\n        [style.height.px]=\"nestedTableHeaderRowHeight\"\r\n        [style.backgroundColor]=\"headerBackgroundColor\"\r\n      >\r\n        <div class=\"th\" *ngFor=\"let _ of [1, 2, 3, 4, 5]\"></div>\r\n      </div>\r\n    </div> -->\r\n    <!-- <div class=\"tbody\">\r\n      <div\r\n        class=\"tr border-below\"\r\n        [style.height.px]=\"nestedTablerowHeight\"\r\n        *ngFor=\"let _ of row?.detail?.result\"\r\n        [style.backgroundColor]=\"headerBackgroundColor\"\r\n      >\r\n        <div class=\"td\" *ngFor=\"let __ of [1, 2, 3, 4, 5]\" class=\"py-0\">\r\n          <span\r\n            [style.height.px]=\"nestedTablerowHeight\"\r\n            [style.max-width.px]=\"nestedTablerowHeight\"\r\n          ></span>\r\n        </div>\r\n      </div>\r\n    </div> -->\r\n  </table>\r\n</ng-template>\r\n\r\n<ng-template #taskManagementTemplate let-taskDetails=\"taskDetails\">\r\n  <div\r\n    class=\"p-4\"\r\n    #taskManagementContainer\r\n    [style.backgroundColor]=\"nestedTableHeaderBackgroundColor\"\r\n    [style.fontFaimly]=\"fontFaimly\"\r\n  >\r\n    <div class=\"d-flex justify-content-between\">\r\n      <div class=\"col-4\">\r\n        <div class=\"item-title\">Description</div>\r\n        <!-- <div class=\"item-content firstDiv\">\r\n        {{ taskDetails.description }}\r\n      </div> -->\r\n        <p\r\n          [style.fontSize]=\"bodyTextFontsSize\"\r\n          class=\"item-content firstDiv taskDescription pe-4\"\r\n          [innerHTML]=\"getSafeComment(taskDetails?.editor_description)\"\r\n          (click)=\"openFullImage($event)\"\r\n        ></p>\r\n      </div>\r\n      <div class=\"col-4\">\r\n        <div class=\"item-title\">Attachments</div>\r\n        <h5 *ngIf=\"taskDetails?.attachments?.length == 0\">\r\n          No Attachments found\r\n        </h5>\r\n        <div\r\n          *ngIf=\"taskDetails?.attachments?.length\"\r\n          class=\"item-content d-flex flex-wrap\"\r\n          style=\"gap: 10px\"\r\n        >\r\n          <a\r\n            *ngFor=\"let attachement of taskDetails?.attachments; let i = index\"\r\n            class=\"symbol-label fs-2 fw-semibold text-success cursor-pointer\"\r\n          >\r\n            <span\r\n              title=\"{{ taskDetails?.attachments_name[i] || 'Attachment' }}\"\r\n              (click)=\"downloadAttchment(attachement)\"\r\n              [inlineSVG]=\"\r\n                singleSpaAssetsPath +\r\n                'data-grid/document-icons/' +\r\n                getExtention(attachement) +\r\n                '.svg'\r\n              \"\r\n            >\r\n            </span>\r\n          </a>\r\n        </div>\r\n      </div>\r\n      <div class=\"col-4\">\r\n        <div class=\"item-title\">\r\n          Comments ({{ taskDetails?.comments?.length }})\r\n        </div>\r\n        <h5 *ngIf=\"taskDetails?.comments?.length == 0\">No Comments found</h5>\r\n        <div *ngIf=\"taskDetails?.comments?.length\" class=\"item-content\">\r\n          <div class=\"comment\" *ngFor=\"let comment of taskDetails.comments\">\r\n            <div class=\"d-flex align-items-center pe-3\">\r\n              <img\r\n                class=\"pic image-input-wrapper\"\r\n                [style.width.px]=\"rowHeight - 12\"\r\n                [style.height.px]=\"rowHeight - 12\"\r\n                *ngIf=\"comment?.comment_by.logo\"\r\n                src=\"{{ comment?.comment_by.logo }}\"\r\n                alt=\"{{ comment.comment_by.full_name }}\"\r\n              />\r\n              <!-- <app-default-image-placeholder *ngIf=\"!comment?.comment_by.logo\" title=\"{{ comment.comment_by.full_name }}\" [name]=\"comment.comment_by.full_name\"></app-default-image-placeholder> -->\r\n              <span\r\n                *ngIf=\"!comment?.comment_by.logo\"\r\n                [ngClass]=\"getDynamicClass(comment.comment_by.full_name)\"\r\n                class=\"pic d-flex align-items-center rounded-circle\"\r\n                [style.width.px]=\"rowHeight - 12\"\r\n                [style.height.px]=\"rowHeight - 12\"\r\n                [style.fontSize.px]=\"rowHeight / 3\"\r\n                title=\"{{ comment.comment_by.full_name }}\"\r\n              >\r\n                {{ getInitials(comment.comment_by.full_name) }}\r\n              </span>\r\n            </div>\r\n            <div>\r\n              <div class=\"comment-author fs-14px\">\r\n                {{ comment?.comment_by.full_name }}\r\n              </div>\r\n              <div\r\n                class=\"comment-content forCommentImg\"\r\n                [innerHTML]=\"getSafeComment(comment.comment)\"\r\n              ></div>\r\n              <div class=\"comment-timestamp\">\r\n                {{ comment.comment_date | date }}\r\n              </div>\r\n              <div class=\"comment-timestamp\">\r\n                Replies: ({{ comment.replies.length }})\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}