carbon-components-angular
Version:
Next generation components
236 lines • 21.5 kB
JavaScript
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"]}