@lucasferreiralsf/angular-frontend-library
Version:
This is a set of custom angular components to easy the development of any Subway frontend project.
406 lines • 33.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, ViewChild, Renderer2 } from '@angular/core';
import { SelectionModel } from '@angular/cdk/collections';
import { MatPaginator } from '@angular/material';
import { DataTableService } from './data-table.service';
import { map } from 'rxjs/operators';
import { PopoverService } from './popover/popover.service';
import { trigger, transition, useAnimation } from '@angular/animations';
import { flipInX, flipOutX } from 'ng-animate';
/**
* @record
*/
export function DataTableColumnNamesInterface() { }
if (false) {
/** @type {?} */
DataTableColumnNamesInterface.prototype.columnNameApi;
/** @type {?} */
DataTableColumnNamesInterface.prototype.displayName;
}
/**
* @record
*/
export function DataTableInputDataInterface() { }
if (false) {
/** @type {?} */
DataTableInputDataInterface.prototype.id;
/** @type {?} */
DataTableInputDataInterface.prototype.actions;
}
/**
* @record
*/
export function DataTableActionsInterface() { }
if (false) {
/** @type {?} */
DataTableActionsInterface.prototype.actionName;
/** @type {?} */
DataTableActionsInterface.prototype.actionDescription;
/** @type {?} */
DataTableActionsInterface.prototype.actionIcon;
/** @type {?} */
DataTableActionsInterface.prototype.actionFunction;
/** @type {?|undefined} */
DataTableActionsInterface.prototype.isDelete;
/** @type {?|undefined} */
DataTableActionsInterface.prototype.isDeleteTitle;
/** @type {?|undefined} */
DataTableActionsInterface.prototype.isDeleteDescription;
}
/**
* @record
*/
export function DataTableTopActionButtonInterface() { }
if (false) {
/** @type {?} */
DataTableTopActionButtonInterface.prototype.actionName;
/** @type {?} */
DataTableTopActionButtonInterface.prototype.eventSlug;
/** @type {?} */
DataTableTopActionButtonInterface.prototype.buttonType;
/** @type {?|undefined} */
DataTableTopActionButtonInterface.prototype.buttonColor;
}
var DataTableComponent = /** @class */ (function () {
function DataTableComponent(dataTableService, popoverService, renderer) {
this.dataTableService = dataTableService;
this.popoverService = popoverService;
this.renderer = renderer;
this.selectColumn = false;
this.columnNames = [];
this.actions = [];
this.inputData = [];
this.topActionButtons = [];
this.displayedColumns = [];
this.columnsToDisplay = [];
this.selection = new SelectionModel(true, []);
this.columnsNameApi = [];
this.topButtonStyle = {
height: '32px',
'line-height': '32px'
};
}
/**
* @return {?}
*/
DataTableComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.data = this.dataTableService.setDataSource(this.inputData);
this.columnsNameApi = this.columnNames.map((/**
* @param {?} e
* @return {?}
*/
function (e) { return e.columnNameApi; }));
this.displayColumns();
this.dataTableService.inputDataEvent.subscribe((/**
* @param {?} inputData
* @return {?}
*/
function (inputData) {
_this.load(inputData);
}));
};
/**
* @param {?} inputData
* @return {?}
*/
DataTableComponent.prototype.load = /**
* @param {?} inputData
* @return {?}
*/
function (inputData) {
var _this = this;
this.inputData = inputData;
this.columnsNameApi = this.columnNames.map((/**
* @param {?} e
* @return {?}
*/
function (e) { return e.columnNameApi; }));
this.data = this.dataTableService.setDataSource(this.inputData);
this.noData = this.data.connect().pipe(map((/**
* @param {?} data
* @return {?}
*/
function (data) { return data.length === 0; })));
this.data.paginator = this.paginator;
this.addActionsToData();
this.displayColumns();
this.popoverService.buttonClickEvent.subscribe((/**
* @param {?} event
* @return {?}
*/
function (event) {
_this.buttonRowClick(event.event, event.elementId);
}));
};
/**
* @return {?}
*/
DataTableComponent.prototype.filterLimparButtonClick = /**
* @return {?}
*/
function () {
this.dataTableService.filterLimparButtonClick();
};
/**
* @return {?}
*/
DataTableComponent.prototype.filterPesquisarButtonClick = /**
* @return {?}
*/
function () {
this.dataTableService.filterPesquisarButtonClick();
};
/**
* @param {?} eventSlug
* @return {?}
*/
DataTableComponent.prototype.topButtonClick = /**
* @param {?} eventSlug
* @return {?}
*/
function (eventSlug) {
this.dataTableService.topButtonClick(eventSlug);
};
/**
* @param {?} event
* @param {?} index
* @return {?}
*/
DataTableComponent.prototype.buttonRowClick = /**
* @param {?} event
* @param {?} index
* @return {?}
*/
function (event, index) {
// console.log(`buttonRowClick: ${event.toLowerCase()}, ${index.toLowerCase()}`);
this.dataTableService.buttonRowClick(event.toLowerCase(), index);
};
/**
* @return {?}
*/
DataTableComponent.prototype.addActionsToData = /**
* @return {?}
*/
function () {
var _this = this;
this.data.data.map((/**
* @param {?} e
* @return {?}
*/
function (e) {
// tslint:disable-next-line: no-string-literal
e['actions'] = Object.assign({}, _this.actions);
}));
};
/**
* @return {?}
*/
DataTableComponent.prototype.isAllSelected = /**
* @return {?}
*/
function () {
/** @type {?} */
var numSelected = this.selection.selected.length;
/** @type {?} */
var numRows = this.data.data.length;
return numSelected === numRows;
};
/**
* @return {?}
*/
DataTableComponent.prototype.masterToggle = /**
* @return {?}
*/
function () {
var _this = this;
this.isAllSelected()
? this.selection.clear()
: this.data.data.forEach((/**
* @param {?} row
* @return {?}
*/
function (row) { return _this.selection.select(row); }));
};
/**
* @return {?}
*/
DataTableComponent.prototype.displayColumns = /**
* @return {?}
*/
function () {
if (this.selectColumn) {
this.addSelectToDisplayedColumns();
}
if (this.actions.length >= 0) {
this.addActionsToDisplayedColumns();
}
};
/**
* @return {?}
*/
DataTableComponent.prototype.addSelectToDisplayedColumns = /**
* @return {?}
*/
function () {
/** @type {?} */
var select = ['select'];
if (this.columnsNameApi && this.columnsNameApi.length !== 0) {
this.columnsNameApi = select.concat(this.columnsNameApi);
this.displayedColumns = this.columnsNameApi;
this.columnsToDisplay = this.displayedColumns.slice();
}
else {
this.displayedColumns = select.concat(Object.keys(this.data[0]));
this.columnsToDisplay = this.displayedColumns.slice();
}
};
/**
* @return {?}
*/
DataTableComponent.prototype.addActionsToDisplayedColumns = /**
* @return {?}
*/
function () {
/** @type {?} */
var actions = ['actions'];
if (this.columnsNameApi && this.columnsNameApi.length !== 0) {
this.columnsNameApi.push(actions[0]);
this.displayedColumns = this.columnsNameApi;
this.columnsToDisplay = this.displayedColumns.slice();
}
else {
this.displayedColumns = actions.concat(Object.keys(this.data[0]));
this.columnsToDisplay = this.displayedColumns.slice();
}
};
/**
* @param {?} columnNameApi
* @return {?}
*/
DataTableComponent.prototype.verifyNameColumn = /**
* @param {?} columnNameApi
* @return {?}
*/
function (columnNameApi) {
/** @type {?} */
var columnNameApiArray = this.columnNames.map((/**
* @param {?} e
* @return {?}
*/
function (e) { return e.columnNameApi; }));
/** @type {?} */
var indexcolumnNameApi = columnNameApiArray.indexOf(columnNameApi);
if (indexcolumnNameApi >= 0) {
return this.columnNames[indexcolumnNameApi].displayName;
}
else {
return columnNameApi;
}
};
/**
* @return {?}
*/
DataTableComponent.prototype.addColumn = /**
* @return {?}
*/
function () {
/** @type {?} */
var randomColumn = Math.floor(Math.random() * this.displayedColumns.length);
this.columnsToDisplay.push(this.displayedColumns[randomColumn]);
};
/**
* @return {?}
*/
DataTableComponent.prototype.removeColumn = /**
* @return {?}
*/
function () {
if (this.columnsToDisplay.length) {
this.columnsToDisplay.pop();
}
};
DataTableComponent.decorators = [
{ type: Component, args: [{
selector: 'sb-data-table',
template: "<div>\r\n <div fxLayout fxLayoutAlign=\"space-between center\" class=\"mr-16 ml-16 mb-5\">\r\n <div #topButtonAction fxLayout=\"row wrap\" fxLayoutAlign=\"flex-start center\" fxLayoutGap=\"10px grid\">\r\n <sb-button\r\n *ngFor=\"let buttonElement of topActionButtons\"\r\n [materialTypeButton]=\"buttonElement.buttonType\"\r\n [color]=\"buttonElement.buttonColor\"\r\n [actionName]=\"buttonElement.actionName\"\r\n [customStyles]=\"topButtonStyle\"\r\n (buttonClick)=\"topButtonClick(buttonElement.eventSlug)\"\r\n ></sb-button>\r\n </div>\r\n <sb-filter-table (limpar)=\"filterLimparButtonClick()\" (pesquisa)=\"filterPesquisarButtonClick()\">\r\n <ng-content select=\".sb-data-table-content\"></ng-content>\r\n </sb-filter-table>\r\n </div>\r\n <table mat-table [dataSource]=\"data\" style=\"width: 100%;\" class=\"table-striped table-hover\">\r\n <!-- Checkbox Column -->\r\n\r\n <ng-container [matColumnDef]=\"column\" *ngFor=\"let column of displayedColumns\">\r\n <div *ngIf=\"column == 'select'\">\r\n <th mat-header-cell *matHeaderCellDef>\r\n <mat-checkbox\r\n (change)=\"$event ? masterToggle() : null\"\r\n [checked]=\"selection.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"selection.hasValue() && !isAllSelected()\"\r\n >\r\n </mat-checkbox>\r\n </th>\r\n <td mat-cell *matCellDef=\"let row\">\r\n <mat-checkbox\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"$event ? selection.toggle(row) : null\"\r\n [checked]=\"selection.isSelected(row)\"\r\n >\r\n </mat-checkbox>\r\n </td>\r\n </div>\r\n <div *ngIf=\"column !== 'select' && column !== 'actions'\">\r\n <th mat-header-cell *matHeaderCellDef>\r\n {{ verifyNameColumn(column) }}\r\n </th>\r\n <td mat-cell *matCellDef=\"let element\">{{ element[column] }}</td>\r\n </div>\r\n <div *ngIf=\"column == 'actions'\">\r\n <th mat-header-cell *matHeaderCellDef>A\u00E7\u00F5es</th>\r\n <td mat-cell *matCellDef=\"let element\">\r\n <div fxLayout>\r\n <div *ngFor=\"let buttonElement of (element.actions | keyvalue)\">\r\n <button\r\n mat-icon-button\r\n *ngIf=\"!buttonElement.value.isDelete\"\r\n (click)=\"buttonRowClick(buttonElement.value.actionName, element.id)\"\r\n matTooltip=\"{{ buttonElement.value.actionDescription }}\"\r\n >\r\n <mat-icon>{{ buttonElement.value.actionIcon }}</mat-icon>\r\n </button>\r\n <sb-popover\r\n *ngIf=\"buttonElement.value.isDelete\"\r\n matTooltip=\"{{ buttonElement.value.actionDescription }}\"\r\n elementId=\"{{ element.id }}\"\r\n popoverTitle=\"{{ buttonElement.value.isDeleteTitle }}\"\r\n popoverDescription=\"{{ buttonElement.value.isDeleteDescription }}\"\r\n ></sb-popover>\r\n </div>\r\n </div>\r\n </td>\r\n </div>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"columnsToDisplay\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: columnsToDisplay\" (click)=\"selection.toggle(row)\"></tr>\r\n </table>\r\n\r\n <div @flipInOut *ngIf=\"data.data.length == 0\" fxLayout=\"column\" fxLayoutAlign=\"center center\" fxLayoutGap=\"5px\" class=\"m-30\">\r\n <img src=\"../../../assets/img/nodata.svg\" />\r\n <p class=\" mat-caption\">\r\n Sem Registros\r\n </p>\r\n </div>\r\n\r\n <mat-paginator [pageSizeOptions]=\"[5, 10, 25, 100]\" class=\"mt-10\"></mat-paginator>\r\n</div>\r\n",
animations: [
trigger('flipInOut', [
transition('void => *', useAnimation(flipInX, {
params: { timing: 0.3, delay: 0, a: '10px', b: '0' }
})),
transition('* => void', useAnimation(flipOutX, {
params: { timing: 0.3, delay: 0 }
}))
])
],
styles: ["td.mat-cell:last-of-type,td.mat-footer-cell:last-of-type,th.mat-header-cell:last-of-type{width:180px;text-align:center}"]
}] }
];
/** @nocollapse */
DataTableComponent.ctorParameters = function () { return [
{ type: DataTableService },
{ type: PopoverService },
{ type: Renderer2 }
]; };
DataTableComponent.propDecorators = {
selectColumn: [{ type: Input }],
columnNames: [{ type: Input }],
actions: [{ type: Input }],
inputData: [{ type: Input }],
topActionButtons: [{ type: Input }],
paginator: [{ type: ViewChild, args: [MatPaginator,] }]
};
return DataTableComponent;
}());
export { DataTableComponent };
if (false) {
/** @type {?} */
DataTableComponent.prototype.selectColumn;
/** @type {?} */
DataTableComponent.prototype.columnNames;
/** @type {?} */
DataTableComponent.prototype.actions;
/** @type {?} */
DataTableComponent.prototype.inputData;
/** @type {?} */
DataTableComponent.prototype.topActionButtons;
/** @type {?} */
DataTableComponent.prototype.paginator;
/** @type {?} */
DataTableComponent.prototype.data;
/** @type {?} */
DataTableComponent.prototype.displayedColumns;
/** @type {?} */
DataTableComponent.prototype.columnsToDisplay;
/** @type {?} */
DataTableComponent.prototype.selection;
/** @type {?} */
DataTableComponent.prototype.columnsNameApi;
/** @type {?} */
DataTableComponent.prototype.noData;
/** @type {?} */
DataTableComponent.prototype.topButtonStyle;
/**
* @type {?}
* @private
*/
DataTableComponent.prototype.dataTableService;
/**
* @type {?}
* @private
*/
DataTableComponent.prototype.popoverService;
/**
* @type {?}
* @private
*/
DataTableComponent.prototype.renderer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"ng://@lucasferreiralsf/angular-frontend-library/","sources":["lib/data-table/data-table.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EAET,KAAK,EACL,SAAS,EACT,SAAS,EAGV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAsB,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;;;;AAE/C,mDAGC;;;IAFC,sDAAsB;;IACtB,oDAAoB;;;;;AAGtB,iDAGC;;;IAFC,yCAAW;;IACX,8CAAmC;;;;;AAGrC,+CAQC;;;IAPC,+CAAmB;;IACnB,sDAA0B;;IAC1B,+CAAmB;;IACnB,mDAAoB;;IACpB,6CAAmB;;IACnB,kDAAuB;;IACvB,wDAA6B;;;;;AAG/B,uDAKC;;;IAJC,uDAAmB;;IACnB,sDAAkB;;IAClB,uDAAmB;;IACnB,wDAAqB;;AAGvB;IA0CE,4BACU,gBAAkC,EAClC,cAA8B,EAC9B,QAAmB;QAFnB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,aAAQ,GAAR,QAAQ,CAAW;QAvBpB,iBAAY,GAAG,KAAK,CAAC;QACrB,gBAAW,GAAoC,EAAE,CAAC;QAClD,YAAO,GAAgC,EAAE,CAAC;QAC1C,cAAS,GAAkC,EAAE,CAAC;QAC9C,qBAAgB,GAAwC,EAAE,CAAC;QAKpE,qBAAgB,GAAa,EAAE,CAAC;QAChC,qBAAgB,GAAa,EAAE,CAAC;QAChC,cAAS,GAAG,IAAI,cAAc,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACzC,mBAAc,GAAa,EAAE,CAAC;QAG9B,mBAAc,GAAO;YACnB,MAAM,EAAE,MAAM;YACd,aAAa,EAAE,MAAM;SACtB,CAAC;IAMC,CAAC;;;;IAEJ,qCAAQ;;;IAAR;QAAA,iBAOC;QANC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAChE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG;;;;QAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,aAAa,EAAf,CAAe,EAAC,CAAC;QACjE,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,SAAS;;;;QAAC,UAAA,SAAS;YACtD,KAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,CAAC,EAAC,CAAC;IACL,CAAC;;;;;IAED,iCAAI;;;;IAAJ,UAAK,SAAS;QAAd,iBAWC;QAVC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG;;;;QAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,aAAa,EAAf,CAAe,EAAC,CAAC;QACjE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAChE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG;;;;QAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,MAAM,KAAK,CAAC,EAAjB,CAAiB,EAAC,CAAC,CAAC;QACvE,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACrC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,SAAS;;;;QAAC,UAAA,KAAK;YAClD,KAAI,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QACpD,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,oDAAuB;;;IAAvB;QACE,IAAI,CAAC,gBAAgB,CAAC,uBAAuB,EAAE,CAAC;IAClD,CAAC;;;;IAED,uDAA0B;;;IAA1B;QACE,IAAI,CAAC,gBAAgB,CAAC,0BAA0B,EAAE,CAAC;IACrD,CAAC;;;;;IAED,2CAAc;;;;IAAd,UAAe,SAAiB;QAC9B,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;IAClD,CAAC;;;;;;IAED,2CAAc;;;;;IAAd,UAAe,KAAa,EAAE,KAAK;QACjC,iFAAiF;QACjF,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,CAAC;IACnE,CAAC;;;;IAED,6CAAgB;;;IAAhB;QAAA,iBAKC;QAJC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG;;;;QAAC,UAAA,CAAC;YAClB,8CAA8C;YAC9C,CAAC,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,KAAI,CAAC,OAAO,CAAC,CAAC;QACjD,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,0CAAa;;;IAAb;;YACQ,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM;;YAC5C,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM;QACrC,OAAO,WAAW,KAAK,OAAO,CAAC;IACjC,CAAC;;;;IAED,yCAAY;;;IAAZ;QAAA,iBAIC;QAHC,IAAI,CAAC,aAAa,EAAE;YAClB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;YACxB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO;;;;YAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,EAA1B,CAA0B,EAAC,CAAC;IAChE,CAAC;;;;IAED,2CAAc;;;IAAd;QACE,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,2BAA2B,EAAE,CAAC;SACpC;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,EAAE;YAC5B,IAAI,CAAC,4BAA4B,EAAE,CAAC;SACrC;IACH,CAAC;;;;IAED,wDAA2B;;;IAA3B;;YACQ,MAAM,GAAG,CAAC,QAAQ,CAAC;QAEzB,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3D,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACzD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,cAAc,CAAC;YAC5C,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;SACvD;aAAM;YACL,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACjE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;SACvD;IACH,CAAC;;;;IAED,yDAA4B;;;IAA5B;;YACQ,OAAO,GAAG,CAAC,SAAS,CAAC;QAE3B,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3D,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;YACrC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,cAAc,CAAC;YAC5C,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;SACvD;aAAM;YACL,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAClE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;SACvD;IACH,CAAC;;;;;IAED,6CAAgB;;;;IAAhB,UAAiB,aAAa;;YACtB,kBAAkB,GAAa,IAAI,CAAC,WAAW,CAAC,GAAG;;;;QACvD,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,aAAa,EAAf,CAAe,EACrB;;YACK,kBAAkB,GAAW,kBAAkB,CAAC,OAAO,CAC3D,aAAa,CACd;QAED,IAAI,kBAAkB,IAAI,CAAC,EAAE;YAC3B,OAAO,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC,WAAW,CAAC;SACzD;aAAM;YACL,OAAO,aAAa,CAAC;SACtB;IACH,CAAC;;;;IAED,sCAAS;;;IAAT;;YACQ,YAAY,GAAG,IAAI,CAAC,KAAK,CAC7B,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAC7C;QACD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC,CAAC;IAClE,CAAC;;;;IAED,yCAAY;;;IAAZ;QACE,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE;YAChC,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC;SAC7B;IACH,CAAC;;gBAxKF,SAAS,SAAC;oBACT,QAAQ,EAAE,eAAe;oBACzB,mvHAA0C;oBAE1C,UAAU,EAAE;wBACV,OAAO,CAAC,WAAW,EAAE;4BACnB,UAAU,CACR,WAAW,EACX,YAAY,CAAC,OAAO,EAAE;gCACpB,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,GAAG,EAAE;6BACrD,CAAC,CACH;4BACD,UAAU,CACR,WAAW,EACX,YAAY,CAAC,QAAQ,EAAE;gCACrB,MAAM,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,EAAE;6BAClC,CAAC,CACH;yBACF,CAAC;qBACH;;iBACF;;;;gBArDQ,gBAAgB;gBAEhB,cAAc;gBARrB,SAAS;;;+BA6DR,KAAK;8BACL,KAAK;0BACL,KAAK;4BACL,KAAK;mCACL,KAAK;4BAEL,SAAS,SAAC,YAAY;;IA6IzB,yBAAC;CAAA,AAzKD,IAyKC;SApJY,kBAAkB;;;IAC7B,0CAA8B;;IAC9B,yCAA2D;;IAC3D,qCAAmD;;IACnD,uCAAuD;;IACvD,8CAAoE;;IAEpE,uCAAiD;;IAEjD,kCAA8B;;IAC9B,8CAAgC;;IAChC,8CAAgC;;IAChC,uCAAyC;;IACzC,4CAA8B;;IAC9B,oCAAO;;IAEP,4CAGE;;;;;IAGA,8CAA0C;;;;;IAC1C,4CAAsC;;;;;IACtC,sCAA2B","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  Input,\r\n  ViewChild,\r\n  Renderer2,\r\n  AfterContentInit,\r\n  AfterViewInit\r\n} from '@angular/core';\r\nimport { SelectionModel } from '@angular/cdk/collections';\r\nimport { MatTableDataSource, MatPaginator } from '@angular/material';\r\nimport { DataTableService } from './data-table.service';\r\nimport { map } from 'rxjs/operators';\r\nimport { PopoverService } from './popover/popover.service';\r\nimport { trigger, transition, useAnimation } from '@angular/animations';\r\nimport { flipInX, flipOutX } from 'ng-animate';\r\n\r\nexport interface DataTableColumnNamesInterface {\r\n  columnNameApi: string;\r\n  displayName: string;\r\n}\r\n\r\nexport interface DataTableInputDataInterface {\r\n  id: number;\r\n  actions: DataTableActionsInterface;\r\n}\r\n\r\nexport interface DataTableActionsInterface {\r\n  actionName: string;\r\n  actionDescription: string;\r\n  actionIcon: string;\r\n  actionFunction: any;\r\n  isDelete?: boolean;\r\n  isDeleteTitle?: string;\r\n  isDeleteDescription?: string;\r\n}\r\n\r\nexport interface DataTableTopActionButtonInterface {\r\n  actionName: string;\r\n  eventSlug: string;\r\n  buttonType: string;\r\n  buttonColor?: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'sb-data-table',\r\n  templateUrl: './data-table.component.html',\r\n  styleUrls: ['./data-table.component.scss'],\r\n  animations: [\r\n    trigger('flipInOut', [\r\n      transition(\r\n        'void => *',\r\n        useAnimation(flipInX, {\r\n          params: { timing: 0.3, delay: 0, a: '10px', b: '0' }\r\n        })\r\n      ),\r\n      transition(\r\n        '* => void',\r\n        useAnimation(flipOutX, {\r\n          params: { timing: 0.3, delay: 0 }\r\n        })\r\n      )\r\n    ])\r\n  ]\r\n})\r\nexport class DataTableComponent implements OnInit {\r\n  @Input() selectColumn = false;\r\n  @Input() columnNames: DataTableColumnNamesInterface[] = [];\r\n  @Input() actions: DataTableActionsInterface[] = [];\r\n  @Input() inputData: DataTableInputDataInterface[] = [];\r\n  @Input() topActionButtons: DataTableTopActionButtonInterface[] = [];\r\n\r\n  @ViewChild(MatPaginator) paginator: MatPaginator;\r\n\r\n  data: MatTableDataSource<any>;\r\n  displayedColumns: string[] = [];\r\n  columnsToDisplay: string[] = [];\r\n  selection = new SelectionModel(true, []);\r\n  columnsNameApi: string[] = [];\r\n  noData;\r\n\r\n  topButtonStyle: {} = {\r\n    height: '32px',\r\n    'line-height': '32px'\r\n  };\r\n\r\n  constructor(\r\n    private dataTableService: DataTableService,\r\n    private popoverService: PopoverService,\r\n    private renderer: Renderer2\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.data = this.dataTableService.setDataSource(this.inputData);\r\n    this.columnsNameApi = this.columnNames.map(e => e.columnNameApi);\r\n    this.displayColumns();\r\n    this.dataTableService.inputDataEvent.subscribe(inputData => {\r\n      this.load(inputData);\r\n    });\r\n  }\r\n\r\n  load(inputData) {\r\n    this.inputData = inputData;\r\n    this.columnsNameApi = this.columnNames.map(e => e.columnNameApi);\r\n    this.data = this.dataTableService.setDataSource(this.inputData);\r\n    this.noData = this.data.connect().pipe(map(data => data.length === 0));\r\n    this.data.paginator = this.paginator;\r\n    this.addActionsToData();\r\n    this.displayColumns();\r\n    this.popoverService.buttonClickEvent.subscribe(event => {\r\n      this.buttonRowClick(event.event, event.elementId);\r\n    });\r\n  }\r\n\r\n  filterLimparButtonClick() {\r\n    this.dataTableService.filterLimparButtonClick();\r\n  }\r\n\r\n  filterPesquisarButtonClick() {\r\n    this.dataTableService.filterPesquisarButtonClick();\r\n  }\r\n\r\n  topButtonClick(eventSlug: string) {\r\n    this.dataTableService.topButtonClick(eventSlug);\r\n  }\r\n\r\n  buttonRowClick(event: string, index) {\r\n    // console.log(`buttonRowClick: ${event.toLowerCase()}, ${index.toLowerCase()}`);\r\n    this.dataTableService.buttonRowClick(event.toLowerCase(), index);\r\n  }\r\n\r\n  addActionsToData() {\r\n    this.data.data.map(e => {\r\n      // tslint:disable-next-line: no-string-literal\r\n      e['actions'] = Object.assign({}, this.actions);\r\n    });\r\n  }\r\n\r\n  isAllSelected() {\r\n    const numSelected = this.selection.selected.length;\r\n    const numRows = this.data.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  masterToggle() {\r\n    this.isAllSelected()\r\n      ? this.selection.clear()\r\n      : this.data.data.forEach(row => this.selection.select(row));\r\n  }\r\n\r\n  displayColumns() {\r\n    if (this.selectColumn) {\r\n      this.addSelectToDisplayedColumns();\r\n    }\r\n\r\n    if (this.actions.length >= 0) {\r\n      this.addActionsToDisplayedColumns();\r\n    }\r\n  }\r\n\r\n  addSelectToDisplayedColumns() {\r\n    const select = ['select'];\r\n\r\n    if (this.columnsNameApi && this.columnsNameApi.length !== 0) {\r\n      this.columnsNameApi = select.concat(this.columnsNameApi);\r\n      this.displayedColumns = this.columnsNameApi;\r\n      this.columnsToDisplay = this.displayedColumns.slice();\r\n    } else {\r\n      this.displayedColumns = select.concat(Object.keys(this.data[0]));\r\n      this.columnsToDisplay = this.displayedColumns.slice();\r\n    }\r\n  }\r\n\r\n  addActionsToDisplayedColumns() {\r\n    const actions = ['actions'];\r\n\r\n    if (this.columnsNameApi && this.columnsNameApi.length !== 0) {\r\n      this.columnsNameApi.push(actions[0]);\r\n      this.displayedColumns = this.columnsNameApi;\r\n      this.columnsToDisplay = this.displayedColumns.slice();\r\n    } else {\r\n      this.displayedColumns = actions.concat(Object.keys(this.data[0]));\r\n      this.columnsToDisplay = this.displayedColumns.slice();\r\n    }\r\n  }\r\n\r\n  verifyNameColumn(columnNameApi) {\r\n    const columnNameApiArray: string[] = this.columnNames.map(\r\n      e => e.columnNameApi\r\n    );\r\n    const indexcolumnNameApi: number = columnNameApiArray.indexOf(\r\n      columnNameApi\r\n    );\r\n\r\n    if (indexcolumnNameApi >= 0) {\r\n      return this.columnNames[indexcolumnNameApi].displayName;\r\n    } else {\r\n      return columnNameApi;\r\n    }\r\n  }\r\n\r\n  addColumn() {\r\n    const randomColumn = Math.floor(\r\n      Math.random() * this.displayedColumns.length\r\n    );\r\n    this.columnsToDisplay.push(this.displayedColumns[randomColumn]);\r\n  }\r\n\r\n  removeColumn() {\r\n    if (this.columnsToDisplay.length) {\r\n      this.columnsToDisplay.pop();\r\n    }\r\n  }\r\n}\r\n"]}