info-library 2.10.87 → 2.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/controls/alert/alert.component.d.ts +3 -0
- package/controls/autocomplete/autocomplete.component.d.ts +5 -2
- package/controls/big-checkbox/big-checkbox.component.d.ts +3 -0
- package/controls/card/card.component.d.ts +3 -0
- package/controls/card-menu/card-menu.component.d.ts +3 -0
- package/controls/checkbox/checkbox.component.d.ts +3 -0
- package/controls/chips/chips.component.d.ts +3 -0
- package/controls/date/date.component.d.ts +3 -0
- package/controls/date-month/date-month.component.d.ts +3 -0
- package/controls/editor/editor.component.d.ts +3 -0
- package/controls/grid/grid.component.d.ts +5 -0
- package/controls/input/input.component.d.ts +3 -0
- package/controls/input-list/input-list.component.d.ts +3 -0
- package/controls/list-checkbox/list-checkbox.component.d.ts +3 -0
- package/controls/message/message.component.d.ts +3 -0
- package/controls/multi-select/multi-select.component.d.ts +3 -0
- package/controls/paginator/paginator.component.d.ts +3 -0
- package/controls/select/select.component.d.ts +3 -0
- package/controls/timeline/timeline.component.d.ts +3 -0
- package/directives/mask.directive.d.ts +3 -0
- package/directives/unmask.directive.d.ts +3 -0
- package/esm2020/controls/alert/alert.component.mjs +74 -0
- package/esm2020/controls/autocomplete/autocomplete.component.mjs +258 -0
- package/esm2020/controls/big-checkbox/big-checkbox.component.mjs +298 -0
- package/esm2020/controls/card/card.component.mjs +77 -0
- package/esm2020/controls/card-menu/card-menu.component.mjs +145 -0
- package/esm2020/controls/checkbox/checkbox.component.mjs +93 -0
- package/esm2020/controls/chips/chips.component.mjs +113 -0
- package/esm2020/controls/date/date.component.mjs +141 -0
- package/esm2020/controls/date-month/date-month.component.mjs +148 -0
- package/esm2020/controls/editor/editor.component.mjs +135 -0
- package/esm2020/controls/grid/grid.component.mjs +1800 -0
- package/esm2020/controls/input/input.component.mjs +314 -0
- package/esm2020/controls/input-list/input-list.component.mjs +258 -0
- package/esm2020/controls/list-checkbox/list-checkbox.component.mjs +238 -0
- package/esm2020/controls/message/message.component.mjs +50 -0
- package/esm2020/controls/multi-select/multi-select.component.mjs +161 -0
- package/esm2020/controls/paginator/paginator.component.mjs +178 -0
- package/esm2020/controls/select/select.component.mjs +180 -0
- package/esm2020/controls/timeline/timeline.component.mjs +117 -0
- package/esm2020/directives/mask.directive.mjs +125 -0
- package/esm2020/directives/unmask.directive.mjs +28 -0
- package/esm2020/enum/dialog-buttons.enum.mjs +9 -0
- package/esm2020/enum/index.mjs +4 -0
- package/esm2020/enum/modal-action.enum.mjs +12 -0
- package/esm2020/enum/page-action.enum.mjs +10 -0
- package/esm2020/global-config.mjs +4 -0
- package/esm2020/info-library.mjs +5 -0
- package/esm2020/info-library.module.mjs +278 -0
- package/esm2020/layouts/dialog/dialog.component.mjs +188 -0
- package/esm2020/layouts/loading/loading.component.mjs +42 -0
- package/esm2020/layouts/main/main.component.mjs +276 -0
- package/esm2020/layouts/modal/modal.component.mjs +258 -0
- package/esm2020/layouts/pagebar/pagebar.component.mjs +404 -0
- package/esm2020/layouts/sidebar/sidebar.component.mjs +395 -0
- package/esm2020/layouts/topbar/topbar.component.mjs +863 -0
- package/esm2020/layouts/topmenu/topmenu.component.mjs +165 -0
- package/esm2020/model/app-config.model.mjs +14 -0
- package/esm2020/model/data-access.model.mjs +35 -0
- package/esm2020/model/dialog-result.model.mjs +8 -0
- package/esm2020/model/dialog.model.mjs +16 -0
- package/esm2020/model/form-prop.model.mjs +35 -0
- package/esm2020/model/grid-button.model.mjs +21 -0
- package/esm2020/model/index.mjs +15 -0
- package/esm2020/model/last-search.model.mjs +9 -0
- package/esm2020/model/login.model.mjs +9 -0
- package/esm2020/model/method-grid-button.model.mjs +9 -0
- package/esm2020/model/notification.model.mjs +9 -0
- package/esm2020/model/pagebar-buttons.model.mjs +15 -0
- package/esm2020/model/permission.model.mjs +3 -0
- package/esm2020/model/platform.model.mjs +21 -0
- package/esm2020/model/session.model.mjs +8 -0
- package/esm2020/pipe/index.mjs +3 -0
- package/esm2020/pipe/mask.pipe.mjs +34 -0
- package/esm2020/pipe/translate.pipe.mjs +26 -0
- package/esm2020/public_api.mjs +36 -0
- package/esm2020/service/authentication.service.mjs +358 -0
- package/esm2020/service/configuration.service.mjs +59 -0
- package/esm2020/service/data.service.mjs +112 -0
- package/esm2020/service/index.mjs +6 -0
- package/esm2020/service/theme.service.mjs +79 -0
- package/esm2020/service/translate.service.mjs +53 -0
- package/esm2020/utils/utilities.mjs +142 -0
- package/fesm2015/info-library.mjs +9326 -0
- package/fesm2015/info-library.mjs.map +1 -0
- package/fesm2020/info-library.mjs +8474 -0
- package/fesm2020/info-library.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/info-library.module.d.ts +58 -0
- package/layouts/dialog/dialog.component.d.ts +5 -0
- package/layouts/loading/loading.component.d.ts +3 -0
- package/layouts/main/main.component.d.ts +6 -0
- package/layouts/modal/modal.component.d.ts +3 -0
- package/layouts/pagebar/pagebar.component.d.ts +5 -0
- package/layouts/sidebar/sidebar.component.d.ts +4 -1
- package/layouts/topbar/topbar.component.d.ts +4 -1
- package/layouts/topmenu/topmenu.component.d.ts +3 -0
- package/package.json +28 -13
- package/pipe/mask.pipe.d.ts +3 -0
- package/pipe/translate.pipe.d.ts +3 -0
- package/service/authentication.service.d.ts +5 -0
- package/service/configuration.service.d.ts +3 -0
- package/service/data.service.d.ts +3 -0
- package/service/theme.service.d.ts +3 -0
- package/service/translate.service.d.ts +3 -0
- package/utils/utilities.d.ts +3 -0
- package/bundles/info-library.umd.js +0 -9740
- package/bundles/info-library.umd.js.map +0 -1
- package/bundles/info-library.umd.min.js +0 -2
- package/bundles/info-library.umd.min.js.map +0 -1
- package/esm2015/controls/alert/alert.component.js +0 -43
- package/esm2015/controls/autocomplete/autocomplete.component.js +0 -386
- package/esm2015/controls/big-checkbox/big-checkbox.component.js +0 -282
- package/esm2015/controls/card/card.component.js +0 -64
- package/esm2015/controls/card-menu/card-menu.component.js +0 -90
- package/esm2015/controls/checkbox/checkbox.component.js +0 -130
- package/esm2015/controls/chips/chips.component.js +0 -124
- package/esm2015/controls/date/date.component.js +0 -167
- package/esm2015/controls/date-month/date-month.component.js +0 -181
- package/esm2015/controls/editor/editor.component.js +0 -237
- package/esm2015/controls/grid/grid.component.js +0 -1391
- package/esm2015/controls/input/input.component.js +0 -196
- package/esm2015/controls/input-list/input-list.component.js +0 -160
- package/esm2015/controls/list-checkbox/list-checkbox.component.js +0 -151
- package/esm2015/controls/message/message.component.js +0 -47
- package/esm2015/controls/multi-select/multi-select.component.js +0 -213
- package/esm2015/controls/paginator/paginator.component.js +0 -151
- package/esm2015/controls/select/select.component.js +0 -231
- package/esm2015/controls/timeline/timeline.component.js +0 -73
- package/esm2015/directives/mask.directive.js +0 -202
- package/esm2015/directives/unmask.directive.js +0 -51
- package/esm2015/enum/dialog-buttons.enum.js +0 -20
- package/esm2015/enum/index.js +0 -9
- package/esm2015/enum/modal-action.enum.js +0 -26
- package/esm2015/enum/page-action.enum.js +0 -22
- package/esm2015/global-config.js +0 -11
- package/esm2015/info-library.js +0 -27
- package/esm2015/info-library.module.js +0 -174
- package/esm2015/layouts/dialog/dialog.component.js +0 -173
- package/esm2015/layouts/loading/loading.component.js +0 -42
- package/esm2015/layouts/main/main.component.js +0 -312
- package/esm2015/layouts/modal/modal.component.js +0 -232
- package/esm2015/layouts/pagebar/pagebar.component.js +0 -286
- package/esm2015/layouts/sidebar/sidebar.component.js +0 -231
- package/esm2015/layouts/topbar/topbar.component.js +0 -413
- package/esm2015/layouts/topmenu/topmenu.component.js +0 -181
- package/esm2015/model/app-config.model.js +0 -39
- package/esm2015/model/data-access.model.js +0 -65
- package/esm2015/model/dialog-result.model.js +0 -23
- package/esm2015/model/dialog.model.js +0 -47
- package/esm2015/model/form-prop.model.js +0 -61
- package/esm2015/model/grid-button.model.js +0 -62
- package/esm2015/model/index.js +0 -20
- package/esm2015/model/last-search.model.js +0 -24
- package/esm2015/model/login.model.js +0 -27
- package/esm2015/model/method-grid-button.model.js +0 -27
- package/esm2015/model/notification.model.js +0 -34
- package/esm2015/model/pagebar-buttons.model.js +0 -39
- package/esm2015/model/permission.model.js +0 -16
- package/esm2015/model/platform.model.js +0 -56
- package/esm2015/model/session.model.js +0 -53
- package/esm2015/pipe/index.js +0 -8
- package/esm2015/pipe/mask.pipe.js +0 -47
- package/esm2015/pipe/translate.pipe.js +0 -45
- package/esm2015/public_api.js +0 -41
- package/esm2015/service/authentication.service.js +0 -732
- package/esm2015/service/configuration.service.js +0 -107
- package/esm2015/service/data.service.js +0 -292
- package/esm2015/service/index.js +0 -11
- package/esm2015/service/theme.service.js +0 -133
- package/esm2015/service/translate.service.js +0 -105
- package/esm2015/utils/utilities.js +0 -256
- package/fesm2015/info-library.js +0 -8792
- package/fesm2015/info-library.js.map +0 -1
- package/info-library.d.ts +0 -21
- package/info-library.metadata.json +0 -1
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { Component, Input, forwardRef, Output, EventEmitter } from "@angular/core";
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
3
|
+
import { InfoDataService } from "../../service/data.service";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../service/data.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "@angular/material/form-field";
|
|
9
|
+
import * as i5 from "@angular/material/select";
|
|
10
|
+
import * as i6 from "@angular/material/core";
|
|
11
|
+
import * as i7 from "@angular/material/progress-bar";
|
|
12
|
+
import * as i8 from "../../pipe/translate.pipe";
|
|
13
|
+
function InfoMultiSelectComponent_mat_option_5_Template(rf, ctx) { if (rf & 1) {
|
|
14
|
+
i0.ɵɵelementStart(0, "mat-option", 4);
|
|
15
|
+
i0.ɵɵelement(1, "span", 5);
|
|
16
|
+
i0.ɵɵpipe(2, "translate");
|
|
17
|
+
i0.ɵɵelementEnd();
|
|
18
|
+
} if (rf & 2) {
|
|
19
|
+
const i_r2 = ctx.$implicit;
|
|
20
|
+
i0.ɵɵproperty("value", i_r2.Id);
|
|
21
|
+
i0.ɵɵadvance(1);
|
|
22
|
+
i0.ɵɵproperty("innerHtml", i0.ɵɵpipeBind1(2, 2, i_r2.Nome), i0.ɵɵsanitizeHtml);
|
|
23
|
+
} }
|
|
24
|
+
function InfoMultiSelectComponent_mat_progress_bar_7_Template(rf, ctx) { if (rf & 1) {
|
|
25
|
+
i0.ɵɵelement(0, "mat-progress-bar", 6);
|
|
26
|
+
} }
|
|
27
|
+
export class InfoMultiSelectComponent {
|
|
28
|
+
constructor(_dataAcessService) {
|
|
29
|
+
this._dataAcessService = _dataAcessService;
|
|
30
|
+
this.placeholder = '';
|
|
31
|
+
this.name = '';
|
|
32
|
+
this.required = false;
|
|
33
|
+
this.selectfirst = false;
|
|
34
|
+
this.disablednoregisters = false;
|
|
35
|
+
this.api = null;
|
|
36
|
+
this.method = 'getchavevalor';
|
|
37
|
+
this.loading = false;
|
|
38
|
+
this.disabled = false;
|
|
39
|
+
this.onselecteditem = new EventEmitter();
|
|
40
|
+
this.selectedValues = [];
|
|
41
|
+
this.initialized = false;
|
|
42
|
+
this._params = null;
|
|
43
|
+
this._data = [];
|
|
44
|
+
}
|
|
45
|
+
get params() {
|
|
46
|
+
return this._params;
|
|
47
|
+
}
|
|
48
|
+
set params(value) {
|
|
49
|
+
this._params = value;
|
|
50
|
+
if (this.initialized)
|
|
51
|
+
this.getData();
|
|
52
|
+
}
|
|
53
|
+
get data() {
|
|
54
|
+
return this._data;
|
|
55
|
+
}
|
|
56
|
+
set data(value) {
|
|
57
|
+
this._data = value;
|
|
58
|
+
if (this.selectfirst && this.data != null && this.data.length > 0 && !this.data.some(d => this.selectedValues?.indexOf(d.Id) > -1))
|
|
59
|
+
this.writeValue([this.data[0].Id]);
|
|
60
|
+
if (this.disablednoregisters)
|
|
61
|
+
this.setDisabledState((this.data == null || this.data.length == 0));
|
|
62
|
+
}
|
|
63
|
+
ngOnInit() {
|
|
64
|
+
this.name += this.placeholder.replace(/ /g, '');
|
|
65
|
+
this.getData();
|
|
66
|
+
}
|
|
67
|
+
writeValue(value) {
|
|
68
|
+
this.selectedValues = value;
|
|
69
|
+
this.onChangeValue();
|
|
70
|
+
}
|
|
71
|
+
getData() {
|
|
72
|
+
this.initialized = true;
|
|
73
|
+
if (this.api == null || (this.params != null && this.params.toLowerCase().indexOf('undefined') > -1))
|
|
74
|
+
return;
|
|
75
|
+
this.loading = true;
|
|
76
|
+
this.data = [];
|
|
77
|
+
this._dataAcessService.get(this.api, this.method, this.params).subscribe(r => {
|
|
78
|
+
if (r.success) {
|
|
79
|
+
this.data = r.data;
|
|
80
|
+
if ((this.selectedValues || []).length > 0)
|
|
81
|
+
this.onChangeValue();
|
|
82
|
+
}
|
|
83
|
+
this.loading = false;
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
onChangeValue() {
|
|
87
|
+
if (this.onChange != null)
|
|
88
|
+
this.onChange(this.selectedValues);
|
|
89
|
+
if (this.onselecteditem != null)
|
|
90
|
+
this.onselecteditem.emit(this.data == null ? null : this.data.filter(r => this.selectedValues?.indexOf(r.Id) > -1));
|
|
91
|
+
}
|
|
92
|
+
registerOnChange(fn) {
|
|
93
|
+
this.onChange = fn;
|
|
94
|
+
}
|
|
95
|
+
registerOnTouched(fn) {
|
|
96
|
+
this.onTouched = fn;
|
|
97
|
+
}
|
|
98
|
+
setDisabledState(isDisabled) {
|
|
99
|
+
this.disabled = this.disablednoregisters && (this.data == null || this.data.length == 0) ? true : isDisabled;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
/** @nocollapse */ InfoMultiSelectComponent.ɵfac = function InfoMultiSelectComponent_Factory(t) { return new (t || InfoMultiSelectComponent)(i0.ɵɵdirectiveInject(i1.InfoDataService)); };
|
|
103
|
+
/** @nocollapse */ InfoMultiSelectComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoMultiSelectComponent, selectors: [["info-multi-select"]], inputs: { placeholder: "placeholder", name: "name", required: "required", selectfirst: "selectfirst", disablednoregisters: "disablednoregisters", api: "api", method: "method", loading: "loading", disabled: "disabled", params: "params", data: "data" }, outputs: { onselecteditem: "onselecteditem" }, features: [i0.ɵɵProvidersFeature([{
|
|
104
|
+
provide: NG_VALUE_ACCESSOR,
|
|
105
|
+
useExisting: forwardRef((() => InfoMultiSelectComponent)),
|
|
106
|
+
multi: true
|
|
107
|
+
}])], decls: 8, vars: 8, consts: [["multiple", "", 3, "ngModel", "disabled", "required", "ngModelChange", "selectionChange"], [3, "value", 4, "ngFor", "ngForOf"], [1, "select-loading"], ["color", "primary", "mode", "indeterminate", 4, "ngIf"], [3, "value"], [3, "innerHtml"], ["color", "primary", "mode", "indeterminate"]], template: function InfoMultiSelectComponent_Template(rf, ctx) { if (rf & 1) {
|
|
108
|
+
i0.ɵɵelementStart(0, "mat-form-field")(1, "mat-label");
|
|
109
|
+
i0.ɵɵtext(2);
|
|
110
|
+
i0.ɵɵpipe(3, "translate");
|
|
111
|
+
i0.ɵɵelementEnd();
|
|
112
|
+
i0.ɵɵelementStart(4, "mat-select", 0);
|
|
113
|
+
i0.ɵɵlistener("ngModelChange", function InfoMultiSelectComponent_Template_mat_select_ngModelChange_4_listener($event) { return ctx.selectedValues = $event; })("selectionChange", function InfoMultiSelectComponent_Template_mat_select_selectionChange_4_listener() { return ctx.onChangeValue(); });
|
|
114
|
+
i0.ɵɵtemplate(5, InfoMultiSelectComponent_mat_option_5_Template, 3, 4, "mat-option", 1);
|
|
115
|
+
i0.ɵɵelementEnd()();
|
|
116
|
+
i0.ɵɵelementStart(6, "section", 2);
|
|
117
|
+
i0.ɵɵtemplate(7, InfoMultiSelectComponent_mat_progress_bar_7_Template, 1, 0, "mat-progress-bar", 3);
|
|
118
|
+
i0.ɵɵelementEnd();
|
|
119
|
+
} if (rf & 2) {
|
|
120
|
+
i0.ɵɵadvance(2);
|
|
121
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 6, ctx.placeholder));
|
|
122
|
+
i0.ɵɵadvance(2);
|
|
123
|
+
i0.ɵɵproperty("ngModel", ctx.selectedValues)("disabled", ctx.disabled || ctx.loading)("required", ctx.required);
|
|
124
|
+
i0.ɵɵadvance(1);
|
|
125
|
+
i0.ɵɵproperty("ngForOf", ctx.data);
|
|
126
|
+
i0.ɵɵadvance(2);
|
|
127
|
+
i0.ɵɵproperty("ngIf", ctx.loading);
|
|
128
|
+
} }, dependencies: [i2.NgForOf, i2.NgIf, i3.NgControlStatus, i3.RequiredValidator, i3.NgModel, i4.MatFormField, i4.MatLabel, i5.MatSelect, i6.MatOption, i7.MatProgressBar, i8.InfoTranslatePipe], styles: ["[_nghost-%COMP%] .mat-select-trigger[_ngcontent-%COMP%]{height:19px}[_nghost-%COMP%] .mat-form-field-type-mat-select[_ngcontent-%COMP%] .mat-form-field-label[_ngcontent-%COMP%]{height:20px}[_nghost-%COMP%] .select-loading[_ngcontent-%COMP%]{position:relative;bottom:15px;opacity:.3;height:1px}[_nghost-%COMP%] .select-loading[_ngcontent-%COMP%] .mat-progress-bar[_ngcontent-%COMP%]{height:1px;margin:0}.min[_nghost-%COMP%] .mat-form-field[_ngcontent-%COMP%]{margin:0!important}"] });
|
|
129
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InfoMultiSelectComponent, [{
|
|
130
|
+
type: Component,
|
|
131
|
+
args: [{ selector: 'info-multi-select', providers: [{
|
|
132
|
+
provide: NG_VALUE_ACCESSOR,
|
|
133
|
+
useExisting: forwardRef((() => InfoMultiSelectComponent)),
|
|
134
|
+
multi: true
|
|
135
|
+
}], template: "<mat-form-field>\r\n <mat-label>{{placeholder | translate}}</mat-label>\r\n\r\n <mat-select [(ngModel)]=\"selectedValues\" (selectionChange)=\"onChangeValue()\" [disabled]=\"disabled || loading\" [required]=\"required\" multiple>\r\n <mat-option *ngFor=\"let i of data\" [value]=\"i.Id\">\r\n <span [innerHtml]=\"i.Nome | translate\"></span>\r\n </mat-option>\r\n </mat-select>\r\n</mat-form-field>\r\n\r\n<section class=\"select-loading\">\r\n <mat-progress-bar color=\"primary\" mode=\"indeterminate\" *ngIf=\"loading\" >\r\n </mat-progress-bar>\r\n</section>", styles: [":host .mat-select-trigger{height:19px}:host .mat-form-field-type-mat-select .mat-form-field-label{height:20px}:host .select-loading{position:relative;bottom:15px;opacity:.3;height:1px}:host .select-loading .mat-progress-bar{height:1px;margin:0}:host.min .mat-form-field{margin:0!important}\n"] }]
|
|
136
|
+
}], function () { return [{ type: i1.InfoDataService }]; }, { placeholder: [{
|
|
137
|
+
type: Input
|
|
138
|
+
}], name: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], required: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], selectfirst: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], disablednoregisters: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], api: [{
|
|
147
|
+
type: Input
|
|
148
|
+
}], method: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}], loading: [{
|
|
151
|
+
type: Input
|
|
152
|
+
}], disabled: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], onselecteditem: [{
|
|
155
|
+
type: Output
|
|
156
|
+
}], params: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], data: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}] }); })();
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/multi-select/multi-select.component.ts","../../../../../projects/info-library/src/controls/multi-select/multi-select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;;;;ICErD,qCAAkD;IAC9C,0BAA8C;;IAClD,iBAAa;;;IAFsB,+BAAc;IACvC,eAAgC;IAAhC,8EAAgC;;;IAM9C,sCACmB;;ADEvB,MAAM,OAAO,wBAAwB;IAiDjC,YAAoB,iBAAkC;QAAlC,sBAAiB,GAAjB,iBAAiB,CAAiB;QA/C7C,gBAAW,GAAG,EAAE,CAAC;QACjB,SAAI,GAAG,EAAE,CAAC;QACV,aAAQ,GAAQ,KAAK,CAAC;QACtB,gBAAW,GAAG,KAAK,CAAC;QACpB,wBAAmB,GAAG,KAAK,CAAC;QAC5B,QAAG,GAAQ,IAAI,CAAC;QAChB,WAAM,GAAG,eAAe,CAAC;QACzB,YAAO,GAAG,KAAK,CAAC;QAChB,aAAQ,GAAG,KAAK,CAAC;QAEhB,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAE9C,mBAAc,GAAU,EAAE,CAAC;QAInB,gBAAW,GAAG,KAAK,CAAC;QAE5B,YAAO,GAAW,IAAI,CAAC;QAavB,UAAK,GAAQ,EAAE,CAAC;IAgB2C,CAAC;IA5B5D,IACI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,IAAI,MAAM,CAAC,KAAK;QACZ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QAErB,IAAI,IAAI,CAAC,WAAW;YAChB,IAAI,CAAC,OAAO,EAAE,CAAC;IACvB,CAAC;IAGD,IACI,IAAI;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAED,IAAI,IAAI,CAAC,KAAK;QACV,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;YAC9H,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAEvC,IAAI,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC;IAC5E,CAAC;IAID,QAAQ;QACJ,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAED,UAAU,CAAC,KAAU;QACjB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAED,OAAO;QACH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAExB,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC;YAChG,OAAO;QAEX,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;QAEf,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACzE,IAAI,CAAC,CAAC,OAAO,EAAE;gBACX,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC;gBACnB,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC;oBAAE,IAAI,CAAC,aAAa,EAAE,CAAC;aACpE;YAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACzB,CAAC,CAAC,CAAC;IACP,CAAC;IAED,aAAa;QACT,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI;YACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAEvC,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI;YAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5H,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,mBAAmB,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC;IACjH,CAAC;;mHAlGQ,wBAAwB;0GAAxB,wBAAwB,kXANtB,CAAC;gBACR,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,EAAC,GAAG,EAAE,CAAC,wBAAwB,EAAC;gBACvD,KAAK,EAAE,IAAI;aACd,CAAC;QCZN,sCAAgB,gBAAA;QACD,YAA2B;;QAAA,iBAAY;QAElD,qCAA6I;QAAjI,8JAA4B,gHAAoB,mBAAe,IAAnC;QACpC,uFAEa;QAClB,iBAAa,EAAA;QAGhB,kCAAgC;QAC5B,mGACmB;QACvB,iBAAU;;QAZK,eAA2B;QAA3B,2DAA2B;QAE1B,eAA4B;QAA5B,4CAA4B,yCAAA,0BAAA;QACV,eAAO;QAAP,kCAAO;QAOmB,eAAa;QAAb,kCAAa;;uFDG5D,wBAAwB;cAVpC,SAAS;2BACI,mBAAmB,aAGlB,CAAC;wBACR,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,EAAC,GAAG,EAAE,yBAAyB,EAAC;wBACvD,KAAK,EAAE,IAAI;qBACd,CAAC;kEAIO,WAAW;kBAAnB,KAAK;YACG,IAAI;kBAAZ,KAAK;YACG,QAAQ;kBAAhB,KAAK;YACG,WAAW;kBAAnB,KAAK;YACG,mBAAmB;kBAA3B,KAAK;YACG,GAAG;kBAAX,KAAK;YACG,MAAM;kBAAd,KAAK;YACG,OAAO;kBAAf,KAAK;YACG,QAAQ;kBAAhB,KAAK;YAEI,cAAc;kBAAvB,MAAM;YAUH,MAAM;kBADT,KAAK;YAcF,IAAI;kBADP,KAAK","sourcesContent":["import { Component, Input, OnInit, forwardRef, Output, EventEmitter } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { InfoDataService } from \"../../service/data.service\";\r\n\r\n@Component({\r\n    selector: 'info-multi-select',\r\n    templateUrl: 'multi-select.component.html',\r\n    styleUrls: ['multi-select.component.scss'],\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => InfoMultiSelectComponent),\r\n        multi: true\r\n    }]\r\n})\r\nexport class InfoMultiSelectComponent implements OnInit, ControlValueAccessor {\r\n\r\n    @Input() placeholder = '';\r\n    @Input() name = '';\r\n    @Input() required: any = false;\r\n    @Input() selectfirst = false;\r\n    @Input() disablednoregisters = false;\r\n    @Input() api: any = null;\r\n    @Input() method = 'getchavevalor';\r\n    @Input() loading = false;\r\n    @Input() disabled = false;\r\n\r\n    @Output() onselecteditem = new EventEmitter();\r\n\r\n    selectedValues: any[] = [];\r\n    onChange: any;\r\n    onTouched: any;\r\n\r\n    private initialized = false;\r\n    \r\n    _params: string = null;\r\n    @Input()\r\n    get params(){\r\n        return this._params;\r\n    }\r\n\r\n    set params(value){\r\n        this._params = value;\r\n\r\n        if (this.initialized)\r\n            this.getData();\r\n    }\r\n    \r\n    _data: any = [];\r\n    @Input()\r\n    get data(){\r\n        return this._data;\r\n    }\r\n\r\n    set data(value){\r\n        this._data = value;\r\n        \r\n        if (this.selectfirst && this.data != null && this.data.length > 0 && !this.data.some(d => this.selectedValues?.indexOf(d.Id) > -1))\r\n            this.writeValue([this.data[0].Id]);\r\n        \r\n        if (this.disablednoregisters)\r\n            this.setDisabledState((this.data == null || this.data.length == 0));\r\n    }\r\n\r\n    constructor(private _dataAcessService: InfoDataService) {  }\r\n\r\n    ngOnInit() {\r\n        this.name += this.placeholder.replace(/ /g, '');\r\n        this.getData();\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        this.selectedValues = value;\r\n        this.onChangeValue();\r\n    }\r\n\r\n    getData() {\r\n        this.initialized = true;\r\n        \r\n        if (this.api == null || (this.params != null && this.params.toLowerCase().indexOf('undefined') > -1))\r\n            return;\r\n\r\n        this.loading = true;\r\n        this.data = [];\r\n        \r\n        this._dataAcessService.get(this.api, this.method, this.params).subscribe(r => {\r\n            if (r.success) {\r\n                this.data = r.data;\r\n                if ((this.selectedValues || []).length > 0) this.onChangeValue();\r\n            }\r\n\r\n            this.loading = false;\r\n        });\r\n    }\r\n\r\n    onChangeValue(){\r\n        if (this.onChange != null)\r\n            this.onChange(this.selectedValues);\r\n\r\n        if (this.onselecteditem != null)\r\n            this.onselecteditem.emit(this.data == null ? null : this.data.filter(r => this.selectedValues?.indexOf(r.Id) > -1));\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        this.disabled = this.disablednoregisters && (this.data == null || this.data.length == 0) ? true : isDisabled;\r\n    }\r\n}","<mat-form-field>\r\n    <mat-label>{{placeholder | translate}}</mat-label>\r\n\r\n    <mat-select [(ngModel)]=\"selectedValues\" (selectionChange)=\"onChangeValue()\" [disabled]=\"disabled || loading\" [required]=\"required\" multiple>\r\n        <mat-option *ngFor=\"let i of data\" [value]=\"i.Id\">\r\n            <span [innerHtml]=\"i.Nome | translate\"></span>\r\n        </mat-option>\r\n   </mat-select>\r\n</mat-form-field>\r\n\r\n<section class=\"select-loading\">\r\n    <mat-progress-bar color=\"primary\" mode=\"indeterminate\" *ngIf=\"loading\" >\r\n    </mat-progress-bar>\r\n</section>"]}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/material/icon";
|
|
5
|
+
import * as i3 from "@angular/material/button";
|
|
6
|
+
import * as i4 from "@angular/material/tooltip";
|
|
7
|
+
import * as i5 from "../../pipe/translate.pipe";
|
|
8
|
+
function InfoPaginatorComponent_div_0_label_3_Template(rf, ctx) { if (rf & 1) {
|
|
9
|
+
i0.ɵɵelementStart(0, "label", 9);
|
|
10
|
+
i0.ɵɵtext(1);
|
|
11
|
+
i0.ɵɵelementEnd();
|
|
12
|
+
} if (rf & 2) {
|
|
13
|
+
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
14
|
+
i0.ɵɵadvance(1);
|
|
15
|
+
i0.ɵɵtextInterpolate(ctx_r1.totalDescription);
|
|
16
|
+
} }
|
|
17
|
+
const _c0 = function (a0) { return { "active": a0 }; };
|
|
18
|
+
function InfoPaginatorComponent_div_0_li_16_Template(rf, ctx) { if (rf & 1) {
|
|
19
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
|
20
|
+
i0.ɵɵelementStart(0, "li")(1, "button", 10);
|
|
21
|
+
i0.ɵɵlistener("click", function InfoPaginatorComponent_div_0_li_16_Template_button_click_1_listener() { const restoredCtx = i0.ɵɵrestoreView(_r5); const page_r3 = restoredCtx.$implicit; const ctx_r4 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r4.goto(page_r3)); });
|
|
22
|
+
i0.ɵɵtext(2);
|
|
23
|
+
i0.ɵɵelementEnd()();
|
|
24
|
+
} if (rf & 2) {
|
|
25
|
+
const page_r3 = ctx.$implicit;
|
|
26
|
+
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
27
|
+
i0.ɵɵadvance(1);
|
|
28
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(2, _c0, page_r3 === ctx_r2.indexActive));
|
|
29
|
+
i0.ɵɵadvance(1);
|
|
30
|
+
i0.ɵɵtextInterpolate(page_r3 + 1);
|
|
31
|
+
} }
|
|
32
|
+
const _c1 = function (a0, a1) { return { "descriptions-min": a0, "descriptions": a1 }; };
|
|
33
|
+
const _c2 = function (a0, a1) { return { "pages-min": a0, "pages": a1 }; };
|
|
34
|
+
function InfoPaginatorComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
35
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
|
36
|
+
i0.ɵɵelementStart(0, "div", 1)(1, "div", 2)(2, "div", 3);
|
|
37
|
+
i0.ɵɵtemplate(3, InfoPaginatorComponent_div_0_label_3_Template, 2, 1, "label", 4);
|
|
38
|
+
i0.ɵɵelementEnd();
|
|
39
|
+
i0.ɵɵelementStart(4, "div", 5)(5, "ul")(6, "li", 6)(7, "button", 7);
|
|
40
|
+
i0.ɵɵlistener("click", function InfoPaginatorComponent_div_0_Template_button_click_7_listener() { i0.ɵɵrestoreView(_r7); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.goto(0)); });
|
|
41
|
+
i0.ɵɵpipe(8, "translate");
|
|
42
|
+
i0.ɵɵelementStart(9, "mat-icon");
|
|
43
|
+
i0.ɵɵtext(10, "first_page");
|
|
44
|
+
i0.ɵɵelementEnd()()();
|
|
45
|
+
i0.ɵɵelementStart(11, "li", 6)(12, "button", 7);
|
|
46
|
+
i0.ɵɵlistener("click", function InfoPaginatorComponent_div_0_Template_button_click_12_listener() { i0.ɵɵrestoreView(_r7); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.previous()); });
|
|
47
|
+
i0.ɵɵpipe(13, "translate");
|
|
48
|
+
i0.ɵɵelementStart(14, "mat-icon");
|
|
49
|
+
i0.ɵɵtext(15, "chevron_left");
|
|
50
|
+
i0.ɵɵelementEnd()()();
|
|
51
|
+
i0.ɵɵtemplate(16, InfoPaginatorComponent_div_0_li_16_Template, 3, 4, "li", 8);
|
|
52
|
+
i0.ɵɵelementStart(17, "li", 6)(18, "button", 7);
|
|
53
|
+
i0.ɵɵlistener("click", function InfoPaginatorComponent_div_0_Template_button_click_18_listener() { i0.ɵɵrestoreView(_r7); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.next()); });
|
|
54
|
+
i0.ɵɵpipe(19, "translate");
|
|
55
|
+
i0.ɵɵelementStart(20, "mat-icon");
|
|
56
|
+
i0.ɵɵtext(21, "chevron_right");
|
|
57
|
+
i0.ɵɵelementEnd()()();
|
|
58
|
+
i0.ɵɵelementStart(22, "li", 6)(23, "button", 7);
|
|
59
|
+
i0.ɵɵlistener("click", function InfoPaginatorComponent_div_0_Template_button_click_23_listener() { i0.ɵɵrestoreView(_r7); const ctx_r10 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r10.goto(ctx_r10.numberPages - 1)); });
|
|
60
|
+
i0.ɵɵpipe(24, "translate");
|
|
61
|
+
i0.ɵɵelementStart(25, "mat-icon");
|
|
62
|
+
i0.ɵɵtext(26, "last_page");
|
|
63
|
+
i0.ɵɵelementEnd()()()()()()();
|
|
64
|
+
} if (rf & 2) {
|
|
65
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
66
|
+
i0.ɵɵadvance(2);
|
|
67
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(20, _c1, ctx_r0.min == true, ctx_r0.min != true));
|
|
68
|
+
i0.ɵɵadvance(1);
|
|
69
|
+
i0.ɵɵproperty("ngIf", ctx_r0.totalDescription != null);
|
|
70
|
+
i0.ɵɵadvance(1);
|
|
71
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(23, _c2, ctx_r0.min == true, ctx_r0.min != true));
|
|
72
|
+
i0.ɵɵadvance(3);
|
|
73
|
+
i0.ɵɵproperty("disabled", ctx_r0.index == 0)("matTooltip", i0.ɵɵpipeBind1(8, 12, "Primeira"));
|
|
74
|
+
i0.ɵɵadvance(5);
|
|
75
|
+
i0.ɵɵproperty("disabled", ctx_r0.index == 0)("matTooltip", i0.ɵɵpipeBind1(13, 14, "Anterior"));
|
|
76
|
+
i0.ɵɵadvance(4);
|
|
77
|
+
i0.ɵɵproperty("ngForOf", ctx_r0.pages);
|
|
78
|
+
i0.ɵɵadvance(2);
|
|
79
|
+
i0.ɵɵproperty("disabled", ctx_r0.index >= ctx_r0.numberPages - 1)("matTooltip", i0.ɵɵpipeBind1(19, 16, "Proxima"));
|
|
80
|
+
i0.ɵɵadvance(5);
|
|
81
|
+
i0.ɵɵproperty("disabled", ctx_r0.index >= ctx_r0.numberPages - 1)("matTooltip", i0.ɵɵpipeBind1(24, 18, "Ultima"));
|
|
82
|
+
} }
|
|
83
|
+
export class InfoPaginatorComponent {
|
|
84
|
+
constructor() {
|
|
85
|
+
this.size = 5;
|
|
86
|
+
this.min = false;
|
|
87
|
+
this.show = false;
|
|
88
|
+
this.index = 0;
|
|
89
|
+
this.change = new EventEmitter();
|
|
90
|
+
this._total = 0;
|
|
91
|
+
this.indexActive = 0;
|
|
92
|
+
this.numberPages = 1;
|
|
93
|
+
this.pages = [];
|
|
94
|
+
this.totalDescription = '';
|
|
95
|
+
}
|
|
96
|
+
get total() {
|
|
97
|
+
return this._total;
|
|
98
|
+
}
|
|
99
|
+
set total(value) {
|
|
100
|
+
this._total = value;
|
|
101
|
+
this.initialize();
|
|
102
|
+
}
|
|
103
|
+
refresh(total) {
|
|
104
|
+
this.total = total;
|
|
105
|
+
}
|
|
106
|
+
initialize() {
|
|
107
|
+
this.pages = [];
|
|
108
|
+
this.indexActive = this.index;
|
|
109
|
+
this.numberPages = Math.ceil(this.total / this.size);
|
|
110
|
+
if (this.total > this.size) {
|
|
111
|
+
let i = (this.index > 2) ? (this.index - 2) : 0;
|
|
112
|
+
let x = this.numberPages;
|
|
113
|
+
if ((this.index + 2) < this.numberPages) {
|
|
114
|
+
let aux = 3;
|
|
115
|
+
if (this.index < 2)
|
|
116
|
+
aux = (5 - this.index);
|
|
117
|
+
x = (this.index + aux);
|
|
118
|
+
}
|
|
119
|
+
else if ((this.index - 2) > 0)
|
|
120
|
+
i = this.index - (5 - (this.numberPages - this.index));
|
|
121
|
+
if (i < 0)
|
|
122
|
+
i = 0;
|
|
123
|
+
if (x > this.numberPages)
|
|
124
|
+
x = this.numberPages;
|
|
125
|
+
for (i; i < x; i++)
|
|
126
|
+
this.pages.push(i);
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
this.pages.push(0);
|
|
130
|
+
}
|
|
131
|
+
this.setDescription();
|
|
132
|
+
this.show = true;
|
|
133
|
+
}
|
|
134
|
+
goto(index) {
|
|
135
|
+
if (this.index == index)
|
|
136
|
+
return;
|
|
137
|
+
this.index = index;
|
|
138
|
+
this.change.emit(this.index);
|
|
139
|
+
}
|
|
140
|
+
next() {
|
|
141
|
+
this.goto(this.index + 1);
|
|
142
|
+
}
|
|
143
|
+
previous() {
|
|
144
|
+
this.goto(this.index - 1);
|
|
145
|
+
}
|
|
146
|
+
setDescription() {
|
|
147
|
+
let currentInit = (this.size * this.index) + 1;
|
|
148
|
+
let currentEnd = this.size * (this.index + 1);
|
|
149
|
+
if (currentEnd > this.total)
|
|
150
|
+
currentEnd = this.total;
|
|
151
|
+
if (currentInit == null || currentEnd == null)
|
|
152
|
+
return;
|
|
153
|
+
this.totalDescription = currentInit.toLocaleString('pt-BR') + ' - ' + currentEnd.toLocaleString('pt-BR') + ' de ' + this.total.toLocaleString('pt-BR');
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
/** @nocollapse */ InfoPaginatorComponent.ɵfac = function InfoPaginatorComponent_Factory(t) { return new (t || InfoPaginatorComponent)(); };
|
|
157
|
+
/** @nocollapse */ InfoPaginatorComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoPaginatorComponent, selectors: [["info-paginator"]], inputs: { size: "size", min: "min", show: "show", total: "total" }, outputs: { index: "index", change: "change" }, decls: 1, vars: 1, consts: [["class", "info-paginator", 4, "ngIf"], [1, "info-paginator"], [1, "row"], [1, "col-md-2", 3, "ngClass"], ["class", "total", 4, "ngIf"], [1, "col-md", "align-right", 3, "ngClass"], [1, "icon"], ["mat-button", "", 3, "disabled", "matTooltip", "click"], [4, "ngFor", "ngForOf"], [1, "total"], ["mat-button", "", 3, "ngClass", "click"]], template: function InfoPaginatorComponent_Template(rf, ctx) { if (rf & 1) {
|
|
158
|
+
i0.ɵɵtemplate(0, InfoPaginatorComponent_div_0_Template, 27, 26, "div", 0);
|
|
159
|
+
} if (rf & 2) {
|
|
160
|
+
i0.ɵɵproperty("ngIf", ctx.show);
|
|
161
|
+
} }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i2.MatIcon, i3.MatButton, i4.MatTooltip, i5.InfoTranslatePipe], styles: ["[_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] .descriptions[_ngcontent-%COMP%], [_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] .pages[_ngcontent-%COMP%]{padding-right:10px!important;padding-left:10px!important}[_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] .descriptions-min[_ngcontent-%COMP%], [_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] .pages-min[_ngcontent-%COMP%]{padding-right:0!important;padding-left:0!important}[_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] ul[_ngcontent-%COMP%]{list-style:none;margin:0;padding:0}[_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] ul[_ngcontent-%COMP%] li[_ngcontent-%COMP%]{display:inline-block;font-size:14px}[_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] ul[_ngcontent-%COMP%] li[_ngcontent-%COMP%] .mat-button[_ngcontent-%COMP%]{min-width:34px;line-height:25px;padding:0;margin:0 2px}[_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] ul[_ngcontent-%COMP%] li[_ngcontent-%COMP%] .mat-button.active[_ngcontent-%COMP%]{font-weight:700}[_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] ul[_ngcontent-%COMP%] li[_ngcontent-%COMP%] .mat-button[_ngcontent-%COMP%] .mat-icon[_ngcontent-%COMP%]{font-size:20px}[_nghost-%COMP%] > .info-paginator[_ngcontent-%COMP%] ul[_ngcontent-%COMP%] li.icon[_ngcontent-%COMP%] .mat-button[_ngcontent-%COMP%]{padding:0 2px}"] });
|
|
162
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InfoPaginatorComponent, [{
|
|
163
|
+
type: Component,
|
|
164
|
+
args: [{ selector: 'info-paginator', template: "<div class=\"info-paginator\" *ngIf=\"show\" >\r\n <div class=\"row\">\r\n <div class=\"col-md-2\" [ngClass]=\"{ 'descriptions-min': min == true, 'descriptions': min != true }\">\r\n <label class=\"total\" *ngIf=\"totalDescription != null\">{{totalDescription}}</label>\r\n </div>\r\n <div class=\"col-md align-right\" [ngClass]=\"{ 'pages-min': min == true, 'pages': min != true }\">\r\n <ul>\r\n <li class=\"icon\">\r\n <button mat-button (click)=\"goto(0)\" [disabled]=\"index == 0\" [matTooltip]=\"'Primeira' | translate\" >\r\n <mat-icon>first_page</mat-icon>\r\n </button>\r\n </li>\r\n\r\n <li class=\"icon\">\r\n <button mat-button (click)=\"previous()\" [disabled]=\"index == 0\" [matTooltip]=\"'Anterior' | translate\" >\r\n <mat-icon>chevron_left</mat-icon>\r\n </button>\r\n </li>\r\n\r\n <li *ngFor=\"let page of pages\" >\r\n <button mat-button (click)=\"goto(page)\" [ngClass]=\"{\r\n 'active': page === indexActive\r\n }\" >{{page + 1}}</button>\r\n </li>\r\n\r\n <li class=\"icon\">\r\n <button mat-button (click)=\"next()\" [disabled]=\"index >= (numberPages - 1)\" [matTooltip]=\"'Proxima' | translate\" >\r\n <mat-icon>chevron_right</mat-icon>\r\n </button>\r\n </li>\r\n\r\n <li class=\"icon\">\r\n <button mat-button (click)=\"goto(numberPages - 1)\" [disabled]=\"index >= (numberPages - 1)\" [matTooltip]=\"'Ultima' | translate\" >\r\n <mat-icon>last_page</mat-icon>\r\n </button>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n</div>", styles: [":host>.info-paginator .descriptions,:host>.info-paginator .pages{padding-right:10px!important;padding-left:10px!important}:host>.info-paginator .descriptions-min,:host>.info-paginator .pages-min{padding-right:0!important;padding-left:0!important}:host>.info-paginator ul{list-style:none;margin:0;padding:0}:host>.info-paginator ul li{display:inline-block;font-size:14px}:host>.info-paginator ul li .mat-button{min-width:34px;line-height:25px;padding:0;margin:0 2px}:host>.info-paginator ul li .mat-button.active{font-weight:700}:host>.info-paginator ul li .mat-button .mat-icon{font-size:20px}:host>.info-paginator ul li.icon .mat-button{padding:0 2px}\n"] }]
|
|
165
|
+
}], null, { size: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], min: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], show: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], index: [{
|
|
172
|
+
type: Output
|
|
173
|
+
}], change: [{
|
|
174
|
+
type: Output
|
|
175
|
+
}], total: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}] }); })();
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/paginator/paginator.component.ts","../../../../../projects/info-library/src/controls/paginator/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\r\n\r\n@Component({\r\n    selector: 'info-paginator',\r\n    templateUrl: 'paginator.component.html',\r\n    styleUrls: ['paginator.component.scss']\r\n})\r\n\r\nexport class InfoPaginatorComponent {\r\n\r\n    @Input() size = 5;\r\n    @Input() min = false;\r\n    @Input() show = false;\r\n    @Output() index = 0;\r\n    @Output() change = new EventEmitter<number>();\r\n\r\n    _total = 0;\r\n    @Input()\r\n    get total(){\r\n        return this._total;\r\n    }\r\n\r\n    set total(value){\r\n        this._total = value;\r\n        this.initialize();\r\n    }\r\n\r\n    onChange: any;\r\n    indexActive = 0;\r\n    numberPages = 1;\r\n    pages = [];\r\n    totalDescription = '';\r\n\r\n    refresh(total: number) {\r\n        this.total = total;\r\n    }\r\n\r\n    initialize() {\r\n        this.pages = [];\r\n        this.indexActive = this.index;\r\n        this.numberPages = Math.ceil(this.total / this.size);\r\n        \r\n        if (this.total > this.size) {\r\n            let i = (this.index > 2) ? (this.index - 2) : 0;\r\n            let x = this.numberPages;\r\n\r\n            if ((this.index + 2) < this.numberPages){\r\n                \r\n                let aux = 3;\r\n                if (this.index < 2)\r\n                    aux = (5 - this.index);\r\n\r\n                x = (this.index + aux);\r\n            }\r\n            else if ((this.index - 2) > 0)\r\n                i = this.index - (5 - (this.numberPages - this.index));\r\n            \r\n            if (i < 0)\r\n                i = 0;\r\n\r\n            if (x > this.numberPages)\r\n                x = this.numberPages;\r\n                \r\n            for (i; i < x; i++)\r\n                this.pages.push(i);\r\n\r\n        } else {\r\n            this.pages.push(0);\r\n        }\r\n        \r\n        this.setDescription();\r\n        this.show = true;\r\n    }\r\n\r\n    goto(index: number) {\r\n        \r\n        if (this.index == index)\r\n            return;\r\n\r\n        this.index = index;\r\n        this.change.emit(this.index);\r\n    }\r\n\r\n    next() {\r\n        this.goto(this.index + 1);\r\n    }\r\n\r\n    previous() {\r\n        this.goto(this.index - 1);\r\n    }\r\n\r\n    setDescription(){\r\n        let currentInit = (this.size * this.index) + 1;\r\n        let currentEnd = this.size * (this.index + 1);\r\n\r\n        if (currentEnd > this.total)\r\n            currentEnd = this.total;\r\n\r\n        if (currentInit == null || currentEnd == null) return;\r\n\r\n        this.totalDescription = currentInit.toLocaleString('pt-BR') + ' - ' + currentEnd.toLocaleString('pt-BR') + ' de ' + this.total.toLocaleString('pt-BR');\r\n    }\r\n}","<div class=\"info-paginator\" *ngIf=\"show\" >\r\n    <div class=\"row\">\r\n        <div class=\"col-md-2\" [ngClass]=\"{ 'descriptions-min': min == true, 'descriptions': min != true }\">\r\n            <label class=\"total\" *ngIf=\"totalDescription != null\">{{totalDescription}}</label>\r\n        </div>\r\n        <div class=\"col-md align-right\" [ngClass]=\"{ 'pages-min': min == true, 'pages': min != true }\">\r\n            <ul>\r\n                <li class=\"icon\">\r\n                    <button mat-button (click)=\"goto(0)\" [disabled]=\"index == 0\" [matTooltip]=\"'Primeira' | translate\" >\r\n                        <mat-icon>first_page</mat-icon>\r\n                    </button>\r\n                </li>\r\n\r\n                <li class=\"icon\">\r\n                    <button mat-button (click)=\"previous()\" [disabled]=\"index == 0\" [matTooltip]=\"'Anterior' | translate\" >\r\n                        <mat-icon>chevron_left</mat-icon>\r\n                    </button>\r\n                </li>\r\n\r\n                <li *ngFor=\"let page of pages\" >\r\n                    <button mat-button (click)=\"goto(page)\" [ngClass]=\"{\r\n                        'active': page === indexActive\r\n                    }\" >{{page + 1}}</button>\r\n                </li>\r\n\r\n                <li class=\"icon\">\r\n                    <button mat-button (click)=\"next()\" [disabled]=\"index >= (numberPages - 1)\" [matTooltip]=\"'Proxima' | translate\" >\r\n                        <mat-icon>chevron_right</mat-icon>\r\n                    </button>\r\n                </li>\r\n\r\n                <li class=\"icon\">\r\n                    <button mat-button (click)=\"goto(numberPages - 1)\" [disabled]=\"index >= (numberPages - 1)\" [matTooltip]=\"'Ultima' | translate\" >\r\n                        <mat-icon>last_page</mat-icon>\r\n                    </button>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { Component, Input, forwardRef, Output, EventEmitter } from "@angular/core";
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
3
|
+
import { InfoDataService } from "../../service/data.service";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../service/data.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "@angular/material/form-field";
|
|
9
|
+
import * as i5 from "@angular/material/select";
|
|
10
|
+
import * as i6 from "@angular/material/core";
|
|
11
|
+
import * as i7 from "@angular/material/progress-bar";
|
|
12
|
+
import * as i8 from "../../pipe/translate.pipe";
|
|
13
|
+
function InfoSelectComponent_mat_option_3_Template(rf, ctx) { if (rf & 1) {
|
|
14
|
+
i0.ɵɵelementStart(0, "mat-option", 5);
|
|
15
|
+
i0.ɵɵtext(1);
|
|
16
|
+
i0.ɵɵpipe(2, "translate");
|
|
17
|
+
i0.ɵɵelementEnd();
|
|
18
|
+
} if (rf & 2) {
|
|
19
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
20
|
+
i0.ɵɵproperty("value", ctx_r0.blankItem.Id);
|
|
21
|
+
i0.ɵɵadvance(1);
|
|
22
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(2, 2, ctx_r0.blankItem.Nome));
|
|
23
|
+
} }
|
|
24
|
+
function InfoSelectComponent_mat_option_4_Template(rf, ctx) { if (rf & 1) {
|
|
25
|
+
i0.ɵɵelement(0, "mat-option", 6);
|
|
26
|
+
i0.ɵɵpipe(1, "translate");
|
|
27
|
+
} if (rf & 2) {
|
|
28
|
+
const i_r3 = ctx.$implicit;
|
|
29
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
30
|
+
i0.ɵɵproperty("value", i_r3.Id)("innerHTML", i0.ɵɵpipeBind2(1, 2, i_r3.Nome, ctx_r1.notranslate === null), i0.ɵɵsanitizeHtml);
|
|
31
|
+
} }
|
|
32
|
+
function InfoSelectComponent_mat_progress_bar_6_Template(rf, ctx) { if (rf & 1) {
|
|
33
|
+
i0.ɵɵelement(0, "mat-progress-bar", 7);
|
|
34
|
+
} }
|
|
35
|
+
export class InfoSelectComponent {
|
|
36
|
+
constructor(_dataAcessService) {
|
|
37
|
+
this._dataAcessService = _dataAcessService;
|
|
38
|
+
this.placeholder = '';
|
|
39
|
+
this.name = '';
|
|
40
|
+
this.required = false;
|
|
41
|
+
this.selectfirst = false;
|
|
42
|
+
this.disablednoregisters = false;
|
|
43
|
+
this.api = null;
|
|
44
|
+
this.method = 'getchavevalor';
|
|
45
|
+
this.blank = false;
|
|
46
|
+
this.blankItem = null;
|
|
47
|
+
this.loading = false;
|
|
48
|
+
this.disabled = false;
|
|
49
|
+
this.notranslate = null;
|
|
50
|
+
this.onselecteditem = new EventEmitter();
|
|
51
|
+
this.selectedValue = null;
|
|
52
|
+
this.translatValue = true;
|
|
53
|
+
this.initialized = false;
|
|
54
|
+
this._params = null;
|
|
55
|
+
this._data = [];
|
|
56
|
+
}
|
|
57
|
+
get params() {
|
|
58
|
+
return this._params;
|
|
59
|
+
}
|
|
60
|
+
set params(value) {
|
|
61
|
+
this._params = value;
|
|
62
|
+
if (this.initialized)
|
|
63
|
+
this.getData();
|
|
64
|
+
}
|
|
65
|
+
get data() {
|
|
66
|
+
return this._data;
|
|
67
|
+
}
|
|
68
|
+
set data(value) {
|
|
69
|
+
this._data = value;
|
|
70
|
+
if (this.selectfirst && this.data != null && this.data.length > 0 && !this.data.some(d => d.Id == this.selectedValue))
|
|
71
|
+
this.writeValue(this.data[0].Id);
|
|
72
|
+
if (this.disablednoregisters)
|
|
73
|
+
this.setDisabledState((this.data == null || this.data.length == 0));
|
|
74
|
+
}
|
|
75
|
+
ngOnInit() {
|
|
76
|
+
this.name += this.placeholder.replace(/ /g, '');
|
|
77
|
+
this.blank = (this.required !== '' && this.required !== 'true' && this.required !== true);
|
|
78
|
+
if (this.blankItem == null)
|
|
79
|
+
this.blankItem = { Id: null, Nome: '' };
|
|
80
|
+
this.getData();
|
|
81
|
+
}
|
|
82
|
+
writeValue(value) {
|
|
83
|
+
this.selectedValue = value;
|
|
84
|
+
this.onChangeValue();
|
|
85
|
+
}
|
|
86
|
+
getData() {
|
|
87
|
+
this.initialized = true;
|
|
88
|
+
if (this.api == null || (this.params != null && this.params.toLowerCase().indexOf('undefined') > -1))
|
|
89
|
+
return;
|
|
90
|
+
this.loading = true;
|
|
91
|
+
this.data = [];
|
|
92
|
+
this._dataAcessService.get(this.api, this.method, this.params).subscribe(r => {
|
|
93
|
+
if (r.success) {
|
|
94
|
+
this.data = r.data;
|
|
95
|
+
if (this.selectedValue)
|
|
96
|
+
this.onChangeValue();
|
|
97
|
+
}
|
|
98
|
+
this.loading = false;
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
onChangeValue() {
|
|
102
|
+
if (this.onChange != null)
|
|
103
|
+
this.onChange(this.selectedValue);
|
|
104
|
+
if (this.onselecteditem != null)
|
|
105
|
+
this.onselecteditem.emit(this.data == null ? null : this.data.find(r => r.Id == this.selectedValue));
|
|
106
|
+
}
|
|
107
|
+
registerOnChange(fn) {
|
|
108
|
+
this.onChange = fn;
|
|
109
|
+
}
|
|
110
|
+
registerOnTouched(fn) {
|
|
111
|
+
this.onTouched = fn;
|
|
112
|
+
}
|
|
113
|
+
setDisabledState(isDisabled) {
|
|
114
|
+
this.disabled = this.disablednoregisters && (this.data == null || this.data.length == 0) ? true : isDisabled;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
/** @nocollapse */ InfoSelectComponent.ɵfac = function InfoSelectComponent_Factory(t) { return new (t || InfoSelectComponent)(i0.ɵɵdirectiveInject(i1.InfoDataService)); };
|
|
118
|
+
/** @nocollapse */ InfoSelectComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoSelectComponent, selectors: [["info-select"]], inputs: { placeholder: "placeholder", name: "name", required: "required", selectfirst: "selectfirst", disablednoregisters: "disablednoregisters", api: "api", method: "method", blank: "blank", blankItem: "blankItem", loading: "loading", disabled: "disabled", notranslate: "notranslate", params: "params", data: "data" }, outputs: { onselecteditem: "onselecteditem" }, features: [i0.ɵɵProvidersFeature([{
|
|
119
|
+
provide: NG_VALUE_ACCESSOR,
|
|
120
|
+
useExisting: forwardRef((() => InfoSelectComponent)),
|
|
121
|
+
multi: true
|
|
122
|
+
}])], decls: 7, vars: 9, consts: [[3, "placeholder", "ngModel", "disabled", "required", "ngModelChange", "selectionChange"], [3, "value", 4, "ngIf"], [3, "value", "innerHTML", 4, "ngFor", "ngForOf"], [1, "select-loading"], ["color", "primary", "mode", "indeterminate", 4, "ngIf"], [3, "value"], [3, "value", "innerHTML"], ["color", "primary", "mode", "indeterminate"]], template: function InfoSelectComponent_Template(rf, ctx) { if (rf & 1) {
|
|
123
|
+
i0.ɵɵelementStart(0, "mat-form-field")(1, "mat-select", 0);
|
|
124
|
+
i0.ɵɵlistener("ngModelChange", function InfoSelectComponent_Template_mat_select_ngModelChange_1_listener($event) { return ctx.selectedValue = $event; })("selectionChange", function InfoSelectComponent_Template_mat_select_selectionChange_1_listener() { return ctx.onChangeValue(); });
|
|
125
|
+
i0.ɵɵpipe(2, "translate");
|
|
126
|
+
i0.ɵɵtemplate(3, InfoSelectComponent_mat_option_3_Template, 3, 4, "mat-option", 1);
|
|
127
|
+
i0.ɵɵtemplate(4, InfoSelectComponent_mat_option_4_Template, 2, 5, "mat-option", 2);
|
|
128
|
+
i0.ɵɵelementEnd()();
|
|
129
|
+
i0.ɵɵelementStart(5, "section", 3);
|
|
130
|
+
i0.ɵɵtemplate(6, InfoSelectComponent_mat_progress_bar_6_Template, 1, 0, "mat-progress-bar", 4);
|
|
131
|
+
i0.ɵɵelementEnd();
|
|
132
|
+
} if (rf & 2) {
|
|
133
|
+
i0.ɵɵadvance(1);
|
|
134
|
+
i0.ɵɵproperty("placeholder", i0.ɵɵpipeBind1(2, 7, ctx.placeholder))("ngModel", ctx.selectedValue)("disabled", ctx.disabled || ctx.loading)("required", ctx.required);
|
|
135
|
+
i0.ɵɵadvance(2);
|
|
136
|
+
i0.ɵɵproperty("ngIf", ctx.blank);
|
|
137
|
+
i0.ɵɵadvance(1);
|
|
138
|
+
i0.ɵɵproperty("ngForOf", ctx.data);
|
|
139
|
+
i0.ɵɵadvance(2);
|
|
140
|
+
i0.ɵɵproperty("ngIf", ctx.loading);
|
|
141
|
+
} }, dependencies: [i2.NgForOf, i2.NgIf, i3.NgControlStatus, i3.RequiredValidator, i3.NgModel, i4.MatFormField, i5.MatSelect, i6.MatOption, i7.MatProgressBar, i8.InfoTranslatePipe], styles: ["[_nghost-%COMP%] .mat-select-trigger[_ngcontent-%COMP%]{height:19px}[_nghost-%COMP%] .mat-form-field-type-mat-select[_ngcontent-%COMP%] .mat-form-field-label[_ngcontent-%COMP%]{height:20px}[_nghost-%COMP%] .mat-option[_ngcontent-%COMP%]{height:unset;white-space:normal}[_nghost-%COMP%] .select-loading[_ngcontent-%COMP%]{position:relative;bottom:15px;opacity:.3;height:1px}[_nghost-%COMP%] .select-loading[_ngcontent-%COMP%] .mat-progress-bar[_ngcontent-%COMP%]{height:1px;margin:0}.min[_nghost-%COMP%] .mat-form-field[_ngcontent-%COMP%]{margin:0!important}"] });
|
|
142
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InfoSelectComponent, [{
|
|
143
|
+
type: Component,
|
|
144
|
+
args: [{ selector: 'info-select', providers: [{
|
|
145
|
+
provide: NG_VALUE_ACCESSOR,
|
|
146
|
+
useExisting: forwardRef((() => InfoSelectComponent)),
|
|
147
|
+
multi: true
|
|
148
|
+
}], template: "<mat-form-field>\r\n <mat-select [placeholder]=\"placeholder | translate\" [(ngModel)]=\"selectedValue\" (selectionChange)=\"onChangeValue()\" [disabled]=\"disabled || loading\" [required]=\"required\">\r\n <mat-option *ngIf=\"blank\" [value]=\"blankItem.Id\">{{ blankItem.Nome | translate }}</mat-option>\r\n <mat-option *ngFor=\"let i of data\" [value]=\"i.Id\" [innerHTML]=\"i.Nome | translate:(notranslate===null)\"></mat-option>\r\n </mat-select>\r\n</mat-form-field>\r\n\r\n<section class=\"select-loading\">\r\n <mat-progress-bar color=\"primary\" mode=\"indeterminate\" *ngIf=\"loading\" >\r\n </mat-progress-bar>\r\n</section>", styles: [":host .mat-select-trigger{height:19px}:host .mat-form-field-type-mat-select .mat-form-field-label{height:20px}:host .mat-option{height:unset;white-space:normal}:host .select-loading{position:relative;bottom:15px;opacity:.3;height:1px}:host .select-loading .mat-progress-bar{height:1px;margin:0}:host.min .mat-form-field{margin:0!important}\n"] }]
|
|
149
|
+
}], function () { return [{ type: i1.InfoDataService }]; }, { placeholder: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], name: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], required: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], selectfirst: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], disablednoregisters: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], api: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], method: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], blank: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], blankItem: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], loading: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], disabled: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], notranslate: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], onselecteditem: [{
|
|
174
|
+
type: Output
|
|
175
|
+
}], params: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], data: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}] }); })();
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/select/select.component.ts","../../../../../projects/info-library/src/controls/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, forwardRef, Output, EventEmitter } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { InfoDataService } from \"../../service/data.service\";\r\n\r\n@Component({\r\n    selector: 'info-select',\r\n    templateUrl: 'select.component.html',\r\n    styleUrls: ['select.component.scss'],\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => InfoSelectComponent),\r\n        multi: true\r\n    }]\r\n})\r\nexport class InfoSelectComponent implements OnInit, ControlValueAccessor {\r\n\r\n    @Input() placeholder = '';\r\n    @Input() name = '';\r\n    @Input() required: any = false;\r\n    @Input() selectfirst = false;\r\n    @Input() disablednoregisters = false;\r\n    @Input() api: any = null;\r\n    @Input() method = 'getchavevalor';\r\n    @Input() blank = false;\r\n    @Input() blankItem: any = null;\r\n    @Input() loading = false;\r\n    @Input() disabled = false;\r\n    @Input() notranslate: any = null;\r\n\r\n    @Output() onselecteditem = new EventEmitter();\r\n\r\n    selectedValue: any = null;\r\n    translatValue: boolean = true;\r\n    onChange: any;\r\n    onTouched: any;\r\n\r\n    private initialized = false;\r\n    \r\n    _params: string = null;\r\n    @Input()\r\n    get params(){\r\n        return this._params;\r\n    }\r\n\r\n    set params(value){\r\n        this._params = value;\r\n\r\n        if (this.initialized)\r\n            this.getData();\r\n    }\r\n    \r\n    _data: any = [];\r\n    @Input()\r\n    get data(){\r\n        return this._data;\r\n    }\r\n\r\n    set data(value){\r\n        this._data = value;\r\n        \r\n        if (this.selectfirst && this.data != null && this.data.length > 0 && !this.data.some(d => d.Id == this.selectedValue))\r\n            this.writeValue(this.data[0].Id);\r\n        \r\n        if (this.disablednoregisters)\r\n            this.setDisabledState((this.data == null || this.data.length == 0));\r\n    }\r\n\r\n    constructor(private _dataAcessService: InfoDataService) {  }\r\n\r\n    ngOnInit() {\r\n        this.name += this.placeholder.replace(/ /g, '');\r\n        this.blank = (this.required !== '' && this.required !== 'true' && this.required !== true);\r\n\r\n        if (this.blankItem == null)\r\n            this.blankItem = { Id: null, Nome: '' };\r\n                \r\n        this.getData();\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        this.selectedValue = value;\r\n        this.onChangeValue();\r\n    }\r\n\r\n    getData() {\r\n        this.initialized = true;\r\n        \r\n        if (this.api == null || (this.params != null && this.params.toLowerCase().indexOf('undefined') > -1))\r\n            return;\r\n\r\n        this.loading = true;\r\n        this.data = [];\r\n        \r\n        this._dataAcessService.get(this.api, this.method, this.params).subscribe(r => {\r\n            if (r.success) {\r\n                this.data = r.data;\r\n                if (this.selectedValue) this.onChangeValue();\r\n            }\r\n\r\n            this.loading = false;\r\n        });\r\n    }\r\n\r\n    onChangeValue(){\r\n        if (this.onChange != null)\r\n            this.onChange(this.selectedValue);\r\n\r\n        if (this.onselecteditem != null)\r\n            this.onselecteditem.emit(this.data == null ? null : this.data.find(r => r.Id == this.selectedValue));\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n        this.disabled = this.disablednoregisters && (this.data == null || this.data.length == 0) ? true : isDisabled;\r\n    }\r\n}","<mat-form-field>\r\n    <mat-select [placeholder]=\"placeholder | translate\" [(ngModel)]=\"selectedValue\" (selectionChange)=\"onChangeValue()\" [disabled]=\"disabled || loading\" [required]=\"required\">\r\n        <mat-option *ngIf=\"blank\" [value]=\"blankItem.Id\">{{ blankItem.Nome | translate }}</mat-option>\r\n        <mat-option *ngFor=\"let i of data\" [value]=\"i.Id\" [innerHTML]=\"i.Nome | translate:(notranslate===null)\"></mat-option>\r\n    </mat-select>\r\n</mat-form-field>\r\n\r\n<section class=\"select-loading\">\r\n    <mat-progress-bar color=\"primary\" mode=\"indeterminate\" *ngIf=\"loading\" >\r\n    </mat-progress-bar>\r\n</section>"]}
|