angular-json-table
Version:
Angular JSON Table is an Angular 2+ module to populate tables from the JSON data provided
240 lines (239 loc) • 19.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { Component, EventEmitter, Input, Output } from '@angular/core';
var DataTableComponent = /** @class */ (function () {
function DataTableComponent() {
this.deleteRow = new EventEmitter();
this.updateRow = new EventEmitter();
this.data = {};
this.displayed = [];
this.perpage = 10;
this.page = 1;
this.checked = [];
this.checkAll = false;
this.dialogue = false;
this.dialogeData = {};
}
/**
* @return {?}
*/
DataTableComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.processData();
};
/**
* @param {?} e
* @param {?} id
* @return {?}
*/
DataTableComponent.prototype.selected = /**
* @param {?} e
* @param {?} id
* @return {?}
*/
function (e, id) {
if (e.target.checked) {
this.checked.push(id);
}
};
/**
* @return {?}
*/
DataTableComponent.prototype.deleteSelected = /**
* @return {?}
*/
function () {
var _this = this;
if (this.checked.length > 0) {
this.deleteRow.emit(this.checked);
this.dataSource = this.dataSource.filter(function (value, index, array) {
return !_this.checked.includes(value.id);
});
this.checked = [];
this.paginate(this.page);
}
};
/**
* @return {?}
*/
DataTableComponent.prototype.totalItems = /**
* @return {?}
*/
function () {
if (this.total > this.perpage) {
return Math.ceil(this.total / this.perpage);
}
else {
return 1;
}
};
/**
* @param {?} page
* @return {?}
*/
DataTableComponent.prototype.paginate = /**
* @param {?} page
* @return {?}
*/
function (page) {
/** @type {?} */
var start = (this.perpage * page) - this.perpage;
/** @type {?} */
var end = (this.perpage * page);
// console.log(start, end);
this.data['data'] = this.dataSource.slice(start, end);
// console.log(this.data);
};
/**
* @param {?} perPage
* @return {?}
*/
DataTableComponent.prototype.pageOnChange = /**
* @param {?} perPage
* @return {?}
*/
function (perPage) {
this.perpage = perPage;
this.page = 1;
//console.log(perPage);
this.paginate(this.page);
};
/**
* @return {?}
*/
DataTableComponent.prototype.previousPage = /**
* @return {?}
*/
function () {
if (this.page > 1) {
this.page--;
}
this.paginate(this.page);
};
/**
* @return {?}
*/
DataTableComponent.prototype.nextPage = /**
* @return {?}
*/
function () {
if (this.page + 1 <= this.totalItems()) {
this.page++;
}
this.paginate(this.page);
};
/**
* @param {?} id
* @return {?}
*/
DataTableComponent.prototype.showUpdate = /**
* @param {?} id
* @return {?}
*/
function (id) {
var _this = this;
this.dialogue = true;
// console.log('Showing the updates');
this.data.data.forEach(function (value) {
if (value.id === id) {
_this.dialogeData = value;
}
});
};
/**
* @return {?}
*/
DataTableComponent.prototype.closeDialogue = /**
* @return {?}
*/
function () {
this.dialogue ? this.dialogue = false : this.dialogue = true;
this.dialogeData = {};
};
/**
* @param {?} dialogeData
* @return {?}
*/
DataTableComponent.prototype.submitUpdateRow = /**
* @param {?} dialogeData
* @return {?}
*/
function (dialogeData) {
this.updateRow.emit(dialogeData);
};
/**
* @return {?}
*/
DataTableComponent.prototype.processData = /**
* @return {?}
*/
function () {
if (this.dataSource && this.dataSource.length > 0) {
this.total = this.dataSource.length;
if (this.headers.thead && this.headers.thead.length > 0) {
this.data['headers'] = this.headers.thead;
this.displayed = this.headers.displayed;
}
else {
console.warn('No headers data for table provided');
}
this.paginate(this.page);
}
else {
console.warn('No data for table provided');
}
};
DataTableComponent.decorators = [
{ type: Component, args: [{
selector: 'json-table',
template: "<div *ngIf=\"data\" class=\"data-table\">\n <div *ngIf=\"false\">\n <input type=\"text\" class=\"search\" placeholder=\"Search for details\">\n </div>\n <table>\n <thead>\n <tr>\n <th style=\"width: 4%\"> </th>\n <th style=\"width: 4%\">#</th>\n <th *ngFor=\"let header of data.headers\" style=\"text-align:left\">{{header}}</th>\n <th *ngIf=\"update\"> </th>\n </tr>\n </thead>\n <tbody>\n\n <tr *ngFor=\"let row of data.data; let i = index\">\n <td><input type=\"checkbox\" [checked]=\"checkAll\" (change)=\"selected($event,row.id)\"></td>\n <td>{{ i+1 }}</td>\n <td *ngFor=\"let attr of displayed\" >{{row[attr]}}</td>\n <td *ngIf=\"update\" style=\"text-align:center\">\n <span (click)=\"showUpdate(row.id)\">\uD83D\uDD89</span>\n </td>\n </tr>\n\n </tbody>\n <tfoot></tfoot>\n </table>\n\n <div class=\"footer\">\n <div class=\"delete\">\n <button (click)=\"deleteSelected()\">Delete {{checked.length}} rows</button>\n </div>\n\n <div class=\"spacer\">\n\n </div>\n\n <div class=\"data-pagination\">\n <select (change)=\"pageOnChange(device.value)\" #device>\n <option value=\"10\">10</option>\n <option value=\"15\">15</option>\n <option value=\"20\">20</option>\n <option value=\"100\">100</option>\n </select>\n | Showing {{page}} of {{totalItems()}} |\n <button class=\"link-button\" (click)=\"previousPage()\">Previous</button>\n -\n <button class=\"link-button\" (click)=\"nextPage()\">Next</button>\n </div>\n </div>\n\n\n <div *ngIf=\"update && dialogue\" class=\"update\" (click)=\"closeDialogue()\">\n\n <div class=\"update-box\" (click)=\"$event.stopPropagation()\">\n <h2>Edit the Row</h2>\n <form #customForm=\"ngForm\" novalidate (ngSubmit)=\"submitUpdateRow(dialogeData); closeDialogue()\">\n <div class=\"f-x\">\n <ng-container *ngFor=\"let attr of displayed; let i = index\">\n <div *ngIf=\"attr!='id' \" class=\"f-y\">\n <label>{{data.headers[i]}}</label>\n <input type=\"text\" [value]=\"dialogeData[attr]\" [placeholder]=\"attr\" [name]=\"attr\"\n [(ngModel)]=\"dialogeData[attr]\">\n </div>\n </ng-container>\n </div>\n <footer>\n <br>\n <button type=\"submit\">Update the row</button>\n <button type=\"button\" (click)=\"closeDialogue()\">Cancel</button>\n </footer>\n </form>\n </div>\n </div>\n\n</div>\n",
styles: [".data-table{box-shadow:0 5px 5px -3px rgba(0,0,0,.2),0 8px 10px 1px rgba(0,0,0,.14),0 3px 14px 2px rgba(0,0,0,.12);margin:10px;border-radius:8px;background:#fff;padding-top:8px}.data-table .search{width:100%;height:42px;border:none;outline:0;text-align:left;border-bottom:1px solid rgba(0,0,0,.12)}.data-table table{display:table;border-collapse:separate;border-spacing:2px;border-color:grey;width:100%;background:#fff}.data-table table tbody td:first-of-type,.data-table table tbody th:first-of-type,.data-table table thead td:first-of-type,.data-table table thead th:first-of-type{padding-left:24px!important;padding-right:24px!important}.data-table table thead{display:table-header-group;vertical-align:middle;border-color:inherit}.data-table table thead tr{height:56px}.data-table table tbody{display:table-row-group;vertical-align:middle;border-color:inherit}.data-table table tbody tr{height:48px;color:rgba(0,0,0,.87)}.data-table table th{padding:0;color:rgba(0,0,0,.54);border-bottom:1px solid rgba(0,0,0,.12)}.data-table table tfoot{display:table-footer-group;vertical-align:middle;border-color:inherit}.data-table .footer{display:flex;height:40px;border-top:1px solid rgba(0,0,0,.12)}.data-table .footer .spacer{flex-grow:1}.data-table .footer .delete{width:120px;background:0 0}.data-table .footer .delete button{height:80%;background:0 0;border:none;outline:0;cursor:pointer;transition:.25s linear;border-radius:4px;margin-left:5px;margin-top:4px}.data-table .footer .delete button:hover{background-color:#fbab33;color:#fff}.data-table .footer .data-pagination{padding-right:20px;padding-top:4px}.data-table .footer .data-pagination select{outline:0;background:0 0;padding:4px}.data-table .footer .data-pagination .link-button{border:none;outline:0;background:0 0}.data-table .footer .data-pagination .link-button:hover{text-decoration:underline}.data-table .update{transition:.5s linear;position:fixed;height:100vh;width:100vw;background:rgba(212,212,212,.51);top:0;left:0;display:flex;align-items:center;justify-content:center}.data-table .update .update-box{box-shadow:0 5px 5px -3px rgba(0,0,0,.2),0 8px 10px 1px rgba(0,0,0,.14),0 3px 14px 2px rgba(0,0,0,.12);background:#fff;padding:8px;border-radius:4px;width:250px}.data-table .update .f-x{display:flex;flex-direction:column}.data-table .update .f-y{display:flex;flex-direction:column;margin-top:6px}.data-table .update input[type=text]{margin-right:4px;padding:4px}"]
}] }
];
/** @nocollapse */
DataTableComponent.ctorParameters = function () { return []; };
DataTableComponent.propDecorators = {
dataSource: [{ type: Input }],
headers: [{ type: Input }],
update: [{ type: Input }],
deleteRow: [{ type: Output }],
updateRow: [{ type: Output }]
};
return DataTableComponent;
}());
export { DataTableComponent };
if (false) {
/** @type {?} */
DataTableComponent.prototype.dataSource;
/** @type {?} */
DataTableComponent.prototype.headers;
/** @type {?} */
DataTableComponent.prototype.update;
/** @type {?} */
DataTableComponent.prototype.deleteRow;
/** @type {?} */
DataTableComponent.prototype.updateRow;
/** @type {?} */
DataTableComponent.prototype.data;
/** @type {?} */
DataTableComponent.prototype.displayed;
/** @type {?} */
DataTableComponent.prototype.perpage;
/** @type {?} */
DataTableComponent.prototype.total;
/** @type {?} */
DataTableComponent.prototype.page;
/** @type {?} */
DataTableComponent.prototype.checked;
/** @type {?} */
DataTableComponent.prototype.checkAll;
/** @type {?} */
DataTableComponent.prototype.dialogue;
/** @type {?} */
DataTableComponent.prototype.dialogeData;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"ng://angular-json-table/","sources":["src/app/modules/data-table/data-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnInit, Output} from '@angular/core';\n\n@Component({\n  selector: 'json-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss']\n})\nexport class DataTableComponent implements OnInit {\n\n  @Input() dataSource: any;\n  @Input() headers: any;\n  @Input() update: boolean;\n\n  @Output() deleteRow: EventEmitter<any> = new EventEmitter<any>();\n  @Output() updateRow: EventEmitter<any> = new EventEmitter<any>();\n\n  data: any = {};\n\n  displayed = [];\n  perpage = 10;\n  total: number;\n  page = 1;\n\n  checked: any = [];\n  checkAll = false;\n  dialogue = false;\n  dialogeData: any = {};\n\n  constructor() {\n  }\n\n  ngOnInit() {\n    this.processData();\n  }\n\n  selected(e, id) {\n    if (e.target.checked) {\n      this.checked.push(id);\n    }\n  }\n\n  deleteSelected() {\n    if (this.checked.length > 0) {\n      this.deleteRow.emit(this.checked);\n      this.dataSource = this.dataSource.filter((value, index, array) => {\n        return !this.checked.includes(value.id);\n      });\n      this.checked = [];\n      this.paginate(this.page);\n    }\n  }\n\n  totalItems() {\n    if (this.total > this.perpage) {\n      return Math.ceil(this.total / this.perpage);\n    } else {\n      return 1;\n    }\n  }\n\n  paginate(page) {\n    const start = (this.perpage * page) - this.perpage;\n    const end = (this.perpage * page);\n    // console.log(start, end);\n    this.data['data'] = this.dataSource.slice(start, end);\n    // console.log(this.data);\n  }\n\n  pageOnChange(perPage) {\n    this.perpage = perPage;\n    this.page = 1;\n    //console.log(perPage);\n    this.paginate(this.page);\n  }\n\n  previousPage() {\n    if (this.page > 1) {\n      this.page--;\n    }\n\n    this.paginate(this.page);\n  }\n\n  nextPage() {\n    if (this.page + 1 <= this.totalItems()) {\n      this.page++;\n    }\n\n    this.paginate(this.page);\n  }\n\n  showUpdate(id: any) {\n    this.dialogue = true;\n    // console.log('Showing the updates');\n    this.data.data.forEach((value) => {\n      if (value.id === id) {\n        this.dialogeData = value;\n      }\n    });\n\n  }\n\n  closeDialogue() {\n    this.dialogue ? this.dialogue = false : this.dialogue = true;\n    this.dialogeData = {};\n  }\n\n  submitUpdateRow(dialogeData: any) {\n    this.updateRow.emit(dialogeData);\n  }\n\n  private processData() {\n    if (this.dataSource && this.dataSource.length > 0) {\n      this.total = this.dataSource.length;\n\n      if (this.headers.thead && this.headers.thead.length > 0) {\n        this.data['headers'] = this.headers.thead;\n        this.displayed = this.headers.displayed;\n      } else {\n        console.warn('No headers data for table provided');\n      }\n\n      this.paginate(this.page);\n    } else {\n      console.warn('No data for table provided');\n    }\n\n\n  }\n}\n\n"]}