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.
Files changed (176) hide show
  1. package/controls/alert/alert.component.d.ts +3 -0
  2. package/controls/autocomplete/autocomplete.component.d.ts +5 -2
  3. package/controls/big-checkbox/big-checkbox.component.d.ts +3 -0
  4. package/controls/card/card.component.d.ts +3 -0
  5. package/controls/card-menu/card-menu.component.d.ts +3 -0
  6. package/controls/checkbox/checkbox.component.d.ts +3 -0
  7. package/controls/chips/chips.component.d.ts +3 -0
  8. package/controls/date/date.component.d.ts +3 -0
  9. package/controls/date-month/date-month.component.d.ts +3 -0
  10. package/controls/editor/editor.component.d.ts +3 -0
  11. package/controls/grid/grid.component.d.ts +5 -0
  12. package/controls/input/input.component.d.ts +3 -0
  13. package/controls/input-list/input-list.component.d.ts +3 -0
  14. package/controls/list-checkbox/list-checkbox.component.d.ts +3 -0
  15. package/controls/message/message.component.d.ts +3 -0
  16. package/controls/multi-select/multi-select.component.d.ts +3 -0
  17. package/controls/paginator/paginator.component.d.ts +3 -0
  18. package/controls/select/select.component.d.ts +3 -0
  19. package/controls/timeline/timeline.component.d.ts +3 -0
  20. package/directives/mask.directive.d.ts +3 -0
  21. package/directives/unmask.directive.d.ts +3 -0
  22. package/esm2020/controls/alert/alert.component.mjs +74 -0
  23. package/esm2020/controls/autocomplete/autocomplete.component.mjs +258 -0
  24. package/esm2020/controls/big-checkbox/big-checkbox.component.mjs +298 -0
  25. package/esm2020/controls/card/card.component.mjs +77 -0
  26. package/esm2020/controls/card-menu/card-menu.component.mjs +145 -0
  27. package/esm2020/controls/checkbox/checkbox.component.mjs +93 -0
  28. package/esm2020/controls/chips/chips.component.mjs +113 -0
  29. package/esm2020/controls/date/date.component.mjs +141 -0
  30. package/esm2020/controls/date-month/date-month.component.mjs +148 -0
  31. package/esm2020/controls/editor/editor.component.mjs +135 -0
  32. package/esm2020/controls/grid/grid.component.mjs +1800 -0
  33. package/esm2020/controls/input/input.component.mjs +314 -0
  34. package/esm2020/controls/input-list/input-list.component.mjs +258 -0
  35. package/esm2020/controls/list-checkbox/list-checkbox.component.mjs +238 -0
  36. package/esm2020/controls/message/message.component.mjs +50 -0
  37. package/esm2020/controls/multi-select/multi-select.component.mjs +161 -0
  38. package/esm2020/controls/paginator/paginator.component.mjs +178 -0
  39. package/esm2020/controls/select/select.component.mjs +180 -0
  40. package/esm2020/controls/timeline/timeline.component.mjs +117 -0
  41. package/esm2020/directives/mask.directive.mjs +125 -0
  42. package/esm2020/directives/unmask.directive.mjs +28 -0
  43. package/esm2020/enum/dialog-buttons.enum.mjs +9 -0
  44. package/esm2020/enum/index.mjs +4 -0
  45. package/esm2020/enum/modal-action.enum.mjs +12 -0
  46. package/esm2020/enum/page-action.enum.mjs +10 -0
  47. package/esm2020/global-config.mjs +4 -0
  48. package/esm2020/info-library.mjs +5 -0
  49. package/esm2020/info-library.module.mjs +278 -0
  50. package/esm2020/layouts/dialog/dialog.component.mjs +188 -0
  51. package/esm2020/layouts/loading/loading.component.mjs +42 -0
  52. package/esm2020/layouts/main/main.component.mjs +276 -0
  53. package/esm2020/layouts/modal/modal.component.mjs +258 -0
  54. package/esm2020/layouts/pagebar/pagebar.component.mjs +404 -0
  55. package/esm2020/layouts/sidebar/sidebar.component.mjs +395 -0
  56. package/esm2020/layouts/topbar/topbar.component.mjs +863 -0
  57. package/esm2020/layouts/topmenu/topmenu.component.mjs +165 -0
  58. package/esm2020/model/app-config.model.mjs +14 -0
  59. package/esm2020/model/data-access.model.mjs +35 -0
  60. package/esm2020/model/dialog-result.model.mjs +8 -0
  61. package/esm2020/model/dialog.model.mjs +16 -0
  62. package/esm2020/model/form-prop.model.mjs +35 -0
  63. package/esm2020/model/grid-button.model.mjs +21 -0
  64. package/esm2020/model/index.mjs +15 -0
  65. package/esm2020/model/last-search.model.mjs +9 -0
  66. package/esm2020/model/login.model.mjs +9 -0
  67. package/esm2020/model/method-grid-button.model.mjs +9 -0
  68. package/esm2020/model/notification.model.mjs +9 -0
  69. package/esm2020/model/pagebar-buttons.model.mjs +15 -0
  70. package/esm2020/model/permission.model.mjs +3 -0
  71. package/esm2020/model/platform.model.mjs +21 -0
  72. package/esm2020/model/session.model.mjs +8 -0
  73. package/esm2020/pipe/index.mjs +3 -0
  74. package/esm2020/pipe/mask.pipe.mjs +34 -0
  75. package/esm2020/pipe/translate.pipe.mjs +26 -0
  76. package/esm2020/public_api.mjs +36 -0
  77. package/esm2020/service/authentication.service.mjs +358 -0
  78. package/esm2020/service/configuration.service.mjs +59 -0
  79. package/esm2020/service/data.service.mjs +112 -0
  80. package/esm2020/service/index.mjs +6 -0
  81. package/esm2020/service/theme.service.mjs +79 -0
  82. package/esm2020/service/translate.service.mjs +53 -0
  83. package/esm2020/utils/utilities.mjs +142 -0
  84. package/fesm2015/info-library.mjs +9326 -0
  85. package/fesm2015/info-library.mjs.map +1 -0
  86. package/fesm2020/info-library.mjs +8474 -0
  87. package/fesm2020/info-library.mjs.map +1 -0
  88. package/index.d.ts +5 -0
  89. package/info-library.module.d.ts +58 -0
  90. package/layouts/dialog/dialog.component.d.ts +5 -0
  91. package/layouts/loading/loading.component.d.ts +3 -0
  92. package/layouts/main/main.component.d.ts +6 -0
  93. package/layouts/modal/modal.component.d.ts +3 -0
  94. package/layouts/pagebar/pagebar.component.d.ts +5 -0
  95. package/layouts/sidebar/sidebar.component.d.ts +4 -1
  96. package/layouts/topbar/topbar.component.d.ts +4 -1
  97. package/layouts/topmenu/topmenu.component.d.ts +3 -0
  98. package/package.json +28 -13
  99. package/pipe/mask.pipe.d.ts +3 -0
  100. package/pipe/translate.pipe.d.ts +3 -0
  101. package/service/authentication.service.d.ts +5 -0
  102. package/service/configuration.service.d.ts +3 -0
  103. package/service/data.service.d.ts +3 -0
  104. package/service/theme.service.d.ts +3 -0
  105. package/service/translate.service.d.ts +3 -0
  106. package/utils/utilities.d.ts +3 -0
  107. package/bundles/info-library.umd.js +0 -9740
  108. package/bundles/info-library.umd.js.map +0 -1
  109. package/bundles/info-library.umd.min.js +0 -2
  110. package/bundles/info-library.umd.min.js.map +0 -1
  111. package/esm2015/controls/alert/alert.component.js +0 -43
  112. package/esm2015/controls/autocomplete/autocomplete.component.js +0 -386
  113. package/esm2015/controls/big-checkbox/big-checkbox.component.js +0 -282
  114. package/esm2015/controls/card/card.component.js +0 -64
  115. package/esm2015/controls/card-menu/card-menu.component.js +0 -90
  116. package/esm2015/controls/checkbox/checkbox.component.js +0 -130
  117. package/esm2015/controls/chips/chips.component.js +0 -124
  118. package/esm2015/controls/date/date.component.js +0 -167
  119. package/esm2015/controls/date-month/date-month.component.js +0 -181
  120. package/esm2015/controls/editor/editor.component.js +0 -237
  121. package/esm2015/controls/grid/grid.component.js +0 -1391
  122. package/esm2015/controls/input/input.component.js +0 -196
  123. package/esm2015/controls/input-list/input-list.component.js +0 -160
  124. package/esm2015/controls/list-checkbox/list-checkbox.component.js +0 -151
  125. package/esm2015/controls/message/message.component.js +0 -47
  126. package/esm2015/controls/multi-select/multi-select.component.js +0 -213
  127. package/esm2015/controls/paginator/paginator.component.js +0 -151
  128. package/esm2015/controls/select/select.component.js +0 -231
  129. package/esm2015/controls/timeline/timeline.component.js +0 -73
  130. package/esm2015/directives/mask.directive.js +0 -202
  131. package/esm2015/directives/unmask.directive.js +0 -51
  132. package/esm2015/enum/dialog-buttons.enum.js +0 -20
  133. package/esm2015/enum/index.js +0 -9
  134. package/esm2015/enum/modal-action.enum.js +0 -26
  135. package/esm2015/enum/page-action.enum.js +0 -22
  136. package/esm2015/global-config.js +0 -11
  137. package/esm2015/info-library.js +0 -27
  138. package/esm2015/info-library.module.js +0 -174
  139. package/esm2015/layouts/dialog/dialog.component.js +0 -173
  140. package/esm2015/layouts/loading/loading.component.js +0 -42
  141. package/esm2015/layouts/main/main.component.js +0 -312
  142. package/esm2015/layouts/modal/modal.component.js +0 -232
  143. package/esm2015/layouts/pagebar/pagebar.component.js +0 -286
  144. package/esm2015/layouts/sidebar/sidebar.component.js +0 -231
  145. package/esm2015/layouts/topbar/topbar.component.js +0 -413
  146. package/esm2015/layouts/topmenu/topmenu.component.js +0 -181
  147. package/esm2015/model/app-config.model.js +0 -39
  148. package/esm2015/model/data-access.model.js +0 -65
  149. package/esm2015/model/dialog-result.model.js +0 -23
  150. package/esm2015/model/dialog.model.js +0 -47
  151. package/esm2015/model/form-prop.model.js +0 -61
  152. package/esm2015/model/grid-button.model.js +0 -62
  153. package/esm2015/model/index.js +0 -20
  154. package/esm2015/model/last-search.model.js +0 -24
  155. package/esm2015/model/login.model.js +0 -27
  156. package/esm2015/model/method-grid-button.model.js +0 -27
  157. package/esm2015/model/notification.model.js +0 -34
  158. package/esm2015/model/pagebar-buttons.model.js +0 -39
  159. package/esm2015/model/permission.model.js +0 -16
  160. package/esm2015/model/platform.model.js +0 -56
  161. package/esm2015/model/session.model.js +0 -53
  162. package/esm2015/pipe/index.js +0 -8
  163. package/esm2015/pipe/mask.pipe.js +0 -47
  164. package/esm2015/pipe/translate.pipe.js +0 -45
  165. package/esm2015/public_api.js +0 -41
  166. package/esm2015/service/authentication.service.js +0 -732
  167. package/esm2015/service/configuration.service.js +0 -107
  168. package/esm2015/service/data.service.js +0 -292
  169. package/esm2015/service/index.js +0 -11
  170. package/esm2015/service/theme.service.js +0 -133
  171. package/esm2015/service/translate.service.js +0 -105
  172. package/esm2015/utils/utilities.js +0 -256
  173. package/fesm2015/info-library.js +0 -8792
  174. package/fesm2015/info-library.js.map +0 -1
  175. package/info-library.d.ts +0 -21
  176. package/info-library.metadata.json +0 -1
@@ -0,0 +1,258 @@
1
+ import { Component, Input, forwardRef, Output, EventEmitter } from "@angular/core";
2
+ import { UntypedFormControl, NG_VALUE_ACCESSOR } from "@angular/forms";
3
+ import { debounceTime, switchMap, distinctUntilChanged } from 'rxjs/operators';
4
+ import { InfoDataService } from "../../service/data.service";
5
+ import { Observable } from "rxjs";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../service/data.service";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "@angular/forms";
10
+ import * as i4 from "@angular/material/icon";
11
+ import * as i5 from "@angular/material/form-field";
12
+ import * as i6 from "@angular/material/input";
13
+ import * as i7 from "@angular/material/core";
14
+ import * as i8 from "@angular/material/progress-bar";
15
+ import * as i9 from "@angular/material/autocomplete";
16
+ import * as i10 from "../../pipe/translate.pipe";
17
+ function InfoAutoCompleteComponent_mat_option_6_Template(rf, ctx) { if (rf & 1) {
18
+ const _r6 = i0.ɵɵgetCurrentView();
19
+ i0.ɵɵelementStart(0, "mat-option", 8);
20
+ i0.ɵɵlistener("onSelectionChange", function InfoAutoCompleteComponent_mat_option_6_Template_mat_option_onSelectionChange_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r6); const option_r4 = restoredCtx.$implicit; const ctx_r5 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r5.writeValue(option_r4.Id)); });
21
+ i0.ɵɵelementEnd();
22
+ } if (rf & 2) {
23
+ const option_r4 = ctx.$implicit;
24
+ i0.ɵɵproperty("value", option_r4)("innerHTML", option_r4.Nome, i0.ɵɵsanitizeHtml);
25
+ } }
26
+ function InfoAutoCompleteComponent_mat_progress_bar_10_Template(rf, ctx) { if (rf & 1) {
27
+ i0.ɵɵelement(0, "mat-progress-bar", 9);
28
+ } }
29
+ export class InfoAutoCompleteComponent {
30
+ constructor(_dataAcess) {
31
+ this._dataAcess = _dataAcess;
32
+ this.control = new UntypedFormControl();
33
+ this.placeholder = '';
34
+ this.name = '';
35
+ this.required = false;
36
+ this.selectfirst = false;
37
+ this.disablednoregisters = false;
38
+ this.getdataonchange = false;
39
+ this.getdataonchangetime = 500;
40
+ this.api = null;
41
+ this.method = 'getchavevalor';
42
+ this.maxlist = 10;
43
+ this.startwith = false;
44
+ this.minchar = 1;
45
+ this.onselecteditem = new EventEmitter();
46
+ this.selectedValue = null;
47
+ this.initialized = false;
48
+ this._loading = false;
49
+ this._params = null;
50
+ this._disabled = null;
51
+ this._data = [];
52
+ }
53
+ get loading() {
54
+ return this._loading;
55
+ }
56
+ set loading(value) {
57
+ this._loading = value;
58
+ if (this._disabled == null)
59
+ this._disabled = false;
60
+ else if (this._disabled.toString() == '')
61
+ this._disabled = true;
62
+ if (this._disabled == false)
63
+ this.setDisabledState(this.loading);
64
+ }
65
+ get params() {
66
+ return this._params;
67
+ }
68
+ set params(value) {
69
+ this._params = value;
70
+ if (this.initialized)
71
+ this.getData().subscribe(a => { this.data = a.data; this.loading = false; });
72
+ }
73
+ set disabled(value) {
74
+ if (this._disabled == null)
75
+ this._disabled = value;
76
+ if (value)
77
+ this.control.disable();
78
+ else
79
+ this.control.enable();
80
+ }
81
+ get data() {
82
+ return this._data;
83
+ }
84
+ set data(value) {
85
+ this._data = value;
86
+ if (this.getdataonchange)
87
+ return;
88
+ setTimeout(() => {
89
+ if (this.selectedValue != null)
90
+ if ((this._data == null || (this._data != null && this._data.length == 0)) && !this.loading) {
91
+ this.writeValue(null);
92
+ this.selectedValue = null;
93
+ }
94
+ else
95
+ this.writeValue(this.selectedValue.Id == null ? this.selectedValue : this.selectedValue.Id);
96
+ else if (this.selectfirst && this.data != null && this.data.length > 0)
97
+ this.writeValue(this.data[0].Id);
98
+ if (this.disablednoregisters)
99
+ this.setDisabledState((this.data == null || this.data.length == 0));
100
+ }, 1000);
101
+ }
102
+ ngOnInit() {
103
+ if (this.minchar == null || this.minchar < 0)
104
+ this.minchar = 1;
105
+ this.name = this.placeholder.replace(/ /g, '') + Math.floor(Math.random() * 1000).toString();
106
+ if (!this.getdataonchange) {
107
+ this.getData().subscribe(a => { this.data = a.data; this.loading = false; });
108
+ this.control.valueChanges.subscribe(value => { this.options = this.filter(value); });
109
+ }
110
+ else {
111
+ this.control.valueChanges.pipe(debounceTime(this.getdataonchangetime), distinctUntilChanged(), switchMap(value => this.getData(value))).subscribe(a => this.data = this.options = a.data);
112
+ }
113
+ }
114
+ filter(value) {
115
+ if (value == null || value.length < this.minchar)
116
+ return [];
117
+ let filterValue = value.Nome == null ? value.toString().toLowerCase() : value.Nome;
118
+ if (this.startwith)
119
+ return this.data.filter(option => option.Nome.toLowerCase().indexOf(filterValue) === 0 || (option.Aux == null ? "" : option.Aux.toLowerCase() == filterValue)).slice(0, this.maxlist);
120
+ else
121
+ return this.data.filter(option => option.Nome.toLowerCase().indexOf(filterValue) > -1 || (option.Aux == null ? "" : option.Aux.toLowerCase().indexOf(filterValue) > -1)).slice(0, this.maxlist);
122
+ }
123
+ getData(value = null) {
124
+ this.initialized = true;
125
+ if (this.api == null || this.api == '')
126
+ return new Observable();
127
+ this.loading = !this.getdataonchange;
128
+ this.data = [];
129
+ let parameters = this.params || '';
130
+ if (this.getdataonchange) {
131
+ if (value == null || value == '')
132
+ return new Observable();
133
+ if (parameters != null && parameters != '')
134
+ parameters += '&';
135
+ parameters += `nome=${value.Nome == null ? value.toString().toLowerCase() : value.Nome}&take=${this.maxlist}`;
136
+ let model = parameters.split("&").map(c => ({ [c.split("=")[0].charAt(0).toUpperCase() + c.split("=")[0].substring(1)]: c.split("=")[1] })).reduce((a, b) => ({ ...a, ...b }));
137
+ return this._dataAcess.post(this.api, model, this.method);
138
+ }
139
+ return this._dataAcess.get(this.api, this.method, parameters);
140
+ }
141
+ onBlur(value) {
142
+ setTimeout(() => {
143
+ if (this.selectedValue != null && this.selectedValue.Id != null)
144
+ return;
145
+ if (!value && this.selectedValue != null && this.selectedValue.trim() == '')
146
+ this.writeValue(null);
147
+ else {
148
+ let first = this.filter(value);
149
+ if (first != null && first.length > 0)
150
+ this.writeValue(first[0].Id);
151
+ else
152
+ this.writeValue(null);
153
+ }
154
+ }, 300);
155
+ }
156
+ onFocus(value) {
157
+ if (this.minchar != null && this.minchar == 0 && (value == null || value == ''))
158
+ setTimeout(() => { this.control.setValue(''); }, 200);
159
+ }
160
+ displayFn(model) {
161
+ if (model == null || model.Nome == null)
162
+ return '';
163
+ let indexSmall = model.Nome.indexOf('<small');
164
+ return indexSmall > -1 ? model.Nome.substring(0, indexSmall).trim() : model.Nome;
165
+ }
166
+ writeValue(value) {
167
+ let obj = this.data.find(r => r.Id == value);
168
+ this.control.setValue(obj);
169
+ if (value != null && obj == null)
170
+ this.selectedValue = value;
171
+ if (this.onChange != null)
172
+ this.onChange(value);
173
+ if (this.onselecteditem != null)
174
+ this.onselecteditem.emit(this.data == null ? null : this.data.find(r => r.Id == value));
175
+ }
176
+ registerOnChange(fn) {
177
+ this.onChange = fn;
178
+ }
179
+ registerOnTouched(fn) {
180
+ this.onTouched = fn;
181
+ }
182
+ setDisabledState(isDisabled) {
183
+ this.disabled = this.disablednoregisters && (this.data == null || this.data.length == 0) ? true : isDisabled;
184
+ }
185
+ }
186
+ /** @nocollapse */ InfoAutoCompleteComponent.ɵfac = function InfoAutoCompleteComponent_Factory(t) { return new (t || InfoAutoCompleteComponent)(i0.ɵɵdirectiveInject(i1.InfoDataService)); };
187
+ /** @nocollapse */ InfoAutoCompleteComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoAutoCompleteComponent, selectors: [["info-autocomplete"]], inputs: { placeholder: "placeholder", name: "name", required: "required", selectfirst: "selectfirst", disablednoregisters: "disablednoregisters", getdataonchange: "getdataonchange", getdataonchangetime: "getdataonchangetime", api: "api", method: "method", maxlist: "maxlist", startwith: "startwith", minchar: "minchar", loading: "loading", params: "params", disabled: "disabled", data: "data" }, outputs: { onselecteditem: "onselecteditem" }, features: [i0.ɵɵProvidersFeature([{
188
+ provide: NG_VALUE_ACCESSOR,
189
+ useExisting: forwardRef((() => InfoAutoCompleteComponent)),
190
+ multi: true
191
+ }])], decls: 11, vars: 10, consts: [["matInput", "", "type", "text", 3, "ngModel", "placeholder", "formControl", "matAutocomplete", "required", "ngModelChange", "blur", "focus"], ["inputAuto", ""], [3, "displayWith"], ["auto", "matAutocomplete"], [3, "value", "innerHTML", "onSelectionChange", 4, "ngFor", "ngForOf"], ["matSuffix", "", 2, "color", "#aaa"], [1, "select-loading"], ["color", "primary", "mode", "indeterminate", 4, "ngIf"], [3, "value", "innerHTML", "onSelectionChange"], ["color", "primary", "mode", "indeterminate"]], template: function InfoAutoCompleteComponent_Template(rf, ctx) { if (rf & 1) {
192
+ i0.ɵɵelementStart(0, "mat-form-field")(1, "input", 0, 1);
193
+ i0.ɵɵlistener("ngModelChange", function InfoAutoCompleteComponent_Template_input_ngModelChange_1_listener($event) { return ctx.selectedValue = $event; })("blur", function InfoAutoCompleteComponent_Template_input_blur_1_listener($event) { return ctx.onBlur($event.target.value); })("focus", function InfoAutoCompleteComponent_Template_input_focus_1_listener($event) { return ctx.onFocus($event.target.value); });
194
+ i0.ɵɵpipe(3, "translate");
195
+ i0.ɵɵelementEnd();
196
+ i0.ɵɵelementStart(4, "mat-autocomplete", 2, 3);
197
+ i0.ɵɵtemplate(6, InfoAutoCompleteComponent_mat_option_6_Template, 1, 2, "mat-option", 4);
198
+ i0.ɵɵelementEnd();
199
+ i0.ɵɵelementStart(7, "mat-icon", 5);
200
+ i0.ɵɵtext(8, "spellcheck");
201
+ i0.ɵɵelementEnd()();
202
+ i0.ɵɵelementStart(9, "section", 6);
203
+ i0.ɵɵtemplate(10, InfoAutoCompleteComponent_mat_progress_bar_10_Template, 1, 0, "mat-progress-bar", 7);
204
+ i0.ɵɵelementEnd();
205
+ } if (rf & 2) {
206
+ const _r1 = i0.ɵɵreference(5);
207
+ i0.ɵɵadvance(1);
208
+ i0.ɵɵproperty("ngModel", ctx.selectedValue)("placeholder", i0.ɵɵpipeBind1(3, 8, ctx.placeholder))("formControl", ctx.control)("matAutocomplete", _r1)("required", ctx.required);
209
+ i0.ɵɵadvance(3);
210
+ i0.ɵɵproperty("displayWith", ctx.displayFn);
211
+ i0.ɵɵadvance(2);
212
+ i0.ɵɵproperty("ngForOf", ctx.options);
213
+ i0.ɵɵadvance(4);
214
+ i0.ɵɵproperty("ngIf", ctx.loading);
215
+ } }, dependencies: [i2.NgForOf, i2.NgIf, i3.DefaultValueAccessor, i3.NgControlStatus, i3.RequiredValidator, i3.FormControlDirective, i4.MatIcon, i5.MatFormField, i5.MatSuffix, i6.MatInput, i7.MatOption, i8.MatProgressBar, i9.MatAutocomplete, i9.MatAutocompleteTrigger, i10.InfoTranslatePipe], styles: ["[_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}[_nghost-%COMP%] mat-option[_ngcontent-%COMP%] small[_ngcontent-%COMP%]{margin-left:10px;font-style:italic}"] });
216
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InfoAutoCompleteComponent, [{
217
+ type: Component,
218
+ args: [{ selector: 'info-autocomplete', providers: [{
219
+ provide: NG_VALUE_ACCESSOR,
220
+ useExisting: forwardRef((() => InfoAutoCompleteComponent)),
221
+ multi: true
222
+ }], template: "<mat-form-field>\r\n <input matInput type=\"text\" [(ngModel)]=\"selectedValue\" [placeholder]=\"placeholder | translate\" [formControl]=\"control\" [matAutocomplete]=\"auto\" \r\n [required]=\"required\" (blur)=\"onBlur($event.target.value)\" (focus)=\"onFocus($event.target.value)\" #inputAuto>\r\n\r\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n <mat-option *ngFor=\"let option of options\" [value]=\"option\" (onSelectionChange)=\"writeValue(option.Id)\" [innerHTML]=\"option.Nome\" >\r\n </mat-option>\r\n </mat-autocomplete>\r\n \r\n <mat-icon matSuffix style=\"color: #aaa\">spellcheck</mat-icon>\r\n</mat-form-field>\r\n\r\n<section class=\"select-loading\">\r\n <mat-progress-bar color=\"primary\" mode=\"indeterminate\" *ngIf=\"loading\"></mat-progress-bar>\r\n</section>", styles: [":host .select-loading{position:relative;bottom:15px;opacity:.3;height:1px}:host .select-loading .mat-progress-bar{height:1px;margin:0}:host mat-option small{margin-left:10px;font-style:italic}\n"] }]
223
+ }], function () { return [{ type: i1.InfoDataService }]; }, { placeholder: [{
224
+ type: Input
225
+ }], name: [{
226
+ type: Input
227
+ }], required: [{
228
+ type: Input
229
+ }], selectfirst: [{
230
+ type: Input
231
+ }], disablednoregisters: [{
232
+ type: Input
233
+ }], getdataonchange: [{
234
+ type: Input
235
+ }], getdataonchangetime: [{
236
+ type: Input
237
+ }], api: [{
238
+ type: Input
239
+ }], method: [{
240
+ type: Input
241
+ }], maxlist: [{
242
+ type: Input
243
+ }], startwith: [{
244
+ type: Input
245
+ }], minchar: [{
246
+ type: Input
247
+ }], onselecteditem: [{
248
+ type: Output
249
+ }], loading: [{
250
+ type: Input
251
+ }], params: [{
252
+ type: Input
253
+ }], disabled: [{
254
+ type: Input
255
+ }], data: [{
256
+ type: Input
257
+ }] }); })();
258
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/autocomplete/autocomplete.component.ts","../../../../../projects/info-library/src/controls/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, forwardRef, Output, EventEmitter } from \"@angular/core\";\r\nimport { UntypedFormControl, ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { debounceTime, switchMap, distinctUntilChanged } from 'rxjs/operators';\r\nimport { InfoDataService } from \"../../service/data.service\";\r\nimport { Observable } from \"rxjs\";\r\nimport { InfoDataAccessModel } from '../../model';\r\n\r\n@Component({\r\n    selector: 'info-autocomplete',\r\n    templateUrl: 'autocomplete.component.html',\r\n    styleUrls: ['./autocomplete.component.scss'],\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => InfoAutoCompleteComponent),\r\n        multi: true\r\n    }]\r\n})\r\nexport class InfoAutoCompleteComponent implements OnInit, ControlValueAccessor {\r\n    control = new UntypedFormControl();\r\n    \r\n    @Input() placeholder = '';\r\n    @Input() name = '';\r\n    @Input() required = false;\r\n    @Input() selectfirst = false;\r\n    @Input() disablednoregisters = false;\r\n    @Input() getdataonchange = false;\r\n    @Input() getdataonchangetime = 500;\r\n    @Input() api: any = null;\r\n    @Input() method = 'getchavevalor';\r\n    @Input() maxlist = 10;\r\n    @Input() startwith = false;\r\n    @Input() minchar = 1;\r\n\r\n    @Output() onselecteditem = new EventEmitter();\r\n\r\n    options: any[];\r\n    selectedValue: any = null;\r\n\r\n    onChange: any;\r\n    onTouched: any;\r\n    \r\n    initialized = false;\r\n\r\n    _loading: boolean = false;\r\n    @Input()\r\n    get loading(){\r\n        return this._loading;\r\n    }\r\n\r\n    set loading(value){\r\n        this._loading = value;\r\n        \r\n        if (this._disabled == null)\r\n            this._disabled = false;\r\n\r\n        else if (this._disabled.toString() == '')\r\n            this._disabled = true;\r\n\r\n        if (this._disabled == false)\r\n            this.setDisabledState(this.loading);\r\n    }\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().subscribe(a => { this.data = a.data; this.loading = false; });\r\n    }\r\n    \r\n    _disabled: boolean = null;\r\n    @Input()\r\n    set disabled(value: boolean) {         \r\n        if (this._disabled == null)\r\n            this._disabled = value;\r\n\r\n        if (value)\r\n            this.control.disable();\r\n        else\r\n            this.control.enable();\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.getdataonchange)\r\n            return;\r\n\r\n        setTimeout(() => {\r\n            if (this.selectedValue != null)\r\n                if ((this._data == null || (this._data != null && this._data.length == 0)) && !this.loading) {\r\n                    this.writeValue(null);\r\n                    this.selectedValue = null;\r\n                } else\r\n                    this.writeValue(this.selectedValue.Id == null ? this.selectedValue : this.selectedValue.Id);\r\n                    \r\n            else if (this.selectfirst && this.data != null && this.data.length > 0)\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        }, 1000);\r\n    }\r\n\r\n    constructor(private _dataAcess: InfoDataService) { }\r\n\r\n    ngOnInit() {\r\n        if (this.minchar == null || this.minchar < 0) this.minchar = 1;\r\n        this.name = this.placeholder.replace(/ /g, '') + Math.floor(Math.random() * 1000).toString();\r\n\r\n        if (!this.getdataonchange) {\r\n            this.getData().subscribe(a => { this.data = a.data; this.loading = false; });\r\n            this.control.valueChanges.subscribe(value => { this.options = this.filter(value)});\r\n        } else {\r\n            this.control.valueChanges.pipe(\r\n                debounceTime(this.getdataonchangetime), \r\n                distinctUntilChanged(),\r\n                switchMap(value => this.getData(value))\r\n            ).subscribe(a => this.data = this.options = a.data);\r\n        }\r\n    }\r\n\r\n    filter(value: any): any[] {\r\n        if (value == null || value.length < this.minchar) return [];\r\n        let filterValue = value.Nome == null ? value.toString().toLowerCase() : value.Nome;\r\n\r\n        if (this.startwith)\r\n            return this.data.filter(option => option.Nome.toLowerCase().indexOf(filterValue) === 0 || (option.Aux == null ? \"\" : option.Aux.toLowerCase() == filterValue)).slice(0, this.maxlist);\r\n        else\r\n            return this.data.filter(option => option.Nome.toLowerCase().indexOf(filterValue) > -1 || (option.Aux == null ? \"\" : option.Aux.toLowerCase().indexOf(filterValue) > -1)).slice(0, this.maxlist);\r\n    }\r\n\r\n    getData(value: any = null): Observable<any> {\r\n        this.initialized = true;\r\n\r\n        if (this.api == null || this.api == '')\r\n            return new Observable<InfoDataAccessModel>();\r\n\r\n        this.loading = !this.getdataonchange;\r\n        this.data = [];\r\n        let parameters = this.params || '';\r\n\r\n        if (this.getdataonchange) {\r\n            if (value == null || value == '')\r\n                return new Observable<InfoDataAccessModel>();\r\n\r\n            if (parameters != null && parameters != '')\r\n                parameters += '&';\r\n\r\n            parameters += `nome=${value.Nome == null ? value.toString().toLowerCase() : value.Nome}&take=${this.maxlist}`;\r\n\r\n            let model = parameters.split(\"&\").map(c => ({ [c.split(\"=\")[0].charAt(0).toUpperCase() + c.split(\"=\")[0].substring(1)]: c.split(\"=\")[1] })).reduce((a,b) => ({...a, ...b}));\r\n            return this._dataAcess.post(this.api, model, this.method);\r\n        }\r\n\r\n        return this._dataAcess.get(this.api, this.method, parameters);\r\n    }\r\n\r\n    onBlur(value) {\r\n        setTimeout(() => {\r\n            if (this.selectedValue != null && this.selectedValue.Id != null)\r\n                return;\r\n\r\n            if (!value && this.selectedValue != null && this.selectedValue.trim() == '')\r\n                this.writeValue(null);\r\n            else {\r\n                let first = this.filter(value);\r\n                if (first != null && first.length > 0)\r\n                    this.writeValue(first[0].Id);\r\n                else\r\n                    this.writeValue(null);\r\n            } \r\n        }, 300);\r\n    }\r\n\r\n    onFocus(value) {\r\n        if (this.minchar != null && this.minchar == 0 && (value == null || value == ''))\r\n            setTimeout(() => { this.control.setValue(''); }, 200);\r\n    }\r\n\r\n    displayFn(model): string {\r\n        if (model == null || model.Nome == null)\r\n            return '';\r\n\r\n        let indexSmall = model.Nome.indexOf('<small');\r\n        return indexSmall > -1 ? model.Nome.substring(0, indexSmall).trim() : model.Nome;\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        let obj = this.data.find(r => r.Id == value);\r\n        this.control.setValue(obj);\r\n\r\n        if (value != null && obj == null)\r\n            this.selectedValue = value;\r\n\r\n        if (this.onChange != null)\r\n            this.onChange(value);\r\n\r\n        if (this.onselecteditem != null)\r\n            this.onselecteditem.emit(this.data == null ? null : this.data.find(r => r.Id == value));\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    <input matInput type=\"text\" [(ngModel)]=\"selectedValue\" [placeholder]=\"placeholder | translate\" [formControl]=\"control\" [matAutocomplete]=\"auto\" \r\n           [required]=\"required\" (blur)=\"onBlur($event.target.value)\" (focus)=\"onFocus($event.target.value)\" #inputAuto>\r\n\r\n    <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n        <mat-option *ngFor=\"let option of options\" [value]=\"option\" (onSelectionChange)=\"writeValue(option.Id)\" [innerHTML]=\"option.Nome\" >\r\n        </mat-option>\r\n    </mat-autocomplete>\r\n    \r\n    <mat-icon matSuffix style=\"color: #aaa\">spellcheck</mat-icon>\r\n</mat-form-field>\r\n\r\n<section class=\"select-loading\">\r\n    <mat-progress-bar color=\"primary\" mode=\"indeterminate\" *ngIf=\"loading\"></mat-progress-bar>\r\n</section>"]}
@@ -0,0 +1,298 @@
1
+ import { Component, Input } from "@angular/core";
2
+ import { InfoDataService } from "../../service/data.service";
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../service/data.service";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@angular/forms";
7
+ import * as i4 from "@angular/material/icon";
8
+ import * as i5 from "@angular/material/form-field";
9
+ import * as i6 from "@angular/material/input";
10
+ import * as i7 from "@angular/material/list";
11
+ import * as i8 from "../../pipe/translate.pipe";
12
+ function InfoBigCheckboxComponent_mat_list_option_1_Template(rf, ctx) { if (rf & 1) {
13
+ const _r5 = i0.ɵɵgetCurrentView();
14
+ i0.ɵɵelementStart(0, "mat-list-option", 5);
15
+ i0.ɵɵlistener("click", function InfoBigCheckboxComponent_mat_list_option_1_Template_mat_list_option_click_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.selectAll()); });
16
+ i0.ɵɵelementStart(1, "label");
17
+ i0.ɵɵtext(2);
18
+ i0.ɵɵpipe(3, "translate");
19
+ i0.ɵɵelementEnd()();
20
+ } if (rf & 2) {
21
+ const ctx_r0 = i0.ɵɵnextContext();
22
+ i0.ɵɵproperty("selected", ctx_r0.getModel().length == 0)("disabled", ctx_r0.readonly);
23
+ i0.ɵɵadvance(2);
24
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(3, 3, ctx_r0.labelselectall));
25
+ } }
26
+ function InfoBigCheckboxComponent_mat_list_option_2_div_1_Template(rf, ctx) { if (rf & 1) {
27
+ i0.ɵɵelement(0, "div", 8);
28
+ } if (rf & 2) {
29
+ const item_r6 = i0.ɵɵnextContext().$implicit;
30
+ i0.ɵɵproperty("innerHTML", item_r6.Nome, i0.ɵɵsanitizeHtml);
31
+ } }
32
+ function InfoBigCheckboxComponent_mat_list_option_2_div_2_Template(rf, ctx) { if (rf & 1) {
33
+ i0.ɵɵelement(0, "div", 8);
34
+ } if (rf & 2) {
35
+ const item_r6 = i0.ɵɵnextContext().$implicit;
36
+ i0.ɵɵproperty("innerHTML", item_r6.Descricao, i0.ɵɵsanitizeHtml);
37
+ } }
38
+ const _c0 = function (a0) { return { "silver": a0 }; };
39
+ function InfoBigCheckboxComponent_mat_list_option_2_Template(rf, ctx) { if (rf & 1) {
40
+ const _r13 = i0.ɵɵgetCurrentView();
41
+ i0.ɵɵelementStart(0, "mat-list-option", 6);
42
+ i0.ɵɵlistener("click", function InfoBigCheckboxComponent_mat_list_option_2_Template_mat_list_option_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r13); const item_r6 = restoredCtx.$implicit; return i0.ɵɵresetView(item_r6.Selecionado = !item_r6.Selecionado); });
43
+ i0.ɵɵtemplate(1, InfoBigCheckboxComponent_mat_list_option_2_div_1_Template, 1, 1, "div", 7);
44
+ i0.ɵɵtemplate(2, InfoBigCheckboxComponent_mat_list_option_2_div_2_Template, 1, 1, "div", 7);
45
+ i0.ɵɵelementEnd();
46
+ } if (rf & 2) {
47
+ const item_r6 = ctx.$implicit;
48
+ const i_r7 = ctx.index;
49
+ const ctx_r1 = i0.ɵɵnextContext();
50
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(5, _c0, i_r7 % 2 == 1))("selected", item_r6.Selecionado)("disabled", ctx_r1.readonly);
51
+ i0.ɵɵadvance(1);
52
+ i0.ɵɵproperty("ngIf", item_r6.Descricao == null);
53
+ i0.ɵɵadvance(1);
54
+ i0.ɵɵproperty("ngIf", item_r6.Descricao != null);
55
+ } }
56
+ function InfoBigCheckboxComponent_ng_container_3_mat_list_item_10_div_1_Template(rf, ctx) { if (rf & 1) {
57
+ i0.ɵɵelement(0, "div", 8);
58
+ } if (rf & 2) {
59
+ const item_r15 = i0.ɵɵnextContext().$implicit;
60
+ i0.ɵɵproperty("innerHTML", item_r15.Nome, i0.ɵɵsanitizeHtml);
61
+ } }
62
+ function InfoBigCheckboxComponent_ng_container_3_mat_list_item_10_div_2_Template(rf, ctx) { if (rf & 1) {
63
+ i0.ɵɵelement(0, "div", 8);
64
+ } if (rf & 2) {
65
+ const item_r15 = i0.ɵɵnextContext().$implicit;
66
+ i0.ɵɵproperty("innerHTML", item_r15.Descricao, i0.ɵɵsanitizeHtml);
67
+ } }
68
+ function InfoBigCheckboxComponent_ng_container_3_mat_list_item_10_Template(rf, ctx) { if (rf & 1) {
69
+ const _r22 = i0.ɵɵgetCurrentView();
70
+ i0.ɵɵelementStart(0, "mat-list-item", 15);
71
+ i0.ɵɵlistener("click", function InfoBigCheckboxComponent_ng_container_3_mat_list_item_10_Template_mat_list_item_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r22); const item_r15 = restoredCtx.$implicit; const ctx_r21 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r21.add(item_r15)); });
72
+ i0.ɵɵtemplate(1, InfoBigCheckboxComponent_ng_container_3_mat_list_item_10_div_1_Template, 1, 1, "div", 7);
73
+ i0.ɵɵtemplate(2, InfoBigCheckboxComponent_ng_container_3_mat_list_item_10_div_2_Template, 1, 1, "div", 7);
74
+ i0.ɵɵelementStart(3, "mat-icon");
75
+ i0.ɵɵtext(4, "add_circle_outline");
76
+ i0.ɵɵelementEnd()();
77
+ } if (rf & 2) {
78
+ const item_r15 = ctx.$implicit;
79
+ const i_r16 = ctx.index;
80
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c0, i_r16 % 2 == 0));
81
+ i0.ɵɵadvance(1);
82
+ i0.ɵɵproperty("ngIf", item_r15.Descricao == null);
83
+ i0.ɵɵadvance(1);
84
+ i0.ɵɵproperty("ngIf", item_r15.Descricao != null);
85
+ } }
86
+ function InfoBigCheckboxComponent_ng_container_3_Template(rf, ctx) { if (rf & 1) {
87
+ const _r24 = i0.ɵɵgetCurrentView();
88
+ i0.ɵɵelementContainerStart(0);
89
+ i0.ɵɵelementStart(1, "mat-form-field", 9)(2, "input", 10);
90
+ i0.ɵɵlistener("ngModelChange", function InfoBigCheckboxComponent_ng_container_3_Template_input_ngModelChange_2_listener($event) { i0.ɵɵrestoreView(_r24); const ctx_r23 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r23.value = $event); });
91
+ i0.ɵɵpipe(3, "translate");
92
+ i0.ɵɵelementEnd();
93
+ i0.ɵɵelementStart(4, "mat-icon", 11);
94
+ i0.ɵɵtext(5, "search");
95
+ i0.ɵɵelementEnd();
96
+ i0.ɵɵelementStart(6, "mat-hint", 12);
97
+ i0.ɵɵtext(7);
98
+ i0.ɵɵpipe(8, "translate");
99
+ i0.ɵɵelementEnd()();
100
+ i0.ɵɵelementStart(9, "mat-list", 13);
101
+ i0.ɵɵtemplate(10, InfoBigCheckboxComponent_ng_container_3_mat_list_item_10_Template, 5, 5, "mat-list-item", 14);
102
+ i0.ɵɵelementEnd();
103
+ i0.ɵɵelementContainerEnd();
104
+ } if (rf & 2) {
105
+ const ctx_r2 = i0.ɵɵnextContext();
106
+ i0.ɵɵadvance(2);
107
+ i0.ɵɵpropertyInterpolate("placeholder", i0.ɵɵpipeBind1(3, 5, ctx_r2.message));
108
+ i0.ɵɵproperty("name", ctx_r2.name)("ngModel", ctx_r2.value);
109
+ i0.ɵɵadvance(5);
110
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(8, 7, ctx_r2.submessage));
111
+ i0.ɵɵadvance(3);
112
+ i0.ɵɵproperty("ngForOf", ctx_r2.getFilteredData());
113
+ } }
114
+ function InfoBigCheckboxComponent_div_4_Template(rf, ctx) { if (rf & 1) {
115
+ i0.ɵɵelementStart(0, "div", 16)(1, "mat-icon");
116
+ i0.ɵɵtext(2, "info_outline");
117
+ i0.ɵɵelementEnd();
118
+ i0.ɵɵtext(3);
119
+ i0.ɵɵpipe(4, "translate");
120
+ i0.ɵɵelementEnd();
121
+ } if (rf & 2) {
122
+ i0.ɵɵadvance(3);
123
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(4, 1, "NenhumItemEncontrado"), "\n");
124
+ } }
125
+ export class InfoBigCheckboxComponent {
126
+ constructor(_dataService) {
127
+ this._dataService = _dataService;
128
+ this.readonly = false;
129
+ this.preload = true;
130
+ this.enabledcheckall = true;
131
+ this.labelselectall = 'Todos';
132
+ this.labelsearch = 'Buscar';
133
+ this.minchar = 0;
134
+ this.max = 20;
135
+ this.submessage = '';
136
+ this.value = '';
137
+ this.api = null;
138
+ this.method = null;
139
+ this.model = [];
140
+ this.data = [];
141
+ this.aux = null;
142
+ this._params = null;
143
+ this._paramsmodel = null;
144
+ this.loading = false;
145
+ this.name = '';
146
+ }
147
+ get params() {
148
+ return this._params;
149
+ }
150
+ set params(value) {
151
+ this._params = value;
152
+ this.getData();
153
+ }
154
+ get paramsmodel() {
155
+ return this._paramsmodel;
156
+ }
157
+ set paramsmodel(value) {
158
+ this._paramsmodel = value;
159
+ this.getData();
160
+ }
161
+ ngOnInit() {
162
+ this.submessage = 'Serão exibidos somente os ' + this.max + ' primeiros itens encontrados';
163
+ this.name = 'input-search-' + Math.floor(Math.random() * 1000).toString();
164
+ this.getData();
165
+ }
166
+ getData() {
167
+ if (this.preload) {
168
+ if (this.params == null && this.paramsmodel != null)
169
+ this.loadByParamModel(this.paramsmodel);
170
+ else
171
+ this.load(this.params);
172
+ }
173
+ }
174
+ load(param = null) {
175
+ if (this.api == null)
176
+ return;
177
+ this.loading = true;
178
+ this.data = [];
179
+ if (this.model == null)
180
+ this.model = [];
181
+ this._dataService
182
+ .get(this.api, this.method, param).subscribe(r => {
183
+ if (r.success)
184
+ this.data = r.data;
185
+ this.loading = false;
186
+ });
187
+ }
188
+ loadByParamModel(paramModel = null) {
189
+ if (this.api == null)
190
+ return;
191
+ this.loading = true;
192
+ this.data = [];
193
+ if (this.model == null)
194
+ this.model = [];
195
+ this._dataService.post(this.api, paramModel, this.method).subscribe(r => {
196
+ if (r.success)
197
+ this.data = r.data;
198
+ this.loading = false;
199
+ });
200
+ }
201
+ getModel() {
202
+ if (this.model == null || this.model.length == 0)
203
+ return [];
204
+ return this.model.filter(m => this.aux == null || m.Aux == this.aux);
205
+ }
206
+ getFilteredData() {
207
+ if (this.data.length == 0 || this.value.length < this.minchar)
208
+ return [];
209
+ return this.data.filter(d => (this.aux == null || this.aux == d.Aux) &&
210
+ this.model.filter(m => m.Id == d.Id).length == 0 &&
211
+ d.Nome.toLowerCase().indexOf(this.value.toLowerCase()) > -1).slice(0, this.max);
212
+ }
213
+ existData() {
214
+ return (this.data != null &&
215
+ this.data.length > 0 &&
216
+ this.data.filter(d => this.aux == null || this.aux == d.Aux).length > 0);
217
+ }
218
+ add(item) {
219
+ if (this.model == null)
220
+ this.model = [];
221
+ this.model.push({
222
+ Id: item.Id,
223
+ Nome: item.Nome,
224
+ Aux: (this.aux == null ? item.Aux : this.aux),
225
+ Descricao: item.Descricao == null ? item.Nome : item.Descricao,
226
+ Selecionado: true
227
+ });
228
+ }
229
+ selectAll() {
230
+ let removeItems = new Array();
231
+ if (this.aux != null) {
232
+ for (var i = 0; i < this.model.length; i++) {
233
+ if (this.model[i].Aux == this.aux)
234
+ removeItems.push(i);
235
+ }
236
+ }
237
+ removeItems.forEach(index => {
238
+ this.model.splice(index, 1);
239
+ });
240
+ }
241
+ }
242
+ /** @nocollapse */ InfoBigCheckboxComponent.ɵfac = function InfoBigCheckboxComponent_Factory(t) { return new (t || InfoBigCheckboxComponent)(i0.ɵɵdirectiveInject(i1.InfoDataService)); };
243
+ /** @nocollapse */ InfoBigCheckboxComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: InfoBigCheckboxComponent, selectors: [["info-big-checkbox"]], inputs: { readonly: "readonly", preload: "preload", enabledcheckall: "enabledcheckall", labelselectall: "labelselectall", labelsearch: "labelsearch", minchar: "minchar", max: "max", message: "message", submessage: "submessage", value: "value", api: "api", method: "method", model: "model", data: "data", aux: "aux", params: "params", paramsmodel: "paramsmodel" }, decls: 5, vars: 4, consts: [[1, "col-md-12", "mb-3"], ["class", "silver", 3, "selected", "disabled", "click", 4, "ngIf"], [3, "ngClass", "selected", "disabled", "click", 4, "ngFor", "ngForOf"], [4, "ngIf"], ["class", "col-md-12 none-data", 4, "ngIf"], [1, "silver", 3, "selected", "disabled", "click"], [3, "ngClass", "selected", "disabled", "click"], [3, "innerHTML", 4, "ngIf"], [3, "innerHTML"], [1, "col-md-12", "mb-4", "input-search"], ["matInput", "", "autocomplete", "false", "autocomplete", "off", 3, "placeholder", "name", "ngModel", "ngModelChange"], ["matSuffix", ""], [1, "mt-2"], [1, "col-md-12"], [3, "ngClass", "click", 4, "ngFor", "ngForOf"], [3, "ngClass", "click"], [1, "col-md-12", "none-data"]], template: function InfoBigCheckboxComponent_Template(rf, ctx) { if (rf & 1) {
244
+ i0.ɵɵelementStart(0, "mat-selection-list", 0);
245
+ i0.ɵɵtemplate(1, InfoBigCheckboxComponent_mat_list_option_1_Template, 4, 5, "mat-list-option", 1);
246
+ i0.ɵɵtemplate(2, InfoBigCheckboxComponent_mat_list_option_2_Template, 3, 7, "mat-list-option", 2);
247
+ i0.ɵɵelementEnd();
248
+ i0.ɵɵtemplate(3, InfoBigCheckboxComponent_ng_container_3_Template, 11, 9, "ng-container", 3);
249
+ i0.ɵɵtemplate(4, InfoBigCheckboxComponent_div_4_Template, 5, 3, "div", 4);
250
+ } if (rf & 2) {
251
+ i0.ɵɵadvance(1);
252
+ i0.ɵɵproperty("ngIf", ctx.enabledcheckall);
253
+ i0.ɵɵadvance(1);
254
+ i0.ɵɵproperty("ngForOf", ctx.getModel());
255
+ i0.ɵɵadvance(1);
256
+ i0.ɵɵproperty("ngIf", ctx.existData());
257
+ i0.ɵɵadvance(1);
258
+ i0.ɵɵproperty("ngIf", !ctx.existData());
259
+ } }, dependencies: [i2.NgClass, i2.NgForOf, i2.NgIf, i3.DefaultValueAccessor, i3.NgControlStatus, i3.NgModel, i4.MatIcon, i5.MatFormField, i5.MatHint, i5.MatSuffix, i6.MatInput, i7.MatList, i7.MatListItem, i7.MatSelectionList, i7.MatListOption, i8.InfoTranslatePipe], styles: ["[_nghost-%COMP%] mat-list-option[_ngcontent-%COMP%]{font-size:14px;cursor:pointer;padding:0!important;font-family:Open Sans,sans-serif}[_nghost-%COMP%] mat-list-option[_ngcontent-%COMP%] label[_ngcontent-%COMP%]{padding-left:5px}[_nghost-%COMP%] mat-list-item[_ngcontent-%COMP%]{height:38px;font-size:14px;cursor:pointer;padding:0 10px 0 20px}[_nghost-%COMP%] mat-list-item[_ngcontent-%COMP%]:hover{background:rgba(0,0,0,.04)}[_nghost-%COMP%] mat-list-item[_ngcontent-%COMP%] mat-icon[_ngcontent-%COMP%]{position:absolute;right:3px;top:8px}[_nghost-%COMP%] mat-list-option.silver[_ngcontent-%COMP%], [_nghost-%COMP%] mat-list-item.silver[_ngcontent-%COMP%]{background:#f5f5f5}[_nghost-%COMP%] mat-list-option[_ngcontent-%COMP%]:hover, [_nghost-%COMP%] mat-list-item[_ngcontent-%COMP%]:hover{background:#eee}[_nghost-%COMP%] mat-list-item-content[_ngcontent-%COMP%]{padding-left:0!important}[_nghost-%COMP%] .none-data[_ngcontent-%COMP%]{font-size:14px;color:#666;background:#f5f5f5;text-align:center;padding:5px 0}[_nghost-%COMP%] .none-data[_ngcontent-%COMP%] mat-icon[_ngcontent-%COMP%]{margin-right:5px;font-size:18px;top:4px;left:5px}"] });
260
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InfoBigCheckboxComponent, [{
261
+ type: Component,
262
+ args: [{ selector: 'info-big-checkbox', template: "<mat-selection-list class=\"col-md-12 mb-3\">\r\n <mat-list-option class=\"silver\" (click)=\"selectAll()\" [selected]=\"getModel().length == 0\" [disabled]=\"readonly\" *ngIf=\"enabledcheckall\">\r\n <label>{{ labelselectall | translate }}</label>\r\n </mat-list-option>\r\n\r\n <mat-list-option *ngFor=\"let item of getModel(); let i = index\" [ngClass]=\"{ 'silver': i % 2 == 1 }\" [selected]=\"item.Selecionado\" (click)=\"item.Selecionado = !item.Selecionado\" [disabled]=\"readonly\">\r\n <div *ngIf=\"item.Descricao == null\" [innerHTML]=\"item.Nome\"></div>\r\n <div *ngIf=\"item.Descricao != null\" [innerHTML]=\"item.Descricao\"></div>\r\n </mat-list-option>\r\n</mat-selection-list>\r\n \r\n<ng-container *ngIf=\"existData()\" >\r\n <mat-form-field class=\"col-md-12 mb-4 input-search\">\r\n <input matInput placeholder=\"{{ message | translate}}\" [name]=\"name\" autocomplete=\"false\" [(ngModel)]=\"value\" autocomplete=\"off\" >\r\n <mat-icon matSuffix >search</mat-icon>\r\n <mat-hint class=\"mt-2\">{{ submessage | translate}}</mat-hint>\r\n </mat-form-field>\r\n \r\n <mat-list class=\"col-md-12\" >\r\n <mat-list-item *ngFor=\"let item of getFilteredData(); let i = index\" [ngClass]=\"{ 'silver': i % 2 == 0 }\" (click)=\"add(item)\">\r\n <div *ngIf=\"item.Descricao == null\" [innerHTML]=\"item.Nome\"></div>\r\n <div *ngIf=\"item.Descricao != null\" [innerHTML]=\"item.Descricao\"></div>\r\n <mat-icon>add_circle_outline</mat-icon>\r\n </mat-list-item>\r\n </mat-list>\r\n</ng-container>\r\n\r\n<div class=\"col-md-12 none-data\" *ngIf=\"!existData()\" >\r\n <mat-icon>info_outline</mat-icon> {{ 'NenhumItemEncontrado' | translate }}\r\n</div>", styles: [":host mat-list-option{font-size:14px;cursor:pointer;padding:0!important;font-family:Open Sans,sans-serif}:host mat-list-option label{padding-left:5px}:host mat-list-item{height:38px;font-size:14px;cursor:pointer;padding:0 10px 0 20px}:host mat-list-item:hover{background:rgba(0,0,0,.04)}:host mat-list-item mat-icon{position:absolute;right:3px;top:8px}:host mat-list-option.silver,:host mat-list-item.silver{background:#f5f5f5}:host mat-list-option:hover,:host mat-list-item:hover{background:#eee}:host mat-list-item-content{padding-left:0!important}:host .none-data{font-size:14px;color:#666;background:#f5f5f5;text-align:center;padding:5px 0}:host .none-data mat-icon{margin-right:5px;font-size:18px;top:4px;left:5px}\n"] }]
263
+ }], function () { return [{ type: i1.InfoDataService }]; }, { readonly: [{
264
+ type: Input
265
+ }], preload: [{
266
+ type: Input
267
+ }], enabledcheckall: [{
268
+ type: Input
269
+ }], labelselectall: [{
270
+ type: Input
271
+ }], labelsearch: [{
272
+ type: Input
273
+ }], minchar: [{
274
+ type: Input
275
+ }], max: [{
276
+ type: Input
277
+ }], message: [{
278
+ type: Input
279
+ }], submessage: [{
280
+ type: Input
281
+ }], value: [{
282
+ type: Input
283
+ }], api: [{
284
+ type: Input
285
+ }], method: [{
286
+ type: Input
287
+ }], model: [{
288
+ type: Input
289
+ }], data: [{
290
+ type: Input
291
+ }], aux: [{
292
+ type: Input
293
+ }], params: [{
294
+ type: Input
295
+ }], paramsmodel: [{
296
+ type: Input
297
+ }] }); })();
298
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"big-checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/info-library/src/controls/big-checkbox/big-checkbox.component.ts","../../../../../projects/info-library/src/controls/big-checkbox/big-checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from \"@angular/core\";\r\nimport { InfoDataService } from \"../../service/data.service\";\r\n\r\n@Component({\r\n    selector: 'info-big-checkbox',\r\n    templateUrl: 'big-checkbox.component.html',\r\n    styleUrls: ['big-checkbox.component.scss']\r\n})\r\nexport class InfoBigCheckboxComponent implements OnInit {\r\n\r\n    @Input() readonly: boolean = false;\r\n    @Input() preload: boolean = true;\r\n    @Input() enabledcheckall: boolean = true;\r\n    @Input() labelselectall: string = 'Todos';\r\n    @Input() labelsearch: string = 'Buscar';\r\n    @Input() minchar: number = 0;\r\n    @Input() max: number = 20;\r\n    @Input() message: string;\r\n    @Input() submessage: string = '';\r\n\r\n    @Input() value: string = '';\r\n    @Input() api: any = null;\r\n    @Input() method: string = null;\r\n\r\n    @Input() model: any = [];\r\n    @Input() data: any[] = [];\r\n    @Input() aux: string = null;\r\n\r\n    private _params: any = 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        this.getData();\r\n    }\r\n\r\n    private _paramsmodel: any = null;\r\n    @Input()\r\n    get paramsmodel(){\r\n        return this._paramsmodel;\r\n    }\r\n\r\n    set paramsmodel(value){\r\n        this._paramsmodel = value;\r\n        this.getData();\r\n    }\r\n\r\n    loading: boolean = false;\r\n    name: string = '';\r\n\r\n    constructor(private _dataService: InfoDataService) { }\r\n\r\n    ngOnInit(){\r\n        this.submessage = 'Serão exibidos somente os ' + this.max + ' primeiros itens encontrados';\r\n        this.name = 'input-search-' + Math.floor(Math.random() * 1000).toString();\r\n        this.getData();\r\n    }\r\n\r\n    getData() {\r\n        if (this.preload) {\r\n            if (this.params == null && this.paramsmodel != null)\r\n                this.loadByParamModel(this.paramsmodel);\r\n\r\n            else this.load(this.params);\r\n        }\r\n    }\r\n\r\n    load(param: any = null) {\r\n\r\n        if (this.api == null)\r\n            return;\r\n\r\n        this.loading = true;\r\n        this.data = [];\r\n        \r\n        if (this.model == null)\r\n            this.model = [];\r\n\r\n        this._dataService\r\n            .get(this.api, this.method, param).subscribe(r => {\r\n            if (r.success)\r\n                this.data = r.data;\r\n\r\n            this.loading = false;\r\n        });\r\n    }\r\n\r\n    loadByParamModel(paramModel: any = null) {\r\n        \r\n        if (this.api == null)\r\n            return;\r\n\r\n        this.loading = true;\r\n        this.data = [];\r\n        \r\n        if (this.model == null)\r\n            this.model = [];\r\n\r\n        this._dataService.post(this.api, paramModel, this.method).subscribe(r => {\r\n            if (r.success)\r\n                this.data = r.data;\r\n                \r\n            this.loading = false;\r\n        });\r\n    }\r\n\r\n    getModel(): any[]{\r\n\r\n        if (this.model == null || this.model.length == 0)\r\n            return [];\r\n\r\n        return this.model.filter(m => this.aux == null || m.Aux == this.aux);\r\n    }\r\n\r\n    getFilteredData(): any[]{\r\n\r\n        if (this.data.length == 0 || this.value.length < this.minchar)\r\n            return [];\r\n\r\n        return this.data.filter(d => \r\n            (this.aux == null || this.aux == d.Aux) &&\r\n            this.model.filter(m => m.Id == d.Id).length == 0 && \r\n            d.Nome.toLowerCase().indexOf(this.value.toLowerCase()) > -1\r\n\r\n        ).slice(0, this.max);\r\n    }\r\n\r\n    existData(): boolean{\r\n        return (this.data != null && \r\n                this.data.length > 0 && \r\n                this.data.filter(d => this.aux == null || this.aux == d.Aux).length > 0);\r\n    }\r\n\r\n    add(item: any){\r\n        \r\n        if (this.model == null)\r\n            this.model = [];\r\n\r\n        this.model.push({\r\n            Id: item.Id,\r\n            Nome: item.Nome,\r\n            Aux: (this.aux == null ? item.Aux : this.aux),\r\n            Descricao: item.Descricao == null ? item.Nome : item.Descricao,\r\n            Selecionado: true\r\n        });\r\n    }\r\n\r\n    selectAll(){\r\n\r\n        let removeItems = new Array();\r\n\r\n        if (this.aux != null) {\r\n            for (var i = 0; i < this.model.length; i++){\r\n                if (this.model[i].Aux == this.aux)\r\n                    removeItems.push(i);\r\n            }\r\n        }\r\n\r\n        removeItems.forEach(index => {\r\n            this.model.splice(index, 1);\r\n        });\r\n    }\r\n}","<mat-selection-list class=\"col-md-12 mb-3\">\r\n    <mat-list-option class=\"silver\" (click)=\"selectAll()\" [selected]=\"getModel().length == 0\" [disabled]=\"readonly\" *ngIf=\"enabledcheckall\">\r\n        <label>{{ labelselectall | translate }}</label>\r\n    </mat-list-option>\r\n\r\n    <mat-list-option *ngFor=\"let item of getModel(); let i = index\" [ngClass]=\"{ 'silver': i % 2 == 1 }\" [selected]=\"item.Selecionado\" (click)=\"item.Selecionado = !item.Selecionado\" [disabled]=\"readonly\">\r\n        <div *ngIf=\"item.Descricao == null\" [innerHTML]=\"item.Nome\"></div>\r\n        <div *ngIf=\"item.Descricao != null\" [innerHTML]=\"item.Descricao\"></div>\r\n    </mat-list-option>\r\n</mat-selection-list>\r\n    \r\n<ng-container *ngIf=\"existData()\" >\r\n    <mat-form-field class=\"col-md-12 mb-4 input-search\">\r\n        <input matInput placeholder=\"{{ message | translate}}\" [name]=\"name\" autocomplete=\"false\" [(ngModel)]=\"value\" autocomplete=\"off\" >\r\n        <mat-icon matSuffix >search</mat-icon>\r\n        <mat-hint class=\"mt-2\">{{ submessage | translate}}</mat-hint>\r\n    </mat-form-field>\r\n    \r\n    <mat-list class=\"col-md-12\" >\r\n        <mat-list-item *ngFor=\"let item of getFilteredData(); let i = index\" [ngClass]=\"{ 'silver': i % 2 == 0 }\" (click)=\"add(item)\">\r\n            <div *ngIf=\"item.Descricao == null\" [innerHTML]=\"item.Nome\"></div>\r\n            <div *ngIf=\"item.Descricao != null\" [innerHTML]=\"item.Descricao\"></div>\r\n            <mat-icon>add_circle_outline</mat-icon>\r\n        </mat-list-item>\r\n    </mat-list>\r\n</ng-container>\r\n\r\n<div class=\"col-md-12 none-data\" *ngIf=\"!existData()\" >\r\n    <mat-icon>info_outline</mat-icon> {{ 'NenhumItemEncontrado' | translate }}\r\n</div>"]}