angular-9-datatable
Version:
DataTable component for Angular 9 framework
177 lines • 23.7 kB
JavaScript
import { __decorate, __metadata, __values } from "tslib";
import { Directive, Input, EventEmitter, SimpleChange, OnChanges, DoCheck, IterableDiffers, IterableDiffer, Output } from "@angular/core";
import * as _ from "lodash";
import { ReplaySubject } from "rxjs";
var DataTable = /** @class */ (function () {
function DataTable(differs) {
this.differs = differs;
this.inputData = [];
this.sortBy = "";
this.sortOrder = "asc";
this.sortByChange = new EventEmitter();
this.sortOrderChange = new EventEmitter();
this.rowsOnPage = 1000;
this.activePage = 1;
this.mustRecalculateData = false;
this.onSortChange = new ReplaySubject(1);
this.onPageChange = new EventEmitter();
this.diff = differs.find([]).create(null);
}
DataTable.prototype.getSort = function () {
return { sortBy: this.sortBy, sortOrder: this.sortOrder };
};
DataTable.prototype.setSort = function (sortBy, sortOrder) {
if (this.sortBy !== sortBy || this.sortOrder !== sortOrder) {
this.sortBy = sortBy;
this.sortOrder = _.includes(["asc", "desc"], sortOrder) ? sortOrder : "asc";
this.mustRecalculateData = true;
this.onSortChange.next({ sortBy: sortBy, sortOrder: sortOrder });
this.sortByChange.emit(this.sortBy);
this.sortOrderChange.emit(this.sortOrder);
}
};
DataTable.prototype.getPage = function () {
return { activePage: this.activePage, rowsOnPage: this.rowsOnPage, dataLength: this.inputData.length };
};
DataTable.prototype.setPage = function (activePage, rowsOnPage) {
if (this.rowsOnPage !== rowsOnPage || this.activePage !== activePage) {
this.activePage = this.activePage !== activePage ? activePage : this.calculateNewActivePage(this.rowsOnPage, rowsOnPage);
this.rowsOnPage = rowsOnPage;
this.mustRecalculateData = true;
this.onPageChange.emit({
activePage: this.activePage,
rowsOnPage: this.rowsOnPage,
dataLength: this.inputData ? this.inputData.length : 0
});
}
};
DataTable.prototype.calculateNewActivePage = function (previousRowsOnPage, currentRowsOnPage) {
var firstRowOnPage = (this.activePage - 1) * previousRowsOnPage + 1;
var newActivePage = Math.ceil(firstRowOnPage / currentRowsOnPage);
return newActivePage;
};
DataTable.prototype.recalculatePage = function () {
var lastPage = Math.ceil(this.inputData.length / this.rowsOnPage);
this.activePage = lastPage < this.activePage ? lastPage : this.activePage;
this.activePage = this.activePage || 1;
this.onPageChange.emit({
activePage: this.activePage,
rowsOnPage: this.rowsOnPage,
dataLength: this.inputData.length
});
};
DataTable.prototype.ngOnChanges = function (changes) {
if (changes["rowsOnPage"]) {
this.rowsOnPage = changes["rowsOnPage"].previousValue;
this.setPage(this.activePage, changes["rowsOnPage"].currentValue);
this.mustRecalculateData = true;
}
if (changes["sortBy"] || changes["sortOrder"]) {
if (!_.includes(["asc", "desc"], this.sortOrder)) {
console.warn("angular2-datatable: value for input mfSortOrder must be one of ['asc', 'desc'], but is:", this.sortOrder);
this.sortOrder = "asc";
}
if (this.sortBy) {
this.onSortChange.next({ sortBy: this.sortBy, sortOrder: this.sortOrder });
}
this.mustRecalculateData = true;
}
if (changes["inputData"]) {
this.inputData = changes["inputData"].currentValue || [];
this.recalculatePage();
this.mustRecalculateData = true;
}
};
DataTable.prototype.ngDoCheck = function () {
var changes = this.diff.diff(this.inputData);
if (changes) {
this.recalculatePage();
this.mustRecalculateData = true;
}
if (this.mustRecalculateData) {
this.fillData();
this.mustRecalculateData = false;
}
};
DataTable.prototype.fillData = function () {
this.activePage = this.activePage;
this.rowsOnPage = this.rowsOnPage;
var offset = (this.activePage - 1) * this.rowsOnPage;
var data = this.inputData;
var sortBy = this.sortBy;
if (typeof sortBy === 'string' || sortBy instanceof String) {
data = _.orderBy(data, this.caseInsensitiveIteratee(sortBy), this.sortOrder == 'asc' ? 'asc' : 'desc');
}
else {
data = _.orderBy(data, sortBy, this.sortOrder == 'asc' ? 'asc' : 'desc');
}
data = _.slice(data, offset, offset + this.rowsOnPage);
this.data = data;
};
DataTable.prototype.caseInsensitiveIteratee = function (sortBy) {
return function (row) {
var e_1, _a;
var value = row;
try {
for (var _b = __values(sortBy.split('.')), _c = _b.next(); !_c.done; _c = _b.next()) {
var sortByProperty = _c.value;
if (value) {
value = value[sortByProperty];
}
}
}
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; }
}
if (value && typeof value === 'string' || value instanceof String) {
return value.toLowerCase();
}
return value;
};
};
DataTable.ctorParameters = function () { return [
{ type: IterableDiffers }
]; };
__decorate([
Input("mfData"),
__metadata("design:type", Array)
], DataTable.prototype, "inputData", void 0);
__decorate([
Input("mfSortBy"),
__metadata("design:type", Object)
], DataTable.prototype, "sortBy", void 0);
__decorate([
Input("mfSortOrder"),
__metadata("design:type", Object)
], DataTable.prototype, "sortOrder", void 0);
__decorate([
Output("mfSortByChange"),
__metadata("design:type", Object)
], DataTable.prototype, "sortByChange", void 0);
__decorate([
Output("mfSortOrderChange"),
__metadata("design:type", Object)
], DataTable.prototype, "sortOrderChange", void 0);
__decorate([
Input("mfRowsOnPage"),
__metadata("design:type", Object)
], DataTable.prototype, "rowsOnPage", void 0);
__decorate([
Input("mfActivePage"),
__metadata("design:type", Object)
], DataTable.prototype, "activePage", void 0);
DataTable = __decorate([
Directive({
selector: 'table[mfData]',
exportAs: 'mfDataTable'
}),
__metadata("design:paramtypes", [IterableDiffers])
], DataTable);
return DataTable;
}());
export { DataTable };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.directive.js","sourceRoot":"ng://angular-9-datatable/","sources":["lib/data-table.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Directive, Input, EventEmitter, SimpleChange, OnChanges, DoCheck, IterableDiffers,\r\n    IterableDiffer, Output\r\n} from \"@angular/core\";\r\nimport * as _ from \"lodash\";\r\nimport { ReplaySubject } from \"rxjs\";\r\n\r\nexport interface SortEvent {\r\n    sortBy: string | string[];\r\n    sortOrder: string\r\n}\r\n\r\nexport interface PageEvent {\r\n    activePage: number;\r\n    rowsOnPage: number;\r\n    dataLength: number;\r\n}\r\n\r\nexport interface DataEvent {\r\n    length: number;\r\n}\r\n\r\n@Directive({\r\n    selector: 'table[mfData]',\r\n    exportAs: 'mfDataTable'\r\n})\r\nexport class DataTable implements OnChanges, DoCheck {\r\n\r\n    private diff: IterableDiffer<any>;\r\n    @Input(\"mfData\") public inputData: any[] = [];\r\n\r\n    @Input(\"mfSortBy\") public sortBy: string | string[] = \"\";\r\n    @Input(\"mfSortOrder\") public sortOrder = \"asc\";\r\n    @Output(\"mfSortByChange\") public sortByChange = new EventEmitter<string | string[]>();\r\n    @Output(\"mfSortOrderChange\") public sortOrderChange = new EventEmitter<string>();\r\n\r\n    @Input(\"mfRowsOnPage\") public rowsOnPage = 1000;\r\n    @Input(\"mfActivePage\") public activePage = 1;\r\n\r\n    private mustRecalculateData = false;\r\n\r\n    public data: any[];\r\n\r\n    public onSortChange = new ReplaySubject<SortEvent>(1);\r\n    public onPageChange = new EventEmitter<PageEvent>();\r\n\r\n    public constructor(private differs: IterableDiffers) {\r\n        this.diff = differs.find([]).create(null);\r\n    }\r\n\r\n    public getSort(): SortEvent {\r\n        return { sortBy: this.sortBy, sortOrder: this.sortOrder };\r\n    }\r\n\r\n    public setSort(sortBy: string | string[], sortOrder: string): void {\r\n        if (this.sortBy !== sortBy || this.sortOrder !== sortOrder) {\r\n            this.sortBy = sortBy;\r\n            this.sortOrder = _.includes([\"asc\", \"desc\"], sortOrder) ? sortOrder : \"asc\";\r\n            this.mustRecalculateData = true;\r\n            this.onSortChange.next({ sortBy: sortBy, sortOrder: sortOrder });\r\n            this.sortByChange.emit(this.sortBy);\r\n            this.sortOrderChange.emit(this.sortOrder);\r\n        }\r\n    }\r\n\r\n    public getPage(): PageEvent {\r\n        return { activePage: this.activePage, rowsOnPage: this.rowsOnPage, dataLength: this.inputData.length };\r\n    }\r\n\r\n    public setPage(activePage: number, rowsOnPage: number): void {\r\n        if (this.rowsOnPage !== rowsOnPage || this.activePage !== activePage) {\r\n            this.activePage = this.activePage !== activePage ? activePage : this.calculateNewActivePage(this.rowsOnPage, rowsOnPage);\r\n            this.rowsOnPage = rowsOnPage;\r\n            this.mustRecalculateData = true;\r\n            this.onPageChange.emit({\r\n                activePage: this.activePage,\r\n                rowsOnPage: this.rowsOnPage,\r\n                dataLength: this.inputData ? this.inputData.length : 0\r\n            });\r\n        }\r\n    }\r\n\r\n    private calculateNewActivePage(previousRowsOnPage: number, currentRowsOnPage: number): number {\r\n        let firstRowOnPage = (this.activePage - 1) * previousRowsOnPage + 1;\r\n        let newActivePage = Math.ceil(firstRowOnPage / currentRowsOnPage);\r\n        return newActivePage;\r\n    }\r\n\r\n    private recalculatePage() {\r\n        let lastPage = Math.ceil(this.inputData.length / this.rowsOnPage);\r\n        this.activePage = lastPage < this.activePage ? lastPage : this.activePage;\r\n        this.activePage = this.activePage || 1;\r\n\r\n        this.onPageChange.emit({\r\n            activePage: this.activePage,\r\n            rowsOnPage: this.rowsOnPage,\r\n            dataLength: this.inputData.length\r\n        });\r\n    }\r\n\r\n    public ngOnChanges(changes: { [key: string]: SimpleChange }): any {\r\n        if (changes[\"rowsOnPage\"]) {\r\n            this.rowsOnPage = changes[\"rowsOnPage\"].previousValue;\r\n            this.setPage(this.activePage, changes[\"rowsOnPage\"].currentValue);\r\n            this.mustRecalculateData = true;\r\n        }\r\n        if (changes[\"sortBy\"] || changes[\"sortOrder\"]) {\r\n            if (!_.includes([\"asc\", \"desc\"], this.sortOrder)) {\r\n                console.warn(\"angular2-datatable: value for input mfSortOrder must be one of ['asc', 'desc'], but is:\", this.sortOrder);\r\n                this.sortOrder = \"asc\";\r\n            }\r\n            if (this.sortBy) {\r\n                this.onSortChange.next({ sortBy: this.sortBy, sortOrder: this.sortOrder });\r\n            }\r\n            this.mustRecalculateData = true;\r\n        }\r\n        if (changes[\"inputData\"]) {\r\n            this.inputData = changes[\"inputData\"].currentValue || [];\r\n            this.recalculatePage();\r\n            this.mustRecalculateData = true;\r\n        }\r\n    }\r\n\r\n    public ngDoCheck(): any {\r\n        let changes = this.diff.diff(this.inputData);\r\n        if (changes) {\r\n            this.recalculatePage();\r\n            this.mustRecalculateData = true;\r\n        }\r\n        if (this.mustRecalculateData) {\r\n            this.fillData();\r\n            this.mustRecalculateData = false;\r\n        }\r\n    }\r\n\r\n    private fillData(): void {\r\n        this.activePage = this.activePage;\r\n        this.rowsOnPage = this.rowsOnPage;\r\n\r\n        let offset = (this.activePage - 1) * this.rowsOnPage;\r\n        let data = this.inputData;\r\n        var sortBy = this.sortBy;\r\n        if (typeof sortBy === 'string' || sortBy instanceof String) {\r\n            data = _.orderBy(data, this.caseInsensitiveIteratee(<string>sortBy), this.sortOrder == 'asc' ? 'asc' : 'desc');\r\n        } else {\r\n            data = _.orderBy(data, sortBy, this.sortOrder == 'asc' ? 'asc' : 'desc');\r\n        }\r\n        data = _.slice(data, offset, offset + this.rowsOnPage);\r\n        this.data = data;\r\n    }\r\n\r\n    private caseInsensitiveIteratee(sortBy: string) {\r\n        return (row: any): any => {\r\n            var value = row;\r\n            for (let sortByProperty of sortBy.split('.')) {\r\n                if (value) {\r\n                    value = value[sortByProperty];\r\n                }\r\n            }\r\n            if (value && typeof value === 'string' || value instanceof String) {\r\n                return value.toLowerCase();\r\n            }\r\n            return value;\r\n        };\r\n    }\r\n}"]}