UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

124 lines 18.4 kB
// © 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"]}