ngx-material-dynamic-table
Version:
Componente angular dinâmico que ajuda a criar uma tabela utilizando o Angular material, de maneira fácil e rápida.
128 lines • 14.8 kB
JavaScript
import { __decorate, __read, __spread } from "tslib";
import { Component, ViewChild, EventEmitter, Output, Input, } from '@angular/core';
import { MatTableDataSource, MatTable } from '@angular/material/table';
import { MatPaginator } from '@angular/material/paginator';
import { MatSort } from '@angular/material/sort';
export var buttonsConfig = {
read: {
icon: 'search',
name: 'read',
tooltip: 'Visualizar',
},
update: {
icon: 'edit',
name: 'edit',
tooltip: 'Editar',
},
delete: {
icon: 'delete',
name: 'delete',
tooltip: 'Excluir',
},
download: {
icon: 'arrow_downward',
name: 'download',
tooltip: 'Download',
},
};
var NgxMaterialDynamicTableComponent = /** @class */ (function () {
function NgxMaterialDynamicTableComponent() {
this.displayedColumns = [];
this.filter = true;
this.buttonAddNewItem = false;
this.buttonExport = false;
this.buttonsConfig = buttonsConfig;
this.sendClick = new EventEmitter();
this.loading = true;
this.action = false;
this.displayedColumnsObject = [];
}
NgxMaterialDynamicTableComponent.prototype.ngOnChanges = function () {
if (this.displayedColumns) {
this.addActionColumn();
}
if (this.dataSource) {
this.createDatasource();
}
};
NgxMaterialDynamicTableComponent.prototype.createDatasource = function () {
this.dados = new MatTableDataSource(this.dataSource);
this.dados.paginator = this.paginator;
this.dados.sort = this.sort;
this.showTable();
};
NgxMaterialDynamicTableComponent.prototype.createColumns = function () {
this.displayedColumnsObject = this.displayedColumns.map(function (col) {
return typeof col.column === 'number' ? col.column.toString() : col.column;
});
this.showTable();
};
NgxMaterialDynamicTableComponent.prototype.showTable = function () {
if (this.dados && this.displayedColumns && this.displayedColumnsObject) {
this.loading = false;
}
};
NgxMaterialDynamicTableComponent.prototype.sendAction = function (action, row, index) {
var content = { action: action, row: row, index: index };
this.sendClick.emit(content);
};
NgxMaterialDynamicTableComponent.prototype.addActionColumn = function () {
if (this.actions) {
var columnAction = { column: 'actions', title: 'Ações' };
this.displayedColumns = __spread(this.displayedColumns, [columnAction]);
}
this.createColumns();
};
NgxMaterialDynamicTableComponent.prototype.applyFilter = function (filterValue) {
this.dados.filter = filterValue.trim().toLowerCase();
};
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "dataSource", void 0);
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "displayedColumns", void 0);
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "actions", void 0);
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "configEditRow", void 0);
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "filter", void 0);
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "buttonAddNewItem", void 0);
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "buttonExport", void 0);
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "componentName", void 0);
__decorate([
Input()
], NgxMaterialDynamicTableComponent.prototype, "buttonsConfig", void 0);
__decorate([
Output()
], NgxMaterialDynamicTableComponent.prototype, "sendClick", void 0);
__decorate([
ViewChild(MatTable, { static: true })
], NgxMaterialDynamicTableComponent.prototype, "table", void 0);
__decorate([
ViewChild(MatPaginator, { static: true })
], NgxMaterialDynamicTableComponent.prototype, "paginator", void 0);
__decorate([
ViewChild(MatSort, { static: true })
], NgxMaterialDynamicTableComponent.prototype, "sort", void 0);
NgxMaterialDynamicTableComponent = __decorate([
Component({
selector: 'ngx-material-dynamic-table',
template: "\r\n\r\n <mat-form-field class=\"pesquisa\" *ngIf=\"filter\">\r\n <span matPrefix>\r\n <i class=\"material-icons\">search</i>\r\n <input type=\"text\" matInput (keyup)=\"applyFilter($event.target.value)\" placelholder=\"Filtrar\">\r\n </span>\r\n </mat-form-field>\r\n <mat-table #table [dataSource]=\"dados\" [hidden]=\"loading || !dados || !displayedColumns || !displayedColumnsObject\">\r\n\r\n <ng-container *ngFor=\"let disCol of displayedColumns; let colIndex = index\" matColumnDef=\"{{disCol.column}}\">\r\n <th mat-header-cell *matHeaderCellDef> {{disCol.title}} </th>\r\n <td mat-cell *matCellDef=\"let element\">\r\n <span *ngIf=\"disCol.column !== 'actions'; else blockActions\">\r\n {{element[disCol.column]}}\r\n </span>\r\n <ng-template #blockActions>\r\n <div class=\"actionsList\">\r\n <span *ngFor=\"let action of actions\">\r\n <a (click)=\"sendAction(action)\" matTooltip=\"{{buttonsConfig[action.column].tooltip}}\">\r\n <i class=\"material-icons\">{{buttonsConfig[action.column].icon}}</i>\r\n </a>\r\n </span>\r\n </div>\r\n </ng-template>\r\n </td>\r\n </ng-container>\r\n\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsObject\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayedColumnsObject;\"></tr>\r\n </mat-table>\r\n <div *ngIf=\"dados && dados.filteredData && dados.filteredData.length === 0\">\r\n <p>Nenhum registro encontrado</p>\r\n </div>\r\n <mat-paginator [hidden]=\"dados === undefined\" [pageSizeOptions]=\"[5,10,20]\" showFirstLastButtons></mat-paginator>\r\n",
styles: ["[hidden]{display:none}.actionsList{display:flex;align-items:center}.actionsList span+span{margin-left:10px}.mat-table{width:100%;display:table}.mat-table tr.mat-header-row{height:auto}.mat-form-field,.pesquisa{width:100%}"]
})
], NgxMaterialDynamicTableComponent);
return NgxMaterialDynamicTableComponent;
}());
export { NgxMaterialDynamicTableComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-material-dynamic-table.component.js","sourceRoot":"ng://ngx-material-dynamic-table/","sources":["lib/ngx-material-dynamic-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  EventEmitter,\r\n  Output,\r\n  Input,\r\n  OnChanges,\r\n} from '@angular/core';\r\nimport { MatTableDataSource, MatTable } from '@angular/material/table';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { MatSort } from '@angular/material/sort';\r\nexport const buttonsConfig = {\r\n  read: {\r\n    icon: 'search',\r\n    name: 'read',\r\n    tooltip: 'Visualizar',\r\n  },\r\n  update: {\r\n    icon: 'edit',\r\n    name: 'edit',\r\n    tooltip: 'Editar',\r\n  },\r\n  delete: {\r\n    icon: 'delete',\r\n    name: 'delete',\r\n    tooltip: 'Excluir',\r\n  },\r\n  download: {\r\n    icon: 'arrow_downward',\r\n    name: 'download',\r\n    tooltip: 'Download',\r\n  },\r\n};\r\n@Component({\r\n  selector: 'ngx-material-dynamic-table',\r\n  templateUrl: './ngx-material-dynamic-table.component.html',\r\n  styleUrls: ['./ngx-material-dynamic-table.component.scss'],\r\n})\r\nexport class NgxMaterialDynamicTableComponent implements OnChanges {\r\n  @Input() dataSource;\r\n  @Input() displayedColumns = [];\r\n  @Input() actions;\r\n  @Input() configEditRow;\r\n  @Input() filter = true;\r\n  @Input() buttonAddNewItem = false;\r\n  @Input() buttonExport = false;\r\n  @Input() componentName;\r\n\r\n  @Input() buttonsConfig = buttonsConfig;\r\n\r\n  @Output() sendClick = new EventEmitter();\r\n\r\n  @ViewChild(MatTable, { static: true }) table: MatTable<any>;\r\n  @ViewChild(MatPaginator, { static: true }) paginator: MatPaginator;\r\n  @ViewChild(MatSort, { static: true }) sort: MatTable<any>;\r\n\r\n  public loading = true;\r\n  public action = false;\r\n  public displayedColumnsObject: any[] = [];\r\n  public dados;\r\n\r\n  constructor() {}\r\n\r\n  ngOnChanges(): void {\r\n    if (this.displayedColumns) {\r\n      this.addActionColumn();\r\n    }\r\n    if (this.dataSource) {\r\n      this.createDatasource();\r\n    }\r\n  }\r\n\r\n  createDatasource() {\r\n    this.dados = new MatTableDataSource<any>(this.dataSource);\r\n    this.dados.paginator = this.paginator;\r\n    this.dados.sort = this.sort;\r\n    this.showTable();\r\n  }\r\n\r\n  createColumns() {\r\n    this.displayedColumnsObject = this.displayedColumns.map((col) =>\r\n      typeof col.column === 'number' ? col.column.toString() : col.column\r\n    );\r\n    this.showTable();\r\n  }\r\n\r\n  showTable() {\r\n    if (this.dados && this.displayedColumns && this.displayedColumnsObject) {\r\n      this.loading = false;\r\n    }\r\n  }\r\n  sendAction(action, row?, index?) {\r\n    const content: any = { action, row, index };\r\n    this.sendClick.emit(content);\r\n  }\r\n  addActionColumn() {\r\n    if (this.actions) {\r\n      const columnAction = { column: 'actions', title: 'Ações' };\r\n      this.displayedColumns = [...this.displayedColumns, columnAction];\r\n    }\r\n    this.createColumns();\r\n  }\r\n  applyFilter(filterValue: string) {\r\n    this.dados.filter = filterValue.trim().toLowerCase();\r\n  }\r\n}\r\n"]}