@nova-ui/bits
Version:
SolarWinds Nova Framework
124 lines • 18.4 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 { CdkCell } from "@angular/cdk/table";
import { ChangeDetectorRef, Directive, ElementRef, HostBinding, HostListener, Input, } from "@angular/core";
import { filter } from "rxjs/operators";
import { TableColumnDefDirective } from "./table-column-def.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";
/**
* @ignore
*/
export class TableCellDirective extends CdkCell {
get tooltip() {
return this.tooltipText;
}
// Prevents dragging of table cells content
mouseDown() {
const selection = window.getSelection();
if (selection) {
selection.removeAllRanges();
}
}
constructor(columnDef, elementRef, tableStateHandlerService, cd) {
super(columnDef, elementRef);
this.columnDef = columnDef;
this.elementRef = elementRef;
this.tableStateHandlerService = tableStateHandlerService;
this.cd = cd;
}
ngOnInit() {
const alignment = this.alignment
? `align-${this.alignment}`
: this.tableStateHandlerService.getAlignment(this.columnDef.name);
this.elementRef.nativeElement.classList.add(alignment);
this.currentCellIndex =
this.tableStateHandlerService.tableColumns.indexOf(this.columnDef.name);
if (this.tableStateHandlerService.reorderable) {
this.subscribeToDraggedOverCell =
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";
this.cd.detectChanges();
}
});
}
if (this.tableStateHandlerService.resizable) {
this.resizeSubscription =
this.tableStateHandlerService.shouldHighlightEdge
.pipe(filter((value) => value.columnIndex === this.currentCellIndex))
.subscribe(() => {
// Anytime the event for this column is emitted state will change.
this.rightEdgeActive = !this.rightEdgeActive;
});
}
}
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);
}
}
ngOnDestroy() {
if (this.subscribeToDraggedOverCell) {
this.subscribeToDraggedOverCell.unsubscribe();
}
if (this.resizeSubscription) {
this.resizeSubscription.unsubscribe();
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableCellDirective, deps: [{ token: i1.TableColumnDefDirective }, { token: i0.ElementRef }, { token: i2.TableStateHandlerService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: TableCellDirective, selector: "nui-cell, td[nui-cell]", inputs: { tooltipText: "tooltipText", alignment: "alignment" }, host: { attributes: { "role": "gridcell" }, listeners: { "mousedown": "mouseDown()" }, properties: { "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-cell" }, usesInheritance: true, usesOnChanges: true, ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableCellDirective, decorators: [{
type: Directive,
args: [{
selector: "nui-cell, td[nui-cell]",
host: {
role: "gridcell",
class: "nui-table__table-cell",
},
}]
}], ctorParameters: () => [{ type: i1.TableColumnDefDirective }, { type: i0.ElementRef }, { type: i2.TableStateHandlerService }, { type: i0.ChangeDetectorRef }], propDecorators: { tooltipText: [{
type: Input
}], alignment: [{
type: Input
}], 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"]
}], mouseDown: [{
type: HostListener,
args: ["mousedown"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell.directive.js","sourceRoot":"","sources":["../../../../../src/lib/table/table-cell/table-cell.directive.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 { CdkCell } from \"@angular/cdk/table\";\nimport {\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges,\n} from \"@angular/core\";\nimport { Subscription } from \"rxjs\";\nimport { filter } from \"rxjs/operators\";\n\nimport { TableColumnDefDirective } from \"./table-column-def.directive\";\nimport { TableStateHandlerService } from \"../table-state-handler.service\";\nimport { TableAlignmentOptions } from \"../types\";\n\n/**\n * @ignore\n */\n\n@Directive({\n    selector: \"nui-cell, td[nui-cell]\",\n    host: {\n        role: \"gridcell\",\n        class: \"nui-table__table-cell\",\n    },\n})\nexport class TableCellDirective\n    extends CdkCell\n    implements OnInit, OnDestroy, OnChanges\n{\n    @Input() tooltipText: string;\n    @Input() alignment: TableAlignmentOptions;\n    public currentCellIndex: number;\n    private subscribeToDraggedOverCell: Subscription;\n    private resizeSubscription: Subscription;\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    // Prevents dragging of table cells content\n    @HostListener(\"mousedown\")\n    mouseDown(): void {\n        const selection: Selection | null = window.getSelection();\n        if (selection) {\n            selection.removeAllRanges();\n        }\n    }\n\n    constructor(\n        private columnDef: TableColumnDefDirective,\n        private elementRef: ElementRef,\n        private tableStateHandlerService: TableStateHandlerService,\n        private cd: ChangeDetectorRef\n    ) {\n        super(columnDef, elementRef);\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.elementRef.nativeElement.classList.add(alignment);\n        this.currentCellIndex =\n            this.tableStateHandlerService.tableColumns.indexOf(\n                this.columnDef.name\n            );\n\n        if (this.tableStateHandlerService.reorderable) {\n            this.subscribeToDraggedOverCell =\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                            this.cd.detectChanges();\n                        }\n                    }\n                );\n        }\n\n        if (this.tableStateHandlerService.resizable) {\n            this.resizeSubscription =\n                this.tableStateHandlerService.shouldHighlightEdge\n                    .pipe(\n                        filter(\n                            (value) =>\n                                value.columnIndex === this.currentCellIndex\n                        )\n                    )\n                    .subscribe(() => {\n                        // Anytime the event for this column is emitted state will change.\n                        this.rightEdgeActive = !this.rightEdgeActive;\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 ngOnDestroy(): void {\n        if (this.subscribeToDraggedOverCell) {\n            this.subscribeToDraggedOverCell.unsubscribe();\n        }\n\n        if (this.resizeSubscription) {\n            this.resizeSubscription.unsubscribe();\n        }\n    }\n}\n"]}