ngx-vector-components 4.4.0 → 4.6.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 +17 -1
- package/esm2020/lib/components/crud-footer/crud-footer.component.mjs +6 -3
- package/esm2020/lib/components/fields/filters/filters.component.mjs +37 -25
- package/esm2020/lib/components/menu/menu.component.mjs +7 -5
- package/fesm2015/ngx-vector-components.mjs +36 -20
- package/fesm2015/ngx-vector-components.mjs.map +1 -1
- package/fesm2020/ngx-vector-components.mjs +36 -20
- package/fesm2020/ngx-vector-components.mjs.map +1 -1
- package/lib/components/crud-footer/crud-footer.component.d.ts +2 -1
- package/lib/components/fields/filters/filters.component.d.ts +4 -3
- package/package.json +7 -7
package/CHANGELOG.md
CHANGED
|
@@ -1,11 +1,27 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [4.6.0] (06/07/2022)
|
|
4
|
+
|
|
5
|
+
### Features
|
|
6
|
+
|
|
7
|
+
- Added `goBackHidden` parameter to hidden goBackButton in `vector-crud-footer`.
|
|
8
|
+
## [4.5.1] (30/06/2022)
|
|
9
|
+
|
|
10
|
+
### Bugfixes
|
|
11
|
+
|
|
12
|
+
- `menu` changed admin menu to show only fintech admin.
|
|
13
|
+
|
|
14
|
+
## [4.5.0] (29/06/2022)
|
|
15
|
+
|
|
16
|
+
### Features
|
|
17
|
+
|
|
18
|
+
- `vector-filters` changed to read the url queryParams to set default values.
|
|
19
|
+
|
|
3
20
|
## [4.4.0] (28/06/2022)
|
|
4
21
|
|
|
5
22
|
### Features
|
|
6
23
|
|
|
7
24
|
- Added `isExternalUrl` in `http-interceptor.ts`;
|
|
8
|
-
- Added `Height` input in `data-table`;
|
|
9
25
|
|
|
10
26
|
## [4.3.0] (27/06/2022)
|
|
11
27
|
|
|
@@ -6,23 +6,26 @@ export class CrudFooterComponent {
|
|
|
6
6
|
constructor() {
|
|
7
7
|
this.submitDisabled = false;
|
|
8
8
|
this.submitHidden = false;
|
|
9
|
+
this.goBackHidden = false;
|
|
9
10
|
this.onGoBack = new EventEmitter();
|
|
10
11
|
this.onSubmit = new EventEmitter();
|
|
11
12
|
}
|
|
12
13
|
ngOnInit() { }
|
|
13
14
|
}
|
|
14
15
|
CrudFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CrudFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
-
CrudFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CrudFooterComponent, selector: "vector-crud-footer", inputs: { submitDisabled: "submitDisabled", submitHidden: "submitHidden" }, outputs: { onGoBack: "onGoBack", onSubmit: "onSubmit" }, ngImport: i0, template: "<div class=\"footer-container shadow-3\">\r\n <div class=\"button\">\r\n <vector-button label=\"Voltar\" (onClick)=\"onGoBack.emit()\"></vector-button>\r\n </div>\r\n <div class=\"button\" *ngIf=\"!submitHidden\">\r\n <vector-button\r\n label=\"Salvar\"\r\n type=\"success\"\r\n (onClick)=\"onSubmit.emit()\"\r\n [disabled]=\"submitDisabled\"\r\n ></vector-button>\r\n </div>\r\n</div>\r\n", styles: [".footer-container{position:fixed;bottom:0px;left:0px;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:60px}.footer-container .button{margin-right:10px}\n"], components: [{ type: i1.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
16
|
+
CrudFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CrudFooterComponent, selector: "vector-crud-footer", inputs: { submitDisabled: "submitDisabled", submitHidden: "submitHidden", goBackHidden: "goBackHidden" }, outputs: { onGoBack: "onGoBack", onSubmit: "onSubmit" }, ngImport: i0, template: "<div class=\"footer-container shadow-3\">\r\n <div class=\"button\" *ngIf=\"!goBackHidden\">\r\n <vector-button label=\"Voltar\" (onClick)=\"onGoBack.emit()\"></vector-button>\r\n </div>\r\n <div class=\"button\" *ngIf=\"!submitHidden\">\r\n <vector-button\r\n label=\"Salvar\"\r\n type=\"success\"\r\n (onClick)=\"onSubmit.emit()\"\r\n [disabled]=\"submitDisabled\"\r\n ></vector-button>\r\n </div>\r\n</div>\r\n", styles: [".footer-container{position:fixed;bottom:0px;left:0px;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:60px}.footer-container .button{margin-right:10px}\n"], components: [{ type: i1.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
16
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CrudFooterComponent, decorators: [{
|
|
17
18
|
type: Component,
|
|
18
|
-
args: [{ selector: 'vector-crud-footer', template: "<div class=\"footer-container shadow-3\">\r\n <div class=\"button\">\r\n <vector-button label=\"Voltar\" (onClick)=\"onGoBack.emit()\"></vector-button>\r\n </div>\r\n <div class=\"button\" *ngIf=\"!submitHidden\">\r\n <vector-button\r\n label=\"Salvar\"\r\n type=\"success\"\r\n (onClick)=\"onSubmit.emit()\"\r\n [disabled]=\"submitDisabled\"\r\n ></vector-button>\r\n </div>\r\n</div>\r\n", styles: [".footer-container{position:fixed;bottom:0px;left:0px;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:60px}.footer-container .button{margin-right:10px}\n"] }]
|
|
19
|
+
args: [{ selector: 'vector-crud-footer', template: "<div class=\"footer-container shadow-3\">\r\n <div class=\"button\" *ngIf=\"!goBackHidden\">\r\n <vector-button label=\"Voltar\" (onClick)=\"onGoBack.emit()\"></vector-button>\r\n </div>\r\n <div class=\"button\" *ngIf=\"!submitHidden\">\r\n <vector-button\r\n label=\"Salvar\"\r\n type=\"success\"\r\n (onClick)=\"onSubmit.emit()\"\r\n [disabled]=\"submitDisabled\"\r\n ></vector-button>\r\n </div>\r\n</div>\r\n", styles: [".footer-container{position:fixed;bottom:0px;left:0px;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:60px}.footer-container .button{margin-right:10px}\n"] }]
|
|
19
20
|
}], ctorParameters: function () { return []; }, propDecorators: { submitDisabled: [{
|
|
20
21
|
type: Input
|
|
21
22
|
}], submitHidden: [{
|
|
22
23
|
type: Input
|
|
24
|
+
}], goBackHidden: [{
|
|
25
|
+
type: Input
|
|
23
26
|
}], onGoBack: [{
|
|
24
27
|
type: Output
|
|
25
28
|
}], onSubmit: [{
|
|
26
29
|
type: Output
|
|
27
30
|
}] } });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3J1ZC1mb290ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jcnVkLWZvb3Rlci9jcnVkLWZvb3Rlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmVjdG9yLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NydWQtZm9vdGVyL2NydWQtZm9vdGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFPL0UsTUFBTSxPQUFPLG1CQUFtQjtJQVk5QjtRQVZPLG1CQUFjLEdBQUcsS0FBSyxDQUFDO1FBRXZCLGlCQUFZLEdBQUcsS0FBSyxDQUFDO1FBRXJCLGlCQUFZLEdBQUcsS0FBSyxDQUFDO1FBRXJCLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRXBDLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO0lBRTVCLENBQUM7SUFFaEIsUUFBUSxLQUFVLENBQUM7O2dIQWRSLG1CQUFtQjtvR0FBbkIsbUJBQW1CLDZOQ1BoQyxnY0FhQTsyRkROYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0Usb0JBQW9COzBFQU12QixjQUFjO3NCQURwQixLQUFLO2dCQUdDLFlBQVk7c0JBRGxCLEtBQUs7Z0JBR0MsWUFBWTtzQkFEbEIsS0FBSztnQkFHQyxRQUFRO3NCQURkLE1BQU07Z0JBR0EsUUFBUTtzQkFEZCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd2ZWN0b3ItY3J1ZC1mb290ZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jcnVkLWZvb3Rlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY3J1ZC1mb290ZXIuY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENydWRGb290ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHN1Ym1pdERpc2FibGVkID0gZmFsc2U7XHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc3VibWl0SGlkZGVuID0gZmFsc2U7XHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZ29CYWNrSGlkZGVuID0gZmFsc2U7XHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIG9uR29CYWNrID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBvblN1Ym1pdCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHt9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImZvb3Rlci1jb250YWluZXIgc2hhZG93LTNcIj5cclxuICA8ZGl2IGNsYXNzPVwiYnV0dG9uXCIgKm5nSWY9XCIhZ29CYWNrSGlkZGVuXCI+XHJcbiAgICA8dmVjdG9yLWJ1dHRvbiBsYWJlbD1cIlZvbHRhclwiIChvbkNsaWNrKT1cIm9uR29CYWNrLmVtaXQoKVwiPjwvdmVjdG9yLWJ1dHRvbj5cclxuICA8L2Rpdj5cclxuICA8ZGl2IGNsYXNzPVwiYnV0dG9uXCIgKm5nSWY9XCIhc3VibWl0SGlkZGVuXCI+XHJcbiAgICA8dmVjdG9yLWJ1dHRvblxyXG4gICAgICBsYWJlbD1cIlNhbHZhclwiXHJcbiAgICAgIHR5cGU9XCJzdWNjZXNzXCJcclxuICAgICAgKG9uQ2xpY2spPVwib25TdWJtaXQuZW1pdCgpXCJcclxuICAgICAgW2Rpc2FibGVkXT1cInN1Ym1pdERpc2FibGVkXCJcclxuICAgID48L3ZlY3Rvci1idXR0b24+XHJcbiAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -3,15 +3,16 @@ import { FormControl, FormGroup, Validators } from '@angular/forms';
|
|
|
3
3
|
import { Subscription } from 'rxjs';
|
|
4
4
|
import { ObjectUtil } from '../../../utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "
|
|
7
|
-
import * as i2 from "../
|
|
8
|
-
import * as i3 from "../
|
|
9
|
-
import * as i4 from "../
|
|
10
|
-
import * as i5 from "../
|
|
11
|
-
import * as i6 from "../button/button.component";
|
|
12
|
-
import * as i7 from "
|
|
13
|
-
import * as i8 from "@angular/
|
|
14
|
-
import * as i9 from "
|
|
6
|
+
import * as i1 from "@angular/router";
|
|
7
|
+
import * as i2 from "../text-field/text-field.component";
|
|
8
|
+
import * as i3 from "../dropdown-field/dropdown-field.component";
|
|
9
|
+
import * as i4 from "../currency-field/currency-field.component";
|
|
10
|
+
import * as i5 from "../calendar-field/calendar-field.component";
|
|
11
|
+
import * as i6 from "../select-button-field/select-button-field.component";
|
|
12
|
+
import * as i7 from "../button/button.component";
|
|
13
|
+
import * as i8 from "@angular/common";
|
|
14
|
+
import * as i9 from "@angular/forms";
|
|
15
|
+
import * as i10 from "../../../pipes/not-hidden.pipe";
|
|
15
16
|
export var FieldType;
|
|
16
17
|
(function (FieldType) {
|
|
17
18
|
FieldType[FieldType["DROPDOWN"] = 0] = "DROPDOWN";
|
|
@@ -23,26 +24,32 @@ export var FieldType;
|
|
|
23
24
|
FieldType[FieldType["SELECT_BUTTON"] = 6] = "SELECT_BUTTON";
|
|
24
25
|
})(FieldType || (FieldType = {}));
|
|
25
26
|
export class FiltersComponent {
|
|
26
|
-
constructor() {
|
|
27
|
+
constructor(activatedRoute) {
|
|
28
|
+
this.activatedRoute = activatedRoute;
|
|
27
29
|
this.onSearch = new EventEmitter();
|
|
28
30
|
this.formBuilded = new EventEmitter();
|
|
29
31
|
this.fieldTypes = FieldType;
|
|
30
32
|
this.formGroup = new FormGroup({});
|
|
31
|
-
this.filterValue = {};
|
|
32
33
|
this._fields = [];
|
|
33
|
-
this.
|
|
34
|
+
this.fieldsSubscription = new Subscription();
|
|
34
35
|
}
|
|
35
36
|
set fields(_fields) {
|
|
36
37
|
this._fields = _fields;
|
|
37
38
|
this.formGroup = new FormGroup({});
|
|
39
|
+
this.fieldsSubscription.unsubscribe();
|
|
40
|
+
this.fieldsSubscription = new Subscription();
|
|
38
41
|
this.fields?.forEach((field) => {
|
|
39
42
|
this.formGroup.addControl(field.name, new FormControl({ value: field.defaultValue, disabled: field.readonly }, this.buildValidators(field)));
|
|
40
43
|
});
|
|
44
|
+
const queryParams = this.activatedRoute.snapshot.queryParams;
|
|
45
|
+
if (Object.keys(queryParams).length) {
|
|
46
|
+
this.formGroup.patchValue(queryParams);
|
|
47
|
+
}
|
|
41
48
|
this.fields
|
|
42
49
|
?.filter((field) => field.dependencies)
|
|
43
50
|
.forEach((field) => {
|
|
44
51
|
field.dependencies?.forEach((dependency) => {
|
|
45
|
-
this.
|
|
52
|
+
this.fieldsSubscription.add(this.formGroup.get(dependency)?.valueChanges.subscribe((value) => {
|
|
46
53
|
this.formGroup.get(field.name)?.reset();
|
|
47
54
|
}));
|
|
48
55
|
});
|
|
@@ -51,6 +58,11 @@ export class FiltersComponent {
|
|
|
51
58
|
this.search();
|
|
52
59
|
}
|
|
53
60
|
this.formBuilded.emit();
|
|
61
|
+
this.fieldsSubscription.add(this.activatedRoute.queryParams.subscribe((queryParams) => {
|
|
62
|
+
if (Object.keys(queryParams).length) {
|
|
63
|
+
this.formGroup.patchValue(queryParams);
|
|
64
|
+
}
|
|
65
|
+
}));
|
|
54
66
|
}
|
|
55
67
|
get fields() {
|
|
56
68
|
return this._fields;
|
|
@@ -60,20 +72,20 @@ export class FiltersComponent {
|
|
|
60
72
|
}
|
|
61
73
|
ngOnInit() { }
|
|
62
74
|
ngOnDestroy() {
|
|
63
|
-
this.
|
|
75
|
+
this.fieldsSubscription.unsubscribe();
|
|
64
76
|
}
|
|
65
77
|
search() {
|
|
66
|
-
|
|
67
|
-
Object.keys(
|
|
68
|
-
if (
|
|
69
|
-
|
|
78
|
+
const filterValue = this.formGroup.getRawValue();
|
|
79
|
+
Object.keys(filterValue).forEach((key) => {
|
|
80
|
+
if (filterValue[key]?.hasOwnProperty('code')) {
|
|
81
|
+
filterValue[key] = filterValue[key].code;
|
|
70
82
|
}
|
|
71
|
-
if (!ObjectUtil.isValid(
|
|
83
|
+
if (!ObjectUtil.isValid(filterValue[key])) {
|
|
72
84
|
const fieldType = this.fields.find((field) => field.name === key)?.type || FieldType.TEXT;
|
|
73
|
-
|
|
85
|
+
filterValue[key] = [FieldType.DROPDOWN, FieldType.NUMBER].includes(fieldType) ? -1 : '';
|
|
74
86
|
}
|
|
75
87
|
});
|
|
76
|
-
this.onSearch.emit(
|
|
88
|
+
this.onSearch.emit(filterValue);
|
|
77
89
|
}
|
|
78
90
|
isTextFieldType(field) {
|
|
79
91
|
return [FieldType.TEXT, FieldType.NUMBER].includes(field.type);
|
|
@@ -129,16 +141,16 @@ export class FiltersComponent {
|
|
|
129
141
|
return validators;
|
|
130
142
|
}
|
|
131
143
|
}
|
|
132
|
-
FiltersComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FiltersComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
133
|
-
FiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: FiltersComponent, selector: "vector-filters", inputs: { fields: "fields" }, outputs: { onSearch: "onSearch", formBuilded: "formBuilded" }, ngImport: i0, template: "<div class=\"grid filter-container\" [ngClass]=\"{ 'display-none': hideFilters }\" [formGroup]=\"formGroup\">\r\n <div *ngFor=\"let field of fields | notHidden\" class=\"field col-12 sm:col-8 {{ getGridClass(field) }}\">\r\n <label>{{ field.label }}</label>\r\n <vector-text-field\r\n *ngIf=\"isTextFieldType(field)\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [mask]=\"field.mask\"\r\n [label]=\"field.placeholder\"\r\n [isRequired]=\"field.required\"\r\n [numeric]=\"field.type === fieldTypes.NUMBER\"\r\n ></vector-text-field>\r\n <vector-dropdown-field\r\n *ngIf=\"field.type === fieldTypes.DROPDOWN || field.type === fieldTypes.DYNAMIC_DROPDOWN\"\r\n [dynamicFilters]=\"field.filterTypes\"\r\n [options]=\"field.options || []\"\r\n [service]=\"field.service\"\r\n [isRequired]=\"field.required\"\r\n [minLengthToService]=\"field.minLengthToService || 0\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [paged]=\"false\"\r\n [dependencies]=\"getFieldDependencies(field)\"\r\n [initialLoad]=\"!!field.defaultValue\"\r\n ></vector-dropdown-field>\r\n <vector-currency-field\r\n *ngIf=\"field.type === fieldTypes.CURRENCY\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [outlined]=\"true\"\r\n ></vector-currency-field>\r\n <vector-calendar-field\r\n *ngIf=\"field.type === fieldTypes.DATE\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [isRequired]=\"field.required\"\r\n [label]=\"field.placeholder || ''\"\r\n ></vector-calendar-field>\r\n <vector-select-button-field\r\n *ngIf=\"field.type === fieldTypes.SELECT_BUTTON\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [options]=\"field.options\"\r\n >\r\n </vector-select-button-field>\r\n </div>\r\n <div class=\"search-button sm:col-4\">\r\n <vector-button\r\n label=\"Pesquisar\"\r\n (click)=\"search()\"\r\n [disabled]=\"!formGroup.valid\"\r\n style=\"float: right; width: 150px\"\r\n ></vector-button>\r\n </div>\r\n</div>\r\n", styles: [".filter-container{align-items:center}.filter-container .field{display:flex;flex-direction:column}.filter-container .search-button{flex:1;padding-right:7px}@media (min-width: 768px){.filter-container .search-button{padding-top:36px}}.display-none{display:none!important}\n"], components: [{ type:
|
|
144
|
+
FiltersComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FiltersComponent, deps: [{ token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
|
|
145
|
+
FiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: FiltersComponent, selector: "vector-filters", inputs: { fields: "fields" }, outputs: { onSearch: "onSearch", formBuilded: "formBuilded" }, ngImport: i0, template: "<div class=\"grid filter-container\" [ngClass]=\"{ 'display-none': hideFilters }\" [formGroup]=\"formGroup\">\r\n <div *ngFor=\"let field of fields | notHidden\" class=\"field col-12 sm:col-8 {{ getGridClass(field) }}\">\r\n <label>{{ field.label }}</label>\r\n <vector-text-field\r\n *ngIf=\"isTextFieldType(field)\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [mask]=\"field.mask\"\r\n [label]=\"field.placeholder\"\r\n [isRequired]=\"field.required\"\r\n [numeric]=\"field.type === fieldTypes.NUMBER\"\r\n ></vector-text-field>\r\n <vector-dropdown-field\r\n *ngIf=\"field.type === fieldTypes.DROPDOWN || field.type === fieldTypes.DYNAMIC_DROPDOWN\"\r\n [dynamicFilters]=\"field.filterTypes\"\r\n [options]=\"field.options || []\"\r\n [service]=\"field.service\"\r\n [isRequired]=\"field.required\"\r\n [minLengthToService]=\"field.minLengthToService || 0\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [paged]=\"false\"\r\n [dependencies]=\"getFieldDependencies(field)\"\r\n [initialLoad]=\"!!field.defaultValue\"\r\n ></vector-dropdown-field>\r\n <vector-currency-field\r\n *ngIf=\"field.type === fieldTypes.CURRENCY\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [outlined]=\"true\"\r\n ></vector-currency-field>\r\n <vector-calendar-field\r\n *ngIf=\"field.type === fieldTypes.DATE\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [isRequired]=\"field.required\"\r\n [label]=\"field.placeholder || ''\"\r\n ></vector-calendar-field>\r\n <vector-select-button-field\r\n *ngIf=\"field.type === fieldTypes.SELECT_BUTTON\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [options]=\"field.options\"\r\n >\r\n </vector-select-button-field>\r\n </div>\r\n <div class=\"search-button sm:col-4\">\r\n <vector-button\r\n label=\"Pesquisar\"\r\n (click)=\"search()\"\r\n [disabled]=\"!formGroup.valid\"\r\n style=\"float: right; width: 150px\"\r\n ></vector-button>\r\n </div>\r\n</div>\r\n", styles: [".filter-container{align-items:center}.filter-container .field{display:flex;flex-direction:column}.filter-container .search-button{flex:1;padding-right:7px}@media (min-width: 768px){.filter-container .search-button{padding-top:36px}}.display-none{display:none!important}\n"], components: [{ type: i2.TextFieldComponent, selector: "vector-text-field", inputs: ["isRequired", "label", "maxlength", "isPassword", "numeric", "decimal", "onlyText", "alphaNumeric", "mask", "autoClear", "rightIcon", "centered", "enableDocumentTypeChoice", "hiddenErrorMessage", "control"], outputs: ["blurEvent", "enterKeyPress", "focusEvent", "onDocumentTypeChange"] }, { type: i3.DropdownFieldComponent, selector: "vector-dropdown-field", inputs: ["options", "isRequired", "control", "label", "service", "paged", "buttonAction", "dependencies", "hiddenErrorMessage", "dynamicFilters", "minLengthToService", "initialLoad"], outputs: ["onFocus"] }, { type: i4.CurrencyFieldComponent, selector: "vector-currency-field", inputs: ["minValue", "maxValue", "placeholder", "control", "outlined", "rounded", "label", "isBankingField", "inputClassName"] }, { type: i5.CalendarComponent, selector: "vector-calendar-field", inputs: ["isRequired", "control", "label", "showCalendarOnFocus", "min", "max", "disabledDates", "disabled", "defaultDate", "hiddenErrorMessage"] }, { type: i6.SelectButtonFieldComponent, selector: "vector-select-button-field", inputs: ["options", "control"] }, { type: i7.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }], directives: [{ type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i9.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i9.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "notHidden": i10.NotHiddenPipe } });
|
|
134
146
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FiltersComponent, decorators: [{
|
|
135
147
|
type: Component,
|
|
136
148
|
args: [{ selector: 'vector-filters', template: "<div class=\"grid filter-container\" [ngClass]=\"{ 'display-none': hideFilters }\" [formGroup]=\"formGroup\">\r\n <div *ngFor=\"let field of fields | notHidden\" class=\"field col-12 sm:col-8 {{ getGridClass(field) }}\">\r\n <label>{{ field.label }}</label>\r\n <vector-text-field\r\n *ngIf=\"isTextFieldType(field)\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [mask]=\"field.mask\"\r\n [label]=\"field.placeholder\"\r\n [isRequired]=\"field.required\"\r\n [numeric]=\"field.type === fieldTypes.NUMBER\"\r\n ></vector-text-field>\r\n <vector-dropdown-field\r\n *ngIf=\"field.type === fieldTypes.DROPDOWN || field.type === fieldTypes.DYNAMIC_DROPDOWN\"\r\n [dynamicFilters]=\"field.filterTypes\"\r\n [options]=\"field.options || []\"\r\n [service]=\"field.service\"\r\n [isRequired]=\"field.required\"\r\n [minLengthToService]=\"field.minLengthToService || 0\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [paged]=\"false\"\r\n [dependencies]=\"getFieldDependencies(field)\"\r\n [initialLoad]=\"!!field.defaultValue\"\r\n ></vector-dropdown-field>\r\n <vector-currency-field\r\n *ngIf=\"field.type === fieldTypes.CURRENCY\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [outlined]=\"true\"\r\n ></vector-currency-field>\r\n <vector-calendar-field\r\n *ngIf=\"field.type === fieldTypes.DATE\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [isRequired]=\"field.required\"\r\n [label]=\"field.placeholder || ''\"\r\n ></vector-calendar-field>\r\n <vector-select-button-field\r\n *ngIf=\"field.type === fieldTypes.SELECT_BUTTON\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [options]=\"field.options\"\r\n >\r\n </vector-select-button-field>\r\n </div>\r\n <div class=\"search-button sm:col-4\">\r\n <vector-button\r\n label=\"Pesquisar\"\r\n (click)=\"search()\"\r\n [disabled]=\"!formGroup.valid\"\r\n style=\"float: right; width: 150px\"\r\n ></vector-button>\r\n </div>\r\n</div>\r\n", styles: [".filter-container{align-items:center}.filter-container .field{display:flex;flex-direction:column}.filter-container .search-button{flex:1;padding-right:7px}@media (min-width: 768px){.filter-container .search-button{padding-top:36px}}.display-none{display:none!important}\n"] }]
|
|
137
|
-
}], ctorParameters: function () { return []; }, propDecorators: { fields: [{
|
|
149
|
+
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }]; }, propDecorators: { fields: [{
|
|
138
150
|
type: Input
|
|
139
151
|
}], onSearch: [{
|
|
140
152
|
type: Output
|
|
141
153
|
}], formBuilded: [{
|
|
142
154
|
type: Output
|
|
143
155
|
}] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/filters/filters.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/filters/filters.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { FormControl, FormGroup, ValidatorFn, Validators } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { ListItem } from '../../../models';\r\nimport { BaseDropdown } from '../../../services';\r\nimport { ObjectUtil } from '../../../utils';\r\n\r\nexport enum FieldType {\r\n  DROPDOWN,\r\n  TEXT,\r\n  DATE,\r\n  NUMBER,\r\n  CURRENCY,\r\n  DYNAMIC_DROPDOWN,\r\n  SELECT_BUTTON,\r\n}\r\n\r\nexport type FilterField = {\r\n  name: string;\r\n  type: FieldType;\r\n  minLength?: number;\r\n  maxLength?: number;\r\n  min?: number;\r\n  max?: number;\r\n  required?: boolean;\r\n  readonly?: boolean;\r\n  label?: string;\r\n  mask?: string;\r\n  options?: ListItem[];\r\n  filterTypes?: ListItem[];\r\n  service?: BaseDropdown;\r\n  defaultValue?: any;\r\n  placeholder?: string;\r\n  hidden?: boolean;\r\n  dependencies?: string[];\r\n  size?: 'small' | 'medium' | 'large' | 'largest' | 'full';\r\n  minLengthToService?: number;\r\n};\r\n\r\n@Component({\r\n  selector: 'vector-filters',\r\n  templateUrl: './filters.component.html',\r\n  styleUrls: ['./filters.component.scss'],\r\n})\r\nexport class FiltersComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  public set fields(_fields: FilterField[]) {\r\n    this._fields = _fields;\r\n    this.formGroup = new FormGroup({});\r\n\r\n    this.fields?.forEach((field) => {\r\n      this.formGroup.addControl(\r\n        field.name,\r\n        new FormControl({ value: field.defaultValue, disabled: field.readonly }, this.buildValidators(field))\r\n      );\r\n    });\r\n    this.fields\r\n      ?.filter((field) => field.dependencies)\r\n      .forEach((field) => {\r\n        field.dependencies?.forEach((dependency) => {\r\n          this.subscription.add(\r\n            this.formGroup.get(dependency)?.valueChanges.subscribe((value) => {\r\n              this.formGroup.get(field.name)?.reset();\r\n            })\r\n          );\r\n        });\r\n      });\r\n    if (this._fields?.length && this.formGroup.valid) {\r\n      this.search();\r\n    }\r\n    this.formBuilded.emit();\r\n  }\r\n  @Output()\r\n  public onSearch = new EventEmitter<any>();\r\n  @Output()\r\n  public formBuilded = new EventEmitter<void>();\r\n\r\n  public get fields() {\r\n    return this._fields;\r\n  }\r\n\r\n  public fieldTypes = FieldType;\r\n  public formGroup = new FormGroup({});\r\n  public filterValue: any = {};\r\n  private _fields: FilterField[] = [];\r\n  private subscription = new Subscription();\r\n\r\n  get hideFilters() {\r\n    return !this.fields?.filter((item) => !item.hidden).length;\r\n  }\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngOnDestroy() {\r\n    this.subscription.unsubscribe();\r\n  }\r\n\r\n  public search() {\r\n    this.filterValue = this.formGroup.getRawValue();\r\n    Object.keys(this.filterValue).forEach((key) => {\r\n      if (this.filterValue[key]?.hasOwnProperty('code')) {\r\n        this.filterValue[key] = this.filterValue[key].code;\r\n      }\r\n      if (!ObjectUtil.isValid(this.filterValue[key])) {\r\n        const fieldType = this.fields.find((field) => field.name === key)?.type || FieldType.TEXT;\r\n        this.filterValue[key] = [FieldType.DROPDOWN, FieldType.NUMBER].includes(fieldType) ? -1 : '';\r\n      }\r\n    });\r\n    this.onSearch.emit(this.filterValue);\r\n  }\r\n\r\n  public isTextFieldType(field: FilterField) {\r\n    return [FieldType.TEXT, FieldType.NUMBER].includes(field.type);\r\n  }\r\n\r\n  public getFieldDependencies(field: FilterField) {\r\n    if (!field.dependencies) {\r\n      return undefined;\r\n    }\r\n    return field.dependencies.reduce((prev, curr) => {\r\n      let depValue = this.formGroup.get(curr)?.value?.code;\r\n      if (!ObjectUtil.isValid(depValue)) {\r\n        depValue = -1;\r\n      }\r\n      return {\r\n        ...prev,\r\n        [curr]: depValue,\r\n      };\r\n    }, {});\r\n  }\r\n\r\n  public getGridClass(field: FilterField) {\r\n    switch (field.size) {\r\n      case 'small':\r\n        return 'md:col-1';\r\n      case 'medium':\r\n        return 'md:col-3';\r\n      case 'large':\r\n        return 'md:col-4';\r\n      case 'largest':\r\n        return 'md:col-8';\r\n      case 'full':\r\n        return 'md:col-12';\r\n      default:\r\n        return 'md:col-4';\r\n    }\r\n  }\r\n\r\n  private buildValidators(field: FilterField): ValidatorFn[] {\r\n    const validators = [];\r\n    if (field.required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    if (field.minLength) {\r\n      validators.push(Validators.minLength(field.minLength));\r\n    }\r\n    if (field.maxLength) {\r\n      validators.push(Validators.maxLength(field.maxLength));\r\n    }\r\n    if (field.min) {\r\n      validators.push(Validators.min(field.min));\r\n    }\r\n    if (field.max) {\r\n      validators.push(Validators.max(field.max));\r\n    }\r\n    return validators;\r\n  }\r\n}\r\n","<div class=\"grid filter-container\" [ngClass]=\"{ 'display-none': hideFilters }\" [formGroup]=\"formGroup\">\r\n  <div *ngFor=\"let field of fields | notHidden\" class=\"field col-12 sm:col-8 {{ getGridClass(field) }}\">\r\n    <label>{{ field.label }}</label>\r\n    <vector-text-field\r\n      *ngIf=\"isTextFieldType(field)\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [mask]=\"field.mask\"\r\n      [label]=\"field.placeholder\"\r\n      [isRequired]=\"field.required\"\r\n      [numeric]=\"field.type === fieldTypes.NUMBER\"\r\n    ></vector-text-field>\r\n    <vector-dropdown-field\r\n      *ngIf=\"field.type === fieldTypes.DROPDOWN || field.type === fieldTypes.DYNAMIC_DROPDOWN\"\r\n      [dynamicFilters]=\"field.filterTypes\"\r\n      [options]=\"field.options || []\"\r\n      [service]=\"field.service\"\r\n      [isRequired]=\"field.required\"\r\n      [minLengthToService]=\"field.minLengthToService || 0\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [paged]=\"false\"\r\n      [dependencies]=\"getFieldDependencies(field)\"\r\n      [initialLoad]=\"!!field.defaultValue\"\r\n    ></vector-dropdown-field>\r\n    <vector-currency-field\r\n      *ngIf=\"field.type === fieldTypes.CURRENCY\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [outlined]=\"true\"\r\n    ></vector-currency-field>\r\n    <vector-calendar-field\r\n      *ngIf=\"field.type === fieldTypes.DATE\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [isRequired]=\"field.required\"\r\n      [label]=\"field.placeholder || ''\"\r\n    ></vector-calendar-field>\r\n    <vector-select-button-field\r\n      *ngIf=\"field.type === fieldTypes.SELECT_BUTTON\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [options]=\"field.options\"\r\n    >\r\n    </vector-select-button-field>\r\n  </div>\r\n  <div class=\"search-button sm:col-4\">\r\n    <vector-button\r\n      label=\"Pesquisar\"\r\n      (click)=\"search()\"\r\n      [disabled]=\"!formGroup.valid\"\r\n      style=\"float: right; width: 150px\"\r\n    ></vector-button>\r\n  </div>\r\n</div>\r\n"]}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/filters/filters.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/filters/filters.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { FormControl, FormGroup, ValidatorFn, Validators } from '@angular/forms';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { Subscription } from 'rxjs';\r\nimport { ListItem } from '../../../models';\r\nimport { BaseDropdown } from '../../../services';\r\nimport { ObjectUtil } from '../../../utils';\r\n\r\nexport enum FieldType {\r\n  DROPDOWN,\r\n  TEXT,\r\n  DATE,\r\n  NUMBER,\r\n  CURRENCY,\r\n  DYNAMIC_DROPDOWN,\r\n  SELECT_BUTTON,\r\n}\r\n\r\nexport type FilterField = {\r\n  name: string;\r\n  type: FieldType;\r\n  minLength?: number;\r\n  maxLength?: number;\r\n  min?: number;\r\n  max?: number;\r\n  required?: boolean;\r\n  readonly?: boolean;\r\n  label?: string;\r\n  mask?: string;\r\n  options?: ListItem[];\r\n  filterTypes?: ListItem[];\r\n  service?: BaseDropdown;\r\n  defaultValue?: any;\r\n  placeholder?: string;\r\n  hidden?: boolean;\r\n  dependencies?: string[];\r\n  size?: 'small' | 'medium' | 'large' | 'largest' | 'full';\r\n  minLengthToService?: number;\r\n};\r\n\r\n@Component({\r\n  selector: 'vector-filters',\r\n  templateUrl: './filters.component.html',\r\n  styleUrls: ['./filters.component.scss'],\r\n})\r\nexport class FiltersComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  public set fields(_fields: FilterField[]) {\r\n    this._fields = _fields;\r\n    this.formGroup = new FormGroup({});\r\n\r\n    this.fieldsSubscription.unsubscribe();\r\n    this.fieldsSubscription = new Subscription();\r\n\r\n    this.fields?.forEach((field) => {\r\n      this.formGroup.addControl(\r\n        field.name,\r\n        new FormControl({ value: field.defaultValue, disabled: field.readonly }, this.buildValidators(field))\r\n      );\r\n    });\r\n\r\n    const queryParams = this.activatedRoute.snapshot.queryParams;\r\n    if (Object.keys(queryParams).length) {\r\n      this.formGroup.patchValue(queryParams);\r\n    }\r\n\r\n    this.fields\r\n      ?.filter((field) => field.dependencies)\r\n      .forEach((field) => {\r\n        field.dependencies?.forEach((dependency) => {\r\n          this.fieldsSubscription.add(\r\n            this.formGroup.get(dependency)?.valueChanges.subscribe((value) => {\r\n              this.formGroup.get(field.name)?.reset();\r\n            })\r\n          );\r\n        });\r\n      });\r\n    if (this._fields?.length && this.formGroup.valid) {\r\n      this.search();\r\n    }\r\n    this.formBuilded.emit();\r\n\r\n    this.fieldsSubscription.add(\r\n      this.activatedRoute.queryParams.subscribe((queryParams) => {\r\n        if (Object.keys(queryParams).length) {\r\n          this.formGroup.patchValue(queryParams);\r\n        }\r\n      })\r\n    );\r\n  }\r\n  @Output()\r\n  public onSearch = new EventEmitter<any>();\r\n  @Output()\r\n  public formBuilded = new EventEmitter<void>();\r\n\r\n  public get fields() {\r\n    return this._fields;\r\n  }\r\n\r\n  public fieldTypes = FieldType;\r\n  public formGroup = new FormGroup({});\r\n  private _fields: FilterField[] = [];\r\n  private fieldsSubscription = new Subscription();\r\n\r\n  get hideFilters() {\r\n    return !this.fields?.filter((item) => !item.hidden).length;\r\n  }\r\n\r\n  constructor(private activatedRoute: ActivatedRoute) {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngOnDestroy() {\r\n    this.fieldsSubscription.unsubscribe();\r\n  }\r\n\r\n  public search() {\r\n    const filterValue = this.formGroup.getRawValue();\r\n    Object.keys(filterValue).forEach((key) => {\r\n      if (filterValue[key]?.hasOwnProperty('code')) {\r\n        filterValue[key] = filterValue[key].code;\r\n      }\r\n      if (!ObjectUtil.isValid(filterValue[key])) {\r\n        const fieldType = this.fields.find((field) => field.name === key)?.type || FieldType.TEXT;\r\n        filterValue[key] = [FieldType.DROPDOWN, FieldType.NUMBER].includes(fieldType) ? -1 : '';\r\n      }\r\n    });\r\n    this.onSearch.emit(filterValue);\r\n  }\r\n\r\n  public isTextFieldType(field: FilterField) {\r\n    return [FieldType.TEXT, FieldType.NUMBER].includes(field.type);\r\n  }\r\n\r\n  public getFieldDependencies(field: FilterField) {\r\n    if (!field.dependencies) {\r\n      return undefined;\r\n    }\r\n    return field.dependencies.reduce((prev, curr) => {\r\n      let depValue = this.formGroup.get(curr)?.value?.code;\r\n      if (!ObjectUtil.isValid(depValue)) {\r\n        depValue = -1;\r\n      }\r\n      return {\r\n        ...prev,\r\n        [curr]: depValue,\r\n      };\r\n    }, {});\r\n  }\r\n\r\n  public getGridClass(field: FilterField) {\r\n    switch (field.size) {\r\n      case 'small':\r\n        return 'md:col-1';\r\n      case 'medium':\r\n        return 'md:col-3';\r\n      case 'large':\r\n        return 'md:col-4';\r\n      case 'largest':\r\n        return 'md:col-8';\r\n      case 'full':\r\n        return 'md:col-12';\r\n      default:\r\n        return 'md:col-4';\r\n    }\r\n  }\r\n\r\n  private buildValidators(field: FilterField): ValidatorFn[] {\r\n    const validators = [];\r\n    if (field.required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    if (field.minLength) {\r\n      validators.push(Validators.minLength(field.minLength));\r\n    }\r\n    if (field.maxLength) {\r\n      validators.push(Validators.maxLength(field.maxLength));\r\n    }\r\n    if (field.min) {\r\n      validators.push(Validators.min(field.min));\r\n    }\r\n    if (field.max) {\r\n      validators.push(Validators.max(field.max));\r\n    }\r\n    return validators;\r\n  }\r\n}\r\n","<div class=\"grid filter-container\" [ngClass]=\"{ 'display-none': hideFilters }\" [formGroup]=\"formGroup\">\r\n  <div *ngFor=\"let field of fields | notHidden\" class=\"field col-12 sm:col-8 {{ getGridClass(field) }}\">\r\n    <label>{{ field.label }}</label>\r\n    <vector-text-field\r\n      *ngIf=\"isTextFieldType(field)\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [mask]=\"field.mask\"\r\n      [label]=\"field.placeholder\"\r\n      [isRequired]=\"field.required\"\r\n      [numeric]=\"field.type === fieldTypes.NUMBER\"\r\n    ></vector-text-field>\r\n    <vector-dropdown-field\r\n      *ngIf=\"field.type === fieldTypes.DROPDOWN || field.type === fieldTypes.DYNAMIC_DROPDOWN\"\r\n      [dynamicFilters]=\"field.filterTypes\"\r\n      [options]=\"field.options || []\"\r\n      [service]=\"field.service\"\r\n      [isRequired]=\"field.required\"\r\n      [minLengthToService]=\"field.minLengthToService || 0\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [paged]=\"false\"\r\n      [dependencies]=\"getFieldDependencies(field)\"\r\n      [initialLoad]=\"!!field.defaultValue\"\r\n    ></vector-dropdown-field>\r\n    <vector-currency-field\r\n      *ngIf=\"field.type === fieldTypes.CURRENCY\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [outlined]=\"true\"\r\n    ></vector-currency-field>\r\n    <vector-calendar-field\r\n      *ngIf=\"field.type === fieldTypes.DATE\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [isRequired]=\"field.required\"\r\n      [label]=\"field.placeholder || ''\"\r\n    ></vector-calendar-field>\r\n    <vector-select-button-field\r\n      *ngIf=\"field.type === fieldTypes.SELECT_BUTTON\"\r\n      [control]=\"formGroup.get(field.name)\"\r\n      [options]=\"field.options\"\r\n    >\r\n    </vector-select-button-field>\r\n  </div>\r\n  <div class=\"search-button sm:col-4\">\r\n    <vector-button\r\n      label=\"Pesquisar\"\r\n      (click)=\"search()\"\r\n      [disabled]=\"!formGroup.valid\"\r\n      style=\"float: right; width: 150px\"\r\n    ></vector-button>\r\n  </div>\r\n</div>\r\n"]}
|