UNPKG

ngx-config-datatable

Version:
277 lines 21.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core'; import { BehaviorSubject, combineLatest, Subscription } from 'rxjs'; import { filter } from 'rxjs/operators'; export class DatatableComponent { constructor() { this.isShowCheckbox = true; this.isShowRowNumber = true; this.className = ''; this.sortCommand = new EventEmitter(); this.checkRowCommand = new EventEmitter(); this.sub = new Subscription(); this.datatableSetting$ = new BehaviorSubject(null); this.data$ = new BehaviorSubject([]); this.rows = []; this.footers = []; this.headerChecked = false; this.sub.add(combineLatest(this.datatableSetting$, this.data$).pipe(filter((/** * @param {?} __0 * @return {?} */ ([datatableSetting, data]) => datatableSetting ? true : false))).subscribe((/** * @param {?} __0 * @return {?} */ ([datatableSetting, data]) => { this.render(); }))); } /** * @param {?} v * @return {?} */ set datatableSetting(v) { this.datatableSetting$.next(v); } /** * @return {?} */ get datatableSetting() { return this.datatableSetting$.getValue(); } /** * @param {?} v * @return {?} */ set data(v) { this.data$.next(v); } /** * @return {?} */ get data() { return this.data$.getValue(); } /** * @return {?} */ ngOnDestroy() { this.sub.unsubscribe(); } /** * @private * @return {?} */ render() { this.rows = []; this.footers = []; this.addRows(); this.addSummaryRow(); } /** * @param {?} sortInfo * @return {?} */ changeSort(sortInfo) { for (const item of this.datatableSetting.headers) { if (item.propName !== sortInfo.propName) { item.sort = 'none'; } else { item.sort = sortInfo.sort; } } this.sortCommand.emit(sortInfo); } /** * @param {?} event * @return {?} */ headerCheckIt(event) { event.preventDefault(); this.headerChecked = !this.headerChecked; for (const row of this.rows) { // tslint:disable-next-line:no-string-literal row['cbk__checked'] = this.headerChecked; } this.checkAllCheckbox(); } /** * @param {?} event * @param {?} row * @return {?} */ rowCheckIt(event, row) { event.preventDefault(); this.checkAllCheckbox(); } /** * @private * @return {?} */ checkAllCheckbox() { // tslint:disable-next-line:no-string-literal this.headerChecked = !this.rows.some((/** * @param {?} a * @return {?} */ a => !a['cbk__checked'])); // tslint:disable-next-line:no-string-literal /** @type {?} */ const ids = this.rows.filter((/** * @param {?} a * @return {?} */ a => !!a['cbk__checked'])).map((/** * @param {?} a * @return {?} */ a => a.id)); this.checkRowCommand.emit(ids); } /** * @private * @return {?} */ addRows() { this.checkDatatableSetting(); for (const row of this.data) { /** @type {?} */ const cs = { id: row.id, rowData: row, columns: [] }; for (const item of this.datatableSetting.headers) { if (!item.isEnabled) { continue; } /** @type {?} */ let vv = row[item.propName]; if (item.converter) { vv = item.converter.to(vv); } cs.columns.push({ isHtml: item.isHtml, content: vv }); } this.rows.push(cs); } } /** * @private * @return {?} */ addSummaryRow() { this.checkDatatableSetting(); /** @type {?} */ const fs = { id: '', rowData: { id: '' }, columns: [] }; if (!this.datatableSetting.headers.some((/** * @param {?} a * @return {?} */ a => a.isSum))) { return; } for (const item of this.datatableSetting.headers) { if (!item.isEnabled) { continue; } if (!item.isSum) { fs.columns.push({ isHtml: item.isHtml, content: '' }); continue; } /** @type {?} */ let tTotal = 0; for (const row of this.data) { /** @type {?} */ const vv = row[item.propName]; tTotal += +vv; } if (item.converter) { tTotal = item.converter.to(tTotal); } fs.columns.push({ isHtml: item.isHtml, content: tTotal }); } this.footers.push(fs); } /** * @private * @return {?} */ checkDatatableSetting() { if (!this.datatableSetting) { throw new Error('please set up the datatableSetting property'); } } } DatatableComponent.decorators = [ { type: Component, args: [{ selector: 'cdt-datatable', template: "<table *ngIf=\"datatableSetting\" [class]=\"className\">\n <thead>\n <tr>\n <th *ngIf=\"isShowCheckbox\">\n <input type=\"checkbox\" \n [checked]=\" headerChecked\"\n (change)=\"headerCheckIt($event)\">\n </th>\n <th *ngIf=\"isShowRowNumber\">#</th>\n <th [ngClass]=\"{'d-none': !item.isEnabled}\" *ngFor=\"let item of datatableSetting.headers\">\n <cdt-btn-sort [info]=\"item\" (clickLink)=\"changeSort($event)\"></cdt-btn-sort>\n </th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let row of rows; let i=index\">\n\n <td *ngIf=\"isShowCheckbox\">\n <input type=\"checkbox\" \n [checked]=\"!!row.cbk__checked\" \n (change)=\"row.cbk__checked=!row.cbk__checked;rowCheckIt($event, row)\">\n </td>\n\n <td *ngIf=\"isShowRowNumber\"><span>{{i+1}}</span></td>\n\n <ng-container *ngFor=\"let column of row.columns\">\n <td *ngIf=\"column.isHtml\" [innerHTML]=\"column.content\"></td>\n <td *ngIf=\"!column.isHtml\" [innerText]=\"column.content\"></td>\n </ng-container>\n\n <td>\n <ng-container *ngTemplateOutlet=\"rowTmpl, context: { $implicit: row }\"></ng-container>\n </td>\n\n </tr>\n </tbody>\n <tfoot>\n <tr *ngFor=\"let row of footers\">\n <th *ngIf=\"isShowCheckbox\">\n </th>\n <th *ngIf=\"isShowRowNumber\"></th>\n <ng-container *ngFor=\"let column of row.columns\">\n <td>{{column.content}}</td>\n </ng-container>\n <th>\n </th>\n </tr>\n </tfoot>\n</table>", styles: [""] }] } ]; /** @nocollapse */ DatatableComponent.ctorParameters = () => []; DatatableComponent.propDecorators = { rowTmpl: [{ type: ContentChild, args: ['rowCommand', { static: true },] }], isShowCheckbox: [{ type: Input }], isShowRowNumber: [{ type: Input }], className: [{ type: Input }], datatableSetting: [{ type: Input }], data: [{ type: Input }], sortCommand: [{ type: Output }], checkRowCommand: [{ type: Output }] }; if (false) { /** @type {?} */ DatatableComponent.prototype.rowTmpl; /** @type {?} */ DatatableComponent.prototype.isShowCheckbox; /** @type {?} */ DatatableComponent.prototype.isShowRowNumber; /** @type {?} */ DatatableComponent.prototype.className; /** @type {?} */ DatatableComponent.prototype.sortCommand; /** @type {?} */ DatatableComponent.prototype.checkRowCommand; /** * @type {?} * @private */ DatatableComponent.prototype.sub; /** * @type {?} * @private */ DatatableComponent.prototype.datatableSetting$; /** * @type {?} * @private */ DatatableComponent.prototype.data$; /** @type {?} */ DatatableComponent.prototype.rows; /** @type {?} */ DatatableComponent.prototype.footers; /** @type {?} */ DatatableComponent.prototype.headerChecked; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable.component.js","sourceRoot":"ng://ngx-config-datatable/","sources":["lib/datatable/components/datatable.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, Input, OnDestroy, Output, TemplateRef } from '@angular/core';\nimport { BehaviorSubject, combineLatest, Subscription } from 'rxjs';\nimport { filter } from 'rxjs/operators';\nimport { IDatatableSetting } from '../interface/IDatatableSetting';\nimport { IHeader } from '../interface/IHeader';\nimport { IIdObject } from '../interface/IIdObject';\nimport { IRow } from '../interface/IRow';\n\n@Component({\n  selector: 'cdt-datatable',\n  templateUrl: './datatable.component.html',\n  styleUrls: ['./datatable.component.scss']\n})\nexport class DatatableComponent implements OnDestroy {\n\n  @ContentChild('rowCommand', { static: true }) rowTmpl: TemplateRef<any>;\n\n  @Input() isShowCheckbox = true;\n  @Input() isShowRowNumber = true;\n\n  @Input() className = '';\n  @Input()\n  set datatableSetting(v: IDatatableSetting) {\n    this.datatableSetting$.next(v);\n  }\n  get datatableSetting() {\n    return this.datatableSetting$.getValue();\n  }\n  @Input()\n  set data(v: IIdObject[]) {\n    this.data$.next(v);\n  }\n  get data() {\n    return this.data$.getValue();\n  }\n  @Output() sortCommand = new EventEmitter<IHeader>();\n  @Output() checkRowCommand = new EventEmitter<string[]>();\n\n  private sub = new Subscription();\n  private datatableSetting$ = new BehaviorSubject<IDatatableSetting>(null);\n  private data$ = new BehaviorSubject<IIdObject[]>([]);\n\n  rows: IRow[] = [];\n  footers: IRow[] = [];\n  headerChecked = false;\n\n  constructor() {\n    this.sub.add(combineLatest(\n      this.datatableSetting$,\n      this.data$\n    ).pipe(\n      filter(([datatableSetting, data]) => datatableSetting ? true : false)\n    ).subscribe(([datatableSetting, data]) => {\n      this.render();\n    }));\n  }\n\n  ngOnDestroy(): void {\n    this.sub.unsubscribe();\n  }\n\n  private render() {\n    this.rows = [];\n    this.footers = [];\n\n    this.addRows();\n    this.addSummaryRow();\n  }\n\n  changeSort(sortInfo: IHeader) {\n    for (const item of this.datatableSetting.headers) {\n      if (item.propName !== sortInfo.propName) {\n        item.sort = 'none';\n      } else {\n        item.sort = sortInfo.sort;\n      }\n    }\n    this.sortCommand.emit(sortInfo);\n  }\n\n  headerCheckIt(event: Event) {\n    event.preventDefault();\n    this.headerChecked = !this.headerChecked;\n\n    for (const row of this.rows) {\n      // tslint:disable-next-line:no-string-literal\n      row['cbk__checked'] = this.headerChecked;\n    }\n    this.checkAllCheckbox();\n  }\n\n  rowCheckIt(event: Event, row) {\n    event.preventDefault();\n    this.checkAllCheckbox();\n  }\n\n  private checkAllCheckbox() {\n    // tslint:disable-next-line:no-string-literal\n    this.headerChecked = !this.rows.some(a => !a['cbk__checked']);\n\n    // tslint:disable-next-line:no-string-literal\n    const ids = this.rows.filter(a => !!a['cbk__checked']).map(a => a.id);\n    this.checkRowCommand.emit(ids);\n  }\n\n  private addRows() {\n    this.checkDatatableSetting();\n\n    for (const row of this.data) {\n      const cs: IRow = {\n        id: row.id,\n        rowData: row,\n        columns: []\n      };\n      for (const item of this.datatableSetting.headers) {\n        if (!item.isEnabled) {\n          continue;\n        }\n        let vv = row[item.propName];\n        if (item.converter) {\n          vv = item.converter.to(vv);\n        }\n        cs.columns.push({\n          isHtml: item.isHtml,\n          content: vv\n        });\n      }\n      this.rows.push(cs);\n    }\n  }\n\n  private addSummaryRow() {\n    this.checkDatatableSetting();\n\n    const fs: IRow = {\n      id: '',\n      rowData: { id: '' },\n      columns: []\n    };\n    if (!this.datatableSetting.headers.some(a => a.isSum)) {\n      return;\n    }\n    for (const item of this.datatableSetting.headers) {\n      if (!item.isEnabled) {\n        continue;\n      }\n      if (!item.isSum) {\n        fs.columns.push({\n          isHtml: item.isHtml,\n          content: ''\n        });\n        continue;\n      }\n\n      let tTotal = 0;\n      for (const row of this.data) {\n        const vv = row[item.propName];\n        tTotal += +vv;\n      }\n      if (item.converter) {\n        tTotal = item.converter.to(tTotal);\n      }\n      fs.columns.push({\n        isHtml: item.isHtml,\n        content: tTotal\n      });\n    }\n    this.footers.push(fs);\n  }\n\n  private checkDatatableSetting() {\n    if (!this.datatableSetting) {\n      throw new Error('please set up the datatableSetting property');\n    }\n  }\n\n}\n"]}