UNPKG

carbon-components-angular

Version:
321 lines 26.7 kB
import { Component, Input, Output, EventEmitter } from "@angular/core"; import { getScrollbarWidth } from "carbon-components-angular/utils"; import * as i0 from "@angular/core"; import * as i1 from "carbon-components-angular/i18n"; import * as i2 from "@angular/common"; import * as i3 from "./table-head-cell.component"; import * as i4 from "./table-head-checkbox.component"; import * as i5 from "./table-head-expand.component"; /** * A subcomponent that creates the thead of the table * * ## Basic usage * * ```html * <thead cdsTableHead [model]="model"></thead> * ``` */ export class TableHead { constructor(i18n) { this.i18n = i18n; this.showSelectionColumn = true; this.enableSingleSelect = false; this.selectAllCheckboxSomeSelected = false; this.selectAllCheckbox = false; this.skeleton = false; this.stickyHeader = false; this.showExpandAllToggle = false; /** * Setting sortable to false will disable all headers including headers which are sortable. Is is * possible to set the sortable state on the header item to disable/enable sorting for only some headers. */ this.sortable = true; /** * When true, the first model column is rendered before expand/selection (Carbon AI row decorator column). */ this.withRowAILabels = false; /** * Emits an index of the column that wants to be sorted. */ this.sort = new EventEmitter(); /** * Emits if all rows are selected. * * @param model */ this.selectAll = new EventEmitter(); /** * Emits if all rows are deselected. * * @param model */ this.deselectAll = new EventEmitter(); /** * Emits if all rows are expanded. * * @param model */ this.expandAllRows = new EventEmitter(); /** * Emits if all rows are collapsed. * * @param model */ this.collapseAllRows = new EventEmitter(); this.scrollbarWidth = 0; this._checkboxHeaderLabel = this.i18n.getOverridable("TABLE.CHECKBOX_HEADER"); this._sortDescendingLabel = this.i18n.getOverridable("TABLE.SORT_DESCENDING"); this._sortAscendingLabel = this.i18n.getOverridable("TABLE.SORT_ASCENDING"); this._filterTitle = this.i18n.getOverridable("TABLE.FILTER"); } set checkboxHeaderLabel(value) { this._checkboxHeaderLabel.override(value); } get checkboxHeaderLabel() { return this._checkboxHeaderLabel.value; } set sortDescendingLabel(value) { this._sortDescendingLabel.override(value); } get sortDescendingLabel() { return this._sortDescendingLabel.value; } set sortAscendingLabel(value) { this._sortAscendingLabel.override(value); } get sortAscendingLabel() { return this._sortAscendingLabel.value; } set filterTitle(value) { this._filterTitle.override(value); } get filterTitle() { return this._filterTitle.value; } ngAfterViewInit() { setTimeout(() => { this.scrollbarWidth = getScrollbarWidth(); }); } onSelectAllCheckboxChange() { if (!this.selectAllCheckbox && !this.selectAllCheckboxSomeSelected) { this.selectAll.emit(this.model); } else { this.deselectAll.emit(this.model); } } onExpandAllRowsChange(expand) { if (expand) { this.expandAllRows.emit(this.model); } else { this.collapseAllRows.emit(this.model); } } getCheckboxHeaderLabel() { return this._checkboxHeaderLabel.subject; } getSortDescendingLabel() { return this._sortDescendingLabel.subject; } getSortAscendingLabel() { return this._sortAscendingLabel.subject; } getFilterTitle() { return this._filterTitle.subject; } } TableHead.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableHead, deps: [{ token: i1.I18n }], target: i0.ɵɵFactoryTarget.Component }); TableHead.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableHead, selector: "[cdsTableHead], [ibmTableHead]", inputs: { model: "model", showSelectionColumn: "showSelectionColumn", enableSingleSelect: "enableSingleSelect", selectAllCheckboxSomeSelected: "selectAllCheckboxSomeSelected", selectAllCheckbox: "selectAllCheckbox", skeleton: "skeleton", stickyHeader: "stickyHeader", showExpandAllToggle: "showExpandAllToggle", sortable: "sortable", withRowAILabels: "withRowAILabels", checkboxHeaderLabel: "checkboxHeaderLabel", sortDescendingLabel: "sortDescendingLabel", sortAscendingLabel: "sortAscendingLabel", filterTitle: "filterTitle" }, outputs: { sort: "sort", selectAll: "selectAll", deselectAll: "deselectAll", expandAllRows: "expandAllRows", collapseAllRows: "collapseAllRows" }, ngImport: i0, template: ` <ng-container *ngIf="model"> <tr> <th *ngIf="withRowAILabels && model.header[0] && model.header[0].visible" [ngStyle]="model.header[0].style" cdsTableHeadCell scope="col" [class]="model.header[0].className" [sortable]="sortable" [skeleton]="skeleton" [id]="model.getId(0)" [column]="model.header[0]" [filterTitle]="getFilterTitle()" [attr.colspan]="model.header[0].colSpan" [attr.rowspan]="model.header[0].rowSpan" (sort)="sort.emit(0)"> </th> <th cdsTableHeadExpand *ngIf="model.hasExpandableRows()" scope="col" [showExpandAllToggle]="showExpandAllToggle" [ngClass]="{'cds--table-expand-v2': stickyHeader}" [id]="model.getId('expand')" [expanded]="model.expandableRowsCount() === model.expandedRowsCount()" (expandedChange)="onExpandAllRowsChange($event)"> </th> <th *ngIf="!skeleton && showSelectionColumn && enableSingleSelect" scope="col" [id]="model.getId('select')"> <!-- add width 0; since the carbon styles don't seem to constrain this headers width --> </th> <th cdsTableHeadCheckbox *ngIf="!skeleton && showSelectionColumn && !enableSingleSelect" scope="col" [checked]="selectAllCheckbox" [indeterminate]="selectAllCheckboxSomeSelected" [ariaLabel]="getCheckboxHeaderLabel()" [skeleton]="skeleton" [name]="model.getHeaderId('select')" (change)="onSelectAllCheckboxChange()" [id]="model.getId('select')"> </th> <ng-container *ngFor="let column of model.header; let i = index"> <th *ngIf="column && column.visible && (!withRowAILabels || i > 0)" [ngStyle]="column.style" cdsTableHeadCell scope="col" [class]="column.className" [sortable]="sortable" [skeleton]="skeleton" [id]="model.getId(i)" [column]="column" [filterTitle]="getFilterTitle()" [attr.colspan]="column.colSpan" [attr.rowspan]="column.rowSpan" (sort)="sort.emit(i)"> </th> </ng-container> <th *ngIf="!skeleton && stickyHeader && scrollbarWidth" scope="col" [ngStyle]="{'width': scrollbarWidth + 'px', 'padding': 0, 'border': 0}"> <!-- Scrollbar pushes body to the left so this header column is added to push the title bar the same amount and keep the header and body columns aligned. --> </th> </tr> </ng-container> <ng-content></ng-content> `, isInline: true, styles: [".cds--table-expand-v2{padding-left:2.5rem}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.TableHeadCell, selector: "[cdsTableHeadCell], [ibmTableHeadCell]", inputs: ["column", "skeleton", "sortable", "sortDescendingLabel", "sortAscendingLabel", "filterTitle"], outputs: ["sort"] }, { kind: "component", type: i4.TableHeadCheckbox, selector: "[cdsTableHeadCheckbox], [ibmTableHeadCheckbox]", inputs: ["checked", "indeterminate", "skeleton", "name", "ariaLabel"], outputs: ["change"] }, { kind: "component", type: i5.TableHeadExpand, selector: "[cdsTableHeadExpand], [ibmTableHeadExpand]", inputs: ["showExpandAllToggle", "expanded"], outputs: ["expandedChange"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableHead, decorators: [{ type: Component, args: [{ selector: "[cdsTableHead], [ibmTableHead]", template: ` <ng-container *ngIf="model"> <tr> <th *ngIf="withRowAILabels && model.header[0] && model.header[0].visible" [ngStyle]="model.header[0].style" cdsTableHeadCell scope="col" [class]="model.header[0].className" [sortable]="sortable" [skeleton]="skeleton" [id]="model.getId(0)" [column]="model.header[0]" [filterTitle]="getFilterTitle()" [attr.colspan]="model.header[0].colSpan" [attr.rowspan]="model.header[0].rowSpan" (sort)="sort.emit(0)"> </th> <th cdsTableHeadExpand *ngIf="model.hasExpandableRows()" scope="col" [showExpandAllToggle]="showExpandAllToggle" [ngClass]="{'cds--table-expand-v2': stickyHeader}" [id]="model.getId('expand')" [expanded]="model.expandableRowsCount() === model.expandedRowsCount()" (expandedChange)="onExpandAllRowsChange($event)"> </th> <th *ngIf="!skeleton && showSelectionColumn && enableSingleSelect" scope="col" [id]="model.getId('select')"> <!-- add width 0; since the carbon styles don't seem to constrain this headers width --> </th> <th cdsTableHeadCheckbox *ngIf="!skeleton && showSelectionColumn && !enableSingleSelect" scope="col" [checked]="selectAllCheckbox" [indeterminate]="selectAllCheckboxSomeSelected" [ariaLabel]="getCheckboxHeaderLabel()" [skeleton]="skeleton" [name]="model.getHeaderId('select')" (change)="onSelectAllCheckboxChange()" [id]="model.getId('select')"> </th> <ng-container *ngFor="let column of model.header; let i = index"> <th *ngIf="column && column.visible && (!withRowAILabels || i > 0)" [ngStyle]="column.style" cdsTableHeadCell scope="col" [class]="column.className" [sortable]="sortable" [skeleton]="skeleton" [id]="model.getId(i)" [column]="column" [filterTitle]="getFilterTitle()" [attr.colspan]="column.colSpan" [attr.rowspan]="column.rowSpan" (sort)="sort.emit(i)"> </th> </ng-container> <th *ngIf="!skeleton && stickyHeader && scrollbarWidth" scope="col" [ngStyle]="{'width': scrollbarWidth + 'px', 'padding': 0, 'border': 0}"> <!-- Scrollbar pushes body to the left so this header column is added to push the title bar the same amount and keep the header and body columns aligned. --> </th> </tr> </ng-container> <ng-content></ng-content> `, styles: [".cds--table-expand-v2{padding-left:2.5rem}\n"] }] }], ctorParameters: function () { return [{ type: i1.I18n }]; }, propDecorators: { model: [{ type: Input }], showSelectionColumn: [{ type: Input }], enableSingleSelect: [{ type: Input }], selectAllCheckboxSomeSelected: [{ type: Input }], selectAllCheckbox: [{ type: Input }], skeleton: [{ type: Input }], stickyHeader: [{ type: Input }], showExpandAllToggle: [{ type: Input }], sortable: [{ type: Input }], withRowAILabels: [{ type: Input }], checkboxHeaderLabel: [{ type: Input }], sortDescendingLabel: [{ type: Input }], sortAscendingLabel: [{ type: Input }], filterTitle: [{ type: Input }], sort: [{ type: Output }], selectAll: [{ type: Output }], deselectAll: [{ type: Output }], expandAllRows: [{ type: Output }], collapseAllRows: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-head.component.js","sourceRoot":"","sources":["../../../../src/table/head/table-head.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tOutput,\n\tEventEmitter,\n\tAfterViewInit\n} from \"@angular/core\";\n\nimport { TableModel } from \"../table-model.class\";\nimport { getScrollbarWidth } from \"carbon-components-angular/utils\";\nimport { I18n, Overridable } from \"carbon-components-angular/i18n\";\nimport { Observable } from \"rxjs\";\nimport { TableRowSize } from \"../table.types\";\n\n/**\n * A subcomponent that creates the thead of the table\n *\n * ## Basic usage\n *\n * ```html\n * \t<thead cdsTableHead [model]=\"model\"></thead>\n * ```\n */\n@Component({\n\t// tslint:disable-next-line:component-selector\n\tselector: \"[cdsTableHead], [ibmTableHead]\",\n\ttemplate: `\n\t<ng-container *ngIf=\"model\">\n\t\t<tr>\n\t\t\t<th\n\t\t\t\t*ngIf=\"withRowAILabels && model.header[0] && model.header[0].visible\"\n\t\t\t\t[ngStyle]=\"model.header[0].style\"\n\t\t\t\tcdsTableHeadCell\n\t\t\t\tscope=\"col\"\n\t\t\t\t[class]=\"model.header[0].className\"\n\t\t\t\t[sortable]=\"sortable\"\n\t\t\t\t[skeleton]=\"skeleton\"\n\t\t\t\t[id]=\"model.getId(0)\"\n\t\t\t\t[column]=\"model.header[0]\"\n\t\t\t\t[filterTitle]=\"getFilterTitle()\"\n\t\t\t\t[attr.colspan]=\"model.header[0].colSpan\"\n\t\t\t\t[attr.rowspan]=\"model.header[0].rowSpan\"\n\t\t\t\t(sort)=\"sort.emit(0)\">\n\t\t\t</th>\n\t\t\t<th\n\t\t\t\tcdsTableHeadExpand\n\t\t\t\t*ngIf=\"model.hasExpandableRows()\"\n\t\t\t\tscope=\"col\"\n\t\t\t\t[showExpandAllToggle]=\"showExpandAllToggle\"\n\t\t\t\t[ngClass]=\"{'cds--table-expand-v2': stickyHeader}\"\n\t\t\t\t[id]=\"model.getId('expand')\"\n\t\t\t\t[expanded]=\"model.expandableRowsCount() === model.expandedRowsCount()\"\n\t\t\t\t(expandedChange)=\"onExpandAllRowsChange($event)\">\n\t\t\t</th>\n\t\t\t<th\n\t\t\t\t*ngIf=\"!skeleton && showSelectionColumn && enableSingleSelect\"\n\t\t\t\tscope=\"col\"\n\t\t\t\t[id]=\"model.getId('select')\">\n\t\t\t\t<!-- add width 0; since the carbon styles don't seem to constrain this headers width -->\n\t\t\t</th>\n\t\t\t<th\n\t\t\t\tcdsTableHeadCheckbox\n\t\t\t\t*ngIf=\"!skeleton && showSelectionColumn && !enableSingleSelect\"\n\t\t\t\tscope=\"col\"\n\t\t\t\t[checked]=\"selectAllCheckbox\"\n\t\t\t\t[indeterminate]=\"selectAllCheckboxSomeSelected\"\n\t\t\t\t[ariaLabel]=\"getCheckboxHeaderLabel()\"\n\t\t\t\t[skeleton]=\"skeleton\"\n\t\t\t\t[name]=\"model.getHeaderId('select')\"\n\t\t\t\t(change)=\"onSelectAllCheckboxChange()\"\n\t\t\t\t[id]=\"model.getId('select')\">\n\t\t\t</th>\n\t\t\t<ng-container *ngFor=\"let column of model.header; let i = index\">\n\t\t\t\t<th\n\t\t\t\t\t*ngIf=\"column && column.visible && (!withRowAILabels || i > 0)\"\n\t\t\t\t\t[ngStyle]=\"column.style\"\n\t\t\t\t\tcdsTableHeadCell\n\t\t\t\t\tscope=\"col\"\n\t\t\t\t\t[class]=\"column.className\"\n\t\t\t\t\t[sortable]=\"sortable\"\n\t\t\t\t\t[skeleton]=\"skeleton\"\n\t\t\t\t\t[id]=\"model.getId(i)\"\n\t\t\t\t\t[column]=\"column\"\n\t\t\t\t\t[filterTitle]=\"getFilterTitle()\"\n\t\t\t\t\t[attr.colspan]=\"column.colSpan\"\n\t\t\t\t\t[attr.rowspan]=\"column.rowSpan\"\n\t\t\t\t\t(sort)=\"sort.emit(i)\">\n\t\t\t\t</th>\n\t\t\t</ng-container>\n\t\t\t<th *ngIf=\"!skeleton && stickyHeader && scrollbarWidth\"\n\t\t\t\tscope=\"col\"\n\t\t\t\t[ngStyle]=\"{'width': scrollbarWidth + 'px', 'padding': 0, 'border': 0}\">\n\t\t\t\t<!--\n\t\t\t\t\tScrollbar pushes body to the left so this header column is added to push\n\t\t\t\t\tthe title bar the same amount and keep the header and body columns aligned.\n\t\t\t\t-->\n\t\t\t</th>\n\t\t</tr>\n\t</ng-container>\n\t<ng-content></ng-content>\n\t`,\n\tstyles: [`\n\t\t.cds--table-expand-v2 {\n\t\t\tpadding-left: 2.5rem;\n\t\t}\n\t`]\n})\nexport class TableHead implements AfterViewInit {\n\t@Input() model: TableModel;\n\n\t@Input() showSelectionColumn = true;\n\n\t@Input() enableSingleSelect = false;\n\n\t@Input() selectAllCheckboxSomeSelected = false;\n\n\t@Input() selectAllCheckbox = false;\n\n\t@Input() skeleton = false;\n\n\t@Input() stickyHeader = false;\n\n\t@Input() showExpandAllToggle = false;\n\n\t/**\n\t * Setting sortable to false will disable all headers including headers which are sortable. Is is\n\t * possible to set the sortable state on the header item to disable/enable sorting for only some headers.\n\t */\n\t@Input() sortable = true;\n\n\t/**\n\t * When true, the first model column is rendered before expand/selection (Carbon AI row decorator column).\n\t */\n\t@Input() withRowAILabels = false;\n\n\t@Input()\n\tset checkboxHeaderLabel(value: string | Observable<string>) {\n\t\tthis._checkboxHeaderLabel.override(value);\n\t}\n\n\tget checkboxHeaderLabel() {\n\t\treturn this._checkboxHeaderLabel.value;\n\t}\n\n\t@Input()\n\tset sortDescendingLabel(value: string | Observable<string>) {\n\t\tthis._sortDescendingLabel.override(value);\n\t}\n\n\tget sortDescendingLabel() {\n\t\treturn this._sortDescendingLabel.value;\n\t}\n\n\t@Input()\n\tset sortAscendingLabel(value: string | Observable<string>) {\n\t\tthis._sortAscendingLabel.override(value);\n\t}\n\n\tget sortAscendingLabel() {\n\t\treturn this._sortAscendingLabel.value;\n\t}\n\n\t@Input()\n\tset filterTitle(value: string | Observable<string>) {\n\t\tthis._filterTitle.override(value);\n\t}\n\n\tget filterTitle() {\n\t\treturn this._filterTitle.value;\n\t}\n\n\t/**\n\t * Emits an index of the column that wants to be sorted.\n\t */\n\t@Output() sort = new EventEmitter<number>();\n\t/**\n\t * Emits if all rows are selected.\n\t *\n\t * @param model\n\t */\n\t@Output() selectAll = new EventEmitter<TableModel>();\n\t/**\n\t * Emits if all rows are deselected.\n\t *\n\t * @param model\n\t */\n\t@Output() deselectAll = new EventEmitter<TableModel>();\n\t/**\n\t * Emits if all rows are expanded.\n\t *\n\t * @param model\n\t */\n\t@Output() expandAllRows = new EventEmitter<TableModel>();\n\t/**\n\t * Emits if all rows are collapsed.\n\t *\n\t * @param model\n\t */\n\t@Output() collapseAllRows = new EventEmitter<TableModel>();\n\n\tpublic scrollbarWidth = 0;\n\n\tprotected _checkboxHeaderLabel = this.i18n.getOverridable(\"TABLE.CHECKBOX_HEADER\");\n\tprotected _sortDescendingLabel = this.i18n.getOverridable(\"TABLE.SORT_DESCENDING\");\n\tprotected _sortAscendingLabel = this.i18n.getOverridable(\"TABLE.SORT_ASCENDING\");\n\tprotected _filterTitle = this.i18n.getOverridable(\"TABLE.FILTER\");\n\n\tconstructor(protected i18n: I18n) {}\n\n\tngAfterViewInit() {\n\t\tsetTimeout(() => {\n\t\t\tthis.scrollbarWidth = getScrollbarWidth();\n\t\t});\n\t}\n\n\tonSelectAllCheckboxChange() {\n\t\tif (!this.selectAllCheckbox && !this.selectAllCheckboxSomeSelected) {\n\t\t\tthis.selectAll.emit(this.model);\n\t\t} else {\n\t\t\tthis.deselectAll.emit(this.model);\n\t\t}\n\t}\n\n\tonExpandAllRowsChange(expand: boolean) {\n\t\tif (expand) {\n\t\t\tthis.expandAllRows.emit(this.model);\n\t\t} else {\n\t\t\tthis.collapseAllRows.emit(this.model);\n\t\t}\n\t}\n\n\tgetCheckboxHeaderLabel(): Observable<string> {\n\t\treturn this._checkboxHeaderLabel.subject;\n\t}\n\n\tgetSortDescendingLabel(): Observable<string> {\n\t\treturn this._sortDescendingLabel.subject;\n\t}\n\n\tgetSortAscendingLabel(): Observable<string> {\n\t\treturn this._sortAscendingLabel.subject;\n\t}\n\n\tgetFilterTitle(): Observable<string> {\n\t\treturn this._filterTitle.subject;\n\t}\n}\n"]}