@nova-ui/bits
Version:
SolarWinds Nova Framework
326 lines • 47.7 kB
JavaScript
// © 2022 SolarWinds Worldwide, LLC. All rights reserved.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
import { CdkHeaderCell } from "@angular/cdk/table";
import { Component, ElementRef, HostBinding, HostListener, Input, NgZone, Renderer2, } from "@angular/core";
import _isNil from "lodash/isNil";
import _isUndefined from "lodash/isUndefined";
import { fromEvent } from "rxjs";
import { filter, pluck } from "rxjs/operators";
import { TableColumnDefDirective } from "./table-column-def.directive";
import { UtilService } from "../../../services/util.service";
import { FIXED_WIDTH_CLASS } from "../constants";
import { TableResizePhase } from "../table-resizer/table-resizer.directive";
import { TableStateHandlerService, } from "../table-state-handler.service";
import * as i0 from "@angular/core";
import * as i1 from "./table-column-def.directive";
import * as i2 from "../table-state-handler.service";
import * as i3 from "../../../services/util.service";
import * as i4 from "@angular/common";
import * as i5 from "../../icon/icon.component";
import * as i6 from "../table-resizer/table-resizer.directive";
/**
* @ignore
*/
export class TableHeaderCellComponent extends CdkHeaderCell {
// binding classes
get isIconCell() {
return this.columnDef.type === "icon";
}
/**
* Conditionally applies a fixed-width marker class for letting external entities
* know whether manual updates to the cell's width are allowed.
*/
get fixedWidth() {
return this.isIconCell;
}
get shouldBeDarkOnSorting() {
return this.sortingState.isColumnSorted;
}
get shouldBeDarkOnReorder() {
return this.leftEdgeActive || this.rightEdgeActive;
}
get isSortable() {
return (this.tableStateHandlerService.sortable &&
!this.isColumnSortingDisabled);
}
get isColumnSorted() {
return this.sortingState.isColumnSorted;
}
get isReorderable() {
return this.tableStateHandlerService.reorderable;
}
get tooltip() {
return this.tooltipText;
}
mouseMovedOver() {
if (this.isColumnResizable() && !this.resizeInProgress) {
this.rightEdgeActive = this.isCursorInCell = true;
}
}
mouseMovedOut() {
// There are some of edge cases of incorrect highlighting that is covered with these booleans
this.isCursorInCell = false;
if (this.isColumnResizable() && this.resizeEventPhase !== "start") {
this.rightEdgeActive = false;
}
}
clicked() {
if (this.tableStateHandlerService.sortable &&
!this.isColumnSortingDisabled &&
this.resizeEventPhase !== TableResizePhase.start) {
const cellIndex = this.tableStateHandlerService.tableColumns.indexOf(this.columnDef.name);
this.tableStateHandlerService.sortColumn(cellIndex);
}
}
// listening for drag n drop events
dragStarted(event) {
if (this.isReorderable) {
const dragTarget = event.target;
const dragCellIndex = this.tableStateHandlerService.getTargetElementCellIndex(event);
this.tableStateHandlerService.dragCellIndex = dragCellIndex;
event.stopPropagation();
if (!event.dataTransfer) {
throw new Error("dataTransfer is null");
}
event.dataTransfer.effectAllowed = "move";
// Prevents dropping foreign elements into table header row
// Also drag n drop doesn't work in Firefox if no data is attached to event.dataTransfer
event.dataTransfer.setData("text", dragCellIndex.toString());
const windowSelection = window.getSelection();
// Prevents dragging a halo of multiple elements, if being selected on screen
if (!_isNil(windowSelection?.type) &&
windowSelection?.type === "Range") {
windowSelection.removeAllRanges();
event.dataTransfer.setDragImage(dragTarget, dragTarget.clientWidth / 2, dragTarget.clientHeight / 2);
}
}
}
dropped(event) {
const dragCellIndex = this.tableStateHandlerService.dragCellIndex;
const dataTransferData = event.dataTransfer?.getData("text");
event.stopPropagation();
event.preventDefault();
this.tableStateHandlerService.draggedOverCell.next(undefined);
if (!_isNil(dragCellIndex) &&
!_isNil(dataTransferData) &&
dragCellIndex.toString() === dataTransferData) {
this.tableStateHandlerService.reorderColumnsOnDrop();
}
}
dragEnd(event) {
event.stopPropagation();
this.tableStateHandlerService.draggedOverCell.next(undefined);
}
constructor(columnDef, elementRef, tableStateHandlerService, utilService, zone, renderer) {
super(columnDef, elementRef);
this.columnDef = columnDef;
this.elementRef = elementRef;
this.tableStateHandlerService = tableStateHandlerService;
this.utilService = utilService;
this.zone = zone;
this.renderer = renderer;
this.isColumnSortingDisabled = false;
this.subscriptions = [];
this.resizable = false;
this.tableStateHandlerService.columnType = {
columnName: this.columnDef.name,
columnType: this.columnDef.type || "default",
};
}
ngOnInit() {
const alignment = this.alignment
? `align-${this.alignment}`
: this.tableStateHandlerService.getAlignment(this.columnDef.name);
this.resizable = this.tableStateHandlerService.resizable;
this.elementRef.nativeElement.classList.add(alignment);
this.currentCellIndex =
this.tableStateHandlerService.tableColumns.indexOf(this.columnDef.name);
this.sortingState = this.tableStateHandlerService.getSortingState(this.currentCellIndex);
if (this.resizable) {
// Get initial width
const columnWidth = this.tableStateHandlerService.getColumnWidth(this.columnDef.name);
this.elementRef.nativeElement.style.width = columnWidth + "px";
this.subscriptions.push(this.tableStateHandlerService.shouldHighlightEdge
.pipe(filter((value) => {
// When resize is in progress on other columns this one shouldn't be highlighted
this.resizeInProgress =
value.columnIndex !== this.currentCellIndex &&
value.eventPhase === "start";
return value.columnIndex === this.currentCellIndex;
}), pluck("eventPhase"))
.subscribe((eventPhase) => {
this.resizeEventPhase = eventPhase;
this.rightEdgeActive = this.isCursorInCell;
}));
}
this.subscriptions.push(this.tableStateHandlerService.columnWidthSubject.subscribe(() => {
const columnWidth = this.tableStateHandlerService.getColumnWidth(this.columnDef.name);
if (columnWidth > 45) {
this.renderer.setStyle(this.elementRef.nativeElement, "width", columnWidth + "px");
}
}));
if (this.isSortable) {
this.subscriptions.push(this.tableStateHandlerService.sortingState.subscribe(() => {
this.sortingState =
this.tableStateHandlerService.getSortingState(this.currentCellIndex);
}));
}
if (this.isReorderable) {
this.subscriptions.push(this.tableStateHandlerService.draggedOverCell.subscribe((draggedOverCell) => {
this.rightEdgeActive = this.leftEdgeActive = false;
if (draggedOverCell?.cellIndex === this.currentCellIndex) {
this.rightEdgeActive =
draggedOverCell?.dropAlignment === "right";
this.leftEdgeActive =
draggedOverCell?.dropAlignment === "left";
}
}));
}
}
ngOnChanges(changes) {
if (changes.alignment && !changes.alignment.firstChange) {
const newAlignment = `align-${changes.alignment.currentValue}`;
const oldAlignment = `align-${changes.alignment.previousValue}`;
this.elementRef.nativeElement.classList.remove(oldAlignment);
this.elementRef.nativeElement.classList.add(newAlignment);
}
}
ngAfterViewInit() {
this.zone.runOutsideAngular(() => {
this.subscriptions.push(fromEvent(this.elementRef.nativeElement, "dragover").subscribe((event) => {
event.stopPropagation();
event.preventDefault();
this.tableStateHandlerService.setDraggedOverCell(event);
}));
});
}
isColumnResizable() {
const isColumnTypeResizable = _isUndefined(this.columnDef.type);
return this.tableStateHandlerService.resizable && isColumnTypeResizable;
}
onColumnWidthChange(offset) {
const currentWidth = this.tableStateHandlerService.getColumnWidth(this.columnDef.name);
const resultWidth = currentWidth + offset;
// resultWidth must be more than 45 because minimum width of the column is 46px
if (resultWidth > 45 || offset > 0) {
this.tableStateHandlerService.setColumnWidth(this.columnDef.name, resultWidth);
}
}
ngOnDestroy() {
this.subscriptions.forEach((subscription) => subscription.unsubscribe());
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableHeaderCellComponent, deps: [{ token: i1.TableColumnDefDirective }, { token: i0.ElementRef }, { token: i2.TableStateHandlerService }, { token: i3.UtilService }, { token: i0.NgZone }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TableHeaderCellComponent, selector: "nui-header-cell, th[nui-header-cell]", inputs: { alignment: "alignment", tooltipText: "tooltipText", isColumnSortingDisabled: "isColumnSortingDisabled" }, host: { attributes: { "role": "columnheader" }, listeners: { "mouseover": "mouseMovedOver()", "mouseleave": "mouseMovedOut()", "click": "clicked()", "dragstart": "dragStarted($event)", "drop": "dropped($event)", "dragend": "dragEnd($event)" }, properties: { "class.nui-table__icon-cell": "this.isIconCell", "class.nui-fixed-width": "this.fixedWidth", "class.nui-table__table-header-cell--sortable--dark": "this.shouldBeDarkOnSorting", "class.nui-table__table-header-cell--reorderable--dark": "this.shouldBeDarkOnReorder", "class.nui-table__table-header-cell--sortable": "this.isSortable", "class.nui-table__table-header-cell--sortable--text-black": "this.isColumnSorted", "attr.draggable": "this.isReorderable", "class.nui-table__table-header-cell--reorderable": "this.isReorderable", "attr.title": "this.tooltip", "class.nui-table__table-cell--left-edge-action": "this.leftEdgeActive", "class.nui-table__table-cell--right-edge-action": "this.rightEdgeActive" }, classAttribute: "nui-table__table-header-cell" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: ` <ng-content></ng-content>
<nui-icon
*ngIf="sortingState.isColumnSorted"
class="nui-table__sorting-icon"
[icon]="sortingState.sortingIcon"
iconColor="gray"
></nui-icon>
<span
*ngIf="isColumnResizable()"
(click)="$event.stopPropagation()"
nuiTableResizer
[columnIndex]="currentCellIndex"
(resizerMovement)="onColumnWidthChange($event)"
></span>`, isInline: true, dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.IconComponent, selector: "nui-icon", inputs: ["iconColor", "brushType", "iconHoverColor", "iconSize", "cssClass", "fillContainer", "status", "childStatus", "icon", "counter"] }, { kind: "directive", type: i6.TableResizerDirective, selector: "[nuiTableResizer]", inputs: ["columnIndex"], outputs: ["resizerMovement"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableHeaderCellComponent, decorators: [{
type: Component,
args: [{
selector: "nui-header-cell, th[nui-header-cell]",
host: {
role: "columnheader",
class: "nui-table__table-header-cell",
},
template: ` <ng-content></ng-content>
<nui-icon
*ngIf="sortingState.isColumnSorted"
class="nui-table__sorting-icon"
[icon]="sortingState.sortingIcon"
iconColor="gray"
></nui-icon>
<span
*ngIf="isColumnResizable()"
(click)="$event.stopPropagation()"
nuiTableResizer
[columnIndex]="currentCellIndex"
(resizerMovement)="onColumnWidthChange($event)"
></span>`,
}]
}], ctorParameters: () => [{ type: i1.TableColumnDefDirective }, { type: i0.ElementRef }, { type: i2.TableStateHandlerService }, { type: i3.UtilService }, { type: i0.NgZone }, { type: i0.Renderer2 }], propDecorators: { alignment: [{
type: Input
}], tooltipText: [{
type: Input
}], isColumnSortingDisabled: [{
type: Input
}], isIconCell: [{
type: HostBinding,
args: ["class.nui-table__icon-cell"]
}], fixedWidth: [{
type: HostBinding,
args: [`class.${FIXED_WIDTH_CLASS}`]
}], shouldBeDarkOnSorting: [{
type: HostBinding,
args: ["class.nui-table__table-header-cell--sortable--dark"]
}], shouldBeDarkOnReorder: [{
type: HostBinding,
args: ["class.nui-table__table-header-cell--reorderable--dark"]
}], isSortable: [{
type: HostBinding,
args: ["class.nui-table__table-header-cell--sortable"]
}], isColumnSorted: [{
type: HostBinding,
args: ["class.nui-table__table-header-cell--sortable--text-black"]
}], isReorderable: [{
type: HostBinding,
args: ["attr.draggable"]
}, {
type: HostBinding,
args: ["class.nui-table__table-header-cell--reorderable"]
}], tooltip: [{
type: HostBinding,
args: ["attr.title"]
}], leftEdgeActive: [{
type: HostBinding,
args: ["class.nui-table__table-cell--left-edge-action"]
}], rightEdgeActive: [{
type: HostBinding,
args: ["class.nui-table__table-cell--right-edge-action"]
}], mouseMovedOver: [{
type: HostListener,
args: ["mouseover"]
}], mouseMovedOut: [{
type: HostListener,
args: ["mouseleave"]
}], clicked: [{
type: HostListener,
args: ["click"]
}], dragStarted: [{
type: HostListener,
args: ["dragstart", ["$event"]]
}], dropped: [{
type: HostListener,
args: ["drop", ["$event"]]
}], dragEnd: [{
type: HostListener,
args: ["dragend", ["$event"]]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-header-cell.component.js","sourceRoot":"","sources":["../../../../../src/lib/table/table-cell/table-header-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["// © 2022 SolarWinds Worldwide, LLC. All rights reserved.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n//  of this software and associated documentation files (the \"Software\"), to\n//  deal in the Software without restriction, including without limitation the\n//  rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n//  sell copies of the Software, and to permit persons to whom the Software is\n//  furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n//  all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n//  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n//  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n//  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n//  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n//  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n//  THE SOFTWARE.\n\nimport { CdkHeaderCell } from \"@angular/cdk/table\";\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Renderer2,\n    SimpleChanges,\n} from \"@angular/core\";\nimport _isNil from \"lodash/isNil\";\nimport _isUndefined from \"lodash/isUndefined\";\nimport { fromEvent, Subscription } from \"rxjs\";\nimport { filter, pluck } from \"rxjs/operators\";\n\nimport { TableColumnDefDirective } from \"./table-column-def.directive\";\nimport { IDragEvent } from \"../../../common/directives/public-api\";\nimport { UtilService } from \"../../../services/util.service\";\nimport { FIXED_WIDTH_CLASS } from \"../constants\";\nimport { TableResizePhase } from \"../table-resizer/table-resizer.directive\";\nimport {\n    ColumnType,\n    ITableSortingState,\n    TableStateHandlerService,\n} from \"../table-state-handler.service\";\nimport { NonResizableColumnTypes, TableAlignmentOptions } from \"../types\";\n\n/**\n * @ignore\n */\n\n@Component({\n    selector: \"nui-header-cell, th[nui-header-cell]\",\n    host: {\n        role: \"columnheader\",\n        class: \"nui-table__table-header-cell\",\n    },\n    template: ` <ng-content></ng-content>\n        <nui-icon\n            *ngIf=\"sortingState.isColumnSorted\"\n            class=\"nui-table__sorting-icon\"\n            [icon]=\"sortingState.sortingIcon\"\n            iconColor=\"gray\"\n        ></nui-icon>\n        <span\n            *ngIf=\"isColumnResizable()\"\n            (click)=\"$event.stopPropagation()\"\n            nuiTableResizer\n            [columnIndex]=\"currentCellIndex\"\n            (resizerMovement)=\"onColumnWidthChange($event)\"\n        ></span>`,\n})\nexport class TableHeaderCellComponent\n    extends CdkHeaderCell\n    implements OnInit, OnChanges, AfterViewInit, OnDestroy\n{\n    @Input() alignment: TableAlignmentOptions;\n    @Input() tooltipText: string;\n    @Input() isColumnSortingDisabled: boolean = false;\n    public currentCellIndex: number;\n    private resizeInProgress: boolean;\n    // Helps to show/hide edge highlight when cursor is outside of the resizable header cell\n    private isCursorInCell: boolean;\n    private resizeEventPhase: TableResizePhase;\n    private subscriptions: Subscription[] = [];\n    public resizable = false;\n    public sortingState: ITableSortingState;\n\n    // binding classes\n    @HostBinding(\"class.nui-table__icon-cell\")\n    get isIconCell(): boolean {\n        return this.columnDef.type === \"icon\";\n    }\n\n    /**\n     * Conditionally applies a fixed-width marker class for letting external entities\n     * know whether manual updates to the cell's width are allowed.\n     */\n    @HostBinding(`class.${FIXED_WIDTH_CLASS}`)\n    get fixedWidth(): boolean {\n        return this.isIconCell;\n    }\n\n    @HostBinding(\"class.nui-table__table-header-cell--sortable--dark\")\n    get shouldBeDarkOnSorting(): boolean {\n        return this.sortingState.isColumnSorted;\n    }\n\n    @HostBinding(\"class.nui-table__table-header-cell--reorderable--dark\")\n    get shouldBeDarkOnReorder(): boolean {\n        return this.leftEdgeActive || this.rightEdgeActive;\n    }\n\n    @HostBinding(\"class.nui-table__table-header-cell--sortable\")\n    get isSortable(): boolean {\n        return (\n            this.tableStateHandlerService.sortable &&\n            !this.isColumnSortingDisabled\n        );\n    }\n\n    @HostBinding(\"class.nui-table__table-header-cell--sortable--text-black\")\n    get isColumnSorted(): boolean {\n        return this.sortingState.isColumnSorted;\n    }\n\n    @HostBinding(\"attr.draggable\")\n    @HostBinding(\"class.nui-table__table-header-cell--reorderable\")\n    get isReorderable(): boolean {\n        return this.tableStateHandlerService.reorderable;\n    }\n\n    @HostBinding(\"attr.title\")\n    get tooltip(): string {\n        return this.tooltipText;\n    }\n\n    @HostBinding(\"class.nui-table__table-cell--left-edge-action\")\n    leftEdgeActive: boolean;\n    @HostBinding(\"class.nui-table__table-cell--right-edge-action\")\n    rightEdgeActive: boolean;\n\n    @HostListener(\"mouseover\")\n    mouseMovedOver(): void {\n        if (this.isColumnResizable() && !this.resizeInProgress) {\n            this.rightEdgeActive = this.isCursorInCell = true;\n        }\n    }\n\n    @HostListener(\"mouseleave\")\n    mouseMovedOut(): void {\n        // There are some of edge cases of incorrect highlighting that is covered with these booleans\n        this.isCursorInCell = false;\n        if (this.isColumnResizable() && this.resizeEventPhase !== \"start\") {\n            this.rightEdgeActive = false;\n        }\n    }\n\n    @HostListener(\"click\")\n    clicked(): void {\n        if (\n            this.tableStateHandlerService.sortable &&\n            !this.isColumnSortingDisabled &&\n            this.resizeEventPhase !== TableResizePhase.start\n        ) {\n            const cellIndex =\n                this.tableStateHandlerService.tableColumns.indexOf(\n                    this.columnDef.name\n                );\n            this.tableStateHandlerService.sortColumn(cellIndex);\n        }\n    }\n\n    // listening for drag n drop events\n    @HostListener(\"dragstart\", [\"$event\"])\n    dragStarted(event: IDragEvent): void {\n        if (this.isReorderable) {\n            const dragTarget = <Element>event.target;\n            const dragCellIndex =\n                this.tableStateHandlerService.getTargetElementCellIndex(event);\n\n            this.tableStateHandlerService.dragCellIndex = dragCellIndex;\n            event.stopPropagation();\n\n            if (!event.dataTransfer) {\n                throw new Error(\"dataTransfer is null\");\n            }\n\n            event.dataTransfer.effectAllowed = \"move\";\n\n            // Prevents dropping foreign elements into table header row\n            // Also drag n drop doesn't work in Firefox if no data is attached to event.dataTransfer\n            event.dataTransfer.setData(\"text\", dragCellIndex.toString());\n\n            const windowSelection: Selection | null = window.getSelection();\n            // Prevents dragging a halo of multiple elements, if being selected on screen\n            if (\n                !_isNil(windowSelection?.type) &&\n                windowSelection?.type === \"Range\"\n            ) {\n                windowSelection.removeAllRanges();\n                event.dataTransfer.setDragImage(\n                    dragTarget,\n                    dragTarget.clientWidth / 2,\n                    dragTarget.clientHeight / 2\n                );\n            }\n        }\n    }\n\n    @HostListener(\"drop\", [\"$event\"])\n    dropped(event: IDragEvent): void {\n        const dragCellIndex = this.tableStateHandlerService.dragCellIndex;\n        const dataTransferData = event.dataTransfer?.getData(\"text\");\n\n        event.stopPropagation();\n        event.preventDefault();\n        this.tableStateHandlerService.draggedOverCell.next(undefined);\n\n        if (\n            !_isNil(dragCellIndex) &&\n            !_isNil(dataTransferData) &&\n            dragCellIndex.toString() === dataTransferData\n        ) {\n            this.tableStateHandlerService.reorderColumnsOnDrop();\n        }\n    }\n\n    @HostListener(\"dragend\", [\"$event\"])\n    dragEnd(event: IDragEvent): void {\n        event.stopPropagation();\n        this.tableStateHandlerService.draggedOverCell.next(undefined);\n    }\n\n    constructor(\n        private columnDef: TableColumnDefDirective,\n        private elementRef: ElementRef,\n        private tableStateHandlerService: TableStateHandlerService,\n        private utilService: UtilService,\n        private zone: NgZone,\n        private renderer: Renderer2\n    ) {\n        super(columnDef, elementRef);\n\n        this.tableStateHandlerService.columnType = <ColumnType>{\n            columnName: this.columnDef.name,\n            columnType: this.columnDef.type || \"default\",\n        };\n    }\n\n    public ngOnInit(): void {\n        const alignment = this.alignment\n            ? `align-${this.alignment}`\n            : this.tableStateHandlerService.getAlignment(this.columnDef.name);\n\n        this.resizable = this.tableStateHandlerService.resizable;\n        this.elementRef.nativeElement.classList.add(alignment);\n        this.currentCellIndex =\n            this.tableStateHandlerService.tableColumns.indexOf(\n                this.columnDef.name\n            );\n        this.sortingState = this.tableStateHandlerService.getSortingState(\n            this.currentCellIndex\n        );\n\n        if (this.resizable) {\n            // Get initial width\n            const columnWidth = this.tableStateHandlerService.getColumnWidth(\n                this.columnDef.name\n            );\n\n            this.elementRef.nativeElement.style.width = columnWidth + \"px\";\n            this.subscriptions.push(\n                this.tableStateHandlerService.shouldHighlightEdge\n                    .pipe(\n                        filter((value) => {\n                            // When resize is in progress on other columns this one shouldn't be highlighted\n                            this.resizeInProgress =\n                                value.columnIndex !== this.currentCellIndex &&\n                                value.eventPhase === \"start\";\n                            return value.columnIndex === this.currentCellIndex;\n                        }),\n                        pluck(\"eventPhase\")\n                    )\n                    .subscribe((eventPhase: TableResizePhase) => {\n                        this.resizeEventPhase = eventPhase;\n                        this.rightEdgeActive = this.isCursorInCell;\n                    })\n            );\n        }\n        this.subscriptions.push(\n            this.tableStateHandlerService.columnWidthSubject.subscribe(() => {\n                const columnWidth =\n                    this.tableStateHandlerService.getColumnWidth(\n                        this.columnDef.name\n                    );\n                if (columnWidth > 45) {\n                    this.renderer.setStyle(this.elementRef.nativeElement, \"width\", columnWidth + \"px\");\n                }\n            })\n        );\n\n        if (this.isSortable) {\n            this.subscriptions.push(\n                this.tableStateHandlerService.sortingState.subscribe(() => {\n                    this.sortingState =\n                        this.tableStateHandlerService.getSortingState(\n                            this.currentCellIndex\n                        );\n                })\n            );\n        }\n\n        if (this.isReorderable) {\n            this.subscriptions.push(\n                this.tableStateHandlerService.draggedOverCell.subscribe(\n                    (draggedOverCell) => {\n                        this.rightEdgeActive = this.leftEdgeActive = false;\n                        if (\n                            draggedOverCell?.cellIndex === this.currentCellIndex\n                        ) {\n                            this.rightEdgeActive =\n                                draggedOverCell?.dropAlignment === \"right\";\n                            this.leftEdgeActive =\n                                draggedOverCell?.dropAlignment === \"left\";\n                        }\n                    }\n                )\n            );\n        }\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.alignment && !changes.alignment.firstChange) {\n            const newAlignment = `align-${changes.alignment.currentValue}`;\n            const oldAlignment = `align-${changes.alignment.previousValue}`;\n            this.elementRef.nativeElement.classList.remove(oldAlignment);\n            this.elementRef.nativeElement.classList.add(newAlignment);\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        this.zone.runOutsideAngular(() => {\n            this.subscriptions.push(\n                fromEvent<DragEvent>(\n                    this.elementRef.nativeElement,\n                    \"dragover\"\n                ).subscribe((event: DragEvent) => {\n                    event.stopPropagation();\n                    event.preventDefault();\n                    this.tableStateHandlerService.setDraggedOverCell(event);\n                })\n            );\n        });\n    }\n\n    public isColumnResizable(): boolean {\n        const isColumnTypeResizable = _isUndefined(\n            <NonResizableColumnTypes>this.columnDef.type\n        );\n        return this.tableStateHandlerService.resizable && isColumnTypeResizable;\n    }\n\n    public onColumnWidthChange(offset: number): void {\n        const currentWidth = this.tableStateHandlerService.getColumnWidth(this.columnDef.name);\n        const resultWidth = currentWidth + offset;\n\n        // resultWidth must be more than 45 because minimum width of the column is 46px\n        if (resultWidth > 45 || offset > 0) {\n            this.tableStateHandlerService.setColumnWidth(\n                this.columnDef.name,\n                resultWidth\n            );\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.subscriptions.forEach((subscription) =>\n            subscription.unsubscribe()\n        );\n    }\n}\n"]}