UNPKG

carbon-components-angular

Version:
236 lines 21.5 kB
import { Component, Input, EventEmitter, Output } from "@angular/core"; import * as i0 from "@angular/core"; import * as i1 from "carbon-components-angular/i18n"; import * as i2 from "@angular/common"; import * as i3 from "../expanded-row-hover.directive"; import * as i4 from "./table-row.component"; import * as i5 from "./table-expanded-row.component"; export class TableBody { constructor(i18n) { this.i18n = i18n; /** * Controls whether to enable multiple or single row selection. */ this.enableSingleSelect = false; /** * Controls whether to show the selection checkboxes column or not. */ this.showSelectionColumn = true; /** * Size of the table rows. */ this.size = "md"; this.skeleton = false; /** * Enables Carbon styles when the first column is an AI decorator column (`TableItem.hasAILabelDecorator`). */ this.withRowAILabels = false; /** * Emits if a single row is selected. * * @param ({model: this.model, selectedRowIndex: index}) */ this.selectRow = new EventEmitter(); /** * Emits if a single row is deselected. * * @param ({model: this.model, deselectedRowIndex: index}) */ this.deselectRow = new EventEmitter(); /** * Emits if a row item excluding expandButtons, checkboxes, or radios is clicked. */ this.rowClick = new EventEmitter(); this._checkboxRowLabel = this.i18n.getOverridable("TABLE.CHECKBOX_ROW"); this._expandButtonAriaLabel = this.i18n.getOverridable("TABLE.EXPAND_BUTTON"); } set expandButtonAriaLabel(value) { this._expandButtonAriaLabel.override(value); } get expandButtonAriaLabel() { return this._expandButtonAriaLabel.value; } set checkboxRowLabel(value) { this._checkboxRowLabel.override(value); } get checkboxRowLabel() { return this._checkboxRowLabel.value; } /** * Triggered when a single row is clicked. * Updates the header checkbox state. * Emits the `selectRow` or `deselectRow` event. */ onRowCheckboxChange(index) { if (this.model.isRowSelected(index)) { this.deselectRow.emit({ model: this.model, deselectedRowIndex: index }); } else { this.selectRow.emit({ model: this.model, selectedRowIndex: index }); } } onRowClick(index) { this.rowClick.emit(index); } getCheckboxRowLabel() { return this._checkboxRowLabel.subject; } getExpandButtonAriaLabel() { return this._expandButtonAriaLabel.subject; } firstExpandedDataInRow(row) { const found = row.find(d => d.expandedData); if (found) { return found.expandedData; } return found; } shouldExpandAsTable(row) { return row.some(d => d.expandAsTable); } } TableBody.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableBody, deps: [{ token: i1.I18n }], target: i0.ɵɵFactoryTarget.Component }); TableBody.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableBody, selector: "[cdsTableBody], [ibmTableBody]", inputs: { model: "model", enableSingleSelect: "enableSingleSelect", expandButtonAriaLabel: "expandButtonAriaLabel", checkboxRowLabel: "checkboxRowLabel", showSelectionColumn: "showSelectionColumn", size: "size", selectionLabelColumn: "selectionLabelColumn", skeleton: "skeleton", withRowAILabels: "withRowAILabels" }, outputs: { selectRow: "selectRow", deselectRow: "deselectRow", rowClick: "rowClick" }, ngImport: i0, template: ` <ng-container *ngIf="model"> <ng-container *ngFor="let row of model.data; let i = index"> <tr cdsTableRow [model]="model" [row]="row" [size]="size" [selected]="model.isRowSelected(i)" [expandable]="model.isRowExpandable(i)" [expanded]="model.isRowExpanded(i)" [checkboxLabel]="getCheckboxRowLabel()" [expandButtonAriaLabel]="getExpandButtonAriaLabel()" [showSelectionColumn]="showSelectionColumn" [enableSingleSelect]="enableSingleSelect" [skeleton]="skeleton" [withRowAILabels]="withRowAILabels" (selectRow)="onRowCheckboxChange(i)" (deselectRow)="onRowCheckboxChange(i)" (expandRow)="model.expandRow(i, !model.isRowExpanded(i))" (rowClick)="onRowClick(i)" *ngIf="!model.isRowFiltered(i)" [class]="(model.rowsClass[i] ? model.rowsClass[i] : null)" [ngClass]="{ 'tbody_row--success': !model.isRowSelected(i) && model.getRowContext(i) === 'success', 'tbody_row--warning': !model.isRowSelected(i) && model.getRowContext(i) === 'warning', 'tbody_row--info': !model.isRowSelected(i) && model.getRowContext(i) === 'info', 'tbody_row--error': !model.isRowSelected(i) && model.getRowContext(i) === 'error' }"> </tr> <tr *ngIf="model.isRowExpandable(i) && !shouldExpandAsTable(row) && !model.isRowFiltered(i)" cdsTableExpandedRow cdsExpandedRowHover [row]="row" [expanded]="model.isRowExpanded(i)" [skeleton]="skeleton"> </tr> <ng-container *ngIf="model.isRowExpandable(i) && shouldExpandAsTable(row) && model.isRowExpanded(i) && !model.isRowFiltered(i)"> <tr *ngFor="let expandedDataRow of firstExpandedDataInRow(row)" cdsTableRow [model]="model" [showSelectionColumnCheckbox]="false" [showSelectionColumn]="showSelectionColumn" [row]="expandedDataRow" [size]="size" [skeleton]="skeleton" [withRowAILabels]="withRowAILabels"> </tr> </ng-container> </ng-container> </ng-container> <ng-content></ng-content> `, isInline: true, 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: i3.ExpandedRowHover, selector: "[cdsExpandedRowHover], [ibmExpandedRowHover]" }, { kind: "component", type: i4.TableRowComponent, selector: "[cdsTableRow], [ibmTableRow]", inputs: ["model", "row", "expanded", "expandable", "selected", "size", "enableSingleSelect", "expandButtonAriaLabel", "checkboxLabel", "showSelectionColumn", "showSelectionColumnCheckbox", "selectionLabelColumn", "skeleton", "withRowAILabels"], outputs: ["selectRow", "deselectRow", "expandRow", "rowClick"] }, { kind: "component", type: i5.TableExpandedRow, selector: "[cdsTableExpandedRow], [ibmTableExpandedRow]", inputs: ["row", "skeleton", "expanded"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableBody, decorators: [{ type: Component, args: [{ // tslint:disable-next-line: component-selector selector: "[cdsTableBody], [ibmTableBody]", template: ` <ng-container *ngIf="model"> <ng-container *ngFor="let row of model.data; let i = index"> <tr cdsTableRow [model]="model" [row]="row" [size]="size" [selected]="model.isRowSelected(i)" [expandable]="model.isRowExpandable(i)" [expanded]="model.isRowExpanded(i)" [checkboxLabel]="getCheckboxRowLabel()" [expandButtonAriaLabel]="getExpandButtonAriaLabel()" [showSelectionColumn]="showSelectionColumn" [enableSingleSelect]="enableSingleSelect" [skeleton]="skeleton" [withRowAILabels]="withRowAILabels" (selectRow)="onRowCheckboxChange(i)" (deselectRow)="onRowCheckboxChange(i)" (expandRow)="model.expandRow(i, !model.isRowExpanded(i))" (rowClick)="onRowClick(i)" *ngIf="!model.isRowFiltered(i)" [class]="(model.rowsClass[i] ? model.rowsClass[i] : null)" [ngClass]="{ 'tbody_row--success': !model.isRowSelected(i) && model.getRowContext(i) === 'success', 'tbody_row--warning': !model.isRowSelected(i) && model.getRowContext(i) === 'warning', 'tbody_row--info': !model.isRowSelected(i) && model.getRowContext(i) === 'info', 'tbody_row--error': !model.isRowSelected(i) && model.getRowContext(i) === 'error' }"> </tr> <tr *ngIf="model.isRowExpandable(i) && !shouldExpandAsTable(row) && !model.isRowFiltered(i)" cdsTableExpandedRow cdsExpandedRowHover [row]="row" [expanded]="model.isRowExpanded(i)" [skeleton]="skeleton"> </tr> <ng-container *ngIf="model.isRowExpandable(i) && shouldExpandAsTable(row) && model.isRowExpanded(i) && !model.isRowFiltered(i)"> <tr *ngFor="let expandedDataRow of firstExpandedDataInRow(row)" cdsTableRow [model]="model" [showSelectionColumnCheckbox]="false" [showSelectionColumn]="showSelectionColumn" [row]="expandedDataRow" [size]="size" [skeleton]="skeleton" [withRowAILabels]="withRowAILabels"> </tr> </ng-container> </ng-container> </ng-container> <ng-content></ng-content> ` }] }], ctorParameters: function () { return [{ type: i1.I18n }]; }, propDecorators: { model: [{ type: Input }], enableSingleSelect: [{ type: Input }], expandButtonAriaLabel: [{ type: Input }], checkboxRowLabel: [{ type: Input }], showSelectionColumn: [{ type: Input }], size: [{ type: Input }], selectionLabelColumn: [{ type: Input }], skeleton: [{ type: Input }], withRowAILabels: [{ type: Input }], selectRow: [{ type: Output }], deselectRow: [{ type: Output }], rowClick: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-body.component.js","sourceRoot":"","sources":["../../../../src/table/body/table-body.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tEventEmitter,\n\tOutput\n} from \"@angular/core\";\nimport { TableModel } from \"../table-model.class\";\nimport { I18n, Overridable } from \"carbon-components-angular/i18n\";\nimport { Observable } from \"rxjs\";\nimport { TableRowSize } from \"../table.types\";\n\n@Component({\n\t// tslint:disable-next-line: component-selector\n\tselector: \"[cdsTableBody], [ibmTableBody]\",\n\ttemplate: `\n\t\t<ng-container *ngIf=\"model\">\n\t\t\t<ng-container *ngFor=\"let row of model.data; let i = index\">\n\t\t\t\t<tr\n\t\t\t\t\tcdsTableRow\n\t\t\t\t\t[model]=\"model\"\n\t\t\t\t\t[row]=\"row\"\n\t\t\t\t\t[size]=\"size\"\n\t\t\t\t\t[selected]=\"model.isRowSelected(i)\"\n\t\t\t\t\t[expandable]=\"model.isRowExpandable(i)\"\n\t\t\t\t\t[expanded]=\"model.isRowExpanded(i)\"\n\t\t\t\t\t[checkboxLabel]=\"getCheckboxRowLabel()\"\n\t\t\t\t\t[expandButtonAriaLabel]=\"getExpandButtonAriaLabel()\"\n\t\t\t\t\t[showSelectionColumn]=\"showSelectionColumn\"\n\t\t\t\t\t[enableSingleSelect]=\"enableSingleSelect\"\n\t\t\t\t\t[skeleton]=\"skeleton\"\n\t\t\t\t\t[withRowAILabels]=\"withRowAILabels\"\n\t\t\t\t\t(selectRow)=\"onRowCheckboxChange(i)\"\n\t\t\t\t\t(deselectRow)=\"onRowCheckboxChange(i)\"\n\t\t\t\t\t(expandRow)=\"model.expandRow(i, !model.isRowExpanded(i))\"\n\t\t\t\t\t(rowClick)=\"onRowClick(i)\"\n\t\t\t\t\t*ngIf=\"!model.isRowFiltered(i)\"\n\t\t\t\t\t[class]=\"(model.rowsClass[i] ? model.rowsClass[i] : null)\"\n\t\t\t\t\t[ngClass]=\"{\n\t\t\t\t\t\t'tbody_row--success': !model.isRowSelected(i) && model.getRowContext(i) === 'success',\n\t\t\t\t\t\t'tbody_row--warning': !model.isRowSelected(i) && model.getRowContext(i) === 'warning',\n\t\t\t\t\t\t'tbody_row--info': !model.isRowSelected(i) && model.getRowContext(i) === 'info',\n\t\t\t\t\t\t'tbody_row--error': !model.isRowSelected(i) && model.getRowContext(i) === 'error'\n\t\t\t\t\t}\">\n\t\t\t\t</tr>\n\t\t\t\t<tr\n\t\t\t\t\t*ngIf=\"model.isRowExpandable(i) && !shouldExpandAsTable(row) && !model.isRowFiltered(i)\"\n\t\t\t\t\tcdsTableExpandedRow\n\t\t\t\t\tcdsExpandedRowHover\n\t\t\t\t\t[row]=\"row\"\n\t\t\t\t\t[expanded]=\"model.isRowExpanded(i)\"\n\t\t\t\t\t[skeleton]=\"skeleton\">\n\t\t\t\t</tr>\n\t\t\t\t<ng-container\n\t\t\t\t\t*ngIf=\"model.isRowExpandable(i) && shouldExpandAsTable(row) && model.isRowExpanded(i) && !model.isRowFiltered(i)\">\n\t\t\t\t\t<tr\n\t\t\t\t\t\t*ngFor=\"let expandedDataRow of firstExpandedDataInRow(row)\"\n\t\t\t\t\t\tcdsTableRow\n\t\t\t\t\t\t[model]=\"model\"\n\t\t\t\t\t\t[showSelectionColumnCheckbox]=\"false\"\n\t\t\t\t\t\t[showSelectionColumn]=\"showSelectionColumn\"\n\t\t\t\t\t\t[row]=\"expandedDataRow\"\n\t\t\t\t\t\t[size]=\"size\"\n\t\t\t\t\t\t[skeleton]=\"skeleton\"\n\t\t\t\t\t\t[withRowAILabels]=\"withRowAILabels\">\n\t\t\t\t\t</tr>\n\t\t\t\t</ng-container>\n\t\t\t</ng-container>\n\t\t</ng-container>\n\t\t<ng-content></ng-content>\n\t`\n})\nexport class TableBody {\n\t@Input() model: TableModel;\n\n\t/**\n\t * Controls whether to enable multiple or single row selection.\n\t */\n\t@Input() enableSingleSelect = false;\n\n\t@Input()\n\tset expandButtonAriaLabel(value: string | Observable<string>) {\n\t\tthis._expandButtonAriaLabel.override(value);\n\t}\n\n\tget expandButtonAriaLabel() {\n\t\treturn this._expandButtonAriaLabel.value;\n\t}\n\n\t@Input()\n\tset checkboxRowLabel(value: string | Observable<string>) {\n\t\tthis._checkboxRowLabel.override(value);\n\t}\n\n\tget checkboxRowLabel() {\n\t\treturn this._checkboxRowLabel.value;\n\t}\n\n\t/**\n\t * Controls whether to show the selection checkboxes column or not.\n\t */\n\t@Input() showSelectionColumn = true;\n\n\t/**\n\t * Size of the table rows.\n\t */\n\t@Input() size: TableRowSize = \"md\";\n\n\t/**\n\t * Used to populate the row selection checkbox label with a useful value if set.\n\t *\n\t * Example:\n\t * ```\n\t * <cds-table [selectionLabelColumn]=\"0\"></cds-table>\n\t * <!-- results in aria-label=\"Select first column value\"\n\t * (where \"first column value\" is the value of the first column in the row -->\n\t * ```\n\t */\n\t@Input() selectionLabelColumn: number;\n\n\t@Input() skeleton = false;\n\n\t/**\n\t * Enables Carbon styles when the first column is an AI decorator column (`TableItem.hasAILabelDecorator`).\n\t */\n\t@Input() withRowAILabels = false;\n\n\t/**\n\t * Emits if a single row is selected.\n\t *\n\t * @param ({model: this.model, selectedRowIndex: index})\n\t */\n\t@Output() selectRow = new EventEmitter<Object>();\n\n\t/**\n\t * Emits if a single row is deselected.\n\t *\n\t * @param ({model: this.model, deselectedRowIndex: index})\n\t */\n\t@Output() deselectRow = new EventEmitter<Object>();\n\n\t/**\n\t * Emits if a row item excluding expandButtons, checkboxes, or radios is clicked.\n\t */\n\t@Output() rowClick = new EventEmitter<number>();\n\n\tprotected _checkboxRowLabel = this.i18n.getOverridable(\"TABLE.CHECKBOX_ROW\");\n\tprotected _expandButtonAriaLabel = this.i18n.getOverridable(\"TABLE.EXPAND_BUTTON\");\n\n\tconstructor(protected i18n: I18n) { }\n\n\t/**\n\t * Triggered when a single row is clicked.\n\t * Updates the header checkbox state.\n\t * Emits the `selectRow` or `deselectRow` event.\n\t */\n\tonRowCheckboxChange(index: number) {\n\t\tif (this.model.isRowSelected(index)) {\n\t\t\tthis.deselectRow.emit({ model: this.model, deselectedRowIndex: index });\n\t\t} else {\n\t\t\tthis.selectRow.emit({ model: this.model, selectedRowIndex: index });\n\t\t}\n\t}\n\n\tonRowClick(index: number) {\n\t\tthis.rowClick.emit(index);\n\t}\n\n\tgetCheckboxRowLabel(): Observable<string> {\n\t\treturn this._checkboxRowLabel.subject;\n\t}\n\n\tgetExpandButtonAriaLabel(): Observable<string> {\n\t\treturn this._expandButtonAriaLabel.subject;\n\t}\n\n\tfirstExpandedDataInRow(row) {\n\t\tconst found = row.find(d => d.expandedData);\n\t\tif (found) {\n\t\t\treturn found.expandedData;\n\t\t}\n\t\treturn found;\n\t}\n\n\tshouldExpandAsTable(row) {\n\t\treturn row.some(d => d.expandAsTable);\n\t}\n}\n"]}