UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

346 lines 63.3 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 { Directionality } from "@angular/cdk/bidi"; import { _DisposeViewRepeaterStrategy, _VIEW_REPEATER_STRATEGY, } from "@angular/cdk/collections"; import { Platform } from "@angular/cdk/platform"; import { CdkVirtualForOf, ViewportRuler } from "@angular/cdk/scrolling"; import { _COALESCED_STYLE_SCHEDULER, _CoalescedStyleScheduler, CDK_TABLE, CDK_TABLE_TEMPLATE, CdkTable, STICKY_POSITIONING_LISTENER, } from "@angular/cdk/table"; import { DOCUMENT } from "@angular/common"; import { Attribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, EventEmitter, HostBinding, Inject, Input, IterableDiffers, Optional, Output, SkipSelf, ViewEncapsulation, } from "@angular/core"; import _isEqual from "lodash/isEqual"; import _keys from "lodash/keys"; import { TableStateHandlerService } from "./table-state-handler.service"; import { TableSelectionMode } from "./types"; import * as i0 from "@angular/core"; import * as i1 from "@angular/cdk/bidi"; import * as i2 from "./table-state-handler.service"; import * as i3 from "@angular/cdk/platform"; import * as i4 from "@angular/cdk/scrolling"; import * as i5 from "@angular/cdk/table"; // <example-url>./../examples/index.html#/table</example-url> /** @dynamic */ export class TableComponent extends CdkTable { get dataSource() { return super.dataSource; } set dataSource(value) { super.dataSource = value; } constructor(_differs, _changeDetectorRef, _elementRef, role, _dir, tableStateHandlerService, document, platform, viewRepeater, coalescedStyleScheduler, viewportRuler, stickyPositioningListener) { // The _ViewRepeater and _CoalescedStyleScheduler parameters were optional before Angular v12. // They're included here for compatibility with Angular v12 and later. super(_differs, _changeDetectorRef, _elementRef, role, _dir, document, platform, viewRepeater, coalescedStyleScheduler, viewportRuler, stickyPositioningListener); this._differs = _differs; this._changeDetectorRef = _changeDetectorRef; this._elementRef = _elementRef; this._dir = _dir; this.tableStateHandlerService = tableStateHandlerService; this.document = document; this.platform = platform; this.reorderable = false; this.sortable = false; this.resizable = false; /** * @deprecated Use selectionConfig instead. */ this.selectable = false; this.selectionConfig = { enabled: false, selectionMode: TableSelectionMode.None, }; this.paginatorUsed = false; this.columnsOrderChange = new EventEmitter(); this.sortOrderChanged = new EventEmitter(); this.selectionChange = new EventEmitter(); this.columnsWidthChange = new EventEmitter(); this.layoutFixed = false; } getFilterComponents() { return !this.sortable ? {} : { sorter: { componentInstance: { // mark this filter to be monitored by our datasource for any changes in order reset other filters(eg: pagination) // before any new search is performed detectFilterChanges: true, getFilters: () => ({ type: "sorter", value: { sortBy: this.sortBy, direction: this.sortDirection, }, }), }, }, }; } // using on changes hook for datasource because if we use pagination, // datasource changes when we change page and rows should know about this ngOnChanges(changes) { if (changes.resizable) { this.tableStateHandlerService.resizable = changes.resizable.currentValue; this.layoutFixed = changes.resizable.currentValue; } if (changes.reorderable) { this.tableStateHandlerService.reorderable = changes.reorderable.currentValue; } if (changes.sortable) { this.tableStateHandlerService.sortable = changes.sortable.currentValue; } if (changes.dataSource) { this.onDataSourceChange(changes.dataSource.currentValue); } if (changes.selectable) { this.changeSelectionMode(changes.selectable.currentValue); } if (changes.selectionConfig) { this.tableStateHandlerService.selectionMode = changes.selectionConfig.currentValue?.selectionMode; } if (changes.selection && !changes.selection.isFirstChange()) { this.changeSelection(changes.selection.currentValue); } if (changes.sortedColumn && !changes.sortedColumn.isFirstChange()) { this.handleSortedColumn(changes.sortedColumn.currentValue); } if (changes.trackBy) { this.tableStateHandlerService.trackBy = changes.trackBy.currentValue; } } ngOnInit() { super.ngOnInit(); const dataSet = this.dataSource; const firstRow = dataSet && dataSet[0]; const columns = _keys(firstRow); this.tableStateHandlerService.tableColumns = columns; columns.forEach((column) => { const alignment = this.tableStateHandlerService.defineAlignment(firstRow[column]); this.tableStateHandlerService.setAlignment(column, alignment); }); if (this.resizable) { this.tableColumnsWidthSubscription = this.tableStateHandlerService.columnWidthSubject.subscribe(() => { this.columnsWidthChange.emit(); }); const parentWidth = this._elementRef.nativeElement.parentElement.getBoundingClientRect().width ? this._elementRef.nativeElement.parentElement.getBoundingClientRect() .width : this._elementRef.nativeElement.parentElement.parentElement.getBoundingClientRect() .width; this.layoutFixed = true; this.tableStateHandlerService.tableParentWidth = parentWidth; } if (this.sortable) { this.tableSortingSubscription = this.tableStateHandlerService.sortingState.subscribe((sortedColumn) => { this.sortDirection = sortedColumn.direction; this.sortBy = sortedColumn.sortBy; // emit only if the data is really changed if (!_isEqual(sortedColumn, this.sortedColumn)) { this.sortOrderChanged.emit(sortedColumn); } }); if (this.sortedColumn) { this.handleSortedColumn(this.sortedColumn); } } if (this.reorderable) { this.tableColumnsSubscription = this.tableStateHandlerService.columnsState.subscribe((tableColumns) => { this.columnsOrderChange.emit(tableColumns); }); } if (this.selectable || this.selectionConfig?.enabled) { this.stickyChangedSubscription = this.tableStateHandlerService.stickyHeaderChangedSubject.subscribe(() => { // calling cdk method to update sticky styles this.updateStickyHeaderRowStyles(); }); } } ngAfterViewInit() { // moved this from ngOnInit since we might emit the selectionChange event // before our component is actually ready and it might cause problems // if we try to manually trigger change detection in a parent component if (this.selectable || this.selectionConfig?.enabled) { this.selectionChangedSubscription = this.tableStateHandlerService.selectionChanged.subscribe((selection) => { this.selectionChange.emit(selection); }); if (this.selection) { this.changeSelection(this.selection); } } } changeSelection(selectedItems) { this.tableStateHandlerService.selection = selectedItems; this.tableStateHandlerService.selectionChanged.next(this.tableStateHandlerService.selection); } // used for backwards compatibility // default behavior was multi selection changeSelectionMode(selectable) { this.tableStateHandlerService.selectable = selectable; if (selectable) { this.tableStateHandlerService.selectionMode = TableSelectionMode.Multi; this.selectionConfig = { ...this.selectionConfig, enabled: true, selectionMode: TableSelectionMode.Multi, }; } else { this.tableStateHandlerService.selectionMode = TableSelectionMode.None; this.selectionConfig = { enabled: false, selectionMode: TableSelectionMode.None, }; } } handleSortedColumn(sortedColumn) { this.tableStateHandlerService.sortedColumn = sortedColumn; this.tableStateHandlerService.sortingState.next(sortedColumn); } onDataSourceChange(ds) { if (!ds) { this.dataSource = []; } const changedDataSource = ds ? ds : []; // if no totalItems specified, we assume that there is only one page this.tableStateHandlerService.totalItems = this.totalItems || changedDataSource.length; this.tableStateHandlerService.changeDataSource(changedDataSource); } ngOnDestroy() { if (this.tableSortingSubscription) { this.tableSortingSubscription.unsubscribe(); } if (this.tableColumnsSubscription) { this.tableColumnsSubscription.unsubscribe(); } if (this.selectionChangedSubscription) { this.selectionChangedSubscription.unsubscribe(); } if (this.stickyChangedSubscription) { this.stickyChangedSubscription.unsubscribe(); } if (this.tableColumnsWidthSubscription) { this.tableColumnsWidthSubscription.unsubscribe(); } super.ngOnDestroy(); } ngAfterContentInit() { // @ts-ignore: Call parent method in case cdk adds it later super.ngAfterContentInit?.(); // Note: Identifying if table is using virtual scroll. this.tableStateHandlerService.hasVirtualScroll = !!this.virtualFor && !this.paginatorUsed; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableComponent, deps: [{ token: i0.IterableDiffers }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: "role", attribute: true }, { token: i1.Directionality }, { token: i2.TableStateHandlerService }, { token: DOCUMENT }, { token: i3.Platform }, { token: _VIEW_REPEATER_STRATEGY }, { token: _COALESCED_STYLE_SCHEDULER }, { token: i4.ViewportRuler }, { token: STICKY_POSITIONING_LISTENER, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TableComponent, selector: "nui-table, table[nui-table]", inputs: { reorderable: "reorderable", sortable: "sortable", resizable: "resizable", selectable: "selectable", selectionConfig: "selectionConfig", totalItems: "totalItems", dataSource: "dataSource", selection: "selection", sortedColumn: "sortedColumn", paginatorUsed: "paginatorUsed" }, outputs: { columnsOrderChange: "columnsOrderChange", sortOrderChanged: "sortOrderChanged", selectionChange: "selectionChange", columnsWidthChange: "columnsWidthChange" }, host: { properties: { "class.nui-table__table-fixed": "this.layoutFixed" }, classAttribute: "nui-table__table" }, providers: [ TableStateHandlerService, { provide: _VIEW_REPEATER_STRATEGY, useClass: _DisposeViewRepeaterStrategy, }, { provide: _COALESCED_STYLE_SCHEDULER, useClass: _CoalescedStyleScheduler, }, { provide: CdkTable, useExisting: TableComponent }, { provide: CDK_TABLE, useExisting: TableComponent }, ], queries: [{ propertyName: "virtualFor", first: true, predicate: CdkVirtualForOf, descendants: true }], exportAs: ["nuiTable"], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "\n <ng-content select=\"caption\"/>\n <ng-content select=\"colgroup, col\"/>\n\n <!--\n Unprojected content throws a hydration error so we need this to capture it.\n It gets removed on the client so it doesn't affect the layout.\n -->\n @if (_isServer) {\n <ng-content/>\n }\n\n @if (_isNativeHtmlTable) {\n <thead role=\"rowgroup\">\n <ng-container headerRowOutlet/>\n </thead>\n <tbody role=\"rowgroup\">\n <ng-container rowOutlet/>\n <ng-container noDataRowOutlet/>\n </tbody>\n <tfoot role=\"rowgroup\">\n <ng-container footerRowOutlet/>\n </tfoot>\n } @else {\n <ng-container headerRowOutlet/>\n <ng-container rowOutlet/>\n <ng-container noDataRowOutlet/>\n <ng-container footerRowOutlet/>\n }\n", isInline: true, styles: [".nui .nui-table__table{display:table;width:100%;font-size:13px;border-collapse:collapse}.nui .nui-table__table .align-right{text-align:right}.nui .nui-table__table .align-center{text-align:center}.nui .nui-table__table-fixed{table-layout:fixed;width:1px}.nui .nui-table__table-fixed .nui-table__table-header-cell,.nui .nui-table__table-fixed .nui-table__table-cell{max-width:none}@media print{.nui .nui-table__table{break-inside:avoid}}.nui .nui-table__container{overflow:auto}.nui .nui-table__table-header-cell{position:relative;display:table-cell;color:var(--nui-color-text-secondary,rgba(17, 17, 17, .6));font-weight:600;padding:0 10px;background:inherit;border:1px solid #d9d9d9;border:1px solid var(--nui-color-line-default, #d9d9d9);min-width:46px;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-user-select:none;user-select:none;background-clip:padding-box}.nui .nui-table__table-header-cell--sortable{cursor:pointer}.nui .nui-table__table-header-cell--sortable:hover{background-color:var(--nui-color-bg-table_header-hover,#e3e3e3)}.nui .nui-table__table-header-cell--sortable--text-black{color:var(--nui-color-text-default,#111)}.nui .nui-table__table-header-cell--sortable--dark{background-color:var(--nui-color-bg-table_header-hover,#e3e3e3)}.nui .nui-table__table-header-cell--reorderable{cursor:move}.nui .nui-table__table-header-cell--reorderable:hover,.nui .nui-table__table-header-cell--reorderable--dark{background-color:var(--nui-color-bg-table_header-hover,#e3e3e3)}.nui .nui-table__table-header-cell.cdk-table-sticky{border:0}.nui .nui-table__table-header-cell.cdk-table-sticky:before{content:\"\";position:absolute;top:0;left:0;bottom:0;width:100%;border-top:1px solid #d9d9d9;border-top:1px solid var(--nui-color-line-default, #d9d9d9);border-bottom:1px solid #d9d9d9;border-bottom:1px solid var(--nui-color-line-default, #d9d9d9);border-left:1px solid #d9d9d9;border-left:1px solid var(--nui-color-line-default, #d9d9d9)}.nui .nui-table__table-header-cell.cdk-table-sticky:last-of-type:before{border-right:1px solid #d9d9d9;border-right:1px solid var(--nui-color-line-default, #d9d9d9)}.nui .nui-table__table-header-cell.cdk-table-sticky.nui-table__table-cell--left-edge-action:before{border-left:2px solid;border-left-color:var(--nui-color-line-selected-contrast,#00c4d2)}.nui .nui-table__table-header-cell.cdk-table-sticky.nui-table__table-cell--right-edge-action:before{border-right:2px solid;border-right-color:var(--nui-color-line-selected-contrast,#00c4d2)}.nui .nui-table__table-header-cell.virtual-sticky{transition-property:width;transition-duration:.2s}.nui .nui-table__table-header-cell--selectable{min-width:75px;width:75px;overflow:visible;padding:0 5px}.nui .nui-table__table-header-cell--selectable.no-options{min-width:auto;width:35px!important}.nui .nui-table__table-header-cell__selector{display:flex}.nui .nui-table__table-header-cell__selector.no-options{min-width:auto}.nui .nui-table__table-header-row{background-color:var(--nui-color-bg-table_header,#f0f0f0);display:table-row;height:40px}.nui .nui-table__table-header-row_height_default{height:40px}.nui .nui-table__table-header-row_height_compact{height:30px}.nui .nui-table__table-header-row_height_compact .nui-table__table-header-cell--selectable{padding:0 3px 0 7px}.nui .nui-table__table-header-row_height_compact .nui-selector__checkbox-button{border:none;border-right:1px solid #d9d9d9;padding:0 4px}.nui .nui-table__table-header-row_height_compact .nui-selector__toggle{border:none;border-left:1px solid #d9d9d9}.nui .nui-table__table-header-row_height_compact .nui-selector__checkbox-container{margin:0}.nui .nui-table__table-header-row_height_compact .nui-selector__checkbox-container .nui-checkbox__label:hover{background:transparent}.nui .nui-table__table-header-row_height_tiny{height:24px}.nui .nui-table__table-header-row_height_tiny .nui-table__table-header-cell--selectable{padding:0 3px 0 7px}.nui .nui-table__table-header-row_height_tiny .nui-selector__checkbox-button{border:none;border-right:1px solid #d9d9d9;padding:0 4px}.nui .nui-table__table-header-row_height_tiny .nui-selector__toggle{border:none;border-left:1px solid #d9d9d9}.nui .nui-table__table-header-row_height_tiny .nui-selector__checkbox-container{margin:0}.nui .nui-table__table-header-row_height_tiny .nui-selector__checkbox-container .nui-checkbox__label:hover{background:transparent}.nui .nui-table__table-row{border-bottom:1px solid #d9d9d9;border-bottom:1px solid var(--nui-color-line-default, #d9d9d9);display:table-row}.nui .nui-table__table-row:hover{background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui .nui-table__table-row_height_default{height:40px}.nui .nui-table__table-row_height_compact{height:30px}.nui .nui-table__table-row_height_tiny{height:24px}.nui .nui-table__table-row td:first-of-type.nui-table__table-cell--drop-left{overflow-x:visible}.nui .nui-table__table-row--selected{background-color:var(--nui-color-selected,rgba(0, 196, 210, .1));color:var(--nui-color-text-default,#111)}.nui .nui-table__table-row--selected:hover{background-color:var(--nui-color-selected-hover,rgba(0, 196, 210, .2))}.nui .nui-table__table-row--clickable{cursor:pointer}.nui .nui-table__table-cell{display:table-cell;color:var(--nui-color-text-default,#111);padding:0 10px;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nui .nui-table__table-cell--selectable{padding:0 0 0 10px}.nui .nui-table__table-cell--left-edge-action{border-left:2px solid;border-left-color:var(--nui-color-line-selected-contrast,#00c4d2)}.nui .nui-table__table-cell--right-edge-action{border-right:2px solid;border-right-color:var(--nui-color-line-selected-contrast,#00c4d2)}.nui .nui-table__table-cell__checkbox .nui-checkbox__label:hover{background-color:transparent}.nui .nui-table__icon-cell{min-width:40px;width:40px}.nui .nui-table__sorting-icon{vertical-align:middle}.nui .nui-table__resizer{width:5px;height:40px;right:0;top:0;position:absolute}.nui .nui-table__resizer:hover{cursor:col-resize}cdk-virtual-scroll-viewport .sticky-header-placeholder th{border-bottom:none!important}\n"], dependencies: [{ kind: "directive", type: i5.DataRowOutlet, selector: "[rowOutlet]" }, { kind: "directive", type: i5.HeaderRowOutlet, selector: "[headerRowOutlet]" }, { kind: "directive", type: i5.FooterRowOutlet, selector: "[footerRowOutlet]" }, { kind: "directive", type: i5.NoDataRowOutlet, selector: "[noDataRowOutlet]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableComponent, decorators: [{ type: Component, args: [{ selector: "nui-table, table[nui-table]", template: CDK_TABLE_TEMPLATE, exportAs: "nuiTable", host: { class: "nui-table__table", }, changeDetection: ChangeDetectionStrategy.OnPush, providers: [ TableStateHandlerService, { provide: _VIEW_REPEATER_STRATEGY, useClass: _DisposeViewRepeaterStrategy, }, { provide: _COALESCED_STYLE_SCHEDULER, useClass: _CoalescedStyleScheduler, }, { provide: CdkTable, useExisting: TableComponent }, { provide: CDK_TABLE, useExisting: TableComponent }, ], encapsulation: ViewEncapsulation.None, styles: [".nui .nui-table__table{display:table;width:100%;font-size:13px;border-collapse:collapse}.nui .nui-table__table .align-right{text-align:right}.nui .nui-table__table .align-center{text-align:center}.nui .nui-table__table-fixed{table-layout:fixed;width:1px}.nui .nui-table__table-fixed .nui-table__table-header-cell,.nui .nui-table__table-fixed .nui-table__table-cell{max-width:none}@media print{.nui .nui-table__table{break-inside:avoid}}.nui .nui-table__container{overflow:auto}.nui .nui-table__table-header-cell{position:relative;display:table-cell;color:var(--nui-color-text-secondary,rgba(17, 17, 17, .6));font-weight:600;padding:0 10px;background:inherit;border:1px solid #d9d9d9;border:1px solid var(--nui-color-line-default, #d9d9d9);min-width:46px;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-user-select:none;user-select:none;background-clip:padding-box}.nui .nui-table__table-header-cell--sortable{cursor:pointer}.nui .nui-table__table-header-cell--sortable:hover{background-color:var(--nui-color-bg-table_header-hover,#e3e3e3)}.nui .nui-table__table-header-cell--sortable--text-black{color:var(--nui-color-text-default,#111)}.nui .nui-table__table-header-cell--sortable--dark{background-color:var(--nui-color-bg-table_header-hover,#e3e3e3)}.nui .nui-table__table-header-cell--reorderable{cursor:move}.nui .nui-table__table-header-cell--reorderable:hover,.nui .nui-table__table-header-cell--reorderable--dark{background-color:var(--nui-color-bg-table_header-hover,#e3e3e3)}.nui .nui-table__table-header-cell.cdk-table-sticky{border:0}.nui .nui-table__table-header-cell.cdk-table-sticky:before{content:\"\";position:absolute;top:0;left:0;bottom:0;width:100%;border-top:1px solid #d9d9d9;border-top:1px solid var(--nui-color-line-default, #d9d9d9);border-bottom:1px solid #d9d9d9;border-bottom:1px solid var(--nui-color-line-default, #d9d9d9);border-left:1px solid #d9d9d9;border-left:1px solid var(--nui-color-line-default, #d9d9d9)}.nui .nui-table__table-header-cell.cdk-table-sticky:last-of-type:before{border-right:1px solid #d9d9d9;border-right:1px solid var(--nui-color-line-default, #d9d9d9)}.nui .nui-table__table-header-cell.cdk-table-sticky.nui-table__table-cell--left-edge-action:before{border-left:2px solid;border-left-color:var(--nui-color-line-selected-contrast,#00c4d2)}.nui .nui-table__table-header-cell.cdk-table-sticky.nui-table__table-cell--right-edge-action:before{border-right:2px solid;border-right-color:var(--nui-color-line-selected-contrast,#00c4d2)}.nui .nui-table__table-header-cell.virtual-sticky{transition-property:width;transition-duration:.2s}.nui .nui-table__table-header-cell--selectable{min-width:75px;width:75px;overflow:visible;padding:0 5px}.nui .nui-table__table-header-cell--selectable.no-options{min-width:auto;width:35px!important}.nui .nui-table__table-header-cell__selector{display:flex}.nui .nui-table__table-header-cell__selector.no-options{min-width:auto}.nui .nui-table__table-header-row{background-color:var(--nui-color-bg-table_header,#f0f0f0);display:table-row;height:40px}.nui .nui-table__table-header-row_height_default{height:40px}.nui .nui-table__table-header-row_height_compact{height:30px}.nui .nui-table__table-header-row_height_compact .nui-table__table-header-cell--selectable{padding:0 3px 0 7px}.nui .nui-table__table-header-row_height_compact .nui-selector__checkbox-button{border:none;border-right:1px solid #d9d9d9;padding:0 4px}.nui .nui-table__table-header-row_height_compact .nui-selector__toggle{border:none;border-left:1px solid #d9d9d9}.nui .nui-table__table-header-row_height_compact .nui-selector__checkbox-container{margin:0}.nui .nui-table__table-header-row_height_compact .nui-selector__checkbox-container .nui-checkbox__label:hover{background:transparent}.nui .nui-table__table-header-row_height_tiny{height:24px}.nui .nui-table__table-header-row_height_tiny .nui-table__table-header-cell--selectable{padding:0 3px 0 7px}.nui .nui-table__table-header-row_height_tiny .nui-selector__checkbox-button{border:none;border-right:1px solid #d9d9d9;padding:0 4px}.nui .nui-table__table-header-row_height_tiny .nui-selector__toggle{border:none;border-left:1px solid #d9d9d9}.nui .nui-table__table-header-row_height_tiny .nui-selector__checkbox-container{margin:0}.nui .nui-table__table-header-row_height_tiny .nui-selector__checkbox-container .nui-checkbox__label:hover{background:transparent}.nui .nui-table__table-row{border-bottom:1px solid #d9d9d9;border-bottom:1px solid var(--nui-color-line-default, #d9d9d9);display:table-row}.nui .nui-table__table-row:hover{background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui .nui-table__table-row_height_default{height:40px}.nui .nui-table__table-row_height_compact{height:30px}.nui .nui-table__table-row_height_tiny{height:24px}.nui .nui-table__table-row td:first-of-type.nui-table__table-cell--drop-left{overflow-x:visible}.nui .nui-table__table-row--selected{background-color:var(--nui-color-selected,rgba(0, 196, 210, .1));color:var(--nui-color-text-default,#111)}.nui .nui-table__table-row--selected:hover{background-color:var(--nui-color-selected-hover,rgba(0, 196, 210, .2))}.nui .nui-table__table-row--clickable{cursor:pointer}.nui .nui-table__table-cell{display:table-cell;color:var(--nui-color-text-default,#111);padding:0 10px;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nui .nui-table__table-cell--selectable{padding:0 0 0 10px}.nui .nui-table__table-cell--left-edge-action{border-left:2px solid;border-left-color:var(--nui-color-line-selected-contrast,#00c4d2)}.nui .nui-table__table-cell--right-edge-action{border-right:2px solid;border-right-color:var(--nui-color-line-selected-contrast,#00c4d2)}.nui .nui-table__table-cell__checkbox .nui-checkbox__label:hover{background-color:transparent}.nui .nui-table__icon-cell{min-width:40px;width:40px}.nui .nui-table__sorting-icon{vertical-align:middle}.nui .nui-table__resizer{width:5px;height:40px;right:0;top:0;position:absolute}.nui .nui-table__resizer:hover{cursor:col-resize}cdk-virtual-scroll-viewport .sticky-header-placeholder th{border-bottom:none!important}\n"] }] }], ctorParameters: () => [{ type: i0.IterableDiffers }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: undefined, decorators: [{ type: Attribute, args: ["role"] }] }, { type: i1.Directionality }, { type: i2.TableStateHandlerService }, { type: Document, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: i3.Platform }, { type: undefined, decorators: [{ type: Inject, args: [_VIEW_REPEATER_STRATEGY] }] }, { type: i5._CoalescedStyleScheduler, decorators: [{ type: Inject, args: [_COALESCED_STYLE_SCHEDULER] }] }, { type: i4.ViewportRuler }, { type: undefined, decorators: [{ type: Optional }, { type: SkipSelf }, { type: Inject, args: [STICKY_POSITIONING_LISTENER] }] }], propDecorators: { reorderable: [{ type: Input }], sortable: [{ type: Input }], resizable: [{ type: Input }], selectable: [{ type: Input }], selectionConfig: [{ type: Input }], totalItems: [{ type: Input }], dataSource: [{ type: Input }], selection: [{ type: Input }], sortedColumn: [{ type: Input }], paginatorUsed: [{ type: Input }], columnsOrderChange: [{ type: Output }], sortOrderChanged: [{ type: Output }], selectionChange: [{ type: Output }], columnsWidthChange: [{ type: Output }], layoutFixed: [{ type: HostBinding, args: ["class.nui-table__table-fixed"] }], virtualFor: [{ type: ContentChild, args: [CdkVirtualForOf] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../src/lib/table/table.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 { Directionality } from \"@angular/cdk/bidi\";\nimport {\n    _DisposeViewRepeaterStrategy,\n    _VIEW_REPEATER_STRATEGY,\n    _ViewRepeater,\n} from \"@angular/cdk/collections\";\nimport { Platform } from \"@angular/cdk/platform\";\nimport { CdkVirtualForOf, ViewportRuler } from \"@angular/cdk/scrolling\";\nimport {\n    _COALESCED_STYLE_SCHEDULER,\n    _CoalescedStyleScheduler,\n    CDK_TABLE,\n    CDK_TABLE_TEMPLATE,\n    CdkTable,\n    RenderRow,\n    RowContext,\n    STICKY_POSITIONING_LISTENER,\n    StickyPositioningListener,\n} from \"@angular/cdk/table\";\nimport { DOCUMENT } from \"@angular/common\";\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    Attribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    IterableDiffers,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    SkipSelf,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport _isEqual from \"lodash/isEqual\";\nimport _keys from \"lodash/keys\";\nimport { Subscription } from \"rxjs\";\n\nimport { TableStateHandlerService } from \"./table-state-handler.service\";\nimport { TableSelectionConfig, TableSelectionMode } from \"./types\";\nimport { IFilteringParticipants, ISelection } from \"../../services/public-api\";\nimport { ComponentChanges } from \"../../types\";\nimport { ISortedItem, SorterDirection } from \"../sorter/public-api\";\n\n// <example-url>./../examples/index.html#/table</example-url>\n\n/** @dynamic */\n@Component({\n    selector: \"nui-table, table[nui-table]\",\n    // We used to have our own template for the table but it broke with Angular release 10 so we are now using this even though it is intended to be private\n    // so we can be up to date with the CDK table template.\n    template: CDK_TABLE_TEMPLATE,\n    exportAs: \"nuiTable\",\n    host: {\n        class: \"nui-table__table\",\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TableStateHandlerService,\n        {\n            provide: _VIEW_REPEATER_STRATEGY,\n            useClass: _DisposeViewRepeaterStrategy,\n        },\n        {\n            provide: _COALESCED_STYLE_SCHEDULER,\n            useClass: _CoalescedStyleScheduler,\n        },\n        { provide: CdkTable, useExisting: TableComponent },\n        { provide: CDK_TABLE, useExisting: TableComponent },\n    ],\n    styleUrls: [\"./table.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class TableComponent<T>\n    extends CdkTable<T>\n    implements OnInit, AfterViewInit, AfterContentInit, OnDestroy, OnChanges\n{\n    @Input() reorderable = false;\n    @Input() sortable = false;\n    @Input() resizable = false;\n    /**\n     * @deprecated Use selectionConfig instead.\n     */\n    @Input() selectable = false;\n    @Input() selectionConfig: TableSelectionConfig = {\n        enabled: false,\n        selectionMode: TableSelectionMode.None,\n    };\n    @Input() totalItems: number;\n\n    @Input()\n    get dataSource(): T[] {\n        return super.dataSource as any;\n    }\n\n    set dataSource(value: T[]) {\n        super.dataSource = value as any;\n    }\n\n    @Input() selection: ISelection;\n    @Input() sortedColumn: ISortedItem;\n    @Input() paginatorUsed: boolean = false;\n\n    @Output() columnsOrderChange: EventEmitter<Array<any>> = new EventEmitter();\n    @Output() sortOrderChanged: EventEmitter<ISortedItem> = new EventEmitter();\n    @Output() selectionChange: EventEmitter<ISelection> = new EventEmitter();\n    @Output() columnsWidthChange: EventEmitter<void> = new EventEmitter();\n\n    public sortDirection: SorterDirection;\n    public sortBy: string;\n    private tableColumnsSubscription: Subscription;\n    private tableSortingSubscription: Subscription;\n    private selectionChangedSubscription: Subscription;\n    private stickyChangedSubscription: Subscription;\n    private tableColumnsWidthSubscription: Subscription;\n    @HostBinding(\"class.nui-table__table-fixed\") layoutFixed = false;\n    @ContentChild(CdkVirtualForOf) public virtualFor?: CdkVirtualForOf<unknown>;\n\n    constructor(\n        protected _differs: IterableDiffers,\n        protected _changeDetectorRef: ChangeDetectorRef,\n      