@seniorsistemas/components-ai 1.3.0 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dynamic-form/dynamic-form.component.mjs +263 -368
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-checkbox.component.mjs +53 -0
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-date.component.mjs +5 -3
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-datetime.component.mjs +5 -3
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-dropdown.component.mjs +5 -3
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-image.component.mjs +162 -0
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-lookup.component.mjs +203 -49
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-multiselect.component.mjs +90 -0
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-number.component.mjs +3 -3
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-text.component.mjs +7 -7
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-time.component.mjs +66 -0
- package/esm2022/lib/components/dynamic-form/fields/index.mjs +5 -1
- package/esm2022/lib/components/dynamic-form/models/dynamic-form.models.mjs +1 -1
- package/esm2022/lib/components/loading/iassist-icon.component.mjs +14 -0
- package/esm2022/lib/components/loading/loading.component.mjs +47 -4
- package/esm2022/lib/i18n/en-US.json +4 -1
- package/esm2022/lib/i18n/es-ES.json +4 -1
- package/esm2022/lib/i18n/pt-BR.json +4 -1
- package/esm2022/lib/models/entity-list.config.mjs +1 -1
- package/esm2022/lib/services/websocket.service.mjs +184 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/seniorsistemas-components-ai.mjs +1283 -661
- package/fesm2022/seniorsistemas-components-ai.mjs.map +1 -1
- package/lib/components/dynamic-form/dynamic-form.component.d.ts +8 -17
- package/lib/components/dynamic-form/fields/dynamic-field-checkbox.component.d.ts +8 -0
- package/lib/components/dynamic-form/fields/dynamic-field-image.component.d.ts +21 -0
- package/lib/components/dynamic-form/fields/dynamic-field-lookup.component.d.ts +19 -6
- package/lib/components/dynamic-form/fields/dynamic-field-multiselect.component.d.ts +10 -0
- package/lib/components/dynamic-form/fields/dynamic-field-time.component.d.ts +9 -0
- package/lib/components/dynamic-form/fields/index.d.ts +4 -0
- package/lib/components/dynamic-form/models/dynamic-form.models.d.ts +30 -84
- package/lib/components/loading/iassist-icon.component.d.ts +6 -0
- package/lib/components/loading/loading.component.d.ts +1 -1
- package/lib/models/entity-list.config.d.ts +12 -132
- package/lib/services/websocket.service.d.ts +63 -0
- package/package.json +3 -2
- package/public-api.d.ts +2 -0
- package/src/lib/i18n/en-US.json +4 -1
- package/src/lib/i18n/es-ES.json +4 -1
- package/src/lib/i18n/pt-BR.json +4 -1
|
@@ -6,10 +6,13 @@ import { InputTextModule } from 'primeng/inputtext';
|
|
|
6
6
|
import { DialogModule } from 'primeng/dialog';
|
|
7
7
|
import { TableModule } from 'primeng/table';
|
|
8
8
|
import { TooltipModule } from 'primeng/tooltip';
|
|
9
|
+
import { OverlayPanelModule } from 'primeng/overlaypanel';
|
|
9
10
|
import { TranslatePipe } from '../../../pipes/translate.pipe';
|
|
10
11
|
import { TranslationHelper } from '../../../utils/translation.helper';
|
|
11
12
|
import { DynamicFieldWrapperComponent } from './dynamic-field-wrapper.component';
|
|
12
|
-
import {
|
|
13
|
+
import { TableLoadingDirective } from '../../../directives/table-loading/table-loading.directive';
|
|
14
|
+
import { Subject } from 'rxjs';
|
|
15
|
+
import { debounceTime, distinctUntilChanged } from 'rxjs/operators';
|
|
13
16
|
import * as i0 from "@angular/core";
|
|
14
17
|
import * as i1 from "../../../services/translation.service";
|
|
15
18
|
import * as i2 from "@angular/common";
|
|
@@ -22,7 +25,6 @@ import * as i8 from "primeng/table";
|
|
|
22
25
|
import * as i9 from "primeng/tooltip";
|
|
23
26
|
export class DynamicFieldLookupComponent {
|
|
24
27
|
translationService;
|
|
25
|
-
cdr;
|
|
26
28
|
field;
|
|
27
29
|
form;
|
|
28
30
|
formGroup;
|
|
@@ -35,20 +37,124 @@ export class DynamicFieldLookupComponent {
|
|
|
35
37
|
filteredData = [];
|
|
36
38
|
totalRecords = 0;
|
|
37
39
|
currentPage = 0;
|
|
38
|
-
pageSize =
|
|
40
|
+
pageSize = 10;
|
|
39
41
|
selectedItem = null;
|
|
40
|
-
skipNextLazyLoad = false;
|
|
41
42
|
columns = [];
|
|
42
43
|
displayField = 'name';
|
|
43
44
|
valueField = 'id';
|
|
44
45
|
searchFields = ['name'];
|
|
45
|
-
|
|
46
|
+
// Autocomplete state
|
|
47
|
+
autocompleteText = '';
|
|
48
|
+
suggestions = [];
|
|
49
|
+
showSuggestions = false;
|
|
50
|
+
autocompleteLoading = false;
|
|
51
|
+
autocompleteSubject = new Subject();
|
|
52
|
+
autocompleteSub;
|
|
53
|
+
get isAutocomplete() {
|
|
54
|
+
return this.field?.lookupAutocomplete === true;
|
|
55
|
+
}
|
|
56
|
+
get minLength() {
|
|
57
|
+
return this.field?.lookupAutocompleteMinLength ?? 2;
|
|
58
|
+
}
|
|
59
|
+
constructor(translationService) {
|
|
46
60
|
this.translationService = translationService;
|
|
47
|
-
this.cdr = cdr;
|
|
48
61
|
}
|
|
49
62
|
ngOnInit() {
|
|
50
63
|
this.setupLookupConfig();
|
|
51
64
|
this.watchValueChanges();
|
|
65
|
+
this.setupAutocomplete();
|
|
66
|
+
}
|
|
67
|
+
ngOnDestroy() {
|
|
68
|
+
this.autocompleteSub?.unsubscribe();
|
|
69
|
+
}
|
|
70
|
+
setupAutocomplete() {
|
|
71
|
+
if (!this.isAutocomplete)
|
|
72
|
+
return;
|
|
73
|
+
this.autocompleteSub = this.autocompleteSubject.pipe(debounceTime(300), distinctUntilChanged()).subscribe(term => {
|
|
74
|
+
if (term.length >= this.minLength) {
|
|
75
|
+
this.searchSuggestions(term);
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
this.suggestions = [];
|
|
79
|
+
this.showSuggestions = false;
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
onAutocompleteInput(event) {
|
|
84
|
+
const value = event.target.value;
|
|
85
|
+
this.autocompleteText = value;
|
|
86
|
+
if (!value) {
|
|
87
|
+
this.clearValue();
|
|
88
|
+
this.suggestions = [];
|
|
89
|
+
this.showSuggestions = false;
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
this.autocompleteSubject.next(value);
|
|
93
|
+
}
|
|
94
|
+
onAutocompleteFocus() {
|
|
95
|
+
if (this.autocompleteText.length >= this.minLength && this.suggestions.length > 0) {
|
|
96
|
+
this.showSuggestions = true;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
onAutocompleteBlur() {
|
|
100
|
+
// Delay to allow click on suggestion
|
|
101
|
+
setTimeout(() => { this.showSuggestions = false; }, 200);
|
|
102
|
+
}
|
|
103
|
+
selectSuggestion(item) {
|
|
104
|
+
this.setValue(item);
|
|
105
|
+
this.displayValue = this.formatDisplayValue(item);
|
|
106
|
+
this.autocompleteText = this.displayValue;
|
|
107
|
+
this.suggestions = [];
|
|
108
|
+
this.showSuggestions = false;
|
|
109
|
+
}
|
|
110
|
+
searchSuggestions(term) {
|
|
111
|
+
if (!this.field?.lookupService)
|
|
112
|
+
return;
|
|
113
|
+
this.autocompleteLoading = true;
|
|
114
|
+
this.showSuggestions = true;
|
|
115
|
+
const listParams = { page: 0, size: 10 };
|
|
116
|
+
if (this.field.lookupSort) {
|
|
117
|
+
listParams.sort = this.field.lookupSort;
|
|
118
|
+
}
|
|
119
|
+
const filterConditions = [];
|
|
120
|
+
const isNumericTerm = !isNaN(Number(term)) && term !== '';
|
|
121
|
+
this.searchFields.forEach(field => {
|
|
122
|
+
const column = this.columns.find(col => col.field === field);
|
|
123
|
+
const fieldType = column?.type || 'text';
|
|
124
|
+
if (fieldType === 'number') {
|
|
125
|
+
if (isNumericTerm) {
|
|
126
|
+
filterConditions.push(`${field} eq ${term}`);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
const upperTerm = term.toUpperCase();
|
|
131
|
+
filterConditions.push(`UPPER(${field}) like '%${upperTerm}%'`);
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
if (filterConditions.length > 0) {
|
|
135
|
+
listParams.filterQuery = filterConditions.join(' or ');
|
|
136
|
+
}
|
|
137
|
+
// Apply lookupFilters
|
|
138
|
+
if (this.field.lookupFilters) {
|
|
139
|
+
const extra = typeof this.field.lookupFilters === 'function'
|
|
140
|
+
? this.field.lookupFilters(this.formGroup?.value || {})
|
|
141
|
+
: this.field.lookupFilters;
|
|
142
|
+
if (extra) {
|
|
143
|
+
listParams.filterQuery = listParams.filterQuery
|
|
144
|
+
? `(${listParams.filterQuery}) and (${extra})`
|
|
145
|
+
: extra;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
this.field.lookupService.list(listParams).subscribe({
|
|
149
|
+
next: (res) => {
|
|
150
|
+
this.suggestions = res.contents || [];
|
|
151
|
+
this.autocompleteLoading = false;
|
|
152
|
+
},
|
|
153
|
+
error: () => {
|
|
154
|
+
this.suggestions = [];
|
|
155
|
+
this.autocompleteLoading = false;
|
|
156
|
+
}
|
|
157
|
+
});
|
|
52
158
|
}
|
|
53
159
|
watchValueChanges() {
|
|
54
160
|
const control = this.getFormControl();
|
|
@@ -102,17 +208,17 @@ export class DynamicFieldLookupComponent {
|
|
|
102
208
|
handleValueDisplay(value) {
|
|
103
209
|
if (value === null || value === undefined || value === '') {
|
|
104
210
|
this.displayValue = '';
|
|
211
|
+
this.autocompleteText = '';
|
|
105
212
|
return;
|
|
106
213
|
}
|
|
107
214
|
if (typeof value === 'object' && value !== null) {
|
|
108
215
|
this.displayValue = this.formatDisplayValue(value);
|
|
109
|
-
|
|
216
|
+
this.autocompleteText = this.displayValue;
|
|
110
217
|
return;
|
|
111
218
|
}
|
|
112
|
-
// Se é um ID (string ou number), não fazer requisição
|
|
113
|
-
// Deixar vazio e só carregar quando abrir o lookup
|
|
114
219
|
if (typeof value === 'string' || typeof value === 'number') {
|
|
115
220
|
this.displayValue = '';
|
|
221
|
+
this.autocompleteText = '';
|
|
116
222
|
return;
|
|
117
223
|
}
|
|
118
224
|
}
|
|
@@ -158,13 +264,11 @@ export class DynamicFieldLookupComponent {
|
|
|
158
264
|
if (!this.showLookupDialog) {
|
|
159
265
|
return;
|
|
160
266
|
}
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
if (this.skipNextLazyLoad) {
|
|
164
|
-
this.skipNextLazyLoad = false;
|
|
267
|
+
const newPage = event.first / event.rows;
|
|
268
|
+
if (newPage === this.currentPage && this.filteredData.length > 0) {
|
|
165
269
|
return;
|
|
166
270
|
}
|
|
167
|
-
this.currentPage =
|
|
271
|
+
this.currentPage = newPage;
|
|
168
272
|
this.loadData();
|
|
169
273
|
}
|
|
170
274
|
loadData() {
|
|
@@ -201,26 +305,19 @@ export class DynamicFieldLookupComponent {
|
|
|
201
305
|
}
|
|
202
306
|
}
|
|
203
307
|
if (this.field.lookupFilters) {
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
const value = dynamicFilters[key];
|
|
213
|
-
if (value !== null && value !== undefined) {
|
|
214
|
-
dynamicFilterConditions.push(`${key} eq '${value}'`);
|
|
215
|
-
}
|
|
216
|
-
});
|
|
217
|
-
if (dynamicFilterConditions.length > 0) {
|
|
218
|
-
const dynamicFilterQuery = dynamicFilterConditions.join(' and ');
|
|
308
|
+
let extraFilter = '';
|
|
309
|
+
if (typeof this.field.lookupFilters === 'function') {
|
|
310
|
+
extraFilter = this.field.lookupFilters(this.formGroup?.value || {});
|
|
311
|
+
}
|
|
312
|
+
else {
|
|
313
|
+
extraFilter = this.field.lookupFilters;
|
|
314
|
+
}
|
|
315
|
+
if (extraFilter) {
|
|
219
316
|
if (listParams.filterQuery) {
|
|
220
|
-
listParams.filterQuery = `(${listParams.filterQuery}) and (${
|
|
317
|
+
listParams.filterQuery = `(${listParams.filterQuery}) and (${extraFilter})`;
|
|
221
318
|
}
|
|
222
319
|
else {
|
|
223
|
-
listParams.filterQuery =
|
|
320
|
+
listParams.filterQuery = extraFilter;
|
|
224
321
|
}
|
|
225
322
|
}
|
|
226
323
|
}
|
|
@@ -239,15 +336,12 @@ export class DynamicFieldLookupComponent {
|
|
|
239
336
|
}
|
|
240
337
|
}
|
|
241
338
|
this.loading = false;
|
|
242
|
-
// The table will fire onLazyLoad when it first renders — skip it
|
|
243
|
-
this.skipNextLazyLoad = true;
|
|
244
339
|
},
|
|
245
340
|
error: (_error) => {
|
|
246
341
|
this.data = [];
|
|
247
342
|
this.filteredData = [];
|
|
248
343
|
this.totalRecords = 0;
|
|
249
344
|
this.loading = false;
|
|
250
|
-
this.skipNextLazyLoad = true;
|
|
251
345
|
}
|
|
252
346
|
});
|
|
253
347
|
}
|
|
@@ -256,10 +350,16 @@ export class DynamicFieldLookupComponent {
|
|
|
256
350
|
this.selectedItem = null;
|
|
257
351
|
return;
|
|
258
352
|
}
|
|
259
|
-
|
|
353
|
+
// value can be a full object or just an ID
|
|
354
|
+
const valueId = typeof this.value === 'object' ? this.value[this.valueField] : this.value;
|
|
355
|
+
const item = this.filteredData.find(i => i[this.valueField] === valueId);
|
|
260
356
|
if (item) {
|
|
261
357
|
this.selectedItem = item;
|
|
262
358
|
}
|
|
359
|
+
else if (typeof this.value === 'object') {
|
|
360
|
+
// Item not in current page but we have the full object from autocomplete
|
|
361
|
+
this.selectedItem = this.value;
|
|
362
|
+
}
|
|
263
363
|
}
|
|
264
364
|
onSearch() {
|
|
265
365
|
if (!this.showLookupDialog) {
|
|
@@ -285,12 +385,15 @@ export class DynamicFieldLookupComponent {
|
|
|
285
385
|
clearValue() {
|
|
286
386
|
this.setValue(null);
|
|
287
387
|
this.displayValue = '';
|
|
388
|
+
this.autocompleteText = '';
|
|
288
389
|
this.selectedItem = null;
|
|
390
|
+
this.suggestions = [];
|
|
391
|
+
this.showSuggestions = false;
|
|
289
392
|
}
|
|
290
393
|
getFieldValue(item, field) {
|
|
291
394
|
return field.split('.').reduce((obj, key) => obj?.[key], item) || '';
|
|
292
395
|
}
|
|
293
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DynamicFieldLookupComponent, deps: [{ token: i1.TranslationService }
|
|
396
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DynamicFieldLookupComponent, deps: [{ token: i1.TranslationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
294
397
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: DynamicFieldLookupComponent, isStandalone: true, selector: "sia-dynamic-field-lookup", inputs: { field: "field", form: "form", formGroup: "formGroup", mode: "mode" }, ngImport: i0, template: `
|
|
295
398
|
<sia-dynamic-field-wrapper [field]="field" [form]="form" [mode]="mode">
|
|
296
399
|
<div [formGroup]="form" class="lookup-field" [ngClass]="{'disabled': isFieldDisabled()}">
|
|
@@ -298,7 +401,23 @@ export class DynamicFieldLookupComponent {
|
|
|
298
401
|
<input type="hidden" [formControlName]="field.field" />
|
|
299
402
|
|
|
300
403
|
<div class="lookup-input-group">
|
|
404
|
+
<!-- Autocomplete mode: editable input -->
|
|
405
|
+
<input
|
|
406
|
+
*ngIf="isAutocomplete"
|
|
407
|
+
#autocompleteInput
|
|
408
|
+
pInputText
|
|
409
|
+
[value]="autocompleteText"
|
|
410
|
+
[placeholder]="getPlaceholder()"
|
|
411
|
+
[class.p-invalid]="isFieldInvalid()"
|
|
412
|
+
[disabled]="isFieldDisabled()"
|
|
413
|
+
class="lookup-display"
|
|
414
|
+
(input)="onAutocompleteInput($event)"
|
|
415
|
+
(focus)="onAutocompleteFocus()"
|
|
416
|
+
(blur)="onAutocompleteBlur()"
|
|
417
|
+
/>
|
|
418
|
+
<!-- Standard mode: readonly input -->
|
|
301
419
|
<input
|
|
420
|
+
*ngIf="!isAutocomplete"
|
|
302
421
|
pInputText
|
|
303
422
|
[value]="displayValue"
|
|
304
423
|
[placeholder]="getPlaceholder()"
|
|
@@ -308,6 +427,18 @@ export class DynamicFieldLookupComponent {
|
|
|
308
427
|
class="lookup-display"
|
|
309
428
|
(click)="openLookup()"
|
|
310
429
|
/>
|
|
430
|
+
<!-- Autocomplete suggestions dropdown -->
|
|
431
|
+
<div class="autocomplete-suggestions" *ngIf="showSuggestions && suggestions.length > 0">
|
|
432
|
+
<div
|
|
433
|
+
class="suggestion-item"
|
|
434
|
+
*ngFor="let item of suggestions"
|
|
435
|
+
(mousedown)="selectSuggestion(item)">
|
|
436
|
+
{{ formatDisplayValue(item) }}
|
|
437
|
+
</div>
|
|
438
|
+
</div>
|
|
439
|
+
<div class="autocomplete-suggestions" *ngIf="showSuggestions && suggestions.length === 0 && autocompleteLoading">
|
|
440
|
+
<div class="suggestion-item suggestion-loading">Buscando...</div>
|
|
441
|
+
</div>
|
|
311
442
|
<div class="lookup-buttons">
|
|
312
443
|
<p-button
|
|
313
444
|
*ngIf="currentValue"
|
|
@@ -383,18 +514,15 @@ export class DynamicFieldLookupComponent {
|
|
|
383
514
|
</div>
|
|
384
515
|
</div>
|
|
385
516
|
|
|
386
|
-
<!-- Loading State -->
|
|
387
|
-
<sia-loading *ngIf="loading" padding="2rem 0" [size]="48"></sia-loading>
|
|
388
|
-
|
|
389
517
|
<!-- Data Table -->
|
|
390
518
|
<p-table
|
|
391
|
-
*ngIf="!loading"
|
|
392
519
|
[value]="filteredData"
|
|
393
520
|
[paginator]="true"
|
|
394
521
|
[rows]="pageSize"
|
|
395
522
|
[totalRecords]="totalRecords"
|
|
396
523
|
[lazy]="true"
|
|
397
524
|
(onLazyLoad)="onPageChange($event)"
|
|
525
|
+
[loading]="loading" siaTableLoading
|
|
398
526
|
[showCurrentPageReport]="true"
|
|
399
527
|
currentPageReportTemplate="Mostrando {first} a {last} de {totalRecords} registros"
|
|
400
528
|
dataKey="id"
|
|
@@ -436,7 +564,7 @@ export class DynamicFieldLookupComponent {
|
|
|
436
564
|
</div>
|
|
437
565
|
</p-dialog>
|
|
438
566
|
</sia-dynamic-field-wrapper>
|
|
439
|
-
`, isInline: true, styles: [".lookup-field{width:100%;position:relative}.lookup-input-group{position:relative;width:100%;.lookup-display{width:100%;cursor:pointer;height:2.857rem;padding:.75rem 4rem .75rem .75rem;font-size:1rem;line-height:1.5;box-sizing:border-box;display:flex;align-items:center;&:focus{outline:none}&:hover{background:transparent}}.lookup-buttons{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px;z-index:10}::ng-deep .p-button{width:2rem!important;height:2rem!important;min-width:2rem!important;min-height:2rem!important;padding:0!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box!important;.p-button-icon{margin:0!important;font-size:.875rem!important}.p-button-label{display:none!important}}}.lookup-dialog-content{height:100%;display:flex;flex-direction:column;padding:0;.search-wrapper{position:relative;margin-bottom:16px;width:100%;.search-input-full{width:100%;padding-right:5.5rem}.search-buttons-inside{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px;::ng-deep .p-button{width:2.5rem!important;height:2.5rem!important}}}.lookup-table{flex:1;.empty-state{text-align:center;padding:32px;color:var(--p-text-color-secondary);i{font-size:48px;margin-bottom:16px;display:block}p{margin:8px 0;font-size:16px}small{font-size:14px}}}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "variant", "style", "styleClass", "badgeClass", "badgeSeverity", "ariaLabel", "autofocus", "fluid", "buttonProps"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i5.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i6.InputText, selector: "[pInputText]", inputs: ["variant", "fluid", "pSize"] }, { kind: "ngmodule", type: DialogModule }, { kind: "component", type: i7.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "closeButtonProps", "maximizeButtonProps", "visible", "style", "position", "role", "content", "contentTemplate", "footerTemplate", "closeIconTemplate", "maximizeIconTemplate", "minimizeIconTemplate", "headlessTemplate"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "ngmodule", type: TableModule }, { kind: "component", type: i8.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "size", "showGridlines", "stripedRows", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "virtualRowHeight", "selectAll"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i8.SelectableRow, selector: "[pSelectableRow]", inputs: ["pSelectableRow", "pSelectableRowIndex", "pSelectableRowDisabled"] }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i9.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: DynamicFieldWrapperComponent, selector: "sia-dynamic-field-wrapper", inputs: ["field", "form", "mode"] }, { kind: "
|
|
567
|
+
`, isInline: true, styles: [".lookup-field{width:100%;position:relative}.lookup-input-group{position:relative;width:100%;.lookup-display{width:100%;cursor:pointer;height:2.857rem;padding:.75rem 4rem .75rem .75rem;font-size:1rem;line-height:1.5;box-sizing:border-box;display:flex;align-items:center;&:focus{outline:none}&:hover{background:transparent}}.lookup-buttons{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px;z-index:10}::ng-deep .p-button{width:2rem!important;height:2rem!important;min-width:2rem!important;min-height:2rem!important;padding:0!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box!important;.p-button-icon{margin:0!important;font-size:.875rem!important}.p-button-label{display:none!important}}.autocomplete-suggestions{position:absolute;top:100%;left:0;right:0;z-index:1000;background:var(--p-surface-0, #fff);border:1px solid var(--p-surface-300, #d1d5db);border-top:none;border-radius:0 0 6px 6px;max-height:200px;overflow-y:auto;box-shadow:0 4px 6px #0000001a;.suggestion-item{padding:.625rem .75rem;cursor:pointer;font-size:.875rem;color:var(--p-text-color, #333);transition:background .15s;&:hover{background:var(--p-surface-100, #f3f4f6)}&.suggestion-loading{color:var(--p-text-muted-color, #999);cursor:default;font-style:italic}}}}.lookup-dialog-content{height:100%;display:flex;flex-direction:column;padding:0;.search-wrapper{position:relative;margin-bottom:16px;width:100%;.search-input-full{width:100%;padding-right:5.5rem}.search-buttons-inside{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px;::ng-deep .p-button{width:2.5rem!important;height:2.5rem!important}}}.lookup-table{flex:1;.empty-state{text-align:center;padding:32px;color:var(--p-text-color-secondary);i{font-size:48px;margin-bottom:16px;display:block}p{margin:8px 0;font-size:16px}small{font-size:14px}}}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "variant", "style", "styleClass", "badgeClass", "badgeSeverity", "ariaLabel", "autofocus", "fluid", "buttonProps"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i5.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i6.InputText, selector: "[pInputText]", inputs: ["variant", "fluid", "pSize"] }, { kind: "ngmodule", type: DialogModule }, { kind: "component", type: i7.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "closeButtonProps", "maximizeButtonProps", "visible", "style", "position", "role", "content", "contentTemplate", "footerTemplate", "closeIconTemplate", "maximizeIconTemplate", "minimizeIconTemplate", "headlessTemplate"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "ngmodule", type: TableModule }, { kind: "component", type: i8.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "size", "showGridlines", "stripedRows", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "virtualRowHeight", "selectAll"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i8.SelectableRow, selector: "[pSelectableRow]", inputs: ["pSelectableRow", "pSelectableRowIndex", "pSelectableRowDisabled"] }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i9.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "ngmodule", type: OverlayPanelModule }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: DynamicFieldWrapperComponent, selector: "sia-dynamic-field-wrapper", inputs: ["field", "form", "mode"] }, { kind: "directive", type: TableLoadingDirective, selector: "p-table[siaTableLoading]", inputs: ["loading", "siaLoadingVariant", "siaLoadingColor", "siaLoadingSize"] }] });
|
|
440
568
|
}
|
|
441
569
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DynamicFieldLookupComponent, decorators: [{
|
|
442
570
|
type: Component,
|
|
@@ -449,9 +577,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
449
577
|
DialogModule,
|
|
450
578
|
TableModule,
|
|
451
579
|
TooltipModule,
|
|
580
|
+
OverlayPanelModule,
|
|
452
581
|
TranslatePipe,
|
|
453
582
|
DynamicFieldWrapperComponent,
|
|
454
|
-
|
|
583
|
+
TableLoadingDirective
|
|
455
584
|
], template: `
|
|
456
585
|
<sia-dynamic-field-wrapper [field]="field" [form]="form" [mode]="mode">
|
|
457
586
|
<div [formGroup]="form" class="lookup-field" [ngClass]="{'disabled': isFieldDisabled()}">
|
|
@@ -459,7 +588,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
459
588
|
<input type="hidden" [formControlName]="field.field" />
|
|
460
589
|
|
|
461
590
|
<div class="lookup-input-group">
|
|
591
|
+
<!-- Autocomplete mode: editable input -->
|
|
462
592
|
<input
|
|
593
|
+
*ngIf="isAutocomplete"
|
|
594
|
+
#autocompleteInput
|
|
595
|
+
pInputText
|
|
596
|
+
[value]="autocompleteText"
|
|
597
|
+
[placeholder]="getPlaceholder()"
|
|
598
|
+
[class.p-invalid]="isFieldInvalid()"
|
|
599
|
+
[disabled]="isFieldDisabled()"
|
|
600
|
+
class="lookup-display"
|
|
601
|
+
(input)="onAutocompleteInput($event)"
|
|
602
|
+
(focus)="onAutocompleteFocus()"
|
|
603
|
+
(blur)="onAutocompleteBlur()"
|
|
604
|
+
/>
|
|
605
|
+
<!-- Standard mode: readonly input -->
|
|
606
|
+
<input
|
|
607
|
+
*ngIf="!isAutocomplete"
|
|
463
608
|
pInputText
|
|
464
609
|
[value]="displayValue"
|
|
465
610
|
[placeholder]="getPlaceholder()"
|
|
@@ -469,6 +614,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
469
614
|
class="lookup-display"
|
|
470
615
|
(click)="openLookup()"
|
|
471
616
|
/>
|
|
617
|
+
<!-- Autocomplete suggestions dropdown -->
|
|
618
|
+
<div class="autocomplete-suggestions" *ngIf="showSuggestions && suggestions.length > 0">
|
|
619
|
+
<div
|
|
620
|
+
class="suggestion-item"
|
|
621
|
+
*ngFor="let item of suggestions"
|
|
622
|
+
(mousedown)="selectSuggestion(item)">
|
|
623
|
+
{{ formatDisplayValue(item) }}
|
|
624
|
+
</div>
|
|
625
|
+
</div>
|
|
626
|
+
<div class="autocomplete-suggestions" *ngIf="showSuggestions && suggestions.length === 0 && autocompleteLoading">
|
|
627
|
+
<div class="suggestion-item suggestion-loading">Buscando...</div>
|
|
628
|
+
</div>
|
|
472
629
|
<div class="lookup-buttons">
|
|
473
630
|
<p-button
|
|
474
631
|
*ngIf="currentValue"
|
|
@@ -544,18 +701,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
544
701
|
</div>
|
|
545
702
|
</div>
|
|
546
703
|
|
|
547
|
-
<!-- Loading State -->
|
|
548
|
-
<sia-loading *ngIf="loading" padding="2rem 0" [size]="48"></sia-loading>
|
|
549
|
-
|
|
550
704
|
<!-- Data Table -->
|
|
551
705
|
<p-table
|
|
552
|
-
*ngIf="!loading"
|
|
553
706
|
[value]="filteredData"
|
|
554
707
|
[paginator]="true"
|
|
555
708
|
[rows]="pageSize"
|
|
556
709
|
[totalRecords]="totalRecords"
|
|
557
710
|
[lazy]="true"
|
|
558
711
|
(onLazyLoad)="onPageChange($event)"
|
|
712
|
+
[loading]="loading" siaTableLoading
|
|
559
713
|
[showCurrentPageReport]="true"
|
|
560
714
|
currentPageReportTemplate="Mostrando {first} a {last} de {totalRecords} registros"
|
|
561
715
|
dataKey="id"
|
|
@@ -597,8 +751,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
597
751
|
</div>
|
|
598
752
|
</p-dialog>
|
|
599
753
|
</sia-dynamic-field-wrapper>
|
|
600
|
-
`, styles: [".lookup-field{width:100%;position:relative}.lookup-input-group{position:relative;width:100%;.lookup-display{width:100%;cursor:pointer;height:2.857rem;padding:.75rem 4rem .75rem .75rem;font-size:1rem;line-height:1.5;box-sizing:border-box;display:flex;align-items:center;&:focus{outline:none}&:hover{background:transparent}}.lookup-buttons{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px;z-index:10}::ng-deep .p-button{width:2rem!important;height:2rem!important;min-width:2rem!important;min-height:2rem!important;padding:0!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box!important;.p-button-icon{margin:0!important;font-size:.875rem!important}.p-button-label{display:none!important}}}.lookup-dialog-content{height:100%;display:flex;flex-direction:column;padding:0;.search-wrapper{position:relative;margin-bottom:16px;width:100%;.search-input-full{width:100%;padding-right:5.5rem}.search-buttons-inside{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px;::ng-deep .p-button{width:2.5rem!important;height:2.5rem!important}}}.lookup-table{flex:1;.empty-state{text-align:center;padding:32px;color:var(--p-text-color-secondary);i{font-size:48px;margin-bottom:16px;display:block}p{margin:8px 0;font-size:16px}small{font-size:14px}}}}\n"] }]
|
|
601
|
-
}], ctorParameters: () => [{ type: i1.TranslationService }
|
|
754
|
+
`, styles: [".lookup-field{width:100%;position:relative}.lookup-input-group{position:relative;width:100%;.lookup-display{width:100%;cursor:pointer;height:2.857rem;padding:.75rem 4rem .75rem .75rem;font-size:1rem;line-height:1.5;box-sizing:border-box;display:flex;align-items:center;&:focus{outline:none}&:hover{background:transparent}}.lookup-buttons{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px;z-index:10}::ng-deep .p-button{width:2rem!important;height:2rem!important;min-width:2rem!important;min-height:2rem!important;padding:0!important;margin:0!important;display:flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box!important;.p-button-icon{margin:0!important;font-size:.875rem!important}.p-button-label{display:none!important}}.autocomplete-suggestions{position:absolute;top:100%;left:0;right:0;z-index:1000;background:var(--p-surface-0, #fff);border:1px solid var(--p-surface-300, #d1d5db);border-top:none;border-radius:0 0 6px 6px;max-height:200px;overflow-y:auto;box-shadow:0 4px 6px #0000001a;.suggestion-item{padding:.625rem .75rem;cursor:pointer;font-size:.875rem;color:var(--p-text-color, #333);transition:background .15s;&:hover{background:var(--p-surface-100, #f3f4f6)}&.suggestion-loading{color:var(--p-text-muted-color, #999);cursor:default;font-style:italic}}}}.lookup-dialog-content{height:100%;display:flex;flex-direction:column;padding:0;.search-wrapper{position:relative;margin-bottom:16px;width:100%;.search-input-full{width:100%;padding-right:5.5rem}.search-buttons-inside{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;gap:2px;::ng-deep .p-button{width:2.5rem!important;height:2.5rem!important}}}.lookup-table{flex:1;.empty-state{text-align:center;padding:32px;color:var(--p-text-color-secondary);i{font-size:48px;margin-bottom:16px;display:block}p{margin:8px 0;font-size:16px}small{font-size:14px}}}}\n"] }]
|
|
755
|
+
}], ctorParameters: () => [{ type: i1.TranslationService }], propDecorators: { field: [{
|
|
602
756
|
type: Input
|
|
603
757
|
}], form: [{
|
|
604
758
|
type: Input
|
|
@@ -607,4 +761,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
607
761
|
}], mode: [{
|
|
608
762
|
type: Input
|
|
609
763
|
}] } });
|
|
610
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field-lookup.component.js","sourceRoot":"","sources":["../../../../../../projects/components-ai/src/lib/components/dynamic-form/fields/dynamic-field-lookup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ChangeDetectorRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup, ReactiveFormsModule, FormsModule } from '@angular/forms';\nimport { ButtonModule } from 'primeng/button';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { DialogModule } from 'primeng/dialog';\nimport { TableModule } from 'primeng/table';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { DynamicFormFieldConfig } from '../models/dynamic-form.models';\nimport { TranslatePipe } from '../../../pipes/translate.pipe';\nimport { TranslationHelper } from '../../../utils/translation.helper';\nimport { TranslationService } from '../../../services/translation.service';\nimport { DynamicFieldWrapperComponent } from './dynamic-field-wrapper.component';\nimport { LookupColumn } from '../../../models/entity-list.config';\nimport { LoadingComponent } from '../../loading/loading.component';\n\n@Component({\n  selector: 'sia-dynamic-field-lookup',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    ButtonModule,\n    InputTextModule,\n    DialogModule,\n    TableModule,\n    TooltipModule,\n    TranslatePipe,\n    DynamicFieldWrapperComponent,\n    LoadingComponent\n  ],\n  template: `\n    <sia-dynamic-field-wrapper [field]=\"field\" [form]=\"form\" [mode]=\"mode\">\n      <div [formGroup]=\"form\" class=\"lookup-field\" [ngClass]=\"{'disabled': isFieldDisabled()}\">\n        <!-- Hidden input para o formControl -->\n        <input type=\"hidden\" [formControlName]=\"field.field\" />\n        \n        <div class=\"lookup-input-group\">\n          <input\n            pInputText\n            [value]=\"displayValue\"\n            [placeholder]=\"getPlaceholder()\"\n            [class.p-invalid]=\"isFieldInvalid()\"\n            [disabled]=\"isFieldDisabled()\"\n            readonly\n            class=\"lookup-display\"\n            (click)=\"openLookup()\"\n          />\n          <div class=\"lookup-buttons\">\n            <p-button\n              *ngIf=\"currentValue\"\n              icon=\"pi pi-trash\"\n              severity=\"danger\"\n              [text]=\"true\"\n              [rounded]=\"true\"\n              (onClick)=\"clearValue()\"\n              [disabled]=\"isFieldDisabled()\"\n              pTooltip=\"Limpar\"\n              tooltipPosition=\"top\"\n              size=\"small\"\n            ></p-button>\n            <p-button\n              icon=\"pi pi-search\"\n              severity=\"secondary\"\n              [text]=\"true\"\n              [rounded]=\"true\"\n              (onClick)=\"openLookup()\"\n              [disabled]=\"isFieldDisabled()\"\n              pTooltip=\"Buscar\"\n              tooltipPosition=\"top\"\n              size=\"small\"\n            ></p-button>\n          </div>\n        </div>\n      </div>\n\n      <!-- Lookup Dialog -->\n      <p-dialog\n        [(visible)]=\"showLookupDialog\"\n        [modal]=\"true\"\n        [style]=\"{ width: '800px', maxHeight: '80vh' }\"\n        [contentStyle]=\"{ maxHeight: 'calc(80vh - 120px)', overflow: 'auto' }\"\n        [draggable]=\"false\"\n        [resizable]=\"true\"\n        [header]=\"'Selecionar ' + (field.label | translate)\"\n        [appendTo]=\"'body'\"\n        (onHide)=\"onDialogHide()\"\n      >\n        <div class=\"lookup-dialog-content\">\n          <!-- Search Input -->\n          <div class=\"search-wrapper\">\n            <input\n              pInputText\n              [(ngModel)]=\"searchTerm\"\n              [placeholder]=\"'Buscar ' + (field.label | translate).toLowerCase() + '...'\"\n              (keydown.enter)=\"onSearch()\"\n              class=\"search-input-full\"\n            />\n            <div class=\"search-buttons-inside\">\n              <p-button\n                *ngIf=\"searchTerm\"\n                icon=\"pi pi-trash\"\n                severity=\"danger\"\n                [text]=\"true\"\n                [rounded]=\"true\"\n                (onClick)=\"clearSearch()\"\n                class=\"search-button-clear\"\n                pTooltip=\"Limpar busca\"\n                tooltipPosition=\"top\"\n              ></p-button>\n              <p-button\n                icon=\"pi pi-search\"\n                severity=\"secondary\"\n                [text]=\"true\"\n                [rounded]=\"true\"\n                (onClick)=\"onSearch()\"\n                class=\"search-button-search\"\n                pTooltip=\"Buscar\"\n                tooltipPosition=\"top\"\n              ></p-button>\n            </div>\n          </div>\n\n          <!-- Loading State -->\n          <sia-loading *ngIf=\"loading\" padding=\"2rem 0\" [size]=\"48\"></sia-loading>\n\n          <!-- Data Table -->\n          <p-table\n            *ngIf=\"!loading\"\n            [value]=\"filteredData\"\n            [paginator]=\"true\"\n            [rows]=\"pageSize\"\n            [totalRecords]=\"totalRecords\"\n            [lazy]=\"true\"\n            (onLazyLoad)=\"onPageChange($event)\"\n            [showCurrentPageReport]=\"true\"\n            currentPageReportTemplate=\"Mostrando {first} a {last} de {totalRecords} registros\"\n            dataKey=\"id\"\n            [rowHover]=\"true\"\n            responsiveLayout=\"scroll\"\n            styleClass=\"p-datatable-striped lookup-table\"\n            [(selection)]=\"selectedItem\"\n            (onRowSelect)=\"onRowSelect($event)\"\n            selectionMode=\"single\"\n          >\n            <ng-template pTemplate=\"header\">\n              <tr>\n                <th *ngFor=\"let col of columns\" [style.width]=\"col.width\">\n                  {{ col.header }}\n                </th>\n              </tr>\n            </ng-template>\n\n            <ng-template pTemplate=\"body\" let-item>\n              <tr [pSelectableRow]=\"item\">\n                <td *ngFor=\"let col of columns\">\n                  {{ getFieldValue(item, col.field) }}\n                </td>\n              </tr>\n            </ng-template>\n\n            <ng-template pTemplate=\"emptymessage\">\n              <tr>\n                <td [attr.colspan]=\"columns.length\" class=\"empty-message\">\n                  <div class=\"empty-state\">\n                    <i class=\"pi pi-search\"></i>\n                    <p>Nenhum registro encontrado</p>\n                    <small>Tente ajustar os termos de busca</small>\n                  </div>\n                </td>\n              </tr>\n            </ng-template>\n          </p-table>\n        </div>\n      </p-dialog>\n    </sia-dynamic-field-wrapper>\n  `,\n  styles: [`\n    .lookup-field {\n      width: 100%;\n      position: relative;\n    }\n\n    .lookup-input-group {\n      position: relative;\n      width: 100%;\n      \n      .lookup-display {\n        width: 100%;\n        cursor: pointer;\n        height: 2.857rem;\n        padding: 0.75rem 4rem 0.75rem 0.75rem;\n        font-size: 1rem;\n        line-height: 1.5;\n        box-sizing: border-box;\n        display: flex;\n        align-items: center;\n        \n        &:focus {\n          outline: none;\n        }\n        \n        &:hover {\n          background: transparent;\n        }\n      }\n\n      .lookup-buttons {\n        position: absolute;\n        right: 4px;\n        top: 50%;\n        transform: translateY(-50%);\n        display: flex;\n        gap: 2px;\n        z-index: 10;\n      }\n\n      ::ng-deep .p-button {\n        width: 2rem !important;\n        height: 2rem !important;\n        min-width: 2rem !important;\n        min-height: 2rem !important;\n        padding: 0 !important;\n        margin: 0 !important;\n        display: flex !important;\n        align-items: center !important;\n        justify-content: center !important;\n        box-sizing: border-box !important;\n        \n        .p-button-icon {\n          margin: 0 !important;\n          font-size: 0.875rem !important;\n        }\n        \n        .p-button-label {\n          display: none !important;\n        }\n      }\n    }\n\n    .lookup-dialog-content {\n      height: 100%;\n      display: flex;\n      flex-direction: column;\n      padding: 0;\n\n      .search-wrapper {\n        position: relative;\n        margin-bottom: 16px;\n        width: 100%;\n\n        .search-input-full {\n          width: 100%;\n          padding-right: 5.5rem;\n        }\n\n        .search-buttons-inside {\n          position: absolute;\n          right: 4px;\n          top: 50%;\n          transform: translateY(-50%);\n          display: flex;\n          gap: 2px;\n          \n          ::ng-deep .p-button {\n            width: 2.5rem !important;\n            height: 2.5rem !important;\n          }\n        }\n      }\n\n      .lookup-table {\n        flex: 1;\n        \n        .empty-state {\n          text-align: center;\n          padding: 32px;\n          color: var(--p-text-color-secondary);\n\n          i {\n            font-size: 48px;\n            margin-bottom: 16px;\n            display: block;\n          }\n\n          p {\n            margin: 8px 0;\n            font-size: 16px;\n          }\n\n          small {\n            font-size: 14px;\n          }\n        }\n      }\n    }\n  `]\n})\nexport class DynamicFieldLookupComponent implements OnInit {\n  @Input() field!: DynamicFormFieldConfig;\n  @Input() form!: FormGroup;\n  @Input() formGroup!: FormGroup;\n  @Input() mode: 'form' | 'filter' = 'form';\n\n  displayValue: string = '';\n  showLookupDialog: boolean = false;\n  loading: boolean = false;\n  searchTerm: string = '';\n  \n  data: any[] = [];\n  filteredData: any[] = [];\n  totalRecords: number = 0;\n  currentPage: number = 0;\n  pageSize: number = 5;\n  selectedItem: any = null;\n  private skipNextLazyLoad: boolean = false;\n  \n  columns: LookupColumn[] = [];\n  displayField: string = 'name';\n  valueField: string = 'id';\n  searchFields: string[] = ['name'];\n\n  constructor(private translationService: TranslationService, private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.setupLookupConfig();\n    this.watchValueChanges();\n  }\n\n  private watchValueChanges(): void {\n    const control = this.getFormControl();\n    if (control) {\n      // Carregar valor inicial\n      if (control.value) {\n        this.handleValueDisplay(control.value);\n      }\n      \n      // Observar mudanças\n      control.valueChanges.subscribe((value: any) => {\n        if (value !== null && value !== undefined && value !== '') {\n          this.handleValueDisplay(value);\n        } else {\n          this.displayValue = '';\n        }\n      });\n    }\n  }\n\n  /**\n   * Obtém o FormControl, lidando com campos aninhados (com ponto no nome)\n   */\n  private getFormControl() {\n    if (!this.field?.field) {\n      return null;\n    }\n\n    // Acessa diretamente via controls[] pois form.get() não funciona com campos que têm ponto\n    return this.form.controls[this.field.field];\n  }\n\n  private get value(): any {\n    const control = this.getFormControl();\n    return control?.value;\n  }\n\n  get currentValue(): any {\n    return this.value;\n  }\n\n  private setValue(value: any): void {\n    const control = this.getFormControl();\n    control?.setValue(value);\n  }\n\n  private setupLookupConfig(): void {\n    if (this.field) {\n      this.displayField = this.field.lookupDisplayField || 'name';\n      this.valueField = this.field.lookupValueField || 'id';\n      this.searchFields = this.field.lookupSearchFields || ['name'];\n      this.columns = this.field.lookupColumns || [\n        { field: this.displayField, header: 'Nome', width: '100%' }\n      ];\n    }\n  }\n\n  private handleValueDisplay(value: any): void {\n    if (value === null || value === undefined || value === '') {\n      this.displayValue = '';\n      return;\n    }\n    \n    if (typeof value === 'object' && value !== null) {\n      this.displayValue = this.formatDisplayValue(value);\n      // Keep the full object in the form control\n      return;\n    }\n    \n    // Se é um ID (string ou number), não fazer requisição\n    // Deixar vazio e só carregar quando abrir o lookup\n    if (typeof value === 'string' || typeof value === 'number') {\n      this.displayValue = '';\n      return;\n    }\n  }\n\n  private formatDisplayValue(item: any): string {\n    if (!item) return '';\n    \n    if (this.field?.lookupDisplayFields && this.field.lookupDisplayFields.length > 0) {\n      const values = this.field.lookupDisplayFields\n        .map(fieldName => this.getFieldValue(item, fieldName))\n        .filter(value => value !== null && value !== undefined && value !== '');\n      \n      return values.join(' - ');\n    }\n    \n    return this.getFieldValue(item, this.displayField) || '';\n  }\n\n  isFieldInvalid(): boolean {\n    const control = this.getFormControl();\n    return !!(control && control.invalid && (control.dirty || control.touched));\n  }\n\n  isFieldDisabled(): boolean {\n    const control = this.getFormControl();\n    return control?.disabled || false;\n  }\n\n  getPlaceholder(): string {\n    return TranslationHelper.getFilterPlaceholder(\n      this.translationService,\n      this.mode,\n      this.field.label,\n      this.field.placeholder\n    );\n  }\n\n  openLookup(): void {\n    if (this.isFieldDisabled()) {\n      return;\n    }\n    \n    this.updateSelectedItem();\n    \n    this.showLookupDialog = true;\n    this.currentPage = 0;\n    this.searchTerm = '';\n    // Delay loadData to next macrotask to avoid NG0100\n    // (p-dialog triggers a CD cycle on open that conflicts with loading state change)\n    setTimeout(() => this.loadData(), 0);\n  }\n\n  onDialogHide(): void {\n    this.searchTerm = '';\n    this.currentPage = 0;\n  }\n\n  onPageChange(event: any): void {\n    if (!this.showLookupDialog) {\n      return;\n    }\n\n    // p-table fires onLazyLoad when it first renders — skip it since\n    // openLookup already triggered loadData\n    if (this.skipNextLazyLoad) {\n      this.skipNextLazyLoad = false;\n      return;\n    }\n    \n    this.currentPage = event.first / event.rows;\n    this.loadData();\n  }\n\n  private loadData(): void {\n    if (!this.field?.lookupService) {\n      return;\n    }\n\n    this.loading = true;\n    \n    const listParams: any = { \n      page: this.currentPage,\n      size: this.pageSize\n    };\n\n    if (this.field.lookupSort) {\n      listParams.sort = this.field.lookupSort;\n    }\n    \n    if (this.searchTerm.trim()) {\n      const term = this.searchTerm.trim();\n      const filterConditions: string[] = [];\n      const isNumericTerm = !isNaN(Number(term)) && term !== '';\n      \n      this.searchFields.forEach(field => {\n        const column = this.columns.find(col => col.field === field);\n        const fieldType = column?.type || 'text';\n        \n        if (fieldType === 'number') {\n          if (isNumericTerm) {\n            filterConditions.push(`${field} eq ${term}`);\n          }\n        } else {\n          const upperTerm = term.toUpperCase();\n          filterConditions.push(`UPPER(${field}) like '%${upperTerm}%'`);\n        }\n      });\n      \n      if (filterConditions.length > 0) {\n        listParams.filterQuery = filterConditions.join(' or ');\n      }\n    }\n    \n    if (this.field.lookupFilters) {\n      Object.keys(this.field.lookupFilters).forEach(key => {\n        listParams[key] = this.field.lookupFilters![key];\n      });\n    }\n    \n    if (this.field.lookupDynamicFilters && this.formGroup) {\n      const dynamicFilters = this.field.lookupDynamicFilters(this.formGroup.value);\n      \n      const dynamicFilterConditions: string[] = [];\n      Object.keys(dynamicFilters).forEach(key => {\n        const value = dynamicFilters[key];\n        if (value !== null && value !== undefined) {\n          dynamicFilterConditions.push(`${key} eq '${value}'`);\n        }\n      });\n      \n      if (dynamicFilterConditions.length > 0) {\n        const dynamicFilterQuery = dynamicFilterConditions.join(' and ');\n        if (listParams.filterQuery) {\n          listParams.filterQuery = `(${listParams.filterQuery}) and (${dynamicFilterQuery})`;\n        } else {\n          listParams.filterQuery = dynamicFilterQuery;\n        }\n      }\n    }\n    \n    this.field.lookupService.list(listParams).subscribe({\n      next: (response: any) => {\n        this.data = response.contents || [];\n        this.filteredData = [...this.data];\n        this.totalRecords = response.totalElements || 0;\n        \n        this.updateSelectedItem();\n        \n        // Após carregar os dados da grid, se temos um valor selecionado mas sem displayValue,\n        // tentar encontrar o item nos dados carregados\n        if (this.value && !this.displayValue) {\n          const item = this.filteredData.find(i => i[this.valueField] === this.value);\n          if (item) {\n            this.displayValue = this.formatDisplayValue(item);\n          }\n        }\n        \n        this.loading = false;\n        // The table will fire onLazyLoad when it first renders — skip it\n        this.skipNextLazyLoad = true;\n      },\n      error: (_error: unknown) => {\n        this.data = [];\n        this.filteredData = [];\n        this.totalRecords = 0;\n        this.loading = false;\n        this.skipNextLazyLoad = true;\n      }\n    });\n  }\n\n  private updateSelectedItem(): void {\n    if (!this.value) {\n      this.selectedItem = null;\n      return;\n    }\n    \n    const item = this.filteredData.find(i => i[this.valueField] === this.value);\n    if (item) {\n      this.selectedItem = item;\n    }\n  }\n\n  onSearch(): void {\n    if (!this.showLookupDialog) {\n      return;\n    }\n    \n    this.currentPage = 0;\n    this.loadData();\n  }\n\n  clearSearch(): void {\n    this.searchTerm = '';\n    this.currentPage = 0;\n    this.loadData();\n  }\n\n  selectItem(item: any): void {\n    // Always set the full object, not just the ID\n    this.setValue(item);\n    this.displayValue = this.formatDisplayValue(item);\n    this.showLookupDialog = false;\n  }\n\n  onRowSelect(event: any): void {\n    this.selectItem(event.data);\n  }\n\n  clearValue(): void {\n    this.setValue(null);\n    this.displayValue = '';\n    this.selectedItem = null;\n  }\n\n  getFieldValue(item: any, field: string): any {\n    return field.split('.').reduce((obj, key) => obj?.[key], item) || '';\n  }\n}\n"]}
|
|
764
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field-lookup.component.js","sourceRoot":"","sources":["../../../../../../projects/components-ai/src/lib/components/dynamic-form/fields/dynamic-field-lookup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup, ReactiveFormsModule, FormsModule } from '@angular/forms';\nimport { ButtonModule } from 'primeng/button';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { DialogModule } from 'primeng/dialog';\nimport { TableModule } from 'primeng/table';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { OverlayPanelModule } from 'primeng/overlaypanel';\nimport { DynamicFormFieldConfig } from '../models/dynamic-form.models';\nimport { TranslatePipe } from '../../../pipes/translate.pipe';\nimport { TranslationHelper } from '../../../utils/translation.helper';\nimport { TranslationService } from '../../../services/translation.service';\nimport { DynamicFieldWrapperComponent } from './dynamic-field-wrapper.component';\nimport { LookupColumn } from '../../../models/entity-list.config';\nimport { TableLoadingDirective } from '../../../directives/table-loading/table-loading.directive';\nimport { Subject, Subscription } from 'rxjs';\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\n\n@Component({\n  selector: 'sia-dynamic-field-lookup',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    ButtonModule,\n    InputTextModule,\n    DialogModule,\n    TableModule,\n    TooltipModule,\n    OverlayPanelModule,\n    TranslatePipe,\n    DynamicFieldWrapperComponent,\n    TableLoadingDirective\n  ],\n  template: `\n    <sia-dynamic-field-wrapper [field]=\"field\" [form]=\"form\" [mode]=\"mode\">\n      <div [formGroup]=\"form\" class=\"lookup-field\" [ngClass]=\"{'disabled': isFieldDisabled()}\">\n        <!-- Hidden input para o formControl -->\n        <input type=\"hidden\" [formControlName]=\"field.field\" />\n        \n        <div class=\"lookup-input-group\">\n          <!-- Autocomplete mode: editable input -->\n          <input\n            *ngIf=\"isAutocomplete\"\n            #autocompleteInput\n            pInputText\n            [value]=\"autocompleteText\"\n            [placeholder]=\"getPlaceholder()\"\n            [class.p-invalid]=\"isFieldInvalid()\"\n            [disabled]=\"isFieldDisabled()\"\n            class=\"lookup-display\"\n            (input)=\"onAutocompleteInput($event)\"\n            (focus)=\"onAutocompleteFocus()\"\n            (blur)=\"onAutocompleteBlur()\"\n          />\n          <!-- Standard mode: readonly input -->\n          <input\n            *ngIf=\"!isAutocomplete\"\n            pInputText\n            [value]=\"displayValue\"\n            [placeholder]=\"getPlaceholder()\"\n            [class.p-invalid]=\"isFieldInvalid()\"\n            [disabled]=\"isFieldDisabled()\"\n            readonly\n            class=\"lookup-display\"\n            (click)=\"openLookup()\"\n          />\n          <!-- Autocomplete suggestions dropdown -->\n          <div class=\"autocomplete-suggestions\" *ngIf=\"showSuggestions && suggestions.length > 0\">\n            <div\n              class=\"suggestion-item\"\n              *ngFor=\"let item of suggestions\"\n              (mousedown)=\"selectSuggestion(item)\">\n              {{ formatDisplayValue(item) }}\n            </div>\n          </div>\n          <div class=\"autocomplete-suggestions\" *ngIf=\"showSuggestions && suggestions.length === 0 && autocompleteLoading\">\n            <div class=\"suggestion-item suggestion-loading\">Buscando...</div>\n          </div>\n          <div class=\"lookup-buttons\">\n            <p-button\n              *ngIf=\"currentValue\"\n              icon=\"pi pi-trash\"\n              severity=\"danger\"\n              [text]=\"true\"\n              [rounded]=\"true\"\n              (onClick)=\"clearValue()\"\n              [disabled]=\"isFieldDisabled()\"\n              pTooltip=\"Limpar\"\n              tooltipPosition=\"top\"\n              size=\"small\"\n            ></p-button>\n            <p-button\n              icon=\"pi pi-search\"\n              severity=\"secondary\"\n              [text]=\"true\"\n              [rounded]=\"true\"\n              (onClick)=\"openLookup()\"\n              [disabled]=\"isFieldDisabled()\"\n              pTooltip=\"Buscar\"\n              tooltipPosition=\"top\"\n              size=\"small\"\n            ></p-button>\n          </div>\n        </div>\n      </div>\n\n      <!-- Lookup Dialog -->\n      <p-dialog\n        [(visible)]=\"showLookupDialog\"\n        [modal]=\"true\"\n        [style]=\"{ width: '800px', maxHeight: '80vh' }\"\n        [contentStyle]=\"{ maxHeight: 'calc(80vh - 120px)', overflow: 'auto' }\"\n        [draggable]=\"false\"\n        [resizable]=\"true\"\n        [header]=\"'Selecionar ' + (field.label | translate)\"\n        [appendTo]=\"'body'\"\n        (onHide)=\"onDialogHide()\"\n      >\n        <div class=\"lookup-dialog-content\">\n          <!-- Search Input -->\n          <div class=\"search-wrapper\">\n            <input\n              pInputText\n              [(ngModel)]=\"searchTerm\"\n              [placeholder]=\"'Buscar ' + (field.label | translate).toLowerCase() + '...'\"\n              (keydown.enter)=\"onSearch()\"\n              class=\"search-input-full\"\n            />\n            <div class=\"search-buttons-inside\">\n              <p-button\n                *ngIf=\"searchTerm\"\n                icon=\"pi pi-trash\"\n                severity=\"danger\"\n                [text]=\"true\"\n                [rounded]=\"true\"\n                (onClick)=\"clearSearch()\"\n                class=\"search-button-clear\"\n                pTooltip=\"Limpar busca\"\n                tooltipPosition=\"top\"\n              ></p-button>\n              <p-button\n                icon=\"pi pi-search\"\n                severity=\"secondary\"\n                [text]=\"true\"\n                [rounded]=\"true\"\n                (onClick)=\"onSearch()\"\n                class=\"search-button-search\"\n                pTooltip=\"Buscar\"\n                tooltipPosition=\"top\"\n              ></p-button>\n            </div>\n          </div>\n\n          <!-- Data Table -->\n          <p-table\n            [value]=\"filteredData\"\n            [paginator]=\"true\"\n            [rows]=\"pageSize\"\n            [totalRecords]=\"totalRecords\"\n            [lazy]=\"true\"\n            (onLazyLoad)=\"onPageChange($event)\"\n            [loading]=\"loading\" siaTableLoading\n            [showCurrentPageReport]=\"true\"\n            currentPageReportTemplate=\"Mostrando {first} a {last} de {totalRecords} registros\"\n            dataKey=\"id\"\n            [rowHover]=\"true\"\n            responsiveLayout=\"scroll\"\n            styleClass=\"p-datatable-striped lookup-table\"\n            [(selection)]=\"selectedItem\"\n            (onRowSelect)=\"onRowSelect($event)\"\n            selectionMode=\"single\"\n          >\n            <ng-template pTemplate=\"header\">\n              <tr>\n                <th *ngFor=\"let col of columns\" [style.width]=\"col.width\">\n                  {{ col.header }}\n                </th>\n              </tr>\n            </ng-template>\n\n            <ng-template pTemplate=\"body\" let-item>\n              <tr [pSelectableRow]=\"item\">\n                <td *ngFor=\"let col of columns\">\n                  {{ getFieldValue(item, col.field) }}\n                </td>\n              </tr>\n            </ng-template>\n\n            <ng-template pTemplate=\"emptymessage\">\n              <tr>\n                <td [attr.colspan]=\"columns.length\" class=\"empty-message\">\n                  <div class=\"empty-state\">\n                    <i class=\"pi pi-search\"></i>\n                    <p>Nenhum registro encontrado</p>\n                    <small>Tente ajustar os termos de busca</small>\n                  </div>\n                </td>\n              </tr>\n            </ng-template>\n          </p-table>\n        </div>\n      </p-dialog>\n    </sia-dynamic-field-wrapper>\n  `,\n  styles: [`\n    .lookup-field {\n      width: 100%;\n      position: relative;\n    }\n\n    .lookup-input-group {\n      position: relative;\n      width: 100%;\n      \n      .lookup-display {\n        width: 100%;\n        cursor: pointer;\n        height: 2.857rem;\n        padding: 0.75rem 4rem 0.75rem 0.75rem;\n        font-size: 1rem;\n        line-height: 1.5;\n        box-sizing: border-box;\n        display: flex;\n        align-items: center;\n        \n        &:focus {\n          outline: none;\n        }\n        \n        &:hover {\n          background: transparent;\n        }\n      }\n\n      .lookup-buttons {\n        position: absolute;\n        right: 4px;\n        top: 50%;\n        transform: translateY(-50%);\n        display: flex;\n        gap: 2px;\n        z-index: 10;\n      }\n\n      ::ng-deep .p-button {\n        width: 2rem !important;\n        height: 2rem !important;\n        min-width: 2rem !important;\n        min-height: 2rem !important;\n        padding: 0 !important;\n        margin: 0 !important;\n        display: flex !important;\n        align-items: center !important;\n        justify-content: center !important;\n        box-sizing: border-box !important;\n        \n        .p-button-icon {\n          margin: 0 !important;\n          font-size: 0.875rem !important;\n        }\n        \n        .p-button-label {\n          display: none !important;\n        }\n      }\n\n      .autocomplete-suggestions {\n        position: absolute;\n        top: 100%;\n        left: 0;\n        right: 0;\n        z-index: 1000;\n        background: var(--p-surface-0, #fff);\n        border: 1px solid var(--p-surface-300, #d1d5db);\n        border-top: none;\n        border-radius: 0 0 6px 6px;\n        max-height: 200px;\n        overflow-y: auto;\n        box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);\n\n        .suggestion-item {\n          padding: 0.625rem 0.75rem;\n          cursor: pointer;\n          font-size: 0.875rem;\n          color: var(--p-text-color, #333);\n          transition: background 0.15s;\n\n          &:hover {\n            background: var(--p-surface-100, #f3f4f6);\n          }\n\n          &.suggestion-loading {\n            color: var(--p-text-muted-color, #999);\n            cursor: default;\n            font-style: italic;\n          }\n        }\n      }\n    }\n\n    .lookup-dialog-content {\n      height: 100%;\n      display: flex;\n      flex-direction: column;\n      padding: 0;\n\n      .search-wrapper {\n        position: relative;\n        margin-bottom: 16px;\n        width: 100%;\n\n        .search-input-full {\n          width: 100%;\n          padding-right: 5.5rem;\n        }\n\n        .search-buttons-inside {\n          position: absolute;\n          right: 4px;\n          top: 50%;\n          transform: translateY(-50%);\n          display: flex;\n          gap: 2px;\n          \n          ::ng-deep .p-button {\n            width: 2.5rem !important;\n            height: 2.5rem !important;\n          }\n        }\n      }\n\n      .lookup-table {\n        flex: 1;\n        \n        .empty-state {\n          text-align: center;\n          padding: 32px;\n          color: var(--p-text-color-secondary);\n\n          i {\n            font-size: 48px;\n            margin-bottom: 16px;\n            display: block;\n          }\n\n          p {\n            margin: 8px 0;\n            font-size: 16px;\n          }\n\n          small {\n            font-size: 14px;\n          }\n        }\n      }\n    }\n  `]\n})\nexport class DynamicFieldLookupComponent implements OnInit, OnDestroy {\n  @Input() field!: DynamicFormFieldConfig;\n  @Input() form!: FormGroup;\n  @Input() formGroup!: FormGroup;\n  @Input() mode: 'form' | 'filter' = 'form';\n\n  displayValue: string = '';\n  showLookupDialog: boolean = false;\n  loading: boolean = false;\n  searchTerm: string = '';\n  \n  data: any[] = [];\n  filteredData: any[] = [];\n  totalRecords: number = 0;\n  currentPage: number = 0;\n  pageSize: number = 10;\n  selectedItem: any = null;\n  \n  columns: LookupColumn[] = [];\n  displayField: string = 'name';\n  valueField: string = 'id';\n  searchFields: string[] = ['name'];\n\n  // Autocomplete state\n  autocompleteText: string = '';\n  suggestions: any[] = [];\n  showSuggestions: boolean = false;\n  autocompleteLoading: boolean = false;\n  private autocompleteSubject = new Subject<string>();\n  private autocompleteSub?: Subscription;\n\n  get isAutocomplete(): boolean {\n    return this.field?.lookupAutocomplete === true;\n  }\n\n  private get minLength(): number {\n    return this.field?.lookupAutocompleteMinLength ?? 2;\n  }\n\n  constructor(private translationService: TranslationService) {}\n\n  ngOnInit(): void {\n    this.setupLookupConfig();\n    this.watchValueChanges();\n    this.setupAutocomplete();\n  }\n\n  ngOnDestroy(): void {\n    this.autocompleteSub?.unsubscribe();\n  }\n\n  private setupAutocomplete(): void {\n    if (!this.isAutocomplete) return;\n    this.autocompleteSub = this.autocompleteSubject.pipe(\n      debounceTime(300),\n      distinctUntilChanged()\n    ).subscribe(term => {\n      if (term.length >= this.minLength) {\n        this.searchSuggestions(term);\n      } else {\n        this.suggestions = [];\n        this.showSuggestions = false;\n      }\n    });\n  }\n\n  onAutocompleteInput(event: Event): void {\n    const value = (event.target as HTMLInputElement).value;\n    this.autocompleteText = value;\n    if (!value) {\n      this.clearValue();\n      this.suggestions = [];\n      this.showSuggestions = false;\n      return;\n    }\n    this.autocompleteSubject.next(value);\n  }\n\n  onAutocompleteFocus(): void {\n    if (this.autocompleteText.length >= this.minLength && this.suggestions.length > 0) {\n      this.showSuggestions = true;\n    }\n  }\n\n  onAutocompleteBlur(): void {\n    // Delay to allow click on suggestion\n    setTimeout(() => { this.showSuggestions = false; }, 200);\n  }\n\n  selectSuggestion(item: any): void {\n    this.setValue(item);\n    this.displayValue = this.formatDisplayValue(item);\n    this.autocompleteText = this.displayValue;\n    this.suggestions = [];\n    this.showSuggestions = false;\n  }\n\n  private searchSuggestions(term: string): void {\n    if (!this.field?.lookupService) return;\n    this.autocompleteLoading = true;\n    this.showSuggestions = true;\n\n    const listParams: any = { page: 0, size: 10 };\n\n    if (this.field.lookupSort) {\n      listParams.sort = this.field.lookupSort;\n    }\n\n    const filterConditions: string[] = [];\n    const isNumericTerm = !isNaN(Number(term)) && term !== '';\n\n    this.searchFields.forEach(field => {\n      const column = this.columns.find(col => col.field === field);\n      const fieldType = column?.type || 'text';\n\n      if (fieldType === 'number') {\n        if (isNumericTerm) {\n          filterConditions.push(`${field} eq ${term}`);\n        }\n      } else {\n        const upperTerm = term.toUpperCase();\n        filterConditions.push(`UPPER(${field}) like '%${upperTerm}%'`);\n      }\n    });\n\n    if (filterConditions.length > 0) {\n      listParams.filterQuery = filterConditions.join(' or ');\n    }\n\n    // Apply lookupFilters\n    if (this.field.lookupFilters) {\n      const extra = typeof this.field.lookupFilters === 'function'\n        ? this.field.lookupFilters(this.formGroup?.value || {})\n        : this.field.lookupFilters;\n      if (extra) {\n        listParams.filterQuery = listParams.filterQuery\n          ? `(${listParams.filterQuery}) and (${extra})`\n          : extra;\n      }\n    }\n\n    this.field.lookupService.list(listParams).subscribe({\n      next: (res: any) => {\n        this.suggestions = res.contents || [];\n        this.autocompleteLoading = false;\n      },\n      error: () => {\n        this.suggestions = [];\n        this.autocompleteLoading = false;\n      }\n    });\n  }\n\n  private watchValueChanges(): void {\n    const control = this.getFormControl();\n    if (control) {\n      // Carregar valor inicial\n      if (control.value) {\n        this.handleValueDisplay(control.value);\n      }\n      \n      // Observar mudanças\n      control.valueChanges.subscribe((value: any) => {\n        if (value !== null && value !== undefined && value !== '') {\n          this.handleValueDisplay(value);\n        } else {\n          this.displayValue = '';\n        }\n      });\n    }\n  }\n\n  /**\n   * Obtém o FormControl, lidando com campos aninhados (com ponto no nome)\n   */\n  private getFormControl() {\n    if (!this.field?.field) {\n      return null;\n    }\n\n    // Acessa diretamente via controls[] pois form.get() não funciona com campos que têm ponto\n    return this.form.controls[this.field.field];\n  }\n\n  private get value(): any {\n    const control = this.getFormControl();\n    return control?.value;\n  }\n\n  get currentValue(): any {\n    return this.value;\n  }\n\n  private setValue(value: any): void {\n    const control = this.getFormControl();\n    control?.setValue(value);\n  }\n\n  private setupLookupConfig(): void {\n    if (this.field) {\n      this.displayField = this.field.lookupDisplayField || 'name';\n      this.valueField = this.field.lookupValueField || 'id';\n      this.searchFields = this.field.lookupSearchFields || ['name'];\n      this.columns = this.field.lookupColumns || [\n        { field: this.displayField, header: 'Nome', width: '100%' }\n      ];\n    }\n  }\n\n  private handleValueDisplay(value: any): void {\n    if (value === null || value === undefined || value === '') {\n      this.displayValue = '';\n      this.autocompleteText = '';\n      return;\n    }\n    \n    if (typeof value === 'object' && value !== null) {\n      this.displayValue = this.formatDisplayValue(value);\n      this.autocompleteText = this.displayValue;\n      return;\n    }\n    \n    if (typeof value === 'string' || typeof value === 'number') {\n      this.displayValue = '';\n      this.autocompleteText = '';\n      return;\n    }\n  }\n\n  formatDisplayValue(item: any): string {\n    if (!item) return '';\n    \n    if (this.field?.lookupDisplayFields && this.field.lookupDisplayFields.length > 0) {\n      const values = this.field.lookupDisplayFields\n        .map(fieldName => this.getFieldValue(item, fieldName))\n        .filter(value => value !== null && value !== undefined && value !== '');\n      \n      return values.join(' - ');\n    }\n    \n    return this.getFieldValue(item, this.displayField) || '';\n  }\n\n  isFieldInvalid(): boolean {\n    const control = this.getFormControl();\n    return !!(control && control.invalid && (control.dirty || control.touched));\n  }\n\n  isFieldDisabled(): boolean {\n    const control = this.getFormControl();\n    return control?.disabled || false;\n  }\n\n  getPlaceholder(): string {\n    return TranslationHelper.getFilterPlaceholder(\n      this.translationService,\n      this.mode,\n      this.field.label,\n      this.field.placeholder\n    );\n  }\n\n  openLookup(): void {\n    if (this.isFieldDisabled()) {\n      return;\n    }\n    \n    this.updateSelectedItem();\n    \n    this.showLookupDialog = true;\n    this.currentPage = 0;\n    this.searchTerm = '';\n    // Delay loadData to next macrotask to avoid NG0100\n    // (p-dialog triggers a CD cycle on open that conflicts with loading state change)\n    setTimeout(() => this.loadData(), 0);\n  }\n\n  onDialogHide(): void {\n    this.searchTerm = '';\n    this.currentPage = 0;\n  }\n\n  onPageChange(event: any): void {\n    if (!this.showLookupDialog) {\n      return;\n    }\n\n    const newPage = event.first / event.rows;\n    if (newPage === this.currentPage && this.filteredData.length > 0) {\n      return;\n    }\n    \n    this.currentPage = newPage;\n    this.loadData();\n  }\n\n  private loadData(): void {\n    if (!this.field?.lookupService) {\n      return;\n    }\n\n    this.loading = true;\n    \n    const listParams: any = { \n      page: this.currentPage,\n      size: this.pageSize\n    };\n\n    if (this.field.lookupSort) {\n      listParams.sort = this.field.lookupSort;\n    }\n    \n    if (this.searchTerm.trim()) {\n      const term = this.searchTerm.trim();\n      const filterConditions: string[] = [];\n      const isNumericTerm = !isNaN(Number(term)) && term !== '';\n      \n      this.searchFields.forEach(field => {\n        const column = this.columns.find(col => col.field === field);\n        const fieldType = column?.type || 'text';\n        \n        if (fieldType === 'number') {\n          if (isNumericTerm) {\n            filterConditions.push(`${field} eq ${term}`);\n          }\n        } else {\n          const upperTerm = term.toUpperCase();\n          filterConditions.push(`UPPER(${field}) like '%${upperTerm}%'`);\n        }\n      });\n      \n      if (filterConditions.length > 0) {\n        listParams.filterQuery = filterConditions.join(' or ');\n      }\n    }\n    \n    if (this.field.lookupFilters) {\n      let extraFilter = '';\n      if (typeof this.field.lookupFilters === 'function') {\n        extraFilter = this.field.lookupFilters(this.formGroup?.value || {});\n      } else {\n        extraFilter = this.field.lookupFilters;\n      }\n      \n      if (extraFilter) {\n        if (listParams.filterQuery) {\n          listParams.filterQuery = `(${listParams.filterQuery}) and (${extraFilter})`;\n        } else {\n          listParams.filterQuery = extraFilter;\n        }\n      }\n    }\n    \n    this.field.lookupService.list(listParams).subscribe({\n      next: (response: any) => {\n        this.data = response.contents || [];\n        this.filteredData = [...this.data];\n        this.totalRecords = response.totalElements || 0;\n        \n        this.updateSelectedItem();\n        \n        // Após carregar os dados da grid, se temos um valor selecionado mas sem displayValue,\n        // tentar encontrar o item nos dados carregados\n        if (this.value && !this.displayValue) {\n          const item = this.filteredData.find(i => i[this.valueField] === this.value);\n          if (item) {\n            this.displayValue = this.formatDisplayValue(item);\n          }\n        }\n        \n        this.loading = false;\n      },\n      error: (_error: unknown) => {\n        this.data = [];\n        this.filteredData = [];\n        this.totalRecords = 0;\n        this.loading = false;\n      }\n    });\n  }\n\n  private updateSelectedItem(): void {\n    if (!this.value) {\n      this.selectedItem = null;\n      return;\n    }\n    \n    // value can be a full object or just an ID\n    const valueId = typeof this.value === 'object' ? this.value[this.valueField] : this.value;\n    const item = this.filteredData.find(i => i[this.valueField] === valueId);\n    if (item) {\n      this.selectedItem = item;\n    } else if (typeof this.value === 'object') {\n      // Item not in current page but we have the full object from autocomplete\n      this.selectedItem = this.value;\n    }\n  }\n\n  onSearch(): void {\n    if (!this.showLookupDialog) {\n      return;\n    }\n    \n    this.currentPage = 0;\n    this.loadData();\n  }\n\n  clearSearch(): void {\n    this.searchTerm = '';\n    this.currentPage = 0;\n    this.loadData();\n  }\n\n  selectItem(item: any): void {\n    // Always set the full object, not just the ID\n    this.setValue(item);\n    this.displayValue = this.formatDisplayValue(item);\n    this.showLookupDialog = false;\n  }\n\n  onRowSelect(event: any): void {\n    this.selectItem(event.data);\n  }\n\n  clearValue(): void {\n    this.setValue(null);\n    this.displayValue = '';\n    this.autocompleteText = '';\n    this.selectedItem = null;\n    this.suggestions = [];\n    this.showSuggestions = false;\n  }\n\n  getFieldValue(item: any, field: string): any {\n    return field.split('.').reduce((obj, key) => obj?.[key], item) || '';\n  }\n}\n"]}
|