@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.
Files changed (40) hide show
  1. package/esm2022/lib/components/dynamic-form/dynamic-form.component.mjs +263 -368
  2. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-checkbox.component.mjs +53 -0
  3. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-date.component.mjs +5 -3
  4. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-datetime.component.mjs +5 -3
  5. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-dropdown.component.mjs +5 -3
  6. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-image.component.mjs +162 -0
  7. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-lookup.component.mjs +203 -49
  8. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-multiselect.component.mjs +90 -0
  9. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-number.component.mjs +3 -3
  10. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-text.component.mjs +7 -7
  11. package/esm2022/lib/components/dynamic-form/fields/dynamic-field-time.component.mjs +66 -0
  12. package/esm2022/lib/components/dynamic-form/fields/index.mjs +5 -1
  13. package/esm2022/lib/components/dynamic-form/models/dynamic-form.models.mjs +1 -1
  14. package/esm2022/lib/components/loading/iassist-icon.component.mjs +14 -0
  15. package/esm2022/lib/components/loading/loading.component.mjs +47 -4
  16. package/esm2022/lib/i18n/en-US.json +4 -1
  17. package/esm2022/lib/i18n/es-ES.json +4 -1
  18. package/esm2022/lib/i18n/pt-BR.json +4 -1
  19. package/esm2022/lib/models/entity-list.config.mjs +1 -1
  20. package/esm2022/lib/services/websocket.service.mjs +184 -0
  21. package/esm2022/public-api.mjs +3 -1
  22. package/fesm2022/seniorsistemas-components-ai.mjs +1283 -661
  23. package/fesm2022/seniorsistemas-components-ai.mjs.map +1 -1
  24. package/lib/components/dynamic-form/dynamic-form.component.d.ts +8 -17
  25. package/lib/components/dynamic-form/fields/dynamic-field-checkbox.component.d.ts +8 -0
  26. package/lib/components/dynamic-form/fields/dynamic-field-image.component.d.ts +21 -0
  27. package/lib/components/dynamic-form/fields/dynamic-field-lookup.component.d.ts +19 -6
  28. package/lib/components/dynamic-form/fields/dynamic-field-multiselect.component.d.ts +10 -0
  29. package/lib/components/dynamic-form/fields/dynamic-field-time.component.d.ts +9 -0
  30. package/lib/components/dynamic-form/fields/index.d.ts +4 -0
  31. package/lib/components/dynamic-form/models/dynamic-form.models.d.ts +30 -84
  32. package/lib/components/loading/iassist-icon.component.d.ts +6 -0
  33. package/lib/components/loading/loading.component.d.ts +1 -1
  34. package/lib/models/entity-list.config.d.ts +12 -132
  35. package/lib/services/websocket.service.d.ts +63 -0
  36. package/package.json +3 -2
  37. package/public-api.d.ts +2 -0
  38. package/src/lib/i18n/en-US.json +4 -1
  39. package/src/lib/i18n/es-ES.json +4 -1
  40. package/src/lib/i18n/pt-BR.json +4 -1
@@ -13,6 +13,10 @@ import { DynamicFieldDatetimeComponent } from './fields/dynamic-field-datetime.c
13
13
  import { DynamicFieldDropdownComponent } from './fields/dynamic-field-dropdown.component';
14
14
  import { DynamicFieldLookupComponent } from './fields/dynamic-field-lookup.component';
15
15
  import { DynamicFieldTextareaComponent } from './fields/dynamic-field-textarea.component';
16
+ import { DynamicFieldTimeComponent } from './fields/dynamic-field-time.component';
17
+ import { DynamicFieldCheckboxComponent } from './fields/dynamic-field-checkbox.component';
18
+ import { DynamicFieldMultiselectComponent } from './fields/dynamic-field-multiselect.component';
19
+ import { DynamicFieldImageComponent } from './fields/dynamic-field-image.component';
16
20
  import * as i0 from "@angular/core";
17
21
  import * as i1 from "@angular/forms";
18
22
  import * as i2 from "../../services/translation.service";
@@ -29,14 +33,11 @@ export class DynamicFormComponent {
29
33
  translationService;
30
34
  maskService;
31
35
  localeService;
32
- formFields = [];
33
- formSections = [];
34
- fixedFilters = []; // Filtros fixos (sempre visíveis no topo)
35
- filterSections = []; // Seções de filtros (colapsáveis)
36
+ sections = [];
36
37
  entityData = null;
37
38
  mode = 'form';
38
- // Display Mode Configuration
39
- displayMode = 'inline';
39
+ // Display Mode — optional. If not set, renders inline without buttons.
40
+ displayMode;
40
41
  visible = false;
41
42
  dialogConfig = {};
42
43
  drawerConfig = {};
@@ -54,102 +55,58 @@ export class DynamicFormComponent {
54
55
  fieldSave = new EventEmitter();
55
56
  form;
56
57
  loading = false;
57
- // Inline edit mode state
58
+ // Inline edit state
58
59
  editingField = null;
59
60
  savingField = false;
60
- get hasFields() {
61
- return this.formFields.length > 0;
62
- }
63
- get hasSections() {
64
- return this.formSections.length > 0;
65
- }
66
- get hasFixedFilters() {
67
- return this.fixedFilters.length > 0;
68
- }
69
- get hasFilterSections() {
70
- return this.filterSections.length > 0;
71
- }
61
+ // --- Computed properties ---
72
62
  get allFields() {
73
- // Retorna todos os campos (diretos + das seções + filtros fixos + seções de filtros)
74
- const sectionFields = this.formSections.flatMap(section => section.fields);
75
- const filterSectionFields = this.filterSections.flatMap(section => section.fields);
76
- return [...this.formFields, ...sectionFields, ...this.fixedFilters, ...filterSectionFields];
77
- }
78
- get isInlineMode() {
79
- return this.displayMode === 'inline';
63
+ return this.sections.flatMap(section => section.fields);
80
64
  }
81
65
  get isInlineEditMode() {
82
66
  return this.mode === 'inline-edit';
83
67
  }
84
- get fieldMode() {
85
- return this.isInlineEditMode ? 'form' : this.mode;
86
- }
87
68
  get isDialogMode() {
88
69
  return this.displayMode === 'dialog';
89
70
  }
90
71
  get isDrawerMode() {
91
72
  return this.displayMode === 'drawer';
92
73
  }
93
- // Dialog configuration with defaults
74
+ get isInlineMode() {
75
+ return !this.displayMode;
76
+ }
77
+ // Dialog config with defaults
94
78
  get dialogHeader() {
95
79
  return this.dialogConfig.header || this.translationService.translate('design.components_ai.form');
96
80
  }
97
- get dialogWidth() {
98
- return this.dialogConfig.width || '600px';
99
- }
100
- get dialogDraggable() {
101
- return this.dialogConfig.draggable !== undefined ? this.dialogConfig.draggable : false;
102
- }
103
- get dialogResizable() {
104
- return this.dialogConfig.resizable !== undefined ? this.dialogConfig.resizable : false;
105
- }
106
- get dialogMaximizable() {
107
- return this.dialogConfig.maximizable !== undefined ? this.dialogConfig.maximizable : false;
108
- }
109
- get dialogCloseOnEscape() {
110
- return this.dialogConfig.closeOnEscape !== undefined ? this.dialogConfig.closeOnEscape : true;
111
- }
112
- get dialogDismissableMask() {
113
- return this.dialogConfig.dismissableMask !== undefined ? this.dialogConfig.dismissableMask : false;
114
- }
115
- // Drawer configuration with defaults
81
+ get dialogWidth() { return this.dialogConfig.width || '600px'; }
82
+ get dialogDraggable() { return this.dialogConfig.draggable ?? false; }
83
+ get dialogResizable() { return this.dialogConfig.resizable ?? false; }
84
+ get dialogMaximizable() { return this.dialogConfig.maximizable ?? false; }
85
+ get dialogCloseOnEscape() { return this.dialogConfig.closeOnEscape ?? true; }
86
+ get dialogDismissableMask() { return this.dialogConfig.dismissableMask ?? false; }
87
+ // Drawer config with defaults
116
88
  get drawerHeader() {
117
89
  return this.drawerConfig.header || this.translationService.translate('design.components_ai.form');
118
90
  }
119
- get drawerPosition() {
120
- return this.drawerConfig.position || 'right';
121
- }
122
- get drawerShowCloseIcon() {
123
- return this.drawerConfig.showCloseIcon !== undefined ? this.drawerConfig.showCloseIcon : true;
124
- }
125
- get drawerCloseOnEscape() {
126
- return this.drawerConfig.closeOnEscape !== undefined ? this.drawerConfig.closeOnEscape : true;
127
- }
128
- get drawerDismissable() {
129
- return this.drawerConfig.dismissable !== undefined ? this.drawerConfig.dismissable : true;
130
- }
91
+ get drawerPosition() { return this.drawerConfig.position || 'right'; }
92
+ get drawerShowCloseIcon() { return this.drawerConfig.showCloseIcon ?? true; }
93
+ get drawerCloseOnEscape() { return this.drawerConfig.closeOnEscape ?? true; }
94
+ get drawerDismissable() { return this.drawerConfig.dismissable ?? true; }
131
95
  get drawerStyle() {
132
96
  const position = this.drawerPosition;
133
97
  const isHorizontal = position === 'left' || position === 'right';
134
- // Se tem customWidth, usa ela
135
98
  if (this.drawerConfig.customWidth) {
136
- return isHorizontal
137
- ? { width: this.drawerConfig.customWidth }
138
- : { height: this.drawerConfig.customWidth };
99
+ return isHorizontal ? { width: this.drawerConfig.customWidth } : { height: this.drawerConfig.customWidth };
139
100
  }
140
- // Usa o tamanho padronizado
141
101
  const size = this.drawerConfig.size || 'medium';
142
102
  const sizeMap = {
143
- 'small': isHorizontal ? '25%' : '25vh',
144
- 'medium': isHorizontal ? '40%' : '40vh',
145
- 'large': isHorizontal ? '60%' : '60vh',
146
- 'xlarge': isHorizontal ? '80%' : '80vh',
147
- 'full': isHorizontal ? '100%' : '100vh'
103
+ small: isHorizontal ? '25%' : '25vh',
104
+ medium: isHorizontal ? '40%' : '40vh',
105
+ large: isHorizontal ? '60%' : '60vh',
106
+ xlarge: isHorizontal ? '80%' : '80vh',
107
+ full: isHorizontal ? '100%' : '100vh'
148
108
  };
149
- const sizeValue = sizeMap[size];
150
- return isHorizontal
151
- ? { width: sizeValue }
152
- : { height: sizeValue };
109
+ return isHorizontal ? { width: sizeMap[size] } : { height: sizeMap[size] };
153
110
  }
154
111
  get submitLabel() {
155
112
  return this.submitButtonLabel || this.translationService.translate('design.components_ai.save');
@@ -163,6 +120,7 @@ export class DynamicFormComponent {
163
120
  this.maskService = maskService;
164
121
  this.localeService = localeService;
165
122
  }
123
+ // --- Lifecycle ---
166
124
  ngOnInit() {
167
125
  this.initForm();
168
126
  if (this.entityData) {
@@ -172,53 +130,43 @@ export class DynamicFormComponent {
172
130
  this.formReady.emit(this.form);
173
131
  }
174
132
  ngOnChanges(changes) {
175
- // Handle entityData changes first
176
133
  if (changes['entityData'] && this.form) {
177
- if (this.entityData) {
178
- this.loadEntityData();
179
- }
180
- else {
181
- this.resetForm();
182
- }
134
+ this.entityData ? this.loadEntityData() : this.resetForm();
183
135
  }
184
- // When dialog/drawer opens, ensure form is loaded with entityData
185
136
  if (changes['visible'] && changes['visible'].currentValue === true) {
186
137
  this.loading = false;
187
- // If opening with entityData, reload it to ensure form is populated
188
138
  if (this.entityData && this.form) {
189
139
  this.loadEntityData();
190
140
  }
191
141
  else if (!this.entityData && this.form) {
192
- // If opening without entityData (new record), reset form
193
142
  this.resetForm();
194
143
  }
195
144
  }
196
145
  }
146
+ // --- Form init ---
197
147
  initForm() {
198
148
  const formControls = {};
199
- // Processa todos os campos (diretos + das seções)
200
149
  this.allFields.forEach(field => {
201
150
  const defaultValue = this.getDefaultValue(field);
202
- const validators = this.mode === 'filter' ? [] : (field.validators || []);
203
- const control = this.fb.control({ value: defaultValue, disabled: field.disabled || false }, validators);
204
- formControls[field.field] = control;
151
+ const validators = field.validators || [];
152
+ formControls[field.field] = this.fb.control({ value: defaultValue, disabled: field.disabled || false }, validators);
205
153
  });
206
154
  this.form = this.fb.group(formControls);
207
155
  this.applyInitialDisabledState();
208
156
  }
209
157
  getDefaultValue(field) {
210
- if (field.defaultValue !== undefined) {
158
+ if (field.defaultValue !== undefined)
211
159
  return field.defaultValue;
212
- }
213
160
  switch (field.type) {
214
161
  case 'number':
162
+ case 'currency':
215
163
  case 'date':
216
- return null;
164
+ case 'time': return null;
165
+ case 'checkbox': return false;
166
+ case 'multiselect': return [];
217
167
  case 'dropdown':
218
- case 'enum':
219
- return this.mode === 'filter' ? null : '';
220
- default:
221
- return '';
168
+ case 'enum': return '';
169
+ default: return '';
222
170
  }
223
171
  }
224
172
  applyInitialDisabledState() {
@@ -231,194 +179,138 @@ export class DynamicFormComponent {
231
179
  }
232
180
  });
233
181
  }
182
+ // --- Data loading ---
234
183
  loadEntityData() {
235
184
  if (this.entityData && this.form) {
236
- const processedData = this.processEntityData(this.entityData);
237
- this.form.patchValue(processedData);
185
+ this.form.patchValue(this.processEntityData(this.entityData));
238
186
  }
239
187
  }
240
188
  processEntityData(entity) {
241
- const processedData = { ...entity };
189
+ const data = { ...entity };
242
190
  this.allFields.forEach(field => {
243
- if (field.type === 'date' && processedData[field.field]) {
244
- const dateValue = processedData[field.field];
245
- if (typeof dateValue === 'string') {
246
- // Convert date string (yyyy-MM-dd or ISO) to Date object for p-calendar
247
- // Use date-only constructor to avoid timezone/hour issues
248
- const parts = dateValue.substring(0, 10).split('-');
191
+ if (field.type === 'date' && data[field.field]) {
192
+ const v = data[field.field];
193
+ if (typeof v === 'string') {
194
+ const parts = v.substring(0, 10).split('-');
249
195
  if (parts.length === 3) {
250
- const date = new Date(+parts[0], +parts[1] - 1, +parts[2]);
251
- if (!isNaN(date.getTime())) {
252
- processedData[field.field] = date;
253
- }
196
+ const d = new Date(+parts[0], +parts[1] - 1, +parts[2]);
197
+ if (!isNaN(d.getTime()))
198
+ data[field.field] = d;
254
199
  }
255
200
  }
256
201
  }
257
- if (field.type === 'lookup' && processedData[field.field]) {
258
- const lookupValue = processedData[field.field];
259
- // Keep the full object if it has display data, otherwise extract ID
260
- if (typeof lookupValue === 'object' && lookupValue.id) {
261
- const hasDisplayData = field.lookupDisplayFields
262
- ? field.lookupDisplayFields.some(f => this.getNestedValue(lookupValue, f))
263
- : lookupValue[field.lookupDisplayField || 'name'];
264
- if (hasDisplayData) {
265
- // Keep the full object to avoid unnecessary API calls
266
- processedData[field.field] = lookupValue;
267
- }
268
- else {
269
- // Only has ID, extract it
270
- processedData[field.field] = lookupValue.id;
202
+ if (field.type === 'time' && data[field.field]) {
203
+ const v = data[field.field];
204
+ if (typeof v === 'string') {
205
+ const parts = v.split(':');
206
+ if (parts.length >= 2) {
207
+ const d = new Date();
208
+ d.setHours(parseInt(parts[0], 10), parseInt(parts[1], 10), 0, 0);
209
+ data[field.field] = d;
271
210
  }
272
211
  }
273
212
  }
213
+ if (field.type === 'lookup' && data[field.field]) {
214
+ const v = data[field.field];
215
+ if (typeof v === 'object' && v.id) {
216
+ const hasDisplay = field.lookupDisplayFields
217
+ ? field.lookupDisplayFields.some(f => this.getNestedValue(v, f))
218
+ : v[field.lookupDisplayField || 'name'];
219
+ if (!hasDisplay)
220
+ data[field.field] = v.id;
221
+ }
222
+ }
274
223
  });
275
- return processedData;
224
+ return data;
276
225
  }
277
226
  getNestedValue(obj, path) {
278
- return path.split('.').reduce((current, key) => current?.[key], obj);
227
+ return path.split('.').reduce((cur, key) => cur?.[key], obj);
279
228
  }
280
229
  resetForm() {
281
230
  if (this.form) {
282
- const resetValues = {};
283
- this.allFields.forEach(field => {
284
- resetValues[field.field] = this.getDefaultValue(field);
285
- });
286
- this.form.reset(resetValues);
231
+ const values = {};
232
+ this.allFields.forEach(f => values[f.field] = this.getDefaultValue(f));
233
+ this.form.reset(values);
287
234
  }
288
235
  }
289
- processFilterValue(formValue) {
290
- const processedValue = { ...formValue };
291
- this.allFields.forEach(field => {
292
- const fieldValue = processedValue[field.field];
293
- if (field.type === 'lookup') {
294
- if (fieldValue && typeof fieldValue === 'object' && fieldValue.id) {
295
- processedValue[field.field] = fieldValue;
296
- }
297
- else if (fieldValue && typeof fieldValue === 'string') {
298
- processedValue[field.field] = { id: fieldValue };
299
- }
300
- else {
301
- processedValue[field.field] = null;
302
- }
303
- }
304
- });
305
- return processedValue;
306
- }
236
+ // --- Value processing on submit ---
307
237
  processFormValue(formValue) {
308
- const processedValue = { ...formValue };
309
- if (this.entityData?.id) {
310
- processedValue.id = this.entityData.id;
311
- }
238
+ const out = { ...formValue };
239
+ if (this.entityData?.id)
240
+ out.id = this.entityData.id;
312
241
  this.allFields.forEach(field => {
313
- const fieldValue = processedValue[field.field];
242
+ const v = out[field.field];
314
243
  if (field.type === 'lookup') {
315
- // Keep the full object for lookup fields
316
- if (fieldValue && typeof fieldValue === 'object') {
317
- // Object is already complete, keep it as is
318
- processedValue[field.field] = fieldValue;
319
- }
320
- else if (fieldValue && fieldValue !== '') {
321
- // If it's just an ID, wrap it in an object
322
- processedValue[field.field] = { id: fieldValue };
323
- }
324
- else {
325
- processedValue[field.field] = null;
326
- }
244
+ if (v && typeof v === 'object') { /* keep */ }
245
+ else if (v && v !== '')
246
+ out[field.field] = { id: v };
247
+ else
248
+ out[field.field] = null;
327
249
  }
328
250
  else if (field.type === 'date') {
329
- if (fieldValue instanceof Date) {
330
- // Serialize as yyyy-MM-dd using local date components (no UTC shift)
331
- const y = fieldValue.getFullYear();
332
- const m = String(fieldValue.getMonth() + 1).padStart(2, '0');
333
- const d = String(fieldValue.getDate()).padStart(2, '0');
334
- processedValue[field.field] = `${y}-${m}-${d}`;
335
- }
336
- else if (!fieldValue) {
337
- processedValue[field.field] = null;
251
+ if (v instanceof Date) {
252
+ out[field.field] = `${v.getFullYear()}-${String(v.getMonth() + 1).padStart(2, '0')}-${String(v.getDate()).padStart(2, '0')}`;
338
253
  }
254
+ else if (!v)
255
+ out[field.field] = null;
339
256
  }
340
- else if (['text', 'textarea', 'number', 'enum', 'dropdown'].includes(field.type)) {
341
- if (fieldValue === '' || fieldValue === undefined) {
342
- processedValue[field.field] = null;
257
+ else if (field.type === 'time') {
258
+ if (v instanceof Date) {
259
+ out[field.field] = `${String(v.getHours()).padStart(2, '0')}:${String(v.getMinutes()).padStart(2, '0')}:00`;
343
260
  }
261
+ else if (!v)
262
+ out[field.field] = null;
263
+ }
264
+ else if (['text', 'textarea', 'number', 'currency', 'enum', 'dropdown'].includes(field.type)) {
265
+ if (v === '' || v === undefined)
266
+ out[field.field] = null;
344
267
  }
345
268
  });
346
- return processedValue;
269
+ return out;
347
270
  }
271
+ // --- Layout ---
348
272
  getFieldGridClass(field) {
273
+ const defaultSize = { xl: 6, lg: 6, md: 6, sm: 12 };
274
+ const size = typeof field.size === 'function'
275
+ ? field.size(this.form?.value || {})
276
+ : (field.size || defaultSize);
349
277
  const classes = [];
350
- // Colspan base (padrão: 6)
351
- let baseColspan = field.colspan || 6;
352
- // Verifica condições de colspan dinâmico
353
- if (field.colspanWhen && field.colspanWhen.length > 0) {
354
- for (const condition of field.colspanWhen) {
355
- const dependentFieldValue = this.form.get(condition.field)?.value;
356
- if (dependentFieldValue === condition.value) {
357
- baseColspan = condition.colspan;
358
- break;
359
- }
360
- }
361
- }
362
- // Adiciona classe base
363
- classes.push(`col-${baseColspan}`);
364
- // Suporta tanto o objeto size quanto as propriedades antigas (para compatibilidade)
365
- const sizeXs = field.size?.xs ?? field.colspanXs;
366
- const sizeSm = field.size?.sm ?? field.colspanSm;
367
- const sizeMd = field.size?.md ?? field.colspanMd;
368
- const sizeLg = field.size?.lg ?? field.colspanLg;
369
- const sizeXl = field.size?.xl ?? field.colspanXl;
370
- // Adiciona classes responsivas se definidas
371
- if (sizeXs !== undefined) {
372
- classes.push(`col-xs-${sizeXs}`);
373
- }
374
- if (sizeSm !== undefined) {
375
- classes.push(`col-sm-${sizeSm}`);
376
- }
377
- if (sizeMd !== undefined) {
378
- classes.push(`col-md-${sizeMd}`);
379
- }
380
- if (sizeLg !== undefined) {
381
- classes.push(`col-lg-${sizeLg}`);
382
- }
383
- if (sizeXl !== undefined) {
384
- classes.push(`col-xl-${sizeXl}`);
385
- }
278
+ // Base class from xl or fallback 6
279
+ classes.push(`col-${size.xl ?? size.lg ?? size.md ?? size.sm ?? 6}`);
280
+ if (size.xs !== undefined)
281
+ classes.push(`col-xs-${size.xs}`);
282
+ if (size.sm !== undefined)
283
+ classes.push(`col-sm-${size.sm}`);
284
+ if (size.md !== undefined)
285
+ classes.push(`col-md-${size.md}`);
286
+ if (size.lg !== undefined)
287
+ classes.push(`col-lg-${size.lg}`);
288
+ if (size.xl !== undefined)
289
+ classes.push(`col-xl-${size.xl}`);
386
290
  return classes.join(' ');
387
291
  }
292
+ // --- Conditional visibility/disabled ---
388
293
  isFieldVisible(field) {
389
- if (!field.visibleWhen) {
294
+ if (!field.visibleWhen)
390
295
  return true;
391
- }
392
- const dependentFieldValue = this.form.get(field.visibleWhen.field)?.value;
393
- return dependentFieldValue === field.visibleWhen.value;
296
+ return field.visibleWhen(this.form?.value || {});
394
297
  }
395
298
  isFieldDisabled(field) {
396
- if (field.disabled) {
299
+ if (field.disabled)
397
300
  return true;
398
- }
399
- if (!('disabledWhen' in field) || !field.disabledWhen) {
301
+ if (!field.disabledWhen)
400
302
  return false;
401
- }
402
- const dependentFieldValue = this.form.get(field.disabledWhen.field)?.value;
403
- if (field.disabledWhen.value === null) {
404
- return !dependentFieldValue;
405
- }
406
- return dependentFieldValue === field.disabledWhen.value;
303
+ return field.disabledWhen(this.form?.value || {});
407
304
  }
408
305
  setupConditionalFieldsWatcher() {
409
- const visibleDependentFields = this.allFields.filter(field => field.visibleWhen);
410
- const visibleWatchedFields = [...new Set(visibleDependentFields.map(field => field.visibleWhen.field))];
411
- const disabledDependentFields = this.allFields.filter(field => field.disabledWhen);
412
- const disabledWatchedFields = [...new Set(disabledDependentFields.map(field => field.disabledWhen.field))];
413
- const allWatchedFields = [...new Set([...visibleWatchedFields, ...disabledWatchedFields])];
414
- allWatchedFields.forEach(fieldName => {
415
- const control = this.form.get(fieldName);
416
- if (control) {
417
- control.valueChanges.subscribe(() => {
418
- this.clearHiddenFields();
419
- this.updateDisabledFields();
420
- });
421
- }
306
+ // Since visibleWhen/disabledWhen are now functions that can depend on any field,
307
+ // we watch all fields for changes and re-evaluate
308
+ const hasConditional = this.allFields.some(f => f.visibleWhen || f.disabledWhen);
309
+ if (!hasConditional)
310
+ return;
311
+ this.form.valueChanges.subscribe(() => {
312
+ this.clearHiddenFields();
313
+ this.updateDisabledFields();
422
314
  });
423
315
  }
424
316
  updateDisabledFields() {
@@ -426,13 +318,13 @@ export class DynamicFormComponent {
426
318
  if (field.disabledWhen) {
427
319
  const control = this.form.get(field.field);
428
320
  if (control) {
429
- const shouldBeDisabled = this.isFieldDisabled(field);
430
- if (shouldBeDisabled && control.enabled) {
321
+ const shouldDisable = this.isFieldDisabled(field);
322
+ if (shouldDisable && control.enabled) {
431
323
  control.setValue(null);
432
- control.disable();
324
+ control.disable({ emitEvent: false });
433
325
  }
434
- else if (!shouldBeDisabled && control.disabled && !field.disabled) {
435
- control.enable();
326
+ else if (!shouldDisable && control.disabled && !field.disabled) {
327
+ control.enable({ emitEvent: false });
436
328
  }
437
329
  }
438
330
  }
@@ -442,100 +334,111 @@ export class DynamicFormComponent {
442
334
  this.allFields.forEach(field => {
443
335
  if (field.visibleWhen && !this.isFieldVisible(field)) {
444
336
  const control = this.form.get(field.field);
445
- if (control) {
446
- const resetValue = this.getDefaultValue(field);
447
- control.setValue(resetValue);
337
+ if (control && control.value !== this.getDefaultValue(field)) {
338
+ control.setValue(this.getDefaultValue(field), { emitEvent: false });
448
339
  control.markAsUntouched();
449
340
  control.markAsPristine();
450
341
  }
451
342
  }
452
343
  });
453
344
  }
454
- getForm() {
455
- return this.form;
456
- }
457
- clearFilters() {
458
- if (this.mode === 'filter') {
459
- this.resetForm();
460
- }
461
- }
462
- getTypePersonValue() {
463
- const typePersonValue = this.form?.get('typePerson')?.value;
464
- return typePersonValue || 'JURIDICAL_PERSON';
465
- }
466
- // Display Mode Control Methods
345
+ // --- Public methods ---
346
+ getForm() { return this.form; }
467
347
  open(entity) {
468
348
  if (entity) {
469
349
  this.entityData = entity;
470
350
  }
471
351
  else {
472
352
  this.entityData = null;
473
- this.resetForm(); // Reset form when opening for new entity
353
+ this.resetForm();
474
354
  }
475
- this.loading = false; // Reset loading state
355
+ this.loading = false;
476
356
  this.visible = true;
477
357
  this.visibleChange.emit(true);
478
358
  }
479
359
  close() {
480
- this.loading = false; // Reset loading state
360
+ this.loading = false;
481
361
  this.visible = false;
482
362
  this.visibleChange.emit(false);
483
- this.resetForm(); // Reset form when closing
363
+ this.resetForm();
484
364
  this.onCancel.emit();
485
365
  }
486
- handleCancel() {
487
- this.close();
488
- }
366
+ handleCancel() { this.close(); }
489
367
  handleSubmit() {
490
368
  if (this.mode === 'form' && this.form.invalid) {
491
369
  this.form.markAllAsTouched();
492
370
  return;
493
371
  }
494
- if (this.mode !== 'filter') {
495
- this.loading = true;
372
+ this.loading = true;
373
+ this.formSubmit.emit(this.processFormValue(this.form.value));
374
+ }
375
+ onFormKeydown(event) {
376
+ if (event.key === 'Enter') {
377
+ const target = event.target;
378
+ if (target.tagName === 'TEXTAREA')
379
+ return;
380
+ event.preventDefault();
381
+ // In inline-edit mode, Enter saves the current field
382
+ if (this.isInlineEditMode && this.editingField) {
383
+ this.saveInlineField(this.editingField);
384
+ }
385
+ else {
386
+ this.handleSubmit();
387
+ }
496
388
  }
497
- const formValue = this.mode === 'filter'
498
- ? this.processFilterValue(this.form.value)
499
- : this.processFormValue(this.form.value);
500
- this.formSubmit.emit(formValue);
501
389
  }
502
- // Inline Edit Mode Methods
390
+ // --- Section helpers ---
391
+ getSectionStyle(section) {
392
+ if (!section.title)
393
+ return 'none';
394
+ return section.style || 'none';
395
+ }
396
+ // --- Inline Edit ---
503
397
  startEditField(fieldName) {
504
- if (this.isInlineEditMode) {
505
- this.editingField = fieldName;
506
- // Ensure the field has the current value from entityData
507
- if (this.entityData) {
508
- const control = this.form.get(fieldName);
509
- if (control) {
510
- const field = this.allFields.find(f => f.field === fieldName);
511
- const value = this.entityData[fieldName];
512
- // For lookup fields in inline-edit mode, keep the full object
513
- // This prevents unnecessary API calls since we already have the data
514
- if (field?.type === 'lookup' && value && typeof value === 'object') {
515
- // Keep the full object - the lookup component will use it
516
- control.setValue(value);
517
- }
518
- else if (field?.type === 'date' && value && typeof value === 'string') {
519
- // Convert date string to Date object for p-calendar (date-only, no time component)
520
- const parts = value.substring(0, 10).split('-');
521
- if (parts.length === 3) {
522
- const date = new Date(+parts[0], +parts[1] - 1, +parts[2]);
523
- control.setValue(!isNaN(date.getTime()) ? date : value);
524
- }
525
- else {
526
- control.setValue(value);
527
- }
398
+ if (!this.isInlineEditMode)
399
+ return;
400
+ this.editingField = fieldName;
401
+ if (this.entityData) {
402
+ const control = this.form.get(fieldName);
403
+ if (control) {
404
+ const field = this.allFields.find(f => f.field === fieldName);
405
+ const value = this.entityData[fieldName];
406
+ if (field?.type === 'lookup' && value && typeof value === 'object') {
407
+ control.setValue(value);
408
+ }
409
+ else if (field?.type === 'date' && value && typeof value === 'string') {
410
+ const parts = value.substring(0, 10).split('-');
411
+ if (parts.length === 3) {
412
+ const d = new Date(+parts[0], +parts[1] - 1, +parts[2]);
413
+ control.setValue(!isNaN(d.getTime()) ? d : value);
528
414
  }
529
415
  else {
530
416
  control.setValue(value);
531
417
  }
532
418
  }
419
+ else {
420
+ control.setValue(value);
421
+ }
533
422
  }
534
423
  }
424
+ // Auto-focus the input after Angular renders the edit field
425
+ setTimeout(() => {
426
+ const el = document.querySelector(`.inline-edit-field input[id="${fieldName}"], .inline-edit-field textarea[id="${fieldName}"]`);
427
+ el?.focus();
428
+ });
429
+ // For lookup fields, auto-save when value changes (user selects from dialog)
430
+ const field = this.allFields.find(f => f.field === fieldName);
431
+ if (field?.type === 'lookup') {
432
+ const control = this.form.get(fieldName);
433
+ const sub = control?.valueChanges.subscribe(val => {
434
+ if (val && typeof val === 'object') {
435
+ sub?.unsubscribe();
436
+ this.saveInlineField(fieldName);
437
+ }
438
+ });
439
+ }
535
440
  }
536
- isFieldEditing(fieldName) {
537
- return this.editingField === fieldName;
538
- }
441
+ isFieldEditing(fieldName) { return this.editingField === fieldName; }
539
442
  saveInlineField(fieldName) {
540
443
  if (!this.isInlineEditMode)
541
444
  return;
@@ -545,29 +448,21 @@ export class DynamicFormComponent {
545
448
  return;
546
449
  }
547
450
  this.savingField = true;
548
- let fieldValue = control.value;
549
- // For lookup fields, keep the full object (don't extract ID)
451
+ let value = control.value;
550
452
  const field = this.allFields.find(f => f.field === fieldName);
551
- if (field?.type === 'lookup' && fieldValue && typeof fieldValue !== 'object') {
552
- // If it's just an ID, wrap it in an object
553
- fieldValue = { id: fieldValue };
453
+ if (field?.type === 'lookup' && value && typeof value !== 'object') {
454
+ value = { id: value };
554
455
  }
555
- // For date fields, serialize as yyyy-MM-dd (no time component)
556
- if (field?.type === 'date' && fieldValue instanceof Date) {
557
- const y = fieldValue.getFullYear();
558
- const m = String(fieldValue.getMonth() + 1).padStart(2, '0');
559
- const d = String(fieldValue.getDate()).padStart(2, '0');
560
- fieldValue = `${y}-${m}-${d}`;
456
+ if (field?.type === 'date' && value instanceof Date) {
457
+ value = `${value.getFullYear()}-${String(value.getMonth() + 1).padStart(2, '0')}-${String(value.getDate()).padStart(2, '0')}`;
561
458
  }
562
- this.fieldSave.emit({ field: fieldName, value: fieldValue });
459
+ this.fieldSave.emit({ field: fieldName, value });
563
460
  }
564
461
  cancelInlineEdit() {
565
462
  if (this.isInlineEditMode && this.editingField) {
566
463
  const control = this.form.get(this.editingField);
567
464
  if (control && this.entityData) {
568
- // Restore original value
569
- const originalValue = this.entityData[this.editingField];
570
- control.setValue(originalValue);
465
+ control.setValue(this.entityData[this.editingField]);
571
466
  control.markAsPristine();
572
467
  control.markAsUntouched();
573
468
  }
@@ -575,75 +470,77 @@ export class DynamicFormComponent {
575
470
  this.savingField = false;
576
471
  }
577
472
  }
578
- // Method to be called by parent after save completes
579
473
  completeInlineEdit() {
580
474
  this.editingField = null;
581
475
  this.savingField = false;
582
476
  }
477
+ // --- Display value for inline-edit mode ---
583
478
  getFieldDisplayValue(fieldName) {
584
479
  if (!this.entityData)
585
480
  return '';
586
481
  const field = this.allFields.find(f => f.field === fieldName);
587
482
  const value = this.entityData[fieldName];
588
- if (!value)
483
+ if (!value && value !== false && value !== 0)
589
484
  return '';
590
- // For lookup fields, return the display name
591
- if (field?.type === 'lookup' && typeof value === 'object' && value.name) {
592
- return value.name;
593
- }
594
- // For lookup fields with multiple display fields
595
- if (field?.type === 'lookup' && typeof value === 'object' && field.lookupDisplayFields) {
596
- return field.lookupDisplayFields
597
- .map(f => this.getNestedValue(value, f))
598
- .filter(v => v)
599
- .join(' - ');
485
+ if (field?.type === 'lookup' && typeof value === 'object') {
486
+ if (field.lookupDisplayFields) {
487
+ return field.lookupDisplayFields.map(f => this.getNestedValue(value, f)).filter(v => v).join(' - ');
488
+ }
489
+ return value[field.lookupDisplayField || 'name'] || '';
600
490
  }
601
- // For dropdown/enum fields, find the matching option label
602
491
  if ((field?.type === 'dropdown' || field?.type === 'enum') && field) {
603
- const options = field.options || field.enumOptions || [];
604
- const optionValue = field.optionValue || 'value';
605
- const optionLabel = field.optionLabel || 'label';
606
- const matchingOption = options.find((opt) => {
607
- const optVal = typeof opt === 'object' ? opt[optionValue] : opt;
608
- return optVal === value;
609
- });
610
- if (matchingOption) {
611
- return typeof matchingOption === 'object' ? matchingOption[optionLabel] : matchingOption;
612
- }
492
+ const opts = field.options || field.enumOptions || [];
493
+ const optVal = field.optionValue || 'value';
494
+ const optLbl = field.optionLabel || 'label';
495
+ const match = opts.find((o) => (typeof o === 'object' ? o[optVal] : o) === value);
496
+ if (match)
497
+ return typeof match === 'object' ? match[optLbl] : match;
498
+ }
499
+ if (field?.type === 'currency' && typeof value === 'number') {
500
+ const moneyConfig = this.maskService.getMoneyConfig();
501
+ return new Intl.NumberFormat(field.locale || moneyConfig.locale, {
502
+ style: 'currency',
503
+ currency: field.currency || moneyConfig.currency
504
+ }).format(value);
613
505
  }
614
- // For number fields, format appropriately
615
506
  if (field?.type === 'number' && typeof value === 'number') {
616
- if (field.numberMode === 'currency') {
617
- return new Intl.NumberFormat(field.locale || 'pt-BR', {
618
- style: 'currency',
619
- currency: field.currency || 'BRL'
620
- }).format(value);
621
- }
622
- return new Intl.NumberFormat(field.locale || 'pt-BR', {
507
+ return new Intl.NumberFormat('pt-BR', {
623
508
  minimumFractionDigits: field.minFractionDigits || 0,
624
509
  maximumFractionDigits: field.maxFractionDigits || 2
625
510
  }).format(value);
626
511
  }
627
- // For date fields, format as date
628
- if (field?.type === 'date' && value) {
512
+ if (field?.type === 'date' && value)
629
513
  return this.localeService.formatDate(value);
514
+ if (field?.type === 'time' && value) {
515
+ if (value instanceof Date)
516
+ return `${String(value.getHours()).padStart(2, '0')}:${String(value.getMinutes()).padStart(2, '0')}`;
517
+ return typeof value === 'string' ? value.substring(0, 5) : String(value);
518
+ }
519
+ if (field?.type === 'checkbox') {
520
+ return value ? this.translationService.translate('design.components_ai.boolean_true')
521
+ : this.translationService.translate('design.components_ai.boolean_false');
522
+ }
523
+ if (field?.type === 'multiselect' && Array.isArray(value)) {
524
+ const opts = field.options || field.enumOptions || [];
525
+ const optVal = field.optionValue || 'value';
526
+ const optLbl = field.optionLabel || 'label';
527
+ return value.map(v => {
528
+ const o = opts.find((opt) => (typeof opt === 'object' ? opt[optVal] : opt) === v);
529
+ return o ? (typeof o === 'object' ? o[optLbl] : o) : v;
530
+ }).join(', ');
630
531
  }
631
- // For text fields with document mask, format the value
632
532
  if (field?.type === 'text' && field.mask === 'document' && value) {
633
- const dependsOn = field.maskDependsOn || 'typePerson';
634
- const typePerson = this.entityData[dependsOn] || 'JURIDICAL_PERSON';
533
+ const typePerson = this.entityData[field.maskDependsOn || 'typePerson'] || 'JURIDICAL_PERSON';
635
534
  return this.maskService.applyDocumentMask(String(value), typePerson);
636
535
  }
637
- if (field?.type === 'text' && field.mask === 'cpf' && value) {
536
+ if (field?.type === 'text' && field.mask === 'cpf' && value)
638
537
  return this.maskService.applyCpfMask(String(value));
639
- }
640
- if (field?.type === 'text' && field.mask === 'cnpj' && value) {
538
+ if (field?.type === 'text' && field.mask === 'cnpj' && value)
641
539
  return this.maskService.applyCnpjMask(String(value));
642
- }
643
540
  return String(value);
644
541
  }
645
542
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DynamicFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.TranslationService }, { token: i3.MaskService }, { token: i4.LocaleService }], target: i0.ɵɵFactoryTarget.Component });
646
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: DynamicFormComponent, isStandalone: true, selector: "sia-dynamic-form", inputs: { formFields: "formFields", formSections: "formSections", fixedFilters: "fixedFilters", filterSections: "filterSections", entityData: "entityData", mode: "mode", displayMode: "displayMode", visible: "visible", dialogConfig: "dialogConfig", drawerConfig: "drawerConfig", showSubmitButton: "showSubmitButton", showCancelButton: "showCancelButton", submitButtonLabel: "submitButtonLabel", cancelButtonLabel: "cancelButtonLabel", submitButtonIcon: "submitButtonIcon", cancelButtonIcon: "cancelButtonIcon" }, outputs: { formReady: "formReady", formSubmit: "formSubmit", visibleChange: "visibleChange", onCancel: "onCancel", fieldSave: "fieldSave" }, usesOnChanges: true, ngImport: i0, template: "<!-- Modo Inline (padr\u00E3o) -->\n<ng-container *ngIf=\"isInlineMode\">\n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n</ng-container>\n\n<!-- Modo Dialog -->\n<p-dialog\n *ngIf=\"isDialogMode\"\n [(visible)]=\"visible\"\n [header]=\"dialogHeader | translate\"\n [modal]=\"true\"\n [style]=\"{ width: dialogWidth }\"\n [draggable]=\"dialogDraggable\"\n [resizable]=\"dialogResizable\"\n [maximizable]=\"dialogMaximizable\"\n [closeOnEscape]=\"dialogCloseOnEscape\"\n [dismissableMask]=\"dialogDismissableMask\"\n (onHide)=\"close()\">\n \n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n \n <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n <div class=\"dialog-footer\">\n <p-button\n *ngIf=\"showCancelButton\"\n [label]=\"cancelLabel | translate\"\n [icon]=\"cancelButtonIcon\"\n severity=\"secondary\"\n (onClick)=\"handleCancel()\"\n [disabled]=\"loading\">\n </p-button>\n <p-button\n *ngIf=\"showSubmitButton\"\n [label]=\"submitLabel | translate\"\n [icon]=\"submitButtonIcon\"\n (onClick)=\"handleSubmit()\"\n [loading]=\"loading\"\n [disabled]=\"form.invalid\">\n </p-button>\n </div>\n </ng-template>\n</p-dialog>\n\n<!-- Modo Drawer -->\n<p-drawer\n *ngIf=\"isDrawerMode\"\n [(visible)]=\"visible\"\n [header]=\"drawerHeader | translate\"\n [position]=\"drawerPosition\"\n [style]=\"drawerStyle\"\n [showCloseIcon]=\"drawerShowCloseIcon\"\n [closeOnEscape]=\"drawerCloseOnEscape\"\n [modal]=\"drawerDismissable\"\n (onHide)=\"close()\">\n \n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n \n <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n <div class=\"drawer-footer\">\n <p-button\n *ngIf=\"showCancelButton\"\n [label]=\"cancelLabel | translate\"\n [icon]=\"cancelButtonIcon\"\n severity=\"secondary\"\n (onClick)=\"handleCancel()\"\n [disabled]=\"loading\">\n </p-button>\n <p-button\n *ngIf=\"showSubmitButton\"\n [label]=\"submitLabel | translate\"\n [icon]=\"submitButtonIcon\"\n (onClick)=\"handleSubmit()\"\n [loading]=\"loading\"\n [disabled]=\"form.invalid\">\n </p-button>\n </div>\n </ng-template>\n</p-drawer>\n\n<!-- Template do Formul\u00E1rio (reutiliz\u00E1vel) -->\n<ng-template #formContent>\n <form [formGroup]=\"form\" class=\"dynamic-form\">\n \n <!-- Filtros Fixos (apenas no modo filter) -->\n <div *ngIf=\"mode === 'filter' && hasFixedFilters\" class=\"fixed-filters-section\">\n <div class=\"grid\">\n <ng-container *ngFor=\"let field of fixedFilters\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Campos Diretos (sem se\u00E7\u00E3o) -->\n <div *ngIf=\"hasFields\">\n <!-- Modo Inline Edit -->\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of formFields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n\n <!-- Modo Form Normal -->\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of formFields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Se\u00E7\u00F5es de Campos (modo form) -->\n <div *ngIf=\"hasSections\" class=\"sections-container\">\n <p-panel \n *ngFor=\"let section of formSections\"\n [toggleable]=\"section.toggleable !== false\"\n [collapsed]=\"section.collapsed || false\"\n [styleClass]=\"'section-panel'\">\n \n <ng-template pTemplate=\"header\">\n <div class=\"section-header\">\n <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n <span class=\"section-title\">{{ section.title }}</span>\n </div>\n </ng-template>\n\n <!-- Modo Inline Edit -->\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n\n <!-- Modo Form Normal -->\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </p-panel>\n </div>\n\n <!-- Se\u00E7\u00F5es de Filtros (apenas no modo filter) -->\n <div *ngIf=\"mode === 'filter' && hasFilterSections\" class=\"filter-sections-container\">\n <p-panel \n *ngFor=\"let section of filterSections\"\n [header]=\"section.title\"\n [toggleable]=\"true\"\n [collapsed]=\"true\">\n\n <div class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </p-panel>\n </div>\n\n <!-- Bot\u00F5es inline (apenas para modo inline) -->\n <div *ngIf=\"isInlineMode && (showSubmitButton || showCancelButton)\" class=\"form-actions\">\n <p-button\n *ngIf=\"showCancelButton\"\n [label]=\"cancelLabel | translate\"\n [icon]=\"cancelButtonIcon\"\n severity=\"secondary\"\n (onClick)=\"handleCancel()\"\n [disabled]=\"loading\">\n </p-button>\n <p-button\n *ngIf=\"showSubmitButton\"\n [label]=\"submitLabel | translate\"\n [icon]=\"submitButtonIcon\"\n (onClick)=\"handleSubmit()\"\n [loading]=\"loading\"\n [disabled]=\"form.invalid\">\n </p-button>\n </div>\n\n </form>\n</ng-template>\n\n<!-- Template de Campo (reutiliz\u00E1vel) -->\n<ng-template #fieldTemplate let-field=\"field\">\n <!-- Text Field -->\n <sia-dynamic-field-text\n *ngIf=\"field.type === 'text'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-text>\n\n <!-- Textarea Field -->\n <sia-dynamic-field-textarea\n *ngIf=\"field.type === 'textarea'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-textarea>\n\n <!-- Number Field -->\n <sia-dynamic-field-number\n *ngIf=\"field.type === 'number'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-number>\n\n <!-- Date Field -->\n <sia-dynamic-field-date\n *ngIf=\"field.type === 'date'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-date>\n\n <!-- Datetime Field -->\n <sia-dynamic-field-datetime\n *ngIf=\"field.type === 'datetime'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-datetime>\n\n <!-- Dropdown/Enum Field -->\n <sia-dynamic-field-dropdown\n *ngIf=\"field.type === 'dropdown' || field.type === 'enum'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-dropdown>\n\n <!-- Lookup Field -->\n <sia-dynamic-field-lookup\n *ngIf=\"field.type === 'lookup'\"\n [field]=\"field\"\n [form]=\"form\"\n [formGroup]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-lookup>\n</ng-template>\n\n\n<!-- Template de Campo Inline Edit -->\n<ng-template #inlineEditFieldTemplate let-field=\"field\">\n <div class=\"edit-inline-field\">\n <label class=\"field-label\">{{ field.label | translate }}</label>\n \n <!-- Display Mode -->\n <div class=\"field-display\" \n *ngIf=\"!isFieldEditing(field.field)\" \n (click)=\"startEditField(field.field)\"\n [class.disabled]=\"field.disabled\">\n <span class=\"display-value\" \n [attr.data-placeholder]=\"field.placeholder || ('crmx.business.not_informed' | translate)\">\n {{ getFieldDisplayValue(field.field) }}\n </span>\n <i class=\"pi pi-pencil edit-icon\" *ngIf=\"!field.disabled\"></i>\n </div>\n \n <!-- Edit Mode -->\n <div class=\"field-edit\" *ngIf=\"isFieldEditing(field.field)\">\n <div class=\"input-container\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n \n <!-- Action Buttons -->\n <div class=\"edit-actions\">\n <p-button \n type=\"button\" \n icon=\"pi pi-check\" \n [rounded]=\"true\"\n severity=\"primary\"\n (onClick)=\"saveInlineField(field.field)\" \n [loading]=\"savingField\"\n [disabled]=\"form.get(field.field)?.invalid\">\n </p-button>\n <p-button \n type=\"button\" \n icon=\"pi pi-times\" \n [rounded]=\"true\"\n severity=\"secondary\"\n (onClick)=\"cancelInlineEdit()\"\n [disabled]=\"savingField\">\n </p-button>\n </div>\n \n <!-- Error Message -->\n <div class=\"field-error\" *ngIf=\"form.get(field.field)?.invalid && form.get(field.field)?.touched\">\n <small class=\"p-error\">\n {{ form.get(field.field)?.errors?.['required'] ? ('crmx.business.required_field' | translate) : '' }}\n </small>\n </div>\n </div>\n </div>\n</ng-template>\n", styles: [".dynamic-form{width:100%}.dynamic-form .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.dynamic-form .grid>div.col-1{grid-column:span 1}.dynamic-form .grid>div.col-2{grid-column:span 2}.dynamic-form .grid>div.col-3{grid-column:span 3}.dynamic-form .grid>div.col-4{grid-column:span 4}.dynamic-form .grid>div.col-5{grid-column:span 5}.dynamic-form .grid>div.col-6{grid-column:span 6}.dynamic-form .grid>div.col-7{grid-column:span 7}.dynamic-form .grid>div.col-8{grid-column:span 8}.dynamic-form .grid>div.col-9{grid-column:span 9}.dynamic-form .grid>div.col-10{grid-column:span 10}.dynamic-form .grid>div.col-11{grid-column:span 11}.dynamic-form .grid>div.col-12{grid-column:span 12}@media (max-width: 575.98px){.dynamic-form .grid>div.col-xs-1{grid-column:span 1}.dynamic-form .grid>div.col-xs-2{grid-column:span 2}.dynamic-form .grid>div.col-xs-3{grid-column:span 3}.dynamic-form .grid>div.col-xs-4{grid-column:span 4}.dynamic-form .grid>div.col-xs-5{grid-column:span 5}.dynamic-form .grid>div.col-xs-6{grid-column:span 6}.dynamic-form .grid>div.col-xs-7{grid-column:span 7}.dynamic-form .grid>div.col-xs-8{grid-column:span 8}.dynamic-form .grid>div.col-xs-9{grid-column:span 9}.dynamic-form .grid>div.col-xs-10{grid-column:span 10}.dynamic-form .grid>div.col-xs-11{grid-column:span 11}.dynamic-form .grid>div.col-xs-12{grid-column:span 12}}@media (min-width: 576px){.dynamic-form .grid>div.col-sm-1{grid-column:span 1}.dynamic-form .grid>div.col-sm-2{grid-column:span 2}.dynamic-form .grid>div.col-sm-3{grid-column:span 3}.dynamic-form .grid>div.col-sm-4{grid-column:span 4}.dynamic-form .grid>div.col-sm-5{grid-column:span 5}.dynamic-form .grid>div.col-sm-6{grid-column:span 6}.dynamic-form .grid>div.col-sm-7{grid-column:span 7}.dynamic-form .grid>div.col-sm-8{grid-column:span 8}.dynamic-form .grid>div.col-sm-9{grid-column:span 9}.dynamic-form .grid>div.col-sm-10{grid-column:span 10}.dynamic-form .grid>div.col-sm-11{grid-column:span 11}.dynamic-form .grid>div.col-sm-12{grid-column:span 12}}@media (min-width: 768px){.dynamic-form .grid>div.col-md-1{grid-column:span 1}.dynamic-form .grid>div.col-md-2{grid-column:span 2}.dynamic-form .grid>div.col-md-3{grid-column:span 3}.dynamic-form .grid>div.col-md-4{grid-column:span 4}.dynamic-form .grid>div.col-md-5{grid-column:span 5}.dynamic-form .grid>div.col-md-6{grid-column:span 6}.dynamic-form .grid>div.col-md-7{grid-column:span 7}.dynamic-form .grid>div.col-md-8{grid-column:span 8}.dynamic-form .grid>div.col-md-9{grid-column:span 9}.dynamic-form .grid>div.col-md-10{grid-column:span 10}.dynamic-form .grid>div.col-md-11{grid-column:span 11}.dynamic-form .grid>div.col-md-12{grid-column:span 12}}@media (min-width: 992px){.dynamic-form .grid>div.col-lg-1{grid-column:span 1}.dynamic-form .grid>div.col-lg-2{grid-column:span 2}.dynamic-form .grid>div.col-lg-3{grid-column:span 3}.dynamic-form .grid>div.col-lg-4{grid-column:span 4}.dynamic-form .grid>div.col-lg-5{grid-column:span 5}.dynamic-form .grid>div.col-lg-6{grid-column:span 6}.dynamic-form .grid>div.col-lg-7{grid-column:span 7}.dynamic-form .grid>div.col-lg-8{grid-column:span 8}.dynamic-form .grid>div.col-lg-9{grid-column:span 9}.dynamic-form .grid>div.col-lg-10{grid-column:span 10}.dynamic-form .grid>div.col-lg-11{grid-column:span 11}.dynamic-form .grid>div.col-lg-12{grid-column:span 12}}@media (min-width: 1200px){.dynamic-form .grid>div.col-xl-1{grid-column:span 1}.dynamic-form .grid>div.col-xl-2{grid-column:span 2}.dynamic-form .grid>div.col-xl-3{grid-column:span 3}.dynamic-form .grid>div.col-xl-4{grid-column:span 4}.dynamic-form .grid>div.col-xl-5{grid-column:span 5}.dynamic-form .grid>div.col-xl-6{grid-column:span 6}.dynamic-form .grid>div.col-xl-7{grid-column:span 7}.dynamic-form .grid>div.col-xl-8{grid-column:span 8}.dynamic-form .grid>div.col-xl-9{grid-column:span 9}.dynamic-form .grid>div.col-xl-10{grid-column:span 10}.dynamic-form .grid>div.col-xl-11{grid-column:span 11}.dynamic-form .grid>div.col-xl-12{grid-column:span 12}}.dynamic-form .sections-container{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-header{background-color:var(--surface-50);border-color:var(--surface-200)}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-header .section-header{display:flex;align-items:center;gap:.5rem;width:100%}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-header .section-header .section-icon{font-size:1.1rem;color:var(--primary-color)}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-header .section-header .section-title{font-weight:600;color:var(--text-color)}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-content{padding:1.5rem}.dynamic-form .fixed-filters-section{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--surface-200)}.dynamic-form .filter-sections-container{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.dynamic-form .form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--surface-200)}.dialog-footer{display:flex;justify-content:flex-end;gap:.5rem}.drawer-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem;border-top:1px solid var(--surface-200)}.inline-edit-fields{display:flex;flex-direction:column;gap:1rem}.inline-edit-fields .inline-edit-field{display:flex;flex-direction:column;gap:.25rem}.inline-edit-fields .inline-edit-field .field-label{font-weight:500;font-size:.875rem;color:var(--text-color-secondary);margin-bottom:.25rem}.inline-edit-fields .inline-edit-field .field-display{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:var(--surface-50);border:1px solid var(--surface-200);border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;min-height:42px}.inline-edit-fields .inline-edit-field .field-display:hover:not(.disabled){background-color:var(--surface-100);border-color:var(--primary-color)}.inline-edit-fields .inline-edit-field .field-display:hover:not(.disabled) .edit-icon{opacity:1}.inline-edit-fields .inline-edit-field .field-display.disabled{cursor:not-allowed;opacity:.6}.inline-edit-fields .inline-edit-field .field-display .display-value{flex:1;color:var(--text-color)}.inline-edit-fields .inline-edit-field .field-display .display-value:empty:before{content:attr(data-placeholder);color:var(--text-color-secondary);font-style:italic}.inline-edit-fields .inline-edit-field .field-display .edit-icon{color:var(--primary-color);font-size:.875rem;opacity:.5;transition:opacity .2s ease}.inline-edit-fields .inline-edit-field .field-edit{display:flex;flex-direction:column;gap:.5rem}.inline-edit-fields .inline-edit-field .field-edit .input-container{flex:1}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field{gap:0}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field label{display:none}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field small.p-error{display:none}.inline-edit-fields .inline-edit-field .field-edit .edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.inline-edit-fields .inline-edit-field .field-edit .field-error small.p-error{color:var(--p-red-500);font-size:.875rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: PanelModule }, { kind: "component", type: i6.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions", "toggleButtonProps"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }, { kind: "directive", type: i7.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: DialogModule }, { kind: "component", type: i8.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: DrawerModule }, { kind: "component", type: i9.Drawer, selector: "p-drawer", inputs: ["appendTo", "blockScroll", "style", "styleClass", "ariaCloseLabel", "autoZIndex", "baseZIndex", "modal", "closeButtonProps", "dismissible", "showCloseIcon", "closeOnEscape", "transitionOptions", "visible", "position", "fullScreen", "header", "maskStyle", "closable"], outputs: ["onShow", "onHide", "visibleChange"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i10.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: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: DynamicFieldTextComponent, selector: "sia-dynamic-field-text" }, { kind: "component", type: DynamicFieldNumberComponent, selector: "sia-dynamic-field-number" }, { kind: "component", type: DynamicFieldDateComponent, selector: "sia-dynamic-field-date" }, { kind: "component", type: DynamicFieldDatetimeComponent, selector: "sia-dynamic-field-datetime" }, { kind: "component", type: DynamicFieldDropdownComponent, selector: "sia-dynamic-field-dropdown" }, { kind: "component", type: DynamicFieldLookupComponent, selector: "sia-dynamic-field-lookup", inputs: ["field", "form", "formGroup", "mode"] }, { kind: "component", type: DynamicFieldTextareaComponent, selector: "sia-dynamic-field-textarea" }] });
543
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: DynamicFormComponent, isStandalone: true, selector: "sia-dynamic-form", inputs: { sections: "sections", entityData: "entityData", mode: "mode", displayMode: "displayMode", visible: "visible", dialogConfig: "dialogConfig", drawerConfig: "drawerConfig", showSubmitButton: "showSubmitButton", showCancelButton: "showCancelButton", submitButtonLabel: "submitButtonLabel", cancelButtonLabel: "cancelButtonLabel", submitButtonIcon: "submitButtonIcon", cancelButtonIcon: "cancelButtonIcon" }, outputs: { formReady: "formReady", formSubmit: "formSubmit", visibleChange: "visibleChange", onCancel: "onCancel", fieldSave: "fieldSave" }, usesOnChanges: true, ngImport: i0, template: "<!-- Inline Mode (no displayMode set) -->\n<ng-container *ngIf=\"isInlineMode\">\n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n</ng-container>\n\n<!-- Dialog Mode -->\n<p-dialog\n *ngIf=\"isDialogMode\"\n [(visible)]=\"visible\"\n [header]=\"dialogHeader | translate\"\n [modal]=\"true\"\n [style]=\"{ width: dialogWidth }\"\n [draggable]=\"dialogDraggable\"\n [resizable]=\"dialogResizable\"\n [maximizable]=\"dialogMaximizable\"\n [closeOnEscape]=\"dialogCloseOnEscape\"\n [dismissableMask]=\"dialogDismissableMask\"\n (onHide)=\"close()\">\n\n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n\n <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n <div class=\"dialog-footer\">\n <p-button *ngIf=\"showCancelButton\" [label]=\"cancelLabel | translate\" [icon]=\"cancelButtonIcon\" severity=\"secondary\" (onClick)=\"handleCancel()\" [disabled]=\"loading\"></p-button>\n <p-button *ngIf=\"showSubmitButton\" [label]=\"submitLabel | translate\" [icon]=\"submitButtonIcon\" (onClick)=\"handleSubmit()\" [loading]=\"loading\" [disabled]=\"form.invalid\"></p-button>\n </div>\n </ng-template>\n</p-dialog>\n\n<!-- Drawer Mode -->\n<p-drawer\n *ngIf=\"isDrawerMode\"\n [(visible)]=\"visible\"\n [header]=\"drawerHeader | translate\"\n [position]=\"drawerPosition\"\n [style]=\"drawerStyle\"\n [showCloseIcon]=\"drawerShowCloseIcon\"\n [closeOnEscape]=\"drawerCloseOnEscape\"\n [modal]=\"drawerDismissable\"\n (onHide)=\"close()\">\n\n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n\n <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n <div class=\"drawer-footer\">\n <p-button *ngIf=\"showCancelButton\" [label]=\"cancelLabel | translate\" [icon]=\"cancelButtonIcon\" severity=\"secondary\" (onClick)=\"handleCancel()\" [disabled]=\"loading\"></p-button>\n <p-button *ngIf=\"showSubmitButton\" [label]=\"submitLabel | translate\" [icon]=\"submitButtonIcon\" (onClick)=\"handleSubmit()\" [loading]=\"loading\" [disabled]=\"form.invalid\"></p-button>\n </div>\n </ng-template>\n</p-drawer>\n\n<!-- Form Content Template -->\n<ng-template #formContent>\n <form [formGroup]=\"form\" class=\"dynamic-form\" (keydown)=\"onFormKeydown($event)\">\n\n <ng-container *ngFor=\"let section of sections\">\n <!-- No title = bare fields -->\n <ng-container *ngIf=\"!section.title\">\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </ng-container>\n\n <!-- Bordered section -->\n <div *ngIf=\"section.title && getSectionStyle(section) === 'bordered'\" class=\"bordered-section\">\n <h3 class=\"section-heading\">\n <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n {{ section.title }}\n </h3>\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Panel section -->\n <p-panel\n *ngIf=\"section.title && getSectionStyle(section) === 'panel'\"\n [toggleable]=\"true\"\n [collapsed]=\"section.collapsed || false\"\n styleClass=\"section-panel\">\n <ng-template pTemplate=\"header\">\n <div class=\"section-header\">\n <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n <span class=\"section-title\">{{ section.title }}</span>\n </div>\n </ng-template>\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </p-panel>\n\n <!-- Heading-only section (title present, style='none' or omitted) -->\n <div *ngIf=\"section.title && getSectionStyle(section) === 'none'\" class=\"heading-section\">\n <h3 class=\"section-heading\">\n <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n {{ section.title }}\n </h3>\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n\n <!-- Custom content projection -->\n <ng-content></ng-content>\n </form>\n</ng-template>\n\n<!-- Field Template -->\n<ng-template #fieldTemplate let-field=\"field\">\n <sia-dynamic-field-text *ngIf=\"field.type === 'text'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-text>\n <sia-dynamic-field-textarea *ngIf=\"field.type === 'textarea'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-textarea>\n <sia-dynamic-field-number *ngIf=\"field.type === 'number' || field.type === 'currency'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-number>\n <sia-dynamic-field-date *ngIf=\"field.type === 'date'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-date>\n <sia-dynamic-field-datetime *ngIf=\"field.type === 'datetime'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-datetime>\n <sia-dynamic-field-dropdown *ngIf=\"field.type === 'dropdown' || field.type === 'enum'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-dropdown>\n <sia-dynamic-field-lookup *ngIf=\"field.type === 'lookup'\" [field]=\"field\" [form]=\"form\" [formGroup]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-lookup>\n <sia-dynamic-field-time *ngIf=\"field.type === 'time'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-time>\n <sia-dynamic-field-checkbox *ngIf=\"field.type === 'checkbox'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-checkbox>\n <sia-dynamic-field-multiselect *ngIf=\"field.type === 'multiselect'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-multiselect>\n <sia-dynamic-field-image *ngIf=\"field.type === 'image'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-image>\n</ng-template>\n\n<!-- Inline Edit Field Template -->\n<ng-template #inlineEditFieldTemplate let-field=\"field\">\n <label class=\"field-label\">{{ field.label | translate }}</label>\n <div class=\"field-display\" *ngIf=\"!isFieldEditing(field.field)\" (click)=\"startEditField(field.field)\" [class.disabled]=\"field.disabled\">\n <span class=\"display-value\" [attr.data-placeholder]=\"field.placeholder || ('design.components_ai.not_informed' | translate)\">{{ getFieldDisplayValue(field.field) }}</span>\n <i class=\"pi pi-pencil edit-icon\" *ngIf=\"!field.disabled\"></i>\n </div>\n <div class=\"field-edit\" *ngIf=\"isFieldEditing(field.field)\">\n <div class=\"input-container\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n <div class=\"edit-actions\">\n <p-button type=\"button\" icon=\"pi pi-check\" [rounded]=\"true\" [text]=\"true\" severity=\"success\" (onClick)=\"saveInlineField(field.field)\" [loading]=\"savingField\" [disabled]=\"form.get(field.field)?.invalid\" size=\"small\"></p-button>\n <p-button type=\"button\" icon=\"pi pi-times\" [rounded]=\"true\" [text]=\"true\" severity=\"danger\" (onClick)=\"cancelInlineEdit()\" [disabled]=\"savingField\" size=\"small\"></p-button>\n </div>\n </div>\n</ng-template>\n", styles: [".dynamic-form{width:100%;display:flex;flex-direction:column;gap:1.5rem}.dynamic-form .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.dynamic-form .grid>div.col-1{grid-column:span 1}.dynamic-form .grid>div.col-2{grid-column:span 2}.dynamic-form .grid>div.col-3{grid-column:span 3}.dynamic-form .grid>div.col-4{grid-column:span 4}.dynamic-form .grid>div.col-5{grid-column:span 5}.dynamic-form .grid>div.col-6{grid-column:span 6}.dynamic-form .grid>div.col-7{grid-column:span 7}.dynamic-form .grid>div.col-8{grid-column:span 8}.dynamic-form .grid>div.col-9{grid-column:span 9}.dynamic-form .grid>div.col-10{grid-column:span 10}.dynamic-form .grid>div.col-11{grid-column:span 11}.dynamic-form .grid>div.col-12{grid-column:span 12}@media (max-width: 575.98px){.dynamic-form .grid>div.col-xs-1{grid-column:span 1}.dynamic-form .grid>div.col-xs-2{grid-column:span 2}.dynamic-form .grid>div.col-xs-3{grid-column:span 3}.dynamic-form .grid>div.col-xs-4{grid-column:span 4}.dynamic-form .grid>div.col-xs-5{grid-column:span 5}.dynamic-form .grid>div.col-xs-6{grid-column:span 6}.dynamic-form .grid>div.col-xs-7{grid-column:span 7}.dynamic-form .grid>div.col-xs-8{grid-column:span 8}.dynamic-form .grid>div.col-xs-9{grid-column:span 9}.dynamic-form .grid>div.col-xs-10{grid-column:span 10}.dynamic-form .grid>div.col-xs-11{grid-column:span 11}.dynamic-form .grid>div.col-xs-12{grid-column:span 12}}@media (min-width: 576px){.dynamic-form .grid>div.col-sm-1{grid-column:span 1}.dynamic-form .grid>div.col-sm-2{grid-column:span 2}.dynamic-form .grid>div.col-sm-3{grid-column:span 3}.dynamic-form .grid>div.col-sm-4{grid-column:span 4}.dynamic-form .grid>div.col-sm-5{grid-column:span 5}.dynamic-form .grid>div.col-sm-6{grid-column:span 6}.dynamic-form .grid>div.col-sm-7{grid-column:span 7}.dynamic-form .grid>div.col-sm-8{grid-column:span 8}.dynamic-form .grid>div.col-sm-9{grid-column:span 9}.dynamic-form .grid>div.col-sm-10{grid-column:span 10}.dynamic-form .grid>div.col-sm-11{grid-column:span 11}.dynamic-form .grid>div.col-sm-12{grid-column:span 12}}@media (min-width: 768px){.dynamic-form .grid>div.col-md-1{grid-column:span 1}.dynamic-form .grid>div.col-md-2{grid-column:span 2}.dynamic-form .grid>div.col-md-3{grid-column:span 3}.dynamic-form .grid>div.col-md-4{grid-column:span 4}.dynamic-form .grid>div.col-md-5{grid-column:span 5}.dynamic-form .grid>div.col-md-6{grid-column:span 6}.dynamic-form .grid>div.col-md-7{grid-column:span 7}.dynamic-form .grid>div.col-md-8{grid-column:span 8}.dynamic-form .grid>div.col-md-9{grid-column:span 9}.dynamic-form .grid>div.col-md-10{grid-column:span 10}.dynamic-form .grid>div.col-md-11{grid-column:span 11}.dynamic-form .grid>div.col-md-12{grid-column:span 12}}@media (min-width: 992px){.dynamic-form .grid>div.col-lg-1{grid-column:span 1}.dynamic-form .grid>div.col-lg-2{grid-column:span 2}.dynamic-form .grid>div.col-lg-3{grid-column:span 3}.dynamic-form .grid>div.col-lg-4{grid-column:span 4}.dynamic-form .grid>div.col-lg-5{grid-column:span 5}.dynamic-form .grid>div.col-lg-6{grid-column:span 6}.dynamic-form .grid>div.col-lg-7{grid-column:span 7}.dynamic-form .grid>div.col-lg-8{grid-column:span 8}.dynamic-form .grid>div.col-lg-9{grid-column:span 9}.dynamic-form .grid>div.col-lg-10{grid-column:span 10}.dynamic-form .grid>div.col-lg-11{grid-column:span 11}.dynamic-form .grid>div.col-lg-12{grid-column:span 12}}@media (min-width: 1200px){.dynamic-form .grid>div.col-xl-1{grid-column:span 1}.dynamic-form .grid>div.col-xl-2{grid-column:span 2}.dynamic-form .grid>div.col-xl-3{grid-column:span 3}.dynamic-form .grid>div.col-xl-4{grid-column:span 4}.dynamic-form .grid>div.col-xl-5{grid-column:span 5}.dynamic-form .grid>div.col-xl-6{grid-column:span 6}.dynamic-form .grid>div.col-xl-7{grid-column:span 7}.dynamic-form .grid>div.col-xl-8{grid-column:span 8}.dynamic-form .grid>div.col-xl-9{grid-column:span 9}.dynamic-form .grid>div.col-xl-10{grid-column:span 10}.dynamic-form .grid>div.col-xl-11{grid-column:span 11}.dynamic-form .grid>div.col-xl-12{grid-column:span 12}}.dynamic-form .bordered-section{border:1px solid var(--p-surface-200, var(--surface-200, #e5e7eb));border-radius:var(--p-border-radius, var(--border-radius, 6px));padding:1.5rem}.dynamic-form .bordered-section .section-heading{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:.5rem}.dynamic-form .bordered-section .section-heading .section-icon{color:var(--primary-color)}.dynamic-form .heading-section .section-heading{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:.5rem}.dynamic-form .heading-section .section-heading .section-icon{color:var(--primary-color)}.dynamic-form ::ng-deep .section-panel .p-panel-header{background-color:var(--surface-50)}.dynamic-form ::ng-deep .section-panel .p-panel-header .section-header{display:flex;align-items:center;gap:.5rem;width:100%}.dynamic-form ::ng-deep .section-panel .p-panel-header .section-header .section-icon{font-size:1.1rem;color:var(--primary-color)}.dynamic-form ::ng-deep .section-panel .p-panel-header .section-header .section-title{font-weight:600;color:var(--text-color)}.dynamic-form ::ng-deep .section-panel .p-panel-content{padding:1.5rem}.dynamic-form .form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--surface-200)}.dialog-footer{display:flex;justify-content:flex-end;gap:.5rem}.drawer-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem;border-top:1px solid var(--surface-200)}.inline-edit-fields{display:flex;flex-direction:column;gap:1rem}.inline-edit-fields .inline-edit-field{display:flex;flex-direction:column;gap:.5rem}.inline-edit-fields .inline-edit-field .field-label{font-weight:500;font-size:.875rem;color:var(--text-color-secondary)}.inline-edit-fields .inline-edit-field .field-display{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:transparent;border:1px solid var(--p-surface-300, var(--surface-300, #d1d5db));border-radius:var(--p-border-radius, var(--border-radius, 6px));cursor:pointer;transition:all .2s ease;min-height:42px}.inline-edit-fields .inline-edit-field .field-display:hover:not(.disabled){border-color:var(--p-primary-color, var(--primary-color))}.inline-edit-fields .inline-edit-field .field-display:hover:not(.disabled) .edit-icon{opacity:1}.inline-edit-fields .inline-edit-field .field-display.disabled{cursor:not-allowed;opacity:.6;background-color:var(--p-surface-50, var(--surface-50, #f9fafb))}.inline-edit-fields .inline-edit-field .field-display .display-value{flex:1;color:var(--text-color)}.inline-edit-fields .inline-edit-field .field-display .display-value:empty:before{content:attr(data-placeholder);color:var(--text-color-secondary);font-style:italic}.inline-edit-fields .inline-edit-field .field-display .edit-icon{color:var(--p-primary-color, var(--primary-color));font-size:.875rem;opacity:0;transition:opacity .2s ease}.inline-edit-fields .inline-edit-field .field-edit{display:flex;align-items:center;gap:.5rem}.inline-edit-fields .inline-edit-field .field-edit .input-container{flex:1}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field{gap:0}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field label{display:none}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field small.p-error{display:none}.inline-edit-fields .inline-edit-field .field-edit .edit-actions{display:flex;gap:0;flex-shrink:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: PanelModule }, { kind: "component", type: i6.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions", "toggleButtonProps"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }, { kind: "directive", type: i7.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: DialogModule }, { kind: "component", type: i8.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: DrawerModule }, { kind: "component", type: i9.Drawer, selector: "p-drawer", inputs: ["appendTo", "blockScroll", "style", "styleClass", "ariaCloseLabel", "autoZIndex", "baseZIndex", "modal", "closeButtonProps", "dismissible", "showCloseIcon", "closeOnEscape", "transitionOptions", "visible", "position", "fullScreen", "header", "maskStyle", "closable"], outputs: ["onShow", "onHide", "visibleChange"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i10.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: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: DynamicFieldTextComponent, selector: "sia-dynamic-field-text" }, { kind: "component", type: DynamicFieldNumberComponent, selector: "sia-dynamic-field-number" }, { kind: "component", type: DynamicFieldDateComponent, selector: "sia-dynamic-field-date" }, { kind: "component", type: DynamicFieldDatetimeComponent, selector: "sia-dynamic-field-datetime" }, { kind: "component", type: DynamicFieldDropdownComponent, selector: "sia-dynamic-field-dropdown" }, { kind: "component", type: DynamicFieldLookupComponent, selector: "sia-dynamic-field-lookup", inputs: ["field", "form", "formGroup", "mode"] }, { kind: "component", type: DynamicFieldTextareaComponent, selector: "sia-dynamic-field-textarea" }, { kind: "component", type: DynamicFieldTimeComponent, selector: "sia-dynamic-field-time" }, { kind: "component", type: DynamicFieldCheckboxComponent, selector: "sia-dynamic-field-checkbox" }, { kind: "component", type: DynamicFieldMultiselectComponent, selector: "sia-dynamic-field-multiselect" }, { kind: "component", type: DynamicFieldImageComponent, selector: "sia-dynamic-field-image" }] });
647
544
  }
648
545
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DynamicFormComponent, decorators: [{
649
546
  type: Component,
@@ -661,15 +558,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
661
558
  DynamicFieldDatetimeComponent,
662
559
  DynamicFieldDropdownComponent,
663
560
  DynamicFieldLookupComponent,
664
- DynamicFieldTextareaComponent
665
- ], template: "<!-- Modo Inline (padr\u00E3o) -->\n<ng-container *ngIf=\"isInlineMode\">\n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n</ng-container>\n\n<!-- Modo Dialog -->\n<p-dialog\n *ngIf=\"isDialogMode\"\n [(visible)]=\"visible\"\n [header]=\"dialogHeader | translate\"\n [modal]=\"true\"\n [style]=\"{ width: dialogWidth }\"\n [draggable]=\"dialogDraggable\"\n [resizable]=\"dialogResizable\"\n [maximizable]=\"dialogMaximizable\"\n [closeOnEscape]=\"dialogCloseOnEscape\"\n [dismissableMask]=\"dialogDismissableMask\"\n (onHide)=\"close()\">\n \n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n \n <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n <div class=\"dialog-footer\">\n <p-button\n *ngIf=\"showCancelButton\"\n [label]=\"cancelLabel | translate\"\n [icon]=\"cancelButtonIcon\"\n severity=\"secondary\"\n (onClick)=\"handleCancel()\"\n [disabled]=\"loading\">\n </p-button>\n <p-button\n *ngIf=\"showSubmitButton\"\n [label]=\"submitLabel | translate\"\n [icon]=\"submitButtonIcon\"\n (onClick)=\"handleSubmit()\"\n [loading]=\"loading\"\n [disabled]=\"form.invalid\">\n </p-button>\n </div>\n </ng-template>\n</p-dialog>\n\n<!-- Modo Drawer -->\n<p-drawer\n *ngIf=\"isDrawerMode\"\n [(visible)]=\"visible\"\n [header]=\"drawerHeader | translate\"\n [position]=\"drawerPosition\"\n [style]=\"drawerStyle\"\n [showCloseIcon]=\"drawerShowCloseIcon\"\n [closeOnEscape]=\"drawerCloseOnEscape\"\n [modal]=\"drawerDismissable\"\n (onHide)=\"close()\">\n \n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n \n <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n <div class=\"drawer-footer\">\n <p-button\n *ngIf=\"showCancelButton\"\n [label]=\"cancelLabel | translate\"\n [icon]=\"cancelButtonIcon\"\n severity=\"secondary\"\n (onClick)=\"handleCancel()\"\n [disabled]=\"loading\">\n </p-button>\n <p-button\n *ngIf=\"showSubmitButton\"\n [label]=\"submitLabel | translate\"\n [icon]=\"submitButtonIcon\"\n (onClick)=\"handleSubmit()\"\n [loading]=\"loading\"\n [disabled]=\"form.invalid\">\n </p-button>\n </div>\n </ng-template>\n</p-drawer>\n\n<!-- Template do Formul\u00E1rio (reutiliz\u00E1vel) -->\n<ng-template #formContent>\n <form [formGroup]=\"form\" class=\"dynamic-form\">\n \n <!-- Filtros Fixos (apenas no modo filter) -->\n <div *ngIf=\"mode === 'filter' && hasFixedFilters\" class=\"fixed-filters-section\">\n <div class=\"grid\">\n <ng-container *ngFor=\"let field of fixedFilters\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Campos Diretos (sem se\u00E7\u00E3o) -->\n <div *ngIf=\"hasFields\">\n <!-- Modo Inline Edit -->\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of formFields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n\n <!-- Modo Form Normal -->\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of formFields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Se\u00E7\u00F5es de Campos (modo form) -->\n <div *ngIf=\"hasSections\" class=\"sections-container\">\n <p-panel \n *ngFor=\"let section of formSections\"\n [toggleable]=\"section.toggleable !== false\"\n [collapsed]=\"section.collapsed || false\"\n [styleClass]=\"'section-panel'\">\n \n <ng-template pTemplate=\"header\">\n <div class=\"section-header\">\n <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n <span class=\"section-title\">{{ section.title }}</span>\n </div>\n </ng-template>\n\n <!-- Modo Inline Edit -->\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n\n <!-- Modo Form Normal -->\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </p-panel>\n </div>\n\n <!-- Se\u00E7\u00F5es de Filtros (apenas no modo filter) -->\n <div *ngIf=\"mode === 'filter' && hasFilterSections\" class=\"filter-sections-container\">\n <p-panel \n *ngFor=\"let section of filterSections\"\n [header]=\"section.title\"\n [toggleable]=\"true\"\n [collapsed]=\"true\">\n\n <div class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </p-panel>\n </div>\n\n <!-- Bot\u00F5es inline (apenas para modo inline) -->\n <div *ngIf=\"isInlineMode && (showSubmitButton || showCancelButton)\" class=\"form-actions\">\n <p-button\n *ngIf=\"showCancelButton\"\n [label]=\"cancelLabel | translate\"\n [icon]=\"cancelButtonIcon\"\n severity=\"secondary\"\n (onClick)=\"handleCancel()\"\n [disabled]=\"loading\">\n </p-button>\n <p-button\n *ngIf=\"showSubmitButton\"\n [label]=\"submitLabel | translate\"\n [icon]=\"submitButtonIcon\"\n (onClick)=\"handleSubmit()\"\n [loading]=\"loading\"\n [disabled]=\"form.invalid\">\n </p-button>\n </div>\n\n </form>\n</ng-template>\n\n<!-- Template de Campo (reutiliz\u00E1vel) -->\n<ng-template #fieldTemplate let-field=\"field\">\n <!-- Text Field -->\n <sia-dynamic-field-text\n *ngIf=\"field.type === 'text'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-text>\n\n <!-- Textarea Field -->\n <sia-dynamic-field-textarea\n *ngIf=\"field.type === 'textarea'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-textarea>\n\n <!-- Number Field -->\n <sia-dynamic-field-number\n *ngIf=\"field.type === 'number'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-number>\n\n <!-- Date Field -->\n <sia-dynamic-field-date\n *ngIf=\"field.type === 'date'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-date>\n\n <!-- Datetime Field -->\n <sia-dynamic-field-datetime\n *ngIf=\"field.type === 'datetime'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-datetime>\n\n <!-- Dropdown/Enum Field -->\n <sia-dynamic-field-dropdown\n *ngIf=\"field.type === 'dropdown' || field.type === 'enum'\"\n [field]=\"field\"\n [form]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-dropdown>\n\n <!-- Lookup Field -->\n <sia-dynamic-field-lookup\n *ngIf=\"field.type === 'lookup'\"\n [field]=\"field\"\n [form]=\"form\"\n [formGroup]=\"form\"\n [mode]=\"fieldMode\">\n </sia-dynamic-field-lookup>\n</ng-template>\n\n\n<!-- Template de Campo Inline Edit -->\n<ng-template #inlineEditFieldTemplate let-field=\"field\">\n <div class=\"edit-inline-field\">\n <label class=\"field-label\">{{ field.label | translate }}</label>\n \n <!-- Display Mode -->\n <div class=\"field-display\" \n *ngIf=\"!isFieldEditing(field.field)\" \n (click)=\"startEditField(field.field)\"\n [class.disabled]=\"field.disabled\">\n <span class=\"display-value\" \n [attr.data-placeholder]=\"field.placeholder || ('crmx.business.not_informed' | translate)\">\n {{ getFieldDisplayValue(field.field) }}\n </span>\n <i class=\"pi pi-pencil edit-icon\" *ngIf=\"!field.disabled\"></i>\n </div>\n \n <!-- Edit Mode -->\n <div class=\"field-edit\" *ngIf=\"isFieldEditing(field.field)\">\n <div class=\"input-container\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n \n <!-- Action Buttons -->\n <div class=\"edit-actions\">\n <p-button \n type=\"button\" \n icon=\"pi pi-check\" \n [rounded]=\"true\"\n severity=\"primary\"\n (onClick)=\"saveInlineField(field.field)\" \n [loading]=\"savingField\"\n [disabled]=\"form.get(field.field)?.invalid\">\n </p-button>\n <p-button \n type=\"button\" \n icon=\"pi pi-times\" \n [rounded]=\"true\"\n severity=\"secondary\"\n (onClick)=\"cancelInlineEdit()\"\n [disabled]=\"savingField\">\n </p-button>\n </div>\n \n <!-- Error Message -->\n <div class=\"field-error\" *ngIf=\"form.get(field.field)?.invalid && form.get(field.field)?.touched\">\n <small class=\"p-error\">\n {{ form.get(field.field)?.errors?.['required'] ? ('crmx.business.required_field' | translate) : '' }}\n </small>\n </div>\n </div>\n </div>\n</ng-template>\n", styles: [".dynamic-form{width:100%}.dynamic-form .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.dynamic-form .grid>div.col-1{grid-column:span 1}.dynamic-form .grid>div.col-2{grid-column:span 2}.dynamic-form .grid>div.col-3{grid-column:span 3}.dynamic-form .grid>div.col-4{grid-column:span 4}.dynamic-form .grid>div.col-5{grid-column:span 5}.dynamic-form .grid>div.col-6{grid-column:span 6}.dynamic-form .grid>div.col-7{grid-column:span 7}.dynamic-form .grid>div.col-8{grid-column:span 8}.dynamic-form .grid>div.col-9{grid-column:span 9}.dynamic-form .grid>div.col-10{grid-column:span 10}.dynamic-form .grid>div.col-11{grid-column:span 11}.dynamic-form .grid>div.col-12{grid-column:span 12}@media (max-width: 575.98px){.dynamic-form .grid>div.col-xs-1{grid-column:span 1}.dynamic-form .grid>div.col-xs-2{grid-column:span 2}.dynamic-form .grid>div.col-xs-3{grid-column:span 3}.dynamic-form .grid>div.col-xs-4{grid-column:span 4}.dynamic-form .grid>div.col-xs-5{grid-column:span 5}.dynamic-form .grid>div.col-xs-6{grid-column:span 6}.dynamic-form .grid>div.col-xs-7{grid-column:span 7}.dynamic-form .grid>div.col-xs-8{grid-column:span 8}.dynamic-form .grid>div.col-xs-9{grid-column:span 9}.dynamic-form .grid>div.col-xs-10{grid-column:span 10}.dynamic-form .grid>div.col-xs-11{grid-column:span 11}.dynamic-form .grid>div.col-xs-12{grid-column:span 12}}@media (min-width: 576px){.dynamic-form .grid>div.col-sm-1{grid-column:span 1}.dynamic-form .grid>div.col-sm-2{grid-column:span 2}.dynamic-form .grid>div.col-sm-3{grid-column:span 3}.dynamic-form .grid>div.col-sm-4{grid-column:span 4}.dynamic-form .grid>div.col-sm-5{grid-column:span 5}.dynamic-form .grid>div.col-sm-6{grid-column:span 6}.dynamic-form .grid>div.col-sm-7{grid-column:span 7}.dynamic-form .grid>div.col-sm-8{grid-column:span 8}.dynamic-form .grid>div.col-sm-9{grid-column:span 9}.dynamic-form .grid>div.col-sm-10{grid-column:span 10}.dynamic-form .grid>div.col-sm-11{grid-column:span 11}.dynamic-form .grid>div.col-sm-12{grid-column:span 12}}@media (min-width: 768px){.dynamic-form .grid>div.col-md-1{grid-column:span 1}.dynamic-form .grid>div.col-md-2{grid-column:span 2}.dynamic-form .grid>div.col-md-3{grid-column:span 3}.dynamic-form .grid>div.col-md-4{grid-column:span 4}.dynamic-form .grid>div.col-md-5{grid-column:span 5}.dynamic-form .grid>div.col-md-6{grid-column:span 6}.dynamic-form .grid>div.col-md-7{grid-column:span 7}.dynamic-form .grid>div.col-md-8{grid-column:span 8}.dynamic-form .grid>div.col-md-9{grid-column:span 9}.dynamic-form .grid>div.col-md-10{grid-column:span 10}.dynamic-form .grid>div.col-md-11{grid-column:span 11}.dynamic-form .grid>div.col-md-12{grid-column:span 12}}@media (min-width: 992px){.dynamic-form .grid>div.col-lg-1{grid-column:span 1}.dynamic-form .grid>div.col-lg-2{grid-column:span 2}.dynamic-form .grid>div.col-lg-3{grid-column:span 3}.dynamic-form .grid>div.col-lg-4{grid-column:span 4}.dynamic-form .grid>div.col-lg-5{grid-column:span 5}.dynamic-form .grid>div.col-lg-6{grid-column:span 6}.dynamic-form .grid>div.col-lg-7{grid-column:span 7}.dynamic-form .grid>div.col-lg-8{grid-column:span 8}.dynamic-form .grid>div.col-lg-9{grid-column:span 9}.dynamic-form .grid>div.col-lg-10{grid-column:span 10}.dynamic-form .grid>div.col-lg-11{grid-column:span 11}.dynamic-form .grid>div.col-lg-12{grid-column:span 12}}@media (min-width: 1200px){.dynamic-form .grid>div.col-xl-1{grid-column:span 1}.dynamic-form .grid>div.col-xl-2{grid-column:span 2}.dynamic-form .grid>div.col-xl-3{grid-column:span 3}.dynamic-form .grid>div.col-xl-4{grid-column:span 4}.dynamic-form .grid>div.col-xl-5{grid-column:span 5}.dynamic-form .grid>div.col-xl-6{grid-column:span 6}.dynamic-form .grid>div.col-xl-7{grid-column:span 7}.dynamic-form .grid>div.col-xl-8{grid-column:span 8}.dynamic-form .grid>div.col-xl-9{grid-column:span 9}.dynamic-form .grid>div.col-xl-10{grid-column:span 10}.dynamic-form .grid>div.col-xl-11{grid-column:span 11}.dynamic-form .grid>div.col-xl-12{grid-column:span 12}}.dynamic-form .sections-container{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-header{background-color:var(--surface-50);border-color:var(--surface-200)}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-header .section-header{display:flex;align-items:center;gap:.5rem;width:100%}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-header .section-header .section-icon{font-size:1.1rem;color:var(--primary-color)}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-header .section-header .section-title{font-weight:600;color:var(--text-color)}.dynamic-form .sections-container ::ng-deep .section-panel .p-panel-content{padding:1.5rem}.dynamic-form .fixed-filters-section{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--surface-200)}.dynamic-form .filter-sections-container{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.dynamic-form .form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--surface-200)}.dialog-footer{display:flex;justify-content:flex-end;gap:.5rem}.drawer-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem;border-top:1px solid var(--surface-200)}.inline-edit-fields{display:flex;flex-direction:column;gap:1rem}.inline-edit-fields .inline-edit-field{display:flex;flex-direction:column;gap:.25rem}.inline-edit-fields .inline-edit-field .field-label{font-weight:500;font-size:.875rem;color:var(--text-color-secondary);margin-bottom:.25rem}.inline-edit-fields .inline-edit-field .field-display{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:var(--surface-50);border:1px solid var(--surface-200);border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;min-height:42px}.inline-edit-fields .inline-edit-field .field-display:hover:not(.disabled){background-color:var(--surface-100);border-color:var(--primary-color)}.inline-edit-fields .inline-edit-field .field-display:hover:not(.disabled) .edit-icon{opacity:1}.inline-edit-fields .inline-edit-field .field-display.disabled{cursor:not-allowed;opacity:.6}.inline-edit-fields .inline-edit-field .field-display .display-value{flex:1;color:var(--text-color)}.inline-edit-fields .inline-edit-field .field-display .display-value:empty:before{content:attr(data-placeholder);color:var(--text-color-secondary);font-style:italic}.inline-edit-fields .inline-edit-field .field-display .edit-icon{color:var(--primary-color);font-size:.875rem;opacity:.5;transition:opacity .2s ease}.inline-edit-fields .inline-edit-field .field-edit{display:flex;flex-direction:column;gap:.5rem}.inline-edit-fields .inline-edit-field .field-edit .input-container{flex:1}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field{gap:0}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field label{display:none}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field small.p-error{display:none}.inline-edit-fields .inline-edit-field .field-edit .edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.inline-edit-fields .inline-edit-field .field-edit .field-error small.p-error{color:var(--p-red-500);font-size:.875rem}\n"] }]
666
- }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.TranslationService }, { type: i3.MaskService }, { type: i4.LocaleService }], propDecorators: { formFields: [{
667
- type: Input
668
- }], formSections: [{
669
- type: Input
670
- }], fixedFilters: [{
671
- type: Input
672
- }], filterSections: [{
561
+ DynamicFieldTextareaComponent,
562
+ DynamicFieldTimeComponent,
563
+ DynamicFieldCheckboxComponent,
564
+ DynamicFieldMultiselectComponent,
565
+ DynamicFieldImageComponent
566
+ ], template: "<!-- Inline Mode (no displayMode set) -->\n<ng-container *ngIf=\"isInlineMode\">\n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n</ng-container>\n\n<!-- Dialog Mode -->\n<p-dialog\n *ngIf=\"isDialogMode\"\n [(visible)]=\"visible\"\n [header]=\"dialogHeader | translate\"\n [modal]=\"true\"\n [style]=\"{ width: dialogWidth }\"\n [draggable]=\"dialogDraggable\"\n [resizable]=\"dialogResizable\"\n [maximizable]=\"dialogMaximizable\"\n [closeOnEscape]=\"dialogCloseOnEscape\"\n [dismissableMask]=\"dialogDismissableMask\"\n (onHide)=\"close()\">\n\n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n\n <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n <div class=\"dialog-footer\">\n <p-button *ngIf=\"showCancelButton\" [label]=\"cancelLabel | translate\" [icon]=\"cancelButtonIcon\" severity=\"secondary\" (onClick)=\"handleCancel()\" [disabled]=\"loading\"></p-button>\n <p-button *ngIf=\"showSubmitButton\" [label]=\"submitLabel | translate\" [icon]=\"submitButtonIcon\" (onClick)=\"handleSubmit()\" [loading]=\"loading\" [disabled]=\"form.invalid\"></p-button>\n </div>\n </ng-template>\n</p-dialog>\n\n<!-- Drawer Mode -->\n<p-drawer\n *ngIf=\"isDrawerMode\"\n [(visible)]=\"visible\"\n [header]=\"drawerHeader | translate\"\n [position]=\"drawerPosition\"\n [style]=\"drawerStyle\"\n [showCloseIcon]=\"drawerShowCloseIcon\"\n [closeOnEscape]=\"drawerCloseOnEscape\"\n [modal]=\"drawerDismissable\"\n (onHide)=\"close()\">\n\n <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n\n <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n <div class=\"drawer-footer\">\n <p-button *ngIf=\"showCancelButton\" [label]=\"cancelLabel | translate\" [icon]=\"cancelButtonIcon\" severity=\"secondary\" (onClick)=\"handleCancel()\" [disabled]=\"loading\"></p-button>\n <p-button *ngIf=\"showSubmitButton\" [label]=\"submitLabel | translate\" [icon]=\"submitButtonIcon\" (onClick)=\"handleSubmit()\" [loading]=\"loading\" [disabled]=\"form.invalid\"></p-button>\n </div>\n </ng-template>\n</p-drawer>\n\n<!-- Form Content Template -->\n<ng-template #formContent>\n <form [formGroup]=\"form\" class=\"dynamic-form\" (keydown)=\"onFormKeydown($event)\">\n\n <ng-container *ngFor=\"let section of sections\">\n <!-- No title = bare fields -->\n <ng-container *ngIf=\"!section.title\">\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </ng-container>\n\n <!-- Bordered section -->\n <div *ngIf=\"section.title && getSectionStyle(section) === 'bordered'\" class=\"bordered-section\">\n <h3 class=\"section-heading\">\n <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n {{ section.title }}\n </h3>\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Panel section -->\n <p-panel\n *ngIf=\"section.title && getSectionStyle(section) === 'panel'\"\n [toggleable]=\"true\"\n [collapsed]=\"section.collapsed || false\"\n styleClass=\"section-panel\">\n <ng-template pTemplate=\"header\">\n <div class=\"section-header\">\n <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n <span class=\"section-title\">{{ section.title }}</span>\n </div>\n </ng-template>\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </p-panel>\n\n <!-- Heading-only section (title present, style='none' or omitted) -->\n <div *ngIf=\"section.title && getSectionStyle(section) === 'none'\" class=\"heading-section\">\n <h3 class=\"section-heading\">\n <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n {{ section.title }}\n </h3>\n <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n <ng-container *ngFor=\"let field of section.fields\">\n <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n\n <!-- Custom content projection -->\n <ng-content></ng-content>\n </form>\n</ng-template>\n\n<!-- Field Template -->\n<ng-template #fieldTemplate let-field=\"field\">\n <sia-dynamic-field-text *ngIf=\"field.type === 'text'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-text>\n <sia-dynamic-field-textarea *ngIf=\"field.type === 'textarea'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-textarea>\n <sia-dynamic-field-number *ngIf=\"field.type === 'number' || field.type === 'currency'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-number>\n <sia-dynamic-field-date *ngIf=\"field.type === 'date'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-date>\n <sia-dynamic-field-datetime *ngIf=\"field.type === 'datetime'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-datetime>\n <sia-dynamic-field-dropdown *ngIf=\"field.type === 'dropdown' || field.type === 'enum'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-dropdown>\n <sia-dynamic-field-lookup *ngIf=\"field.type === 'lookup'\" [field]=\"field\" [form]=\"form\" [formGroup]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-lookup>\n <sia-dynamic-field-time *ngIf=\"field.type === 'time'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-time>\n <sia-dynamic-field-checkbox *ngIf=\"field.type === 'checkbox'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-checkbox>\n <sia-dynamic-field-multiselect *ngIf=\"field.type === 'multiselect'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-multiselect>\n <sia-dynamic-field-image *ngIf=\"field.type === 'image'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-image>\n</ng-template>\n\n<!-- Inline Edit Field Template -->\n<ng-template #inlineEditFieldTemplate let-field=\"field\">\n <label class=\"field-label\">{{ field.label | translate }}</label>\n <div class=\"field-display\" *ngIf=\"!isFieldEditing(field.field)\" (click)=\"startEditField(field.field)\" [class.disabled]=\"field.disabled\">\n <span class=\"display-value\" [attr.data-placeholder]=\"field.placeholder || ('design.components_ai.not_informed' | translate)\">{{ getFieldDisplayValue(field.field) }}</span>\n <i class=\"pi pi-pencil edit-icon\" *ngIf=\"!field.disabled\"></i>\n </div>\n <div class=\"field-edit\" *ngIf=\"isFieldEditing(field.field)\">\n <div class=\"input-container\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n </div>\n <div class=\"edit-actions\">\n <p-button type=\"button\" icon=\"pi pi-check\" [rounded]=\"true\" [text]=\"true\" severity=\"success\" (onClick)=\"saveInlineField(field.field)\" [loading]=\"savingField\" [disabled]=\"form.get(field.field)?.invalid\" size=\"small\"></p-button>\n <p-button type=\"button\" icon=\"pi pi-times\" [rounded]=\"true\" [text]=\"true\" severity=\"danger\" (onClick)=\"cancelInlineEdit()\" [disabled]=\"savingField\" size=\"small\"></p-button>\n </div>\n </div>\n</ng-template>\n", styles: [".dynamic-form{width:100%;display:flex;flex-direction:column;gap:1.5rem}.dynamic-form .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.dynamic-form .grid>div.col-1{grid-column:span 1}.dynamic-form .grid>div.col-2{grid-column:span 2}.dynamic-form .grid>div.col-3{grid-column:span 3}.dynamic-form .grid>div.col-4{grid-column:span 4}.dynamic-form .grid>div.col-5{grid-column:span 5}.dynamic-form .grid>div.col-6{grid-column:span 6}.dynamic-form .grid>div.col-7{grid-column:span 7}.dynamic-form .grid>div.col-8{grid-column:span 8}.dynamic-form .grid>div.col-9{grid-column:span 9}.dynamic-form .grid>div.col-10{grid-column:span 10}.dynamic-form .grid>div.col-11{grid-column:span 11}.dynamic-form .grid>div.col-12{grid-column:span 12}@media (max-width: 575.98px){.dynamic-form .grid>div.col-xs-1{grid-column:span 1}.dynamic-form .grid>div.col-xs-2{grid-column:span 2}.dynamic-form .grid>div.col-xs-3{grid-column:span 3}.dynamic-form .grid>div.col-xs-4{grid-column:span 4}.dynamic-form .grid>div.col-xs-5{grid-column:span 5}.dynamic-form .grid>div.col-xs-6{grid-column:span 6}.dynamic-form .grid>div.col-xs-7{grid-column:span 7}.dynamic-form .grid>div.col-xs-8{grid-column:span 8}.dynamic-form .grid>div.col-xs-9{grid-column:span 9}.dynamic-form .grid>div.col-xs-10{grid-column:span 10}.dynamic-form .grid>div.col-xs-11{grid-column:span 11}.dynamic-form .grid>div.col-xs-12{grid-column:span 12}}@media (min-width: 576px){.dynamic-form .grid>div.col-sm-1{grid-column:span 1}.dynamic-form .grid>div.col-sm-2{grid-column:span 2}.dynamic-form .grid>div.col-sm-3{grid-column:span 3}.dynamic-form .grid>div.col-sm-4{grid-column:span 4}.dynamic-form .grid>div.col-sm-5{grid-column:span 5}.dynamic-form .grid>div.col-sm-6{grid-column:span 6}.dynamic-form .grid>div.col-sm-7{grid-column:span 7}.dynamic-form .grid>div.col-sm-8{grid-column:span 8}.dynamic-form .grid>div.col-sm-9{grid-column:span 9}.dynamic-form .grid>div.col-sm-10{grid-column:span 10}.dynamic-form .grid>div.col-sm-11{grid-column:span 11}.dynamic-form .grid>div.col-sm-12{grid-column:span 12}}@media (min-width: 768px){.dynamic-form .grid>div.col-md-1{grid-column:span 1}.dynamic-form .grid>div.col-md-2{grid-column:span 2}.dynamic-form .grid>div.col-md-3{grid-column:span 3}.dynamic-form .grid>div.col-md-4{grid-column:span 4}.dynamic-form .grid>div.col-md-5{grid-column:span 5}.dynamic-form .grid>div.col-md-6{grid-column:span 6}.dynamic-form .grid>div.col-md-7{grid-column:span 7}.dynamic-form .grid>div.col-md-8{grid-column:span 8}.dynamic-form .grid>div.col-md-9{grid-column:span 9}.dynamic-form .grid>div.col-md-10{grid-column:span 10}.dynamic-form .grid>div.col-md-11{grid-column:span 11}.dynamic-form .grid>div.col-md-12{grid-column:span 12}}@media (min-width: 992px){.dynamic-form .grid>div.col-lg-1{grid-column:span 1}.dynamic-form .grid>div.col-lg-2{grid-column:span 2}.dynamic-form .grid>div.col-lg-3{grid-column:span 3}.dynamic-form .grid>div.col-lg-4{grid-column:span 4}.dynamic-form .grid>div.col-lg-5{grid-column:span 5}.dynamic-form .grid>div.col-lg-6{grid-column:span 6}.dynamic-form .grid>div.col-lg-7{grid-column:span 7}.dynamic-form .grid>div.col-lg-8{grid-column:span 8}.dynamic-form .grid>div.col-lg-9{grid-column:span 9}.dynamic-form .grid>div.col-lg-10{grid-column:span 10}.dynamic-form .grid>div.col-lg-11{grid-column:span 11}.dynamic-form .grid>div.col-lg-12{grid-column:span 12}}@media (min-width: 1200px){.dynamic-form .grid>div.col-xl-1{grid-column:span 1}.dynamic-form .grid>div.col-xl-2{grid-column:span 2}.dynamic-form .grid>div.col-xl-3{grid-column:span 3}.dynamic-form .grid>div.col-xl-4{grid-column:span 4}.dynamic-form .grid>div.col-xl-5{grid-column:span 5}.dynamic-form .grid>div.col-xl-6{grid-column:span 6}.dynamic-form .grid>div.col-xl-7{grid-column:span 7}.dynamic-form .grid>div.col-xl-8{grid-column:span 8}.dynamic-form .grid>div.col-xl-9{grid-column:span 9}.dynamic-form .grid>div.col-xl-10{grid-column:span 10}.dynamic-form .grid>div.col-xl-11{grid-column:span 11}.dynamic-form .grid>div.col-xl-12{grid-column:span 12}}.dynamic-form .bordered-section{border:1px solid var(--p-surface-200, var(--surface-200, #e5e7eb));border-radius:var(--p-border-radius, var(--border-radius, 6px));padding:1.5rem}.dynamic-form .bordered-section .section-heading{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:.5rem}.dynamic-form .bordered-section .section-heading .section-icon{color:var(--primary-color)}.dynamic-form .heading-section .section-heading{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:.5rem}.dynamic-form .heading-section .section-heading .section-icon{color:var(--primary-color)}.dynamic-form ::ng-deep .section-panel .p-panel-header{background-color:var(--surface-50)}.dynamic-form ::ng-deep .section-panel .p-panel-header .section-header{display:flex;align-items:center;gap:.5rem;width:100%}.dynamic-form ::ng-deep .section-panel .p-panel-header .section-header .section-icon{font-size:1.1rem;color:var(--primary-color)}.dynamic-form ::ng-deep .section-panel .p-panel-header .section-header .section-title{font-weight:600;color:var(--text-color)}.dynamic-form ::ng-deep .section-panel .p-panel-content{padding:1.5rem}.dynamic-form .form-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--surface-200)}.dialog-footer{display:flex;justify-content:flex-end;gap:.5rem}.drawer-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem;border-top:1px solid var(--surface-200)}.inline-edit-fields{display:flex;flex-direction:column;gap:1rem}.inline-edit-fields .inline-edit-field{display:flex;flex-direction:column;gap:.5rem}.inline-edit-fields .inline-edit-field .field-label{font-weight:500;font-size:.875rem;color:var(--text-color-secondary)}.inline-edit-fields .inline-edit-field .field-display{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:transparent;border:1px solid var(--p-surface-300, var(--surface-300, #d1d5db));border-radius:var(--p-border-radius, var(--border-radius, 6px));cursor:pointer;transition:all .2s ease;min-height:42px}.inline-edit-fields .inline-edit-field .field-display:hover:not(.disabled){border-color:var(--p-primary-color, var(--primary-color))}.inline-edit-fields .inline-edit-field .field-display:hover:not(.disabled) .edit-icon{opacity:1}.inline-edit-fields .inline-edit-field .field-display.disabled{cursor:not-allowed;opacity:.6;background-color:var(--p-surface-50, var(--surface-50, #f9fafb))}.inline-edit-fields .inline-edit-field .field-display .display-value{flex:1;color:var(--text-color)}.inline-edit-fields .inline-edit-field .field-display .display-value:empty:before{content:attr(data-placeholder);color:var(--text-color-secondary);font-style:italic}.inline-edit-fields .inline-edit-field .field-display .edit-icon{color:var(--p-primary-color, var(--primary-color));font-size:.875rem;opacity:0;transition:opacity .2s ease}.inline-edit-fields .inline-edit-field .field-edit{display:flex;align-items:center;gap:.5rem}.inline-edit-fields .inline-edit-field .field-edit .input-container{flex:1}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field{gap:0}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field label{display:none}.inline-edit-fields .inline-edit-field .field-edit .input-container ::ng-deep .field small.p-error{display:none}.inline-edit-fields .inline-edit-field .field-edit .edit-actions{display:flex;gap:0;flex-shrink:0}\n"] }]
567
+ }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.TranslationService }, { type: i3.MaskService }, { type: i4.LocaleService }], propDecorators: { sections: [{
673
568
  type: Input
674
569
  }], entityData: [{
675
570
  type: Input
@@ -706,4 +601,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
706
601
  }], fieldSave: [{
707
602
  type: Output
708
603
  }] } });
709
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"","sources":["../../../../../projects/components-ai/src/lib/components/dynamic-form/dynamic-form.component.ts","../../../../../projects/components-ai/src/lib/components/dynamic-form/dynamic-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, OnChanges, SimpleChanges } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormBuilder, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { PanelModule } from 'primeng/panel';\nimport { DialogModule } from 'primeng/dialog';\nimport { DrawerModule } from 'primeng/drawer';\nimport { ButtonModule } from 'primeng/button';\nimport { \n  DynamicFormFieldConfig, \n  DynamicFormSection,\n  DynamicFormDisplayMode,\n  DynamicFormDialogConfig,\n  DynamicFormDrawerConfig\n} from './models/dynamic-form.models';\nimport { TranslationService } from '../../services/translation.service';\nimport { MaskService } from '../../services/mask.service';\nimport { LocaleService } from '../../services/locale.service';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { DynamicFieldTextComponent } from './fields/dynamic-field-text.component';\nimport { DynamicFieldNumberComponent } from './fields/dynamic-field-number.component';\nimport { DynamicFieldDateComponent } from './fields/dynamic-field-date.component';\nimport { DynamicFieldDatetimeComponent } from './fields/dynamic-field-datetime.component';\nimport { DynamicFieldDropdownComponent } from './fields/dynamic-field-dropdown.component';\nimport { DynamicFieldLookupComponent } from './fields/dynamic-field-lookup.component';\nimport { DynamicFieldTextareaComponent } from './fields/dynamic-field-textarea.component';\n\n@Component({\n  selector: 'sia-dynamic-form',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    PanelModule,\n    DialogModule,\n    DrawerModule,\n    ButtonModule,\n    TranslatePipe,\n    DynamicFieldTextComponent,\n    DynamicFieldNumberComponent,\n    DynamicFieldDateComponent,\n    DynamicFieldDatetimeComponent,\n    DynamicFieldDropdownComponent,\n    DynamicFieldLookupComponent,\n    DynamicFieldTextareaComponent\n  ],\n  templateUrl: './dynamic-form.component.html',\n  styleUrl: './dynamic-form.component.scss'\n})\nexport class DynamicFormComponent implements OnInit, OnChanges {\n  @Input() formFields: DynamicFormFieldConfig[] = [];\n  @Input() formSections: DynamicFormSection[] = [];\n  @Input() fixedFilters: DynamicFormFieldConfig[] = []; // Filtros fixos (sempre visíveis no topo)\n  @Input() filterSections: DynamicFormSection[] = []; // Seções de filtros (colapsáveis)\n  @Input() entityData: any = null;\n  @Input() mode: 'form' | 'filter' | 'inline-edit' = 'form';\n  \n  // Display Mode Configuration\n  @Input() displayMode: DynamicFormDisplayMode = 'inline';\n  @Input() visible: boolean = false;\n  @Input() dialogConfig: DynamicFormDialogConfig = {};\n  @Input() drawerConfig: DynamicFormDrawerConfig = {};\n  \n  // Button Configuration\n  @Input() showSubmitButton: boolean = false;\n  @Input() showCancelButton: boolean = false;\n  @Input() submitButtonLabel?: string;\n  @Input() cancelButtonLabel?: string;\n  @Input() submitButtonIcon: string = 'pi pi-check';\n  @Input() cancelButtonIcon: string = 'pi pi-times';\n  \n  @Output() formReady = new EventEmitter<FormGroup>();\n  @Output() formSubmit = new EventEmitter<any>();\n  @Output() visibleChange = new EventEmitter<boolean>();\n  @Output() onCancel = new EventEmitter<void>();\n  @Output() fieldSave = new EventEmitter<{ field: string, value: any }>();\n\n  form!: FormGroup;\n  loading: boolean = false;\n  \n  // Inline edit mode state\n  editingField: string | null = null;\n  savingField: boolean = false;\n\n  get hasFields(): boolean {\n    return this.formFields.length > 0;\n  }\n\n  get hasSections(): boolean {\n    return this.formSections.length > 0;\n  }\n\n  get hasFixedFilters(): boolean {\n    return this.fixedFilters.length > 0;\n  }\n\n  get hasFilterSections(): boolean {\n    return this.filterSections.length > 0;\n  }\n\n  get allFields(): DynamicFormFieldConfig[] {\n    // Retorna todos os campos (diretos + das seções + filtros fixos + seções de filtros)\n    const sectionFields = this.formSections.flatMap(section => section.fields);\n    const filterSectionFields = this.filterSections.flatMap(section => section.fields);\n    return [...this.formFields, ...sectionFields, ...this.fixedFilters, ...filterSectionFields];\n  }\n\n  get isInlineMode(): boolean {\n    return this.displayMode === 'inline';\n  }\n\n  get isInlineEditMode(): boolean {\n    return this.mode === 'inline-edit';\n  }\n\n  get fieldMode(): 'form' | 'filter' {\n    return this.isInlineEditMode ? 'form' : this.mode as 'form' | 'filter';\n  }\n\n  get isDialogMode(): boolean {\n    return this.displayMode === 'dialog';\n  }\n\n  get isDrawerMode(): boolean {\n    return this.displayMode === 'drawer';\n  }\n\n  // Dialog configuration with defaults\n  get dialogHeader(): string {\n    return this.dialogConfig.header || this.translationService.translate('design.components_ai.form');\n  }\n\n  get dialogWidth(): string {\n    return this.dialogConfig.width || '600px';\n  }\n\n  get dialogDraggable(): boolean {\n    return this.dialogConfig.draggable !== undefined ? this.dialogConfig.draggable : false;\n  }\n\n  get dialogResizable(): boolean {\n    return this.dialogConfig.resizable !== undefined ? this.dialogConfig.resizable : false;\n  }\n\n  get dialogMaximizable(): boolean {\n    return this.dialogConfig.maximizable !== undefined ? this.dialogConfig.maximizable : false;\n  }\n\n  get dialogCloseOnEscape(): boolean {\n    return this.dialogConfig.closeOnEscape !== undefined ? this.dialogConfig.closeOnEscape : true;\n  }\n\n  get dialogDismissableMask(): boolean {\n    return this.dialogConfig.dismissableMask !== undefined ? this.dialogConfig.dismissableMask : false;\n  }\n\n  // Drawer configuration with defaults\n  get drawerHeader(): string {\n    return this.drawerConfig.header || this.translationService.translate('design.components_ai.form');\n  }\n\n  get drawerPosition(): 'left' | 'right' | 'top' | 'bottom' {\n    return this.drawerConfig.position || 'right';\n  }\n\n  get drawerShowCloseIcon(): boolean {\n    return this.drawerConfig.showCloseIcon !== undefined ? this.drawerConfig.showCloseIcon : true;\n  }\n\n  get drawerCloseOnEscape(): boolean {\n    return this.drawerConfig.closeOnEscape !== undefined ? this.drawerConfig.closeOnEscape : true;\n  }\n\n  get drawerDismissable(): boolean {\n    return this.drawerConfig.dismissable !== undefined ? this.drawerConfig.dismissable : true;\n  }\n\n  get drawerStyle(): { [key: string]: string } {\n    const position = this.drawerPosition;\n    const isHorizontal = position === 'left' || position === 'right';\n    \n    // Se tem customWidth, usa ela\n    if (this.drawerConfig.customWidth) {\n      return isHorizontal \n        ? { width: this.drawerConfig.customWidth }\n        : { height: this.drawerConfig.customWidth };\n    }\n    \n    // Usa o tamanho padronizado\n    const size = this.drawerConfig.size || 'medium';\n    const sizeMap = {\n      'small': isHorizontal ? '25%' : '25vh',\n      'medium': isHorizontal ? '40%' : '40vh',\n      'large': isHorizontal ? '60%' : '60vh',\n      'xlarge': isHorizontal ? '80%' : '80vh',\n      'full': isHorizontal ? '100%' : '100vh'\n    };\n    \n    const sizeValue = sizeMap[size];\n    return isHorizontal \n      ? { width: sizeValue }\n      : { height: sizeValue };\n  }\n\n  get submitLabel(): string {\n    return this.submitButtonLabel || this.translationService.translate('design.components_ai.save');\n  }\n\n  get cancelLabel(): string {\n    return this.cancelButtonLabel || this.translationService.translate('design.components_ai.cancel');\n  }\n\n  constructor(\n    private fb: FormBuilder,\n    private translationService: TranslationService,\n    private maskService: MaskService,\n    private localeService: LocaleService\n  ) {}\n\n  ngOnInit(): void {\n    this.initForm();\n    if (this.entityData) {\n      this.loadEntityData();\n    }\n    this.setupConditionalFieldsWatcher();\n    this.formReady.emit(this.form);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Handle entityData changes first\n    if (changes['entityData'] && this.form) {\n      if (this.entityData) {\n        this.loadEntityData();\n      } else {\n        this.resetForm();\n      }\n    }\n    \n    // When dialog/drawer opens, ensure form is loaded with entityData\n    if (changes['visible'] && changes['visible'].currentValue === true) {\n      this.loading = false;\n      \n      // If opening with entityData, reload it to ensure form is populated\n      if (this.entityData && this.form) {\n        this.loadEntityData();\n      } else if (!this.entityData && this.form) {\n        // If opening without entityData (new record), reset form\n        this.resetForm();\n      }\n    }\n  }\n\n  initForm(): void {\n    const formControls: any = {};\n    \n    // Processa todos os campos (diretos + das seções)\n    this.allFields.forEach(field => {\n      const defaultValue = this.getDefaultValue(field);\n      const validators = this.mode === 'filter' ? [] : (field.validators || []);\n      \n      const control = this.fb.control(\n        { value: defaultValue, disabled: field.disabled || false },\n        validators\n      );\n      \n      formControls[field.field] = control;\n    });\n    \n    this.form = this.fb.group(formControls);\n    this.applyInitialDisabledState();\n  }\n\n  private getDefaultValue(field: DynamicFormFieldConfig): any {\n    if (field.defaultValue !== undefined) {\n      return field.defaultValue;\n    }\n\n    switch (field.type) {\n      case 'number':\n      case 'date':\n        return null;\n      case 'dropdown':\n      case 'enum':\n        return this.mode === 'filter' ? null : '';\n      default:\n        return '';\n    }\n  }\n\n  private applyInitialDisabledState(): void {\n    this.allFields.forEach(field => {\n      if (field.disabledWhen) {\n        const control = this.form.get(field.field);\n        if (control && this.isFieldDisabled(field)) {\n          control.disable();\n        }\n      }\n    });\n  }\n\n  loadEntityData(): void {\n    if (this.entityData && this.form) {\n      const processedData = this.processEntityData(this.entityData);\n      this.form.patchValue(processedData);\n    }\n  }\n\n  private processEntityData(entity: any): any {\n    const processedData = { ...entity };\n    \n    this.allFields.forEach(field => {\n      if (field.type === 'date' && processedData[field.field]) {\n        const dateValue = processedData[field.field];\n        if (typeof dateValue === 'string') {\n          // Convert date string (yyyy-MM-dd or ISO) to Date object for p-calendar\n          // Use date-only constructor to avoid timezone/hour issues\n          const parts = dateValue.substring(0, 10).split('-');\n          if (parts.length === 3) {\n            const date = new Date(+parts[0], +parts[1] - 1, +parts[2]);\n            if (!isNaN(date.getTime())) {\n              processedData[field.field] = date;\n            }\n          }\n        }\n      }\n\n      if (field.type === 'lookup' && processedData[field.field]) {\n        const lookupValue = processedData[field.field];\n        // Keep the full object if it has display data, otherwise extract ID\n        if (typeof lookupValue === 'object' && lookupValue.id) {\n          const hasDisplayData = field.lookupDisplayFields \n            ? field.lookupDisplayFields.some(f => this.getNestedValue(lookupValue, f))\n            : lookupValue[field.lookupDisplayField || 'name'];\n          \n          if (hasDisplayData) {\n            // Keep the full object to avoid unnecessary API calls\n            processedData[field.field] = lookupValue;\n          } else {\n            // Only has ID, extract it\n            processedData[field.field] = lookupValue.id;\n          }\n        }\n      }\n    });\n    \n    return processedData;\n  }\n\n  private getNestedValue(obj: any, path: string): any {\n    return path.split('.').reduce((current, key) => current?.[key], obj);\n  }\n\n  resetForm(): void {\n    if (this.form) {\n      const resetValues: any = {};\n      this.allFields.forEach(field => {\n        resetValues[field.field] = this.getDefaultValue(field);\n      });\n      this.form.reset(resetValues);\n    }\n  }\n\n  private processFilterValue(formValue: any): any {\n    const processedValue = { ...formValue };\n    \n    this.allFields.forEach(field => {\n      const fieldValue = processedValue[field.field];\n      \n      if (field.type === 'lookup') {\n        if (fieldValue && typeof fieldValue === 'object' && fieldValue.id) {\n          processedValue[field.field] = fieldValue;\n        } else if (fieldValue && typeof fieldValue === 'string') {\n          processedValue[field.field] = { id: fieldValue };\n        } else {\n          processedValue[field.field] = null;\n        }\n      }\n    });\n    \n    return processedValue;\n  }\n\n  private processFormValue(formValue: any): any {\n    const processedValue = { ...formValue };\n    \n    if (this.entityData?.id) {\n      processedValue.id = this.entityData.id;\n    }\n    \n    this.allFields.forEach(field => {\n      const fieldValue = processedValue[field.field];\n      \n      if (field.type === 'lookup') {\n        // Keep the full object for lookup fields\n        if (fieldValue && typeof fieldValue === 'object') {\n          // Object is already complete, keep it as is\n          processedValue[field.field] = fieldValue;\n        } else if (fieldValue && fieldValue !== '') {\n          // If it's just an ID, wrap it in an object\n          processedValue[field.field] = { id: fieldValue };\n        } else {\n          processedValue[field.field] = null;\n        }\n      } else if (field.type === 'date') {\n        if (fieldValue instanceof Date) {\n          // Serialize as yyyy-MM-dd using local date components (no UTC shift)\n          const y = fieldValue.getFullYear();\n          const m = String(fieldValue.getMonth() + 1).padStart(2, '0');\n          const d = String(fieldValue.getDate()).padStart(2, '0');\n          processedValue[field.field] = `${y}-${m}-${d}`;\n        } else if (!fieldValue) {\n          processedValue[field.field] = null;\n        }\n      } else if (['text', 'textarea', 'number', 'enum', 'dropdown'].includes(field.type)) {\n        if (fieldValue === '' || fieldValue === undefined) {\n          processedValue[field.field] = null;\n        }\n      }\n    });\n    \n    return processedValue;\n  }\n\n  getFieldGridClass(field: DynamicFormFieldConfig): string {\n    const classes: string[] = [];\n    \n    // Colspan base (padrão: 6)\n    let baseColspan = field.colspan || 6;\n    \n    // Verifica condições de colspan dinâmico\n    if (field.colspanWhen && field.colspanWhen.length > 0) {\n      for (const condition of field.colspanWhen) {\n        const dependentFieldValue = this.form.get(condition.field)?.value;\n        if (dependentFieldValue === condition.value) {\n          baseColspan = condition.colspan;\n          break;\n        }\n      }\n    }\n    \n    // Adiciona classe base\n    classes.push(`col-${baseColspan}`);\n    \n    // Suporta tanto o objeto size quanto as propriedades antigas (para compatibilidade)\n    const sizeXs = field.size?.xs ?? field.colspanXs;\n    const sizeSm = field.size?.sm ?? field.colspanSm;\n    const sizeMd = field.size?.md ?? field.colspanMd;\n    const sizeLg = field.size?.lg ?? field.colspanLg;\n    const sizeXl = field.size?.xl ?? field.colspanXl;\n    \n    // Adiciona classes responsivas se definidas\n    if (sizeXs !== undefined) {\n      classes.push(`col-xs-${sizeXs}`);\n    }\n    if (sizeSm !== undefined) {\n      classes.push(`col-sm-${sizeSm}`);\n    }\n    if (sizeMd !== undefined) {\n      classes.push(`col-md-${sizeMd}`);\n    }\n    if (sizeLg !== undefined) {\n      classes.push(`col-lg-${sizeLg}`);\n    }\n    if (sizeXl !== undefined) {\n      classes.push(`col-xl-${sizeXl}`);\n    }\n    \n    return classes.join(' ');\n  }\n\n  isFieldVisible(field: DynamicFormFieldConfig): boolean {\n    if (!field.visibleWhen) {\n      return true;\n    }\n\n    const dependentFieldValue = this.form.get(field.visibleWhen.field)?.value;\n    return dependentFieldValue === field.visibleWhen.value;\n  }\n\n  isFieldDisabled(field: DynamicFormFieldConfig): boolean {\n    if (field.disabled) {\n      return true;\n    }\n    \n    if (!('disabledWhen' in field) || !field.disabledWhen) {\n      return false;\n    }\n\n    const dependentFieldValue = this.form.get(field.disabledWhen!.field)?.value;\n    \n    if (field.disabledWhen!.value === null) {\n      return !dependentFieldValue;\n    }\n    \n    return dependentFieldValue === field.disabledWhen!.value;\n  }\n\n  setupConditionalFieldsWatcher(): void {\n    const visibleDependentFields = this.allFields.filter(field => field.visibleWhen);\n    const visibleWatchedFields = [...new Set(visibleDependentFields.map(field => field.visibleWhen!.field))];\n\n    const disabledDependentFields = this.allFields.filter(field => field.disabledWhen);\n    const disabledWatchedFields = [...new Set(disabledDependentFields.map(field => field.disabledWhen!.field))];\n\n    const allWatchedFields = [...new Set([...visibleWatchedFields, ...disabledWatchedFields])];\n\n    allWatchedFields.forEach(fieldName => {\n      const control = this.form.get(fieldName);\n      if (control) {\n        control.valueChanges.subscribe(() => {\n          this.clearHiddenFields();\n          this.updateDisabledFields();\n        });\n      }\n    });\n  }\n\n  updateDisabledFields(): void {\n    this.allFields.forEach(field => {\n      if (field.disabledWhen) {\n        const control = this.form.get(field.field);\n        if (control) {\n          const shouldBeDisabled = this.isFieldDisabled(field);\n          \n          if (shouldBeDisabled && control.enabled) {\n            control.setValue(null);\n            control.disable();\n          } else if (!shouldBeDisabled && control.disabled && !field.disabled) {\n            control.enable();\n          }\n        }\n      }\n    });\n  }\n\n  clearHiddenFields(): void {\n    this.allFields.forEach(field => {\n      if (field.visibleWhen && !this.isFieldVisible(field)) {\n        const control = this.form.get(field.field);\n        if (control) {\n          const resetValue = this.getDefaultValue(field);\n          control.setValue(resetValue);\n          control.markAsUntouched();\n          control.markAsPristine();\n        }\n      }\n    });\n  }\n\n  getForm(): FormGroup {\n    return this.form;\n  }\n\n  clearFilters(): void {\n    if (this.mode === 'filter') {\n      this.resetForm();\n    }\n  }\n\n  getTypePersonValue(): 'NATURAL_PERSON' | 'JURIDICAL_PERSON' {\n    const typePersonValue = this.form?.get('typePerson')?.value;\n    return typePersonValue || 'JURIDICAL_PERSON';\n  }\n\n  // Display Mode Control Methods\n  open(entity?: any): void {\n    if (entity) {\n      this.entityData = entity;\n    } else {\n      this.entityData = null;\n      this.resetForm(); // Reset form when opening for new entity\n    }\n    this.loading = false; // Reset loading state\n    this.visible = true;\n    this.visibleChange.emit(true);\n  }\n\n  close(): void {\n    this.loading = false; // Reset loading state\n    this.visible = false;\n    this.visibleChange.emit(false);\n    this.resetForm(); // Reset form when closing\n    this.onCancel.emit();\n  }\n\n  handleCancel(): void {\n    this.close();\n  }\n\n  handleSubmit(): void {\n    if (this.mode === 'form' && this.form.invalid) {\n      this.form.markAllAsTouched();\n      return;\n    }\n    \n    if (this.mode !== 'filter') {\n      this.loading = true;\n    }\n    \n    const formValue = this.mode === 'filter' \n      ? this.processFilterValue(this.form.value)\n      : this.processFormValue(this.form.value);\n    \n    this.formSubmit.emit(formValue);\n  }\n\n  // Inline Edit Mode Methods\n  startEditField(fieldName: string): void {\n    if (this.isInlineEditMode) {\n      this.editingField = fieldName;\n      \n      // Ensure the field has the current value from entityData\n      if (this.entityData) {\n        const control = this.form.get(fieldName);\n        if (control) {\n          const field = this.allFields.find(f => f.field === fieldName);\n          const value = this.entityData[fieldName];\n          \n          // For lookup fields in inline-edit mode, keep the full object\n          // This prevents unnecessary API calls since we already have the data\n          if (field?.type === 'lookup' && value && typeof value === 'object') {\n            // Keep the full object - the lookup component will use it\n            control.setValue(value);\n          } else if (field?.type === 'date' && value && typeof value === 'string') {\n            // Convert date string to Date object for p-calendar (date-only, no time component)\n            const parts = value.substring(0, 10).split('-');\n            if (parts.length === 3) {\n              const date = new Date(+parts[0], +parts[1] - 1, +parts[2]);\n              control.setValue(!isNaN(date.getTime()) ? date : value);\n            } else {\n              control.setValue(value);\n            }\n          } else {\n            control.setValue(value);\n          }\n        }\n      }\n    }\n  }\n\n  isFieldEditing(fieldName: string): boolean {\n    return this.editingField === fieldName;\n  }\n\n  saveInlineField(fieldName: string): void {\n    if (!this.isInlineEditMode) return;\n\n    const control = this.form.get(fieldName);\n    if (!control || control.invalid) {\n      control?.markAsTouched();\n      return;\n    }\n\n    this.savingField = true;\n    \n    let fieldValue = control.value;\n    \n    // For lookup fields, keep the full object (don't extract ID)\n    const field = this.allFields.find(f => f.field === fieldName);\n    if (field?.type === 'lookup' && fieldValue && typeof fieldValue !== 'object') {\n      // If it's just an ID, wrap it in an object\n      fieldValue = { id: fieldValue };\n    }\n\n    // For date fields, serialize as yyyy-MM-dd (no time component)\n    if (field?.type === 'date' && fieldValue instanceof Date) {\n      const y = fieldValue.getFullYear();\n      const m = String(fieldValue.getMonth() + 1).padStart(2, '0');\n      const d = String(fieldValue.getDate()).padStart(2, '0');\n      fieldValue = `${y}-${m}-${d}`;\n    }\n    \n    this.fieldSave.emit({ field: fieldName, value: fieldValue });\n  }\n\n  cancelInlineEdit(): void {\n    if (this.isInlineEditMode && this.editingField) {\n      const control = this.form.get(this.editingField);\n      if (control && this.entityData) {\n        // Restore original value\n        const originalValue = this.entityData[this.editingField];\n        control.setValue(originalValue);\n        control.markAsPristine();\n        control.markAsUntouched();\n      }\n      this.editingField = null;\n      this.savingField = false;\n    }\n  }\n\n  // Method to be called by parent after save completes\n  completeInlineEdit(): void {\n    this.editingField = null;\n    this.savingField = false;\n  }\n\n  getFieldDisplayValue(fieldName: string): string {\n    if (!this.entityData) return '';\n\n    const field = this.allFields.find(f => f.field === fieldName);\n    const value = this.entityData[fieldName];\n\n    if (!value) return '';\n\n    // For lookup fields, return the display name\n    if (field?.type === 'lookup' && typeof value === 'object' && value.name) {\n      return value.name;\n    }\n\n    // For lookup fields with multiple display fields\n    if (field?.type === 'lookup' && typeof value === 'object' && field.lookupDisplayFields) {\n      return field.lookupDisplayFields\n        .map(f => this.getNestedValue(value, f))\n        .filter(v => v)\n        .join(' - ');\n    }\n\n    // For dropdown/enum fields, find the matching option label\n    if ((field?.type === 'dropdown' || field?.type === 'enum') && field) {\n      const options = field.options || field.enumOptions || [];\n      const optionValue = field.optionValue || 'value';\n      const optionLabel = field.optionLabel || 'label';\n      const matchingOption = options.find((opt: any) => {\n        const optVal = typeof opt === 'object' ? opt[optionValue] : opt;\n        return optVal === value;\n      });\n      if (matchingOption) {\n        return typeof matchingOption === 'object' ? matchingOption[optionLabel] : matchingOption;\n      }\n    }\n\n    // For number fields, format appropriately\n    if (field?.type === 'number' && typeof value === 'number') {\n      if (field.numberMode === 'currency') {\n        return new Intl.NumberFormat(field.locale || 'pt-BR', {\n          style: 'currency',\n          currency: field.currency || 'BRL'\n        }).format(value);\n      }\n      return new Intl.NumberFormat(field.locale || 'pt-BR', {\n        minimumFractionDigits: field.minFractionDigits || 0,\n        maximumFractionDigits: field.maxFractionDigits || 2\n      }).format(value);\n    }\n\n    // For date fields, format as date\n    if (field?.type === 'date' && value) {\n      return this.localeService.formatDate(value);\n    }\n\n    // For text fields with document mask, format the value\n    if (field?.type === 'text' && field.mask === 'document' && value) {\n      const dependsOn = field.maskDependsOn || 'typePerson';\n      const typePerson = this.entityData[dependsOn] || 'JURIDICAL_PERSON';\n      return this.maskService.applyDocumentMask(String(value), typePerson);\n    }\n    if (field?.type === 'text' && field.mask === 'cpf' && value) {\n      return this.maskService.applyCpfMask(String(value));\n    }\n    if (field?.type === 'text' && field.mask === 'cnpj' && value) {\n      return this.maskService.applyCnpjMask(String(value));\n    }\n\n    return String(value);\n  }\n}\n","<!-- Modo Inline (padrão) -->\n<ng-container *ngIf=\"isInlineMode\">\n  <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n</ng-container>\n\n<!-- Modo Dialog -->\n<p-dialog\n  *ngIf=\"isDialogMode\"\n  [(visible)]=\"visible\"\n  [header]=\"dialogHeader | translate\"\n  [modal]=\"true\"\n  [style]=\"{ width: dialogWidth }\"\n  [draggable]=\"dialogDraggable\"\n  [resizable]=\"dialogResizable\"\n  [maximizable]=\"dialogMaximizable\"\n  [closeOnEscape]=\"dialogCloseOnEscape\"\n  [dismissableMask]=\"dialogDismissableMask\"\n  (onHide)=\"close()\">\n  \n  <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n  \n  <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n    <div class=\"dialog-footer\">\n      <p-button\n        *ngIf=\"showCancelButton\"\n        [label]=\"cancelLabel | translate\"\n        [icon]=\"cancelButtonIcon\"\n        severity=\"secondary\"\n        (onClick)=\"handleCancel()\"\n        [disabled]=\"loading\">\n      </p-button>\n      <p-button\n        *ngIf=\"showSubmitButton\"\n        [label]=\"submitLabel | translate\"\n        [icon]=\"submitButtonIcon\"\n        (onClick)=\"handleSubmit()\"\n        [loading]=\"loading\"\n        [disabled]=\"form.invalid\">\n      </p-button>\n    </div>\n  </ng-template>\n</p-dialog>\n\n<!-- Modo Drawer -->\n<p-drawer\n  *ngIf=\"isDrawerMode\"\n  [(visible)]=\"visible\"\n  [header]=\"drawerHeader | translate\"\n  [position]=\"drawerPosition\"\n  [style]=\"drawerStyle\"\n  [showCloseIcon]=\"drawerShowCloseIcon\"\n  [closeOnEscape]=\"drawerCloseOnEscape\"\n  [modal]=\"drawerDismissable\"\n  (onHide)=\"close()\">\n  \n  <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n  \n  <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n    <div class=\"drawer-footer\">\n      <p-button\n        *ngIf=\"showCancelButton\"\n        [label]=\"cancelLabel | translate\"\n        [icon]=\"cancelButtonIcon\"\n        severity=\"secondary\"\n        (onClick)=\"handleCancel()\"\n        [disabled]=\"loading\">\n      </p-button>\n      <p-button\n        *ngIf=\"showSubmitButton\"\n        [label]=\"submitLabel | translate\"\n        [icon]=\"submitButtonIcon\"\n        (onClick)=\"handleSubmit()\"\n        [loading]=\"loading\"\n        [disabled]=\"form.invalid\">\n      </p-button>\n    </div>\n  </ng-template>\n</p-drawer>\n\n<!-- Template do Formulário (reutilizável) -->\n<ng-template #formContent>\n  <form [formGroup]=\"form\" class=\"dynamic-form\">\n    \n    <!-- Filtros Fixos (apenas no modo filter) -->\n    <div *ngIf=\"mode === 'filter' && hasFixedFilters\" class=\"fixed-filters-section\">\n      <div class=\"grid\">\n        <ng-container *ngFor=\"let field of fixedFilters\">\n          <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n            <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n          </div>\n        </ng-container>\n      </div>\n    </div>\n\n    <!-- Campos Diretos (sem seção) -->\n    <div *ngIf=\"hasFields\">\n      <!-- Modo Inline Edit -->\n      <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n        <ng-container *ngFor=\"let field of formFields\">\n          <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n            <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n          </div>\n        </ng-container>\n      </div>\n\n      <!-- Modo Form Normal -->\n      <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n        <ng-container *ngFor=\"let field of formFields\">\n          <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n            <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n          </div>\n        </ng-container>\n      </div>\n    </div>\n\n    <!-- Seções de Campos (modo form) -->\n    <div *ngIf=\"hasSections\" class=\"sections-container\">\n      <p-panel \n        *ngFor=\"let section of formSections\"\n        [toggleable]=\"section.toggleable !== false\"\n        [collapsed]=\"section.collapsed || false\"\n        [styleClass]=\"'section-panel'\">\n        \n        <ng-template pTemplate=\"header\">\n          <div class=\"section-header\">\n            <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n            <span class=\"section-title\">{{ section.title }}</span>\n          </div>\n        </ng-template>\n\n        <!-- Modo Inline Edit -->\n        <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n              <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n\n        <!-- Modo Form Normal -->\n        <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n              <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n      </p-panel>\n    </div>\n\n    <!-- Seções de Filtros (apenas no modo filter) -->\n    <div *ngIf=\"mode === 'filter' && hasFilterSections\" class=\"filter-sections-container\">\n      <p-panel \n        *ngFor=\"let section of filterSections\"\n        [header]=\"section.title\"\n        [toggleable]=\"true\"\n        [collapsed]=\"true\">\n\n        <div class=\"grid\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n              <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n      </p-panel>\n    </div>\n\n    <!-- Botões inline (apenas para modo inline) -->\n    <div *ngIf=\"isInlineMode && (showSubmitButton || showCancelButton)\" class=\"form-actions\">\n      <p-button\n        *ngIf=\"showCancelButton\"\n        [label]=\"cancelLabel | translate\"\n        [icon]=\"cancelButtonIcon\"\n        severity=\"secondary\"\n        (onClick)=\"handleCancel()\"\n        [disabled]=\"loading\">\n      </p-button>\n      <p-button\n        *ngIf=\"showSubmitButton\"\n        [label]=\"submitLabel | translate\"\n        [icon]=\"submitButtonIcon\"\n        (onClick)=\"handleSubmit()\"\n        [loading]=\"loading\"\n        [disabled]=\"form.invalid\">\n      </p-button>\n    </div>\n\n  </form>\n</ng-template>\n\n<!-- Template de Campo (reutilizável) -->\n<ng-template #fieldTemplate let-field=\"field\">\n  <!-- Text Field -->\n  <sia-dynamic-field-text\n    *ngIf=\"field.type === 'text'\"\n    [field]=\"field\"\n    [form]=\"form\"\n    [mode]=\"fieldMode\">\n  </sia-dynamic-field-text>\n\n  <!-- Textarea Field -->\n  <sia-dynamic-field-textarea\n    *ngIf=\"field.type === 'textarea'\"\n    [field]=\"field\"\n    [form]=\"form\"\n    [mode]=\"fieldMode\">\n  </sia-dynamic-field-textarea>\n\n  <!-- Number Field -->\n  <sia-dynamic-field-number\n    *ngIf=\"field.type === 'number'\"\n    [field]=\"field\"\n    [form]=\"form\"\n    [mode]=\"fieldMode\">\n  </sia-dynamic-field-number>\n\n  <!-- Date Field -->\n  <sia-dynamic-field-date\n    *ngIf=\"field.type === 'date'\"\n    [field]=\"field\"\n    [form]=\"form\"\n    [mode]=\"fieldMode\">\n  </sia-dynamic-field-date>\n\n  <!-- Datetime Field -->\n  <sia-dynamic-field-datetime\n    *ngIf=\"field.type === 'datetime'\"\n    [field]=\"field\"\n    [form]=\"form\"\n    [mode]=\"fieldMode\">\n  </sia-dynamic-field-datetime>\n\n  <!-- Dropdown/Enum Field -->\n  <sia-dynamic-field-dropdown\n    *ngIf=\"field.type === 'dropdown' || field.type === 'enum'\"\n    [field]=\"field\"\n    [form]=\"form\"\n    [mode]=\"fieldMode\">\n  </sia-dynamic-field-dropdown>\n\n  <!-- Lookup Field -->\n  <sia-dynamic-field-lookup\n    *ngIf=\"field.type === 'lookup'\"\n    [field]=\"field\"\n    [form]=\"form\"\n    [formGroup]=\"form\"\n    [mode]=\"fieldMode\">\n  </sia-dynamic-field-lookup>\n</ng-template>\n\n\n<!-- Template de Campo Inline Edit -->\n<ng-template #inlineEditFieldTemplate let-field=\"field\">\n  <div class=\"edit-inline-field\">\n    <label class=\"field-label\">{{ field.label | translate }}</label>\n    \n    <!-- Display Mode -->\n    <div class=\"field-display\" \n         *ngIf=\"!isFieldEditing(field.field)\" \n         (click)=\"startEditField(field.field)\"\n         [class.disabled]=\"field.disabled\">\n      <span class=\"display-value\" \n            [attr.data-placeholder]=\"field.placeholder || ('crmx.business.not_informed' | translate)\">\n        {{ getFieldDisplayValue(field.field) }}\n      </span>\n      <i class=\"pi pi-pencil edit-icon\" *ngIf=\"!field.disabled\"></i>\n    </div>\n    \n    <!-- Edit Mode -->\n    <div class=\"field-edit\" *ngIf=\"isFieldEditing(field.field)\">\n      <div class=\"input-container\">\n        <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n      </div>\n      \n      <!-- Action Buttons -->\n      <div class=\"edit-actions\">\n        <p-button \n          type=\"button\" \n          icon=\"pi pi-check\" \n          [rounded]=\"true\"\n          severity=\"primary\"\n          (onClick)=\"saveInlineField(field.field)\" \n          [loading]=\"savingField\"\n          [disabled]=\"form.get(field.field)?.invalid\">\n        </p-button>\n        <p-button \n          type=\"button\" \n          icon=\"pi pi-times\" \n          [rounded]=\"true\"\n          severity=\"secondary\"\n          (onClick)=\"cancelInlineEdit()\"\n          [disabled]=\"savingField\">\n        </p-button>\n      </div>\n      \n      <!-- Error Message -->\n      <div class=\"field-error\" *ngIf=\"form.get(field.field)?.invalid && form.get(field.field)?.touched\">\n        <small class=\"p-error\">\n          {{ form.get(field.field)?.errors?.['required'] ? ('crmx.business.required_field' | translate) : '' }}\n        </small>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
604
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"","sources":["../../../../../projects/components-ai/src/lib/components/dynamic-form/dynamic-form.component.ts","../../../../../projects/components-ai/src/lib/components/dynamic-form/dynamic-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, OnChanges, SimpleChanges } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormBuilder, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { PanelModule } from 'primeng/panel';\nimport { DialogModule } from 'primeng/dialog';\nimport { DrawerModule } from 'primeng/drawer';\nimport { ButtonModule } from 'primeng/button';\nimport {\n  DynamicFormFieldConfig,\n  DynamicFormFieldSize,\n  DynamicFormSection,\n  DynamicFormDialogConfig,\n  DynamicFormDrawerConfig\n} from './models/dynamic-form.models';\nimport { TranslationService } from '../../services/translation.service';\nimport { MaskService } from '../../services/mask.service';\nimport { LocaleService } from '../../services/locale.service';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { DynamicFieldTextComponent } from './fields/dynamic-field-text.component';\nimport { DynamicFieldNumberComponent } from './fields/dynamic-field-number.component';\nimport { DynamicFieldDateComponent } from './fields/dynamic-field-date.component';\nimport { DynamicFieldDatetimeComponent } from './fields/dynamic-field-datetime.component';\nimport { DynamicFieldDropdownComponent } from './fields/dynamic-field-dropdown.component';\nimport { DynamicFieldLookupComponent } from './fields/dynamic-field-lookup.component';\nimport { DynamicFieldTextareaComponent } from './fields/dynamic-field-textarea.component';\nimport { DynamicFieldTimeComponent } from './fields/dynamic-field-time.component';\nimport { DynamicFieldCheckboxComponent } from './fields/dynamic-field-checkbox.component';\nimport { DynamicFieldMultiselectComponent } from './fields/dynamic-field-multiselect.component';\nimport { DynamicFieldImageComponent } from './fields/dynamic-field-image.component';\n\n@Component({\n  selector: 'sia-dynamic-form',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    PanelModule,\n    DialogModule,\n    DrawerModule,\n    ButtonModule,\n    TranslatePipe,\n    DynamicFieldTextComponent,\n    DynamicFieldNumberComponent,\n    DynamicFieldDateComponent,\n    DynamicFieldDatetimeComponent,\n    DynamicFieldDropdownComponent,\n    DynamicFieldLookupComponent,\n    DynamicFieldTextareaComponent,\n    DynamicFieldTimeComponent,\n    DynamicFieldCheckboxComponent,\n    DynamicFieldMultiselectComponent,\n    DynamicFieldImageComponent\n  ],\n  templateUrl: './dynamic-form.component.html',\n  styleUrl: './dynamic-form.component.scss'\n})\nexport class DynamicFormComponent implements OnInit, OnChanges {\n  @Input() sections: DynamicFormSection[] = [];\n  @Input() entityData: any = null;\n  @Input() mode: 'form' | 'inline-edit' = 'form';\n\n  // Display Mode — optional. If not set, renders inline without buttons.\n  @Input() displayMode?: 'dialog' | 'drawer';\n  @Input() visible: boolean = false;\n  @Input() dialogConfig: DynamicFormDialogConfig = {};\n  @Input() drawerConfig: DynamicFormDrawerConfig = {};\n\n  // Button Configuration\n  @Input() showSubmitButton: boolean = false;\n  @Input() showCancelButton: boolean = false;\n  @Input() submitButtonLabel?: string;\n  @Input() cancelButtonLabel?: string;\n  @Input() submitButtonIcon: string = 'pi pi-check';\n  @Input() cancelButtonIcon: string = 'pi pi-times';\n\n  @Output() formReady = new EventEmitter<FormGroup>();\n  @Output() formSubmit = new EventEmitter<any>();\n  @Output() visibleChange = new EventEmitter<boolean>();\n  @Output() onCancel = new EventEmitter<void>();\n  @Output() fieldSave = new EventEmitter<{ field: string, value: any }>();\n\n  form!: FormGroup;\n  loading: boolean = false;\n\n  // Inline edit state\n  editingField: string | null = null;\n  savingField: boolean = false;\n\n  // --- Computed properties ---\n\n  get allFields(): DynamicFormFieldConfig[] {\n    return this.sections.flatMap(section => section.fields);\n  }\n\n  get isInlineEditMode(): boolean {\n    return this.mode === 'inline-edit';\n  }\n\n  get isDialogMode(): boolean {\n    return this.displayMode === 'dialog';\n  }\n\n  get isDrawerMode(): boolean {\n    return this.displayMode === 'drawer';\n  }\n\n  get isInlineMode(): boolean {\n    return !this.displayMode;\n  }\n\n  // Dialog config with defaults\n  get dialogHeader(): string {\n    return this.dialogConfig.header || this.translationService.translate('design.components_ai.form');\n  }\n  get dialogWidth(): string { return this.dialogConfig.width || '600px'; }\n  get dialogDraggable(): boolean { return this.dialogConfig.draggable ?? false; }\n  get dialogResizable(): boolean { return this.dialogConfig.resizable ?? false; }\n  get dialogMaximizable(): boolean { return this.dialogConfig.maximizable ?? false; }\n  get dialogCloseOnEscape(): boolean { return this.dialogConfig.closeOnEscape ?? true; }\n  get dialogDismissableMask(): boolean { return this.dialogConfig.dismissableMask ?? false; }\n\n  // Drawer config with defaults\n  get drawerHeader(): string {\n    return this.drawerConfig.header || this.translationService.translate('design.components_ai.form');\n  }\n  get drawerPosition(): 'left' | 'right' | 'top' | 'bottom' { return this.drawerConfig.position || 'right'; }\n  get drawerShowCloseIcon(): boolean { return this.drawerConfig.showCloseIcon ?? true; }\n  get drawerCloseOnEscape(): boolean { return this.drawerConfig.closeOnEscape ?? true; }\n  get drawerDismissable(): boolean { return this.drawerConfig.dismissable ?? true; }\n\n  get drawerStyle(): { [key: string]: string } {\n    const position = this.drawerPosition;\n    const isHorizontal = position === 'left' || position === 'right';\n    if (this.drawerConfig.customWidth) {\n      return isHorizontal ? { width: this.drawerConfig.customWidth } : { height: this.drawerConfig.customWidth };\n    }\n    const size = this.drawerConfig.size || 'medium';\n    const sizeMap: Record<string, string> = {\n      small: isHorizontal ? '25%' : '25vh',\n      medium: isHorizontal ? '40%' : '40vh',\n      large: isHorizontal ? '60%' : '60vh',\n      xlarge: isHorizontal ? '80%' : '80vh',\n      full: isHorizontal ? '100%' : '100vh'\n    };\n    return isHorizontal ? { width: sizeMap[size] } : { height: sizeMap[size] };\n  }\n\n  get submitLabel(): string {\n    return this.submitButtonLabel || this.translationService.translate('design.components_ai.save');\n  }\n  get cancelLabel(): string {\n    return this.cancelButtonLabel || this.translationService.translate('design.components_ai.cancel');\n  }\n\n  constructor(\n    private fb: FormBuilder,\n    private translationService: TranslationService,\n    private maskService: MaskService,\n    private localeService: LocaleService\n  ) {}\n\n  // --- Lifecycle ---\n\n  ngOnInit(): void {\n    this.initForm();\n    if (this.entityData) {\n      this.loadEntityData();\n    }\n    this.setupConditionalFieldsWatcher();\n    this.formReady.emit(this.form);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['entityData'] && this.form) {\n      this.entityData ? this.loadEntityData() : this.resetForm();\n    }\n    if (changes['visible'] && changes['visible'].currentValue === true) {\n      this.loading = false;\n      if (this.entityData && this.form) {\n        this.loadEntityData();\n      } else if (!this.entityData && this.form) {\n        this.resetForm();\n      }\n    }\n  }\n\n  // --- Form init ---\n\n  initForm(): void {\n    const formControls: any = {};\n    this.allFields.forEach(field => {\n      const defaultValue = this.getDefaultValue(field);\n      const validators = field.validators || [];\n      formControls[field.field] = this.fb.control(\n        { value: defaultValue, disabled: field.disabled || false },\n        validators\n      );\n    });\n    this.form = this.fb.group(formControls);\n    this.applyInitialDisabledState();\n  }\n\n  private getDefaultValue(field: DynamicFormFieldConfig): any {\n    if (field.defaultValue !== undefined) return field.defaultValue;\n    switch (field.type) {\n      case 'number': case 'currency': case 'date': case 'time': return null;\n      case 'checkbox': return false;\n      case 'multiselect': return [];\n      case 'dropdown': case 'enum': return '';\n      default: return '';\n    }\n  }\n\n  private applyInitialDisabledState(): void {\n    this.allFields.forEach(field => {\n      if (field.disabledWhen) {\n        const control = this.form.get(field.field);\n        if (control && this.isFieldDisabled(field)) {\n          control.disable();\n        }\n      }\n    });\n  }\n\n  // --- Data loading ---\n\n  loadEntityData(): void {\n    if (this.entityData && this.form) {\n      this.form.patchValue(this.processEntityData(this.entityData));\n    }\n  }\n\n  private processEntityData(entity: any): any {\n    const data = { ...entity };\n    this.allFields.forEach(field => {\n      if (field.type === 'date' && data[field.field]) {\n        const v = data[field.field];\n        if (typeof v === 'string') {\n          const parts = v.substring(0, 10).split('-');\n          if (parts.length === 3) {\n            const d = new Date(+parts[0], +parts[1] - 1, +parts[2]);\n            if (!isNaN(d.getTime())) data[field.field] = d;\n          }\n        }\n      }\n      if (field.type === 'time' && data[field.field]) {\n        const v = data[field.field];\n        if (typeof v === 'string') {\n          const parts = v.split(':');\n          if (parts.length >= 2) {\n            const d = new Date();\n            d.setHours(parseInt(parts[0], 10), parseInt(parts[1], 10), 0, 0);\n            data[field.field] = d;\n          }\n        }\n      }\n      if (field.type === 'lookup' && data[field.field]) {\n        const v = data[field.field];\n        if (typeof v === 'object' && v.id) {\n          const hasDisplay = field.lookupDisplayFields\n            ? field.lookupDisplayFields.some(f => this.getNestedValue(v, f))\n            : v[field.lookupDisplayField || 'name'];\n          if (!hasDisplay) data[field.field] = v.id;\n        }\n      }\n    });\n    return data;\n  }\n\n  private getNestedValue(obj: any, path: string): any {\n    return path.split('.').reduce((cur, key) => cur?.[key], obj);\n  }\n\n  resetForm(): void {\n    if (this.form) {\n      const values: any = {};\n      this.allFields.forEach(f => values[f.field] = this.getDefaultValue(f));\n      this.form.reset(values);\n    }\n  }\n\n  // --- Value processing on submit ---\n\n  private processFormValue(formValue: any): any {\n    const out = { ...formValue };\n    if (this.entityData?.id) out.id = this.entityData.id;\n\n    this.allFields.forEach(field => {\n      const v = out[field.field];\n      if (field.type === 'lookup') {\n        if (v && typeof v === 'object') { /* keep */ }\n        else if (v && v !== '') out[field.field] = { id: v };\n        else out[field.field] = null;\n      } else if (field.type === 'date') {\n        if (v instanceof Date) {\n          out[field.field] = `${v.getFullYear()}-${String(v.getMonth() + 1).padStart(2, '0')}-${String(v.getDate()).padStart(2, '0')}`;\n        } else if (!v) out[field.field] = null;\n      } else if (field.type === 'time') {\n        if (v instanceof Date) {\n          out[field.field] = `${String(v.getHours()).padStart(2, '0')}:${String(v.getMinutes()).padStart(2, '0')}:00`;\n        } else if (!v) out[field.field] = null;\n      } else if (['text', 'textarea', 'number', 'currency', 'enum', 'dropdown'].includes(field.type)) {\n        if (v === '' || v === undefined) out[field.field] = null;\n      }\n    });\n    return out;\n  }\n\n  // --- Layout ---\n\n  getFieldGridClass(field: DynamicFormFieldConfig): string {\n    const defaultSize: DynamicFormFieldSize = { xl: 6, lg: 6, md: 6, sm: 12 };\n    const size: DynamicFormFieldSize = typeof field.size === 'function'\n      ? field.size(this.form?.value || {})\n      : (field.size || defaultSize);\n\n    const classes: string[] = [];\n    // Base class from xl or fallback 6\n    classes.push(`col-${size.xl ?? size.lg ?? size.md ?? size.sm ?? 6}`);\n    if (size.xs !== undefined) classes.push(`col-xs-${size.xs}`);\n    if (size.sm !== undefined) classes.push(`col-sm-${size.sm}`);\n    if (size.md !== undefined) classes.push(`col-md-${size.md}`);\n    if (size.lg !== undefined) classes.push(`col-lg-${size.lg}`);\n    if (size.xl !== undefined) classes.push(`col-xl-${size.xl}`);\n    return classes.join(' ');\n  }\n\n  // --- Conditional visibility/disabled ---\n\n  isFieldVisible(field: DynamicFormFieldConfig): boolean {\n    if (!field.visibleWhen) return true;\n    return field.visibleWhen(this.form?.value || {});\n  }\n\n  isFieldDisabled(field: DynamicFormFieldConfig): boolean {\n    if (field.disabled) return true;\n    if (!field.disabledWhen) return false;\n    return field.disabledWhen(this.form?.value || {});\n  }\n\n  setupConditionalFieldsWatcher(): void {\n    // Since visibleWhen/disabledWhen are now functions that can depend on any field,\n    // we watch all fields for changes and re-evaluate\n    const hasConditional = this.allFields.some(f => f.visibleWhen || f.disabledWhen);\n    if (!hasConditional) return;\n\n    this.form.valueChanges.subscribe(() => {\n      this.clearHiddenFields();\n      this.updateDisabledFields();\n    });\n  }\n\n  updateDisabledFields(): void {\n    this.allFields.forEach(field => {\n      if (field.disabledWhen) {\n        const control = this.form.get(field.field);\n        if (control) {\n          const shouldDisable = this.isFieldDisabled(field);\n          if (shouldDisable && control.enabled) {\n            control.setValue(null);\n            control.disable({ emitEvent: false });\n          } else if (!shouldDisable && control.disabled && !field.disabled) {\n            control.enable({ emitEvent: false });\n          }\n        }\n      }\n    });\n  }\n\n  clearHiddenFields(): void {\n    this.allFields.forEach(field => {\n      if (field.visibleWhen && !this.isFieldVisible(field)) {\n        const control = this.form.get(field.field);\n        if (control && control.value !== this.getDefaultValue(field)) {\n          control.setValue(this.getDefaultValue(field), { emitEvent: false });\n          control.markAsUntouched();\n          control.markAsPristine();\n        }\n      }\n    });\n  }\n\n  // --- Public methods ---\n\n  getForm(): FormGroup { return this.form; }\n\n  open(entity?: any): void {\n    if (entity) {\n      this.entityData = entity;\n    } else {\n      this.entityData = null;\n      this.resetForm();\n    }\n    this.loading = false;\n    this.visible = true;\n    this.visibleChange.emit(true);\n  }\n\n  close(): void {\n    this.loading = false;\n    this.visible = false;\n    this.visibleChange.emit(false);\n    this.resetForm();\n    this.onCancel.emit();\n  }\n\n  handleCancel(): void { this.close(); }\n\n  handleSubmit(): void {\n    if (this.mode === 'form' && this.form.invalid) {\n      this.form.markAllAsTouched();\n      return;\n    }\n    this.loading = true;\n    this.formSubmit.emit(this.processFormValue(this.form.value));\n  }\n\n  onFormKeydown(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      const target = event.target as HTMLElement;\n      if (target.tagName === 'TEXTAREA') return;\n      event.preventDefault();\n      // In inline-edit mode, Enter saves the current field\n      if (this.isInlineEditMode && this.editingField) {\n        this.saveInlineField(this.editingField);\n      } else {\n        this.handleSubmit();\n      }\n    }\n  }\n\n  // --- Section helpers ---\n\n  getSectionStyle(section: DynamicFormSection): string {\n    if (!section.title) return 'none';\n    return section.style || 'none';\n  }\n\n  // --- Inline Edit ---\n\n  startEditField(fieldName: string): void {\n    if (!this.isInlineEditMode) return;\n    this.editingField = fieldName;\n    if (this.entityData) {\n      const control = this.form.get(fieldName);\n      if (control) {\n        const field = this.allFields.find(f => f.field === fieldName);\n        const value = this.entityData[fieldName];\n        if (field?.type === 'lookup' && value && typeof value === 'object') {\n          control.setValue(value);\n        } else if (field?.type === 'date' && value && typeof value === 'string') {\n          const parts = value.substring(0, 10).split('-');\n          if (parts.length === 3) {\n            const d = new Date(+parts[0], +parts[1] - 1, +parts[2]);\n            control.setValue(!isNaN(d.getTime()) ? d : value);\n          } else {\n            control.setValue(value);\n          }\n        } else {\n          control.setValue(value);\n        }\n      }\n    }\n    // Auto-focus the input after Angular renders the edit field\n    setTimeout(() => {\n      const el = document.querySelector(`.inline-edit-field input[id=\"${fieldName}\"], .inline-edit-field textarea[id=\"${fieldName}\"]`) as HTMLElement;\n      el?.focus();\n    });\n\n    // For lookup fields, auto-save when value changes (user selects from dialog)\n    const field = this.allFields.find(f => f.field === fieldName);\n    if (field?.type === 'lookup') {\n      const control = this.form.get(fieldName);\n      const sub = control?.valueChanges.subscribe(val => {\n        if (val && typeof val === 'object') {\n          sub?.unsubscribe();\n          this.saveInlineField(fieldName);\n        }\n      });\n    }\n  }\n\n  isFieldEditing(fieldName: string): boolean { return this.editingField === fieldName; }\n\n  saveInlineField(fieldName: string): void {\n    if (!this.isInlineEditMode) return;\n    const control = this.form.get(fieldName);\n    if (!control || control.invalid) { control?.markAsTouched(); return; }\n\n    this.savingField = true;\n    let value = control.value;\n    const field = this.allFields.find(f => f.field === fieldName);\n\n    if (field?.type === 'lookup' && value && typeof value !== 'object') {\n      value = { id: value };\n    }\n    if (field?.type === 'date' && value instanceof Date) {\n      value = `${value.getFullYear()}-${String(value.getMonth() + 1).padStart(2, '0')}-${String(value.getDate()).padStart(2, '0')}`;\n    }\n    this.fieldSave.emit({ field: fieldName, value });\n  }\n\n  cancelInlineEdit(): void {\n    if (this.isInlineEditMode && this.editingField) {\n      const control = this.form.get(this.editingField);\n      if (control && this.entityData) {\n        control.setValue(this.entityData[this.editingField]);\n        control.markAsPristine();\n        control.markAsUntouched();\n      }\n      this.editingField = null;\n      this.savingField = false;\n    }\n  }\n\n  completeInlineEdit(): void {\n    this.editingField = null;\n    this.savingField = false;\n  }\n\n  // --- Display value for inline-edit mode ---\n\n  getFieldDisplayValue(fieldName: string): string {\n    if (!this.entityData) return '';\n    const field = this.allFields.find(f => f.field === fieldName);\n    const value = this.entityData[fieldName];\n    if (!value && value !== false && value !== 0) return '';\n\n    if (field?.type === 'lookup' && typeof value === 'object') {\n      if (field.lookupDisplayFields) {\n        return field.lookupDisplayFields.map(f => this.getNestedValue(value, f)).filter(v => v).join(' - ');\n      }\n      return value[field.lookupDisplayField || 'name'] || '';\n    }\n\n    if ((field?.type === 'dropdown' || field?.type === 'enum') && field) {\n      const opts = field.options || field.enumOptions || [];\n      const optVal = field.optionValue || 'value';\n      const optLbl = field.optionLabel || 'label';\n      const match = opts.find((o: any) => (typeof o === 'object' ? o[optVal] : o) === value);\n      if (match) return typeof match === 'object' ? match[optLbl] : match;\n    }\n\n    if (field?.type === 'currency' && typeof value === 'number') {\n      const moneyConfig = this.maskService.getMoneyConfig();\n      return new Intl.NumberFormat(field.locale || moneyConfig.locale, {\n        style: 'currency',\n        currency: field.currency || moneyConfig.currency\n      }).format(value);\n    }\n\n    if (field?.type === 'number' && typeof value === 'number') {\n      return new Intl.NumberFormat('pt-BR', {\n        minimumFractionDigits: field.minFractionDigits || 0,\n        maximumFractionDigits: field.maxFractionDigits || 2\n      }).format(value);\n    }\n\n    if (field?.type === 'date' && value) return this.localeService.formatDate(value);\n\n    if (field?.type === 'time' && value) {\n      if (value instanceof Date) return `${String(value.getHours()).padStart(2, '0')}:${String(value.getMinutes()).padStart(2, '0')}`;\n      return typeof value === 'string' ? value.substring(0, 5) : String(value);\n    }\n\n    if (field?.type === 'checkbox') {\n      return value ? this.translationService.translate('design.components_ai.boolean_true')\n                    : this.translationService.translate('design.components_ai.boolean_false');\n    }\n\n    if (field?.type === 'multiselect' && Array.isArray(value)) {\n      const opts = field.options || field.enumOptions || [];\n      const optVal = field.optionValue || 'value';\n      const optLbl = field.optionLabel || 'label';\n      return value.map(v => {\n        const o = opts.find((opt: any) => (typeof opt === 'object' ? opt[optVal] : opt) === v);\n        return o ? (typeof o === 'object' ? o[optLbl] : o) : v;\n      }).join(', ');\n    }\n\n    if (field?.type === 'text' && field.mask === 'document' && value) {\n      const typePerson = this.entityData[field.maskDependsOn || 'typePerson'] || 'JURIDICAL_PERSON';\n      return this.maskService.applyDocumentMask(String(value), typePerson);\n    }\n    if (field?.type === 'text' && field.mask === 'cpf' && value) return this.maskService.applyCpfMask(String(value));\n    if (field?.type === 'text' && field.mask === 'cnpj' && value) return this.maskService.applyCnpjMask(String(value));\n\n    return String(value);\n  }\n}\n","<!-- Inline Mode (no displayMode set) -->\n<ng-container *ngIf=\"isInlineMode\">\n  <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n</ng-container>\n\n<!-- Dialog Mode -->\n<p-dialog\n  *ngIf=\"isDialogMode\"\n  [(visible)]=\"visible\"\n  [header]=\"dialogHeader | translate\"\n  [modal]=\"true\"\n  [style]=\"{ width: dialogWidth }\"\n  [draggable]=\"dialogDraggable\"\n  [resizable]=\"dialogResizable\"\n  [maximizable]=\"dialogMaximizable\"\n  [closeOnEscape]=\"dialogCloseOnEscape\"\n  [dismissableMask]=\"dialogDismissableMask\"\n  (onHide)=\"close()\">\n\n  <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n\n  <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n    <div class=\"dialog-footer\">\n      <p-button *ngIf=\"showCancelButton\" [label]=\"cancelLabel | translate\" [icon]=\"cancelButtonIcon\" severity=\"secondary\" (onClick)=\"handleCancel()\" [disabled]=\"loading\"></p-button>\n      <p-button *ngIf=\"showSubmitButton\" [label]=\"submitLabel | translate\" [icon]=\"submitButtonIcon\" (onClick)=\"handleSubmit()\" [loading]=\"loading\" [disabled]=\"form.invalid\"></p-button>\n    </div>\n  </ng-template>\n</p-dialog>\n\n<!-- Drawer Mode -->\n<p-drawer\n  *ngIf=\"isDrawerMode\"\n  [(visible)]=\"visible\"\n  [header]=\"drawerHeader | translate\"\n  [position]=\"drawerPosition\"\n  [style]=\"drawerStyle\"\n  [showCloseIcon]=\"drawerShowCloseIcon\"\n  [closeOnEscape]=\"drawerCloseOnEscape\"\n  [modal]=\"drawerDismissable\"\n  (onHide)=\"close()\">\n\n  <ng-container *ngTemplateOutlet=\"formContent\"></ng-container>\n\n  <ng-template pTemplate=\"footer\" *ngIf=\"showSubmitButton || showCancelButton\">\n    <div class=\"drawer-footer\">\n      <p-button *ngIf=\"showCancelButton\" [label]=\"cancelLabel | translate\" [icon]=\"cancelButtonIcon\" severity=\"secondary\" (onClick)=\"handleCancel()\" [disabled]=\"loading\"></p-button>\n      <p-button *ngIf=\"showSubmitButton\" [label]=\"submitLabel | translate\" [icon]=\"submitButtonIcon\" (onClick)=\"handleSubmit()\" [loading]=\"loading\" [disabled]=\"form.invalid\"></p-button>\n    </div>\n  </ng-template>\n</p-drawer>\n\n<!-- Form Content Template -->\n<ng-template #formContent>\n  <form [formGroup]=\"form\" class=\"dynamic-form\" (keydown)=\"onFormKeydown($event)\">\n\n    <ng-container *ngFor=\"let section of sections\">\n      <!-- No title = bare fields -->\n      <ng-container *ngIf=\"!section.title\">\n        <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n              <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n        <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n              <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n      </ng-container>\n\n      <!-- Bordered section -->\n      <div *ngIf=\"section.title && getSectionStyle(section) === 'bordered'\" class=\"bordered-section\">\n        <h3 class=\"section-heading\">\n          <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n          {{ section.title }}\n        </h3>\n        <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n              <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n        <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n              <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n      </div>\n\n      <!-- Panel section -->\n      <p-panel\n        *ngIf=\"section.title && getSectionStyle(section) === 'panel'\"\n        [toggleable]=\"true\"\n        [collapsed]=\"section.collapsed || false\"\n        styleClass=\"section-panel\">\n        <ng-template pTemplate=\"header\">\n          <div class=\"section-header\">\n            <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n            <span class=\"section-title\">{{ section.title }}</span>\n          </div>\n        </ng-template>\n        <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n              <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n        <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n              <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n      </p-panel>\n\n      <!-- Heading-only section (title present, style='none' or omitted) -->\n      <div *ngIf=\"section.title && getSectionStyle(section) === 'none'\" class=\"heading-section\">\n        <h3 class=\"section-heading\">\n          <i *ngIf=\"section.icon\" [class]=\"section.icon + ' section-icon'\"></i>\n          {{ section.title }}\n        </h3>\n        <div *ngIf=\"!isInlineEditMode\" class=\"grid\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" [ngClass]=\"getFieldGridClass(field)\">\n              <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n        <div *ngIf=\"isInlineEditMode\" class=\"inline-edit-fields\">\n          <ng-container *ngFor=\"let field of section.fields\">\n            <div *ngIf=\"isFieldVisible(field)\" class=\"inline-edit-field\">\n              <ng-container *ngTemplateOutlet=\"inlineEditFieldTemplate; context: { field: field }\"></ng-container>\n            </div>\n          </ng-container>\n        </div>\n      </div>\n    </ng-container>\n\n    <!-- Custom content projection -->\n    <ng-content></ng-content>\n  </form>\n</ng-template>\n\n<!-- Field Template -->\n<ng-template #fieldTemplate let-field=\"field\">\n  <sia-dynamic-field-text *ngIf=\"field.type === 'text'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-text>\n  <sia-dynamic-field-textarea *ngIf=\"field.type === 'textarea'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-textarea>\n  <sia-dynamic-field-number *ngIf=\"field.type === 'number' || field.type === 'currency'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-number>\n  <sia-dynamic-field-date *ngIf=\"field.type === 'date'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-date>\n  <sia-dynamic-field-datetime *ngIf=\"field.type === 'datetime'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-datetime>\n  <sia-dynamic-field-dropdown *ngIf=\"field.type === 'dropdown' || field.type === 'enum'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-dropdown>\n  <sia-dynamic-field-lookup *ngIf=\"field.type === 'lookup'\" [field]=\"field\" [form]=\"form\" [formGroup]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-lookup>\n  <sia-dynamic-field-time *ngIf=\"field.type === 'time'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-time>\n  <sia-dynamic-field-checkbox *ngIf=\"field.type === 'checkbox'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-checkbox>\n  <sia-dynamic-field-multiselect *ngIf=\"field.type === 'multiselect'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-multiselect>\n  <sia-dynamic-field-image *ngIf=\"field.type === 'image'\" [field]=\"field\" [form]=\"form\" [mode]=\"'form'\"></sia-dynamic-field-image>\n</ng-template>\n\n<!-- Inline Edit Field Template -->\n<ng-template #inlineEditFieldTemplate let-field=\"field\">\n  <label class=\"field-label\">{{ field.label | translate }}</label>\n  <div class=\"field-display\" *ngIf=\"!isFieldEditing(field.field)\" (click)=\"startEditField(field.field)\" [class.disabled]=\"field.disabled\">\n    <span class=\"display-value\" [attr.data-placeholder]=\"field.placeholder || ('design.components_ai.not_informed' | translate)\">{{ getFieldDisplayValue(field.field) }}</span>\n    <i class=\"pi pi-pencil edit-icon\" *ngIf=\"!field.disabled\"></i>\n  </div>\n  <div class=\"field-edit\" *ngIf=\"isFieldEditing(field.field)\">\n    <div class=\"input-container\">\n      <ng-container *ngTemplateOutlet=\"fieldTemplate; context: { field: field }\"></ng-container>\n    </div>\n    <div class=\"edit-actions\">\n      <p-button type=\"button\" icon=\"pi pi-check\" [rounded]=\"true\" [text]=\"true\" severity=\"success\" (onClick)=\"saveInlineField(field.field)\" [loading]=\"savingField\" [disabled]=\"form.get(field.field)?.invalid\" size=\"small\"></p-button>\n      <p-button type=\"button\" icon=\"pi pi-times\" [rounded]=\"true\" [text]=\"true\" severity=\"danger\" (onClick)=\"cancelInlineEdit()\" [disabled]=\"savingField\" size=\"small\"></p-button>\n    </div>\n  </div>\n</ng-template>\n"]}