keevo-components 1.8.135 → 1.8.136

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,477 @@
1
+ import { Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { getOrExecute, mapToMenuItem, } from '../../api/components/table/kv-menuitem';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "../../api/pipes/cpfcnpj.pipe";
6
+ import * as i3 from "../../api/pipes/telefone.pipe";
7
+ import * as i4 from "primeng/api";
8
+ import * as i5 from "primeng/autofocus";
9
+ import * as i6 from "primeng/tooltip";
10
+ import * as i7 from "primeng/button";
11
+ import * as i8 from "primeng/card";
12
+ import * as i9 from "primeng/checkbox";
13
+ import * as i10 from "primeng/inputtext";
14
+ import * as i11 from "primeng/panel";
15
+ import * as i12 from "primeng/ripple";
16
+ import * as i13 from "primeng/tieredmenu";
17
+ import * as i14 from "primeng/table";
18
+ import * as i15 from "@angular/forms";
19
+ import * as i16 from "../kv-inputs/kv-switch/kv-switch.component";
20
+ const imgDefault = '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';
21
+ export class KvTableExpandableComponent {
22
+ set setConfig(value) {
23
+ this.config = {
24
+ enableCation: value.enableCation || true,
25
+ enableSelect: value.enableSelect || false,
26
+ enableFilter: value.enableFilter || true,
27
+ ...value,
28
+ };
29
+ if (this.config.enableFilter) {
30
+ this.config.columns.forEach((col) => {
31
+ this.globalFilterFields.push('data.' + col.field);
32
+ });
33
+ }
34
+ }
35
+ constructor(datePipe, decimalPipe, cpfCnpjPipe, telefonePipe) {
36
+ this.datePipe = datePipe;
37
+ this.decimalPipe = decimalPipe;
38
+ this.cpfCnpjPipe = cpfCnpjPipe;
39
+ this.telefonePipe = telefonePipe;
40
+ this.expandedRows = {};
41
+ this.globalFilterFields = [];
42
+ this.columns = [];
43
+ this.deletedColuns = [];
44
+ this.dataIndex = {};
45
+ this.collapsed = false;
46
+ this.tableData = [];
47
+ this.currDataSource = [];
48
+ this.filtrosAvancados = false;
49
+ this.dataSource = [];
50
+ this.selectedItems = [];
51
+ this.tableCaptalized = false;
52
+ this.applyStyle = (rowData, col) => '';
53
+ this.paginator = true;
54
+ this.rows = 5;
55
+ this.pageLinksOptions = 1;
56
+ this.responsiveLayout = true;
57
+ this.isTableScrollable = false;
58
+ this.scrollHeight = '';
59
+ this.rowTrackBy = (index, item) => item;
60
+ this.showFirstLastIcon = false;
61
+ this.filterField = new EventEmitter();
62
+ this.onActiveItem = new EventEmitter();
63
+ this.onActiveItemLote = new EventEmitter();
64
+ this.doubleClickEvent = new EventEmitter();
65
+ this.onSwitchTableChange = new EventEmitter();
66
+ this.onPaginate = new EventEmitter();
67
+ this.onSelectionChange = new EventEmitter();
68
+ this.isRowSelectable = this.isRowSelectable.bind(this);
69
+ }
70
+ ngOnInit() {
71
+ this.tamanhoTela = window.innerWidth;
72
+ this.adicionaAcoesTabela();
73
+ this.config.columns.forEach((col) => {
74
+ this.columns.push(col);
75
+ });
76
+ }
77
+ ngDoCheck() {
78
+ if (JSON.stringify(this.dataSource) !== JSON.stringify(this.currDataSource)) {
79
+ if (this.dataSource) {
80
+ this.tableData = this.dataSource.map((x) => ({
81
+ data: x,
82
+ actions: this.config.actions
83
+ ? this.config.actions.map((y) => mapToMenuItem(y, x))
84
+ : undefined,
85
+ }));
86
+ this.currDataSource = [...this.dataSource];
87
+ this.createDataIndex();
88
+ }
89
+ }
90
+ }
91
+ onGlobalFilter(table, event) {
92
+ this.filterField.emit(event.target.value);
93
+ table.filterGlobal(event.target.value, 'contains');
94
+ }
95
+ adicionaAcoesTabela() {
96
+ this.config.actionsLote?.unshift({
97
+ icon: 'collapse_all',
98
+ tooltip: 'Collapse',
99
+ command: () => {
100
+ this.collapseAll();
101
+ },
102
+ showAcoesLote: true,
103
+ }, {
104
+ icon: 'expand_all',
105
+ tooltip: 'Expand',
106
+ command: () => {
107
+ this.expandAll();
108
+ },
109
+ showAcoesLote: true,
110
+ });
111
+ }
112
+ checkMenuFiltro(col) {
113
+ let deletedColumn = this.deletedColuns.find((x) => x.field == col.field);
114
+ if (deletedColumn)
115
+ col.checked = false;
116
+ else
117
+ col.checked = true;
118
+ }
119
+ sortByPosition() {
120
+ return function (elem1, elem2) {
121
+ if (elem1.position < elem2.position) {
122
+ return -1;
123
+ }
124
+ else if (elem1.position > elem2.position) {
125
+ return 1;
126
+ }
127
+ else {
128
+ return 0;
129
+ }
130
+ };
131
+ }
132
+ dinamicDisableColumn(col) {
133
+ if (col.fixedColumn)
134
+ return col.fixedColumn;
135
+ else
136
+ return false;
137
+ }
138
+ dinamicColumnSet(e, col) {
139
+ col.checked = e.checked;
140
+ if (e.checked)
141
+ this.addColumn(col.field);
142
+ else
143
+ this.deleteColumn(col.field);
144
+ if (col.position)
145
+ this.config.columns.sort(this.sortByPosition());
146
+ }
147
+ addColumn(field) {
148
+ let index;
149
+ let column = this.config.columns.find((x) => x.field == field);
150
+ if (!column) {
151
+ let deletedColumn = this.deletedColuns.find((x) => x.field == field);
152
+ if (deletedColumn != undefined) {
153
+ index = this.deletedColuns.indexOf(deletedColumn);
154
+ this.deletedColuns.slice(index, 1);
155
+ this.config.columns.push(deletedColumn);
156
+ }
157
+ }
158
+ }
159
+ deleteColumn(field) {
160
+ let index;
161
+ let column = this.config.columns.find((x) => x.field == field);
162
+ if (column) {
163
+ index = this.config.columns.indexOf(column);
164
+ this.config.columns.splice(index, 1);
165
+ this.deletedColuns.push(column);
166
+ }
167
+ }
168
+ doubleClick(e, rowData) {
169
+ let eventDoubleClick = { event: e, rowData: rowData };
170
+ let array = [];
171
+ e.target.classList.forEach((x) => array.push(x));
172
+ this.doubleClickEvent.emit(eventDoubleClick);
173
+ }
174
+ centralizarColunas(col) {
175
+ if (col.centralize) {
176
+ return 'text-align: center';
177
+ }
178
+ else
179
+ return '';
180
+ }
181
+ alignColunas(col) {
182
+ if (col.align) {
183
+ return `text-align: ${col.align}`;
184
+ }
185
+ else
186
+ return '';
187
+ }
188
+ alignColunasHeader(col) {
189
+ if (col.align) {
190
+ if (col.align == 'right')
191
+ return 'justify-content: end';
192
+ else
193
+ return '';
194
+ }
195
+ else
196
+ return '';
197
+ }
198
+ retornarRow(rowData, col, field) {
199
+ const _rowaction = this.config.rows ? this.config.rows[col.field] : null;
200
+ const _field = _rowaction && _rowaction[field]
201
+ ? _rowaction[field].constructor === Function
202
+ ? _rowaction[field].apply(this, [rowData])
203
+ : _rowaction[field]
204
+ : null;
205
+ return _field;
206
+ }
207
+ returnTooltipRow(rowData, col) {
208
+ return this.retornarRow(rowData, col, 'tooltiprow');
209
+ }
210
+ getOrExecute(action, data) {
211
+ return getOrExecute(action, data);
212
+ }
213
+ isBooleanField(rowData, col) {
214
+ return typeof rowData[col.field] == 'boolean';
215
+ }
216
+ isChipField(col) {
217
+ return col.fieldType == 'chip';
218
+ }
219
+ isImageField(col) {
220
+ let retorno = col.fieldType && col.fieldType === 'image' ? true : false;
221
+ return retorno;
222
+ }
223
+ isSwitchField(col) {
224
+ let retorno = col.fieldType && col.fieldType === 'switch' ? true : false;
225
+ return retorno;
226
+ }
227
+ isRowSelectable(event) {
228
+ return !this.isDisabledCheckbox(event.data);
229
+ }
230
+ activeItemLote(selectedItems) {
231
+ this.onActiveItemLote.emit(selectedItems);
232
+ }
233
+ selectItem(event, group) {
234
+ if (event.target.checked) {
235
+ this.selectedItems = [...this.selectedItems, group];
236
+ }
237
+ else {
238
+ const index = this.selectedItems.indexOf(group, 0);
239
+ if (index > -1) {
240
+ this.selectedItems.splice(index, 1);
241
+ }
242
+ }
243
+ this.onActiveItemLote.emit(this.selectedItems);
244
+ }
245
+ isSelected(item) {
246
+ // Verifica se o item está presente na lista de itens selecionados
247
+ return this.selectedItems.includes(item);
248
+ }
249
+ activeItem(rowData) {
250
+ this.onActiveItem.emit(rowData);
251
+ }
252
+ selectGroup(event, grouped, valor) {
253
+ const itensGroup = this.dataSource.filter(x => x[grouped] == valor);
254
+ if (event.target.checked) {
255
+ itensGroup.forEach((x) => {
256
+ if (!this.selectedItems.includes(x))
257
+ this.selectedItems = [...this.selectedItems, x];
258
+ });
259
+ }
260
+ else {
261
+ itensGroup.forEach((x) => {
262
+ if (this.selectedItems.includes(x)) {
263
+ const index = this.selectedItems.indexOf(x, 0);
264
+ if (index > -1) {
265
+ this.selectedItems.splice(index, 1);
266
+ }
267
+ }
268
+ });
269
+ }
270
+ this.onActiveItemLote.emit(this.selectedItems);
271
+ }
272
+ isAllGroupSelected(grouped, valor) {
273
+ const itensGroup = this.dataSource.filter(x => x[grouped] == valor);
274
+ return itensGroup.every(x => this.selectedItems.includes(x));
275
+ }
276
+ isGroupIndeterminate(grouped, valor) {
277
+ if (this.isAllGroupSelected(grouped, valor))
278
+ return false;
279
+ const itensGroup = this.dataSource.filter(x => x[grouped] == valor);
280
+ return itensGroup.some(x => this.selectedItems.includes(x));
281
+ }
282
+ selectAll(event) {
283
+ if (event.target.checked) {
284
+ this.selectedItems = this.dataSource;
285
+ }
286
+ else {
287
+ this.selectedItems = [];
288
+ }
289
+ this.onActiveItemLote.emit(this.selectedItems);
290
+ }
291
+ isAllIndeterminate() {
292
+ if (this.isAllSelected())
293
+ return false;
294
+ return this.dataSource.some(x => this.selectedItems.includes(x));
295
+ }
296
+ isAllSelected() {
297
+ return this.dataSource.every(x => this.selectedItems.includes(x));
298
+ }
299
+ transformValue(rowData, col) {
300
+ let value = rowData[col.field];
301
+ if (value != null) {
302
+ if (!col.pipe) {
303
+ return value;
304
+ }
305
+ switch (col.pipe) {
306
+ case 'date':
307
+ return this.datePipe.transform(value, 'dd/MM/yyyy');
308
+ case 'dateMonthYear':
309
+ return this.datePipe.transform(value, 'MM/yyyy');
310
+ case 'decimal':
311
+ return this.decimalPipe.transform(value, '1.2-2', 'pt-BR');
312
+ case 'cpfcnpj':
313
+ return this.cpfCnpjPipe.transform(value);
314
+ case 'telefone':
315
+ return this.telefonePipe.transform(value);
316
+ case 'money':
317
+ return this.formatarValor(value);
318
+ case 'percentage':
319
+ return `${value} %`;
320
+ default:
321
+ break;
322
+ }
323
+ }
324
+ }
325
+ getCustomTemplate(templatename) {
326
+ return this._templates[templatename];
327
+ }
328
+ formatarValor(valor) {
329
+ const formatter = new Intl.NumberFormat('pt-BR', {
330
+ style: 'currency',
331
+ currency: 'BRL',
332
+ });
333
+ return formatter.format(valor);
334
+ }
335
+ returnRowClass(rowData, col) {
336
+ let value = rowData[col.field];
337
+ let rowClass;
338
+ this.tableSize > 800 ? (rowClass = 'text-base') : (rowClass = 'text-sm');
339
+ if (col.expiredDate == true) {
340
+ new Date(value) < new Date()
341
+ ? (rowClass = rowClass + ' text-red-400 font-semibold')
342
+ : '';
343
+ }
344
+ return rowClass;
345
+ }
346
+ returnClassChip(rowData, col) {
347
+ return `chip-style w-auto border-round-2xl p-2 text-${this.retornarRow(rowData, col, 'stylechip')} border-${this.retornarRow(rowData, col, 'stylechip')}`;
348
+ }
349
+ returnClassIcon(rowData, col) {
350
+ return this.retornarRow(rowData, col, 'iconrow');
351
+ }
352
+ returnTooltipIcon(rowData, col) {
353
+ return this.retornarRow(rowData, col, 'tooltipiconrow');
354
+ }
355
+ isDisabledCheckbox(rowData) {
356
+ return this.config.disableControlCheckboxFunction
357
+ ? this.config.disableControlCheckboxFunction(rowData)
358
+ : false;
359
+ }
360
+ loadImage(rowData, col) {
361
+ /*
362
+ Nossa coluna de imagem trabalha com strings do tipo: base64 ou url
363
+ */
364
+ let retorno = `data:image/jpg;base64, ${imgDefault}`;
365
+ if (rowData && col && rowData[col.field] && rowData[col.field] !== '') {
366
+ if (rowData[col.field].includes('http'))
367
+ retorno = rowData[col.field];
368
+ else
369
+ retorno = `data:image/jpg;base64, ${rowData[col.field]}`;
370
+ }
371
+ return retorno;
372
+ }
373
+ onSwitchChange(estado, rowData, col) {
374
+ this.onSwitchTableChange.emit({
375
+ estado: estado,
376
+ rowData: rowData,
377
+ col: col,
378
+ });
379
+ }
380
+ paginate(event) {
381
+ if (event) {
382
+ let paginaInicial = (event?.first > 0 ? event.first / event.rows : event.first) + 1;
383
+ let termoPesquisa = '';
384
+ let ordenacao = '';
385
+ if (event.globalFilter)
386
+ termoPesquisa = event.globalFilter;
387
+ if (event.sortField)
388
+ ordenacao = `${event.sortField} ${event.sortOrder === 1 ? 'ASC' : 'DESC'}`;
389
+ const objeto = {
390
+ paginaInicial: paginaInicial,
391
+ tamanhoPagina: event.rows,
392
+ termoPesquisa: termoPesquisa,
393
+ ordenacao: ordenacao,
394
+ };
395
+ this.onPaginate.emit(objeto);
396
+ }
397
+ }
398
+ selectionChange(value) {
399
+ this.onSelectionChange.emit(value);
400
+ }
401
+ expandAll() {
402
+ this.expandedRows = this.dataSource.reduce((acc, p) => (acc[p[this.config.fieldGroup || 0]] = true) && acc, {});
403
+ }
404
+ collapseAll() {
405
+ this.expandedRows = {};
406
+ }
407
+ createDataIndex() {
408
+ this.tableData.forEach((item) => {
409
+ this.dataIndex[item.data] = item;
410
+ });
411
+ }
412
+ returnRowDataActions(rowData) {
413
+ // let item = this.tableData.find((item: any) => item?.data === rowData);
414
+ let item = this.dataIndex[rowData];
415
+ if (item?.actions)
416
+ this.menuItems = item?.actions;
417
+ }
418
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTableExpandableComponent, deps: [{ token: i1.DatePipe }, { token: i1.DecimalPipe }, { token: i2.CpfCnpjPipe }, { token: i3.TelefonePipe }], target: i0.ɵɵFactoryTarget.Component }); }
419
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvTableExpandableComponent, selector: "kv-table-expandable", inputs: { _templates: ["templates", "_templates"], setConfig: ["config", "setConfig"], filtrosAvancados: "filtrosAvancados", dataSource: "dataSource", selectedItems: "selectedItems", tableCaptalized: "tableCaptalized", applyStyle: "applyStyle", tableSize: "tableSize", paginator: "paginator", rows: "rows", rowsPerPageOptions: "rowsPerPageOptions", totalRecords: "totalRecords", pageLinksOptions: "pageLinksOptions", responsiveLayout: "responsiveLayout", isTableScrollable: "isTableScrollable", scrollHeight: "scrollHeight", rowTrackBy: "rowTrackBy", showFirstLastIcon: "showFirstLastIcon" }, outputs: { filterField: "filterField", onActiveItem: "onActiveItem", onActiveItemLote: "onActiveItemLote", doubleClickEvent: "doubleClickEvent", onSwitchTableChange: "onSwitchTableChange", onPaginate: "onPaginate", onSelectionChange: "onSelectionChange" }, ngImport: i0, template: "<div>\r\n @if (filtrosAvancados) {\r\n <p-panel\r\n header=\"Filtros avan\u00E7ados\"\r\n [toggleable]=\"true\"\r\n [collapsed]=\"true\"\r\n (collapsedChange)=\"collapsed = !collapsed\"\r\n [style]=\"{ 'margin-bottom': '2px' }\"\r\n >\r\n <ng-template pTemplate=\"headericons\">\r\n @if (!collapsed) {\r\n <i class=\"pi pi-filter\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 aberto -->\r\n @if (collapsed) {\r\n <i class=\"pi pi-minus\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 fechado -->\r\n </ng-template>\r\n <ng-content></ng-content>\r\n </p-panel>\r\n } @if (config) {\r\n <p-table\r\n #dt\r\n styleClass=\"p-datatable-sm\"\r\n [value]=\"dataSource\"\r\n [(selection)]=\"selectedItems\"\r\n [rowSelectable]=\"isRowSelectable\"\r\n rowGroupMode=\"subheader\"\r\n [groupRowsBy]=\"config.fieldGroup\"\r\n [columns]=\"config.columns\"\r\n [lazy]=\"config.lazy\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n (selectionChange)=\"selectionChange($event)\"\r\n sortField=\"representative.name\"\r\n sortMode=\"single\"\r\n dataKey=\"representative.name\"\r\n [expandedRowKeys]=\"expandedRows\"\r\n [paginator]=\"paginator\"\r\n [rows]=\"rows\"\r\n [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n [totalRecords]=\"totalRecords\"\r\n [globalFilterFields]=\"globalFilterFields\"\r\n [showCurrentPageReport]=\"true\"\r\n currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n [rowHover]=\"true\"\r\n [pageLinks]=\"pageLinksOptions\"\r\n [responsive]=\"true\"\r\n [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n [scrollable]=\"isTableScrollable\"\r\n [scrollHeight]=\"scrollHeight\"\r\n [rowTrackBy]=\"rowTrackBy\"\r\n [showFirstLastIcon]=\"showFirstLastIcon\"\r\n >\r\n @if (config.enableCation) {\r\n <ng-template pTemplate=\"caption\">\r\n <div\r\n class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\"\r\n >\r\n <div class=\"col-12 flex flex-column\">\r\n @if (config.title) {\r\n <div class=\"text-md font-bold my-3\">\r\n {{ config.title }}\r\n </div>\r\n } @if (config.subtitle) {\r\n <div class=\"text-sm mb-4 font-medium\">\r\n {{ config.subtitle }}\r\n </div>\r\n }\r\n </div>\r\n\r\n <div\r\n class=\"flex flex-row align-items-center md:col-6 lg:col-4 {{\r\n tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n }} mt-1 mb-2 \"\r\n >\r\n @if (config.enableFilter) {\r\n <span class=\"p-input-icon-left\">\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(dt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2rem\"\r\n />\r\n </span>\r\n }\r\n\r\n <!-- <div\r\n #menuFiltroDiv\r\n id = \"menuFiltroDiv\"\r\n [style.visibility]=\"'hidden'\"\r\n class=\"absolute z-4 bg-gray-200\"\r\n (click)=\"onClickEvent($event)\"\r\n > -->\r\n\r\n <div\r\n #menuFiltroDiv\r\n id=\"menuFiltroDiv\"\r\n [style.visibility]=\"'hidden'\"\r\n class=\"absolute z-4 bg-gray-200 menu-columns-filtro\"\r\n >\r\n <p-card>\r\n @for (col of columns; track col) {\r\n <div class=\"flex flex-column text-medium w-15rem\">\r\n {{ checkMenuFiltro(col) }}\r\n @if (!dinamicDisableColumn(col)) {\r\n <p-checkbox\r\n #filterColumns\r\n [label]=\"col.header\"\r\n [binary]=\"true\"\r\n class=\"checkbox-container\"\r\n (onChange)=\"dinamicColumnSet($event, col)\"\r\n [(ngModel)]=\"col.checked\"\r\n ></p-checkbox>\r\n }\r\n </div>\r\n }\r\n </p-card>\r\n </div>\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end\">\r\n @for (action of config.actionsLote; track i; let i = $index) {\r\n <div class=\"btns-options\" [style]=\"{ 'margin-right': '7px' }\">\r\n @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n <button\r\n id=\"actionLoteBtns\"\r\n pButton\r\n class=\"actionLoteBtns p-button-raised p-button-text\"\r\n (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n style=\"background-color: #1da750\"\r\n [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n [tooltipPosition]=\"\r\n (getOrExecute(action.tooltip, selectedItems)?.length ??\r\n 0 > 7) &&\r\n config.actionsLote &&\r\n i == config.actionsLote.length - 1\r\n ? 'left'\r\n : 'bottom'\r\n \"\r\n [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n style=\"color: white\"\r\n >\r\n {{ getOrExecute(action.icon, selectedItems) }}\r\n </span>\r\n </button>\r\n }\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </ng-template>\r\n } @if (config.enableSelect){\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th colspan=\"12\">\r\n <div class=\"w-full\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"isAllSelected()\"\r\n [indeterminate]=\"isAllIndeterminate()\"\r\n (click)=\"selectAll($event)\"\r\n />\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n }\r\n\r\n <ng-template\r\n pTemplate=\"groupheader\"\r\n let-group\r\n let-rowIndex=\"rowIndex\"\r\n let-expanded=\"expanded\"\r\n >\r\n <tr>\r\n <td colspan=\"12\" class=\"groupheader\">\r\n <div class=\"flex flex-row align-items-center w-full\">\r\n <button\r\n type=\"button\"\r\n pButton\r\n pRipple\r\n [pRowToggler]=\"group\"\r\n class=\"p-button-text p-button-rounded p-button-plain mr-2\"\r\n [icon]=\"expanded ? 'pi pi-chevron-down' : 'pi pi-chevron-right'\"\r\n ></button>\r\n @if (config.fieldGroupColorFunction){\r\n <div\r\n class=\"tag\"\r\n [style.background-color]=\"config.fieldGroupColorFunction(group)\"\r\n ></div>\r\n }\r\n <span class=\"font-bold ml-2\">{{\r\n group[config.fieldGroup || 0]\r\n }}</span>\r\n </div>\r\n </td>\r\n </tr>\r\n @if(expanded){\r\n <tr class=\"p-datatable-header\" style=\"height: 40px\">\r\n @if (config.enableSelect) {\r\n <th>\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"isAllGroupSelected(config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n [indeterminate]=\"isGroupIndeterminate(config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n (click)=\"selectGroup($event, config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n />\r\n </th>\r\n } @for (col of columns; track $index) {\r\n <th\r\n [pSortableColumn]=\"'data.' + col.field\"\r\n [pSortableColumnDisabled]=\"col.sortable === false\"\r\n [style.width]=\"col.width\"\r\n class=\"text-sm\"\r\n >\r\n <div\r\n [class]=\"\r\n centralizarColunas(col) && alignColunasHeader(col) == ''\r\n ? 'flex flex-row justify-content-center'\r\n : 'flex flex-row'\r\n \"\r\n [style]=\"alignColunasHeader(col)\"\r\n >\r\n <span>{{ col.header }}</span>\r\n @if (col.sortable) {\r\n <p-sortIcon\r\n [field]=\"'data.' + col.field\"\r\n style=\"font-size: 10px\"\r\n ></p-sortIcon>\r\n } @if (col.headerTooltip) {\r\n <span\r\n class=\"material-symbols-outlined flex align-items-center\"\r\n [pTooltip]=\"col.headerTooltip\"\r\n >info</span\r\n >\r\n }\r\n </div>\r\n </th>\r\n } @if (config.actions && config.actions.length > 0) {\r\n <th></th>\r\n }\r\n </tr>\r\n }\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"rowexpansion\" let-group>\r\n <tr\r\n (dblclick)=\"doubleClick($event, group)\"\r\n [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n >\r\n @if (config.enableSelect) {\r\n <td [style]=\"applyStyle(group, { field: 'check-box', header: '' })\">\r\n <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(group.data)\"-->\r\n <!-- <p-tableCheckbox\r\n [value]=\"group\"\r\n [disabled]=\"isDisabledCheckbox(group)\"\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableCheckbox>\r\n -->\r\n <input\r\n type=\"checkbox\"\r\n [value]=\"group\"\r\n [checked]=\"isSelected(group)\"\r\n (click)=\"selectItem($event, group)\"\r\n />\r\n </td>\r\n } @for (col of columns; track $index) {\r\n <ng-container>\r\n @if (!col.template) {\r\n <td\r\n class=\"rowTable\"\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n [pTooltip]=\"returnTooltipRow(group, col)\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n\r\n <span\r\n *ngIf=\"!isBooleanField(group, col); else booleanField\"\r\n [class]=\"returnRowClass(group, col)\"\r\n >\r\n @if (!isChipField(col) && !col.iconField && !isImageField(col)) {\r\n <span>\r\n @if (col.icon) {\r\n <i [class]=\"col.icon + ' mr-2'\"></i>\r\n }\r\n {{ transformValue(group, col) }}\r\n </span>\r\n } @if (isChipField(col) && !col.iconField) {\r\n <div>\r\n <span\r\n [class]=\"returnClassChip(group, col)\"\r\n [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n >{{ transformValue(group, col) }}</span\r\n >\r\n </div>\r\n }\r\n </span>\r\n\r\n @if (isImageField(col)) {\r\n <span>\r\n <span>\r\n <img class=\"image\" [src]=\"loadImage(group, col)\" />\r\n </span>\r\n </span>\r\n } @if (col.iconField) {\r\n <i\r\n [ngClass]=\"{\r\n 'material-icons': col.indIconMaterial,\r\n 'material-symbols-outlined mr-2': !col.indIconMaterial\r\n }\"\r\n [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n >\r\n {{ returnClassIcon(group, col) }}\r\n </i>\r\n }\r\n\r\n <ng-template #booleanField>\r\n @if (!col.iconField && !isSwitchField(col)) {\r\n <i\r\n [ngClass]=\"group[col.field] ? 'text-green-500' : 'text-red-500'\"\r\n ><span class=\"material-symbols-outlined\">\r\n {{ group[col.field] ? \"check\" : \"close\" }}\r\n </span>\r\n </i>\r\n } @if (isSwitchField(col)) {\r\n <span [class]=\"returnRowClass(group, col)\">\r\n <kv-switch\r\n (onSwitchChange)=\"onSwitchChange($event, group, col)\"\r\n [disabled]=\"col?.onlyReadField ?? true\"\r\n [switchValue]=\"transformValue(group, col)\"\r\n >\r\n </kv-switch>\r\n </span>\r\n }\r\n </ng-template>\r\n </td>\r\n } @if (col.template) {\r\n <td\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n class=\"rowTable\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n @if (getCustomTemplate(col.template.name)) {\r\n <ng-container\r\n [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n [ngTemplateOutletContext]=\"{ $implicit: group }\"\r\n />\r\n }\r\n </td>\r\n }\r\n </ng-container>\r\n } @if (config.actions && config.actions.length > 0) {\r\n <td [style]=\"applyStyle(group, { field: 'btns-options', header: '' })\">\r\n <div class=\"flex flex-row justify-content-end w-full\">\r\n <!-- <button\r\n id=\"moreVertBtn\"\r\n pButton\r\n class=\"actionBtns p-button-text p-button-raised\"\r\n (click)=\"menu.toggle($event); activeItem(group)\"\r\n > -->\r\n\r\n <span\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 20px\"\r\n (click)=\"\r\n returnRowDataActions(group);\r\n menu.toggle($event);\r\n activeItem(group)\r\n \"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <!-- </button> -->\r\n\r\n <p-tieredMenu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-tieredMenu>\r\n </div>\r\n </td>\r\n }\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"emptymessage\" let-columns>\r\n <tr>\r\n <td\r\n [attr.colspan]=\"columns.length + 2\"\r\n style=\"text-align: center; border-radius: 10px !important\"\r\n >\r\n <p class=\"font-medium m-0\">Nenhum registro encontrado</p>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n }\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.btns-options{position:relative;left:20px}.actionLoteBtns{align-items:center;background-color:transparent;color:#a9a9a9;display:flex;font-size:16px;width:2rem;height:2rem;top:2px;margin-left:.5rem;justify-content:center;text-decoration:none;text-align:justify;padding:12px}.tag{width:.5rem;height:1.25rem;border-radius:.25rem}input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid #ccc;border-radius:4px;position:relative;cursor:pointer;outline:none}input[type=checkbox]:after{content:\"\";position:absolute;left:5px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0;transition:opacity .2s}input[type=checkbox]:checked{background-color:#007bff;border-color:#007bff}input[type=checkbox]:checked:after{opacity:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i5.AutoFocus, selector: "[pAutoFocus]", inputs: ["autofocus"] }, { kind: "directive", type: i6.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i7.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i8.Card, selector: "p-card", inputs: ["header", "subheader", "style", "styleClass"] }, { kind: "component", type: i9.Checkbox, selector: "p-checkbox", inputs: ["value", "name", "disabled", "binary", "label", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "style", "styleClass", "labelStyleClass", "formControl", "checkboxIcon", "readonly", "required", "autofocus", "trueValue", "falseValue", "variant"], outputs: ["onChange", "onFocus", "onBlur"] }, { kind: "directive", type: i10.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "component", type: i11.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }, { kind: "directive", type: i12.Ripple, selector: "[pRipple]" }, { kind: "component", type: i13.TieredMenu, selector: "p-tieredMenu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "autoDisplay", "showTransitionOptions", "hideTransitionOptions", "id", "ariaLabel", "ariaLabelledBy", "disabled", "tabindex"], outputs: ["onShow", "onHide"] }, { kind: "component", type: i14.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll", "virtualRowHeight"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i14.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "directive", type: i14.RowToggler, selector: "[pRowToggler]", inputs: ["pRowToggler", "pRowTogglerDisabled"] }, { kind: "component", type: i14.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "directive", type: i15.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i15.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i16.KvSwitchComponent, selector: "kv-switch", inputs: ["readonly", "switchValue"], outputs: ["onSwitchChange"] }] }); }
420
+ }
421
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTableExpandableComponent, decorators: [{
422
+ type: Component,
423
+ args: [{ selector: 'kv-table-expandable', template: "<div>\r\n @if (filtrosAvancados) {\r\n <p-panel\r\n header=\"Filtros avan\u00E7ados\"\r\n [toggleable]=\"true\"\r\n [collapsed]=\"true\"\r\n (collapsedChange)=\"collapsed = !collapsed\"\r\n [style]=\"{ 'margin-bottom': '2px' }\"\r\n >\r\n <ng-template pTemplate=\"headericons\">\r\n @if (!collapsed) {\r\n <i class=\"pi pi-filter\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 aberto -->\r\n @if (collapsed) {\r\n <i class=\"pi pi-minus\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 fechado -->\r\n </ng-template>\r\n <ng-content></ng-content>\r\n </p-panel>\r\n } @if (config) {\r\n <p-table\r\n #dt\r\n styleClass=\"p-datatable-sm\"\r\n [value]=\"dataSource\"\r\n [(selection)]=\"selectedItems\"\r\n [rowSelectable]=\"isRowSelectable\"\r\n rowGroupMode=\"subheader\"\r\n [groupRowsBy]=\"config.fieldGroup\"\r\n [columns]=\"config.columns\"\r\n [lazy]=\"config.lazy\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n (selectionChange)=\"selectionChange($event)\"\r\n sortField=\"representative.name\"\r\n sortMode=\"single\"\r\n dataKey=\"representative.name\"\r\n [expandedRowKeys]=\"expandedRows\"\r\n [paginator]=\"paginator\"\r\n [rows]=\"rows\"\r\n [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n [totalRecords]=\"totalRecords\"\r\n [globalFilterFields]=\"globalFilterFields\"\r\n [showCurrentPageReport]=\"true\"\r\n currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n [rowHover]=\"true\"\r\n [pageLinks]=\"pageLinksOptions\"\r\n [responsive]=\"true\"\r\n [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n [scrollable]=\"isTableScrollable\"\r\n [scrollHeight]=\"scrollHeight\"\r\n [rowTrackBy]=\"rowTrackBy\"\r\n [showFirstLastIcon]=\"showFirstLastIcon\"\r\n >\r\n @if (config.enableCation) {\r\n <ng-template pTemplate=\"caption\">\r\n <div\r\n class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\"\r\n >\r\n <div class=\"col-12 flex flex-column\">\r\n @if (config.title) {\r\n <div class=\"text-md font-bold my-3\">\r\n {{ config.title }}\r\n </div>\r\n } @if (config.subtitle) {\r\n <div class=\"text-sm mb-4 font-medium\">\r\n {{ config.subtitle }}\r\n </div>\r\n }\r\n </div>\r\n\r\n <div\r\n class=\"flex flex-row align-items-center md:col-6 lg:col-4 {{\r\n tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n }} mt-1 mb-2 \"\r\n >\r\n @if (config.enableFilter) {\r\n <span class=\"p-input-icon-left\">\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(dt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2rem\"\r\n />\r\n </span>\r\n }\r\n\r\n <!-- <div\r\n #menuFiltroDiv\r\n id = \"menuFiltroDiv\"\r\n [style.visibility]=\"'hidden'\"\r\n class=\"absolute z-4 bg-gray-200\"\r\n (click)=\"onClickEvent($event)\"\r\n > -->\r\n\r\n <div\r\n #menuFiltroDiv\r\n id=\"menuFiltroDiv\"\r\n [style.visibility]=\"'hidden'\"\r\n class=\"absolute z-4 bg-gray-200 menu-columns-filtro\"\r\n >\r\n <p-card>\r\n @for (col of columns; track col) {\r\n <div class=\"flex flex-column text-medium w-15rem\">\r\n {{ checkMenuFiltro(col) }}\r\n @if (!dinamicDisableColumn(col)) {\r\n <p-checkbox\r\n #filterColumns\r\n [label]=\"col.header\"\r\n [binary]=\"true\"\r\n class=\"checkbox-container\"\r\n (onChange)=\"dinamicColumnSet($event, col)\"\r\n [(ngModel)]=\"col.checked\"\r\n ></p-checkbox>\r\n }\r\n </div>\r\n }\r\n </p-card>\r\n </div>\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end\">\r\n @for (action of config.actionsLote; track i; let i = $index) {\r\n <div class=\"btns-options\" [style]=\"{ 'margin-right': '7px' }\">\r\n @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n <button\r\n id=\"actionLoteBtns\"\r\n pButton\r\n class=\"actionLoteBtns p-button-raised p-button-text\"\r\n (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n style=\"background-color: #1da750\"\r\n [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n [tooltipPosition]=\"\r\n (getOrExecute(action.tooltip, selectedItems)?.length ??\r\n 0 > 7) &&\r\n config.actionsLote &&\r\n i == config.actionsLote.length - 1\r\n ? 'left'\r\n : 'bottom'\r\n \"\r\n [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n style=\"color: white\"\r\n >\r\n {{ getOrExecute(action.icon, selectedItems) }}\r\n </span>\r\n </button>\r\n }\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </ng-template>\r\n } @if (config.enableSelect){\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th colspan=\"12\">\r\n <div class=\"w-full\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"isAllSelected()\"\r\n [indeterminate]=\"isAllIndeterminate()\"\r\n (click)=\"selectAll($event)\"\r\n />\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n }\r\n\r\n <ng-template\r\n pTemplate=\"groupheader\"\r\n let-group\r\n let-rowIndex=\"rowIndex\"\r\n let-expanded=\"expanded\"\r\n >\r\n <tr>\r\n <td colspan=\"12\" class=\"groupheader\">\r\n <div class=\"flex flex-row align-items-center w-full\">\r\n <button\r\n type=\"button\"\r\n pButton\r\n pRipple\r\n [pRowToggler]=\"group\"\r\n class=\"p-button-text p-button-rounded p-button-plain mr-2\"\r\n [icon]=\"expanded ? 'pi pi-chevron-down' : 'pi pi-chevron-right'\"\r\n ></button>\r\n @if (config.fieldGroupColorFunction){\r\n <div\r\n class=\"tag\"\r\n [style.background-color]=\"config.fieldGroupColorFunction(group)\"\r\n ></div>\r\n }\r\n <span class=\"font-bold ml-2\">{{\r\n group[config.fieldGroup || 0]\r\n }}</span>\r\n </div>\r\n </td>\r\n </tr>\r\n @if(expanded){\r\n <tr class=\"p-datatable-header\" style=\"height: 40px\">\r\n @if (config.enableSelect) {\r\n <th>\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"isAllGroupSelected(config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n [indeterminate]=\"isGroupIndeterminate(config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n (click)=\"selectGroup($event, config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n />\r\n </th>\r\n } @for (col of columns; track $index) {\r\n <th\r\n [pSortableColumn]=\"'data.' + col.field\"\r\n [pSortableColumnDisabled]=\"col.sortable === false\"\r\n [style.width]=\"col.width\"\r\n class=\"text-sm\"\r\n >\r\n <div\r\n [class]=\"\r\n centralizarColunas(col) && alignColunasHeader(col) == ''\r\n ? 'flex flex-row justify-content-center'\r\n : 'flex flex-row'\r\n \"\r\n [style]=\"alignColunasHeader(col)\"\r\n >\r\n <span>{{ col.header }}</span>\r\n @if (col.sortable) {\r\n <p-sortIcon\r\n [field]=\"'data.' + col.field\"\r\n style=\"font-size: 10px\"\r\n ></p-sortIcon>\r\n } @if (col.headerTooltip) {\r\n <span\r\n class=\"material-symbols-outlined flex align-items-center\"\r\n [pTooltip]=\"col.headerTooltip\"\r\n >info</span\r\n >\r\n }\r\n </div>\r\n </th>\r\n } @if (config.actions && config.actions.length > 0) {\r\n <th></th>\r\n }\r\n </tr>\r\n }\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"rowexpansion\" let-group>\r\n <tr\r\n (dblclick)=\"doubleClick($event, group)\"\r\n [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n >\r\n @if (config.enableSelect) {\r\n <td [style]=\"applyStyle(group, { field: 'check-box', header: '' })\">\r\n <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(group.data)\"-->\r\n <!-- <p-tableCheckbox\r\n [value]=\"group\"\r\n [disabled]=\"isDisabledCheckbox(group)\"\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableCheckbox>\r\n -->\r\n <input\r\n type=\"checkbox\"\r\n [value]=\"group\"\r\n [checked]=\"isSelected(group)\"\r\n (click)=\"selectItem($event, group)\"\r\n />\r\n </td>\r\n } @for (col of columns; track $index) {\r\n <ng-container>\r\n @if (!col.template) {\r\n <td\r\n class=\"rowTable\"\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n [pTooltip]=\"returnTooltipRow(group, col)\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n\r\n <span\r\n *ngIf=\"!isBooleanField(group, col); else booleanField\"\r\n [class]=\"returnRowClass(group, col)\"\r\n >\r\n @if (!isChipField(col) && !col.iconField && !isImageField(col)) {\r\n <span>\r\n @if (col.icon) {\r\n <i [class]=\"col.icon + ' mr-2'\"></i>\r\n }\r\n {{ transformValue(group, col) }}\r\n </span>\r\n } @if (isChipField(col) && !col.iconField) {\r\n <div>\r\n <span\r\n [class]=\"returnClassChip(group, col)\"\r\n [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n >{{ transformValue(group, col) }}</span\r\n >\r\n </div>\r\n }\r\n </span>\r\n\r\n @if (isImageField(col)) {\r\n <span>\r\n <span>\r\n <img class=\"image\" [src]=\"loadImage(group, col)\" />\r\n </span>\r\n </span>\r\n } @if (col.iconField) {\r\n <i\r\n [ngClass]=\"{\r\n 'material-icons': col.indIconMaterial,\r\n 'material-symbols-outlined mr-2': !col.indIconMaterial\r\n }\"\r\n [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n >\r\n {{ returnClassIcon(group, col) }}\r\n </i>\r\n }\r\n\r\n <ng-template #booleanField>\r\n @if (!col.iconField && !isSwitchField(col)) {\r\n <i\r\n [ngClass]=\"group[col.field] ? 'text-green-500' : 'text-red-500'\"\r\n ><span class=\"material-symbols-outlined\">\r\n {{ group[col.field] ? \"check\" : \"close\" }}\r\n </span>\r\n </i>\r\n } @if (isSwitchField(col)) {\r\n <span [class]=\"returnRowClass(group, col)\">\r\n <kv-switch\r\n (onSwitchChange)=\"onSwitchChange($event, group, col)\"\r\n [disabled]=\"col?.onlyReadField ?? true\"\r\n [switchValue]=\"transformValue(group, col)\"\r\n >\r\n </kv-switch>\r\n </span>\r\n }\r\n </ng-template>\r\n </td>\r\n } @if (col.template) {\r\n <td\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n class=\"rowTable\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n @if (getCustomTemplate(col.template.name)) {\r\n <ng-container\r\n [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n [ngTemplateOutletContext]=\"{ $implicit: group }\"\r\n />\r\n }\r\n </td>\r\n }\r\n </ng-container>\r\n } @if (config.actions && config.actions.length > 0) {\r\n <td [style]=\"applyStyle(group, { field: 'btns-options', header: '' })\">\r\n <div class=\"flex flex-row justify-content-end w-full\">\r\n <!-- <button\r\n id=\"moreVertBtn\"\r\n pButton\r\n class=\"actionBtns p-button-text p-button-raised\"\r\n (click)=\"menu.toggle($event); activeItem(group)\"\r\n > -->\r\n\r\n <span\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 20px\"\r\n (click)=\"\r\n returnRowDataActions(group);\r\n menu.toggle($event);\r\n activeItem(group)\r\n \"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <!-- </button> -->\r\n\r\n <p-tieredMenu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-tieredMenu>\r\n </div>\r\n </td>\r\n }\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"emptymessage\" let-columns>\r\n <tr>\r\n <td\r\n [attr.colspan]=\"columns.length + 2\"\r\n style=\"text-align: center; border-radius: 10px !important\"\r\n >\r\n <p class=\"font-medium m-0\">Nenhum registro encontrado</p>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n }\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.btns-options{position:relative;left:20px}.actionLoteBtns{align-items:center;background-color:transparent;color:#a9a9a9;display:flex;font-size:16px;width:2rem;height:2rem;top:2px;margin-left:.5rem;justify-content:center;text-decoration:none;text-align:justify;padding:12px}.tag{width:.5rem;height:1.25rem;border-radius:.25rem}input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid #ccc;border-radius:4px;position:relative;cursor:pointer;outline:none}input[type=checkbox]:after{content:\"\";position:absolute;left:5px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0;transition:opacity .2s}input[type=checkbox]:checked{background-color:#007bff;border-color:#007bff}input[type=checkbox]:checked:after{opacity:1}\n"] }]
424
+ }], ctorParameters: () => [{ type: i1.DatePipe }, { type: i1.DecimalPipe }, { type: i2.CpfCnpjPipe }, { type: i3.TelefonePipe }], propDecorators: { _templates: [{
425
+ type: Input,
426
+ args: ['templates']
427
+ }], setConfig: [{
428
+ type: Input,
429
+ args: ['config']
430
+ }], filtrosAvancados: [{
431
+ type: Input
432
+ }], dataSource: [{
433
+ type: Input
434
+ }], selectedItems: [{
435
+ type: Input
436
+ }], tableCaptalized: [{
437
+ type: Input
438
+ }], applyStyle: [{
439
+ type: Input
440
+ }], tableSize: [{
441
+ type: Input
442
+ }], paginator: [{
443
+ type: Input
444
+ }], rows: [{
445
+ type: Input
446
+ }], rowsPerPageOptions: [{
447
+ type: Input
448
+ }], totalRecords: [{
449
+ type: Input
450
+ }], pageLinksOptions: [{
451
+ type: Input
452
+ }], responsiveLayout: [{
453
+ type: Input
454
+ }], isTableScrollable: [{
455
+ type: Input
456
+ }], scrollHeight: [{
457
+ type: Input
458
+ }], rowTrackBy: [{
459
+ type: Input
460
+ }], showFirstLastIcon: [{
461
+ type: Input
462
+ }], filterField: [{
463
+ type: Output
464
+ }], onActiveItem: [{
465
+ type: Output
466
+ }], onActiveItemLote: [{
467
+ type: Output
468
+ }], doubleClickEvent: [{
469
+ type: Output
470
+ }], onSwitchTableChange: [{
471
+ type: Output
472
+ }], onPaginate: [{
473
+ type: Output
474
+ }], onSelectionChange: [{
475
+ type: Output
476
+ }] } });
477
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-table-expandable.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-table-expandable/kv-table-expandable.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-table-expandable/kv-table-expandable.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  DoCheck,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n} from '@angular/core';\r\nimport { TableConfig } from '../../api/components/table/table.config';\r\nimport { Table } from 'primeng/table';\r\nimport { TableConfigColumn } from '../../api/components/table/table.config.column';\r\nimport {\r\n  ValueOrFn,\r\n  getOrExecute,\r\n  mapToMenuItem,\r\n} from '../../api/components/table/kv-menuitem';\r\nimport { DatePipe, DecimalPipe } from '@angular/common';\r\nimport { CpfCnpjPipe } from '../../api/pipes/cpfcnpj.pipe';\r\nimport { TelefonePipe } from '../../api/pipes/telefone.pipe';\r\nimport { MenuItem } from 'primeng/api';\r\nimport { TablePaginate } from '../../api/components/table/table.paginate';\r\n\r\nconst imgDefault =\r\n  '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';\r\n\r\n@Component({\r\n  selector: 'kv-table-expandable',\r\n  templateUrl: './kv-table-expandable.component.html',\r\n  styleUrl: './kv-table-expandable.component.scss',\r\n})\r\nexport class KvTableExpandableComponent implements OnInit, DoCheck {\r\n  expandedRows: any = {};\r\n  config!: TableConfig;\r\n  globalFilterFields: string[] = [];\r\n  tamanhoTela!: number;\r\n  columns: TableConfigColumn[] = [];\r\n  deletedColuns: TableConfigColumn[] = [];\r\n  dataIndex: { [key: string]: any } = {};\r\n  menuItems!: MenuItem[];\r\n\r\n  collapsed: boolean = false;\r\n  tableData: { data: any; actions?: MenuItem[] }[] = [];\r\n  currDataSource: any[] = [];\r\n\r\n  @Input('templates') _templates!: any;\r\n\r\n  @Input('config') set setConfig(value: TableConfig) {\r\n    this.config = {\r\n      enableCation: value.enableCation || true,\r\n      enableSelect: value.enableSelect || false,\r\n      enableFilter: value.enableFilter || true,\r\n      ...value,\r\n    };\r\n\r\n    if (this.config.enableFilter) {\r\n      this.config.columns.forEach((col) => {\r\n        this.globalFilterFields.push('data.' + col.field);\r\n      });\r\n    }\r\n  }\r\n\r\n  @Input() filtrosAvancados: boolean = false;\r\n  @Input() dataSource: any[] = [];\r\n  @Input() selectedItems: any[] = [];\r\n  @Input() tableCaptalized: boolean = false;\r\n  @Input() applyStyle: Function = (rowData: any, col: TableConfigColumn) => '';\r\n  @Input() tableSize!: number;\r\n  @Input() paginator: boolean = true;\r\n  @Input() rows: number = 5;\r\n  @Input() rowsPerPageOptions!: number[];\r\n  @Input() totalRecords!: number;\r\n  @Input() pageLinksOptions: number = 1;\r\n  @Input() responsiveLayout: boolean = true;\r\n  @Input() isTableScrollable: boolean = false;\r\n  @Input() scrollHeight: string = '';\r\n  @Input() rowTrackBy: Function = (index: number, item: any) => item;\r\n  @Input() showFirstLastIcon: boolean = false;\r\n\r\n  @Output() filterField: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSwitchTableChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<TablePaginate> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(\r\n    private readonly datePipe: DatePipe,\r\n    private readonly decimalPipe: DecimalPipe,\r\n    private readonly cpfCnpjPipe: CpfCnpjPipe,\r\n    private readonly telefonePipe: TelefonePipe\r\n  ) {\r\n    this.isRowSelectable = this.isRowSelectable.bind(this);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.tamanhoTela = window.innerWidth;\r\n    this.adicionaAcoesTabela();\r\n    this.config.columns.forEach((col: any) => {\r\n      this.columns.push(col);\r\n    });\r\n  }\r\n\r\n  ngDoCheck(): void {\r\n    if (\r\n      JSON.stringify(this.dataSource) !== JSON.stringify(this.currDataSource)\r\n    ) {\r\n      if (this.dataSource) {\r\n        this.tableData = this.dataSource.map((x) => ({\r\n          data: x,\r\n          actions: this.config.actions\r\n            ? this.config.actions.map((y) => mapToMenuItem(y, x))\r\n            : undefined,\r\n        }));\r\n        this.currDataSource = [...this.dataSource];\r\n        this.createDataIndex();\r\n      }\r\n    }\r\n  }\r\n\r\n  public onGlobalFilter(table: Table, event: Event) {\r\n    this.filterField.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  adicionaAcoesTabela() {\r\n    this.config.actionsLote?.unshift(\r\n      {\r\n        icon: 'collapse_all',\r\n        tooltip: 'Collapse',\r\n        command: () => {\r\n          this.collapseAll();\r\n        },\r\n        showAcoesLote: true,\r\n      },\r\n      {\r\n        icon: 'expand_all',\r\n        tooltip: 'Expand',\r\n        command: () => {\r\n          this.expandAll();\r\n        },\r\n        showAcoesLote: true,\r\n      }\r\n    );\r\n  }\r\n\r\n  checkMenuFiltro(col: any) {\r\n    let deletedColumn: TableConfigColumn | undefined = this.deletedColuns.find(\r\n      (x: TableConfigColumn) => x.field == col.field\r\n    );\r\n    if (deletedColumn) col.checked = false;\r\n    else col.checked = true;\r\n  }\r\n\r\n  sortByPosition() {\r\n    return function (elem1: any, elem2: any) {\r\n      if (elem1.position < elem2.position) {\r\n        return -1;\r\n      } else if (elem1.position > elem2.position) {\r\n        return 1;\r\n      } else {\r\n        return 0;\r\n      }\r\n    };\r\n  }\r\n\r\n  dinamicDisableColumn(col: TableConfigColumn): boolean {\r\n    if (col.fixedColumn) return col.fixedColumn;\r\n    else return false;\r\n  }\r\n\r\n  dinamicColumnSet(e: any, col: any) {\r\n    col.checked = e.checked;\r\n    if (e.checked) this.addColumn(col.field);\r\n    else this.deleteColumn(col.field);\r\n\r\n    if (col.position) this.config.columns.sort(this.sortByPosition());\r\n  }\r\n\r\n  addColumn(field: string) {\r\n    let index: number;\r\n\r\n    let column: TableConfigColumn | undefined = this.config.columns.find(\r\n      (x) => x.field == field\r\n    );\r\n\r\n    if (!column) {\r\n      let deletedColumn: TableConfigColumn | undefined =\r\n        this.deletedColuns.find((x) => x.field == field);\r\n\r\n      if (deletedColumn != undefined) {\r\n        index = this.deletedColuns.indexOf(deletedColumn);\r\n        this.deletedColuns.slice(index, 1);\r\n        this.config.columns.push(deletedColumn);\r\n      }\r\n    }\r\n  }\r\n\r\n  deleteColumn(field: string) {\r\n    let index: number;\r\n\r\n    let column: TableConfigColumn | undefined = this.config.columns.find(\r\n      (x) => x.field == field\r\n    );\r\n    if (column) {\r\n      index = this.config.columns.indexOf(column);\r\n      this.config.columns.splice(index, 1);\r\n      this.deletedColuns.push(column);\r\n    }\r\n  }\r\n\r\n  doubleClick(e: any, rowData: any) {\r\n    let eventDoubleClick = { event: e, rowData: rowData };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n\r\n  centralizarColunas(col: any): string {\r\n    if (col.centralize) {\r\n      return 'text-align: center';\r\n    } else return '';\r\n  }\r\n\r\n  alignColunas(col: any): string {\r\n    if (col.align) {\r\n      return `text-align: ${col.align}`;\r\n    } else return '';\r\n  }\r\n\r\n  alignColunasHeader(col: any): string {\r\n    if (col.align) {\r\n      if (col.align == 'right') return 'justify-content: end';\r\n      else return '';\r\n    } else return '';\r\n  }\r\n\r\n  retornarRow(rowData: any, col: any, field: string): string {\r\n    const _rowaction = this.config.rows ? this.config.rows[col.field] : null;\r\n    const _field: string =\r\n      _rowaction && _rowaction[field]\r\n        ? _rowaction[field].constructor === Function\r\n          ? _rowaction[field].apply(this, [rowData])\r\n          : _rowaction[field]\r\n        : null;\r\n    return _field;\r\n  }\r\n\r\n  returnTooltipRow(rowData: any, col: any): any {\r\n    return this.retornarRow(rowData, col, 'tooltiprow');\r\n  }\r\n\r\n  getOrExecute<T>(action: ValueOrFn<T>, data: any): T {\r\n    return getOrExecute(action, data);\r\n  }\r\n\r\n  isBooleanField(rowData: any, col: TableConfigColumn): boolean {\r\n    return typeof rowData[col.field] == 'boolean';\r\n  }\r\n\r\n  isChipField(col: TableConfigColumn): boolean {\r\n    return col.fieldType == 'chip';\r\n  }\r\n\r\n  isImageField(col: TableConfigColumn): boolean {\r\n    let retorno = col.fieldType && col.fieldType === 'image' ? true : false;\r\n    return retorno;\r\n  }\r\n\r\n  isSwitchField(col: TableConfigColumn): boolean {\r\n    let retorno = col.fieldType && col.fieldType === 'switch' ? true : false;\r\n    return retorno;\r\n  }\r\n\r\n  isRowSelectable(event: any) {\r\n    return !this.isDisabledCheckbox(event.data);\r\n  }\r\n\r\n  public activeItemLote(selectedItems: any) {\r\n    this.onActiveItemLote.emit(selectedItems);\r\n  }\r\n\r\n  selectItem(event: any, group: any) {\r\n    if (event.target.checked) {\r\n      this.selectedItems = [...this.selectedItems, group];\r\n    } else {\r\n      const index = this.selectedItems.indexOf(group, 0);\r\n      if (index > -1) {\r\n        this.selectedItems.splice(index, 1);\r\n      }\r\n    }\r\n    this.onActiveItemLote.emit(this.selectedItems);\r\n  }\r\n\r\n  isSelected(item: any) {\r\n    // Verifica se o item está presente na lista de itens selecionados\r\n    return this.selectedItems.includes(item);\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  public selectGroup(event: any, grouped: any, valor: any){\r\n    const itensGroup = this.dataSource.filter(x => x[grouped] == valor)\r\n    if (event.target.checked){\r\n      itensGroup.forEach((x) => {\r\n        if (!this.selectedItems.includes(x))\r\n          this.selectedItems = [...this.selectedItems, x]\r\n      })\r\n    } else {\r\n      itensGroup.forEach((x) => {\r\n        if (this.selectedItems.includes(x)){\r\n          const index = this.selectedItems.indexOf(x, 0);\r\n          if (index > -1) {\r\n            this.selectedItems.splice(index, 1);\r\n          }\r\n        }\r\n      })\r\n    }\r\n\r\n    this.onActiveItemLote.emit(this.selectedItems)\r\n  }\r\n\r\n  isAllGroupSelected(grouped: any, valor: any){\r\n    const itensGroup = this.dataSource.filter(x => x[grouped] == valor)\r\n    return itensGroup.every( x => this.selectedItems.includes(x));\r\n  }\r\n\r\n  isGroupIndeterminate(grouped: any, valor: any){\r\n    if(this.isAllGroupSelected(grouped, valor))\r\n      return false;\r\n    const itensGroup = this.dataSource.filter(x => x[grouped] == valor)\r\n    return itensGroup.some( x => this.selectedItems.includes(x));\r\n  }\r\n\r\n  public selectAll(event: any) {\r\n    if (event.target.checked){\r\n      this.selectedItems = this.dataSource;\r\n    } else {\r\n      this.selectedItems = [];\r\n    }\r\n    this.onActiveItemLote.emit(this.selectedItems);\r\n  }\r\n\r\n  isAllIndeterminate(){\r\n    if(this.isAllSelected())\r\n      return false;\r\n    return this.dataSource.some( x => this.selectedItems.includes(x));\r\n  }\r\n\r\n  isAllSelected(){\r\n    return this.dataSource.every( x => this.selectedItems.includes(x));\r\n  }\r\n\r\n  transformValue(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\r\n\r\n    if (value != null) {\r\n      if (!col.pipe) {\r\n        return value;\r\n      }\r\n\r\n      switch (col.pipe) {\r\n        case 'date':\r\n          return this.datePipe.transform(value, 'dd/MM/yyyy');\r\n        case 'dateMonthYear':\r\n          return this.datePipe.transform(value, 'MM/yyyy');\r\n        case 'decimal':\r\n          return this.decimalPipe.transform(value, '1.2-2', 'pt-BR');\r\n        case 'cpfcnpj':\r\n          return this.cpfCnpjPipe.transform(value);\r\n        case 'telefone':\r\n          return this.telefonePipe.transform(value);\r\n        case 'money':\r\n          return this.formatarValor(value);\r\n        case 'percentage':\r\n          return `${value} %`;\r\n\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  getCustomTemplate(templatename: string): TemplateRef<any> {\r\n    return this._templates[templatename];\r\n  }\r\n\r\n  formatarValor(valor: number): string {\r\n    const formatter = new Intl.NumberFormat('pt-BR', {\r\n      style: 'currency',\r\n      currency: 'BRL',\r\n    });\r\n\r\n    return formatter.format(valor);\r\n  }\r\n\r\n  returnRowClass(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\r\n    let rowClass: string;\r\n\r\n    this.tableSize > 800 ? (rowClass = 'text-base') : (rowClass = 'text-sm');\r\n\r\n    if (col.expiredDate == true) {\r\n      new Date(value) < new Date()\r\n        ? (rowClass = rowClass + ' text-red-400 font-semibold')\r\n        : '';\r\n    }\r\n    return rowClass;\r\n  }\r\n\r\n  returnClassChip(rowData: any, col: any): string {\r\n    return `chip-style w-auto border-round-2xl p-2 text-${this.retornarRow(\r\n      rowData,\r\n      col,\r\n      'stylechip'\r\n    )} border-${this.retornarRow(rowData, col, 'stylechip')}`;\r\n  }\r\n\r\n  returnClassIcon(rowData: any, col: any): string {\r\n    return this.retornarRow(rowData, col, 'iconrow');\r\n  }\r\n\r\n  returnTooltipIcon(rowData: any, col: any): string {\r\n    return this.retornarRow(rowData, col, 'tooltipiconrow');\r\n  }\r\n\r\n  isDisabledCheckbox(rowData: any): boolean {\r\n    return this.config.disableControlCheckboxFunction\r\n      ? this.config.disableControlCheckboxFunction(rowData)\r\n      : false;\r\n  }\r\n\r\n  loadImage(rowData: any, col: TableConfigColumn): string {\r\n    /*\r\n      Nossa coluna de imagem trabalha com strings do tipo: base64 ou url\r\n    */\r\n    let retorno = `data:image/jpg;base64, ${imgDefault}`;\r\n    if (rowData && col && rowData[col.field] && rowData[col.field] !== '') {\r\n      if (rowData[col.field].includes('http')) retorno = rowData[col.field];\r\n      else retorno = `data:image/jpg;base64, ${rowData[col.field]}`;\r\n    }\r\n\r\n    return retorno;\r\n  }\r\n\r\n  onSwitchChange(estado: any, rowData: boolean, col: any) {\r\n    this.onSwitchTableChange.emit({\r\n      estado: estado,\r\n      rowData: rowData,\r\n      col: col,\r\n    });\r\n  }\r\n\r\n  public paginate(event: any) {\r\n    if (event) {\r\n      let paginaInicial =\r\n        (event?.first > 0 ? event.first / event.rows : event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if (event.globalFilter) termoPesquisa = event.globalFilter;\r\n\r\n      if (event.sortField)\r\n        ordenacao = `${event.sortField} ${\r\n          event.sortOrder === 1 ? 'ASC' : 'DESC'\r\n        }`;\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao,\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  selectionChange(value: any) {\r\n    this.onSelectionChange.emit(value);\r\n  }\r\n\r\n  expandAll() {\r\n    this.expandedRows = this.dataSource.reduce(\r\n      (acc, p) => (acc[p[this.config.fieldGroup || 0]] = true) && acc,\r\n      {}\r\n    );\r\n  }\r\n\r\n  collapseAll() {\r\n    this.expandedRows = {};\r\n  }\r\n\r\n  createDataIndex(): void {\r\n    this.tableData.forEach((item) => {\r\n      this.dataIndex[item.data] = item;\r\n    });\r\n  }\r\n\r\n  returnRowDataActions(rowData: any) {\r\n    // let item = this.tableData.find((item: any) => item?.data === rowData);\r\n    let item = this.dataIndex[rowData];\r\n\r\n    if (item?.actions) this.menuItems = item?.actions;\r\n  }\r\n}\r\n","<div>\r\n  @if (filtrosAvancados) {\r\n  <p-panel\r\n    header=\"Filtros avançados\"\r\n    [toggleable]=\"true\"\r\n    [collapsed]=\"true\"\r\n    (collapsedChange)=\"collapsed = !collapsed\"\r\n    [style]=\"{ 'margin-bottom': '2px' }\"\r\n  >\r\n    <ng-template pTemplate=\"headericons\">\r\n      @if (!collapsed) {\r\n      <i class=\"pi pi-filter\"></i>\r\n      }\r\n      <!-- Ícone quando o painel está aberto -->\r\n      @if (collapsed) {\r\n      <i class=\"pi pi-minus\"></i>\r\n      }\r\n      <!-- Ícone quando o painel está fechado -->\r\n    </ng-template>\r\n    <ng-content></ng-content>\r\n  </p-panel>\r\n  } @if (config) {\r\n  <p-table\r\n    #dt\r\n    styleClass=\"p-datatable-sm\"\r\n    [value]=\"dataSource\"\r\n    [(selection)]=\"selectedItems\"\r\n    [rowSelectable]=\"isRowSelectable\"\r\n    rowGroupMode=\"subheader\"\r\n    [groupRowsBy]=\"config.fieldGroup\"\r\n    [columns]=\"config.columns\"\r\n    [lazy]=\"config.lazy\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    (selectionChange)=\"selectionChange($event)\"\r\n    sortField=\"representative.name\"\r\n    sortMode=\"single\"\r\n    dataKey=\"representative.name\"\r\n    [expandedRowKeys]=\"expandedRows\"\r\n    [paginator]=\"paginator\"\r\n    [rows]=\"rows\"\r\n    [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n    [totalRecords]=\"totalRecords\"\r\n    [globalFilterFields]=\"globalFilterFields\"\r\n    [showCurrentPageReport]=\"true\"\r\n    currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n    [rowHover]=\"true\"\r\n    [pageLinks]=\"pageLinksOptions\"\r\n    [responsive]=\"true\"\r\n    [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n    [scrollable]=\"isTableScrollable\"\r\n    [scrollHeight]=\"scrollHeight\"\r\n    [rowTrackBy]=\"rowTrackBy\"\r\n    [showFirstLastIcon]=\"showFirstLastIcon\"\r\n  >\r\n    @if (config.enableCation) {\r\n    <ng-template pTemplate=\"caption\">\r\n      <div\r\n        class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\"\r\n      >\r\n        <div class=\"col-12 flex flex-column\">\r\n          @if (config.title) {\r\n          <div class=\"text-md font-bold my-3\">\r\n            {{ config.title }}\r\n          </div>\r\n          } @if (config.subtitle) {\r\n          <div class=\"text-sm mb-4 font-medium\">\r\n            {{ config.subtitle }}\r\n          </div>\r\n          }\r\n        </div>\r\n\r\n        <div\r\n          class=\"flex flex-row align-items-center md:col-6 lg:col-4 {{\r\n            tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n          }} mt-1 mb-2 \"\r\n        >\r\n          @if (config.enableFilter) {\r\n          <span class=\"p-input-icon-left\">\r\n            <i class=\"pi pi-search\"></i>\r\n\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"true\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(dt, $event)\"\r\n              placeholder=\"Pesquisar...\"\r\n              class=\"h-2rem\"\r\n            />\r\n          </span>\r\n          }\r\n\r\n          <!-- <div\r\n            #menuFiltroDiv\r\n            id = \"menuFiltroDiv\"\r\n            [style.visibility]=\"'hidden'\"\r\n            class=\"absolute z-4 bg-gray-200\"\r\n            (click)=\"onClickEvent($event)\"\r\n          > -->\r\n\r\n          <div\r\n            #menuFiltroDiv\r\n            id=\"menuFiltroDiv\"\r\n            [style.visibility]=\"'hidden'\"\r\n            class=\"absolute z-4 bg-gray-200 menu-columns-filtro\"\r\n          >\r\n            <p-card>\r\n              @for (col of columns; track col) {\r\n              <div class=\"flex flex-column text-medium w-15rem\">\r\n                {{ checkMenuFiltro(col) }}\r\n                @if (!dinamicDisableColumn(col)) {\r\n                <p-checkbox\r\n                  #filterColumns\r\n                  [label]=\"col.header\"\r\n                  [binary]=\"true\"\r\n                  class=\"checkbox-container\"\r\n                  (onChange)=\"dinamicColumnSet($event, col)\"\r\n                  [(ngModel)]=\"col.checked\"\r\n                ></p-checkbox>\r\n                }\r\n              </div>\r\n              }\r\n            </p-card>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"flex flex-row col-1 justify-content-end\">\r\n          @for (action of config.actionsLote; track i; let i = $index) {\r\n          <div class=\"btns-options\" [style]=\"{ 'margin-right': '7px' }\">\r\n            @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n            (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n            <button\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              class=\"actionLoteBtns p-button-raised p-button-text\"\r\n              (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n              style=\"background-color: #1da750\"\r\n              [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n              [tooltipPosition]=\"\r\n                (getOrExecute(action.tooltip, selectedItems)?.length ??\r\n                  0 > 7) &&\r\n                config.actionsLote &&\r\n                i == config.actionsLote.length - 1\r\n                  ? 'left'\r\n                  : 'bottom'\r\n              \"\r\n              [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n            >\r\n              <span\r\n                class=\"material-symbols-outlined md-22\"\r\n                style=\"color: white\"\r\n              >\r\n                {{ getOrExecute(action.icon, selectedItems) }}\r\n              </span>\r\n            </button>\r\n            }\r\n          </div>\r\n          }\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    } @if (config.enableSelect){\r\n    <ng-template pTemplate=\"header\">\r\n      <tr>\r\n        <th colspan=\"12\">\r\n          <div class=\"w-full\">\r\n            <!-- <p-tableHeaderCheckbox\r\n              (click)=\"activeItemLote(selectedItems)\"\r\n            ></p-tableHeaderCheckbox> -->\r\n            <input\r\n              type=\"checkbox\"\r\n              [checked]=\"isAllSelected()\"\r\n              [indeterminate]=\"isAllIndeterminate()\"\r\n              (click)=\"selectAll($event)\"\r\n            />\r\n          </div>\r\n        </th>\r\n      </tr>\r\n    </ng-template>\r\n    }\r\n\r\n    <ng-template\r\n      pTemplate=\"groupheader\"\r\n      let-group\r\n      let-rowIndex=\"rowIndex\"\r\n      let-expanded=\"expanded\"\r\n    >\r\n      <tr>\r\n        <td colspan=\"12\" class=\"groupheader\">\r\n          <div class=\"flex flex-row align-items-center w-full\">\r\n            <button\r\n              type=\"button\"\r\n              pButton\r\n              pRipple\r\n              [pRowToggler]=\"group\"\r\n              class=\"p-button-text p-button-rounded p-button-plain mr-2\"\r\n              [icon]=\"expanded ? 'pi pi-chevron-down' : 'pi pi-chevron-right'\"\r\n            ></button>\r\n            @if (config.fieldGroupColorFunction){\r\n            <div\r\n              class=\"tag\"\r\n              [style.background-color]=\"config.fieldGroupColorFunction(group)\"\r\n            ></div>\r\n            }\r\n            <span class=\"font-bold ml-2\">{{\r\n              group[config.fieldGroup || 0]\r\n            }}</span>\r\n          </div>\r\n        </td>\r\n      </tr>\r\n      @if(expanded){\r\n      <tr class=\"p-datatable-header\" style=\"height: 40px\">\r\n        @if (config.enableSelect) {\r\n        <th>\r\n          <!-- <p-tableHeaderCheckbox\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n          ></p-tableHeaderCheckbox> -->\r\n          <input\r\n              type=\"checkbox\"\r\n              [checked]=\"isAllGroupSelected(config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n              [indeterminate]=\"isGroupIndeterminate(config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n              (click)=\"selectGroup($event, config.fieldGroup || 0 , group[config.fieldGroup || 0])\"\r\n            />\r\n        </th>\r\n        } @for (col of columns; track $index) {\r\n        <th\r\n          [pSortableColumn]=\"'data.' + col.field\"\r\n          [pSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.width]=\"col.width\"\r\n          class=\"text-sm\"\r\n        >\r\n          <div\r\n            [class]=\"\r\n              centralizarColunas(col) && alignColunasHeader(col) == ''\r\n                ? 'flex flex-row justify-content-center'\r\n                : 'flex flex-row'\r\n            \"\r\n            [style]=\"alignColunasHeader(col)\"\r\n          >\r\n            <span>{{ col.header }}</span>\r\n            @if (col.sortable) {\r\n            <p-sortIcon\r\n              [field]=\"'data.' + col.field\"\r\n              style=\"font-size: 10px\"\r\n            ></p-sortIcon>\r\n            } @if (col.headerTooltip) {\r\n            <span\r\n              class=\"material-symbols-outlined flex align-items-center\"\r\n              [pTooltip]=\"col.headerTooltip\"\r\n              >info</span\r\n            >\r\n            }\r\n          </div>\r\n        </th>\r\n        } @if (config.actions && config.actions.length > 0) {\r\n        <th></th>\r\n        }\r\n      </tr>\r\n      }\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"rowexpansion\" let-group>\r\n      <tr\r\n        (dblclick)=\"doubleClick($event, group)\"\r\n        [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n      >\r\n        @if (config.enableSelect) {\r\n        <td [style]=\"applyStyle(group, { field: 'check-box', header: '' })\">\r\n          <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(group.data)\"-->\r\n          <!-- <p-tableCheckbox\r\n            [value]=\"group\"\r\n            [disabled]=\"isDisabledCheckbox(group)\"\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n          ></p-tableCheckbox>\r\n           -->\r\n          <input\r\n            type=\"checkbox\"\r\n            [value]=\"group\"\r\n            [checked]=\"isSelected(group)\"\r\n            (click)=\"selectItem($event, group)\"\r\n          />\r\n        </td>\r\n        } @for (col of columns; track $index) {\r\n        <ng-container>\r\n          @if (!col.template) {\r\n          <td\r\n            class=\"rowTable\"\r\n            [style]=\"\r\n              applyStyle(group, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            [pTooltip]=\"returnTooltipRow(group, col)\"\r\n          >\r\n            <span class=\"p-column-title\">{{ col.header }}:</span>\r\n\r\n            <span\r\n              *ngIf=\"!isBooleanField(group, col); else booleanField\"\r\n              [class]=\"returnRowClass(group, col)\"\r\n            >\r\n              @if (!isChipField(col) && !col.iconField && !isImageField(col)) {\r\n              <span>\r\n                @if (col.icon) {\r\n                <i [class]=\"col.icon + ' mr-2'\"></i>\r\n                }\r\n                {{ transformValue(group, col) }}\r\n              </span>\r\n              } @if (isChipField(col) && !col.iconField) {\r\n              <div>\r\n                <span\r\n                  [class]=\"returnClassChip(group, col)\"\r\n                  [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n                  >{{ transformValue(group, col) }}</span\r\n                >\r\n              </div>\r\n              }\r\n            </span>\r\n\r\n            @if (isImageField(col)) {\r\n            <span>\r\n              <span>\r\n                <img class=\"image\" [src]=\"loadImage(group, col)\" />\r\n              </span>\r\n            </span>\r\n            } @if (col.iconField) {\r\n            <i\r\n              [ngClass]=\"{\r\n                'material-icons': col.indIconMaterial,\r\n                'material-symbols-outlined mr-2': !col.indIconMaterial\r\n              }\"\r\n              [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n            >\r\n              {{ returnClassIcon(group, col) }}\r\n            </i>\r\n            }\r\n\r\n            <ng-template #booleanField>\r\n              @if (!col.iconField && !isSwitchField(col)) {\r\n              <i\r\n                [ngClass]=\"group[col.field] ? 'text-green-500' : 'text-red-500'\"\r\n                ><span class=\"material-symbols-outlined\">\r\n                  {{ group[col.field] ? \"check\" : \"close\" }}\r\n                </span>\r\n              </i>\r\n              } @if (isSwitchField(col)) {\r\n              <span [class]=\"returnRowClass(group, col)\">\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, group, col)\"\r\n                  [disabled]=\"col?.onlyReadField ?? true\"\r\n                  [switchValue]=\"transformValue(group, col)\"\r\n                >\r\n                </kv-switch>\r\n              </span>\r\n              }\r\n            </ng-template>\r\n          </td>\r\n          } @if (col.template) {\r\n          <td\r\n            [style]=\"\r\n              applyStyle(group, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            class=\"rowTable\"\r\n          >\r\n            <span class=\"p-column-title\">{{ col.header }}:</span>\r\n            @if (getCustomTemplate(col.template.name)) {\r\n            <ng-container\r\n              [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n              [ngTemplateOutletContext]=\"{ $implicit: group }\"\r\n            />\r\n            }\r\n          </td>\r\n          }\r\n        </ng-container>\r\n        } @if (config.actions && config.actions.length > 0) {\r\n        <td [style]=\"applyStyle(group, { field: 'btns-options', header: '' })\">\r\n          <div class=\"flex flex-row justify-content-end w-full\">\r\n            <!-- <button\r\n                    id=\"moreVertBtn\"\r\n                    pButton\r\n                    class=\"actionBtns p-button-text p-button-raised\"\r\n                    (click)=\"menu.toggle($event); activeItem(group)\"\r\n                  > -->\r\n\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n              style=\"font-size: 20px\"\r\n              (click)=\"\r\n                returnRowDataActions(group);\r\n                menu.toggle($event);\r\n                activeItem(group)\r\n              \"\r\n            >\r\n              more_horiz\r\n            </span>\r\n\r\n            <!-- </button> -->\r\n\r\n            <p-tieredMenu\r\n              #menu\r\n              [popup]=\"true\"\r\n              [model]=\"menuItems\"\r\n              appendTo=\"body\"\r\n            ></p-tieredMenu>\r\n          </div>\r\n        </td>\r\n        }\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"emptymessage\" let-columns>\r\n      <tr>\r\n        <td\r\n          [attr.colspan]=\"columns.length + 2\"\r\n          style=\"text-align: center; border-radius: 10px !important\"\r\n        >\r\n          <p class=\"font-medium m-0\">Nenhum registro encontrado</p>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-table>\r\n  }\r\n</div>\r\n"]}