ngx-config-datatable
Version:
use configuration to generate datatable
393 lines • 26.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core';
import { BehaviorSubject, combineLatest, Subscription } from 'rxjs';
import { filter } from 'rxjs/operators';
var DatatableComponent = /** @class */ (function () {
function DatatableComponent() {
var _this = this;
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 {?}
*/
function (_a) {
var _b = tslib_1.__read(_a, 2), datatableSetting = _b[0], data = _b[1];
return datatableSetting ? true : false;
}))).subscribe((/**
* @param {?} __0
* @return {?}
*/
function (_a) {
var _b = tslib_1.__read(_a, 2), datatableSetting = _b[0], data = _b[1];
_this.render();
})));
}
Object.defineProperty(DatatableComponent.prototype, "datatableSetting", {
get: /**
* @return {?}
*/
function () {
return this.datatableSetting$.getValue();
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this.datatableSetting$.next(v);
},
enumerable: true,
configurable: true
});
Object.defineProperty(DatatableComponent.prototype, "data", {
get: /**
* @return {?}
*/
function () {
return this.data$.getValue();
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this.data$.next(v);
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
DatatableComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.sub.unsubscribe();
};
/**
* @private
* @return {?}
*/
DatatableComponent.prototype.render = /**
* @private
* @return {?}
*/
function () {
this.rows = [];
this.footers = [];
this.addRows();
this.addSummaryRow();
};
/**
* @param {?} sortInfo
* @return {?}
*/
DatatableComponent.prototype.changeSort = /**
* @param {?} sortInfo
* @return {?}
*/
function (sortInfo) {
var e_1, _a;
try {
for (var _b = tslib_1.__values(this.datatableSetting.headers), _c = _b.next(); !_c.done; _c = _b.next()) {
var item = _c.value;
if (item.propName !== sortInfo.propName) {
item.sort = 'none';
}
else {
item.sort = sortInfo.sort;
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this.sortCommand.emit(sortInfo);
};
/**
* @param {?} event
* @return {?}
*/
DatatableComponent.prototype.headerCheckIt = /**
* @param {?} event
* @return {?}
*/
function (event) {
var e_2, _a;
event.preventDefault();
this.headerChecked = !this.headerChecked;
try {
for (var _b = tslib_1.__values(this.rows), _c = _b.next(); !_c.done; _c = _b.next()) {
var row = _c.value;
// tslint:disable-next-line:no-string-literal
row['cbk__checked'] = this.headerChecked;
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
this.checkAllCheckbox();
};
/**
* @param {?} event
* @param {?} row
* @return {?}
*/
DatatableComponent.prototype.rowCheckIt = /**
* @param {?} event
* @param {?} row
* @return {?}
*/
function (event, row) {
event.preventDefault();
this.checkAllCheckbox();
};
/**
* @private
* @return {?}
*/
DatatableComponent.prototype.checkAllCheckbox = /**
* @private
* @return {?}
*/
function () {
// tslint:disable-next-line:no-string-literal
this.headerChecked = !this.rows.some((/**
* @param {?} a
* @return {?}
*/
function (a) { return !a['cbk__checked']; }));
// tslint:disable-next-line:no-string-literal
/** @type {?} */
var ids = this.rows.filter((/**
* @param {?} a
* @return {?}
*/
function (a) { return !!a['cbk__checked']; })).map((/**
* @param {?} a
* @return {?}
*/
function (a) { return a.id; }));
this.checkRowCommand.emit(ids);
};
/**
* @private
* @return {?}
*/
DatatableComponent.prototype.addRows = /**
* @private
* @return {?}
*/
function () {
var e_3, _a, e_4, _b;
this.checkDatatableSetting();
try {
for (var _c = tslib_1.__values(this.data), _d = _c.next(); !_d.done; _d = _c.next()) {
var row = _d.value;
/** @type {?} */
var cs = {
id: row.id,
rowData: row,
columns: []
};
try {
for (var _e = tslib_1.__values(this.datatableSetting.headers), _f = _e.next(); !_f.done; _f = _e.next()) {
var item = _f.value;
if (!item.isEnabled) {
continue;
}
/** @type {?} */
var vv = row[item.propName];
if (item.converter) {
vv = item.converter.to(vv);
}
cs.columns.push({
isHtml: item.isHtml,
content: vv
});
}
}
catch (e_4_1) { e_4 = { error: e_4_1 }; }
finally {
try {
if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
}
finally { if (e_4) throw e_4.error; }
}
this.rows.push(cs);
}
}
catch (e_3_1) { e_3 = { error: e_3_1 }; }
finally {
try {
if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
}
finally { if (e_3) throw e_3.error; }
}
};
/**
* @private
* @return {?}
*/
DatatableComponent.prototype.addSummaryRow = /**
* @private
* @return {?}
*/
function () {
var e_5, _a, e_6, _b;
this.checkDatatableSetting();
/** @type {?} */
var fs = {
id: '',
rowData: { id: '' },
columns: []
};
if (!this.datatableSetting.headers.some((/**
* @param {?} a
* @return {?}
*/
function (a) { return a.isSum; }))) {
return;
}
try {
for (var _c = tslib_1.__values(this.datatableSetting.headers), _d = _c.next(); !_d.done; _d = _c.next()) {
var item = _d.value;
if (!item.isEnabled) {
continue;
}
if (!item.isSum) {
fs.columns.push({
isHtml: item.isHtml,
content: ''
});
continue;
}
/** @type {?} */
var tTotal = 0;
try {
for (var _e = tslib_1.__values(this.data), _f = _e.next(); !_f.done; _f = _e.next()) {
var row = _f.value;
/** @type {?} */
var vv = row[item.propName];
tTotal += +vv;
}
}
catch (e_6_1) { e_6 = { error: e_6_1 }; }
finally {
try {
if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
}
finally { if (e_6) throw e_6.error; }
}
if (item.converter) {
tTotal = item.converter.to(tTotal);
}
fs.columns.push({
isHtml: item.isHtml,
content: tTotal
});
}
}
catch (e_5_1) { e_5 = { error: e_5_1 }; }
finally {
try {
if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
}
finally { if (e_5) throw e_5.error; }
}
this.footers.push(fs);
};
/**
* @private
* @return {?}
*/
DatatableComponent.prototype.checkDatatableSetting = /**
* @private
* @return {?}
*/
function () {
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 = function () { return []; };
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 }]
};
return DatatableComponent;
}());
export { DatatableComponent };
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"]}