appproject-components 0.0.1 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,531 @@
1
+ import { Component, Input, ViewChild } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { Subject, of } from 'rxjs';
4
+ import { BaseInputComponent } from '../baseInputComponent';
5
+ import { debounceTime, switchMap } from 'rxjs/operators';
6
+ import { ModelTreeviewComponent } from '../model-treeview/model-treeview.component';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/common/http";
9
+ import * as i2 from "@ionic/angular";
10
+ import * as i3 from "@angular/common";
11
+ export class InputPesquisaComponent extends BaseInputComponent {
12
+ constructor(httpClient, modalCtrl) {
13
+ super();
14
+ this.httpClient = httpClient;
15
+ this.modalCtrl = modalCtrl;
16
+ this.podePesquisar = true;
17
+ this.textoPesquisa = '';
18
+ this.selectElementVisivel = false;
19
+ this.listaPesquisa = [];
20
+ this.max = '30';
21
+ this.pesquisaSubject = new Subject();
22
+ this.filterFunction = null;
23
+ this.selectId = 'selectElement';
24
+ this.campoId = 'Id';
25
+ this.campoPaiId = 'PaiId';
26
+ this.campoDisplay = 'Descricao';
27
+ this.tipo = '';
28
+ //@ViewChild('selectElement', { read: ElementRef, static: true }) selectElement;
29
+ this.selectElement = null;
30
+ //parametros para chamada API
31
+ //endpoint para pesquisa por digitação
32
+ this.url = '';
33
+ this.urlItem = '';
34
+ //endpoint para montar a arvore, se estiver vazia será usado o campo 'url'
35
+ this.urlTree = '';
36
+ this.empresa = 0;
37
+ this.loadInit = false;
38
+ this.onChange = (data) => { };
39
+ this.onTouch = () => { };
40
+ this.disabled = false;
41
+ this.console = console;
42
+ this.modelChanged = new Subject();
43
+ this.modelChangeSubscription = this.modelChanged
44
+ .pipe(debounceTime(500))
45
+ .subscribe(data => {
46
+ this.carregaItemIdParaLista(data);
47
+ });
48
+ }
49
+ writeValue(value) {
50
+ //console.log('write value', value);
51
+ this.onChange(value);
52
+ this.data = value;
53
+ if (value == null || value == 0) {
54
+ this.writePesquisa('');
55
+ this.selectedItem = null;
56
+ }
57
+ else {
58
+ if (this.loadInit == true) {
59
+ this.loadInit = false;
60
+ this.modelChanged.next(value);
61
+ //this.carregaItemIdParaLista(value);
62
+ }
63
+ else {
64
+ //console.log(this.selectedItem);
65
+ if (!this.selectedItem || (this.selectedItem && this.selectedItem[this.campoId] != value)) {
66
+ console.log('Id diferente');
67
+ this.modelChanged.next(value);
68
+ //this.carregaItemIdParaLista(value);
69
+ }
70
+ }
71
+ }
72
+ }
73
+ registerOnChange(fn) {
74
+ this.onChange = fn;
75
+ }
76
+ registerOnTouched(fn) {
77
+ this.onTouch = fn;
78
+ }
79
+ setDisabledState(isDisabled) {
80
+ this.disabled = this.disabled;
81
+ }
82
+ onBlur(event) {
83
+ console.log('blur', event);
84
+ console.log(event.detail.relatedTarget);
85
+ if (event.detail.relatedTarget == null || event.detail.relatedTarget.id.indexOf(this.selectId + 'IonItem') == -1) {
86
+ console.log("true", event.detail.relatedTarget.id);
87
+ //pesquisar item na lista
88
+ if (!this.existeNaListaTexto(this.textoPesquisa, true)) {
89
+ this.limparClick();
90
+ }
91
+ this.dropDownPesquisa(0);
92
+ if (this.form) {
93
+ this.form.get(this.formControlName)?.markAsTouched();
94
+ }
95
+ }
96
+ }
97
+ ngOnInit() {
98
+ this.pesquisaSubject.pipe(switchMap((url) => {
99
+ this.console.log('subject url:', url);
100
+ if (!this.isEmpty(url))
101
+ return this.httpClient.get(url);
102
+ else
103
+ return of([]);
104
+ }))
105
+ .subscribe({
106
+ next: (result) => {
107
+ //this.listaPesquisa = result;
108
+ this.console.log('subject subscribe result:', result);
109
+ this.listaPesquisa = [];
110
+ if (result && result.length > 0) {
111
+ if (this.filterFunction) {
112
+ result = result.filter(this.filterFunction);
113
+ }
114
+ result.forEach((ent, index) => {
115
+ this.listaPesquisa.push({ ...ent, Index: index, Selected: false });
116
+ });
117
+ }
118
+ this.podePesquisar = true;
119
+ if (this.listaPesquisa.length > 0) {
120
+ this.dropDownPesquisa(this.listaPesquisa.length);
121
+ }
122
+ },
123
+ error: (error) => {
124
+ this.podePesquisar = true;
125
+ console.log('erro pesquisa', error);
126
+ }
127
+ });
128
+ }
129
+ writePesquisa(value) {
130
+ //console.log('write pesquisa', value);
131
+ this.textoPesquisa = value;
132
+ }
133
+ showPesquisa(e) {
134
+ //console.log('show pesquisa', e.keyCode);
135
+ var self = this;
136
+ if ((e.keyCode >= 48 && e.keyCode <= 57) ||
137
+ (e.keyCode >= 65 && e.keyCode <= 90) ||
138
+ (e.keyCode >= 96 && e.keyCode <= 105) ||
139
+ (e.keyCode == 8)) {
140
+ if (!self.podePesquisar) {
141
+ return;
142
+ }
143
+ let filtro = self.textoPesquisa;
144
+ if (filtro != null && filtro != '' && filtro.length >= 2) {
145
+ self.pesquisarEntidade(filtro);
146
+ }
147
+ else {
148
+ if (e.keyCode == 8 && !filtro) {
149
+ this.limparClick();
150
+ }
151
+ }
152
+ }
153
+ else {
154
+ if (e.keyCode == 40 || e.keyCode == 38) {
155
+ self.dropDownPesquisa(self.listaPesquisa.length);
156
+ if (self.selectElementVisivel == true) {
157
+ //let select = self.selectElement; //document.getElementById(self.TemplateSelect1Id());
158
+ //ion-list
159
+ //selecionado
160
+ //console.log(self.listaPesquisa);
161
+ let inc = e.keyCode == 40 ? 1 : -1;
162
+ let selected = self.listaPesquisa.find(s => s['Selected'] === true);
163
+ let cur = 0;
164
+ if (selected != null) {
165
+ cur = selected['Index'];
166
+ //desmarcar o atual
167
+ selected['Selected'] = false;
168
+ cur = cur + inc;
169
+ }
170
+ else {
171
+ cur = 0;
172
+ }
173
+ if (cur < 0) {
174
+ cur = self.listaPesquisa.length - 1;
175
+ }
176
+ else if (cur >= self.listaPesquisa.length) {
177
+ cur = 0;
178
+ }
179
+ let novoSelected = self.listaPesquisa.find(n => n['Index'] === cur);
180
+ if (novoSelected != null) {
181
+ novoSelected['Selected'] = true;
182
+ self.selectedItem = novoSelected;
183
+ self.textoPesquisa = novoSelected[self.campoDisplay];
184
+ }
185
+ /*
186
+ let select = document.getElementById(this.selectId) as any;
187
+ console.log('select Element', select)
188
+ if (select != null) {
189
+ let inc = e.keyCode == 40 ? 1 : -1;
190
+ let cur = select.selectedIndex;
191
+ if (cur == NaN) cur = -1;
192
+ select.selectedIndex = cur + inc;
193
+ if (select.selectedIndex >= 0 && select.selectedIndex < self.listaPesquisa.length) {
194
+ self.selectedItem = self.listaPesquisa[select.selectedIndex];
195
+ if (self.selectedItem != null) {
196
+ self.textoPesquisa = self.selectedItem[self.campoDisplay];
197
+ }
198
+ }
199
+ }
200
+ */
201
+ }
202
+ }
203
+ else if (e.keyCode == 13) {
204
+ console.log('enter key', e);
205
+ //self.selecionarComboClick(e);
206
+ self.selecionarComboClick(null);
207
+ //return false;
208
+ }
209
+ else if (e.keyCode == 27) {
210
+ //ESC
211
+ self.dropDownPesquisa(0);
212
+ }
213
+ }
214
+ }
215
+ highlight(texto) {
216
+ let index = texto.toLowerCase().indexOf(this.textoPesquisa.toLowerCase());
217
+ //console.log(index);
218
+ if (index >= 0) {
219
+ return texto.substring(0, index) + '<strong>' + texto.substring(index, index + this.textoPesquisa.length) + '</strong>' + texto.substring(index + this.textoPesquisa.length); //texto.replace(this.textoPesquisa, `<strong>${this.textoPesquisa}</strong>`);
220
+ }
221
+ else {
222
+ return texto;
223
+ }
224
+ }
225
+ selecionarComboClick(item) {
226
+ // console.log(item);
227
+ var self = this;
228
+ // console.log('combo click', self);
229
+ /*
230
+ let select = document.getElementById(this.selectId) as any;
231
+ if (select.selectedIndex >= 0) {
232
+ self.selectedItem = self.listaPesquisa[select.selectedIndex];
233
+ }
234
+ console.log('selected', this.selectedItem);
235
+ //self.selectedItem = this.listaPesquisa.find(i => i[this.campoId] == e);
236
+ if (self.selectedItem != null) {
237
+ self.textoPesquisa = self.selectedItem[self.campoDisplay];
238
+ self.writeValue(self.selectedItem[self.campoId]);
239
+ if (e != null) {
240
+ self.selectElementVisivel = false;
241
+ if (self.action != null) {
242
+ self.action(self.selectedItem(), e);
243
+ }
244
+ }
245
+ }
246
+ else {
247
+ self.selectElementVisivel = false;
248
+ }
249
+ */
250
+ // pesquisar selecionado
251
+ // console.log(this.listaPesquisa);
252
+ let selected = this.listaPesquisa.find(s => s['Selected'] === true);
253
+ // if (!selected) {
254
+ // console.log(this.campoId, item);
255
+ // selected = this.listaPesquisa.filter( s => s[this.campoId] == item[this.campoId]);
256
+ // }
257
+ //se o item form passado como parametro (click no ion-item)
258
+ if (item != null) {
259
+ if (selected != null) {
260
+ selected['Selected'] = false;
261
+ }
262
+ item['Selected'] = true;
263
+ selected = item;
264
+ }
265
+ if (selected != null) {
266
+ self.selectedItem = selected;
267
+ self.textoPesquisa = selected[self.campoDisplay];
268
+ self.writeValue(selected[self.campoId]);
269
+ self.selectElementVisivel = false;
270
+ console.log('action', self.change);
271
+ if (self.change != null) {
272
+ self.change(self.selectedItem);
273
+ }
274
+ }
275
+ else {
276
+ self.selectElementVisivel = false;
277
+ }
278
+ // this.listaPesquisa.forEach( pesquisa => {
279
+ // console.log(pesquisa, self.data);
280
+ // } );
281
+ // console.log(this.textoPesquisa);
282
+ }
283
+ selecionarComboChange(e) {
284
+ var self = this;
285
+ console.log('combo change', e);
286
+ self.selectedItem = this.listaPesquisa.find(i => i[this.campoId] == e);
287
+ if (self.selectedItem != null) {
288
+ self.writeValue(e);
289
+ self.textoPesquisa = self.selectedItem[self.campoDisplay];
290
+ if (e != null) {
291
+ self.selectElementVisivel = false;
292
+ if (self.change != null) {
293
+ self.change(self.selectedItem, e);
294
+ }
295
+ }
296
+ }
297
+ else {
298
+ self.selectElementVisivel = false;
299
+ }
300
+ }
301
+ dropDownPesquisa(length) {
302
+ var self = this;
303
+ if (self.listaPesquisa != null && self.listaPesquisa.length > 0) {
304
+ if (length == -1) {
305
+ length = self.listaPesquisa.length;
306
+ }
307
+ self.selectElementVisivel = length == 0 ? false : true;
308
+ //console.log(this.selectElement);
309
+ //this.selectElement.open();
310
+ /*
311
+ //let element = this.selectElement;
312
+ let element = document.getElementById(this.selectId);
313
+ console.log('dropDown', element);
314
+ (element as any).size = length + 1;
315
+ if (length == 0) {
316
+ self.selectElementVisivel = false;
317
+ } else {
318
+ self.selectElementVisivel = true;
319
+ }
320
+ */
321
+ }
322
+ }
323
+ pesquisarEntidade(filtro) {
324
+ let url = this.url.replace('<<FILTRO>>', filtro).replace('<<EMPRESA>>', this.empresa.toString());
325
+ console.log('pesquisarEntidade url', url);
326
+ this.podePesquisar = false;
327
+ this.pesquisaSubject.next(url);
328
+ }
329
+ pesquisarEntidadeOld(filtro) {
330
+ let url = this.url.replace('<<FILTRO>>', filtro).replace('<<EMPRESA>>', this.empresa.toString());
331
+ console.log('pesquisarEntidade url', url);
332
+ this.podePesquisar = false;
333
+ this.httpClient.get(url)
334
+ .subscribe({ next: (result) => {
335
+ //this.listaPesquisa = result;
336
+ if (this.filterFunction) {
337
+ result = result.filter(this.filterFunction);
338
+ }
339
+ this.listaPesquisa = [];
340
+ result.forEach((ent, index) => {
341
+ this.listaPesquisa.push({ ...ent, Index: index, Selected: false });
342
+ });
343
+ this.podePesquisar = true;
344
+ if (this.listaPesquisa.length > 0) {
345
+ this.dropDownPesquisa(this.listaPesquisa.length);
346
+ }
347
+ }, error: error => {
348
+ console.log('erro pesquisa', error);
349
+ this.podePesquisar = true;
350
+ } });
351
+ }
352
+ existeNaLista(id, setRegistro = false) {
353
+ if (this.listaPesquisa && this.listaPesquisa.length > 0) {
354
+ let existe = this.listaPesquisa.find(l => l[this.campoId] === id);
355
+ if (existe) {
356
+ if (setRegistro) {
357
+ this.selectedItem = existe;
358
+ this.selecionarComboClick(this.selectedItem);
359
+ }
360
+ return true;
361
+ }
362
+ else {
363
+ return false;
364
+ }
365
+ }
366
+ else {
367
+ return false;
368
+ }
369
+ }
370
+ existeNaListaTexto(texto, setRegistro = false) {
371
+ console.log("existe texto:", texto, this.campoDisplay, this.listaPesquisa);
372
+ if (this.listaPesquisa && this.listaPesquisa.length > 0) {
373
+ let existe = this.listaPesquisa.find(l => l[this.campoDisplay].toUpperCase() === texto.toUpperCase());
374
+ if (existe) {
375
+ if (setRegistro) {
376
+ this.selectedItem = existe;
377
+ this.selecionarComboClick(this.selectedItem);
378
+ }
379
+ return true;
380
+ }
381
+ else {
382
+ return false;
383
+ }
384
+ }
385
+ else {
386
+ return false;
387
+ }
388
+ }
389
+ validarItemSelecionado(setarRegistro = false) {
390
+ console.log('validar selecionado');
391
+ //passar pela função de filtro
392
+ let valido = false;
393
+ if (this.selectedItem) {
394
+ if (this.filterFunction) {
395
+ let existe = [{ ...this.selectedItem }].filter(this.filterFunction);
396
+ if (existe != null && existe.length > 0) {
397
+ valido = true;
398
+ }
399
+ }
400
+ else {
401
+ valido = true;
402
+ }
403
+ if (valido && setarRegistro) {
404
+ this.selecionarComboClick(this.selectedItem);
405
+ }
406
+ return valido;
407
+ }
408
+ else {
409
+ return false;
410
+ }
411
+ }
412
+ carregaItemIdParaLista(id) {
413
+ let url = this.urlItem.replace('<<ID>>', id.toString());
414
+ console.log(this.urlItem);
415
+ console.log('pesquisar ID url', url);
416
+ this.podePesquisar = false;
417
+ this.httpClient.get(url)
418
+ .subscribe({ next: (result) => {
419
+ this.listaPesquisa = [];
420
+ this.listaPesquisa.push({ ...result, Index: 0, Selected: true });
421
+ this.podePesquisar = true;
422
+ if (this.listaPesquisa.length > 0) {
423
+ this.selectedItem = this.listaPesquisa[0];
424
+ this.selecionarComboClick(this.selectedItem);
425
+ }
426
+ }, error: error => {
427
+ console.log('erro pesquisa', error);
428
+ this.podePesquisar = true;
429
+ } });
430
+ }
431
+ limparClick() {
432
+ this.writeValue(null);
433
+ this.writePesquisa(null);
434
+ this.listaPesquisa = [];
435
+ this.dropDownPesquisa(0);
436
+ //this.podePesquisar = true;
437
+ this.pesquisaSubject.next('');
438
+ if (this.limpar) {
439
+ this.limpar();
440
+ }
441
+ }
442
+ verificarPesquisa() {
443
+ //TODO: verificar se o texto corresponde com um item da lista
444
+ this.selecionarComboClick(null);
445
+ }
446
+ async pesquisarClick() {
447
+ /*
448
+ if (this.pesquisaAction != null) {
449
+ this.pesquisaAction();
450
+ }
451
+ */
452
+ //pesquisaCategoria
453
+ console.log(this.filterFunction, this.url, this.urlTree);
454
+ const modal = await this.modalCtrl.create({
455
+ component: ModelTreeviewComponent,
456
+ componentProps: {
457
+ //campoId: this.campoId,
458
+ //campoPai: this.campoPaiId,
459
+ //campoLabel: this.campoDisplay,
460
+ filterFunction: this.filterFunction,
461
+ empresaSelecionadaId: this.empresa,
462
+ tipo: this.tipo,
463
+ //especifico
464
+ //planoContas: this.planoContas,
465
+ url: this.isEmpty(this.urlTree) ? this.url : this.urlTree
466
+ },
467
+ cssClass: 'my-custom-modal-pesquisa'
468
+ });
469
+ modal.onDidDismiss().then(data => {
470
+ let result = data['data'];
471
+ console.log(result);
472
+ if (result != null && result.Id > 0) {
473
+ this.carregaItemIdParaLista(result.Id);
474
+ }
475
+ });
476
+ modal.present();
477
+ }
478
+ isEmpty(valor) {
479
+ return valor == null || valor == undefined || valor == '';
480
+ }
481
+ }
482
+ InputPesquisaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: InputPesquisaComponent, deps: [{ token: i1.HttpClient }, { token: i2.ModalController }], target: i0.ɵɵFactoryTarget.Component });
483
+ InputPesquisaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: InputPesquisaComponent, selector: "kb-input-pesquisa", inputs: { textoPesquisa: "textoPesquisa", max: "max", filterFunction: "filterFunction", selectId: "selectId", campoId: "campoId", campoPaiId: "campoPaiId", campoDisplay: "campoDisplay", tipo: "tipo", change: "change", pesquisaAction: "pesquisaAction", limpar: "limpar", url: "url", urlItem: "urlItem", urlTree: "urlTree", empresa: "empresa", loadInit: "loadInit" }, providers: [{
484
+ provide: NG_VALUE_ACCESSOR,
485
+ useExisting: InputPesquisaComponent,
486
+ multi: true
487
+ }], viewQueries: [{ propertyName: "selectElement", first: true, predicate: ["selectElement"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div style=\"padding-inline-end: 0px;\">\n <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n <!-- formControlName=\"{{ campo }}\" -->\n <ion-spinner *ngIf=\"!podePesquisar\"\n style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n slot=\"start\" name=\"lines\"></ion-spinner>\n <!-- (ionBlur)=\"verificarPesquisa()\" -->\n <!-- conflito com click da lista -->\n <ion-input #inputPesquisa\n type=\"{{type}}\" \n [placeholder]=\"placeholder\" \n maxlength=\"{{ max }}\" \n (ionBlur)=\"onBlur($event)\"\n [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n (keyup)=\"showPesquisa($event)\"\n autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n (click)=\"dropDownPesquisa(-1)\"\n [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"limparClick()\">\n <ion-icon name=\"close-outline\"></ion-icon>\n </ion-button>\n \n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"pesquisarClick()\">\n <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n </ion-button>\n \n </ion-item>\n \n <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n \n <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n class=\"pesquisa-item\">\n <!-- {{ item | json}} -->\n <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n </ion-item>\n \n </ion-list>\n \n <!--\n <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (ionChange)=\"selecionarComboChange($event.target.value)\">\n <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </ion-select-option>\n </ion-select>\n -->\n \n <!--\n <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </option>\n \n </select>\n -->\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n \n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n &#8226; {{ validation.message }}\n </div>\n </ng-container>\n \n </div>\n </div>", styles: ["ion-label{margin-bottom:4px!important;opacity:1!important}ion-input{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:29px}input:focus{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}.error-message{font-size:small;color:red;margin-left:15px}.padding{padding:auto}.no-padding{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px;height:55px!important}.no-padding-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.pesquisa-select{display:block;position:absolute;top:58px;left:20px;width:100%;z-index:800;font-size:16px;font-family:Roboto,Helvetica Neue,sans-serif;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.pesquisa-select option{overflow-y:hidden}.pesquisa-select option:hover,.pesquisa-select option:checked{background-color:#add8e6}.pesquisa-list{display:block;position:absolute;top:58px;left:20px;width:calc(100% - 50px);z-index:800;border:1px lightgrey solid;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:0}.pesquisa-item{--inner-padding-top: 0px;--inner-padding-bottom: 0px;--padding-top: 0px;--padding-bottom: 0px;--min-height: 30px !important;font-size:12px}.pesquisa-item button{padding:0}.selected-item{background-color:#add8e6}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i2.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i2.IonInput, selector: "ion-input", inputs: ["accept", "autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearOnEdit", "color", "debounce", "disabled", "enterkeyhint", "inputmode", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "size", "spellcheck", "step", "type", "value"] }, { kind: "component", type: i2.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i2.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i2.IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: i2.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "directive", type: i2.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }] });
488
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: InputPesquisaComponent, decorators: [{
489
+ type: Component,
490
+ args: [{ selector: 'kb-input-pesquisa', providers: [{
491
+ provide: NG_VALUE_ACCESSOR,
492
+ useExisting: InputPesquisaComponent,
493
+ multi: true
494
+ }], template: "<div style=\"padding-inline-end: 0px;\">\n <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n <!-- formControlName=\"{{ campo }}\" -->\n <ion-spinner *ngIf=\"!podePesquisar\"\n style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n slot=\"start\" name=\"lines\"></ion-spinner>\n <!-- (ionBlur)=\"verificarPesquisa()\" -->\n <!-- conflito com click da lista -->\n <ion-input #inputPesquisa\n type=\"{{type}}\" \n [placeholder]=\"placeholder\" \n maxlength=\"{{ max }}\" \n (ionBlur)=\"onBlur($event)\"\n [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n (keyup)=\"showPesquisa($event)\"\n autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n (click)=\"dropDownPesquisa(-1)\"\n [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"limparClick()\">\n <ion-icon name=\"close-outline\"></ion-icon>\n </ion-button>\n \n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"pesquisarClick()\">\n <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n </ion-button>\n \n </ion-item>\n \n <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n \n <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n class=\"pesquisa-item\">\n <!-- {{ item | json}} -->\n <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n </ion-item>\n \n </ion-list>\n \n <!--\n <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (ionChange)=\"selecionarComboChange($event.target.value)\">\n <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </ion-select-option>\n </ion-select>\n -->\n \n <!--\n <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </option>\n \n </select>\n -->\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n \n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n &#8226; {{ validation.message }}\n </div>\n </ng-container>\n \n </div>\n </div>", styles: ["ion-label{margin-bottom:4px!important;opacity:1!important}ion-input{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:29px}input:focus{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}.error-message{font-size:small;color:red;margin-left:15px}.padding{padding:auto}.no-padding{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px;height:55px!important}.no-padding-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.pesquisa-select{display:block;position:absolute;top:58px;left:20px;width:100%;z-index:800;font-size:16px;font-family:Roboto,Helvetica Neue,sans-serif;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.pesquisa-select option{overflow-y:hidden}.pesquisa-select option:hover,.pesquisa-select option:checked{background-color:#add8e6}.pesquisa-list{display:block;position:absolute;top:58px;left:20px;width:calc(100% - 50px);z-index:800;border:1px lightgrey solid;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:0}.pesquisa-item{--inner-padding-top: 0px;--inner-padding-bottom: 0px;--padding-top: 0px;--padding-bottom: 0px;--min-height: 30px !important;font-size:12px}.pesquisa-item button{padding:0}.selected-item{background-color:#add8e6}\n"] }]
495
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.ModalController }]; }, propDecorators: { textoPesquisa: [{
496
+ type: Input
497
+ }], max: [{
498
+ type: Input
499
+ }], filterFunction: [{
500
+ type: Input
501
+ }], selectId: [{
502
+ type: Input
503
+ }], campoId: [{
504
+ type: Input
505
+ }], campoPaiId: [{
506
+ type: Input
507
+ }], campoDisplay: [{
508
+ type: Input
509
+ }], tipo: [{
510
+ type: Input
511
+ }], selectElement: [{
512
+ type: ViewChild,
513
+ args: ['selectElement', { static: false }]
514
+ }], change: [{
515
+ type: Input
516
+ }], pesquisaAction: [{
517
+ type: Input
518
+ }], limpar: [{
519
+ type: Input
520
+ }], url: [{
521
+ type: Input
522
+ }], urlItem: [{
523
+ type: Input
524
+ }], urlTree: [{
525
+ type: Input
526
+ }], empresa: [{
527
+ type: Input
528
+ }], loadInit: [{
529
+ type: Input
530
+ }] } });
531
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-pesquisa.component.js","sourceRoot":"","sources":["../../../../../projects/appproject-components/src/lib/input-pesquisa/input-pesquisa.component.ts","../../../../../projects/appproject-components/src/lib/input-pesquisa/input-pesquisa.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Component, Input, OnInit, Predicate, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IonSelect, ModalController } from '@ionic/angular';\nimport { Subject, Subscription, of } from 'rxjs';\nimport { BaseInputComponent } from '../baseInputComponent';\nimport { debounceTime, switchMap } from 'rxjs/operators'\nimport { ModelTreeviewComponent } from '../model-treeview/model-treeview.component';\n\n@Component({\n  selector: 'kb-input-pesquisa',\n  templateUrl: './input-pesquisa.component.html',\n  styleUrls: ['./input-pesquisa.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputPesquisaComponent,\n    multi: true\n  }]\n})\nexport class InputPesquisaComponent extends BaseInputComponent implements OnInit, ControlValueAccessor {\n\n  podePesquisar: boolean = true;\n  @Input() textoPesquisa: string = '';\n  selectElementVisivel: boolean = false;\n  listaPesquisa: any[] = [];\n  selectedItem: any;\n  @Input() override max: string = '30';\n  private pesquisaSubject: Subject<string> = new Subject();\n\n  @Input() filterFunction: Predicate<any> | null = null;\n  @Input() selectId: string = 'selectElement';\n  @Input() campoId: string = 'Id';\n  @Input() campoPaiId: string = 'PaiId';\n  @Input() campoDisplay: string = 'Descricao';\n  @Input() tipo: string = '';\n  //@ViewChild('selectElement', { read: ElementRef, static: true }) selectElement;\n  @ViewChild('selectElement', { static: false }) selectElement: IonSelect | null = null;\n\n  @Input() change?: Function;\n  @Input() pesquisaAction?: Function;\n  @Input() limpar?: Function;\n  //parametros para chamada API\n  //endpoint para pesquisa por digitação\n  @Input() url: string = '';\n  @Input() urlItem: string = '';\n  //endpoint para montar a arvore, se estiver vazia será usado o campo 'url'\n  @Input() urlTree: string = '';\n  @Input() empresa: number = 0;\n  @Input() loadInit: boolean = false;\n\n  //planoContas: number;\n\n  //control value acessor\n  public data: number | any;\n  private onChange: Function = (data: number) => { };\n  private onTouch: Function = () => { };\n  private disabled: boolean = false;\n  public console = console;\n\n  modelChanged: Subject<any> = new Subject<any>();\n  modelChangeSubscription?: Subscription;\n\n  writeValue(value: number | any): void {\n    //console.log('write value', value);\n    this.onChange(value);\n    this.data = value;\n    if (value == null || value == 0) {\n      this.writePesquisa('');\n      this.selectedItem = null;\n    } else {\n      if (this.loadInit == true) {\n        this.loadInit = false;\n        this.modelChanged.next(value);\n        //this.carregaItemIdParaLista(value);\n      } else {\n        //console.log(this.selectedItem);\n        if (!this.selectedItem || (this.selectedItem && this.selectedItem[this.campoId] != value)) {\n          console.log('Id diferente');\n          this.modelChanged.next(value);\n          //this.carregaItemIdParaLista(value);\n        }\n      }\n    }\n\n  }\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = this.disabled;\n  }\n\n  constructor(private httpClient: HttpClient,\n    private modalCtrl: ModalController) {\n    super();\n\n    this.modelChangeSubscription = this.modelChanged\n      .pipe(debounceTime(500)\n      )\n      .subscribe(data => {\n        this.carregaItemIdParaLista(data);\n      });\n  }\n\n  onBlur(event: any) {\n    console.log('blur', event);\n    console.log(event.detail.relatedTarget);\n    if (event.detail.relatedTarget == null || event.detail.relatedTarget.id.indexOf(this.selectId + 'IonItem') == -1) {\n      console.log(\"true\", event.detail.relatedTarget.id);\n      //pesquisar item na lista\n      if (!this.existeNaListaTexto(this.textoPesquisa, true)) {\n        this.limparClick();\n      }\n\n      this.dropDownPesquisa(0);\n      if (this.form) {\n        this.form.get(this.formControlName)?.markAsTouched();\n      }\n    }\n  }\n\n  override ngOnInit() {\n    this.pesquisaSubject.pipe(switchMap((url) => {\n      this.console.log('subject url:', url);\n      if (!this.isEmpty(url))\n        return this.httpClient.get<any>(url);\n      else\n        return of([]);\n    }))\n      .subscribe({\n        next: (result: any) => {\n          //this.listaPesquisa = result;\n          this.console.log('subject subscribe result:', result);\n          this.listaPesquisa = [];\n\n          if (result && result.length > 0) {\n            if (this.filterFunction) {\n              result = result.filter(this.filterFunction);\n            }\n\n            result.forEach((ent: any, index: any) => {\n              this.listaPesquisa.push({ ...ent, Index: index, Selected: false });\n            });\n          }\n\n          this.podePesquisar = true;\n          if (this.listaPesquisa.length > 0) {\n            this.dropDownPesquisa(this.listaPesquisa.length);\n          }\n        }\n        , error: (error) => {\n          this.podePesquisar = true;\n          console.log('erro pesquisa', error);\n        }\n      });\n  }\n\n  writePesquisa(value: string | any): void {\n    //console.log('write pesquisa', value);\n    this.textoPesquisa = value;\n  }\n\n  showPesquisa(e: any): void {\n    //console.log('show pesquisa', e.keyCode);\n    var self = this;\n    if ((e.keyCode >= 48 && e.keyCode <= 57) ||\n      (e.keyCode >= 65 && e.keyCode <= 90) ||\n      (e.keyCode >= 96 && e.keyCode <= 105) ||\n      (e.keyCode == 8)) {\n      if (!self.podePesquisar) {\n        return;\n      }\n      let filtro = self.textoPesquisa;\n      if (filtro != null && filtro != '' && filtro.length >= 2) {\n        self.pesquisarEntidade(filtro);\n\n      }\n      else {\n        if (e.keyCode == 8 && !filtro) {\n          this.limparClick();\n        }\n      }\n    }\n\n    else {\n      if (e.keyCode == 40 || e.keyCode == 38) {\n        self.dropDownPesquisa(self.listaPesquisa.length);\n        if (self.selectElementVisivel == true) {\n          //let select = self.selectElement; //document.getElementById(self.TemplateSelect1Id());\n\n          //ion-list\n          //selecionado\n          //console.log(self.listaPesquisa);\n          let inc = e.keyCode == 40 ? 1 : -1;\n          let selected = self.listaPesquisa.find(s => s['Selected'] === true);\n          let cur = 0;\n          if (selected != null) {\n            cur = selected['Index'];\n            //desmarcar o atual\n            selected['Selected'] = false;\n            cur = cur + inc;\n          } else {\n            cur = 0;\n          }\n\n          if (cur < 0) {\n            cur = self.listaPesquisa.length - 1;\n          } else if (cur >= self.listaPesquisa.length) {\n            cur = 0;\n          }\n\n          let novoSelected = self.listaPesquisa.find(n => n['Index'] === cur);\n          if (novoSelected != null) {\n            novoSelected['Selected'] = true;\n            self.selectedItem = novoSelected;\n            self.textoPesquisa = novoSelected[self.campoDisplay];\n          }\n          /*\n          let select = document.getElementById(this.selectId) as any;\n          console.log('select Element', select)\n          if (select != null) {\n            let inc = e.keyCode == 40 ? 1 : -1;\n            let cur = select.selectedIndex;\n            if (cur == NaN) cur = -1;\n            select.selectedIndex = cur + inc;\n            if (select.selectedIndex >= 0 && select.selectedIndex < self.listaPesquisa.length) {\n              self.selectedItem = self.listaPesquisa[select.selectedIndex];\n              if (self.selectedItem != null) {\n                self.textoPesquisa = self.selectedItem[self.campoDisplay];\n              }\n            }\n          }\n          */\n        }\n\n      } else\n        if (e.keyCode == 13) {\n          console.log('enter key', e)\n          //self.selecionarComboClick(e);\n          self.selecionarComboClick(null);\n          //return false;\n        } else if (e.keyCode == 27) {\n          //ESC\n          self.dropDownPesquisa(0);\n        }\n    }\n\n  }\n\n  highlight(texto: string): string {\n    let index = texto.toLowerCase().indexOf(this.textoPesquisa.toLowerCase());\n    //console.log(index);\n    if (index >= 0) {\n      return texto.substring(0, index) + '<strong>' + texto.substring(index, index + this.textoPesquisa.length) + '</strong>' + texto.substring(index + this.textoPesquisa.length);  //texto.replace(this.textoPesquisa, `<strong>${this.textoPesquisa}</strong>`);\n    } else {\n      return texto;\n    }\n  }\n\n  selecionarComboClick(item: any) {\n    // console.log(item);\n    var self = this;\n    // console.log('combo click', self);\n\n    /*\n    let select = document.getElementById(this.selectId) as any;\n    if (select.selectedIndex >= 0) {\n      self.selectedItem = self.listaPesquisa[select.selectedIndex];\n    }\n    console.log('selected', this.selectedItem);\n    //self.selectedItem = this.listaPesquisa.find(i => i[this.campoId] == e);\n    if (self.selectedItem != null) {\n      self.textoPesquisa = self.selectedItem[self.campoDisplay];\n      self.writeValue(self.selectedItem[self.campoId]);\n      if (e != null) {\n        self.selectElementVisivel = false;\n        if (self.action != null) {\n          self.action(self.selectedItem(), e);\n        }\n      }\n    }\n    else {\n      self.selectElementVisivel = false;\n    }\n    */\n    // pesquisar selecionado\n    // console.log(this.listaPesquisa);\n    let selected = this.listaPesquisa.find(s => s['Selected'] === true);\n\n    // if (!selected) {\n    //   console.log(this.campoId, item);\n    //   selected = this.listaPesquisa.filter( s => s[this.campoId] == item[this.campoId]);\n    // }\n\n    //se o item form passado como parametro (click no ion-item)\n    if (item != null) {\n      if (selected != null) {\n        selected['Selected'] = false;\n      }\n      item['Selected'] = true;\n      selected = item;\n    }\n    if (selected != null) {\n      self.selectedItem = selected;\n      self.textoPesquisa = selected[self.campoDisplay];\n      self.writeValue(selected[self.campoId]);\n      self.selectElementVisivel = false;\n      console.log('action', self.change);\n      if (self.change != null) {\n        self.change(self.selectedItem);\n      }\n    } else {\n      self.selectElementVisivel = false;\n    }\n    // this.listaPesquisa.forEach( pesquisa => {\n    //   console.log(pesquisa, self.data);\n    // } );\n    // console.log(this.textoPesquisa);\n  }\n\n  selecionarComboChange(e: any) {\n    var self = this;\n    console.log('combo change', e);\n    self.selectedItem = this.listaPesquisa.find(i => i[this.campoId] == e);\n    if (self.selectedItem != null) {\n      self.writeValue(e);\n      self.textoPesquisa = self.selectedItem[self.campoDisplay];\n      if (e != null) {\n        self.selectElementVisivel = false;\n        if (self.change != null) {\n          self.change(self.selectedItem, e);\n        }\n      }\n    }\n    else {\n      self.selectElementVisivel = false;\n    }\n  }\n\n  dropDownPesquisa(length: number) {\n    var self = this;\n    if (self.listaPesquisa != null && self.listaPesquisa.length > 0) {\n      if (length == -1) {\n        length = self.listaPesquisa.length;\n      }\n      self.selectElementVisivel = length == 0 ? false : true;\n\n      //console.log(this.selectElement);\n      //this.selectElement.open();\n\n      /*\n      //let element = this.selectElement;\n      let element = document.getElementById(this.selectId);\n      console.log('dropDown', element);\n      (element as any).size = length + 1;\n      if (length == 0) {\n        self.selectElementVisivel = false;\n      } else {\n        self.selectElementVisivel = true;\n      }\n      */\n    }\n  }\n\n  pesquisarEntidade(filtro: string) {\n    let url = this.url.replace('<<FILTRO>>', filtro).replace('<<EMPRESA>>', this.empresa.toString());\n    console.log('pesquisarEntidade url', url);\n    this.podePesquisar = false;\n    this.pesquisaSubject.next(url);\n  }\n\n  pesquisarEntidadeOld(filtro: string) {\n    let url = this.url.replace('<<FILTRO>>', filtro).replace('<<EMPRESA>>', this.empresa.toString());\n    console.log('pesquisarEntidade url', url);\n    this.podePesquisar = false;\n    this.httpClient.get<any>(url)\n      .subscribe({ next: (result: any) => {\n        //this.listaPesquisa = result;\n        if (this.filterFunction) {\n          result = result.filter(this.filterFunction);\n        }\n        this.listaPesquisa = [];\n        result.forEach((ent: any, index: number) => {\n          this.listaPesquisa.push({ ...ent, Index: index, Selected: false });\n        });\n\n        this.podePesquisar = true;\n        if (this.listaPesquisa.length > 0) {\n          this.dropDownPesquisa(this.listaPesquisa.length);\n        }\n      }, error: error => {\n        console.log('erro pesquisa', error);\n        this.podePesquisar = true;\n      }});\n  }\n\n  existeNaLista(id: number, setRegistro: boolean = false): boolean {\n    if (this.listaPesquisa && this.listaPesquisa.length > 0) {\n      let existe = this.listaPesquisa.find(l => l[this.campoId] === id);\n      if (existe) {\n        if (setRegistro) {\n          this.selectedItem = existe;\n          this.selecionarComboClick(this.selectedItem);\n        }\n        return true;\n      } else {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  existeNaListaTexto(texto: string, setRegistro: boolean = false): boolean {\n    console.log(\"existe texto:\", texto, this.campoDisplay, this.listaPesquisa);\n    if (this.listaPesquisa && this.listaPesquisa.length > 0) {\n      let existe = this.listaPesquisa.find(l => l[this.campoDisplay].toUpperCase() === texto.toUpperCase());\n      if (existe) {\n        if (setRegistro) {\n          this.selectedItem = existe;\n          this.selecionarComboClick(this.selectedItem);\n        }\n        return true;\n      } else {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  validarItemSelecionado(setarRegistro: boolean = false): boolean {\n    console.log('validar selecionado');\n    //passar pela função de filtro\n    let valido = false;\n    if (this.selectedItem) {\n      if (this.filterFunction) {\n        let existe = [{ ...this.selectedItem }].filter(this.filterFunction);\n        if (existe != null && existe.length > 0) {\n          valido = true;\n        }\n      } else {\n        valido = true;\n      }\n      if (valido && setarRegistro) {\n        this.selecionarComboClick(this.selectedItem);\n      }\n\n      return valido;\n    } else {\n      return false;\n    }\n  }\n\n  carregaItemIdParaLista(id: number) {\n    let url = this.urlItem.replace('<<ID>>', id.toString());\n    console.log(this.urlItem);\n    console.log('pesquisar ID url', url);\n    this.podePesquisar = false;\n    this.httpClient.get<any>(url)\n      .subscribe({ next: (result: any) => {\n        this.listaPesquisa = [];\n        this.listaPesquisa.push({ ...result, Index: 0, Selected: true });\n        this.podePesquisar = true;\n        if (this.listaPesquisa.length > 0) {\n          this.selectedItem = this.listaPesquisa[0];\n          this.selecionarComboClick(this.selectedItem);\n        }\n      }, error:  error => {\n        console.log('erro pesquisa', error);\n        this.podePesquisar = true;\n      }});\n  }\n\n  limparClick() {\n    this.writeValue(null);\n    this.writePesquisa(null);\n    this.listaPesquisa = [];\n    this.dropDownPesquisa(0);\n    //this.podePesquisar = true;\n    this.pesquisaSubject.next('');\n    if (this.limpar) {\n      this.limpar();\n    }\n  }\n\n  verificarPesquisa() {\n    //TODO: verificar se o texto corresponde com um item da lista\n    this.selecionarComboClick(null);\n  }\n\n  async pesquisarClick() {\n    /*\n    if (this.pesquisaAction != null) {\n      this.pesquisaAction();\n    }\n    */\n    //pesquisaCategoria\n    console.log(this.filterFunction, this.url, this.urlTree);\n\n    const modal = await this.modalCtrl.create({\n      component: ModelTreeviewComponent,\n      componentProps: {\n        //campoId: this.campoId,\n        //campoPai: this.campoPaiId,\n        //campoLabel: this.campoDisplay,\n        filterFunction: this.filterFunction,\n        empresaSelecionadaId: this.empresa,\n        tipo: this.tipo,\n        //especifico\n        //planoContas: this.planoContas,\n        url: this.isEmpty(this.urlTree) ? this.url : this.urlTree\n      },\n      cssClass: 'my-custom-modal-pesquisa'\n    });\n\n    modal.onDidDismiss().then(data => {\n      let result = data['data'];\n      console.log(result);\n      if (result != null && result.Id > 0) {\n        this.carregaItemIdParaLista(result.Id);\n      }\n    });\n    modal.present();\n\n  }\n\n  isEmpty(valor: string | any) {\n    return valor == null || valor == undefined || valor == ''\n  }\n}\n","<div style=\"padding-inline-end: 0px;\">\n    <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n      <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n      <!-- formControlName=\"{{ campo }}\"  -->\n      <ion-spinner *ngIf=\"!podePesquisar\"\n        style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n        slot=\"start\" name=\"lines\"></ion-spinner>\n      <!-- (ionBlur)=\"verificarPesquisa()\" -->\n      <!-- conflito com click da lista -->\n      <ion-input #inputPesquisa\n        type=\"{{type}}\" \n        [placeholder]=\"placeholder\" \n        maxlength=\"{{ max }}\" \n        (ionBlur)=\"onBlur($event)\"\n        [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n        (keyup)=\"showPesquisa($event)\"\n        autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n        (click)=\"dropDownPesquisa(-1)\"\n        [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n      <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n        style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n        (click)=\"limparClick()\">\n        <ion-icon name=\"close-outline\"></ion-icon>\n      </ion-button>\n  \n      <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n        style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n        (click)=\"pesquisarClick()\">\n        <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n      </ion-button>\n      \n    </ion-item>\n  \n    <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n      \n      <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n      (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n        class=\"pesquisa-item\">\n        <!-- {{ item | json}} -->\n        <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n      </ion-item>\n  \n    </ion-list>\n  \n    <!--\n    <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n      (ionChange)=\"selecionarComboChange($event.target.value)\">\n      <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n        {{ item[campoDisplay] }}\n      </ion-select-option>\n    </ion-select>\n    -->\n  \n    <!--\n    <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n      (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n      <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n        {{ item[campoDisplay] }}\n      </option>\n  \n    </select>\n    -->\n  \n    <div class=\"validation-errors\" *ngIf=\"form\">\n  \n      <ng-container *ngFor=\"let validation of validation_messages\">\n        <div class=\"error-message\"\n          *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n          &#8226; {{ validation.message }}\n        </div>\n      </ng-container>\n  \n    </div>\n  </div>"]}