UNPKG

ornamentum

Version:
333 lines 37.6 kB
/** * @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\">&nbsp;</td>\n <td *ngIf=\"config.showIndexColumn\">&nbsp;</td>\n <td *ngIf=\"showRowSelectCheckbox\">&nbsp;</td>\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"column.visible\">&nbsp;</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"]}