ngx-vector-components 4.11.2 → 4.14.0
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.
- package/CHANGELOG.md +22 -0
- package/assets/styles/_primeng-custom-theme.scss +1 -1
- package/esm2020/lib/components/crud-history/crud-history.component.mjs +48 -17
- package/esm2020/lib/components/fields/checkbox-field/checkbox-field.component.mjs +9 -3
- package/esm2020/lib/components/fields/data-table/data-table.component.mjs +23 -4
- package/esm2020/lib/components/generic-modal/generic-modal.component.mjs +29 -18
- package/esm2020/lib/models/crud-history.model.mjs +1 -7
- package/esm2020/lib/models/data-table.model.mjs +6 -1
- package/esm2020/lib/models/generic-modal.model.mjs +2 -0
- package/esm2020/lib/resolvers/index.mjs +1 -2
- package/fesm2015/ngx-vector-components.mjs +111 -64
- package/fesm2015/ngx-vector-components.mjs.map +1 -1
- package/fesm2020/ngx-vector-components.mjs +111 -64
- package/fesm2020/ngx-vector-components.mjs.map +1 -1
- package/lib/components/crud-history/crud-history.component.d.ts +7 -5
- package/lib/components/fields/checkbox-field/checkbox-field.component.d.ts +4 -1
- package/lib/components/fields/data-table/data-table.component.d.ts +5 -2
- package/lib/components/generic-modal/generic-modal.component.d.ts +10 -7
- package/lib/models/crud-history.model.d.ts +9 -8
- package/lib/models/data-table.model.d.ts +4 -0
- package/lib/models/generic-modal.model.d.ts +13 -0
- package/lib/resolvers/index.d.ts +0 -1
- package/package.json +1 -1
- package/esm2020/lib/resolvers/get-entity-history.resolver.mjs +0 -22
- package/lib/resolvers/get-entity-history.resolver.d.ts +0 -11
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,27 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [4.14.0] (22/07/2022)
|
|
4
|
+
|
|
5
|
+
### Features
|
|
6
|
+
|
|
7
|
+
- Added `AlterationHistory` in `vector-crud-history` to use the logtech pattern.
|
|
8
|
+
|
|
9
|
+
## [4.13.0] (18/07/2022)
|
|
10
|
+
|
|
11
|
+
### Features
|
|
12
|
+
|
|
13
|
+
- Added `selectionType` in `vector-data-table` to add `checkboxbutton` or `radionbutton` in table.
|
|
14
|
+
|
|
15
|
+
### Refactor
|
|
16
|
+
|
|
17
|
+
- Refactor `generic-modal` to accept news parameters and output events for make more dynamically.
|
|
18
|
+
|
|
19
|
+
## [4.12.0] (18/07/2022)
|
|
20
|
+
|
|
21
|
+
### Features
|
|
22
|
+
|
|
23
|
+
- Added `multipleCheck` in `vector-checkbox-field` to add multiple options.
|
|
24
|
+
|
|
3
25
|
## [4.11.2] (16/07/2022)
|
|
4
26
|
|
|
5
27
|
### Bugfixes
|
|
@@ -1,51 +1,82 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { CrudHistoryEventType } from '../../models';
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
import * as i1 from "primeng/accordion";
|
|
5
4
|
import * as i2 from "../badge/badge.component";
|
|
6
5
|
import * as i3 from "@angular/common";
|
|
7
6
|
import * as i4 from "primeng/api";
|
|
8
7
|
export class CrudHistoryComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.onClick = new EventEmitter();
|
|
10
|
+
}
|
|
9
11
|
getHistoryBadgeBackgroundColor(crudHistoryEventType) {
|
|
10
12
|
switch (crudHistoryEventType) {
|
|
11
|
-
case
|
|
13
|
+
case 'ActionCreate':
|
|
14
|
+
return '#CBFFAE';
|
|
15
|
+
case 'ActionUpdate':
|
|
16
|
+
return '#FFE6B0';
|
|
17
|
+
case 'ActionDelete':
|
|
18
|
+
return 'Removido';
|
|
19
|
+
case 'ActionUpdate-OnComposition':
|
|
20
|
+
return '#FFE6B0';
|
|
21
|
+
case 'ActionUpdate-OnUnit':
|
|
22
|
+
return '#FFE6B0';
|
|
23
|
+
case 'ActionCreate-OnComposition':
|
|
12
24
|
return '#CBFFAE';
|
|
13
|
-
case
|
|
25
|
+
case 'ActionCancel':
|
|
14
26
|
return '#FFE6B0';
|
|
15
|
-
case CrudHistoryEventType.DELETE:
|
|
16
27
|
default:
|
|
17
|
-
return '
|
|
28
|
+
return '';
|
|
18
29
|
}
|
|
19
30
|
}
|
|
20
31
|
getHistoryBadgeColor(crudHistoryEventType) {
|
|
21
32
|
switch (crudHistoryEventType) {
|
|
22
|
-
case
|
|
33
|
+
case 'ActionCreate':
|
|
23
34
|
return '#067306';
|
|
24
|
-
case
|
|
35
|
+
case 'ActionUpdate':
|
|
25
36
|
return '#946300';
|
|
26
|
-
case
|
|
27
|
-
default:
|
|
37
|
+
case 'ActionDelete':
|
|
28
38
|
return '#6B2D2D';
|
|
39
|
+
case 'ActionUpdate-OnComposition':
|
|
40
|
+
return '#946300';
|
|
41
|
+
case 'ActionUpdate-OnUnit':
|
|
42
|
+
return '#946300';
|
|
43
|
+
case 'ActionCreate-OnComposition':
|
|
44
|
+
return '#067306';
|
|
45
|
+
case 'ActionCancel':
|
|
46
|
+
return '#946300';
|
|
47
|
+
default:
|
|
48
|
+
return '';
|
|
29
49
|
}
|
|
30
50
|
}
|
|
31
51
|
getHistoryBadgeLabel(crudHistoryEventType) {
|
|
32
52
|
switch (crudHistoryEventType) {
|
|
33
|
-
case
|
|
53
|
+
case 'ActionCreate':
|
|
34
54
|
return 'Criado';
|
|
35
|
-
case
|
|
55
|
+
case 'ActionUpdate':
|
|
36
56
|
return 'Modificado';
|
|
37
|
-
case
|
|
38
|
-
default:
|
|
57
|
+
case 'ActionDelete':
|
|
39
58
|
return 'Removido';
|
|
59
|
+
case 'ActionUpdate-OnComposition':
|
|
60
|
+
return 'Composição Modificada';
|
|
61
|
+
case 'ActionUpdate-OnUnit':
|
|
62
|
+
return 'Unidade Modificada';
|
|
63
|
+
case 'ActionCreate-OnComposition':
|
|
64
|
+
return 'Composição Criada';
|
|
65
|
+
case 'ActionCancel':
|
|
66
|
+
return 'Modificado';
|
|
67
|
+
default:
|
|
68
|
+
return '';
|
|
40
69
|
}
|
|
41
70
|
}
|
|
42
71
|
}
|
|
43
72
|
CrudHistoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CrudHistoryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
44
|
-
CrudHistoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CrudHistoryComponent, selector: "vector-crud-history", inputs: { crudHistory: "crudHistory" }, ngImport: i0, template: "<p-accordionTab *ngIf=\"crudHistory\" class=\"history-item\">\n <ng-template pTemplate=\"header\">\n <div class=\"history-item-header-container\">\n <div class=\"history-item-header-left\">\n <vector-badge\n [customBackgroundColor]=\"getHistoryBadgeBackgroundColor(crudHistory.eventType)\"\n [customColor]=\"getHistoryBadgeColor(crudHistory.eventType)\"\n [label]=\"getHistoryBadgeLabel(crudHistory.eventType)\"\n ></vector-badge>\n <span>por {{ crudHistory.
|
|
73
|
+
CrudHistoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CrudHistoryComponent, selector: "vector-crud-history", inputs: { crudHistory: "crudHistory" }, outputs: { onClick: "onClick" }, ngImport: i0, template: "<p-accordionTab *ngIf=\"crudHistory\" class=\"history-item\">\n <ng-template pTemplate=\"header\">\n <div class=\"history-item-header-container\" (click)=\"onClick.emit()\">\n <div class=\"history-item-header-left\">\n <vector-badge\n [customBackgroundColor]=\"getHistoryBadgeBackgroundColor(crudHistory.eventType)\"\n [customColor]=\"getHistoryBadgeColor(crudHistory.eventType)\"\n [label]=\"getHistoryBadgeLabel(crudHistory.eventType)\"\n ></vector-badge>\n <span>por {{ crudHistory.modifierName }}</span>\n </div>\n <span class=\"history-item-header-right\">\n {{ crudHistory.dateTime | date: 'dd/MM/yyyy HH:mm' }}\n </span>\n </div>\n </ng-template>\n <ng-template pTemplate=\"content\">\n <div *ngFor=\"let auditDelta of crudHistory.dataAuditDelta\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-6 field\">\n <span>{{ auditDelta.fieldName }}</span>\n </div>\n <div class=\"col-12 md:col-6 field\">\n <span class=\"new-value\">{{ auditDelta.newValue }}</span>\n <s class=\"old-value\">{{ auditDelta.oldValue }}</s>\n </div>\n </div>\n </div>\n </ng-template>\n</p-accordionTab>\n", styles: [".history-item{width:100%;margin:10px 0}.history-item .history-item-header-container{display:flex;align-items:center;justify-content:space-between;width:100%}.history-item .history-item-header-container .history-item-header-left{display:flex;align-items:center}.history-item .history-item-header-container .history-item-header-left span{margin-left:15px;color:var(--theme-medium);font-weight:600}.history-item .history-item-header-container .history-item-header-right{font-size:.8rem;color:var(--gray-darker);margin-right:40px}.new-value{color:#83c5be}.old-value{color:#000}\n"], components: [{ type: i1.AccordionTab, selector: "p-accordionTab", inputs: ["header", "disabled", "cache", "transitionOptions", "selected"], outputs: ["selectedChange"] }, { type: i2.BadgeComponent, selector: "vector-badge", inputs: ["type", "label", "customColor", "customBackgroundColor"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "date": i3.DatePipe } });
|
|
45
74
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CrudHistoryComponent, decorators: [{
|
|
46
75
|
type: Component,
|
|
47
|
-
args: [{ selector: 'vector-crud-history', template: "<p-accordionTab *ngIf=\"crudHistory\" class=\"history-item\">\n <ng-template pTemplate=\"header\">\n <div class=\"history-item-header-container\">\n <div class=\"history-item-header-left\">\n <vector-badge\n [customBackgroundColor]=\"getHistoryBadgeBackgroundColor(crudHistory.eventType)\"\n [customColor]=\"getHistoryBadgeColor(crudHistory.eventType)\"\n [label]=\"getHistoryBadgeLabel(crudHistory.eventType)\"\n ></vector-badge>\n <span>por {{ crudHistory.
|
|
76
|
+
args: [{ selector: 'vector-crud-history', template: "<p-accordionTab *ngIf=\"crudHistory\" class=\"history-item\">\n <ng-template pTemplate=\"header\">\n <div class=\"history-item-header-container\" (click)=\"onClick.emit()\">\n <div class=\"history-item-header-left\">\n <vector-badge\n [customBackgroundColor]=\"getHistoryBadgeBackgroundColor(crudHistory.eventType)\"\n [customColor]=\"getHistoryBadgeColor(crudHistory.eventType)\"\n [label]=\"getHistoryBadgeLabel(crudHistory.eventType)\"\n ></vector-badge>\n <span>por {{ crudHistory.modifierName }}</span>\n </div>\n <span class=\"history-item-header-right\">\n {{ crudHistory.dateTime | date: 'dd/MM/yyyy HH:mm' }}\n </span>\n </div>\n </ng-template>\n <ng-template pTemplate=\"content\">\n <div *ngFor=\"let auditDelta of crudHistory.dataAuditDelta\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-6 field\">\n <span>{{ auditDelta.fieldName }}</span>\n </div>\n <div class=\"col-12 md:col-6 field\">\n <span class=\"new-value\">{{ auditDelta.newValue }}</span>\n <s class=\"old-value\">{{ auditDelta.oldValue }}</s>\n </div>\n </div>\n </div>\n </ng-template>\n</p-accordionTab>\n", styles: [".history-item{width:100%;margin:10px 0}.history-item .history-item-header-container{display:flex;align-items:center;justify-content:space-between;width:100%}.history-item .history-item-header-container .history-item-header-left{display:flex;align-items:center}.history-item .history-item-header-container .history-item-header-left span{margin-left:15px;color:var(--theme-medium);font-weight:600}.history-item .history-item-header-container .history-item-header-right{font-size:.8rem;color:var(--gray-darker);margin-right:40px}.new-value{color:#83c5be}.old-value{color:#000}\n"] }]
|
|
48
77
|
}], propDecorators: { crudHistory: [{
|
|
49
78
|
type: Input
|
|
79
|
+
}], onClick: [{
|
|
80
|
+
type: Output
|
|
50
81
|
}] } });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3J1ZC1oaXN0b3J5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY3J1ZC1oaXN0b3J5L2NydWQtaGlzdG9yeS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmVjdG9yLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NydWQtaGlzdG9yeS9jcnVkLWhpc3RvcnkuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBUXZFLE1BQU0sT0FBTyxvQkFBb0I7SUFMakM7UUFTUyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztLQStEMUM7SUE5RFEsOEJBQThCLENBQUMsb0JBQTZCO1FBQ2pFLFFBQVEsb0JBQW9CLEVBQUU7WUFDNUIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssY0FBYztnQkFDakIsT0FBTyxVQUFVLENBQUM7WUFDcEIsS0FBSyw0QkFBNEI7Z0JBQy9CLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUsscUJBQXFCO2dCQUN4QixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQjtnQkFDRSxPQUFPLEVBQUUsQ0FBQztTQUNiO0lBQ0gsQ0FBQztJQUVNLG9CQUFvQixDQUFDLG9CQUE2QjtRQUN2RCxRQUFRLG9CQUFvQixFQUFFO1lBQzVCLEtBQUssY0FBYztnQkFDakIsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssNEJBQTRCO2dCQUMvQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLHFCQUFxQjtnQkFDeEIsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyw0QkFBNEI7Z0JBQy9CLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssY0FBYztnQkFDakIsT0FBTyxTQUFTLENBQUM7WUFDbkI7Z0JBQ0UsT0FBTyxFQUFFLENBQUM7U0FDYjtJQUNILENBQUM7SUFFTSxvQkFBb0IsQ0FBQyxvQkFBNkI7UUFDdkQsUUFBUSxvQkFBb0IsRUFBRTtZQUM1QixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sUUFBUSxDQUFDO1lBQ2xCLEtBQUssY0FBYztnQkFDakIsT0FBTyxZQUFZLENBQUM7WUFDdEIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFVBQVUsQ0FBQztZQUNwQixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyx1QkFBdUIsQ0FBQztZQUNqQyxLQUFLLHFCQUFxQjtnQkFDeEIsT0FBTyxvQkFBb0IsQ0FBQztZQUM5QixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyxtQkFBbUIsQ0FBQztZQUM3QixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sWUFBWSxDQUFDO1lBQ3RCO2dCQUNFLE9BQU8sRUFBRSxDQUFDO1NBQ2I7SUFDSCxDQUFDOztpSEFsRVUsb0JBQW9CO3FHQUFwQixvQkFBb0Isb0lDUmpDLGd1Q0E4QkE7MkZEdEJhLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxxQkFBcUI7OEJBTXhCLFdBQVc7c0JBRGpCLEtBQUs7Z0JBR0MsT0FBTztzQkFEYixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENydWRIaXN0b3J5IH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmVjdG9yLWNydWQtaGlzdG9yeScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jcnVkLWhpc3RvcnkuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jcnVkLWhpc3RvcnkuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ3J1ZEhpc3RvcnlDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgY3J1ZEhpc3Rvcnk/OiBDcnVkSGlzdG9yeTxhbnk+O1xuICBAT3V0cHV0KClcbiAgcHVibGljIG9uQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcbiAgcHVibGljIGdldEhpc3RvcnlCYWRnZUJhY2tncm91bmRDb2xvcihjcnVkSGlzdG9yeUV2ZW50VHlwZT86IHN0cmluZyk6IHN0cmluZyB7XG4gICAgc3dpdGNoIChjcnVkSGlzdG9yeUV2ZW50VHlwZSkge1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlJzpcbiAgICAgICAgcmV0dXJuICcjQ0JGRkFFJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZSc6XG4gICAgICAgIHJldHVybiAnI0ZGRTZCMCc7XG4gICAgICBjYXNlICdBY3Rpb25EZWxldGUnOlxuICAgICAgICByZXR1cm4gJ1JlbW92aWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICcjRkZFNkIwJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PblVuaXQnOlxuICAgICAgICByZXR1cm4gJyNGRkU2QjAnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJyNDQkZGQUUnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICcjRkZFNkIwJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0SGlzdG9yeUJhZGdlQ29sb3IoY3J1ZEhpc3RvcnlFdmVudFR5cGU/OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHN3aXRjaCAoY3J1ZEhpc3RvcnlFdmVudFR5cGUpIHtcbiAgICAgIGNhc2UgJ0FjdGlvbkNyZWF0ZSc6XG4gICAgICAgIHJldHVybiAnIzA2NzMwNic7XG4gICAgICBjYXNlICdBY3Rpb25VcGRhdGUnOlxuICAgICAgICByZXR1cm4gJyM5NDYzMDAnO1xuICAgICAgY2FzZSAnQWN0aW9uRGVsZXRlJzpcbiAgICAgICAgcmV0dXJuICcjNkIyRDJEJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICcjOTQ2MzAwJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PblVuaXQnOlxuICAgICAgICByZXR1cm4gJyM5NDYzMDAnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJyMwNjczMDYnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICcjOTQ2MzAwJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0SGlzdG9yeUJhZGdlTGFiZWwoY3J1ZEhpc3RvcnlFdmVudFR5cGU/OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHN3aXRjaCAoY3J1ZEhpc3RvcnlFdmVudFR5cGUpIHtcbiAgICAgIGNhc2UgJ0FjdGlvbkNyZWF0ZSc6XG4gICAgICAgIHJldHVybiAnQ3JpYWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZSc6XG4gICAgICAgIHJldHVybiAnTW9kaWZpY2Fkbyc7XG4gICAgICBjYXNlICdBY3Rpb25EZWxldGUnOlxuICAgICAgICByZXR1cm4gJ1JlbW92aWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICdDb21wb3Npw6fDo28gTW9kaWZpY2FkYSc7XG4gICAgICBjYXNlICdBY3Rpb25VcGRhdGUtT25Vbml0JzpcbiAgICAgICAgcmV0dXJuICdVbmlkYWRlIE1vZGlmaWNhZGEnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJ0NvbXBvc2nDp8OjbyBDcmlhZGEnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICdNb2RpZmljYWRvJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cbn1cbiIsIjxwLWFjY29yZGlvblRhYiAqbmdJZj1cImNydWRIaXN0b3J5XCIgY2xhc3M9XCJoaXN0b3J5LWl0ZW1cIj5cbiAgPG5nLXRlbXBsYXRlIHBUZW1wbGF0ZT1cImhlYWRlclwiPlxuICAgIDxkaXYgY2xhc3M9XCJoaXN0b3J5LWl0ZW0taGVhZGVyLWNvbnRhaW5lclwiIChjbGljayk9XCJvbkNsaWNrLmVtaXQoKVwiPlxuICAgICAgPGRpdiBjbGFzcz1cImhpc3RvcnktaXRlbS1oZWFkZXItbGVmdFwiPlxuICAgICAgICA8dmVjdG9yLWJhZGdlXG4gICAgICAgICAgW2N1c3RvbUJhY2tncm91bmRDb2xvcl09XCJnZXRIaXN0b3J5QmFkZ2VCYWNrZ3JvdW5kQ29sb3IoY3J1ZEhpc3RvcnkuZXZlbnRUeXBlKVwiXG4gICAgICAgICAgW2N1c3RvbUNvbG9yXT1cImdldEhpc3RvcnlCYWRnZUNvbG9yKGNydWRIaXN0b3J5LmV2ZW50VHlwZSlcIlxuICAgICAgICAgIFtsYWJlbF09XCJnZXRIaXN0b3J5QmFkZ2VMYWJlbChjcnVkSGlzdG9yeS5ldmVudFR5cGUpXCJcbiAgICAgICAgPjwvdmVjdG9yLWJhZGdlPlxuICAgICAgICA8c3Bhbj5wb3Ige3sgY3J1ZEhpc3RvcnkubW9kaWZpZXJOYW1lIH19PC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgICA8c3BhbiBjbGFzcz1cImhpc3RvcnktaXRlbS1oZWFkZXItcmlnaHRcIj5cbiAgICAgICAge3sgY3J1ZEhpc3RvcnkuZGF0ZVRpbWUgfCBkYXRlOiAnZGQvTU0veXl5eSBISDptbScgfX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgPC9uZy10ZW1wbGF0ZT5cbiAgPG5nLXRlbXBsYXRlIHBUZW1wbGF0ZT1cImNvbnRlbnRcIj5cbiAgICA8ZGl2ICpuZ0Zvcj1cImxldCBhdWRpdERlbHRhIG9mIGNydWRIaXN0b3J5LmRhdGFBdWRpdERlbHRhXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiZ3JpZFwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyIG1kOmNvbC02IGZpZWxkXCI+XG4gICAgICAgICAgPHNwYW4+e3sgYXVkaXREZWx0YS5maWVsZE5hbWUgfX08L3NwYW4+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyIG1kOmNvbC02IGZpZWxkXCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJuZXctdmFsdWVcIj57eyBhdWRpdERlbHRhLm5ld1ZhbHVlIH19PC9zcGFuPlxuICAgICAgICAgIDxzIGNsYXNzPVwib2xkLXZhbHVlXCI+e3sgYXVkaXREZWx0YS5vbGRWYWx1ZSB9fTwvcz5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgPC9uZy10ZW1wbGF0ZT5cbjwvcC1hY2NvcmRpb25UYWI+XG4iXX0=
|
|
@@ -10,16 +10,18 @@ export class CheckboxFieldComponent {
|
|
|
10
10
|
this.rounded = false;
|
|
11
11
|
this.labelSize = 'default';
|
|
12
12
|
this.value = false;
|
|
13
|
+
this.groupName = '';
|
|
14
|
+
this.options = null;
|
|
13
15
|
this.disabled = false;
|
|
14
16
|
this.valueChange = new EventEmitter();
|
|
15
17
|
}
|
|
16
18
|
ngOnInit() { }
|
|
17
19
|
}
|
|
18
20
|
CheckboxFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CheckboxFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
19
|
-
CheckboxFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CheckboxFieldComponent, selector: "vector-checkbox-field", inputs: { isRequired: "isRequired", control: "control", label: "label", rounded: "rounded", labelSize: "labelSize", value: "value", disabled: "disabled" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<div class=\"checkbox-container\">\n <p-checkbox\n *ngIf=\"control\"\n
|
|
21
|
+
CheckboxFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CheckboxFieldComponent, selector: "vector-checkbox-field", inputs: { isRequired: "isRequired", control: "control", label: "label", rounded: "rounded", labelSize: "labelSize", value: "value", groupName: "groupName", options: "options", disabled: "disabled" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<div class=\"checkbox-container flex-wrap\">\n <ng-container *ngIf=\"control && groupName\">\n <div class=\"checkbox-item mb-3 mr-3\" *ngFor=\"let option of options\">\n <p-checkbox\n [name]=\"groupName\"\n [formControl]=\"control\"\n [value]=\"option\"\n checkboxIcon=\"fas fa-check\"\n [class.rounded-checkbox]=\"rounded\"\n [inputId]=\"option.code\"\n ></p-checkbox>\n <label [for]=\"option.code\"> {{ option.name }}</label>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"control && !groupName\">\n <p-checkbox\n *ngIf=\"control\"\n [formControl]=\"control\"\n checkboxIcon=\"fas fa-check\"\n [binary]=\"true\"\n [class.rounded-checkbox]=\"rounded\"\n ></p-checkbox>\n <p-checkbox\n *ngIf=\"!control\"\n [ngModel]=\"value\"\n (ngModelChange)=\"value = $event; valueChange.emit($event)\"\n checkboxIcon=\"fas fa-check\"\n [binary]=\"true\"\n [class.rounded-checkbox]=\"rounded\"\n [disabled]=\"disabled\"\n ></p-checkbox>\n <label *ngIf=\"label\" [class.large-label]=\"labelSize === 'large'\" (click)=\"control.setValue(!control.value)\"\n >{{ label }}\n <span class=\"red-label\" *ngIf=\"isRequired\"> (*)</span>\n </label>\n </ng-container>\n</div>\n", styles: [".checkbox-container{display:flex;align-items:center}.checkbox-container label{margin-left:10px}.checkbox-container .large-label{font-size:1em}.checkbox-container .checkbox-item{min-width:80px}\n"], components: [{ type: i1.Checkbox, selector: "p-checkbox", inputs: ["value", "name", "disabled", "binary", "label", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "style", "styleClass", "labelStyleClass", "formControl", "checkboxIcon", "readonly", "required", "trueValue", "falseValue"], outputs: ["onChange"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
20
22
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CheckboxFieldComponent, decorators: [{
|
|
21
23
|
type: Component,
|
|
22
|
-
args: [{ selector: 'vector-checkbox-field', template: "<div class=\"checkbox-container\">\n <p-checkbox\n *ngIf=\"control\"\n
|
|
24
|
+
args: [{ selector: 'vector-checkbox-field', template: "<div class=\"checkbox-container flex-wrap\">\n <ng-container *ngIf=\"control && groupName\">\n <div class=\"checkbox-item mb-3 mr-3\" *ngFor=\"let option of options\">\n <p-checkbox\n [name]=\"groupName\"\n [formControl]=\"control\"\n [value]=\"option\"\n checkboxIcon=\"fas fa-check\"\n [class.rounded-checkbox]=\"rounded\"\n [inputId]=\"option.code\"\n ></p-checkbox>\n <label [for]=\"option.code\"> {{ option.name }}</label>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"control && !groupName\">\n <p-checkbox\n *ngIf=\"control\"\n [formControl]=\"control\"\n checkboxIcon=\"fas fa-check\"\n [binary]=\"true\"\n [class.rounded-checkbox]=\"rounded\"\n ></p-checkbox>\n <p-checkbox\n *ngIf=\"!control\"\n [ngModel]=\"value\"\n (ngModelChange)=\"value = $event; valueChange.emit($event)\"\n checkboxIcon=\"fas fa-check\"\n [binary]=\"true\"\n [class.rounded-checkbox]=\"rounded\"\n [disabled]=\"disabled\"\n ></p-checkbox>\n <label *ngIf=\"label\" [class.large-label]=\"labelSize === 'large'\" (click)=\"control.setValue(!control.value)\"\n >{{ label }}\n <span class=\"red-label\" *ngIf=\"isRequired\"> (*)</span>\n </label>\n </ng-container>\n</div>\n", styles: [".checkbox-container{display:flex;align-items:center}.checkbox-container label{margin-left:10px}.checkbox-container .large-label{font-size:1em}.checkbox-container .checkbox-item{min-width:80px}\n"] }]
|
|
23
25
|
}], ctorParameters: function () { return []; }, propDecorators: { isRequired: [{
|
|
24
26
|
type: Input
|
|
25
27
|
}], control: [{
|
|
@@ -32,9 +34,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
32
34
|
type: Input
|
|
33
35
|
}], value: [{
|
|
34
36
|
type: Input
|
|
37
|
+
}], groupName: [{
|
|
38
|
+
type: Input
|
|
39
|
+
}], options: [{
|
|
40
|
+
type: Input
|
|
35
41
|
}], disabled: [{
|
|
36
42
|
type: Input
|
|
37
43
|
}], valueChange: [{
|
|
38
44
|
type: Output
|
|
39
45
|
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3gtZmllbGQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9maWVsZHMvY2hlY2tib3gtZmllbGQvY2hlY2tib3gtZmllbGQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9maWVsZHMvY2hlY2tib3gtZmllbGQvY2hlY2tib3gtZmllbGQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRL0UsTUFBTSxPQUFPLHNCQUFzQjtJQXFCakM7UUFuQk8sZUFBVSxHQUFZLEtBQUssQ0FBQztRQUk1QixVQUFLLEdBQVcsRUFBRSxDQUFDO1FBRW5CLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFFekIsY0FBUyxHQUF3QixTQUFTLENBQUM7UUFFM0MsVUFBSyxHQUF3QixLQUFLLENBQUM7UUFFbkMsY0FBUyxHQUFXLEVBQUUsQ0FBQztRQUV2QixZQUFPLEdBQXNCLElBQUksQ0FBQztRQUVsQyxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRWpCLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztJQUNsQyxDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDOzttSEF2QkYsc0JBQXNCO3VHQUF0QixzQkFBc0IsOFNDUm5DLHF5Q0FzQ0E7MkZEOUJhLHNCQUFzQjtrQkFMbEMsU0FBUzsrQkFDRSx1QkFBdUI7MEVBTTFCLFVBQVU7c0JBRGhCLEtBQUs7Z0JBR0MsT0FBTztzQkFEYixLQUFLO2dCQUdDLEtBQUs7c0JBRFgsS0FBSztnQkFHQyxPQUFPO3NCQURiLEtBQUs7Z0JBR0MsU0FBUztzQkFEZixLQUFLO2dCQUdDLEtBQUs7c0JBRFgsS0FBSztnQkFHQyxTQUFTO3NCQURmLEtBQUs7Z0JBR0MsT0FBTztzQkFEYixLQUFLO2dCQUdDLFFBQVE7c0JBRGQsS0FBSztnQkFHQyxXQUFXO3NCQURqQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2ZWN0b3ItY2hlY2tib3gtZmllbGQnLFxuICB0ZW1wbGF0ZVVybDogJy4vY2hlY2tib3gtZmllbGQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaGVja2JveC1maWVsZC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBDaGVja2JveEZpZWxkQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgcHVibGljIGlzUmVxdWlyZWQ6IGJvb2xlYW4gPSBmYWxzZTtcbiAgQElucHV0KClcbiAgcHVibGljIGNvbnRyb2w6IGFueTtcbiAgQElucHV0KClcbiAgcHVibGljIGxhYmVsOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KClcbiAgcHVibGljIHJvdW5kZWQ6IGJvb2xlYW4gPSBmYWxzZTtcbiAgQElucHV0KClcbiAgcHVibGljIGxhYmVsU2l6ZTogJ2RlZmF1bHQnIHwgJ2xhcmdlJyA9ICdkZWZhdWx0JztcbiAgQElucHV0KClcbiAgcHVibGljIHZhbHVlOiBib29sZWFuIHwgdW5kZWZpbmVkID0gZmFsc2U7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBncm91cE5hbWU6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKVxuICBwdWJsaWMgb3B0aW9uczogTGlzdEl0ZW1bXSB8IG51bGwgPSBudWxsO1xuICBASW5wdXQoKVxuICBwdWJsaWMgZGlzYWJsZWQgPSBmYWxzZTtcbiAgQE91dHB1dCgpXG4gIHB1YmxpYyB2YWx1ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge31cbn1cbiIsIjxkaXYgY2xhc3M9XCJjaGVja2JveC1jb250YWluZXIgZmxleC13cmFwXCI+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJjb250cm9sICYmIGdyb3VwTmFtZVwiPlxuICAgIDxkaXYgY2xhc3M9XCJjaGVja2JveC1pdGVtIG1iLTMgbXItM1wiICpuZ0Zvcj1cImxldCBvcHRpb24gb2Ygb3B0aW9uc1wiPlxuICAgICAgPHAtY2hlY2tib3hcbiAgICAgICAgW25hbWVdPVwiZ3JvdXBOYW1lXCJcbiAgICAgICAgW2Zvcm1Db250cm9sXT1cImNvbnRyb2xcIlxuICAgICAgICBbdmFsdWVdPVwib3B0aW9uXCJcbiAgICAgICAgY2hlY2tib3hJY29uPVwiZmFzIGZhLWNoZWNrXCJcbiAgICAgICAgW2NsYXNzLnJvdW5kZWQtY2hlY2tib3hdPVwicm91bmRlZFwiXG4gICAgICAgIFtpbnB1dElkXT1cIm9wdGlvbi5jb2RlXCJcbiAgICAgID48L3AtY2hlY2tib3g+XG4gICAgICA8bGFiZWwgW2Zvcl09XCJvcHRpb24uY29kZVwiPiB7eyBvcHRpb24ubmFtZSB9fTwvbGFiZWw+XG4gICAgPC9kaXY+XG4gIDwvbmctY29udGFpbmVyPlxuXG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJjb250cm9sICYmICFncm91cE5hbWVcIj5cbiAgICA8cC1jaGVja2JveFxuICAgICAgKm5nSWY9XCJjb250cm9sXCJcbiAgICAgIFtmb3JtQ29udHJvbF09XCJjb250cm9sXCJcbiAgICAgIGNoZWNrYm94SWNvbj1cImZhcyBmYS1jaGVja1wiXG4gICAgICBbYmluYXJ5XT1cInRydWVcIlxuICAgICAgW2NsYXNzLnJvdW5kZWQtY2hlY2tib3hdPVwicm91bmRlZFwiXG4gICAgPjwvcC1jaGVja2JveD5cbiAgICA8cC1jaGVja2JveFxuICAgICAgKm5nSWY9XCIhY29udHJvbFwiXG4gICAgICBbbmdNb2RlbF09XCJ2YWx1ZVwiXG4gICAgICAobmdNb2RlbENoYW5nZSk9XCJ2YWx1ZSA9ICRldmVudDsgdmFsdWVDaGFuZ2UuZW1pdCgkZXZlbnQpXCJcbiAgICAgIGNoZWNrYm94SWNvbj1cImZhcyBmYS1jaGVja1wiXG4gICAgICBbYmluYXJ5XT1cInRydWVcIlxuICAgICAgW2NsYXNzLnJvdW5kZWQtY2hlY2tib3hdPVwicm91bmRlZFwiXG4gICAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICAgID48L3AtY2hlY2tib3g+XG4gICAgPGxhYmVsICpuZ0lmPVwibGFiZWxcIiBbY2xhc3MubGFyZ2UtbGFiZWxdPVwibGFiZWxTaXplID09PSAnbGFyZ2UnXCIgKGNsaWNrKT1cImNvbnRyb2wuc2V0VmFsdWUoIWNvbnRyb2wudmFsdWUpXCJcbiAgICAgID57eyBsYWJlbCB9fVxuICAgICAgPHNwYW4gY2xhc3M9XCJyZWQtbGFiZWxcIiAqbmdJZj1cImlzUmVxdWlyZWRcIj4gKCopPC9zcGFuPlxuICAgIDwvbGFiZWw+XG4gIDwvbmctY29udGFpbmVyPlxuPC9kaXY+XG4iXX0=
|
|
@@ -28,7 +28,7 @@ export class DataTableComponent {
|
|
|
28
28
|
this.virtualPagination = false;
|
|
29
29
|
this.addItemButtonPlusSign = false;
|
|
30
30
|
this.hasActions = true;
|
|
31
|
-
this.
|
|
31
|
+
this.selectionType = null;
|
|
32
32
|
this.onLazyLoad = new EventEmitter();
|
|
33
33
|
this.onFilter = new EventEmitter();
|
|
34
34
|
this.onAdd = new EventEmitter();
|
|
@@ -37,6 +37,7 @@ export class DataTableComponent {
|
|
|
37
37
|
this.onSelectedRows = new EventEmitter();
|
|
38
38
|
this.onFilterChanged = new EventEmitter();
|
|
39
39
|
this.selectedItems = [];
|
|
40
|
+
this._selectionMode = null;
|
|
40
41
|
this._height = 'small';
|
|
41
42
|
this._tabs = [];
|
|
42
43
|
this._draw = 1;
|
|
@@ -47,6 +48,19 @@ export class DataTableComponent {
|
|
|
47
48
|
this._tabs = _tabs;
|
|
48
49
|
this._tabSelected = _tabs[0];
|
|
49
50
|
}
|
|
51
|
+
set selectionMode(_selectionMode) {
|
|
52
|
+
switch (_selectionMode) {
|
|
53
|
+
case 'single':
|
|
54
|
+
this._selectionMode = 'single';
|
|
55
|
+
break;
|
|
56
|
+
case 'multiple':
|
|
57
|
+
this._selectionMode = 'multiple';
|
|
58
|
+
break;
|
|
59
|
+
default:
|
|
60
|
+
this._selectionMode = null;
|
|
61
|
+
break;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
50
64
|
set height(_height) {
|
|
51
65
|
switch (_height) {
|
|
52
66
|
case 'small':
|
|
@@ -71,6 +85,9 @@ export class DataTableComponent {
|
|
|
71
85
|
get height() {
|
|
72
86
|
return this._height;
|
|
73
87
|
}
|
|
88
|
+
get selectionMode() {
|
|
89
|
+
return this._selectionMode;
|
|
90
|
+
}
|
|
74
91
|
ngOnInit() {
|
|
75
92
|
if (!this.height) {
|
|
76
93
|
this.height = 'small';
|
|
@@ -210,10 +227,10 @@ export class DataTableComponent {
|
|
|
210
227
|
}
|
|
211
228
|
}
|
|
212
229
|
DataTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: DataTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
213
|
-
DataTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: DataTableComponent, selector: "vector-data-table", inputs: { columns: "columns", data: "data", exportExcel: "exportExcel", exportPDF: "exportPDF", totalRecords: "totalRecords", filters: "filters", addItemLabel: "addItemLabel", pagination: "pagination", virtualPagination: "virtualPagination", tabs: "tabs", addItemButtonPlusSign: "addItemButtonPlusSign", hasActions: "hasActions", selectionMode: "selectionMode", height: "height" }, outputs: { onLazyLoad: "onLazyLoad", onFilter: "onFilter", onAdd: "onAdd", onExportExcel: "onExportExcel", onExportPDF: "onExportPDF", onSelectedRows: "onSelectedRows", onFilterChanged: "onFilterChanged" }, viewQueries: [{ propertyName: "filtersComponent", first: true, predicate: FiltersComponent, descendants: true, static: true }], ngImport: i0, template: "<div class=\"grid\">\n <div class=\"col-12\">\n <vector-filters\n [fields]=\"filters\"\n (onSearch)=\"lazyLoaded({ filter: true, data: $event })\"\n (formBuilded)=\"subscribeToFilterChanges()\"\n ></vector-filters>\n </div>\n <div class=\"table-header-actions field\" *ngIf=\"addItemLabel || exportExcel || exportPDF\">\n <button *ngIf=\"exportExcel\" (click)=\"onExportExcel.emit()\" class=\"export-button export-excel\">\n <i class=\"fas fa-file\"></i><span>Excel</span>\n </button>\n <button *ngIf=\"exportPDF\" (click)=\"onExportPDF.emit()\" class=\"export-button export-pdf\">\n <i class=\"fas fa-file\"></i><span>PDF</span>\n </button>\n <vector-button\n *ngIf=\"addItemLabel\"\n class=\"add-item-button\"\n [label]=\"addItemLabel\"\n (click)=\"onAdd.emit()\"\n [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\n ></vector-button>\n </div>\n <div class=\"col-12\">\n <vector-panel class=\"data-table-panel\">\n <p-tabView (onChange)=\"onTabChange($event)\" *ngIf=\"tabs?.length\">\n <p-tabPanel *ngFor=\"let tab of tabs\" [header]=\"tab.name\"></p-tabPanel>\n </p-tabView>\n <p-table\n currentPageReportTemplate=\"Mostrando {first} at\u00E9 {last} de {totalRecords} registros\"\n sortMode=\"single\"\n [rows]=\"10\"\n [lazy]=\"pagination && !virtualPagination\"\n [value]=\"data\"\n [paginator]=\"pagination\"\n [totalRecords]=\"totalRecords\"\n [showCurrentPageReport]=\"true\"\n [rowsPerPageOptions]=\"[10, 25, 50, 100]\"\n [responsive]=\"true\"\n [resizableColumns]=\"true\"\n [scrollable]=\"true\"\n scrollDirection=\"vertical\"\n responsiveLayout=\"scroll\"\n [scrollHeight]=\"height\"\n [selectionMode]=\"selectionMode\"\n [(selection)]=\"selectedItems\"\n (onRowSelect)=\"changeSelectedItems($event)\"\n (onRowUnselect)=\"changeSelectedItems($event)\"\n (onLazyLoad)=\"lazyLoaded({ filter: false, data: $event })\"\n >\n <ng-template pTemplate=\"header\">\n <tr class=\"header\">\n <th style=\"max-width: 100px\" class=\"centered\" *ngIf=\"hasActions\">A\u00E7\u00F5es</th>\n <th\n *ngFor=\"let col of columns\"\n [ngStyle]=\"getColStyle(col)\"\n [pSortableColumn]=\"col.notSortable ? '' : col.field\"\n >\n {{ col.header }} <p-sortIcon *ngIf=\"!col.notSortable\" [field]=\"col.field\"></p-sortIcon>\n </th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-rowData let-item>\n <tr class=\"row\" [pSelectableRow]=\"rowData\">\n <td *ngIf=\"hasActions\" style=\"max-width: 100px\" class=\"centered\">\n <p-menu #menu [model]=\"item.actions\" [popup]=\"true\" appendTo=\"body\"></p-menu>\n <i class=\"actions-menu-button fas fa-cog\" (click)=\"menu.toggle($event)\"></i>\n </td>\n <td\n *ngFor=\"let col of columns\"\n class=\"cell\"\n [innerHTML]=\"getCellContent(item, col)\"\n (click)=\"col && col.clickFunction && col.clickFunction(item)\"\n [ngStyle]=\"getColStyle(col)\"\n ></td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\">\n <tr class=\"row\">\n <td class=\"no-results\" [attr.colspan]=\"columns.length + 1\">Nenhum resultado encontrado</td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"paginatorright\"> </ng-template>\n <ng-template let-item pTemplate=\"paginatordropdownitem\"> {{ item.value }} </ng-template>\n </p-table>\n </vector-panel>\n </div>\n</div>\n", styles: [".no-results{padding:15px;background-color:#fff;width:100%}.centered{display:flex;justify-content:center}.table-header-actions{display:flex;justify-content:flex-end;align-items:flex-end;width:100%;padding-right:7px;margin-bottom:15px!important}@media (min-width: 768px){.table-header-actions{margin-top:-3px}}.table-header-actions .export-button{padding:7px 10px;color:#fff;display:flex;align-items:center;border:none;border-radius:5px;margin:5px;font-size:.75rem;cursor:pointer}.table-header-actions .export-button.export-excel{background-color:var(--success-color)}.table-header-actions .export-button.export-excel:hover{background-color:var(--success-color-dark)}.table-header-actions .export-button.export-pdf{background-color:var(--error-color)}.table-header-actions .export-button.export-pdf:hover{background-color:var(--error-color-dark)}.table-header-actions .export-button i{color:#fff}.table-header-actions .export-button span{margin-left:5px}.table-header-actions .add-item-button{margin-left:10px}.actions-menu-button{font-size:23px;cursor:pointer;color:var(--theme-medium)}\n"], components: [{ type: i1.FiltersComponent, selector: "vector-filters", inputs: ["fields"], outputs: ["onSearch", "formBuilded"] }, { type: i2.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }, { type: i3.PanelComponent, selector: "vector-panel" }, { type: i4.TabView, selector: "p-tabView", inputs: ["orientation", "style", "styleClass", "controlClose", "scrollable", "activeIndex"], outputs: ["onChange", "onClose", "activeIndexChange"] }, { type: i4.TabPanel, selector: "p-tabPanel", inputs: ["closable", "headerStyle", "headerStyleClass", "cache", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "selected", "disabled", "header", "leftIcon", "rightIcon"] }, { type: i5.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "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", "virtualScrollDelay", "virtualRowHeight", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "minBufferPx", "maxBufferPx", "responsiveLayout", "breakpoint", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["selectAllChange", "selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { type: i5.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { type: i6.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { type: i5.SelectableRow, selector: "[pSelectableRow]", inputs: ["pSelectableRow", "pSelectableRowIndex", "pSelectableRowDisabled"] }] });
|
|
230
|
+
DataTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: DataTableComponent, selector: "vector-data-table", inputs: { columns: "columns", data: "data", exportExcel: "exportExcel", exportPDF: "exportPDF", totalRecords: "totalRecords", filters: "filters", addItemLabel: "addItemLabel", pagination: "pagination", virtualPagination: "virtualPagination", tabs: "tabs", addItemButtonPlusSign: "addItemButtonPlusSign", hasActions: "hasActions", selectionMode: "selectionMode", selectionType: "selectionType", height: "height" }, outputs: { onLazyLoad: "onLazyLoad", onFilter: "onFilter", onAdd: "onAdd", onExportExcel: "onExportExcel", onExportPDF: "onExportPDF", onSelectedRows: "onSelectedRows", onFilterChanged: "onFilterChanged" }, viewQueries: [{ propertyName: "filtersComponent", first: true, predicate: FiltersComponent, descendants: true, static: true }], ngImport: i0, template: "<div class=\"grid\">\n <div class=\"col-12\">\n <vector-filters\n [fields]=\"filters\"\n (onSearch)=\"lazyLoaded({ filter: true, data: $event })\"\n (formBuilded)=\"subscribeToFilterChanges()\"\n ></vector-filters>\n </div>\n <div class=\"table-header-actions field\" *ngIf=\"addItemLabel || exportExcel || exportPDF\">\n <button *ngIf=\"exportExcel\" (click)=\"onExportExcel.emit()\" class=\"export-button export-excel\">\n <i class=\"fas fa-file\"></i><span>Excel</span>\n </button>\n <button *ngIf=\"exportPDF\" (click)=\"onExportPDF.emit()\" class=\"export-button export-pdf\">\n <i class=\"fas fa-file\"></i><span>PDF</span>\n </button>\n <vector-button\n *ngIf=\"addItemLabel\"\n class=\"add-item-button\"\n [label]=\"addItemLabel\"\n (click)=\"onAdd.emit()\"\n [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\n ></vector-button>\n </div>\n <div class=\"col-12\">\n <vector-panel class=\"data-table-panel\">\n <p-tabView (onChange)=\"onTabChange($event)\" *ngIf=\"tabs?.length\">\n <p-tabPanel *ngFor=\"let tab of tabs\" [header]=\"tab.name\"></p-tabPanel>\n </p-tabView>\n <p-table\n currentPageReportTemplate=\"Mostrando {first} at\u00E9 {last} de {totalRecords} registros\"\n sortMode=\"single\"\n [rows]=\"10\"\n [lazy]=\"pagination && !virtualPagination\"\n [value]=\"data\"\n [paginator]=\"pagination\"\n [totalRecords]=\"totalRecords\"\n [showCurrentPageReport]=\"true\"\n [rowsPerPageOptions]=\"[10, 25, 50, 100]\"\n [responsive]=\"true\"\n [resizableColumns]=\"true\"\n [scrollable]=\"true\"\n scrollDirection=\"vertical\"\n responsiveLayout=\"scroll\"\n [scrollHeight]=\"height\"\n [attr.selectionMode]=\"selectionMode\"\n [(selection)]=\"selectedItems\"\n (onRowSelect)=\"changeSelectedItems($event)\"\n (onRowUnselect)=\"changeSelectedItems($event)\"\n (onLazyLoad)=\"lazyLoaded({ filter: false, data: $event })\"\n >\n <ng-template pTemplate=\"header\">\n <tr class=\"header\">\n <th style=\"max-width: 3rem\" *ngIf=\"selectionType === 'checkbox'\">\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n </th>\n <th style=\"max-width: 100px\" class=\"centered\" *ngIf=\"hasActions\">A\u00E7\u00F5es</th>\n <th\n *ngFor=\"let col of columns\"\n [ngStyle]=\"getColStyle(col)\"\n [pSortableColumn]=\"col.notSortable ? '' : col.field\"\n >\n {{ col.header }} <p-sortIcon *ngIf=\"!col.notSortable\" [field]=\"col.field\"></p-sortIcon>\n </th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-rowData let-item>\n <tr class=\"row\" [pSelectableRow]=\"rowData\">\n <ng-container *ngIf=\"selectionType === 'checkbox'\">\n <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\n <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n </td>\n </ng-container>\n <ng-container *ngIf=\"selectionType === 'radiobutton'\">\n <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\n <p-tableRadioButton [value]=\"item\"></p-tableRadioButton>\n </td>\n </ng-container>\n <td *ngIf=\"hasActions\" style=\"max-width: 100px\" class=\"centered\">\n <p-menu #menu [model]=\"item.actions\" [popup]=\"true\" appendTo=\"body\"></p-menu>\n <i class=\"actions-menu-button fas fa-cog\" (click)=\"menu.toggle($event)\"></i>\n </td>\n <td\n *ngFor=\"let col of columns\"\n class=\"cell\"\n [innerHTML]=\"getCellContent(item, col)\"\n (click)=\"col && col.clickFunction && col.clickFunction(item)\"\n [ngStyle]=\"getColStyle(col)\"\n ></td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\">\n <tr class=\"row\">\n <td class=\"no-results\" [attr.colspan]=\"columns.length + 1\">Nenhum resultado encontrado</td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"paginatorright\"> </ng-template>\n <ng-template let-item pTemplate=\"paginatordropdownitem\"> {{ item.value }} </ng-template>\n </p-table>\n </vector-panel>\n </div>\n</div>\n", styles: [".no-results{padding:15px;background-color:#fff;width:100%}.centered{display:flex;justify-content:center}.table-header-actions{display:flex;justify-content:flex-end;align-items:flex-end;width:100%;padding-right:7px;margin-bottom:15px!important}@media (min-width: 768px){.table-header-actions{margin-top:-3px}}.table-header-actions .export-button{padding:7px 10px;color:#fff;display:flex;align-items:center;border:none;border-radius:5px;margin:5px;font-size:.75rem;cursor:pointer}.table-header-actions .export-button.export-excel{background-color:var(--success-color)}.table-header-actions .export-button.export-excel:hover{background-color:var(--success-color-dark)}.table-header-actions .export-button.export-pdf{background-color:var(--error-color)}.table-header-actions .export-button.export-pdf:hover{background-color:var(--error-color-dark)}.table-header-actions .export-button i{color:#fff}.table-header-actions .export-button span{margin-left:5px}.table-header-actions .add-item-button{margin-left:10px}.actions-menu-button{font-size:23px;cursor:pointer;color:var(--theme-medium)}\n"], components: [{ type: i1.FiltersComponent, selector: "vector-filters", inputs: ["fields"], outputs: ["onSearch", "formBuilded"] }, { type: i2.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }, { type: i3.PanelComponent, selector: "vector-panel" }, { type: i4.TabView, selector: "p-tabView", inputs: ["orientation", "style", "styleClass", "controlClose", "scrollable", "activeIndex"], outputs: ["onChange", "onClose", "activeIndexChange"] }, { type: i4.TabPanel, selector: "p-tabPanel", inputs: ["closable", "headerStyle", "headerStyleClass", "cache", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "selected", "disabled", "header", "leftIcon", "rightIcon"] }, { type: i5.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "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", "virtualScrollDelay", "virtualRowHeight", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "minBufferPx", "maxBufferPx", "responsiveLayout", "breakpoint", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["selectAllChange", "selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { type: i5.TableHeaderCheckbox, selector: "p-tableHeaderCheckbox", inputs: ["disabled", "inputId", "name", "ariaLabel"] }, { type: i5.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { type: i5.TableCheckbox, selector: "p-tableCheckbox", inputs: ["disabled", "value", "index", "inputId", "name", "required", "ariaLabel"] }, { type: i5.TableRadioButton, selector: "p-tableRadioButton", inputs: ["disabled", "value", "index", "inputId", "name", "ariaLabel"] }, { type: i6.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { type: i5.SelectableRow, selector: "[pSelectableRow]", inputs: ["pSelectableRow", "pSelectableRowIndex", "pSelectableRowDisabled"] }] });
|
|
214
231
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: DataTableComponent, decorators: [{
|
|
215
232
|
type: Component,
|
|
216
|
-
args: [{ selector: 'vector-data-table', template: "<div class=\"grid\">\n <div class=\"col-12\">\n <vector-filters\n [fields]=\"filters\"\n (onSearch)=\"lazyLoaded({ filter: true, data: $event })\"\n (formBuilded)=\"subscribeToFilterChanges()\"\n ></vector-filters>\n </div>\n <div class=\"table-header-actions field\" *ngIf=\"addItemLabel || exportExcel || exportPDF\">\n <button *ngIf=\"exportExcel\" (click)=\"onExportExcel.emit()\" class=\"export-button export-excel\">\n <i class=\"fas fa-file\"></i><span>Excel</span>\n </button>\n <button *ngIf=\"exportPDF\" (click)=\"onExportPDF.emit()\" class=\"export-button export-pdf\">\n <i class=\"fas fa-file\"></i><span>PDF</span>\n </button>\n <vector-button\n *ngIf=\"addItemLabel\"\n class=\"add-item-button\"\n [label]=\"addItemLabel\"\n (click)=\"onAdd.emit()\"\n [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\n ></vector-button>\n </div>\n <div class=\"col-12\">\n <vector-panel class=\"data-table-panel\">\n <p-tabView (onChange)=\"onTabChange($event)\" *ngIf=\"tabs?.length\">\n <p-tabPanel *ngFor=\"let tab of tabs\" [header]=\"tab.name\"></p-tabPanel>\n </p-tabView>\n <p-table\n currentPageReportTemplate=\"Mostrando {first} at\u00E9 {last} de {totalRecords} registros\"\n sortMode=\"single\"\n [rows]=\"10\"\n [lazy]=\"pagination && !virtualPagination\"\n [value]=\"data\"\n [paginator]=\"pagination\"\n [totalRecords]=\"totalRecords\"\n [showCurrentPageReport]=\"true\"\n [rowsPerPageOptions]=\"[10, 25, 50, 100]\"\n [responsive]=\"true\"\n [resizableColumns]=\"true\"\n [scrollable]=\"true\"\n scrollDirection=\"vertical\"\n responsiveLayout=\"scroll\"\n [scrollHeight]=\"height\"\n [selectionMode]=\"selectionMode\"\n [(selection)]=\"selectedItems\"\n (onRowSelect)=\"changeSelectedItems($event)\"\n (onRowUnselect)=\"changeSelectedItems($event)\"\n (onLazyLoad)=\"lazyLoaded({ filter: false, data: $event })\"\n >\n <ng-template pTemplate=\"header\">\n <tr class=\"header\">\n <th style=\"max-width: 100px\" class=\"centered\" *ngIf=\"hasActions\">A\u00E7\u00F5es</th>\n <th\n *ngFor=\"let col of columns\"\n [ngStyle]=\"getColStyle(col)\"\n [pSortableColumn]=\"col.notSortable ? '' : col.field\"\n >\n {{ col.header }} <p-sortIcon *ngIf=\"!col.notSortable\" [field]=\"col.field\"></p-sortIcon>\n </th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-rowData let-item>\n <tr class=\"row\" [pSelectableRow]=\"rowData\">\n <td *ngIf=\"hasActions\" style=\"max-width: 100px\" class=\"centered\">\n <p-menu #menu [model]=\"item.actions\" [popup]=\"true\" appendTo=\"body\"></p-menu>\n <i class=\"actions-menu-button fas fa-cog\" (click)=\"menu.toggle($event)\"></i>\n </td>\n <td\n *ngFor=\"let col of columns\"\n class=\"cell\"\n [innerHTML]=\"getCellContent(item, col)\"\n (click)=\"col && col.clickFunction && col.clickFunction(item)\"\n [ngStyle]=\"getColStyle(col)\"\n ></td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\">\n <tr class=\"row\">\n <td class=\"no-results\" [attr.colspan]=\"columns.length + 1\">Nenhum resultado encontrado</td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"paginatorright\"> </ng-template>\n <ng-template let-item pTemplate=\"paginatordropdownitem\"> {{ item.value }} </ng-template>\n </p-table>\n </vector-panel>\n </div>\n</div>\n", styles: [".no-results{padding:15px;background-color:#fff;width:100%}.centered{display:flex;justify-content:center}.table-header-actions{display:flex;justify-content:flex-end;align-items:flex-end;width:100%;padding-right:7px;margin-bottom:15px!important}@media (min-width: 768px){.table-header-actions{margin-top:-3px}}.table-header-actions .export-button{padding:7px 10px;color:#fff;display:flex;align-items:center;border:none;border-radius:5px;margin:5px;font-size:.75rem;cursor:pointer}.table-header-actions .export-button.export-excel{background-color:var(--success-color)}.table-header-actions .export-button.export-excel:hover{background-color:var(--success-color-dark)}.table-header-actions .export-button.export-pdf{background-color:var(--error-color)}.table-header-actions .export-button.export-pdf:hover{background-color:var(--error-color-dark)}.table-header-actions .export-button i{color:#fff}.table-header-actions .export-button span{margin-left:5px}.table-header-actions .add-item-button{margin-left:10px}.actions-menu-button{font-size:23px;cursor:pointer;color:var(--theme-medium)}\n"] }]
|
|
233
|
+
args: [{ selector: 'vector-data-table', template: "<div class=\"grid\">\n <div class=\"col-12\">\n <vector-filters\n [fields]=\"filters\"\n (onSearch)=\"lazyLoaded({ filter: true, data: $event })\"\n (formBuilded)=\"subscribeToFilterChanges()\"\n ></vector-filters>\n </div>\n <div class=\"table-header-actions field\" *ngIf=\"addItemLabel || exportExcel || exportPDF\">\n <button *ngIf=\"exportExcel\" (click)=\"onExportExcel.emit()\" class=\"export-button export-excel\">\n <i class=\"fas fa-file\"></i><span>Excel</span>\n </button>\n <button *ngIf=\"exportPDF\" (click)=\"onExportPDF.emit()\" class=\"export-button export-pdf\">\n <i class=\"fas fa-file\"></i><span>PDF</span>\n </button>\n <vector-button\n *ngIf=\"addItemLabel\"\n class=\"add-item-button\"\n [label]=\"addItemLabel\"\n (click)=\"onAdd.emit()\"\n [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\n ></vector-button>\n </div>\n <div class=\"col-12\">\n <vector-panel class=\"data-table-panel\">\n <p-tabView (onChange)=\"onTabChange($event)\" *ngIf=\"tabs?.length\">\n <p-tabPanel *ngFor=\"let tab of tabs\" [header]=\"tab.name\"></p-tabPanel>\n </p-tabView>\n <p-table\n currentPageReportTemplate=\"Mostrando {first} at\u00E9 {last} de {totalRecords} registros\"\n sortMode=\"single\"\n [rows]=\"10\"\n [lazy]=\"pagination && !virtualPagination\"\n [value]=\"data\"\n [paginator]=\"pagination\"\n [totalRecords]=\"totalRecords\"\n [showCurrentPageReport]=\"true\"\n [rowsPerPageOptions]=\"[10, 25, 50, 100]\"\n [responsive]=\"true\"\n [resizableColumns]=\"true\"\n [scrollable]=\"true\"\n scrollDirection=\"vertical\"\n responsiveLayout=\"scroll\"\n [scrollHeight]=\"height\"\n [attr.selectionMode]=\"selectionMode\"\n [(selection)]=\"selectedItems\"\n (onRowSelect)=\"changeSelectedItems($event)\"\n (onRowUnselect)=\"changeSelectedItems($event)\"\n (onLazyLoad)=\"lazyLoaded({ filter: false, data: $event })\"\n >\n <ng-template pTemplate=\"header\">\n <tr class=\"header\">\n <th style=\"max-width: 3rem\" *ngIf=\"selectionType === 'checkbox'\">\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n </th>\n <th style=\"max-width: 100px\" class=\"centered\" *ngIf=\"hasActions\">A\u00E7\u00F5es</th>\n <th\n *ngFor=\"let col of columns\"\n [ngStyle]=\"getColStyle(col)\"\n [pSortableColumn]=\"col.notSortable ? '' : col.field\"\n >\n {{ col.header }} <p-sortIcon *ngIf=\"!col.notSortable\" [field]=\"col.field\"></p-sortIcon>\n </th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-rowData let-item>\n <tr class=\"row\" [pSelectableRow]=\"rowData\">\n <ng-container *ngIf=\"selectionType === 'checkbox'\">\n <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\n <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n </td>\n </ng-container>\n <ng-container *ngIf=\"selectionType === 'radiobutton'\">\n <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\n <p-tableRadioButton [value]=\"item\"></p-tableRadioButton>\n </td>\n </ng-container>\n <td *ngIf=\"hasActions\" style=\"max-width: 100px\" class=\"centered\">\n <p-menu #menu [model]=\"item.actions\" [popup]=\"true\" appendTo=\"body\"></p-menu>\n <i class=\"actions-menu-button fas fa-cog\" (click)=\"menu.toggle($event)\"></i>\n </td>\n <td\n *ngFor=\"let col of columns\"\n class=\"cell\"\n [innerHTML]=\"getCellContent(item, col)\"\n (click)=\"col && col.clickFunction && col.clickFunction(item)\"\n [ngStyle]=\"getColStyle(col)\"\n ></td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\">\n <tr class=\"row\">\n <td class=\"no-results\" [attr.colspan]=\"columns.length + 1\">Nenhum resultado encontrado</td>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"paginatorright\"> </ng-template>\n <ng-template let-item pTemplate=\"paginatordropdownitem\"> {{ item.value }} </ng-template>\n </p-table>\n </vector-panel>\n </div>\n</div>\n", styles: [".no-results{padding:15px;background-color:#fff;width:100%}.centered{display:flex;justify-content:center}.table-header-actions{display:flex;justify-content:flex-end;align-items:flex-end;width:100%;padding-right:7px;margin-bottom:15px!important}@media (min-width: 768px){.table-header-actions{margin-top:-3px}}.table-header-actions .export-button{padding:7px 10px;color:#fff;display:flex;align-items:center;border:none;border-radius:5px;margin:5px;font-size:.75rem;cursor:pointer}.table-header-actions .export-button.export-excel{background-color:var(--success-color)}.table-header-actions .export-button.export-excel:hover{background-color:var(--success-color-dark)}.table-header-actions .export-button.export-pdf{background-color:var(--error-color)}.table-header-actions .export-button.export-pdf:hover{background-color:var(--error-color-dark)}.table-header-actions .export-button i{color:#fff}.table-header-actions .export-button span{margin-left:5px}.table-header-actions .add-item-button{margin-left:10px}.actions-menu-button{font-size:23px;cursor:pointer;color:var(--theme-medium)}\n"] }]
|
|
217
234
|
}], ctorParameters: function () { return []; }, propDecorators: { columns: [{
|
|
218
235
|
type: Input
|
|
219
236
|
}], data: [{
|
|
@@ -240,6 +257,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
240
257
|
type: Input
|
|
241
258
|
}], selectionMode: [{
|
|
242
259
|
type: Input
|
|
260
|
+
}], selectionType: [{
|
|
261
|
+
type: Input
|
|
243
262
|
}], height: [{
|
|
244
263
|
type: Input
|
|
245
264
|
}], onLazyLoad: [{
|
|
@@ -260,4 +279,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
260
279
|
type: ViewChild,
|
|
261
280
|
args: [FiltersComponent, { static: true }]
|
|
262
281
|
}] } });
|
|
263
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/data-table/data-table.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { DateTime } from 'luxon';\nimport { Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport { FilterChangedEvent, ListItem, Status } from '../../../models';\nimport { DataTableLazyLoadEvent, TableColumn, TableColumnType } from '../../../models/data-table.model';\nimport { MaskUtil } from '../../../utils';\nimport { FilterField, FiltersComponent } from '../filters/filters.component';\n\n@Component({\n  selector: 'vector-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n})\nexport class DataTableComponent implements OnInit, OnDestroy {\n  @Input()\n  public columns: TableColumn[] = [];\n  @Input()\n  public data: any[] = [];\n  @Input()\n  public exportExcel = false;\n  @Input()\n  public exportPDF = false;\n  @Input()\n  public totalRecords = 0;\n  @Input()\n  public filters: FilterField[] = [];\n  @Input()\n  public addItemLabel = '';\n  @Input()\n  public pagination = true;\n  @Input()\n  public virtualPagination = false;\n  @Input()\n  public set tabs(_tabs: ListItem[]) {\n    this._tabs = _tabs;\n    this._tabSelected = _tabs[0];\n  }\n  @Input()\n  public addItemButtonPlusSign = false;\n  @Input()\n  public hasActions: boolean = true;\n  @Input()\n  public selectionMode: 'single' | 'multiple' | '' = '';\n  @Input()\n  public set height(_height: string) {\n    switch (_height) {\n      case 'small':\n        this._height = '300px';\n        break;\n      case 'medium':\n        this._height = '500px';\n        break;\n      case 'large':\n        this._height = '700px';\n        break;\n      case 'full':\n        this._height = 'flex';\n        break;\n      default:\n        this._height = '300px';\n    }\n  }\n  @Output()\n  public onLazyLoad = new EventEmitter<DataTableLazyLoadEvent>();\n  @Output()\n  public onFilter = new EventEmitter<any>();\n  @Output()\n  public onAdd = new EventEmitter<void>();\n  @Output()\n  public onExportExcel = new EventEmitter<void>();\n  @Output()\n  public onExportPDF = new EventEmitter<void>();\n  @Output()\n  public onSelectedRows = new EventEmitter<any>();\n  @Output()\n  public onFilterChanged = new EventEmitter<FilterChangedEvent>();\n  @ViewChild(FiltersComponent, { static: true })\n  public filtersComponent: FiltersComponent | undefined;\n\n  public selectedItems: any = [];\n\n  get tabs() {\n    return this._tabs;\n  }\n  get height() {\n    return this._height;\n  }\n\n  private _height: string = 'small';\n  private _tabs: ListItem[] = [];\n  private _draw = 1;\n  private _firstLazyLoadedDone = false;\n  private _lastLazyLoadEvent: DataTableLazyLoadEvent | undefined;\n  private _tabSelected: ListItem | undefined;\n  private _filterSubscription = new Subscription();\n\n  constructor() {}\n\n  ngOnInit(): void {\n    if (!this.height) {\n      this.height = 'small';\n    }\n\n    if (!this.pagination || this.virtualPagination) {\n      this.filtersComponent?.search();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._filterSubscription.unsubscribe();\n  }\n\n  getColStyle(col: TableColumn) {\n    return { 'min-width': col.width };\n  }\n\n  lazyLoaded(params: { filter: boolean; data: any } = { filter: false, data: { start: 0, rows: 10 } }) {\n    if (!params.filter) {\n      const columns = this.columns.map((col) => {\n        return {\n          data: col.field,\n          name: `${col.field.substring(0, 1).toUpperCase()}${col.field.substring(1, col.field.length)}`,\n          orderable: true,\n          search: { value: '', regex: false },\n          searchable: true,\n        };\n      });\n      if (this.hasActions) {\n        columns.unshift({\n          data: 'active',\n          name: 'Active',\n          orderable: true,\n          search: { value: '', regex: false },\n          searchable: true,\n        });\n      }\n      this._lastLazyLoadEvent = {\n        ...(this._lastLazyLoadEvent || ({} as any)),\n        start: params.data.first,\n        length: params.data.rows,\n        draw: this._draw++,\n        order: params.data.sortField\n          ? [\n              {\n                column:\n                  this.columns.findIndex((col) => col.field === params.data.sortField) + (this.hasActions ? 1 : 0),\n                dir: params.data.sortOrder > 0 ? 'asc' : 'desc',\n              },\n            ]\n          : [{ column: 0, dir: 'desc' }],\n        columns: columns,\n      };\n    } else {\n      this._lastLazyLoadEvent = {\n        ...this._lastLazyLoadEvent,\n        ...params.data,\n      };\n      if (this._tabSelected) {\n        this._lastLazyLoadEvent = {\n          ...(this._lastLazyLoadEvent || ({} as any)),\n          ...{ Status: this._tabSelected.code },\n        };\n      }\n    }\n\n    if (this._firstLazyLoadedDone) {\n      this.onLazyLoad.emit(this._lastLazyLoadEvent);\n    }\n    this._firstLazyLoadedDone = true;\n  }\n\n  getCellContent(item: any, col: TableColumn) {\n    let content = `<span class=\"p-column-title\">${col.header}</span><span class=\"w-100\">`;\n    if (!col.type || col.type === TableColumnType.TEXT) {\n      content += item[col.field] || '';\n    }\n\n    if (col.type === TableColumnType.CUSTOM_STYLE) {\n      content += `<span class=\"${col.textFieldClass ? item[col.textFieldClass] : ''}\">${item[col.field || '']}</span>`;\n    }\n\n    if (col.type === TableColumnType.BOOLEAN) {\n      content += `<div class=\"text-centered\"><i class=\" status-table-field fas fa-${\n        item[col.field] ? 'check boolean-value-positive' : 'times boolean-value-negative'\n      }\"></i></div>`;\n    }\n\n    if (col.type === TableColumnType.ENUM && col.getEnumTranslated) {\n      content += col.getEnumTranslated(item[col.field]);\n    }\n\n    if (col.type === TableColumnType.DATETIME && item[col.field]) {\n      const dateTime =\n        item[col.field] instanceof Date ? DateTime.fromJSDate(item[col.field]) : DateTime.fromISO(item[col.field]);\n      content += dateTime.toFormat('dd/MM/yyyy HH:mm');\n    }\n\n    if (col.type === TableColumnType.STATUS_BADGE) {\n      content += `<div class=\"text-centered\"><i class=\"fas fa-circle status-table-field ${this.getStatusColor(\n        item[col.field]\n      )}\"></i></div>`;\n    }\n\n    if (col.type === TableColumnType.ACTIVE_BOOLEAN_BADGE) {\n      content += `<div class=\"text-centered\"><i class=\"fas fa-circle status-table-field ${this.getActiveStatusColor(\n        item[col.field]\n      )}\"></i></div>`;\n    }\n\n    if (col.type === TableColumnType.BUTTON) {\n      content += `<div class=\"text-centered\"><i class=\"fas ${\n        col.icon || 'fa-circle'\n      } status-table-field table-button\"></i></div>`;\n    }\n\n    if (col.type === TableColumnType.MASK) {\n      content += MaskUtil.doMaskString(item[col.field] || '', col.mask);\n    }\n\n    content += `</span>`;\n    return content;\n  }\n\n  onTabChange($event: any) {\n    this._tabSelected = this.tabs[$event.index];\n    this.lazyLoaded({ filter: true, data: {} });\n  }\n\n  subscribeToFilterChanges() {\n    this._filterSubscription.unsubscribe();\n    this._filterSubscription = new Subscription();\n    Object.keys(this.filtersComponent?.formGroup.controls || {}).forEach((key) => {\n      this._filterSubscription.add(\n        this.filtersComponent?.formGroup\n          .get(key)\n          ?.valueChanges.pipe(debounceTime(300))\n          .subscribe((value) => {\n            this.onFilterChanged.emit({ field: key, value });\n          })\n      );\n      this.onFilterChanged.emit({ field: key, value: this.filtersComponent?.formGroup.get(key)?.value });\n    });\n  }\n\n  get listHasActions() {\n    return this.data.some((item) => item.actions?.length);\n  }\n\n  private getStatusColor(status: Status) {\n    switch (status) {\n      case Status.PENDING:\n        return 'warning';\n      case Status.APPROVED:\n        return 'success';\n      case Status.REJECTED:\n        return 'error';\n    }\n    return '';\n  }\n\n  private getActiveStatusColor(active: boolean) {\n    return active ? 'success' : 'error';\n  }\n\n  public changeSelectedItems(value: any) {\n    this.onSelectedRows.emit(this.selectedItems);\n  }\n}\n","<div class=\"grid\">\n  <div class=\"col-12\">\n    <vector-filters\n      [fields]=\"filters\"\n      (onSearch)=\"lazyLoaded({ filter: true, data: $event })\"\n      (formBuilded)=\"subscribeToFilterChanges()\"\n    ></vector-filters>\n  </div>\n  <div class=\"table-header-actions field\" *ngIf=\"addItemLabel || exportExcel || exportPDF\">\n    <button *ngIf=\"exportExcel\" (click)=\"onExportExcel.emit()\" class=\"export-button export-excel\">\n      <i class=\"fas fa-file\"></i><span>Excel</span>\n    </button>\n    <button *ngIf=\"exportPDF\" (click)=\"onExportPDF.emit()\" class=\"export-button export-pdf\">\n      <i class=\"fas fa-file\"></i><span>PDF</span>\n    </button>\n    <vector-button\n      *ngIf=\"addItemLabel\"\n      class=\"add-item-button\"\n      [label]=\"addItemLabel\"\n      (click)=\"onAdd.emit()\"\n      [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\n    ></vector-button>\n  </div>\n  <div class=\"col-12\">\n    <vector-panel class=\"data-table-panel\">\n      <p-tabView (onChange)=\"onTabChange($event)\" *ngIf=\"tabs?.length\">\n        <p-tabPanel *ngFor=\"let tab of tabs\" [header]=\"tab.name\"></p-tabPanel>\n      </p-tabView>\n      <p-table\n        currentPageReportTemplate=\"Mostrando {first} até {last} de {totalRecords} registros\"\n        sortMode=\"single\"\n        [rows]=\"10\"\n        [lazy]=\"pagination && !virtualPagination\"\n        [value]=\"data\"\n        [paginator]=\"pagination\"\n        [totalRecords]=\"totalRecords\"\n        [showCurrentPageReport]=\"true\"\n        [rowsPerPageOptions]=\"[10, 25, 50, 100]\"\n        [responsive]=\"true\"\n        [resizableColumns]=\"true\"\n        [scrollable]=\"true\"\n        scrollDirection=\"vertical\"\n        responsiveLayout=\"scroll\"\n        [scrollHeight]=\"height\"\n        [selectionMode]=\"selectionMode\"\n        [(selection)]=\"selectedItems\"\n        (onRowSelect)=\"changeSelectedItems($event)\"\n        (onRowUnselect)=\"changeSelectedItems($event)\"\n        (onLazyLoad)=\"lazyLoaded({ filter: false, data: $event })\"\n      >\n        <ng-template pTemplate=\"header\">\n          <tr class=\"header\">\n            <th style=\"max-width: 100px\" class=\"centered\" *ngIf=\"hasActions\">Ações</th>\n            <th\n              *ngFor=\"let col of columns\"\n              [ngStyle]=\"getColStyle(col)\"\n              [pSortableColumn]=\"col.notSortable ? '' : col.field\"\n            >\n              {{ col.header }} <p-sortIcon *ngIf=\"!col.notSortable\" [field]=\"col.field\"></p-sortIcon>\n            </th>\n          </tr>\n        </ng-template>\n        <ng-template pTemplate=\"body\" let-rowData let-item>\n          <tr class=\"row\" [pSelectableRow]=\"rowData\">\n            <td *ngIf=\"hasActions\" style=\"max-width: 100px\" class=\"centered\">\n              <p-menu #menu [model]=\"item.actions\" [popup]=\"true\" appendTo=\"body\"></p-menu>\n              <i class=\"actions-menu-button fas fa-cog\" (click)=\"menu.toggle($event)\"></i>\n            </td>\n            <td\n              *ngFor=\"let col of columns\"\n              class=\"cell\"\n              [innerHTML]=\"getCellContent(item, col)\"\n              (click)=\"col && col.clickFunction && col.clickFunction(item)\"\n              [ngStyle]=\"getColStyle(col)\"\n            ></td>\n          </tr>\n        </ng-template>\n        <ng-template pTemplate=\"emptymessage\">\n          <tr class=\"row\">\n            <td class=\"no-results\" [attr.colspan]=\"columns.length + 1\">Nenhum resultado encontrado</td>\n          </tr>\n        </ng-template>\n        <ng-template pTemplate=\"paginatorright\"> </ng-template>\n        <ng-template let-item pTemplate=\"paginatordropdownitem\"> {{ item.value }} </ng-template>\n      </p-table>\n    </vector-panel>\n  </div>\n</div>\n"]}
|
|
282
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/data-table/data-table.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { DateTime } from 'luxon';\nimport { Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport { FilterChangedEvent, ListItem, Status } from '../../../models';\nimport { DataTableLazyLoadEvent, TableColumn, TableColumnType } from '../../../models/data-table.model';\nimport { MaskUtil } from '../../../utils';\nimport { FilterField, FiltersComponent } from '../filters/filters.component';\n\n@Component({\n  selector: 'vector-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n})\nexport class DataTableComponent implements OnInit, OnDestroy {\n  @Input()\n  public columns: TableColumn[] = [];\n  @Input()\n  public data: any[] = [];\n  @Input()\n  public exportExcel = false;\n  @Input()\n  public exportPDF = false;\n  @Input()\n  public totalRecords = 0;\n  @Input()\n  public filters: FilterField[] = [];\n  @Input()\n  public addItemLabel = '';\n  @Input()\n  public pagination = true;\n  @Input()\n  public virtualPagination = false;\n  @Input()\n  public set tabs(_tabs: ListItem[]) {\n    this._tabs = _tabs;\n    this._tabSelected = _tabs[0];\n  }\n  @Input()\n  public addItemButtonPlusSign = false;\n  @Input()\n  public hasActions: boolean = true;\n  @Input()\n  public set selectionMode(_selectionMode) {\n    switch (_selectionMode) {\n      case 'single':\n        this._selectionMode = 'single';\n        break;\n      case 'multiple':\n        this._selectionMode = 'multiple';\n        break;\n      default:\n        this._selectionMode = null;\n        break;\n    }\n  }\n  @Input()\n  public selectionType: 'checkbox' | 'radiobutton' | null = null;\n  @Input()\n  public set height(_height: string) {\n    switch (_height) {\n      case 'small':\n        this._height = '300px';\n        break;\n      case 'medium':\n        this._height = '500px';\n        break;\n      case 'large':\n        this._height = '700px';\n        break;\n      case 'full':\n        this._height = 'flex';\n        break;\n      default:\n        this._height = '300px';\n    }\n  }\n  @Output()\n  public onLazyLoad = new EventEmitter<DataTableLazyLoadEvent>();\n  @Output()\n  public onFilter = new EventEmitter<any>();\n  @Output()\n  public onAdd = new EventEmitter<void>();\n  @Output()\n  public onExportExcel = new EventEmitter<void>();\n  @Output()\n  public onExportPDF = new EventEmitter<void>();\n  @Output()\n  public onSelectedRows = new EventEmitter<any>();\n  @Output()\n  public onFilterChanged = new EventEmitter<FilterChangedEvent>();\n  @ViewChild(FiltersComponent, { static: true })\n  public filtersComponent: FiltersComponent | undefined;\n\n  public selectedItems: any = [];\n\n  get tabs() {\n    return this._tabs;\n  }\n  get height() {\n    return this._height;\n  }\n  get selectionMode() {\n    return this._selectionMode;\n  }\n\n  private _selectionMode: 'single' | 'multiple' | null = null;\n  private _height: string = 'small';\n  private _tabs: ListItem[] = [];\n  private _draw = 1;\n  private _firstLazyLoadedDone = false;\n  private _lastLazyLoadEvent: DataTableLazyLoadEvent | undefined;\n  private _tabSelected: ListItem | undefined;\n  private _filterSubscription = new Subscription();\n\n  constructor() {}\n\n  ngOnInit(): void {\n    if (!this.height) {\n      this.height = 'small';\n    }\n\n    if (!this.pagination || this.virtualPagination) {\n      this.filtersComponent?.search();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._filterSubscription.unsubscribe();\n  }\n\n  getColStyle(col: TableColumn) {\n    return { 'min-width': col.width };\n  }\n\n  lazyLoaded(params: { filter: boolean; data: any } = { filter: false, data: { start: 0, rows: 10 } }) {\n    if (!params.filter) {\n      const columns = this.columns.map((col) => {\n        return {\n          data: col.field,\n          name: `${col.field.substring(0, 1).toUpperCase()}${col.field.substring(1, col.field.length)}`,\n          orderable: true,\n          search: { value: '', regex: false },\n          searchable: true,\n        };\n      });\n      if (this.hasActions) {\n        columns.unshift({\n          data: 'active',\n          name: 'Active',\n          orderable: true,\n          search: { value: '', regex: false },\n          searchable: true,\n        });\n      }\n      this._lastLazyLoadEvent = {\n        ...(this._lastLazyLoadEvent || ({} as any)),\n        start: params.data.first,\n        length: params.data.rows,\n        draw: this._draw++,\n        order: params.data.sortField\n          ? [\n              {\n                column:\n                  this.columns.findIndex((col) => col.field === params.data.sortField) + (this.hasActions ? 1 : 0),\n                dir: params.data.sortOrder > 0 ? 'asc' : 'desc',\n              },\n            ]\n          : [{ column: 0, dir: 'desc' }],\n        columns: columns,\n      };\n    } else {\n      this._lastLazyLoadEvent = {\n        ...this._lastLazyLoadEvent,\n        ...params.data,\n      };\n      if (this._tabSelected) {\n        this._lastLazyLoadEvent = {\n          ...(this._lastLazyLoadEvent || ({} as any)),\n          ...{ Status: this._tabSelected.code },\n        };\n      }\n    }\n\n    if (this._firstLazyLoadedDone) {\n      this.onLazyLoad.emit(this._lastLazyLoadEvent);\n    }\n    this._firstLazyLoadedDone = true;\n  }\n\n  getCellContent(item: any, col: TableColumn) {\n    let content = `<span class=\"p-column-title\">${col.header}</span><span class=\"w-100\">`;\n    if (!col.type || col.type === TableColumnType.TEXT) {\n      content += item[col.field] || '';\n    }\n\n    if (col.type === TableColumnType.CUSTOM_STYLE) {\n      content += `<span class=\"${col.textFieldClass ? item[col.textFieldClass] : ''}\">${item[col.field || '']}</span>`;\n    }\n\n    if (col.type === TableColumnType.BOOLEAN) {\n      content += `<div class=\"text-centered\"><i class=\" status-table-field fas fa-${\n        item[col.field] ? 'check boolean-value-positive' : 'times boolean-value-negative'\n      }\"></i></div>`;\n    }\n\n    if (col.type === TableColumnType.ENUM && col.getEnumTranslated) {\n      content += col.getEnumTranslated(item[col.field]);\n    }\n\n    if (col.type === TableColumnType.DATETIME && item[col.field]) {\n      const dateTime =\n        item[col.field] instanceof Date ? DateTime.fromJSDate(item[col.field]) : DateTime.fromISO(item[col.field]);\n      content += dateTime.toFormat('dd/MM/yyyy HH:mm');\n    }\n\n    if (col.type === TableColumnType.STATUS_BADGE) {\n      content += `<div class=\"text-centered\"><i class=\"fas fa-circle status-table-field ${this.getStatusColor(\n        item[col.field]\n      )}\"></i></div>`;\n    }\n\n    if (col.type === TableColumnType.ACTIVE_BOOLEAN_BADGE) {\n      content += `<div class=\"text-centered\"><i class=\"fas fa-circle status-table-field ${this.getActiveStatusColor(\n        item[col.field]\n      )}\"></i></div>`;\n    }\n\n    if (col.type === TableColumnType.BUTTON) {\n      content += `<div class=\"text-centered\"><i class=\"fas ${\n        col.icon || 'fa-circle'\n      } status-table-field table-button\"></i></div>`;\n    }\n\n    if (col.type === TableColumnType.MASK) {\n      content += MaskUtil.doMaskString(item[col.field] || '', col.mask);\n    }\n\n    content += `</span>`;\n    return content;\n  }\n\n  onTabChange($event: any) {\n    this._tabSelected = this.tabs[$event.index];\n    this.lazyLoaded({ filter: true, data: {} });\n  }\n\n  subscribeToFilterChanges() {\n    this._filterSubscription.unsubscribe();\n    this._filterSubscription = new Subscription();\n    Object.keys(this.filtersComponent?.formGroup.controls || {}).forEach((key) => {\n      this._filterSubscription.add(\n        this.filtersComponent?.formGroup\n          .get(key)\n          ?.valueChanges.pipe(debounceTime(300))\n          .subscribe((value) => {\n            this.onFilterChanged.emit({ field: key, value });\n          })\n      );\n      this.onFilterChanged.emit({ field: key, value: this.filtersComponent?.formGroup.get(key)?.value });\n    });\n  }\n\n  get listHasActions() {\n    return this.data.some((item) => item.actions?.length);\n  }\n\n  private getStatusColor(status: Status) {\n    switch (status) {\n      case Status.PENDING:\n        return 'warning';\n      case Status.APPROVED:\n        return 'success';\n      case Status.REJECTED:\n        return 'error';\n    }\n    return '';\n  }\n\n  private getActiveStatusColor(active: boolean) {\n    return active ? 'success' : 'error';\n  }\n\n  public changeSelectedItems(value: any) {\n    this.onSelectedRows.emit(this.selectedItems);\n  }\n}\n","<div class=\"grid\">\n  <div class=\"col-12\">\n    <vector-filters\n      [fields]=\"filters\"\n      (onSearch)=\"lazyLoaded({ filter: true, data: $event })\"\n      (formBuilded)=\"subscribeToFilterChanges()\"\n    ></vector-filters>\n  </div>\n  <div class=\"table-header-actions field\" *ngIf=\"addItemLabel || exportExcel || exportPDF\">\n    <button *ngIf=\"exportExcel\" (click)=\"onExportExcel.emit()\" class=\"export-button export-excel\">\n      <i class=\"fas fa-file\"></i><span>Excel</span>\n    </button>\n    <button *ngIf=\"exportPDF\" (click)=\"onExportPDF.emit()\" class=\"export-button export-pdf\">\n      <i class=\"fas fa-file\"></i><span>PDF</span>\n    </button>\n    <vector-button\n      *ngIf=\"addItemLabel\"\n      class=\"add-item-button\"\n      [label]=\"addItemLabel\"\n      (click)=\"onAdd.emit()\"\n      [rightIcon]=\"addItemButtonPlusSign ? 'pi pi-plus' : ''\"\n    ></vector-button>\n  </div>\n  <div class=\"col-12\">\n    <vector-panel class=\"data-table-panel\">\n      <p-tabView (onChange)=\"onTabChange($event)\" *ngIf=\"tabs?.length\">\n        <p-tabPanel *ngFor=\"let tab of tabs\" [header]=\"tab.name\"></p-tabPanel>\n      </p-tabView>\n      <p-table\n        currentPageReportTemplate=\"Mostrando {first} até {last} de {totalRecords} registros\"\n        sortMode=\"single\"\n        [rows]=\"10\"\n        [lazy]=\"pagination && !virtualPagination\"\n        [value]=\"data\"\n        [paginator]=\"pagination\"\n        [totalRecords]=\"totalRecords\"\n        [showCurrentPageReport]=\"true\"\n        [rowsPerPageOptions]=\"[10, 25, 50, 100]\"\n        [responsive]=\"true\"\n        [resizableColumns]=\"true\"\n        [scrollable]=\"true\"\n        scrollDirection=\"vertical\"\n        responsiveLayout=\"scroll\"\n        [scrollHeight]=\"height\"\n        [attr.selectionMode]=\"selectionMode\"\n        [(selection)]=\"selectedItems\"\n        (onRowSelect)=\"changeSelectedItems($event)\"\n        (onRowUnselect)=\"changeSelectedItems($event)\"\n        (onLazyLoad)=\"lazyLoaded({ filter: false, data: $event })\"\n      >\n        <ng-template pTemplate=\"header\">\n          <tr class=\"header\">\n            <th style=\"max-width: 3rem\" *ngIf=\"selectionType === 'checkbox'\">\n              <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n            </th>\n            <th style=\"max-width: 100px\" class=\"centered\" *ngIf=\"hasActions\">Ações</th>\n            <th\n              *ngFor=\"let col of columns\"\n              [ngStyle]=\"getColStyle(col)\"\n              [pSortableColumn]=\"col.notSortable ? '' : col.field\"\n            >\n              {{ col.header }} <p-sortIcon *ngIf=\"!col.notSortable\" [field]=\"col.field\"></p-sortIcon>\n            </th>\n          </tr>\n        </ng-template>\n        <ng-template pTemplate=\"body\" let-rowData let-item>\n          <tr class=\"row\" [pSelectableRow]=\"rowData\">\n            <ng-container *ngIf=\"selectionType === 'checkbox'\">\n              <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\n                <p-tableCheckbox [value]=\"item\"></p-tableCheckbox>\n              </td>\n            </ng-container>\n            <ng-container *ngIf=\"selectionType === 'radiobutton'\">\n              <td style=\"max-width: 3rem; padding-left: 10px\" class=\"flex justify-content-center align-items-center\">\n                <p-tableRadioButton [value]=\"item\"></p-tableRadioButton>\n              </td>\n            </ng-container>\n            <td *ngIf=\"hasActions\" style=\"max-width: 100px\" class=\"centered\">\n              <p-menu #menu [model]=\"item.actions\" [popup]=\"true\" appendTo=\"body\"></p-menu>\n              <i class=\"actions-menu-button fas fa-cog\" (click)=\"menu.toggle($event)\"></i>\n            </td>\n            <td\n              *ngFor=\"let col of columns\"\n              class=\"cell\"\n              [innerHTML]=\"getCellContent(item, col)\"\n              (click)=\"col && col.clickFunction && col.clickFunction(item)\"\n              [ngStyle]=\"getColStyle(col)\"\n            ></td>\n          </tr>\n        </ng-template>\n        <ng-template pTemplate=\"emptymessage\">\n          <tr class=\"row\">\n            <td class=\"no-results\" [attr.colspan]=\"columns.length + 1\">Nenhum resultado encontrado</td>\n          </tr>\n        </ng-template>\n        <ng-template pTemplate=\"paginatorright\"> </ng-template>\n        <ng-template let-item pTemplate=\"paginatordropdownitem\"> {{ item.value }} </ng-template>\n      </p-table>\n    </vector-panel>\n  </div>\n</div>\n"]}
|