mis-crystal-design-system 18.2.0 → 18.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/datepicker_v2/tz-datepicker.directive.d.ts +2 -2
- package/daterangepicker_v2/tz-daterangepicker.directive.d.ts +2 -2
- package/esm2022/table/actions-cell/actions-cell.component.mjs +8 -3
- package/esm2022/table/table.component.mjs +2 -2
- package/fesm2022/mis-crystal-design-system-table.mjs +8 -3
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/package.json +7 -7
- package/specificdatepicker/tz-specificdatepicker.directive.d.ts +2 -2
|
@@ -12,8 +12,8 @@ export declare class TzDatepickerDirective implements OnInit {
|
|
|
12
12
|
selectedDate: import("@angular/core").InputSignal<string>;
|
|
13
13
|
datesDisabled: import("@angular/core").InputSignal<string[]>;
|
|
14
14
|
dateMessages: import("@angular/core").InputSignal<IDatePickerToastText[]>;
|
|
15
|
-
positionX: import("@angular/core").InputSignal<"start" | "
|
|
16
|
-
positionY: import("@angular/core").InputSignal<"
|
|
15
|
+
positionX: import("@angular/core").InputSignal<"start" | "center" | "end">;
|
|
16
|
+
positionY: import("@angular/core").InputSignal<"center" | "top" | "bottom">;
|
|
17
17
|
offsetX: import("@angular/core").InputSignal<number>;
|
|
18
18
|
offsetY: import("@angular/core").InputSignal<number>;
|
|
19
19
|
allowBookingOnDisabledDay: import("@angular/core").InputSignal<boolean>;
|
|
@@ -13,8 +13,8 @@ export declare class TzDaterangepickerDirective {
|
|
|
13
13
|
datesDisabled: import("@angular/core").InputSignal<string[]>;
|
|
14
14
|
selectedRangeLabel: import("@angular/core").InputSignal<string>;
|
|
15
15
|
dateMessages: import("@angular/core").InputSignal<IDatePickerToastText[]>;
|
|
16
|
-
positionX: import("@angular/core").InputSignal<"start" | "
|
|
17
|
-
positionY: import("@angular/core").InputSignal<"
|
|
16
|
+
positionX: import("@angular/core").InputSignal<"start" | "center" | "end">;
|
|
17
|
+
positionY: import("@angular/core").InputSignal<"center" | "top" | "bottom">;
|
|
18
18
|
offsetX: import("@angular/core").InputSignal<number>;
|
|
19
19
|
offsetY: import("@angular/core").InputSignal<number>;
|
|
20
20
|
dateChange: import("@angular/core").OutputEmitterRef<ISelectedDatesConfig>;
|
|
@@ -332,8 +332,13 @@ export class ActionsCellComponent {
|
|
|
332
332
|
}
|
|
333
333
|
}
|
|
334
334
|
onClick(event) {
|
|
335
|
-
|
|
336
|
-
|
|
335
|
+
let newValue;
|
|
336
|
+
if (this.actionType() === 'row-collapse') {
|
|
337
|
+
newValue = !this.currentState();
|
|
338
|
+
}
|
|
339
|
+
else {
|
|
340
|
+
newValue = event && typeof event === 'object' ? event.value : event;
|
|
341
|
+
}
|
|
337
342
|
this.currentState.set(newValue);
|
|
338
343
|
this.actionClick.emit({
|
|
339
344
|
actionType: this.actionType(),
|
|
@@ -387,4 +392,4 @@ export class ActionsCellComponent {
|
|
|
387
392
|
args: ["document:click"]
|
|
388
393
|
}] }); })();
|
|
389
394
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ActionsCellComponent, { className: "ActionsCellComponent" }); })();
|
|
390
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions-cell.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/table/actions-cell/actions-cell.component.ts","../../../../../projects/mis-components/table/actions-cell/actions-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, HostListener, ElementRef, ViewChild, TemplateRef, ViewContainerRef, OnDestroy, input, output, signal } from \"@angular/core\";\nimport { ConnectionPositionPair, Overlay, OverlayConfig, OverlayRef } from \"@angular/cdk/overlay\";\nimport { TemplatePortal } from \"@angular/cdk/portal\";\nimport { ActionItem } from \"../table.component\";\n\n@Component({\n  selector: \"mis-actions-cell\",\n  templateUrl: \"./actions-cell.component.html\",\n  styleUrl: \"./actions-cell.component.css\"\n})\nexport class ActionsCellComponent implements OnInit, OnDestroy {\n  cellData = input<any>();\n  config = input<any>();\n\n  actionClick = output<{ item?: ActionItem; data?: any, actionType?: string, value?: any }>();\n\n  @ViewChild('dropdownMenu', { static: false }) dropdownMenu: TemplateRef<any>;\n  @ViewChild('dropdownTrigger', { static: false }) dropdownTrigger: ElementRef;\n\n  isDropdownOpen = signal<boolean>(false);\n  actionItems = signal<ActionItem[]>([]);\n  actionType = signal<\"inline\" | \"dropdown\" | \"checkbox\" | \"row-collapse\">(\"inline\");\n  action = signal<((data: any) => void) | undefined>(undefined);\n  data = signal<any>(undefined);\n  disable = signal<((data: any) => boolean) | undefined>(undefined);\n  currentState = signal<boolean>(false);\n  private _style = signal<any>({});\n  containerStyle = signal<any>({});\n  private overlayRef: OverlayRef | null = null;\n\n  constructor(\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef\n  ) {}\n\n  ngOnInit(): void {\n    if (this.config()) {\n      this.actionItems.set(this.config().actionItems);\n      this.actionType.set(this.config().actionType);\n      this._style.set(this.config().style);\n      this.action.set(this.config().action);\n      this.disable.set(this.config().disable);\n      this.processStyle();\n    }\n  \n    if (this.cellData() !== null) {\n      const defaultStates: Record<string, boolean> = {\n        'checkbox': false,\n        'row-collapse': true,\n      };\n      if (this.actionType() in defaultStates) {\n        this.currentState.set(typeof this.cellData() === 'boolean' ? this.cellData() : defaultStates[this.actionType()]);\n      } else {\n        this.data.set(this.cellData());\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.closeDropdown();\n  }\n\n  private processStyle(): void {\n    // Remove width from style to avoid conflicts with table column width\n    const { width, ...restStyle } = this._style();\n    this.containerStyle.set(restStyle);\n  }\n\n  onActionClick(item: ActionItem, event: Event) {\n    event.stopPropagation();\n\n    // Check permissions before executing action\n    if (this.isDisabled(item)) return;\n\n    // Execute action only if permitted\n    if (item.action) {\n      item.action(this.data());\n    }\n\n    this.actionClick.emit({ item });\n  }\n\n  trackByAction(index: number, item: ActionItem): string {\n    return item.value;\n  }\n\n  isSvgFile(iconPath: string): boolean {\n    if (!iconPath) return false;\n    return iconPath.toLowerCase().includes(\".svg\") || iconPath.toLowerCase().includes(\"assets/icons/\");\n  }\n\n  @HostListener(\"document:click\")\n  onDocumentClick() {\n    if (this.isDropdownOpen()) {\n      this.closeDropdown();\n    }\n  }\n\n  toggleDropdown(event: Event) {\n    event.stopPropagation();\n    \n    if (this.isDropdownOpen()) {\n      this.closeDropdown();\n    } else {\n      this.openDropdown();\n    }\n  }\n\n  private openDropdown(): void {\n    if (!this.dropdownTrigger || !this.dropdownMenu) return;\n\n    // Close all submenus when opening main menu\n    this.actionItems().forEach((item: any) => (item.showSubmenu = false));\n\n    const positions = this.getDropdownPositions();\n    \n    const overlayConfig = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      positionStrategy: this.overlay\n        .position()\n        .flexibleConnectedTo(this.dropdownTrigger)\n        .withPositions(positions)\n        .withPush(true),\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\n    });\n\n    this.overlayRef = this.overlay.create(overlayConfig);\n    const portal = new TemplatePortal(this.dropdownMenu, this.viewContainerRef);\n    this.overlayRef.attach(portal);\n\n    this.overlayRef.backdropClick().subscribe(() => {\n      this.closeDropdown();\n    });\n\n    this.isDropdownOpen.set(true);\n  }\n\n  private closeDropdown(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n      this.overlayRef = null;\n    }\n    this.isDropdownOpen.set(false);\n  }\n\n  private getDropdownPositions(): ConnectionPositionPair[] {\n    // Use CDK Overlay's flexible positioning - it will automatically choose the best position\n    return [\n      // Primary position: below and aligned to end (right)\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'bottom' },\n        { overlayX: 'end', overlayY: 'top' },\n        0, 4\n      ),\n      // Fallback position: above and aligned to end (right)\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'top' },\n        { overlayX: 'end', overlayY: 'bottom' },\n        0, -4\n      ),\n      // Fallback position: below and aligned to start (left)\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'bottom' },\n        { overlayX: 'start', overlayY: 'top' },\n        0, 4\n      ),\n      // Fallback position: above and aligned to start (left)\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'start', overlayY: 'bottom' },\n        0, -4\n      )\n    ];\n  }\n\n  onDropdownItemClick(item: any, event: Event) {\n    event.stopPropagation();\n\n    if (this.isDisabled(item)) return;\n\n    if (item?.children?.length) {\n      // Toggle submenu\n      item.showSubmenu = !item.showSubmenu;\n      // Optionally close other submenus\n      this.actionItems().forEach((i: any) => {\n        if (i !== item) i.showSubmenu = false;\n      });\n    } else {\n      // Handle action\n      if (item.action) item.action(this.data());\n      this.actionClick.emit({ item, data: this.data() });\n      this.closeDropdown(); // Only close if action was executed\n    }\n  }\n\n  onClick(event?: any): void{\n    // Handle checkbox value - event might be {value: true} or just true\n    const newValue = event && typeof event === 'object' ? event.value : event;\n    this.currentState.set(newValue);\n    this.actionClick.emit({ \n      actionType: this.actionType(),\n      value: newValue\n    });\n  }\n\n  isDisabled(item: ActionItem): boolean {\n    if (typeof item.disable === \"function\") {\n      return item.disable(this.data());\n    }\n    return false;\n  }\n  \n}\n","<div class=\"actions-cell-container\" [ngStyle]=\"containerStyle()\">\n  <!-- Inline Actions -->\n  <div *ngIf=\"actionType() === 'inline'\" class=\"inline-actions\">\n    <div\n      *ngFor=\"let item of actionItems(); trackBy: trackByAction\"\n      class=\"action-item\"\n      [ngClass]=\"{ disabled: isDisabled(item) }\"\n      (click)=\"onActionClick(item, $event)\"\n    >\n      <img [src]=\"item.icon\" [alt]=\"item.label\" class=\"action-icon-svg\" />\n    </div>\n  </div>\n\n  <!-- Dropdown Actions -->\n  <div *ngIf=\"actionType() === 'dropdown'\" class=\"dropdown-actions\">\n    <div #dropdownTrigger class=\"dropdown-trigger\" (click)=\"toggleDropdown($event)\" title=\"More actions\">\n      <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n        <circle cx=\"10\" cy=\"4\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"10\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"16\" r=\"2\" fill=\"#333\" />\n      </svg>\n    </div>\n  </div>\n\n  <!-- Checkbox Actions -->\n  <div *ngIf=\"actionType() === 'checkbox'\" class=\"checkbox-actions\">\n    <mis-checkbox [checked]=\"currentState()\" (valueChange)=\"onClick($event)\" [disabled]=\"disable() ? disable()(data()) : false\"> </mis-checkbox>\n  </div>\n</div>\n\n<!-- Collapse / Expand Actions -->\n<div *ngIf=\"actionType() === 'row-collapse'\" class=\"collapse-toggle-action\">\n  <div class=\"collapse-icon\" (click)=\"onClick($event)\" [title]=\"currentState() ? 'Expand' : 'Collapse'\">\n    <svg *ngIf=\"currentState()\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\">\n      <path d=\"M7 10l5 5 5-5\" stroke=\"#0D1321\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n    </svg>\n    <svg *ngIf=\"!currentState()\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\">\n      <path d=\"M7 14l5-5 5 5\" stroke=\"#0D1321\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n    </svg>\n  </div>\n</div>\n\n<!-- CDK Overlay Template for Dropdown Menu -->\n<ng-template #dropdownMenu>\n  <div class=\"dropdown-menu-overlay\">\n    <div\n      class=\"dropdown-menu-item\"\n      *ngFor=\"let item of actionItems()\"\n      (click)=\"onDropdownItemClick(item, $event)\"\n      [ngClass]=\"{ disabled: isDisabled(item) }\"\n    >\n      <ng-container *ngIf=\"item.children?.length; else noChildren\">\n        <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n          <img [src]=\"item.icon\" />\n        </span>\n        <span class=\"dropdown-label\">{{ item.label }}</span>\n        <span class=\"submenu-arrow\">\n          <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\">\n            <path d=\"M9 6L15 12L9 18\" stroke=\"#0D1321\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n\n        <!-- DYNAMIC SUBMENU -->\n        <div class=\"dropdown-submenu\" *ngIf=\"item.showSubmenu\">\n          <div\n            class=\"dropdown-menu-item\"\n            *ngFor=\"let child of item.children\"\n            [ngClass]=\"{ disabled: isDisabled(child) }\"\n            (click)=\"onDropdownItemClick(child, $event)\"\n          >\n            <span class=\"dropdown-icon\" *ngIf=\"child.icon\">\n              <img [src]=\"child.icon\" />\n            </span>\n            <span class=\"dropdown-label\">{{ child.label }}</span>\n          </div>\n        </div>\n      </ng-container>\n\n      <ng-template #noChildren>\n        <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n          <img [src]=\"item.icon\" />\n        </span>\n        <span class=\"dropdown-label\">{{ item.label }}</span>\n      </ng-template>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
395
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions-cell.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/table/actions-cell/actions-cell.component.ts","../../../../../projects/mis-components/table/actions-cell/actions-cell.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,YAAY,EAAc,SAAS,EAA4C,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACxJ,OAAO,EAAE,sBAAsB,EAAW,aAAa,EAAc,MAAM,sBAAsB,CAAC;AAClG,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;;ICCjD,+BAKC;IADC,oNAAS,qCAA2B,KAAC;IAErC,0BAAoE;IACtE,iBAAM;;;;IAJJ,gFAA0C;IAGrC,cAAiB;IAAC,AAAlB,oDAAiB,sBAAmB;;;IAP7C,8BAA8D;IAC5D,2EAKC;IAGH,iBAAM;;;IAPe,cAAkB;IAAA,AAAlB,8CAAkB,sCAAsB;;;;IAW3D,AADF,+BAAkE,iBACqC;IAAtD,mLAAS,6BAAsB,KAAC;;IAC7E,+BAA4D;IAG1D,AADA,AADA,6BAA2C,iBACC,iBACA;IAGlD,AADE,AADE,iBAAM,EACF,EACF;;;;IAIJ,AADF,+BAAkE,uBAC4D;IAAnF,wMAAe,sBAAe,KAAC;IAC1E,AAD+H,iBAAe,EACxI;;;IADU,cAA0B;IAAiC,AAA3D,+CAA0B,wEAAmF;;;;IAO3H,+BAAuE;IACrE,2BAAuH;IACzH,iBAAM;;;;IACN,+BAAwE;IACtE,2BAAuH;IACzH,iBAAM;;;;IANR,AADF,+BAA4E,cAC4B;IAA3E,mLAAS,sBAAe,KAAC;IAIlD,AAHA,iFAAuE,oEAGC;IAI5E,AADE,iBAAM,EACF;;;IARiD,cAAgD;IAAhD,qEAAgD;IAC7F,cAAoB;IAApB,4CAAoB;IAGpB,cAAqB;IAArB,6CAAqB;;;IAgBvB,gCAA8C;IAC5C,0BAAyB;IAC3B,iBAAO;;;IADA,cAAiB;IAAjB,oDAAiB;;;IAiBpB,gCAA+C;IAC7C,0BAA0B;IAC5B,iBAAO;;;IADA,cAAkB;IAAlB,sDAAkB;;;;IAP3B,+BAKC;IADC,yPAAS,6CAAkC,KAAC;IAE5C,uHAA+C;IAG/C,gCAA6B;IAAA,YAAiB;IAChD,AADgD,iBAAO,EACjD;;;;IAPJ,kFAA2C;IAGd,cAAgB;IAAhB,qCAAgB;IAGhB,eAAiB;IAAjB,qCAAiB;;;IAVlD,+BAAuD;IACrD,+GAKC;IAMH,iBAAM;;;IATgB,cAAgB;IAAhB,0CAAgB;;;IAfxC,6BAA6D;IAC3D,2GAA8C;IAG9C,gCAA6B;IAAA,YAAgB;IAAA,iBAAO;IACpD,gCAA4B;;IAC1B,+BAA4D;IAC1D,2BAA6G;IAEjH,AADE,iBAAM,EACD;IAGP,yGAAuD;;;;IAX1B,cAAe;IAAf,mCAAe;IAGf,eAAgB;IAAhB,mCAAgB;IAQd,eAAsB;IAAtB,0CAAsB;;;IAgBrD,gCAA8C;IAC5C,0BAAyB;IAC3B,iBAAO;;;IADA,cAAiB;IAAjB,oDAAiB;;;IADxB,0GAA8C;IAG9C,gCAA6B;IAAA,YAAgB;IAAA,iBAAO;;;IAHvB,mCAAe;IAGf,eAAgB;IAAhB,mCAAgB;;;;IArCjD,+BAKC;IAFC,4NAAS,2CAAiC,KAAC;IA8B3C,AA3BA,4GAA6D,6HA2BpC;IAM3B,iBAAM;;;;;IAnCJ,gFAA0C;IAE3B,cAA6B;IAAA,AAA7B,gFAA6B,4BAAe;;;IAP/D,+BAAmC;IACjC,oFAKC;IAmCH,iBAAM;;;IAtCe,cAAgB;IAAhB,8CAAgB;;ADrCvC,MAAM,OAAO,oBAAoB;IAoB/B,YACU,OAAgB,EAChB,gBAAkC;QADlC,YAAO,GAAP,OAAO,CAAS;QAChB,qBAAgB,GAAhB,gBAAgB,CAAkB;QArB5C,aAAQ,GAAG,KAAK,EAAO,CAAC;QACxB,WAAM,GAAG,KAAK,EAAO,CAAC;QAEtB,gBAAW,GAAG,MAAM,EAAuE,CAAC;QAK5F,mBAAc,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QACxC,gBAAW,GAAG,MAAM,CAAe,EAAE,CAAC,CAAC;QACvC,eAAU,GAAG,MAAM,CAAsD,QAAQ,CAAC,CAAC;QACnF,WAAM,GAAG,MAAM,CAAoC,SAAS,CAAC,CAAC;QAC9D,SAAI,GAAG,MAAM,CAAM,SAAS,CAAC,CAAC;QAC9B,YAAO,GAAG,MAAM,CAAuC,SAAS,CAAC,CAAC;QAClE,iBAAY,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QAC9B,WAAM,GAAG,MAAM,CAAM,EAAE,CAAC,CAAC;QACjC,mBAAc,GAAG,MAAM,CAAM,EAAE,CAAC,CAAC;QACzB,eAAU,GAAsB,IAAI,CAAC;IAK1C,CAAC;IAEJ,QAAQ;QACN,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC;YAClB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,WAAW,CAAC,CAAC;YAChD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,CAAC;YAC9C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC;YACrC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC;YACtC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC;YACxC,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE,KAAK,IAAI,EAAE,CAAC;YAC7B,MAAM,aAAa,GAA4B;gBAC7C,UAAU,EAAE,KAAK;gBACjB,cAAc,EAAE,IAAI;aACrB,CAAC;YACF,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,aAAa,EAAE,CAAC;gBACvC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,IAAI,CAAC,QAAQ,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;YACnH,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YACjC,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAEO,YAAY;QAClB,qEAAqE;QACrE,MAAM,EAAE,KAAK,EAAE,GAAG,SAAS,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC9C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACrC,CAAC;IAED,aAAa,CAAC,IAAgB,EAAE,KAAY;QAC1C,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,4CAA4C;QAC5C,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YAAE,OAAO;QAElC,mCAAmC;QACnC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAC3B,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,aAAa,CAAC,KAAa,EAAE,IAAgB;QAC3C,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,SAAS,CAAC,QAAgB;QACxB,IAAI,CAAC,QAAQ;YAAE,OAAO,KAAK,CAAC;QAC5B,OAAO,QAAQ,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;IACrG,CAAC;IAGD,eAAe;QACb,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC;IACH,CAAC;IAED,cAAc,CAAC,KAAY;QACzB,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,OAAO;QAExD,4CAA4C;QAC5C,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC;QAEtE,MAAM,SAAS,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE9C,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC;YACtC,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,kCAAkC;YACjD,gBAAgB,EAAE,IAAI,CAAC,OAAO;iBAC3B,QAAQ,EAAE;iBACV,mBAAmB,CAAC,IAAI,CAAC,eAAe,CAAC;iBACzC,aAAa,CAAC,SAAS,CAAC;iBACxB,QAAQ,CAAC,IAAI,CAAC;YACjB,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE;SAC3D,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QACrD,MAAM,MAAM,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC5E,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAE/B,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7C,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAEO,aAAa;QACnB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACzB,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAEO,oBAAoB;QAC1B,0FAA0F;QAC1F,OAAO;YACL,qDAAqD;YACrD,IAAI,sBAAsB,CACxB,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,EACrC,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EACpC,CAAC,EAAE,CAAC,CACL;YACD,sDAAsD;YACtD,IAAI,sBAAsB,CACxB,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAClC,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,EACvC,CAAC,EAAE,CAAC,CAAC,CACN;YACD,uDAAuD;YACvD,IAAI,sBAAsB,CACxB,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,EACvC,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,EACtC,CAAC,EAAE,CAAC,CACL;YACD,uDAAuD;YACvD,IAAI,sBAAsB,CACxB,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EACpC,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,EACzC,CAAC,EAAE,CAAC,CAAC,CACN;SACF,CAAC;IACJ,CAAC;IAED,mBAAmB,CAAC,IAAS,EAAE,KAAY;QACzC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YAAE,OAAO;QAElC,IAAI,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;YAC3B,iBAAiB;YACjB,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;YACrC,kCAAkC;YAClC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,CAAC,CAAM,EAAE,EAAE;gBACpC,IAAI,CAAC,KAAK,IAAI;oBAAE,CAAC,CAAC,WAAW,GAAG,KAAK,CAAC;YACxC,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,gBAAgB;YAChB,IAAI,IAAI,CAAC,MAAM;gBAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YAC1C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YACnD,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,oCAAoC;QAC5D,CAAC;IACH,CAAC;IAED,OAAO,CAAC,KAAW;QACjB,IAAI,QAAiB,CAAC;QACtB,IAAI,IAAI,CAAC,UAAU,EAAE,KAAK,cAAc,EAAE,CAAC;YACzC,QAAQ,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;QAClC,CAAC;aAAM,CAAC;YACN,QAAQ,GAAG,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QACtE,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YACpB,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE;YAC7B,KAAK,EAAE,QAAQ;SAChB,CAAC,CAAC;IACL,CAAC;IAED,UAAU,CAAC,IAAgB;QACzB,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,UAAU,EAAE,CAAC;YACvC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QACnC,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;qHA9MU,oBAAoB;oEAApB,oBAAoB;;;;;;;;YAApB,yFAAA,qBAAiB,iCAAG;;YCVjC,8BAAiE;YAyB/D,AAXA,AAZA,qEAA8D,wDAYI,wDAWA;YAGpE,iBAAM;YAeN,AAZA,qEAA4E,yGAYjD;;YA3CS,8CAA4B;YAExD,cAA+B;YAA/B,oDAA+B;YAY/B,cAAiC;YAAjC,sDAAiC;YAWjC,cAAiC;YAAjC,sDAAiC;YAMnC,cAAqC;YAArC,0DAAqC;;;iFDrB9B,oBAAoB;cALhC,SAAS;2BACE,kBAAkB;uEAUkB,YAAY;kBAAzD,SAAS;mBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YACK,eAAe;kBAA/D,SAAS;mBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;YA2E/C,eAAe;kBADd,YAAY;mBAAC,gBAAgB;;kFAjFnB,oBAAoB","sourcesContent":["import { Component, OnInit, HostListener, ElementRef, ViewChild, TemplateRef, ViewContainerRef, OnDestroy, input, output, signal } from \"@angular/core\";\nimport { ConnectionPositionPair, Overlay, OverlayConfig, OverlayRef } from \"@angular/cdk/overlay\";\nimport { TemplatePortal } from \"@angular/cdk/portal\";\nimport { ActionItem } from \"../table.component\";\n\n@Component({\n  selector: \"mis-actions-cell\",\n  templateUrl: \"./actions-cell.component.html\",\n  styleUrl: \"./actions-cell.component.css\"\n})\nexport class ActionsCellComponent implements OnInit, OnDestroy {\n  cellData = input<any>();\n  config = input<any>();\n\n  actionClick = output<{ item?: ActionItem; data?: any, actionType?: string, value?: any }>();\n\n  @ViewChild('dropdownMenu', { static: false }) dropdownMenu: TemplateRef<any>;\n  @ViewChild('dropdownTrigger', { static: false }) dropdownTrigger: ElementRef;\n\n  isDropdownOpen = signal<boolean>(false);\n  actionItems = signal<ActionItem[]>([]);\n  actionType = signal<\"inline\" | \"dropdown\" | \"checkbox\" | \"row-collapse\">(\"inline\");\n  action = signal<((data: any) => void) | undefined>(undefined);\n  data = signal<any>(undefined);\n  disable = signal<((data: any) => boolean) | undefined>(undefined);\n  currentState = signal<boolean>(false);\n  private _style = signal<any>({});\n  containerStyle = signal<any>({});\n  private overlayRef: OverlayRef | null = null;\n\n  constructor(\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef\n  ) {}\n\n  ngOnInit(): void {\n    if (this.config()) {\n      this.actionItems.set(this.config().actionItems);\n      this.actionType.set(this.config().actionType);\n      this._style.set(this.config().style);\n      this.action.set(this.config().action);\n      this.disable.set(this.config().disable);\n      this.processStyle();\n    }\n  \n    if (this.cellData() !== null) {\n      const defaultStates: Record<string, boolean> = {\n        'checkbox': false,\n        'row-collapse': true,\n      };\n      if (this.actionType() in defaultStates) {\n        this.currentState.set(typeof this.cellData() === 'boolean' ? this.cellData() : defaultStates[this.actionType()]);\n      } else {\n        this.data.set(this.cellData());\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.closeDropdown();\n  }\n\n  private processStyle(): void {\n    // Remove width from style to avoid conflicts with table column width\n    const { width, ...restStyle } = this._style();\n    this.containerStyle.set(restStyle);\n  }\n\n  onActionClick(item: ActionItem, event: Event) {\n    event.stopPropagation();\n\n    // Check permissions before executing action\n    if (this.isDisabled(item)) return;\n\n    // Execute action only if permitted\n    if (item.action) {\n      item.action(this.data());\n    }\n\n    this.actionClick.emit({ item });\n  }\n\n  trackByAction(index: number, item: ActionItem): string {\n    return item.value;\n  }\n\n  isSvgFile(iconPath: string): boolean {\n    if (!iconPath) return false;\n    return iconPath.toLowerCase().includes(\".svg\") || iconPath.toLowerCase().includes(\"assets/icons/\");\n  }\n\n  @HostListener(\"document:click\")\n  onDocumentClick() {\n    if (this.isDropdownOpen()) {\n      this.closeDropdown();\n    }\n  }\n\n  toggleDropdown(event: Event) {\n    event.stopPropagation();\n    \n    if (this.isDropdownOpen()) {\n      this.closeDropdown();\n    } else {\n      this.openDropdown();\n    }\n  }\n\n  private openDropdown(): void {\n    if (!this.dropdownTrigger || !this.dropdownMenu) return;\n\n    // Close all submenus when opening main menu\n    this.actionItems().forEach((item: any) => (item.showSubmenu = false));\n\n    const positions = this.getDropdownPositions();\n    \n    const overlayConfig = new OverlayConfig({\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      positionStrategy: this.overlay\n        .position()\n        .flexibleConnectedTo(this.dropdownTrigger)\n        .withPositions(positions)\n        .withPush(true),\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\n    });\n\n    this.overlayRef = this.overlay.create(overlayConfig);\n    const portal = new TemplatePortal(this.dropdownMenu, this.viewContainerRef);\n    this.overlayRef.attach(portal);\n\n    this.overlayRef.backdropClick().subscribe(() => {\n      this.closeDropdown();\n    });\n\n    this.isDropdownOpen.set(true);\n  }\n\n  private closeDropdown(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n      this.overlayRef = null;\n    }\n    this.isDropdownOpen.set(false);\n  }\n\n  private getDropdownPositions(): ConnectionPositionPair[] {\n    // Use CDK Overlay's flexible positioning - it will automatically choose the best position\n    return [\n      // Primary position: below and aligned to end (right)\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'bottom' },\n        { overlayX: 'end', overlayY: 'top' },\n        0, 4\n      ),\n      // Fallback position: above and aligned to end (right)\n      new ConnectionPositionPair(\n        { originX: 'end', originY: 'top' },\n        { overlayX: 'end', overlayY: 'bottom' },\n        0, -4\n      ),\n      // Fallback position: below and aligned to start (left)\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'bottom' },\n        { overlayX: 'start', overlayY: 'top' },\n        0, 4\n      ),\n      // Fallback position: above and aligned to start (left)\n      new ConnectionPositionPair(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'start', overlayY: 'bottom' },\n        0, -4\n      )\n    ];\n  }\n\n  onDropdownItemClick(item: any, event: Event) {\n    event.stopPropagation();\n\n    if (this.isDisabled(item)) return;\n\n    if (item?.children?.length) {\n      // Toggle submenu\n      item.showSubmenu = !item.showSubmenu;\n      // Optionally close other submenus\n      this.actionItems().forEach((i: any) => {\n        if (i !== item) i.showSubmenu = false;\n      });\n    } else {\n      // Handle action\n      if (item.action) item.action(this.data());\n      this.actionClick.emit({ item, data: this.data() });\n      this.closeDropdown(); // Only close if action was executed\n    }\n  }\n\n  onClick(event?: any): void{\n    let newValue: boolean;\n    if (this.actionType() === 'row-collapse') {\n      newValue = !this.currentState();\n    } else {\n      newValue = event && typeof event === 'object' ? event.value : event;\n    }\n\n    this.currentState.set(newValue);\n    this.actionClick.emit({ \n      actionType: this.actionType(),\n      value: newValue\n    });\n  }\n\n  isDisabled(item: ActionItem): boolean {\n    if (typeof item.disable === \"function\") {\n      return item.disable(this.data());\n    }\n    return false;\n  }\n  \n}\n","<div class=\"actions-cell-container\" [ngStyle]=\"containerStyle()\">\n  <!-- Inline Actions -->\n  <div *ngIf=\"actionType() === 'inline'\" class=\"inline-actions\">\n    <div\n      *ngFor=\"let item of actionItems(); trackBy: trackByAction\"\n      class=\"action-item\"\n      [ngClass]=\"{ disabled: isDisabled(item) }\"\n      (click)=\"onActionClick(item, $event)\"\n    >\n      <img [src]=\"item.icon\" [alt]=\"item.label\" class=\"action-icon-svg\" />\n    </div>\n  </div>\n\n  <!-- Dropdown Actions -->\n  <div *ngIf=\"actionType() === 'dropdown'\" class=\"dropdown-actions\">\n    <div #dropdownTrigger class=\"dropdown-trigger\" (click)=\"toggleDropdown($event)\" title=\"More actions\">\n      <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n        <circle cx=\"10\" cy=\"4\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"10\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"16\" r=\"2\" fill=\"#333\" />\n      </svg>\n    </div>\n  </div>\n\n  <!-- Checkbox Actions -->\n  <div *ngIf=\"actionType() === 'checkbox'\" class=\"checkbox-actions\">\n    <mis-checkbox [checked]=\"currentState()\" (valueChange)=\"onClick($event)\" [disabled]=\"disable() ? disable()(data()) : false\"> </mis-checkbox>\n  </div>\n</div>\n\n<!-- Collapse / Expand Actions -->\n<div *ngIf=\"actionType() === 'row-collapse'\" class=\"collapse-toggle-action\">\n  <div class=\"collapse-icon\" (click)=\"onClick($event)\" [title]=\"currentState() ? 'Expand' : 'Collapse'\">\n    <svg *ngIf=\"currentState()\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\">\n      <path d=\"M7 10l5 5 5-5\" stroke=\"#0D1321\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n    </svg>\n    <svg *ngIf=\"!currentState()\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\">\n      <path d=\"M7 14l5-5 5 5\" stroke=\"#0D1321\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n    </svg>\n  </div>\n</div>\n\n<!-- CDK Overlay Template for Dropdown Menu -->\n<ng-template #dropdownMenu>\n  <div class=\"dropdown-menu-overlay\">\n    <div\n      class=\"dropdown-menu-item\"\n      *ngFor=\"let item of actionItems()\"\n      (click)=\"onDropdownItemClick(item, $event)\"\n      [ngClass]=\"{ disabled: isDisabled(item) }\"\n    >\n      <ng-container *ngIf=\"item.children?.length; else noChildren\">\n        <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n          <img [src]=\"item.icon\" />\n        </span>\n        <span class=\"dropdown-label\">{{ item.label }}</span>\n        <span class=\"submenu-arrow\">\n          <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\">\n            <path d=\"M9 6L15 12L9 18\" stroke=\"#0D1321\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n\n        <!-- DYNAMIC SUBMENU -->\n        <div class=\"dropdown-submenu\" *ngIf=\"item.showSubmenu\">\n          <div\n            class=\"dropdown-menu-item\"\n            *ngFor=\"let child of item.children\"\n            [ngClass]=\"{ disabled: isDisabled(child) }\"\n            (click)=\"onDropdownItemClick(child, $event)\"\n          >\n            <span class=\"dropdown-icon\" *ngIf=\"child.icon\">\n              <img [src]=\"child.icon\" />\n            </span>\n            <span class=\"dropdown-label\">{{ child.label }}</span>\n          </div>\n        </div>\n      </ng-container>\n\n      <ng-template #noChildren>\n        <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n          <img [src]=\"item.icon\" />\n        </span>\n        <span class=\"dropdown-label\">{{ item.label }}</span>\n      </ng-template>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -791,7 +791,7 @@ export class TableComponent {
|
|
|
791
791
|
else if (event.actionType === 'row-collapse') {
|
|
792
792
|
const rowCollapse = this.findActionConfig('row-collapse');
|
|
793
793
|
if (rowCollapse && this.tableData()[rowIndex]) {
|
|
794
|
-
|
|
794
|
+
this.tableData()[rowIndex][rowCollapse.index] = event.value;
|
|
795
795
|
rowCollapse.config.action?.(this.tableData());
|
|
796
796
|
this.buildExpandedMap();
|
|
797
797
|
}
|
|
@@ -915,4 +915,4 @@ export class TableComponent {
|
|
|
915
915
|
args: ["table"]
|
|
916
916
|
}] }); })();
|
|
917
917
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TableComponent, { className: "TableComponent" }); })();
|
|
918
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/table.component.ts","../../../../projects/mis-components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  OnChanges,\n  OnInit,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewChildren,\n  input,\n  output,\n  signal,\n  computed,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  untracked\n} from \"@angular/core\";\nimport { Filter, TableFilterComponent } from \"./filter/filter.component\";\nimport { SortState } from \"./sort-icons.directive\";\nimport { effect } from \"@angular/core\";\nimport { DropdownItem } from \"mis-crystal-design-system/dropdown\";\n\n@Component({\n  selector: \"mis-table\",\n  templateUrl: \"table.component.html\",\n  styleUrls: [\"table.component.css\"]\n})\nexport class TableComponent implements OnInit, AfterViewInit, OnChanges {\n  // Initialize with -1 to indicate no row is colored at the beginning\n  activeRowIndex = signal<number[]>([]);\n  hasCheckboxActions = signal<boolean>(false);\n  selectAllCheckbox = signal<boolean>(false);\n\n  // Filter related variables\n  showFilter = signal<boolean>(false);\n  filterName = signal<string>(\"\");\n  filterData = signal<Array<Filter>>([]);\n  filterContainerStyles = signal<any>({});\n  appliedFilters = signal<{ [key: string]: Array<{ name: string; value: string }> }>({});\n  \n  // Convert outputs to signal-based outputs\n  filtersUpdated = output<{\n    [key: string]: Array<{ name: string; value: string }>;\n  }>();\n\n  @ViewChild(\"filter\") filter: TableFilterComponent | any;\n  @ViewChildren(\"colHeaderRef\") colHeaders: QueryList<ElementRef> | any;\n\n  // Pagination related variables\n  pages = signal<Array<number>>([]);\n  tableLength = signal<number>(0);\n  selectedPage = signal<number>(1); // Internal state for selected page - this is the source of truth\n  private isInternalPageUpdate = false; // Flag to prevent effect from overwriting during user-initiated updates\n  \n  /**\n   * LEGACY CODE WORKAROUND: Track user-initiated page selections to prevent config overwrites.\n   * \n   * Some legacy parent components don't update tableConfig.paginationConfig.selectedPage when\n   * the page changes. This causes the effect to overwrite user selections with stale config values.\n   * \n   * IDEAL SOLUTION: Parent components should always update config.selectedPage in their\n   * pageSelected event handler. This workaround protects user actions until legacy code\n   * can be updated.\n   * \n   * TODO: Remove this workaround once all parent components properly update config.selectedPage\n   */\n  private userSelectedPage: number | null = null;\n  \n  pageSelected = output<number>();\n  pageSizeChanged = output<number>();\n  pageSizeOptions = computed(() => {\n    const config = this.tableConfig()?.paginationConfig;\n    if (!config?.pageSizes || !Array.isArray(config.pageSizes) || !config.pageSizes?.length) return [];\n  \n    return config.pageSizes?.map(option => ({\n      label: option?.toString() || '',\n      value: option?.toString() || '',\n    })) || [];\n  });\n\n  showPageSizeDropdown = computed(() => {\n    return !!this.tableConfig()?.paginationConfig?.showPageSizeDropdown;\n  });\n\n  selectedPageSizeOption = signal<DropdownItem>({ label: \"\", value: \"\" });\n\n  // Convert inputs to signal-based inputs\n  tableConfig = input<TableConfig>();\n  subTableconfig = input<TableConfig>();\n  tableDataLoading = input<boolean>();\n  expandedIndex = input<number>();\n  tableData = input<Array<Array<any>>>([]);\n  subTableData = input<Array<Array<any>>>([]);\n  subTableDataLoading = input<boolean>();\n  currentSort = input<{column: string, direction: 'ASC' | 'DESC' | ''} | null>();\n  @ViewChild(\"table\") table: ElementRef | any;\n  collapseColIndex = signal<number>(-1);\n  previewLines = signal<number>(0);\n  rowCollapseConfigIndex = signal<number>(-1);\n  expandedMap = signal<Record<string, boolean>>({});\n\n\n  // Sorting related properties\n  multiColumnSort = signal<SortState[]>([]);\n  sortChange = output<SortState>();\n  headerAction = output<{ type: string; payload?: any }>();\n\n  \n  constructor(private renderer: Renderer2) {\n    effect(() => {\n        this.tableLength.set(this.tableData()?.length ?? 0);\n        \n        const config = this.tableConfig();\n        \n        if (config && config.activeRowIndex !== null && config.activeRowIndex !== undefined) {\n            const activeRowIndex = config.activeRowIndex;\n            this.activeRowIndex.set(Array.isArray(activeRowIndex) ? activeRowIndex : [activeRowIndex]);\n        }\n\n        if (this.rowCollapseConfigIndex() !== -1) {\n             this.buildExpandedMap();\n        }\n\n        // --- PAGINATION PAGE ARRAY LOGIC (MOVED/REPLACED initializePagination) ---\n        const len = config?.paginationConfig?.noOfPages;\n        const disablePageJumping = config?.paginationConfig?.disablePageJumping;\n        \n        /**\n         * LEGACY CODE WORKAROUND: Protect user-initiated page selections from config overwrites.\n         * \n         * When users click pagination arrows, we update internal state immediately. However,\n         * some legacy parent components don't update config.selectedPage, causing the effect\n         * to run with stale config values that would overwrite the user's selection.\n         * \n         * Strategy: Treat internal state as source of truth for user-initiated changes.\n         * Only sync from config when it's safe (not a user-selected page).\n         * \n         * IDEAL: Parent should always update config.selectedPage in pageSelected handler.\n         */\n        const currentSelectedPage = this.selectedPage();\n        const configSelectedPage = config?.paginationConfig?.selectedPage;\n        const isUserSelectedPage = this.userSelectedPage !== null && currentSelectedPage === this.userSelectedPage;\n        \n        if (!this.isInternalPageUpdate) {\n          // Only sync from config if:\n          // 1. Config has a selectedPage value\n          // 2. Current page is NOT a user-initiated selection (protect user actions)\n          // 3. Config value is valid and different from current\n          if (configSelectedPage !== undefined && configSelectedPage !== null && !isUserSelectedPage) {\n            const maxPages = config?.paginationConfig?.noOfPages || 1;\n            if (currentSelectedPage !== configSelectedPage && \n                configSelectedPage >= 1 && \n                configSelectedPage <= maxPages) {\n              this.selectedPage.set(configSelectedPage);\n            }\n          }\n          \n          // If config doesn't have selectedPage, only initialize invalid state\n          // Never reset a valid page number, especially user-selected ones\n          if ((configSelectedPage === undefined || configSelectedPage === null) && \n              !isUserSelectedPage &&\n              (currentSelectedPage === 0 || currentSelectedPage < 1)) {\n            this.selectedPage.set(1);\n          }\n          \n          // Clear user selection tracking when config matches user's selection\n          // This indicates parent has updated config correctly\n          if (configSelectedPage === this.userSelectedPage) {\n            this.userSelectedPage = null;\n          }\n        }\n        \n        // Reset the flag after processing\n        this.isInternalPageUpdate = false;\n        \n        // Only run if pagination is configured and page jumping is enabled\n        if (len && len > 0 && !disablePageJumping) {\n            // Read the internal state of the selected page for calculating the pages array.\n            // Since this runs on every config change, we rely on the value set \n            // by updateSelectedPage() or synced from config above.\n            const pageNumber = this.selectedPage(); \n\n            if (len <= 7) {\n                const newPages = [];\n                for (let i = 1; i <= len; i++) {\n                    newPages.push(i);\n                }\n                this.pages.set(newPages);\n            } else {\n                if (pageNumber - 2 <= 1) {\n                    this.pages.set([1, 2, 3, 4, 0, len]);\n                } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n                    this.pages.set([1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len]);\n                } else if (pageNumber + 2 >= len) {\n                    this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);\n                }\n            }\n        }\n        // --- END PAGINATION PAGE ARRAY LOGIC ---\n\n        \n        if(config?.paginationConfig?.showPageSizeDropdown) {\n          const options = this.pageSizeOptions();\n          const rowsPerPage = this.tableConfig()?.paginationConfig?.rowsPerPage;\n          \n          if (!Array.isArray(options) || !rowsPerPage) {\n            this.selectedPageSizeOption.set({ label: \"\", value: \"\" });\n            return;\n          }\n          \n          const selected = options.find(opt => opt?.value === rowsPerPage.toString());\n          if (selected) {\n            this.selectedPageSizeOption.set(selected);\n          } else if (options.length > 0) {\n            // If configured rowsPerPage is not among options, pick the floor value and notify parent\n            const target = Number(rowsPerPage);\n            //Sort the options\n            const sorted = options\n              .map(opt => ({ opt, num: Number(opt?.value) }))\n              .filter(({ num }) => Number.isFinite(num))\n              .sort((a, b) => a.num - b.num);\n\n            let floorOption = sorted[0]?.opt;\n            for (let i = sorted.length - 1; i >= 0; i--) {\n              if (sorted[i].num <= target) {\n                floorOption = sorted[i].opt;\n                break;\n              }\n            }\n            console.error(\"The configured rowsPerPage was not matched to any of the pageSizes sent in the paginationConfig. Selecting the nearest floor value among the available pageSizes.\");\n            this.selectedPageSizeOption.set(floorOption);\n            this.onPageSizeChange(floorOption);\n          } else {\n            console.error(\"No page size options available.\")\n          }\n        }\n    }, { allowSignalWrites: true });\n\n    // Reactive height calculation: maintains exact old behavior for backward compatibility\n    // Old code: height - 56 + \"px\" (flawed for percentages, but we maintain it)\n    // Note: Effect must be in constructor, not lifecycle hooks (NG0203 error otherwise)\n    // effect(() => {\n    //   const config = this.tableConfig();\n    //   if (!config?.paginationConfig || !this.table?.nativeElement) return;\n    \n    //   const height = config.height;\n    //   // Old behavior: height - 56 + \"px\" (maintains the flaw for backward compatibility)\n    //   const result = (height as any) - 56;\n    //   const finalHeight = result + \"px\";\n    //   this.renderer.setStyle(this.table.nativeElement, \"height\", finalHeight);\n    // });\n  }\n\n\n  // Function to handle row click\n  selectRow(index: number) {\n    if (this.hasCheckboxActions()) return;\n    this.activeRowIndex.set([index]); // Set the selected index to the clicked row's index\n    !!this.tableConfig().rowConfig.action && this.tableConfig().rowConfig.action(index);\n  }\n\n  ngOnInit(): void {\n    this.hasCheckboxActions.set(this.tableConfig().colConfig?.some(col => col.type === \"actions\" && col.actionType === \"checkbox\"));\n    this.tableLength.set(!!this.tableData() ? this.tableData().length : 0);\n    this.initializeFilters();\n    if (this.tableConfig().paginationConfig) {\n      this.initializePagination();\n    }\n    if (this.tableConfig().canScrollHorizontally === undefined) {\n      // Note: We can't directly modify input signals, this should be handled by parent component\n    }\n    document.addEventListener(\"click\", event => {\n      if (this.filter) {\n        let isCheckBoxClicked = true;\n        let targetElement = event.target as HTMLSpanElement;\n        if (targetElement.className === \"checkmark\") {\n          isCheckBoxClicked = true;\n          this.showFilter.set(true);\n        }\n        let isClickInsideElement = this.filter.container.nativeElement.contains(event.target);\n        if (!isClickInsideElement && !isCheckBoxClicked) {\n          this.toggleFilter(this.filterName());\n        }\n      }\n    });\n\n    // fetch collapseColIndex and previewLines if present\n    this.rowCollapseConfigIndex.set(this.tableConfig()?.colConfig?.findIndex(\n      col => col.type === 'actions' && col.actionType === 'row-collapse'\n    ));\n    if (this.rowCollapseConfigIndex() !== -1) {\n      this.collapseColIndex.set(this.tableConfig().colConfig[this.rowCollapseConfigIndex()].collapseColumnIndex ?? null);\n      this.previewLines.set(this.tableConfig().colConfig[this.rowCollapseConfigIndex()].previewLines ?? null);\n      this.buildExpandedMap();\n    }\n  }\n\n  buildExpandedMap(): void{\n    const newExpandedMap: Record<string, boolean> = {};\n    const collapseIndex = this.rowCollapseConfigIndex();\n    \n    this.tableData().forEach((row, rowIndex) => {\n        newExpandedMap[`${rowIndex}`] = row[collapseIndex];\n    });\n    this.expandedMap.set(newExpandedMap);\n}\n\n  ngAfterViewInit() {\n    // ViewChild is now available - manually trigger height calculation once\n    // The effect in constructor will handle subsequent config changes\n    const config = this.tableConfig();\n    if (config?.paginationConfig && this.table?.nativeElement) {\n      const height = config.height;\n      const result = (height as any) - 56;\n      const finalHeight = result + \"px\";\n      this.renderer.setStyle(this.table.nativeElement, \"height\", finalHeight);\n    }\n  }\n  \n  ngOnChanges() {\n    this.tableLength.set(this.tableData()?.length ?? 0);\n    if (this.tableConfig().activeRowIndex !== null && this.tableConfig().activeRowIndex !== undefined) {\n      const activeRowIndex = this.tableConfig().activeRowIndex;\n      this.activeRowIndex.set(Array.isArray(activeRowIndex) ? activeRowIndex : [activeRowIndex])\n    }\n  }\n\n  // Filter related functions\n  initializeFilters() {\n    const newAppliedFilters: { [key: string]: Array<{ name: string; value: string }> } = {};\n    const allFilters: Array<Filter> = [];\n    \n    for (let colHeader of this.tableConfig()?.colHeaderConfig) {\n      if (colHeader.filters) {\n        let filters = [];\n        for (let filter of colHeader.filters) {\n          if (filter.checked) {\n            filters.push({\n              name: filter.name,\n              value: filter.value\n            });\n          }\n          // Add all filters to the filterData array\n          allFilters.push(filter);\n        }\n        if (filters.length > 0) newAppliedFilters[colHeader.data] = filters;\n      }\n    }\n    this.appliedFilters.set(newAppliedFilters);\n    this.filterData.set(allFilters);\n }\n  toggleFilter(filterName: string) {\n    if (!this.showFilter()) {\n      this.filterName.set(filterName);\n      this.showFilter.set(true);\n\n      let offSet = 0;\n      let colHeadersReversed = this.colHeaders.toArray().reverse();\n\n      for (let header of colHeadersReversed) {\n        if (header.nativeElement.innerText === filterName) break;\n        offSet += header.nativeElement.offsetWidth;\n      }\n      this.filterContainerStyles.set({\n        top: \"44px\",\n        right: offSet > 0 ? offSet - 116 + \"px\" : \"12px\"\n      });\n    } else {\n      this.filterName.set(\"\");\n      this.filterData.set([]);\n      this.showFilter.set(false);\n    }\n  }\n  updateAppliedFilters(appliedFilters: Array<{ name: string; value: string }>) {\n    const currentFilters = this.appliedFilters();\n    if (appliedFilters.length == 0) {\n      delete currentFilters[this.filterName()];\n    } else {\n      currentFilters[this.filterName()] = appliedFilters;\n    }\n    this.appliedFilters.set({ ...currentFilters });\n    this.filtersUpdated.emit({ ...this.appliedFilters() });\n    this.toggleFilter(this.filterName());\n  }\n\n  // Pagination related functions\n  initializePagination() {\n    if (this.tableConfig().paginationConfig) {\n      // Initialize selectedPage from config if provided, otherwise default to 1\n      // const configSelectedPage = this.tableConfig().paginationConfig.selectedPage;\n      // this.selectedPage.set(configSelectedPage ?? 1);\n      \n      let len = this.tableConfig().paginationConfig.noOfPages;\n      if (len <= 7) {\n        const newPages = [];\n        for (let i = 1; i <= len; i++) {\n          newPages.push(i);\n        }\n        this.pages.set(newPages);\n      } else {\n        this.pages.set([1, 2, 3, 4, 0, len]);\n      }\n    }\n  }\n  updateSelectedPage(pageNumber: number) {\n    // Guard clause to prevent out-of-range updates\n    if (pageNumber < 1 || pageNumber > this.tableConfig().paginationConfig.noOfPages) return;\n\n    /**\n     * LEGACY CODE WORKAROUND: Track user-initiated page selection.\n     * \n     * We track this to prevent the effect from overwriting user selections when\n     * legacy parent components don't update config.selectedPage. The effect will\n     * skip syncing from config while this page is marked as user-selected.\n     * \n     * IDEAL: Parent should update config.selectedPage in pageSelected handler.\n     * Once all parents do this, we can remove userSelectedPage tracking.\n     */\n    this.isInternalPageUpdate = true;\n    this.userSelectedPage = pageNumber;\n\n    // Update internal state immediately - this is the source of truth\n    this.selectedPage.set(pageNumber);\n\n    // Reset header checkbox when navigating to a different page\n    this.selectAllCheckbox.set(false);\n    \n    // Update page numbers display for pagination with many pages\n    let len = this.tableConfig().paginationConfig.noOfPages;\n    if (len > 7) {\n      if (pageNumber - 2 <= 1) {\n        this.pages.set([1, 2, 3, 4, 0, len]);\n      } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n        this.pages.set([1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len]);\n      } else if (pageNumber + 2 >= len) {\n        this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);\n      }\n    }\n    \n    // Emit to parent - they may or may not update config, but we protect our state\n    this.pageSelected.emit(pageNumber);\n  }\n\n  // Main container related functions\n  getContainerHeight() {\n    if (this.tableConfig()?.height) return this.tableConfig().height;\n    else return \"\";\n  }\n  getContainerWidth() {\n    if (this.tableConfig()?.width) return this.tableConfig().width;\n    else return \"\";\n  }\n\n  // Column Headers related functions\n  getColHeadersRowStyles() {\n    const { colHeadersRowConfig } = this.tableConfig();\n    const minHeight = colHeadersRowConfig?.height || \"44px\";\n    const borderTop = (colHeadersRowConfig?.style as any)?.borderTop || \"\";\n    const borderBottom = (colHeadersRowConfig?.style as any)?.borderBottom || \"1px solid #E0E0E0\";\n    const backgroundColor = (colHeadersRowConfig?.style as any)?.backgroundColor || \"#FFFFFF\";\n    const fontSize = (colHeadersRowConfig?.style as any)?.fontSize || \"14px\";\n    return {\n      \"min-height\": minHeight,\n      \"border-top\": borderTop,\n      \"border-bottom\": borderBottom,\n      \"background-color\": backgroundColor,\n      \"font-size\": fontSize\n    };\n  }\n\n  onSortChange(sortState: SortState) {\n    // Emit the sort change to the parent component\n    this.sortChange.emit(sortState);\n    \n    // Handle multi-column sort if enabled\n    if (this.tableConfig().multiColumnSort) {\n      const currentMultiSort = this.multiColumnSort();\n      const index = currentMultiSort.findIndex(sort => sort.column === sortState.column);\n      if (index !== -1) {\n        if (sortState.direction === null) {\n          const newMultiSort = [...currentMultiSort];\n          newMultiSort.splice(index, 1);\n          this.multiColumnSort.set(newMultiSort);\n        } else {\n          const newMultiSort = [...currentMultiSort];\n          newMultiSort[index] = sortState;\n          this.multiColumnSort.set(newMultiSort);\n        }\n      } else if (sortState.direction !== null) {\n        this.multiColumnSort.set([...currentMultiSort, sortState]);\n      }\n    }\n  }\n\n  getActionsCellStyle(style: any): any {\n    if (!style) return {};\n    const { width, ...restStyle } = style;\n    return restStyle;\n  }\n\n  onActionClick(event: any, rowIndex: number): void {\n    if (event.actionType === 'checkbox') {\n      const actionInfo = this.findActionConfig('checkbox');\n      if (actionInfo && this.tableData()[rowIndex]) {\n        const { index, config } = actionInfo;\n        const currentActiveRows = this.activeRowIndex();\n        \n        const checkedRowIndices = event.value\n          ? [...currentActiveRows, rowIndex]\n          : currentActiveRows.filter(i => i !== rowIndex);\n                const updatedTableData = this.updateCheckboxState(checkedRowIndices, index);\n        \n        const checkedItems = this.buildCheckedItems(checkedRowIndices, updatedTableData);\n        config.action?.(checkedItems, rowIndex);\n      }\n\n    } else if(event.actionType === 'row-collapse'){\n      const rowCollapse = this.findActionConfig('row-collapse');\n      if (rowCollapse && this.tableData()[rowIndex]) {\n        // Note: We can't directly modify input signals, this should be handled by parent component\n        rowCollapse.config.action?.(this.tableData());\n        this.buildExpandedMap();\n      }\n    }\n  }\n\n  findActionConfig(actionType: string): { index: number, config: ColConfig } | null {\n    for (let i = 0; i < this.tableConfig().colConfig.length; i++) {\n      const col = this.tableConfig().colConfig[i];\n      if (col.type === 'actions' && col.actionType === actionType) {\n        return { index: i, config: col };\n      }\n    }\n    return null;\n  }\n  \n\n  isRowDisabled(row: any): boolean {\n    return typeof this.tableConfig().rowConfig.disableRow === \"function\" ? this.tableConfig().rowConfig.disableRow(row) : false;\n  }\n\n  private updateCheckboxState(checkedRowIndices: number[], checkboxColIndex: number): any[][] {\n    const currentData = this.tableData();\n    \n    this.activeRowIndex.set(checkedRowIndices);\n    \n    const updatedTableData = currentData.map((row, i) => {\n      const rowCopy = Array.from(row);\n      const isDisabled = this.isRowDisabled(row);\n      \n      if (!isDisabled) {\n        rowCopy[checkboxColIndex] = checkedRowIndices.includes(i);\n      }\n      \n      return rowCopy;\n    });\n    \n    this.headerAction?.emit({\n      type: \"checkboxToggle\",\n      payload: updatedTableData\n    });\n    \n    return updatedTableData;\n  }\n\n  private buildCheckedItems(checkedRowIndices: number[], updatedTableData: any[][]): any[][] {\n    return checkedRowIndices\n      .map(checkedIndex => {\n        const row = updatedTableData[checkedIndex];\n        if (row) {\n          return [...row];\n        }\n        return null;\n      })\n      .filter(row => row !== null) as any[][];\n  }\n\n  toggleCheckbox() {\n    this.selectAllCheckbox.set(!this.selectAllCheckbox());\n    const checkboxColIndex = this.tableConfig().colConfig.findIndex(col => col.type === 'actions' && col.actionType === 'checkbox');\n    if (checkboxColIndex !== -1) {\n      const isSelectAll = this.selectAllCheckbox();\n      const currentData = this.tableData();\n      \n      const checkedRowIndices = isSelectAll\n        ? currentData\n            .map((row, index) => this.isRowDisabled(row) ? -1 : index)\n            .filter(index => index !== -1)\n        : [];\n      \n      this.updateCheckboxState(checkedRowIndices, checkboxColIndex);\n    }\n  }\n\n\n  onPageSizeChange(selectedOption: DropdownItem) {\n    this.pageSizeChanged.emit(parseInt(selectedOption.value));\n  }\n\n  shouldShowPagination(): boolean {\n      const config = this.tableConfig()?.paginationConfig;\n      if (!config) return false;\n      const hasMultiplePages = config.noOfPages > 1;\n      const hasEnoughData = this.tableLength() > config.rowsPerPage;\n      return this.showPageSizeDropdown() || hasMultiplePages || hasEnoughData;\n  }\n}\n\nexport interface TableConfig {\n  height: string | \"100%\";\n  width: string | \"100%\";\n  paginationConfig?: PaginationConfig | undefined | null;\n  colHeadersRowConfig: RowConfig | undefined | null;\n  rowConfig: RowConfig | undefined | null;\n  colHeaderConfig: Array<ColHeaderConfig>;\n  colConfig: Array<ColConfig>;\n  canExpand?: boolean;\n  canScrollHorizontally?: boolean;\n  cellHover?: boolean;\n  activeRowIndex?: number | number[];\n  multiColumnSort?: boolean;\n}\nexport interface PaginationConfig {\n  noOfPages: number;\n  rowsPerPage: number;\n  totalNoOfRows: number;\n  selectedPage?: number;\n  disablePageJumping?: boolean;\n  showPageSizeDropdown?: boolean; // When true, rowsPerPage value should be included in pageSizes array\n  pageSizes?: number[];\n}\nexport interface RowConfig {\n  height?: string | undefined | null;\n  style?: {};\n  action?: any;\n  disableRow?: (data: any) => boolean;\n}\nexport interface ColHeaderConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"checkbox\";\n  data: any;\n  componentRef?: any;\n  filters?: Array<Filter> | null;\n  style?: {};\n  action?: any;\n  isSortable?: boolean;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\nexport interface ColConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"actions\" | \"html\";\n  componentRef?: any;\n  style?: {};\n  action?: any;\n  actionItems?: ActionItem[];\n  actionType?: \"inline\" | \"dropdown\" | \"checkbox\" | \"row-collapse\"; // inline for individual icons, dropdown for menu\n  disable?: (rowData: any) => boolean;\n  collapseColumnIndex?: number;\n  previewLines?: number;\n}\nexport interface ActionItem {\n  label: string;\n  value: string;\n  icon?: string;\n  disable?: (data: any) => boolean;\n  action?: (data: any) => void;\n  children?: ActionItem[];\n}\nexport interface InternalActionItem extends ActionItem {\n  showSubmenu?: boolean;\n}\n","<div\n  [ngStyle]=\"{\n    height: getContainerHeight(),\n    width: getContainerWidth(),\n    'overflow-x': tableConfig().canScrollHorizontally ? 'auto' : 'unset'\n  }\"\n  id=\"main-container\"\n>\n  <mis-table-filter\n    #filter\n    (filtersApplied)=\"updateAppliedFilters($event)\"\n    *ngIf=\"showFilter()\"\n    [containerStyles]=\"filterContainerStyles()\"\n    [filtersData]=\"filterData()\"\n  ></mis-table-filter>\n  <div\n    #table\n    id=\"table-container\"\n    [ngClass]=\"{ 'no-scrollbar': expandedIndex() < 0, scrollbar: !(expandedIndex() < 0), 'scroll-horizontally': tableConfig().canScrollHorizontally }\"\n  >\n    <div\n    [ngStyle]=\"getColHeadersRowStyles()\"\n      id=\"col-headers-container\"\n    >\n      <div\n        #colHeaderRef\n        (click)=\"colHeader?.action ? colHeader?.action(colHeader) : null\"\n        *ngFor=\"let colHeader of tableConfig()?.colHeaderConfig\"\n        class=\"col-header\"\n        [ngStyle]=\"{\n          width: colHeader?.style?.width || '',\n          cursor: colHeader.action ? 'pointer' : 'default',\n          'justify-content': colHeader?.style?.justifyContent\n            ? colHeader?.style?.justifyContent\n            : colHeader.type === 'number'\n            ? 'flex-end'\n            : 'space-between'\n        }\"\n      >\n        <p *ngIf=\"colHeader?.type !== 'custom' && colHeader?.type !== 'checkbox'\" class=\"col-header-text\">\n          {{ colHeader?.data || \" \" }}\n        </p>\n        <span\n          (click)=\"filterData.set(colHeader.filters); toggleFilter(colHeader.data); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type !== 'custom' && colHeader?.filters && colHeader?.filters?.length > 0\"\n          class=\"filter-icon\"\n        >\n          <span *ngIf=\"appliedFilters()[colHeader.data]?.length > 0\" id=\"filter-active\"></span>\n          <svg fill=\"none\" height=\"10\" viewBox=\"0 0 13 10\" width=\"13\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path\n              clip-rule=\"evenodd\"\n              d=\"M4.97546 10H7.64213V8H4.97546V10ZM0.308472 0V2H12.3085V0H0.308472ZM2.30847 6H10.3085V4H2.30847V6Z\"\n              fill=\"#181F33\"\n              fill-rule=\"evenodd\"\n            />\n          </svg>\n        </span>\n        <span\n          (click)=\"toggleCheckbox(); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type === 'checkbox'\"\n          class=\"checkbox-icon\"\n        >\n          <mis-checkbox [checked]=\"selectAllCheckbox()\"></mis-checkbox>\n        </span>\n        <span *ngIf=\"colHeader?.isSortable && !colHeader?.filters\" appSortIcons\n          [column]=\"colHeader\"\n          [activeSort]=\"currentSort()\"\n          [activeSorts]=\"multiColumnSort()\"\n          [multiColumnSort]=\"tableConfig().multiColumnSort\"\n          (sortChange)=\"onSortChange($event)\"\n          class=\"sort-icon\">\n        </span>\n      <ng-template *ngIf=\"colHeader?.type === 'custom'\" customTableCell [customComponent]=\"colHeader?.componentRef\" [data]=\"colHeader.data\"></ng-template>\n      </div>\n    </div>\n    \n    <div id=\"data-container\">\n      <div class=\"row-wrapper\" *ngFor=\"let row of tableData(); let i = index; let rowIndex = index\">\n        <div\n          class=\"t-row\"\n          [ngClass]=\"{ 't-row-hover': tableConfig().cellHover, 'active-row': activeRowIndex().includes(i) }\"\n          [ngStyle]=\"{ 'min-height': tableConfig()?.rowConfig?.height ? tableConfig().rowConfig.height : '44px' }\"\n          (click)=\"selectRow(i)\"\n          [class.disabled-row]=\"isRowDisabled(row)\"\n          >\n          <div\n            (click)=\"tableConfig()?.colConfig[colIndex]?.action && tableConfig()?.colConfig[colIndex]?.actionType !== 'checkbox' ? tableConfig()?.colConfig[colIndex]?.action(col) : null\"\n            *ngFor=\"let col of row; let colIndex = index\"\n            [ngStyle]=\"{\n              width: tableConfig()?.colConfig[colIndex]?.style?.width || tableConfig()?.colHeaderConfig[colIndex]?.style?.width || ''\n            }\"\n            class=\"t-col-container\"\n            [ngClass]=\"{ 't-col-container-hover': tableConfig().cellHover }\"\n          >\n            <div\n              class=\"t-col\"\n              [style]=\"tableConfig().colConfig[colIndex]?.style\"\n              [ngStyle]=\"{\n                width: '100%',\n                cursor: tableConfig().colConfig[colIndex]?.action ? 'pointer' : 'default',\n                'justify-content': tableConfig().colConfig[colIndex]?.style?.justifyContent\n                  ? tableConfig().colConfig[colIndex]?.style?.justifyContent\n                  : tableConfig().colConfig[colIndex]?.type === 'number'\n                  ? 'flex-end'\n                  : 'space-between'\n              }\"\n            >\n            <div\n            *ngIf=\"tableConfig().colConfig[colIndex]?.type !== 'custom' && tableConfig().colConfig[colIndex]?.type !== 'actions'\"\n            [ngStyle]=\"{\n              color: tableConfig()?.colConfig[colIndex]?.style?.color || '',\n              '--collapsed-lines': previewLines() || 3\n            }\"\n            [ngClass]=\"{\n              'collapsed-cell': collapseColIndex() == colIndex && expandedMap()[rowIndex]\n            }\"\n            class=\"t-col-text\"\n          >\n            <!-- Render as HTML -->\n            <ng-container *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'html'; else plainText\">\n              <span [innerHTML]=\"col\"></span>\n            </ng-container>\n          \n            <!-- Render as plain text -->\n            <ng-template #plainText>\n              <span>{{ col }}</span>\n            </ng-template>\n          </div>\n        \n              <ng-template\n                *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'custom'\"\n                [customComponent]=\"tableConfig().colConfig[colIndex].componentRef\"\n                [data]=\"col\"\n                customTableCell\n              ></ng-template>\n                <mis-actions-cell\n                  *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'actions'\"\n                  [cellData]=\"col\"\n                  [config]=\"tableConfig().colConfig[colIndex]\"\n                  (actionClick)=\"onActionClick($event, rowIndex)\"\n                  [ngClass]=\"{\n                    'disable-actions': (tableConfig().colConfig[colIndex]?.actionType === 'checkbox' || tableConfig().colConfig[colIndex]?.actionType === 'row-collapse') && isRowDisabled(row)\n                  }\"\n                ></mis-actions-cell>\n\n            </div>\n          </div>\n        </div>\n        <div *ngIf=\"tableConfig()?.canExpand && expandedIndex() === i\" class=\"sub-row\">\n          <ng-container *ngIf=\"subTableDataLoading()\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              Loading...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading() && subTableData().length === 0\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              No Data Available...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading() && subTableData().length > 0\">\n            <sub-table [config]=\"subTableconfig()\" [tableData]=\"subTableData()\"></sub-table>\n          </ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div id=\"pagination-content-container\">\n    @if(shouldShowPagination()){\n      <div \n        id=\"pagination-container\"\n      >\n        <p id=\"pagination-text\">\n          Showing\n          {{ (selectedPage() - 1) * tableConfig().paginationConfig.rowsPerPage + 1 }}-{{\n            (selectedPage() - 1) * tableConfig().paginationConfig.rowsPerPage + tableLength()\n          }}\n          of {{ tableConfig().paginationConfig.totalNoOfRows }} items\n        </p>\n        @if(showPageSizeDropdown()) {\n          <div class=\"page-size-selector\">\n            <mis-dropdown\n              [data]=\"pageSizeOptions()\"\n              [selectedItem]=\"selectedPageSizeOption()\"\n              [width]=\"'90px'\"\n              [height]=\"'32px'\"\n              [searchEnabled]=\"false\"\n              [dropdownListHeight]=\"'100px'\"\n              (onChange)=\"onPageSizeChange($event)\"\n              class=\"page-size-dropdown\"\n            ></mis-dropdown>\n          </div>\n        }\n        <div id=\"pages-container\">\n          <span   (click)=\"selectedPage() > 1 && updateSelectedPage(selectedPage() - 1)\" class=\"page\" [class.page-nav-inactive]=\"selectedPage() === 1\">\n            <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                clip-rule=\"evenodd\"\n                d=\"M0.857405 5.56295C0.855794 5.56139 0.854188 5.55982 0.852588 5.55824C0.695955 5.40408 0.617641 5.20203 0.617647 4.99998C0.617641 4.79793 0.695955 4.59588 0.852588 4.44172C0.854188 4.44014 0.855794 4.43858 0.857404 4.43702L5.13066 0.231231C5.44392 -0.0770771 5.9518 -0.0770771 6.26506 0.231231C6.57831 0.53954 6.57831 1.03941 6.26506 1.34772L2.5542 4.99998L6.26506 8.65225C6.57831 8.96055 6.57831 9.46042 6.26506 9.76873C5.9518 10.077 5.44392 10.077 5.13066 9.76873L0.857405 5.56295Z\"\n                fill=\"#181F33\"\n                fill-rule=\"evenodd\"\n              />\n            </svg>\n          </span>\n            <!-- Page numbers (only show if disablePageJumping is false) -->\n            <ng-container *ngIf=\"!tableConfig().paginationConfig?.disablePageJumping\">\n              <div *ngFor=\"let pageNumber of pages()\">\n                <span\n                  (click)=\"updateSelectedPage(pageNumber)\"\n                  *ngIf=\"pageNumber != 0\"\n                  [ngClass]=\"{ 'page-active': pageNumber === selectedPage() }\"\n                  class=\"page page-jumping-enabled\"\n                >{{ pageNumber }}</span>\n                <span *ngIf=\"pageNumber == 0\" class=\"page-seperator\">\n                  <div [ngStyle]=\"{ display: 'flex' }\">\n                    <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                    <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                    <span class=\"dot\"></span>\n                  </div>          \n                </span>\n              </div>\n            </ng-container>\n        \n          <span [class.page-nav-inactive]=\"selectedPage() === tableConfig().paginationConfig?.noOfPages\"\n          (click)=\"selectedPage() < tableConfig().paginationConfig?.noOfPages && updateSelectedPage(selectedPage() + 1)\" class=\"page\">\n            <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                clip-rule=\"evenodd\"\n                d=\"M6.1426 5.56295C6.14421 5.56139 6.14581 5.55982 6.14741 5.55824C6.30405 5.40408 6.38236 5.20203 6.38236 4.99998C6.38236 4.79793 6.30405 4.59588 6.14741 4.44172C6.14581 4.44014 6.14421 4.43858 6.1426 4.43702L1.86934 0.231231C1.55608 -0.0770771 1.0482 -0.0770771 0.734942 0.231231C0.421688 0.53954 0.421688 1.03941 0.734942 1.34772L4.4458 4.99998L0.734941 8.65225C0.421686 8.96055 0.421686 9.46042 0.734941 9.76873C1.0482 10.077 1.55608 10.077 1.86934 9.76873L6.1426 5.56295Z\"\n                fill=\"#181F33\"\n                fill-rule=\"evenodd\"\n              />\n            </svg>\n          </span>\n        </div>\n      </div>\n    }\n  </div>\n</div>\n"]}
|
|
918
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/table.component.ts","../../../../projects/mis-components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  OnChanges,\n  OnInit,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewChildren,\n  input,\n  output,\n  signal,\n  computed,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  untracked\n} from \"@angular/core\";\nimport { Filter, TableFilterComponent } from \"./filter/filter.component\";\nimport { SortState } from \"./sort-icons.directive\";\nimport { effect } from \"@angular/core\";\nimport { DropdownItem } from \"mis-crystal-design-system/dropdown\";\n\n@Component({\n  selector: \"mis-table\",\n  templateUrl: \"table.component.html\",\n  styleUrls: [\"table.component.css\"]\n})\nexport class TableComponent implements OnInit, AfterViewInit, OnChanges {\n  // Initialize with -1 to indicate no row is colored at the beginning\n  activeRowIndex = signal<number[]>([]);\n  hasCheckboxActions = signal<boolean>(false);\n  selectAllCheckbox = signal<boolean>(false);\n\n  // Filter related variables\n  showFilter = signal<boolean>(false);\n  filterName = signal<string>(\"\");\n  filterData = signal<Array<Filter>>([]);\n  filterContainerStyles = signal<any>({});\n  appliedFilters = signal<{ [key: string]: Array<{ name: string; value: string }> }>({});\n  \n  // Convert outputs to signal-based outputs\n  filtersUpdated = output<{\n    [key: string]: Array<{ name: string; value: string }>;\n  }>();\n\n  @ViewChild(\"filter\") filter: TableFilterComponent | any;\n  @ViewChildren(\"colHeaderRef\") colHeaders: QueryList<ElementRef> | any;\n\n  // Pagination related variables\n  pages = signal<Array<number>>([]);\n  tableLength = signal<number>(0);\n  selectedPage = signal<number>(1); // Internal state for selected page - this is the source of truth\n  private isInternalPageUpdate = false; // Flag to prevent effect from overwriting during user-initiated updates\n  \n  /**\n   * LEGACY CODE WORKAROUND: Track user-initiated page selections to prevent config overwrites.\n   * \n   * Some legacy parent components don't update tableConfig.paginationConfig.selectedPage when\n   * the page changes. This causes the effect to overwrite user selections with stale config values.\n   * \n   * IDEAL SOLUTION: Parent components should always update config.selectedPage in their\n   * pageSelected event handler. This workaround protects user actions until legacy code\n   * can be updated.\n   * \n   * TODO: Remove this workaround once all parent components properly update config.selectedPage\n   */\n  private userSelectedPage: number | null = null;\n  \n  pageSelected = output<number>();\n  pageSizeChanged = output<number>();\n  pageSizeOptions = computed(() => {\n    const config = this.tableConfig()?.paginationConfig;\n    if (!config?.pageSizes || !Array.isArray(config.pageSizes) || !config.pageSizes?.length) return [];\n  \n    return config.pageSizes?.map(option => ({\n      label: option?.toString() || '',\n      value: option?.toString() || '',\n    })) || [];\n  });\n\n  showPageSizeDropdown = computed(() => {\n    return !!this.tableConfig()?.paginationConfig?.showPageSizeDropdown;\n  });\n\n  selectedPageSizeOption = signal<DropdownItem>({ label: \"\", value: \"\" });\n\n  // Convert inputs to signal-based inputs\n  tableConfig = input<TableConfig>();\n  subTableconfig = input<TableConfig>();\n  tableDataLoading = input<boolean>();\n  expandedIndex = input<number>();\n  tableData = input<Array<Array<any>>>([]);\n  subTableData = input<Array<Array<any>>>([]);\n  subTableDataLoading = input<boolean>();\n  currentSort = input<{column: string, direction: 'ASC' | 'DESC' | ''} | null>();\n  @ViewChild(\"table\") table: ElementRef | any;\n  collapseColIndex = signal<number>(-1);\n  previewLines = signal<number>(0);\n  rowCollapseConfigIndex = signal<number>(-1);\n  expandedMap = signal<Record<string, boolean>>({});\n\n\n  // Sorting related properties\n  multiColumnSort = signal<SortState[]>([]);\n  sortChange = output<SortState>();\n  headerAction = output<{ type: string; payload?: any }>();\n\n  \n  constructor(private renderer: Renderer2) {\n    effect(() => {\n        this.tableLength.set(this.tableData()?.length ?? 0);\n        \n        const config = this.tableConfig();\n        \n        if (config && config.activeRowIndex !== null && config.activeRowIndex !== undefined) {\n            const activeRowIndex = config.activeRowIndex;\n            this.activeRowIndex.set(Array.isArray(activeRowIndex) ? activeRowIndex : [activeRowIndex]);\n        }\n\n        if (this.rowCollapseConfigIndex() !== -1) {\n             this.buildExpandedMap();\n        }\n\n        // --- PAGINATION PAGE ARRAY LOGIC (MOVED/REPLACED initializePagination) ---\n        const len = config?.paginationConfig?.noOfPages;\n        const disablePageJumping = config?.paginationConfig?.disablePageJumping;\n        \n        /**\n         * LEGACY CODE WORKAROUND: Protect user-initiated page selections from config overwrites.\n         * \n         * When users click pagination arrows, we update internal state immediately. However,\n         * some legacy parent components don't update config.selectedPage, causing the effect\n         * to run with stale config values that would overwrite the user's selection.\n         * \n         * Strategy: Treat internal state as source of truth for user-initiated changes.\n         * Only sync from config when it's safe (not a user-selected page).\n         * \n         * IDEAL: Parent should always update config.selectedPage in pageSelected handler.\n         */\n        const currentSelectedPage = this.selectedPage();\n        const configSelectedPage = config?.paginationConfig?.selectedPage;\n        const isUserSelectedPage = this.userSelectedPage !== null && currentSelectedPage === this.userSelectedPage;\n        \n        if (!this.isInternalPageUpdate) {\n          // Only sync from config if:\n          // 1. Config has a selectedPage value\n          // 2. Current page is NOT a user-initiated selection (protect user actions)\n          // 3. Config value is valid and different from current\n          if (configSelectedPage !== undefined && configSelectedPage !== null && !isUserSelectedPage) {\n            const maxPages = config?.paginationConfig?.noOfPages || 1;\n            if (currentSelectedPage !== configSelectedPage && \n                configSelectedPage >= 1 && \n                configSelectedPage <= maxPages) {\n              this.selectedPage.set(configSelectedPage);\n            }\n          }\n          \n          // If config doesn't have selectedPage, only initialize invalid state\n          // Never reset a valid page number, especially user-selected ones\n          if ((configSelectedPage === undefined || configSelectedPage === null) && \n              !isUserSelectedPage &&\n              (currentSelectedPage === 0 || currentSelectedPage < 1)) {\n            this.selectedPage.set(1);\n          }\n          \n          // Clear user selection tracking when config matches user's selection\n          // This indicates parent has updated config correctly\n          if (configSelectedPage === this.userSelectedPage) {\n            this.userSelectedPage = null;\n          }\n        }\n        \n        // Reset the flag after processing\n        this.isInternalPageUpdate = false;\n        \n        // Only run if pagination is configured and page jumping is enabled\n        if (len && len > 0 && !disablePageJumping) {\n            // Read the internal state of the selected page for calculating the pages array.\n            // Since this runs on every config change, we rely on the value set \n            // by updateSelectedPage() or synced from config above.\n            const pageNumber = this.selectedPage(); \n\n            if (len <= 7) {\n                const newPages = [];\n                for (let i = 1; i <= len; i++) {\n                    newPages.push(i);\n                }\n                this.pages.set(newPages);\n            } else {\n                if (pageNumber - 2 <= 1) {\n                    this.pages.set([1, 2, 3, 4, 0, len]);\n                } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n                    this.pages.set([1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len]);\n                } else if (pageNumber + 2 >= len) {\n                    this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);\n                }\n            }\n        }\n        // --- END PAGINATION PAGE ARRAY LOGIC ---\n\n        \n        if(config?.paginationConfig?.showPageSizeDropdown) {\n          const options = this.pageSizeOptions();\n          const rowsPerPage = this.tableConfig()?.paginationConfig?.rowsPerPage;\n          \n          if (!Array.isArray(options) || !rowsPerPage) {\n            this.selectedPageSizeOption.set({ label: \"\", value: \"\" });\n            return;\n          }\n          \n          const selected = options.find(opt => opt?.value === rowsPerPage.toString());\n          if (selected) {\n            this.selectedPageSizeOption.set(selected);\n          } else if (options.length > 0) {\n            // If configured rowsPerPage is not among options, pick the floor value and notify parent\n            const target = Number(rowsPerPage);\n            //Sort the options\n            const sorted = options\n              .map(opt => ({ opt, num: Number(opt?.value) }))\n              .filter(({ num }) => Number.isFinite(num))\n              .sort((a, b) => a.num - b.num);\n\n            let floorOption = sorted[0]?.opt;\n            for (let i = sorted.length - 1; i >= 0; i--) {\n              if (sorted[i].num <= target) {\n                floorOption = sorted[i].opt;\n                break;\n              }\n            }\n            console.error(\"The configured rowsPerPage was not matched to any of the pageSizes sent in the paginationConfig. Selecting the nearest floor value among the available pageSizes.\");\n            this.selectedPageSizeOption.set(floorOption);\n            this.onPageSizeChange(floorOption);\n          } else {\n            console.error(\"No page size options available.\")\n          }\n        }\n    }, { allowSignalWrites: true });\n\n    // Reactive height calculation: maintains exact old behavior for backward compatibility\n    // Old code: height - 56 + \"px\" (flawed for percentages, but we maintain it)\n    // Note: Effect must be in constructor, not lifecycle hooks (NG0203 error otherwise)\n    // effect(() => {\n    //   const config = this.tableConfig();\n    //   if (!config?.paginationConfig || !this.table?.nativeElement) return;\n    \n    //   const height = config.height;\n    //   // Old behavior: height - 56 + \"px\" (maintains the flaw for backward compatibility)\n    //   const result = (height as any) - 56;\n    //   const finalHeight = result + \"px\";\n    //   this.renderer.setStyle(this.table.nativeElement, \"height\", finalHeight);\n    // });\n  }\n\n\n  // Function to handle row click\n  selectRow(index: number) {\n    if (this.hasCheckboxActions()) return;\n    this.activeRowIndex.set([index]); // Set the selected index to the clicked row's index\n    !!this.tableConfig().rowConfig.action && this.tableConfig().rowConfig.action(index);\n  }\n\n  ngOnInit(): void {\n    this.hasCheckboxActions.set(this.tableConfig().colConfig?.some(col => col.type === \"actions\" && col.actionType === \"checkbox\"));\n    this.tableLength.set(!!this.tableData() ? this.tableData().length : 0);\n    this.initializeFilters();\n    if (this.tableConfig().paginationConfig) {\n      this.initializePagination();\n    }\n    if (this.tableConfig().canScrollHorizontally === undefined) {\n      // Note: We can't directly modify input signals, this should be handled by parent component\n    }\n    document.addEventListener(\"click\", event => {\n      if (this.filter) {\n        let isCheckBoxClicked = true;\n        let targetElement = event.target as HTMLSpanElement;\n        if (targetElement.className === \"checkmark\") {\n          isCheckBoxClicked = true;\n          this.showFilter.set(true);\n        }\n        let isClickInsideElement = this.filter.container.nativeElement.contains(event.target);\n        if (!isClickInsideElement && !isCheckBoxClicked) {\n          this.toggleFilter(this.filterName());\n        }\n      }\n    });\n\n    // fetch collapseColIndex and previewLines if present\n    this.rowCollapseConfigIndex.set(this.tableConfig()?.colConfig?.findIndex(\n      col => col.type === 'actions' && col.actionType === 'row-collapse'\n    ));\n    if (this.rowCollapseConfigIndex() !== -1) {\n      this.collapseColIndex.set(this.tableConfig().colConfig[this.rowCollapseConfigIndex()].collapseColumnIndex ?? null);\n      this.previewLines.set(this.tableConfig().colConfig[this.rowCollapseConfigIndex()].previewLines ?? null);\n      this.buildExpandedMap();\n    }\n  }\n\n  buildExpandedMap(): void{\n    const newExpandedMap: Record<string, boolean> = {};\n    const collapseIndex = this.rowCollapseConfigIndex();\n    \n    this.tableData().forEach((row, rowIndex) => {\n        newExpandedMap[`${rowIndex}`] = row[collapseIndex];\n    });\n    this.expandedMap.set(newExpandedMap);\n}\n\n  ngAfterViewInit() {\n    // ViewChild is now available - manually trigger height calculation once\n    // The effect in constructor will handle subsequent config changes\n    const config = this.tableConfig();\n    if (config?.paginationConfig && this.table?.nativeElement) {\n      const height = config.height;\n      const result = (height as any) - 56;\n      const finalHeight = result + \"px\";\n      this.renderer.setStyle(this.table.nativeElement, \"height\", finalHeight);\n    }\n  }\n  \n  ngOnChanges() {\n    this.tableLength.set(this.tableData()?.length ?? 0);\n    if (this.tableConfig().activeRowIndex !== null && this.tableConfig().activeRowIndex !== undefined) {\n      const activeRowIndex = this.tableConfig().activeRowIndex;\n      this.activeRowIndex.set(Array.isArray(activeRowIndex) ? activeRowIndex : [activeRowIndex])\n    }\n  }\n\n  // Filter related functions\n  initializeFilters() {\n    const newAppliedFilters: { [key: string]: Array<{ name: string; value: string }> } = {};\n    const allFilters: Array<Filter> = [];\n    \n    for (let colHeader of this.tableConfig()?.colHeaderConfig) {\n      if (colHeader.filters) {\n        let filters = [];\n        for (let filter of colHeader.filters) {\n          if (filter.checked) {\n            filters.push({\n              name: filter.name,\n              value: filter.value\n            });\n          }\n          // Add all filters to the filterData array\n          allFilters.push(filter);\n        }\n        if (filters.length > 0) newAppliedFilters[colHeader.data] = filters;\n      }\n    }\n    this.appliedFilters.set(newAppliedFilters);\n    this.filterData.set(allFilters);\n }\n  toggleFilter(filterName: string) {\n    if (!this.showFilter()) {\n      this.filterName.set(filterName);\n      this.showFilter.set(true);\n\n      let offSet = 0;\n      let colHeadersReversed = this.colHeaders.toArray().reverse();\n\n      for (let header of colHeadersReversed) {\n        if (header.nativeElement.innerText === filterName) break;\n        offSet += header.nativeElement.offsetWidth;\n      }\n      this.filterContainerStyles.set({\n        top: \"44px\",\n        right: offSet > 0 ? offSet - 116 + \"px\" : \"12px\"\n      });\n    } else {\n      this.filterName.set(\"\");\n      this.filterData.set([]);\n      this.showFilter.set(false);\n    }\n  }\n  updateAppliedFilters(appliedFilters: Array<{ name: string; value: string }>) {\n    const currentFilters = this.appliedFilters();\n    if (appliedFilters.length == 0) {\n      delete currentFilters[this.filterName()];\n    } else {\n      currentFilters[this.filterName()] = appliedFilters;\n    }\n    this.appliedFilters.set({ ...currentFilters });\n    this.filtersUpdated.emit({ ...this.appliedFilters() });\n    this.toggleFilter(this.filterName());\n  }\n\n  // Pagination related functions\n  initializePagination() {\n    if (this.tableConfig().paginationConfig) {\n      // Initialize selectedPage from config if provided, otherwise default to 1\n      // const configSelectedPage = this.tableConfig().paginationConfig.selectedPage;\n      // this.selectedPage.set(configSelectedPage ?? 1);\n      \n      let len = this.tableConfig().paginationConfig.noOfPages;\n      if (len <= 7) {\n        const newPages = [];\n        for (let i = 1; i <= len; i++) {\n          newPages.push(i);\n        }\n        this.pages.set(newPages);\n      } else {\n        this.pages.set([1, 2, 3, 4, 0, len]);\n      }\n    }\n  }\n  updateSelectedPage(pageNumber: number) {\n    // Guard clause to prevent out-of-range updates\n    if (pageNumber < 1 || pageNumber > this.tableConfig().paginationConfig.noOfPages) return;\n\n    /**\n     * LEGACY CODE WORKAROUND: Track user-initiated page selection.\n     * \n     * We track this to prevent the effect from overwriting user selections when\n     * legacy parent components don't update config.selectedPage. The effect will\n     * skip syncing from config while this page is marked as user-selected.\n     * \n     * IDEAL: Parent should update config.selectedPage in pageSelected handler.\n     * Once all parents do this, we can remove userSelectedPage tracking.\n     */\n    this.isInternalPageUpdate = true;\n    this.userSelectedPage = pageNumber;\n\n    // Update internal state immediately - this is the source of truth\n    this.selectedPage.set(pageNumber);\n\n    // Reset header checkbox when navigating to a different page\n    this.selectAllCheckbox.set(false);\n    \n    // Update page numbers display for pagination with many pages\n    let len = this.tableConfig().paginationConfig.noOfPages;\n    if (len > 7) {\n      if (pageNumber - 2 <= 1) {\n        this.pages.set([1, 2, 3, 4, 0, len]);\n      } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n        this.pages.set([1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len]);\n      } else if (pageNumber + 2 >= len) {\n        this.pages.set([1, 0, len - 3, len - 2, len - 1, len]);\n      }\n    }\n    \n    // Emit to parent - they may or may not update config, but we protect our state\n    this.pageSelected.emit(pageNumber);\n  }\n\n  // Main container related functions\n  getContainerHeight() {\n    if (this.tableConfig()?.height) return this.tableConfig().height;\n    else return \"\";\n  }\n  getContainerWidth() {\n    if (this.tableConfig()?.width) return this.tableConfig().width;\n    else return \"\";\n  }\n\n  // Column Headers related functions\n  getColHeadersRowStyles() {\n    const { colHeadersRowConfig } = this.tableConfig();\n    const minHeight = colHeadersRowConfig?.height || \"44px\";\n    const borderTop = (colHeadersRowConfig?.style as any)?.borderTop || \"\";\n    const borderBottom = (colHeadersRowConfig?.style as any)?.borderBottom || \"1px solid #E0E0E0\";\n    const backgroundColor = (colHeadersRowConfig?.style as any)?.backgroundColor || \"#FFFFFF\";\n    const fontSize = (colHeadersRowConfig?.style as any)?.fontSize || \"14px\";\n    return {\n      \"min-height\": minHeight,\n      \"border-top\": borderTop,\n      \"border-bottom\": borderBottom,\n      \"background-color\": backgroundColor,\n      \"font-size\": fontSize\n    };\n  }\n\n  onSortChange(sortState: SortState) {\n    // Emit the sort change to the parent component\n    this.sortChange.emit(sortState);\n    \n    // Handle multi-column sort if enabled\n    if (this.tableConfig().multiColumnSort) {\n      const currentMultiSort = this.multiColumnSort();\n      const index = currentMultiSort.findIndex(sort => sort.column === sortState.column);\n      if (index !== -1) {\n        if (sortState.direction === null) {\n          const newMultiSort = [...currentMultiSort];\n          newMultiSort.splice(index, 1);\n          this.multiColumnSort.set(newMultiSort);\n        } else {\n          const newMultiSort = [...currentMultiSort];\n          newMultiSort[index] = sortState;\n          this.multiColumnSort.set(newMultiSort);\n        }\n      } else if (sortState.direction !== null) {\n        this.multiColumnSort.set([...currentMultiSort, sortState]);\n      }\n    }\n  }\n\n  getActionsCellStyle(style: any): any {\n    if (!style) return {};\n    const { width, ...restStyle } = style;\n    return restStyle;\n  }\n\n  onActionClick(event: any, rowIndex: number): void {\n    if (event.actionType === 'checkbox') {\n      const actionInfo = this.findActionConfig('checkbox');\n      if (actionInfo && this.tableData()[rowIndex]) {\n        const { index, config } = actionInfo;\n        const currentActiveRows = this.activeRowIndex();\n        \n        const checkedRowIndices = event.value\n          ? [...currentActiveRows, rowIndex]\n          : currentActiveRows.filter(i => i !== rowIndex);\n                const updatedTableData = this.updateCheckboxState(checkedRowIndices, index);\n        \n        const checkedItems = this.buildCheckedItems(checkedRowIndices, updatedTableData);\n        config.action?.(checkedItems, rowIndex);\n      }\n\n    } else if(event.actionType === 'row-collapse'){\n      const rowCollapse = this.findActionConfig('row-collapse');\n      if (rowCollapse && this.tableData()[rowIndex]) {\n        this.tableData()[rowIndex][rowCollapse.index] = event.value;\n        rowCollapse.config.action?.(this.tableData());\n        this.buildExpandedMap();\n      }\n    }\n  }\n\n  findActionConfig(actionType: string): { index: number, config: ColConfig } | null {\n    for (let i = 0; i < this.tableConfig().colConfig.length; i++) {\n      const col = this.tableConfig().colConfig[i];\n      if (col.type === 'actions' && col.actionType === actionType) {\n        return { index: i, config: col };\n      }\n    }\n    return null;\n  }\n  \n\n  isRowDisabled(row: any): boolean {\n    return typeof this.tableConfig().rowConfig.disableRow === \"function\" ? this.tableConfig().rowConfig.disableRow(row) : false;\n  }\n\n  private updateCheckboxState(checkedRowIndices: number[], checkboxColIndex: number): any[][] {\n    const currentData = this.tableData();\n    \n    this.activeRowIndex.set(checkedRowIndices);\n    \n    const updatedTableData = currentData.map((row, i) => {\n      const rowCopy = Array.from(row);\n      const isDisabled = this.isRowDisabled(row);\n      \n      if (!isDisabled) {\n        rowCopy[checkboxColIndex] = checkedRowIndices.includes(i);\n      }\n      \n      return rowCopy;\n    });\n    \n    this.headerAction?.emit({\n      type: \"checkboxToggle\",\n      payload: updatedTableData\n    });\n    \n    return updatedTableData;\n  }\n\n  private buildCheckedItems(checkedRowIndices: number[], updatedTableData: any[][]): any[][] {\n    return checkedRowIndices\n      .map(checkedIndex => {\n        const row = updatedTableData[checkedIndex];\n        if (row) {\n          return [...row];\n        }\n        return null;\n      })\n      .filter(row => row !== null) as any[][];\n  }\n\n  toggleCheckbox() {\n    this.selectAllCheckbox.set(!this.selectAllCheckbox());\n    const checkboxColIndex = this.tableConfig().colConfig.findIndex(col => col.type === 'actions' && col.actionType === 'checkbox');\n    if (checkboxColIndex !== -1) {\n      const isSelectAll = this.selectAllCheckbox();\n      const currentData = this.tableData();\n      \n      const checkedRowIndices = isSelectAll\n        ? currentData\n            .map((row, index) => this.isRowDisabled(row) ? -1 : index)\n            .filter(index => index !== -1)\n        : [];\n      \n      this.updateCheckboxState(checkedRowIndices, checkboxColIndex);\n    }\n  }\n\n\n  onPageSizeChange(selectedOption: DropdownItem) {\n    this.pageSizeChanged.emit(parseInt(selectedOption.value));\n  }\n\n  shouldShowPagination(): boolean {\n      const config = this.tableConfig()?.paginationConfig;\n      if (!config) return false;\n      const hasMultiplePages = config.noOfPages > 1;\n      const hasEnoughData = this.tableLength() > config.rowsPerPage;\n      return this.showPageSizeDropdown() || hasMultiplePages || hasEnoughData;\n  }\n}\n\nexport interface TableConfig {\n  height: string | \"100%\";\n  width: string | \"100%\";\n  paginationConfig?: PaginationConfig | undefined | null;\n  colHeadersRowConfig: RowConfig | undefined | null;\n  rowConfig: RowConfig | undefined | null;\n  colHeaderConfig: Array<ColHeaderConfig>;\n  colConfig: Array<ColConfig>;\n  canExpand?: boolean;\n  canScrollHorizontally?: boolean;\n  cellHover?: boolean;\n  activeRowIndex?: number | number[];\n  multiColumnSort?: boolean;\n}\nexport interface PaginationConfig {\n  noOfPages: number;\n  rowsPerPage: number;\n  totalNoOfRows: number;\n  selectedPage?: number;\n  disablePageJumping?: boolean;\n  showPageSizeDropdown?: boolean; // When true, rowsPerPage value should be included in pageSizes array\n  pageSizes?: number[];\n}\nexport interface RowConfig {\n  height?: string | undefined | null;\n  style?: {};\n  action?: any;\n  disableRow?: (data: any) => boolean;\n}\nexport interface ColHeaderConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"checkbox\";\n  data: any;\n  componentRef?: any;\n  filters?: Array<Filter> | null;\n  style?: {};\n  action?: any;\n  isSortable?: boolean;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\nexport interface ColConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"actions\" | \"html\";\n  componentRef?: any;\n  style?: {};\n  action?: any;\n  actionItems?: ActionItem[];\n  actionType?: \"inline\" | \"dropdown\" | \"checkbox\" | \"row-collapse\"; // inline for individual icons, dropdown for menu\n  disable?: (rowData: any) => boolean;\n  collapseColumnIndex?: number;\n  previewLines?: number;\n}\nexport interface ActionItem {\n  label: string;\n  value: string;\n  icon?: string;\n  disable?: (data: any) => boolean;\n  action?: (data: any) => void;\n  children?: ActionItem[];\n}\nexport interface InternalActionItem extends ActionItem {\n  showSubmenu?: boolean;\n}\n","<div\n  [ngStyle]=\"{\n    height: getContainerHeight(),\n    width: getContainerWidth(),\n    'overflow-x': tableConfig().canScrollHorizontally ? 'auto' : 'unset'\n  }\"\n  id=\"main-container\"\n>\n  <mis-table-filter\n    #filter\n    (filtersApplied)=\"updateAppliedFilters($event)\"\n    *ngIf=\"showFilter()\"\n    [containerStyles]=\"filterContainerStyles()\"\n    [filtersData]=\"filterData()\"\n  ></mis-table-filter>\n  <div\n    #table\n    id=\"table-container\"\n    [ngClass]=\"{ 'no-scrollbar': expandedIndex() < 0, scrollbar: !(expandedIndex() < 0), 'scroll-horizontally': tableConfig().canScrollHorizontally }\"\n  >\n    <div\n    [ngStyle]=\"getColHeadersRowStyles()\"\n      id=\"col-headers-container\"\n    >\n      <div\n        #colHeaderRef\n        (click)=\"colHeader?.action ? colHeader?.action(colHeader) : null\"\n        *ngFor=\"let colHeader of tableConfig()?.colHeaderConfig\"\n        class=\"col-header\"\n        [ngStyle]=\"{\n          width: colHeader?.style?.width || '',\n          cursor: colHeader.action ? 'pointer' : 'default',\n          'justify-content': colHeader?.style?.justifyContent\n            ? colHeader?.style?.justifyContent\n            : colHeader.type === 'number'\n            ? 'flex-end'\n            : 'space-between'\n        }\"\n      >\n        <p *ngIf=\"colHeader?.type !== 'custom' && colHeader?.type !== 'checkbox'\" class=\"col-header-text\">\n          {{ colHeader?.data || \" \" }}\n        </p>\n        <span\n          (click)=\"filterData.set(colHeader.filters); toggleFilter(colHeader.data); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type !== 'custom' && colHeader?.filters && colHeader?.filters?.length > 0\"\n          class=\"filter-icon\"\n        >\n          <span *ngIf=\"appliedFilters()[colHeader.data]?.length > 0\" id=\"filter-active\"></span>\n          <svg fill=\"none\" height=\"10\" viewBox=\"0 0 13 10\" width=\"13\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path\n              clip-rule=\"evenodd\"\n              d=\"M4.97546 10H7.64213V8H4.97546V10ZM0.308472 0V2H12.3085V0H0.308472ZM2.30847 6H10.3085V4H2.30847V6Z\"\n              fill=\"#181F33\"\n              fill-rule=\"evenodd\"\n            />\n          </svg>\n        </span>\n        <span\n          (click)=\"toggleCheckbox(); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type === 'checkbox'\"\n          class=\"checkbox-icon\"\n        >\n          <mis-checkbox [checked]=\"selectAllCheckbox()\"></mis-checkbox>\n        </span>\n        <span *ngIf=\"colHeader?.isSortable && !colHeader?.filters\" appSortIcons\n          [column]=\"colHeader\"\n          [activeSort]=\"currentSort()\"\n          [activeSorts]=\"multiColumnSort()\"\n          [multiColumnSort]=\"tableConfig().multiColumnSort\"\n          (sortChange)=\"onSortChange($event)\"\n          class=\"sort-icon\">\n        </span>\n      <ng-template *ngIf=\"colHeader?.type === 'custom'\" customTableCell [customComponent]=\"colHeader?.componentRef\" [data]=\"colHeader.data\"></ng-template>\n      </div>\n    </div>\n    \n    <div id=\"data-container\">\n      <div class=\"row-wrapper\" *ngFor=\"let row of tableData(); let i = index; let rowIndex = index\">\n        <div\n          class=\"t-row\"\n          [ngClass]=\"{ 't-row-hover': tableConfig().cellHover, 'active-row': activeRowIndex().includes(i) }\"\n          [ngStyle]=\"{ 'min-height': tableConfig()?.rowConfig?.height ? tableConfig().rowConfig.height : '44px' }\"\n          (click)=\"selectRow(i)\"\n          [class.disabled-row]=\"isRowDisabled(row)\"\n          >\n          <div\n            (click)=\"tableConfig()?.colConfig[colIndex]?.action && tableConfig()?.colConfig[colIndex]?.actionType !== 'checkbox' ? tableConfig()?.colConfig[colIndex]?.action(col) : null\"\n            *ngFor=\"let col of row; let colIndex = index\"\n            [ngStyle]=\"{\n              width: tableConfig()?.colConfig[colIndex]?.style?.width || tableConfig()?.colHeaderConfig[colIndex]?.style?.width || ''\n            }\"\n            class=\"t-col-container\"\n            [ngClass]=\"{ 't-col-container-hover': tableConfig().cellHover }\"\n          >\n            <div\n              class=\"t-col\"\n              [style]=\"tableConfig().colConfig[colIndex]?.style\"\n              [ngStyle]=\"{\n                width: '100%',\n                cursor: tableConfig().colConfig[colIndex]?.action ? 'pointer' : 'default',\n                'justify-content': tableConfig().colConfig[colIndex]?.style?.justifyContent\n                  ? tableConfig().colConfig[colIndex]?.style?.justifyContent\n                  : tableConfig().colConfig[colIndex]?.type === 'number'\n                  ? 'flex-end'\n                  : 'space-between'\n              }\"\n            >\n            <div\n            *ngIf=\"tableConfig().colConfig[colIndex]?.type !== 'custom' && tableConfig().colConfig[colIndex]?.type !== 'actions'\"\n            [ngStyle]=\"{\n              color: tableConfig()?.colConfig[colIndex]?.style?.color || '',\n              '--collapsed-lines': previewLines() || 3\n            }\"\n            [ngClass]=\"{\n              'collapsed-cell': collapseColIndex() == colIndex && expandedMap()[rowIndex]\n            }\"\n            class=\"t-col-text\"\n          >\n            <!-- Render as HTML -->\n            <ng-container *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'html'; else plainText\">\n              <span [innerHTML]=\"col\"></span>\n            </ng-container>\n          \n            <!-- Render as plain text -->\n            <ng-template #plainText>\n              <span>{{ col }}</span>\n            </ng-template>\n          </div>\n        \n              <ng-template\n                *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'custom'\"\n                [customComponent]=\"tableConfig().colConfig[colIndex].componentRef\"\n                [data]=\"col\"\n                customTableCell\n              ></ng-template>\n                <mis-actions-cell\n                  *ngIf=\"tableConfig().colConfig[colIndex]?.type === 'actions'\"\n                  [cellData]=\"col\"\n                  [config]=\"tableConfig().colConfig[colIndex]\"\n                  (actionClick)=\"onActionClick($event, rowIndex)\"\n                  [ngClass]=\"{\n                    'disable-actions': (tableConfig().colConfig[colIndex]?.actionType === 'checkbox' || tableConfig().colConfig[colIndex]?.actionType === 'row-collapse') && isRowDisabled(row)\n                  }\"\n                ></mis-actions-cell>\n\n            </div>\n          </div>\n        </div>\n        <div *ngIf=\"tableConfig()?.canExpand && expandedIndex() === i\" class=\"sub-row\">\n          <ng-container *ngIf=\"subTableDataLoading()\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              Loading...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading() && subTableData().length === 0\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              No Data Available...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading() && subTableData().length > 0\">\n            <sub-table [config]=\"subTableconfig()\" [tableData]=\"subTableData()\"></sub-table>\n          </ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div id=\"pagination-content-container\">\n    @if(shouldShowPagination()){\n      <div \n        id=\"pagination-container\"\n      >\n        <p id=\"pagination-text\">\n          Showing\n          {{ (selectedPage() - 1) * tableConfig().paginationConfig.rowsPerPage + 1 }}-{{\n            (selectedPage() - 1) * tableConfig().paginationConfig.rowsPerPage + tableLength()\n          }}\n          of {{ tableConfig().paginationConfig.totalNoOfRows }} items\n        </p>\n        @if(showPageSizeDropdown()) {\n          <div class=\"page-size-selector\">\n            <mis-dropdown\n              [data]=\"pageSizeOptions()\"\n              [selectedItem]=\"selectedPageSizeOption()\"\n              [width]=\"'90px'\"\n              [height]=\"'32px'\"\n              [searchEnabled]=\"false\"\n              [dropdownListHeight]=\"'100px'\"\n              (onChange)=\"onPageSizeChange($event)\"\n              class=\"page-size-dropdown\"\n            ></mis-dropdown>\n          </div>\n        }\n        <div id=\"pages-container\">\n          <span   (click)=\"selectedPage() > 1 && updateSelectedPage(selectedPage() - 1)\" class=\"page\" [class.page-nav-inactive]=\"selectedPage() === 1\">\n            <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                clip-rule=\"evenodd\"\n                d=\"M0.857405 5.56295C0.855794 5.56139 0.854188 5.55982 0.852588 5.55824C0.695955 5.40408 0.617641 5.20203 0.617647 4.99998C0.617641 4.79793 0.695955 4.59588 0.852588 4.44172C0.854188 4.44014 0.855794 4.43858 0.857404 4.43702L5.13066 0.231231C5.44392 -0.0770771 5.9518 -0.0770771 6.26506 0.231231C6.57831 0.53954 6.57831 1.03941 6.26506 1.34772L2.5542 4.99998L6.26506 8.65225C6.57831 8.96055 6.57831 9.46042 6.26506 9.76873C5.9518 10.077 5.44392 10.077 5.13066 9.76873L0.857405 5.56295Z\"\n                fill=\"#181F33\"\n                fill-rule=\"evenodd\"\n              />\n            </svg>\n          </span>\n            <!-- Page numbers (only show if disablePageJumping is false) -->\n            <ng-container *ngIf=\"!tableConfig().paginationConfig?.disablePageJumping\">\n              <div *ngFor=\"let pageNumber of pages()\">\n                <span\n                  (click)=\"updateSelectedPage(pageNumber)\"\n                  *ngIf=\"pageNumber != 0\"\n                  [ngClass]=\"{ 'page-active': pageNumber === selectedPage() }\"\n                  class=\"page page-jumping-enabled\"\n                >{{ pageNumber }}</span>\n                <span *ngIf=\"pageNumber == 0\" class=\"page-seperator\">\n                  <div [ngStyle]=\"{ display: 'flex' }\">\n                    <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                    <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                    <span class=\"dot\"></span>\n                  </div>          \n                </span>\n              </div>\n            </ng-container>\n        \n          <span [class.page-nav-inactive]=\"selectedPage() === tableConfig().paginationConfig?.noOfPages\"\n          (click)=\"selectedPage() < tableConfig().paginationConfig?.noOfPages && updateSelectedPage(selectedPage() + 1)\" class=\"page\">\n            <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path\n                clip-rule=\"evenodd\"\n                d=\"M6.1426 5.56295C6.14421 5.56139 6.14581 5.55982 6.14741 5.55824C6.30405 5.40408 6.38236 5.20203 6.38236 4.99998C6.38236 4.79793 6.30405 4.59588 6.14741 4.44172C6.14581 4.44014 6.14421 4.43858 6.1426 4.43702L1.86934 0.231231C1.55608 -0.0770771 1.0482 -0.0770771 0.734942 0.231231C0.421688 0.53954 0.421688 1.03941 0.734942 1.34772L4.4458 4.99998L0.734941 8.65225C0.421686 8.96055 0.421686 9.46042 0.734941 9.76873C1.0482 10.077 1.55608 10.077 1.86934 9.76873L6.1426 5.56295Z\"\n                fill=\"#181F33\"\n                fill-rule=\"evenodd\"\n              />\n            </svg>\n          </span>\n        </div>\n      </div>\n    }\n  </div>\n</div>\n"]}
|
|
@@ -802,7 +802,7 @@ class TableComponent {
|
|
|
802
802
|
else if (event.actionType === 'row-collapse') {
|
|
803
803
|
const rowCollapse = this.findActionConfig('row-collapse');
|
|
804
804
|
if (rowCollapse && this.tableData()[rowIndex]) {
|
|
805
|
-
|
|
805
|
+
this.tableData()[rowIndex][rowCollapse.index] = event.value;
|
|
806
806
|
rowCollapse.config.action?.(this.tableData());
|
|
807
807
|
this.buildExpandedMap();
|
|
808
808
|
}
|
|
@@ -1850,8 +1850,13 @@ class ActionsCellComponent {
|
|
|
1850
1850
|
}
|
|
1851
1851
|
}
|
|
1852
1852
|
onClick(event) {
|
|
1853
|
-
|
|
1854
|
-
|
|
1853
|
+
let newValue;
|
|
1854
|
+
if (this.actionType() === 'row-collapse') {
|
|
1855
|
+
newValue = !this.currentState();
|
|
1856
|
+
}
|
|
1857
|
+
else {
|
|
1858
|
+
newValue = event && typeof event === 'object' ? event.value : event;
|
|
1859
|
+
}
|
|
1855
1860
|
this.currentState.set(newValue);
|
|
1856
1861
|
this.actionClick.emit({
|
|
1857
1862
|
actionType: this.actionType(),
|