@seniorsistemas/components-ai 1.3.0 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dynamic-form/dynamic-form.component.mjs +263 -368
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-checkbox.component.mjs +53 -0
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-date.component.mjs +5 -3
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-datetime.component.mjs +5 -3
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-dropdown.component.mjs +5 -3
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-image.component.mjs +162 -0
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-lookup.component.mjs +203 -49
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-multiselect.component.mjs +90 -0
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-number.component.mjs +3 -3
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-text.component.mjs +7 -7
- package/esm2022/lib/components/dynamic-form/fields/dynamic-field-time.component.mjs +66 -0
- package/esm2022/lib/components/dynamic-form/fields/index.mjs +5 -1
- package/esm2022/lib/components/dynamic-form/models/dynamic-form.models.mjs +1 -1
- package/esm2022/lib/components/loading/iassist-icon.component.mjs +14 -0
- package/esm2022/lib/components/loading/loading.component.mjs +47 -4
- package/esm2022/lib/i18n/en-US.json +4 -1
- package/esm2022/lib/i18n/es-ES.json +4 -1
- package/esm2022/lib/i18n/pt-BR.json +4 -1
- package/esm2022/lib/models/entity-list.config.mjs +1 -1
- package/esm2022/lib/services/websocket.service.mjs +184 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/seniorsistemas-components-ai.mjs +1283 -661
- package/fesm2022/seniorsistemas-components-ai.mjs.map +1 -1
- package/lib/components/dynamic-form/dynamic-form.component.d.ts +8 -17
- package/lib/components/dynamic-form/fields/dynamic-field-checkbox.component.d.ts +8 -0
- package/lib/components/dynamic-form/fields/dynamic-field-image.component.d.ts +21 -0
- package/lib/components/dynamic-form/fields/dynamic-field-lookup.component.d.ts +19 -6
- package/lib/components/dynamic-form/fields/dynamic-field-multiselect.component.d.ts +10 -0
- package/lib/components/dynamic-form/fields/dynamic-field-time.component.d.ts +9 -0
- package/lib/components/dynamic-form/fields/index.d.ts +4 -0
- package/lib/components/dynamic-form/models/dynamic-form.models.d.ts +30 -84
- package/lib/components/loading/iassist-icon.component.d.ts +6 -0
- package/lib/components/loading/loading.component.d.ts +1 -1
- package/lib/models/entity-list.config.d.ts +12 -132
- package/lib/services/websocket.service.d.ts +63 -0
- package/package.json +3 -2
- package/public-api.d.ts +2 -0
- package/src/lib/i18n/en-US.json +4 -1
- package/src/lib/i18n/es-ES.json +4 -1
- package/src/lib/i18n/pt-BR.json +4 -1
|
@@ -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
|
-
|
|
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
|
|
39
|
-
displayMode
|
|
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
|
|
58
|
+
// Inline edit state
|
|
58
59
|
editingField = null;
|
|
59
60
|
savingField = false;
|
|
60
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
99
|
-
}
|
|
100
|
-
get
|
|
101
|
-
|
|
102
|
-
}
|
|
103
|
-
|
|
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
|
-
|
|
121
|
-
}
|
|
122
|
-
get
|
|
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
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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 =
|
|
203
|
-
|
|
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
|
-
|
|
164
|
+
case 'time': return null;
|
|
165
|
+
case 'checkbox': return false;
|
|
166
|
+
case 'multiselect': return [];
|
|
217
167
|
case 'dropdown':
|
|
218
|
-
case 'enum':
|
|
219
|
-
|
|
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
|
-
|
|
237
|
-
this.form.patchValue(processedData);
|
|
185
|
+
this.form.patchValue(this.processEntityData(this.entityData));
|
|
238
186
|
}
|
|
239
187
|
}
|
|
240
188
|
processEntityData(entity) {
|
|
241
|
-
const
|
|
189
|
+
const data = { ...entity };
|
|
242
190
|
this.allFields.forEach(field => {
|
|
243
|
-
if (field.type === 'date' &&
|
|
244
|
-
const
|
|
245
|
-
if (typeof
|
|
246
|
-
|
|
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
|
|
251
|
-
if (!isNaN(
|
|
252
|
-
|
|
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 === '
|
|
258
|
-
const
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
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
|
|
224
|
+
return data;
|
|
276
225
|
}
|
|
277
226
|
getNestedValue(obj, path) {
|
|
278
|
-
return path.split('.').reduce((
|
|
227
|
+
return path.split('.').reduce((cur, key) => cur?.[key], obj);
|
|
279
228
|
}
|
|
280
229
|
resetForm() {
|
|
281
230
|
if (this.form) {
|
|
282
|
-
const
|
|
283
|
-
this.allFields.forEach(
|
|
284
|
-
|
|
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
|
-
|
|
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
|
|
309
|
-
if (this.entityData?.id)
|
|
310
|
-
|
|
311
|
-
}
|
|
238
|
+
const out = { ...formValue };
|
|
239
|
+
if (this.entityData?.id)
|
|
240
|
+
out.id = this.entityData.id;
|
|
312
241
|
this.allFields.forEach(field => {
|
|
313
|
-
const
|
|
242
|
+
const v = out[field.field];
|
|
314
243
|
if (field.type === 'lookup') {
|
|
315
|
-
|
|
316
|
-
if (
|
|
317
|
-
|
|
318
|
-
|
|
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 (
|
|
330
|
-
|
|
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 (
|
|
341
|
-
if (
|
|
342
|
-
|
|
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
|
|
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
|
-
//
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
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
|
-
|
|
410
|
-
|
|
411
|
-
const
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
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
|
|
430
|
-
if (
|
|
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 (!
|
|
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
|
-
|
|
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
|
-
|
|
455
|
-
|
|
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();
|
|
353
|
+
this.resetForm();
|
|
474
354
|
}
|
|
475
|
-
this.loading = false;
|
|
355
|
+
this.loading = false;
|
|
476
356
|
this.visible = true;
|
|
477
357
|
this.visibleChange.emit(true);
|
|
478
358
|
}
|
|
479
359
|
close() {
|
|
480
|
-
this.loading = false;
|
|
360
|
+
this.loading = false;
|
|
481
361
|
this.visible = false;
|
|
482
362
|
this.visibleChange.emit(false);
|
|
483
|
-
this.resetForm();
|
|
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
|
-
|
|
495
|
-
|
|
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
|
-
//
|
|
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
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
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
|
|
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' &&
|
|
552
|
-
|
|
553
|
-
fieldValue = { id: fieldValue };
|
|
453
|
+
if (field?.type === 'lookup' && value && typeof value !== 'object') {
|
|
454
|
+
value = { id: value };
|
|
554
455
|
}
|
|
555
|
-
|
|
556
|
-
|
|
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
|
|
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
|
-
|
|
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
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
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
|
|
604
|
-
const
|
|
605
|
-
const
|
|
606
|
-
const
|
|
607
|
-
|
|
608
|
-
return
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
type: Input
|
|
670
|
-
|
|
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"]}
|