ornamentum
Version:
Angular Toolkit
333 lines • 37.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, TemplateRef } from '@angular/core';
import { DataTableConfigService } from '../../services/data-table-config.service';
import { DataTableDataStateService } from '../../services/data-table-data-state.service';
import { DataTableEventStateService } from '../../services/data-table-event.service';
import { get } from '../../../utility/services/object-utility.class';
/**
* Data table body component. Data table body table definition rendering is handled by this component.
*/
export class DataTableBodyComponent {
/**
* @param {?} config
* @param {?} dataStateService
* @param {?} eventStateService
*/
constructor(config, dataStateService, eventStateService) {
this.config = config;
this.dataStateService = dataStateService;
this.eventStateService = eventStateService;
}
/**
* Unique data row tracking callback.
* @param {?} index Current index.
* @param {?} dataRow Data row object reference.
* @return {?}
*/
dataRowTrackBy(index, dataRow) {
return dataRow.index;
}
/**
* Odd row status; True if row index is a odd number.
* @param {?} row Data row object.
* @return {?} True if odd row.
*/
isOddRow(row) {
return row.index % 2 === 0;
}
/**
* Even row status; True if row index is a even number.
* @param {?} row Data row object.
* @return {?} True if even row.
*/
isEvenRow(row) {
return row.index % 2 === 1;
}
/**
* Odd substitute row status by row index; True if row index is an odd substitute row.
* @param {?} index Row index.
* @return {?} True if odd substitute row.
*/
isOddSubstituteRow(index) {
return (index + this.dataStateService.substituteRows.length) % 2 === 0;
}
/**
* Even substitute row status by row index; True if row index is an even substitute row.
* @param {?} index Row index.
* @return {?} True if even substitute row.
*/
isEvenSubstituteRow(index) {
return (index + this.dataStateService.substituteRows.length) % 2 === 1;
}
/**
* On row expand event handler.
* @param {?} $event Click event argument reference.
* @param {?} dataRow Data row object.
* @return {?}
*/
onRowExpand($event, dataRow) {
dataRow.expanded = !dataRow.expanded;
if (!this.config.showRowExpandLoadingSpinner) {
dataRow.dataLoaded = true;
}
}
/**
* On row initialize event handler.
* @param {?} dataRow Data table row.
* @return {?}
*/
onRowInit(dataRow) {
this.eventStateService.rowBindStream.emit(dataRow);
}
/**
* On cell initialize event handler.
* @param {?} column Data table column component reference.
* @param {?} row Data table row object.
* @return {?}
*/
onCellInit(column, row) {
this.eventStateService.cellBindStream.emit({
column,
row
});
}
/**
* Cell clicked event handler.
* @param {?} column Column data table component reference.
* @param {?} row Data table row reference.
* @param {?} event Mouse click event argument reference.
* @return {?}
*/
cellClicked(column, row, event) {
this.eventStateService.cellClickStream.emit({ row, column, event });
}
/**
* Get row span collection by data row.
* @param {?} row Data row reference.
* @return {?} Dummy row span collection.
*/
getRowSpanCollection(row) {
return Array.from({
length: this.dataStateService.onDynamicRowSpanExtract(row)
});
}
/**
* Get total column count used for substitute row generation.
* @return {?} Number of columns.
*/
get totalColumnCount() {
/** @type {?} */
let count = 0;
count += this.config.showIndexColumn ? 1 : 0;
count += this.config.showRowSelectCheckboxColumn ? 1 : 0;
count += this.config.expandableRows ? 1 : 0;
this.columns.forEach((/**
* @param {?} column
* @return {?}
*/
column => {
count += column.visible ? 1 : 0;
}));
return count;
}
/**
* On row select click event handler.
* @param {?} row Data row reference.
* @param {?} event Row click event.
* @return {?}
*/
onRowSelectClick(row, event) {
// Prevent single mode checkbox getting unchecked on tapping already selected.
if (this.config.selectMode === 'single') {
/** @type {?} */
const id = get(row.item, this.config.selectTrackBy);
/** @type {?} */
const previousSelection = this.dataStateService.selectedRow;
if (previousSelection === id) {
event.preventDefault();
row.selected = true;
}
}
}
/**
* On row selection change event handler.
* @param {?} row Data row reference.
* @return {?}
*/
onRowSelectChange(row) {
/** @type {?} */
const id = get(row.item, this.config.selectTrackBy);
switch (this.config.selectMode) {
case 'multi': {
/** @type {?} */
const index = this.dataStateService.selectedRows.indexOf(id);
if (row.selected && index < 0) {
this.dataStateService.selectedRows.push(id);
}
else if (!row.selected && index > -1) {
this.dataStateService.selectedRows.splice(index, 1);
}
/** @type {?} */
const previousAllRowSelectedState = this.dataStateService.allRowSelected;
this.dataStateService.allRowSelected = this.dataStateService.dataRows.every((/**
* @param {?} dataRow
* @return {?}
*/
(dataRow) => {
return dataRow.selected;
}));
this.eventStateService.rowSelectChangeStream.emit(this.dataStateService.selectedRows);
if (previousAllRowSelectedState !== this.dataStateService.allRowSelected) {
this.eventStateService.allRowSelectChangeStream.emit(this.dataStateService.allRowSelected);
}
break;
}
case 'single_toggle': {
if (row.selected) {
this.dataStateService.selectedRow = id;
// deselect all other row other rows
this.dataStateService.dataRows.forEach((/**
* @param {?} dataRow
* @return {?}
*/
(dataRow) => {
if (dataRow !== row) {
dataRow.selected = false;
}
}));
}
else {
this.dataStateService.selectedRow = undefined;
}
this.eventStateService.rowSelectChangeStream.emit(this.dataStateService.selectedRow);
break;
}
case 'single': {
/** @type {?} */
const previousSelection = this.dataStateService.selectedRow;
this.dataStateService.selectedRow = id;
row.selected = true;
// deselect all other row other rows
this.dataStateService.dataRows.forEach((/**
* @param {?} dataRow
* @return {?}
*/
(dataRow) => {
if (dataRow !== row) {
dataRow.selected = false;
}
}));
if (previousSelection !== id) {
this.eventStateService.rowSelectChangeStream.emit(this.dataStateService.selectedRow);
}
break;
}
}
}
/**
* Row clicked event handler.
* @param {?} row Data row object.
* @param {?} event Mouse click event argument object.
* @return {?}
*/
rowClicked(row, event) {
if (this.config.selectOnRowClick || (this.config.expandableRows && this.config.expandOnRowClick)) {
/** @type {?} */
const target = (/** @type {?} */ (event.target));
if (target && target.classList && target.classList.contains('ng-ignore-propagation')) {
return;
}
if (this.config.rowSelectable && this.config.selectOnRowClick) {
row.selected = !row.selected;
this.onRowSelectChange(row);
}
if (this.config.expandOnRowClick) {
row.expanded = !row.expanded;
}
}
this.eventStateService.rowClickStream.emit({ row, event });
}
/**
* Row double clicked event handler.
* @param {?} row Data row object.
* @param {?} event Event Mouse click event argument object.
* @return {?}
*/
rowDoubleClicked(row, event) {
this.eventStateService.rowDoubleClickStream.emit({ row, event });
}
/**
* Get substitute row availability status.
* @return {?} True if substitute rows are available.
*/
get hasSubstituteRows() {
return !this.config.loadOnScroll
&& this.config.showSubstituteRows
&& this.dataStateService.dataRows.length
&& !this.dataStateService.showNoDataOverlay;
}
/**
* Get cell value by data field.
* @param {?} row Data row reference.
* @param {?} column Data table column component reference.
* @return {?}
*/
getFieldValue(row, column) {
return get(row.item, column.field);
}
/**
* Get row select checkbox display status.
* @return {?} True if row selector checkbox should be displayed.
*/
get showRowSelectCheckbox() {
return this.config.rowSelectable && this.config.showRowSelectCheckbox;
}
/**
* Get row expend view loading status. Used to display loading spinner on expand column while data fetching.
* @param {?} row Data row object reference.
* @return {?}
*/
isRowExpanderLoading(row) {
return row.expanded && !row.dataLoaded;
}
}
DataTableBodyComponent.decorators = [
{ type: Component, args: [{
exportAs: 'ngDataTableBody',
// tslint:disable-next-line
selector: '[ngDataTableBody]',
template: "<ng-container *ngFor=\"let row of dataStateService.dataRows; trackBy: dataRowTrackBy; let i = index;\">\n <ng-container *ngFor=\"let ignored of getRowSpanCollection(row); let rowSpanIndex = index; let rowSpanCount = count\">\n <tr\n class=\"ng-data-table-row\"\n (ngInit)=\"onRowInit(row)\"\n [attr.title]=\"row.tooltip\"\n [class.row-odd]=\"isOddRow(row)\"\n [class.row-even]=\"isEvenRow(row)\"\n [class.selected]=\"row.selected\"\n [class.clickable]=\"config.selectOnRowClick\"\n [class.disabled]=\"row.disabled\"\n [ngClass]=\"row.cssClass\"\n (dblclick)=\"rowDoubleClicked(row, $event)\"\n (click)=\"rowClicked(row, $event)\"\n >\n <td\n class=\"ng-data-table-row-expand-button ng-ignore-propagation\"\n [style.background-color]=\"row.color\"\n *ngIf=\"config.expandableRows && !rowSpanIndex\"\n (click)=\"onRowExpand($event, row)\"\n [attr.rowspan]=\"rowSpanCount\"\n >\n <div [hidden]=\"config.showRowExpandLoadingSpinner && isRowExpanderLoading(row)\">\n <span class=\"ng-data-table-expander-collapsed-icon ng-ignore-propagation\" *ngIf=\"!row.expanded\"></span>\n <span class=\"ng-data-table-expander-expanded-icon ng-ignore-propagation\" *ngIf=\"row.expanded\"></span>\n </div>\n <ng-data-table-loading-spinner\n *ngIf=\"config.showRowExpandLoadingSpinner\"\n [loadingSpinnerTemplate]=\"rowExpandLoadingSpinnerTemplate\"\n [isLoading]=\"isRowExpanderLoading(row)\"\n [showOverlay]=\"false\"\n >\n </ng-data-table-loading-spinner>\n </td>\n <td\n class=\"index-column\"\n [style.background-color]=\"row.color\"\n *ngIf=\"config.showIndexColumn && !rowSpanIndex\"\n [textContent]=\"row.index\"\n [attr.rowspan]=\"rowSpanCount\"\n >\n </td>\n <td\n class=\"ng-data-table-select-column\"\n [style.background-color]=\"row.color\"\n *ngIf=\"showRowSelectCheckbox && !rowSpanIndex\"\n [attr.rowspan]=\"rowSpanCount\"\n >\n <div class=\"ng-data-table-checkbox-container ng-ignore-propagation\">\n <input class=\"ng-data-table-checkbox-input ng-ignore-propagation\" type=\"checkbox\"\n [id]=\"dataStateService.getUniqueId('dr', i)\"\n [(ngModel)]=\"row.selected\"\n (click)=\"onRowSelectClick(row, $event)\"\n (change)=\"onRowSelectChange(row)\"\n />\n <label class=\"ng-ignore-propagation\" [for]=\"dataStateService.getUniqueId('dr', i)\"></label>\n </div>\n </td>\n <ng-container *ngFor=\"let column of columns\">\n <ng-container *ngIf=\"column.visible\">\n <td\n class=\"ng-data-table-data-column\"\n *ngIf=\"!column.cellTemplate && !rowSpanIndex\"\n (ngInit)=\"onCellInit(column, row)\"\n [ngClass]=\"column.cssClass\"\n [attr.rowspan]=\"rowSpanCount\"\n [style.background-color]=\"column.getCellColor(row) || row.color\"\n (click)=\"cellClicked(column, row, $event)\"\n >\n <span>{{ getFieldValue(row, column) }}</span>\n </td>\n <ng-container\n *ngIf=\"column.cellTemplate\"\n [ngTemplateOutlet]=\"column.cellTemplate\"\n [ngTemplateOutletContext]=\"{ column: column, row: row, spanIndex: rowSpanIndex, rowSpan: rowSpanCount }\"\n >\n </ng-container>\n </ng-container>\n </ng-container>\n </tr>\n </ng-container>\n <tr *ngIf=\"config.expandableRows\" [hidden]=\"!row.expanded\" class=\"ng-data-table-row-expansion\">\n <td [attr.colspan]=\"totalColumnCount\">\n <ng-container [ngTemplateOutlet]=\"rowExpandTemplate\" [ngTemplateOutletContext]=\"{ row: row }\"> </ng-container>\n </td>\n </tr>\n</ng-container>\n<ng-container *ngIf=\"hasSubstituteRows\">\n <tr\n *ngFor=\"let ignored of dataStateService.substituteRows; let index = index\"\n [class.row-odd]=\"isOddSubstituteRow(index)\"\n [class.row-even]=\"isEvenSubstituteRow(index)\"\n >\n <td *ngIf=\"config.expandableRows\"> </td>\n <td *ngIf=\"config.showIndexColumn\"> </td>\n <td *ngIf=\"showRowSelectCheckbox\"> </td>\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"column.visible\"> </td>\n </ng-container>\n </tr>\n</ng-container>\n"
}] }
];
/** @nocollapse */
DataTableBodyComponent.ctorParameters = () => [
{ type: DataTableConfigService },
{ type: DataTableDataStateService },
{ type: DataTableEventStateService }
];
DataTableBodyComponent.propDecorators = {
columns: [{ type: Input }],
rowExpandTemplate: [{ type: Input }],
rowExpandLoadingSpinnerTemplate: [{ type: Input }]
};
if (false) {
/** @type {?} */
DataTableBodyComponent.prototype.columns;
/** @type {?} */
DataTableBodyComponent.prototype.rowExpandTemplate;
/** @type {?} */
DataTableBodyComponent.prototype.rowExpandLoadingSpinnerTemplate;
/** @type {?} */
DataTableBodyComponent.prototype.config;
/** @type {?} */
DataTableBodyComponent.prototype.dataStateService;
/**
* @type {?}
* @private
*/
DataTableBodyComponent.prototype.eventStateService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-body.component.js","sourceRoot":"ng://ornamentum/","sources":["data-table/components/data-table-body/data-table-body.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, TemplateRef } from '@angular/core';\n\nimport { DataTableRow } from '../../models/data-table-row.model';\n\nimport { DataTableColumnComponent } from '../data-table-column/data-table-column.component';\n\nimport { DataTableConfigService } from '../../services/data-table-config.service';\nimport { DataTableDataStateService } from '../../services/data-table-data-state.service';\nimport { DataTableEventStateService } from '../../services/data-table-event.service';\n\nimport { get } from '../../../utility/services/object-utility.class';\n\n/**\n * Data table body component. Data table body table definition rendering is handled by this component.\n */\n@Component({\n  exportAs: 'ngDataTableBody',\n  // tslint:disable-next-line\n  selector: '[ngDataTableBody]',\n  templateUrl: './data-table-body.component.html'\n})\nexport class DataTableBodyComponent {\n  @Input()\n  public columns: DataTableColumnComponent[];\n\n  @Input()\n  public rowExpandTemplate: TemplateRef<any>;\n\n  @Input()\n  public rowExpandLoadingSpinnerTemplate: TemplateRef<any>;\n\n  constructor(\n    public config: DataTableConfigService,\n    public dataStateService: DataTableDataStateService,\n    private eventStateService: DataTableEventStateService\n  ) {}\n\n  /**\n   * Unique data row tracking callback.\n   * @param index Current index.\n   * @param dataRow Data row object reference.\n   */\n  public dataRowTrackBy(index: number, dataRow: DataTableRow<any>): number {\n    return dataRow.index;\n  }\n\n  /**\n   * Odd row status; True if row index is a odd number.\n   * @param row Data row object.\n   * @return True if odd row.\n   */\n  public isOddRow(row: DataTableRow<any>): boolean {\n    return row.index % 2 === 0;\n  }\n\n  /**\n   * Even row status; True if row index is a even number.\n   * @param row Data row object.\n   * @return True if even row.\n   */\n  public isEvenRow(row: DataTableRow<any>): boolean {\n    return row.index % 2 === 1;\n  }\n\n  /**\n   * Odd substitute row status by row index; True if row index is an odd substitute row.\n   * @param index Row index.\n   * @return True if odd substitute row.\n   */\n  public isOddSubstituteRow(index: number): boolean {\n    return (index + this.dataStateService.substituteRows.length) % 2 === 0;\n  }\n\n  /**\n   * Even substitute row status by row index; True if row index is an even substitute row.\n   * @param index Row index.\n   * @return True if even substitute row.\n   */\n  public isEvenSubstituteRow(index: number): boolean {\n    return (index + this.dataStateService.substituteRows.length) % 2 === 1;\n  }\n\n  /**\n   * On row expand event handler.\n   * @param $event Click event argument reference.\n   * @param dataRow Data row object.\n   */\n  public onRowExpand($event: Event, dataRow: DataTableRow<any>): void {\n    dataRow.expanded = !dataRow.expanded;\n\n    if (!this.config.showRowExpandLoadingSpinner) {\n      dataRow.dataLoaded = true;\n    }\n  }\n\n  /**\n   * On row initialize event handler.\n   * @param dataRow Data table row.\n   */\n  public onRowInit(dataRow): void {\n    this.eventStateService.rowBindStream.emit(dataRow);\n  }\n\n  /**\n   * On cell initialize event handler.\n   * @param column Data table column component reference.\n   * @param row Data table row object.\n   */\n  public onCellInit(column: DataTableColumnComponent, row: DataTableRow<any>): void {\n    this.eventStateService.cellBindStream.emit({\n      column,\n      row\n    });\n  }\n\n  /**\n   * Cell clicked event handler.\n   * @param column Column data table component reference.\n   * @param row Data table row reference.\n   * @param event Mouse click event argument reference.\n   */\n  public cellClicked(column: DataTableColumnComponent, row: DataTableRow<any>, event: MouseEvent): void {\n    this.eventStateService.cellClickStream.emit({ row, column, event });\n  }\n\n  /**\n   * Get row span collection by data row.\n   * @param row Data row reference.\n   * @return Dummy row span collection.\n   */\n  public getRowSpanCollection(row: DataTableRow<any>): any[] {\n    return Array.from({\n      length: this.dataStateService.onDynamicRowSpanExtract(row)\n    });\n  }\n\n  /**\n   * Get total column count used for substitute row generation.\n   * @return Number of columns.\n   */\n  public get totalColumnCount(): number {\n    let count = 0;\n    count += this.config.showIndexColumn ? 1 : 0;\n    count += this.config.showRowSelectCheckboxColumn ? 1 : 0;\n    count += this.config.expandableRows ? 1 : 0;\n    this.columns.forEach(column => {\n      count += column.visible ? 1 : 0;\n    });\n\n    return count;\n  }\n\n  /**\n   * On row select click event handler.\n   * @param row Data row reference.\n   * @param event Row click event.\n   */\n  public onRowSelectClick(row: DataTableRow<any>, event: Event): void {\n    // Prevent single mode checkbox getting unchecked on tapping already selected.\n    if (this.config.selectMode === 'single') {\n      const id = get(row.item, this.config.selectTrackBy);\n      const previousSelection = this.dataStateService.selectedRow;\n\n      if (previousSelection === id) {\n        event.preventDefault();\n        row.selected = true;\n      }\n    }\n  }\n\n  /**\n   * On row selection change event handler.\n   * @param row Data row reference.\n   */\n  public onRowSelectChange(row: DataTableRow<any>): void {\n    const id = get(row.item, this.config.selectTrackBy);\n\n    switch (this.config.selectMode) {\n      case 'multi': {\n        const index = this.dataStateService.selectedRows.indexOf(id);\n        if (row.selected && index < 0) {\n          this.dataStateService.selectedRows.push(id);\n        } else if (!row.selected && index > -1) {\n          this.dataStateService.selectedRows.splice(index, 1);\n        }\n\n        const previousAllRowSelectedState = this.dataStateService.allRowSelected;\n        this.dataStateService.allRowSelected = this.dataStateService.dataRows.every((dataRow: DataTableRow<any>) => {\n          return dataRow.selected;\n        });\n\n        this.eventStateService.rowSelectChangeStream.emit(this.dataStateService.selectedRows);\n\n        if (previousAllRowSelectedState !== this.dataStateService.allRowSelected) {\n          this.eventStateService.allRowSelectChangeStream.emit(this.dataStateService.allRowSelected);\n        }\n        break;\n      }\n      case 'single_toggle': {\n        if (row.selected) {\n          this.dataStateService.selectedRow = id;\n\n          // deselect all other row other rows\n          this.dataStateService.dataRows.forEach((dataRow: DataTableRow<any>) => {\n            if (dataRow !== row) {\n              dataRow.selected = false;\n            }\n          });\n        } else {\n          this.dataStateService.selectedRow = undefined;\n        }\n\n        this.eventStateService.rowSelectChangeStream.emit(this.dataStateService.selectedRow);\n        break;\n      }\n      case 'single': {\n        const previousSelection = this.dataStateService.selectedRow;\n        this.dataStateService.selectedRow = id;\n        row.selected = true;\n\n        // deselect all other row other rows\n        this.dataStateService.dataRows.forEach((dataRow: DataTableRow<any>) => {\n          if (dataRow !== row) {\n            dataRow.selected = false;\n          }\n        });\n\n        if (previousSelection !== id) {\n          this.eventStateService.rowSelectChangeStream.emit(this.dataStateService.selectedRow);\n        }\n        break;\n      }\n    }\n  }\n\n  /**\n   * Row clicked event handler.\n   * @param row Data row object.\n   * @param event Mouse click event argument object.\n   */\n  public rowClicked(row: DataTableRow<any>, event: MouseEvent): void {\n    if (this.config.selectOnRowClick || (this.config.expandableRows && this.config.expandOnRowClick)) {\n      const target = event.target as HTMLElement;\n      if (target && target.classList && target.classList.contains('ng-ignore-propagation')) {\n        return;\n      }\n\n      if (this.config.rowSelectable && this.config.selectOnRowClick) {\n        row.selected = !row.selected;\n        this.onRowSelectChange(row);\n      }\n\n      if (this.config.expandOnRowClick) {\n        row.expanded = !row.expanded;\n      }\n    }\n\n    this.eventStateService.rowClickStream.emit({ row, event });\n  }\n\n  /**\n   * Row double clicked event handler.\n   * @param row Data row object.\n   * @param event Event Mouse click event argument object.\n   */\n  public rowDoubleClicked(row: DataTableRow<any>, event: MouseEvent): void {\n    this.eventStateService.rowDoubleClickStream.emit({ row, event });\n  }\n\n  /**\n   * Get substitute row availability status.\n   * @return True if substitute rows are available.\n   */\n  public get hasSubstituteRows(): boolean {\n    return !this.config.loadOnScroll\n      && this.config.showSubstituteRows\n      && this.dataStateService.dataRows.length\n      && !this.dataStateService.showNoDataOverlay;\n  }\n\n  /**\n   * Get cell value by data field.\n   * @param row Data row reference.\n   * @param column Data table column component reference.\n   */\n  public getFieldValue(row: DataTableRow<any>, column: DataTableColumnComponent) {\n    return get(row.item, column.field);\n  }\n\n  /**\n   * Get row select checkbox display status.\n   * @return True if row selector checkbox should be displayed.\n   */\n  public get showRowSelectCheckbox(): boolean {\n    return this.config.rowSelectable && this.config.showRowSelectCheckbox;\n  }\n\n  /**\n   * Get row expend view loading status. Used to display loading spinner on expand column while data fetching.\n   * @param row Data row object reference.\n   */\n  public isRowExpanderLoading(row: DataTableRow<any>): boolean {\n    return row.expanded && !row.dataLoaded;\n  }\n}\n"]}