@muraai/mnl-form 0.0.1-alpha-db495b1 → 0.0.1-alpha-6116399

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/fesm2022/muraai-mnl-form.mjs +150 -143
  2. package/fesm2022/muraai-mnl-form.mjs.map +1 -1
  3. package/lib/types/upload-file.d.ts +1 -1
  4. package/lib/workflow-status/ workflow-status.module.d.ts +8 -8
  5. package/lib/workflow-status/workflow-status.component.d.ts +1 -1
  6. package/package.json +4 -5
  7. package/esm2022/lib/confirmation-dialog/confirmation-dialog.component.mjs +0 -34
  8. package/esm2022/lib/mnl-form/mnl-form-standalone.module.mjs +0 -155
  9. package/esm2022/lib/mnl-form/mnl-form.component.mjs +0 -199
  10. package/esm2022/lib/models/custom-form-field.model.mjs +0 -2
  11. package/esm2022/lib/models/workflow-status.model.mjs +0 -2
  12. package/esm2022/lib/services/graphql.service.mjs +0 -30
  13. package/esm2022/lib/services/scoring.service.mjs +0 -103
  14. package/esm2022/lib/types/action-button-renderer.component.mjs +0 -59
  15. package/esm2022/lib/types/autocomplete-type.component.mjs +0 -68
  16. package/esm2022/lib/types/button.type.mjs +0 -72
  17. package/esm2022/lib/types/comments.type.mjs +0 -102
  18. package/esm2022/lib/types/country-code-input.type.mjs +0 -181
  19. package/esm2022/lib/types/custom-date.type.mjs +0 -20
  20. package/esm2022/lib/types/custom-input.component.mjs +0 -62
  21. package/esm2022/lib/types/date-format.type.mjs +0 -196
  22. package/esm2022/lib/types/expansion-panel.types.mjs +0 -85
  23. package/esm2022/lib/types/formly-field-panel.type.mjs +0 -70
  24. package/esm2022/lib/types/grid-actionable.type.mjs +0 -197
  25. package/esm2022/lib/types/grid-formly-cell.component.mjs +0 -42
  26. package/esm2022/lib/types/grid.type.mjs +0 -125
  27. package/esm2022/lib/types/input.type.mjs +0 -43
  28. package/esm2022/lib/types/mu-helper-text.type.mjs +0 -331
  29. package/esm2022/lib/types/multi-select-autocomplete.mjs +0 -139
  30. package/esm2022/lib/types/multi-select-checkbox.component.mjs +0 -247
  31. package/esm2022/lib/types/radio.type.mjs +0 -71
  32. package/esm2022/lib/types/scrollable-tabs.types.mjs +0 -220
  33. package/esm2022/lib/types/select-api-auto-complete.component.mjs +0 -111
  34. package/esm2022/lib/types/select-autocomplete-redefined.component.mjs +0 -142
  35. package/esm2022/lib/types/select-autocomplete.type.mjs +0 -254
  36. package/esm2022/lib/types/stepper.type.mjs +0 -268
  37. package/esm2022/lib/types/table.types.mjs +0 -79
  38. package/esm2022/lib/types/tabs.types.mjs +0 -293
  39. package/esm2022/lib/types/tabular-form-dialog.component.mjs +0 -331
  40. package/esm2022/lib/types/tabular-form.type.mjs +0 -641
  41. package/esm2022/lib/types/upload-file.mjs +0 -524
  42. package/esm2022/lib/types/view-file-dialog.component.mjs +0 -90
  43. package/esm2022/lib/utils/formly.utils.mjs +0 -105
  44. package/esm2022/lib/validators/custom-email-validator.mjs +0 -18
  45. package/esm2022/lib/validators/ein-validators.mjs +0 -11
  46. package/esm2022/lib/validators/gst-validator.mjs +0 -11
  47. package/esm2022/lib/validators/normal-email-validator.mjs +0 -17
  48. package/esm2022/lib/validators/npi-validator.mjs +0 -11
  49. package/esm2022/lib/validators/pan-validator.mjs +0 -11
  50. package/esm2022/lib/validators/phone-number-validator.mjs +0 -22
  51. package/esm2022/lib/validators/select-validator.mjs +0 -7
  52. package/esm2022/lib/validators/tinSsn-validator.mjs +0 -12
  53. package/esm2022/lib/workflow-status/ workflow-status.module.mjs +0 -52
  54. package/esm2022/lib/workflow-status/workflow-status.component.mjs +0 -70
  55. package/esm2022/lib/wrappers/form-field-description-wrapper.component.mjs +0 -44
  56. package/esm2022/lib/wrappers/form-field-wrapper.component.mjs +0 -34
  57. package/esm2022/lib/wrappers/formly-wrapper-with-old-value.component.mjs +0 -140
  58. package/esm2022/lib/wrappers/prefix-suffix-wrapper.component.mjs +0 -95
  59. package/esm2022/lib/wrappers/prefix-sufix-extension.component.mjs +0 -9
  60. package/esm2022/muraai-mnl-form.mjs +0 -5
  61. package/esm2022/public-api.mjs +0 -12
@@ -1,641 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import { MatDialogModule } from '@angular/material/dialog';
3
- import { MatTableModule } from '@angular/material/table';
4
- import { MatSnackBarModule } from '@angular/material/snack-bar';
5
- import { CommonModule, DatePipe } from '@angular/common';
6
- import { FieldArrayType, FormlyModule } from '@ngx-formly/core';
7
- import { ReactiveFormsModule } from '@angular/forms';
8
- import { TabularFormDialogComponent } from './tabular-form-dialog.component';
9
- import { MatButtonModule } from '@angular/material/button';
10
- import { TranslateModule } from '@ngx-translate/core';
11
- import { AgGridModule } from 'ag-grid-angular';
12
- import { MatIconModule } from '@angular/material/icon';
13
- import { MatTooltipModule } from '@angular/material/tooltip';
14
- import { deepEqual, flattenJson } from '../utils/formly.utils';
15
- import { ViewFileDialogComponent } from './view-file-dialog.component';
16
- import { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component';
17
- import * as i0 from "@angular/core";
18
- import * as i1 from "@angular/material/dialog";
19
- import * as i2 from "@angular/material/snack-bar";
20
- import * as i3 from "@ngx-translate/core";
21
- import * as i4 from "@angular/common";
22
- import * as i5 from "@ngx-formly/core";
23
- import * as i6 from "@angular/material/button";
24
- import * as i7 from "ag-grid-angular";
25
- import * as i8 from "@angular/material/icon";
26
- import * as i9 from "@angular/material/tooltip";
27
- export class TabularFormComponent extends FieldArrayType {
28
- constructor(dialog, snackBar, cd, translateService, datePipe) {
29
- super();
30
- this.dialog = dialog;
31
- this.snackBar = snackBar;
32
- this.cd = cd;
33
- this.translateService = translateService;
34
- this.datePipe = datePipe;
35
- this.selectedRowCount = 0;
36
- this.isButtonsDisabled = false;
37
- this.columnDefs = [];
38
- this.rowData = [];
39
- this.defaultColDef = {
40
- sortable: true,
41
- filter: true,
42
- resizable: true,
43
- flex: 1,
44
- minWidth: 150,
45
- wrapHeaderText: true,
46
- autoHeaderHeight: true
47
- };
48
- this.getRowStyle = (params) => {
49
- if (this.options.formState.showOldValues) {
50
- if (params.data?.isChanged) {
51
- return { backgroundColor: '#ffcccc' };
52
- }
53
- if (params.data?.addedNewRow) {
54
- return { backgroundColor: '#F0EBAD80' };
55
- }
56
- }
57
- return undefined;
58
- };
59
- }
60
- ngOnInit() {
61
- if (this.options.formState.showOldValues) {
62
- const oldValues = flattenJson(this.options.formState.oldValues);
63
- this.oldValue = oldValues?.[this.field.key];
64
- }
65
- if (this.field?.enabledForRoles) {
66
- this.isButtonsDisabled = !this.options.formState?.userRoles?.some((role) => this.field?.enabledForRoles?.includes(role));
67
- }
68
- if (this.field?.props?.['columnDefs']) {
69
- if (this.options.formState?.showOldValues) {
70
- this.columnDefs = [
71
- {
72
- headerCheckboxSelection: !this.isButtonsDisabled,
73
- checkboxSelection: (params) => {
74
- return !this.isButtonsDisabled && !params.data.isOldData;
75
- },
76
- headerName: '',
77
- width: 40,
78
- maxWidth: 40,
79
- filter: false,
80
- resizable: false
81
- },
82
- {
83
- headerName: '',
84
- width: 40,
85
- maxWidth: 60,
86
- filter: false,
87
- resizable: false,
88
- field: 'isChanged',
89
- cellRenderer: (params) => {
90
- if (params.value) {
91
- return `<i class="material-icons cursor-pointer mt-[9px]" style="color: red;">edit</i>`;
92
- }
93
- else {
94
- return `<i class="material-icons cursor-pointer mt-[9px]" style="color: black;">visibility</i>`;
95
- }
96
- },
97
- onCellClicked: (params) => {
98
- this.showChangedValues(params);
99
- },
100
- tooltipValueGetter: (params) => {
101
- if (params.value) {
102
- return 'This row data is changed, Please click on this to view the changed details';
103
- }
104
- return '';
105
- },
106
- },
107
- ...this.translateLabels(this.field?.props?.['columnDefs'])
108
- ];
109
- }
110
- else {
111
- this.columnDefs = [
112
- {
113
- headerCheckboxSelection: !this.isButtonsDisabled,
114
- checkboxSelection: !this.isButtonsDisabled,
115
- headerName: '',
116
- width: 40,
117
- maxWidth: 40,
118
- filter: false,
119
- resizable: false
120
- },
121
- {
122
- headerName: '',
123
- field: 'view',
124
- width: 50,
125
- maxWidth: 50,
126
- filter: false,
127
- resizable: false,
128
- cellRenderer: () => {
129
- return `<i class="material-icons cursor-pointer mt-[9px]" style="color: black;">visibility</i>`;
130
- },
131
- onCellClicked: (params) => {
132
- this.showChangedValues(params);
133
- }
134
- },
135
- ...this.translateLabels(this.field?.props?.['columnDefs'])
136
- ];
137
- }
138
- this.columnDefs = this.columnDefs?.map(colDef => {
139
- if (colDef?.type === 'date') {
140
- return {
141
- ...colDef,
142
- valueFormatter: ((params) => this.formatDate(params.value))
143
- };
144
- }
145
- if (colDef?.field?.includes('FileName')) {
146
- return {
147
- ...colDef,
148
- cellRenderer: (params) => {
149
- if (params.value) {
150
- return `<a href="javascript:void(0)" style="color: blue; text-decoration: underline;">
151
- ${params.value}
152
- </a>`;
153
- }
154
- else {
155
- return '';
156
- }
157
- },
158
- onCellClicked: (params) => {
159
- this.onFilenameClick(params);
160
- },
161
- };
162
- }
163
- return colDef;
164
- });
165
- const gridData = findNestedKey(this.field.parent?.model, this.field.key);
166
- this.rowData = Array.isArray(gridData) ? gridData : [];
167
- if (this.field.props?.['rowData']) {
168
- this.field.props?.['rowData']?.asObservable()?.pipe()?.subscribe((data) => {
169
- if (data[0]?.id) {
170
- if (this.rowData.find((row) => row.id == data[0]?.id)) {
171
- this.rowData = [...this.rowData];
172
- }
173
- else {
174
- this.rowData = [...this.rowData, ...data];
175
- }
176
- }
177
- });
178
- }
179
- if (this.field.props?.['updateRowData']) {
180
- this.field.props?.['updateRowData']?.asObservable()?.pipe()?.subscribe((data) => {
181
- const updatedRows = this.rowData.map((row) => {
182
- const newRow = data.find((eachRow) => eachRow.id == row.id);
183
- const newRowData = {
184
- ...row,
185
- ...(newRow ?? {})
186
- };
187
- return newRowData;
188
- });
189
- this.rowData = [...updatedRows];
190
- this.gridApi?.selectAll();
191
- this.gridApi?.deselectAll();
192
- });
193
- }
194
- }
195
- }
196
- onGridReady(params) {
197
- this.gridApi = params.api;
198
- this.updateSelectedRowCount();
199
- }
200
- openDialog() {
201
- if (this.field && this.field.props?.['dialogOpened']) {
202
- this.field.props?.['dialogOpened'](event, this.field);
203
- }
204
- const dialogRef = this.dialog.open(TabularFormDialogComponent, {
205
- width: this.props?.['dialogWidth'] ?? '75%',
206
- maxWidth: '100%',
207
- height: this.props?.['dialogHeight'] ?? '85%',
208
- data: { fieldConfig: this.field.fieldArray.fieldGroup, label: this.field.props?.addLabel ?? 'Add', formState: this.options?.formState, tabularProps: this.field.props,
209
- parentModel: this.field.parent?.model
210
- },
211
- disableClose: true,
212
- autoFocus: false
213
- });
214
- dialogRef.afterClosed().subscribe(result => {
215
- if (result) {
216
- result.id = this.generateRandomNumber();
217
- if (this.options.formState.showOldValues) {
218
- result.addedNewRow = true;
219
- }
220
- if (this.props?.['isSequentialNumGenerationRequired']) {
221
- result.sequentialNumberId = `000${this.generateSequentialIdNumber(this.field.parent?.model)}`;
222
- }
223
- this.addRowToGrid(result);
224
- }
225
- if (this.field && this.field.props?.['dialogClosed']) {
226
- this.field.props?.['dialogClosed'](event, this.field);
227
- }
228
- });
229
- dialogRef.componentInstance.saveData.subscribe((data) => {
230
- data.id = this.generateRandomNumber();
231
- if (this.options.formState.showOldValues) {
232
- data.addedNewRow = true;
233
- }
234
- updateModel(this.field.parent?.model, this.field.key, data, 'push');
235
- this.addRowToGrid(data);
236
- });
237
- }
238
- generateRandomNumber() {
239
- return Math.floor(1000 + Math.random() * 9000);
240
- }
241
- addRowToGrid(data) {
242
- if (this.rowData.length > this.getMaxRows()) {
243
- this.snackBar.open(`Cannot add more than ${this.getMaxRows()} rows`, 'Close', {
244
- duration: 3000
245
- });
246
- return;
247
- }
248
- for (const key in data) {
249
- if (data[key] instanceof Object) {
250
- if (data[key]?.fileName) {
251
- data[`${key}FileName`] = data[key].fileName;
252
- }
253
- }
254
- }
255
- if (this.columnDefs.length === 0) {
256
- this.columnDefs = [
257
- {
258
- headerCheckboxSelection: true,
259
- checkboxSelection: true,
260
- headerName: '',
261
- width: 40,
262
- maxWidth: 40,
263
- resizable: false,
264
- filter: false
265
- },
266
- ...Object.keys(data)
267
- .filter(key => {
268
- const fieldConfig = this.findFieldConfigByKey(this.field.fieldGroup || [], key);
269
- return key !== 'id' && fieldConfig?.type !== 'mu-button';
270
- })
271
- .map(key => {
272
- const label = this.findLabelInNestedFields(this.field.fieldGroup || [], key);
273
- return {
274
- field: key,
275
- headerName: label
276
- };
277
- })
278
- ];
279
- }
280
- if (this.rowData.find((row) => row.id == data.id)) {
281
- this.rowData = [...this.rowData];
282
- }
283
- else {
284
- this.rowData = [...this.rowData, data];
285
- }
286
- this.add(null, data);
287
- this.cd.detectChanges();
288
- this.snackBar.open(this.translateService.instant('MNL_TABULAR_FORM.DATA_ADDED_SUCCESSFULLY'), 'Close', {
289
- duration: 0,
290
- });
291
- this.gridApi.selectAll();
292
- this.gridApi.deselectAll();
293
- }
294
- findFieldConfigByKey(fieldConfigs, key) {
295
- for (const field of fieldConfigs) {
296
- if (field.key === key) {
297
- return field;
298
- }
299
- if (field.fieldGroup) {
300
- const foundField = this.findFieldConfigByKey(field.fieldGroup, key);
301
- if (foundField) {
302
- return foundField;
303
- }
304
- }
305
- }
306
- return null;
307
- }
308
- getMaxRows() {
309
- return this.to['maxRows'];
310
- }
311
- findLabelInNestedFields(fieldConfigs, key) {
312
- for (const field of fieldConfigs) {
313
- if (field.key === key) {
314
- return field.props?.label || key;
315
- }
316
- if (field.fieldGroup) {
317
- const label = this.findLabelInNestedFields(field.fieldGroup, key);
318
- if (label) {
319
- return label;
320
- }
321
- }
322
- }
323
- return key;
324
- }
325
- removeSelectedRows() {
326
- if (this.options.formState.showOldValues) {
327
- const selectedData = this.gridApi.getSelectedNodes().map(node => node.data);
328
- if (!selectedData.every(data => data.addedNewRow)) {
329
- this.snackBar.open(this.translateService.instant('MNL_TABULAR_FORM.NO_ACCESS_TO_DELETE_OLD_RECORDS'), 'Ok', {
330
- duration: 0,
331
- panelClass: ['error-snackbar'],
332
- });
333
- return;
334
- }
335
- }
336
- const dialog = this.dialog.open(ConfirmationDialogComponent, {
337
- width: '50%',
338
- height: '28%',
339
- data: { title: 'Are you sure to delete?' }
340
- });
341
- dialog.afterClosed().subscribe((res) => {
342
- if (res) {
343
- const selectedNodes = this.gridApi.getSelectedNodes();
344
- const selectedData = selectedNodes.map(node => node.data);
345
- this.rowData = this.rowData.filter(row => !selectedData.includes(row));
346
- updateModel(this.field.parent?.model, this.field.key, this.rowData, 'assign');
347
- this.gridApi.applyTransaction({
348
- remove: selectedData
349
- });
350
- this.updateSelectedRowCount();
351
- }
352
- });
353
- }
354
- onRowSelected(event) {
355
- this.updateSelectedRowCount();
356
- }
357
- updateSelectedRowCount() {
358
- this.selectedRowCount = this.gridApi.getSelectedNodes().length;
359
- }
360
- translateLabels(columnDefs) {
361
- return columnDefs.map((column) => {
362
- return {
363
- ...column,
364
- headerName: this.translateService.instant(column.headerName)
365
- };
366
- });
367
- }
368
- editDialog() {
369
- const selectedNodes = this.gridApi.getSelectedNodes();
370
- const selectedData = selectedNodes.map(node => node.data);
371
- if (selectedData?.length > 1) {
372
- this.snackBar.open(this.translateService.instant('MNL_TABULAR_FORM.MULTI_ROW_EDIT_ERROR'), 'Ok', {
373
- duration: 5000,
374
- });
375
- return;
376
- }
377
- if (this.field && this.field.props?.['dialogOpened']) {
378
- this.field.props?.['dialogOpened'](event, this.field);
379
- }
380
- const dialogRef = this.dialog.open(TabularFormDialogComponent, {
381
- width: this.props?.['dialogWidth'] ?? '75%',
382
- maxWidth: '100%',
383
- height: this.props?.['dialogHeight'] ?? '85%',
384
- data: { fieldConfig: this.field.fieldArray.fieldGroup, label: this.field.props?.editLabel ?? 'Edit', formState: this.options?.formState, selectedRowData: selectedData[0], tabularProps: this.field.props, parentModel: this.field.parent?.model },
385
- disableClose: true,
386
- autoFocus: false
387
- });
388
- dialogRef.afterClosed().subscribe(result => {
389
- if (result) {
390
- this.rowData = this.rowData.map((rowRecord) => {
391
- if (rowRecord?.['id'] === result?.id) {
392
- if (this.options.formState?.showOldValues) {
393
- const oldRowValue = this.oldValue.find((record) => record.id === result?.id);
394
- if (oldRowValue) {
395
- oldRowValue['isChanged'] = false;
396
- result['isChanged'] = false;
397
- const mergdOld = {
398
- ...result,
399
- ...oldRowValue
400
- };
401
- const eq = deepEqual(mergdOld, result);
402
- rowRecord['isChanged'] = !eq;
403
- result['isChanged'] = !eq;
404
- }
405
- }
406
- const updatedRow = {
407
- ...rowRecord,
408
- ...result,
409
- };
410
- Object.keys(updatedRow).forEach(key => {
411
- if (updatedRow[key] instanceof Object) {
412
- if (updatedRow[key]?.fileName) {
413
- updatedRow[`${key}FileName`] = updatedRow[key].fileName;
414
- }
415
- }
416
- });
417
- return updatedRow;
418
- }
419
- return rowRecord;
420
- });
421
- updateModel(this.field.parent?.model, this.field.key, this.rowData, 'assign');
422
- this.cd.detectChanges();
423
- }
424
- this.updateSelectedRowCount();
425
- this.cd.detectChanges();
426
- if (this.field && this.field.props?.['tabularDataEdited']) {
427
- this.field.props?.['tabularDataEdited'](event, this.field);
428
- }
429
- if (this.field && this.field.props?.['dialogClosed']) {
430
- this.field.props?.['dialogClosed'](event, this.field);
431
- }
432
- });
433
- }
434
- formatDate(date) {
435
- if (date) {
436
- const d = new Date(date);
437
- const day = String(d.getDate()).padStart(2, '0');
438
- const monthNames = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
439
- const month = monthNames[d.getMonth()];
440
- const year = d.getFullYear();
441
- return `${day}-${month}-${year}`;
442
- }
443
- else {
444
- return '';
445
- }
446
- }
447
- onFilenameClick(params) {
448
- const uploadedFileNameKey = Object.keys(params.data).filter(key => key.endsWith('FileName'));
449
- const uploadedFileObjectKey = uploadedFileNameKey[0]?.replace(/FileName$/, "");
450
- if (uploadedFileObjectKey)
451
- this.viewFile(params.data[uploadedFileObjectKey]);
452
- }
453
- viewFile(element) {
454
- const dialogRef = this.dialog.open(ViewFileDialogComponent, {
455
- width: '75%',
456
- maxWidth: '95%',
457
- height: '85%',
458
- data: element
459
- });
460
- }
461
- showChangedValues(params) {
462
- const formState = {
463
- ...this.options.formState,
464
- userRoles: []
465
- };
466
- this.dialog.open(TabularFormDialogComponent, {
467
- width: this.props?.['dialogWidth'] ?? '75%',
468
- maxWidth: '95%',
469
- height: '85%',
470
- data: { fieldConfig: this.field.fieldArray.fieldGroup, label: this.field.props?.viewLabel ?? 'View', formState: formState, selectedRowData: params.data, hideUpdateBtn: true, parentModel: this.field.parent?.model, tabularProps: this.field.props },
471
- disableClose: true
472
- });
473
- }
474
- generateSequentialIdNumber(parentModel) {
475
- if (parentModel?.[this.props?.['parenetModelKeyToGenerateSequentialNumber']]?.length) {
476
- const latestRecordIdNumber = parentModel?.[this.props?.['parenetModelKeyToGenerateSequentialNumber']]?.sort((a, b) => +(b?.sequentialNumberId) - +(a?.sequentialNumberId))?.find((parenData) => +(parenData?.sequentialNumberId));
477
- return +(latestRecordIdNumber?.sequentialNumberId) + 1;
478
- }
479
- return 1;
480
- }
481
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TabularFormComponent, deps: [{ token: i1.MatDialog }, { token: i2.MatSnackBar }, { token: i0.ChangeDetectorRef }, { token: i3.TranslateService }, { token: i4.DatePipe }], target: i0.ɵɵFactoryTarget.Component }); }
482
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: TabularFormComponent, isStandalone: true, selector: "mu-formly-add-dialog-type", providers: [DatePipe], usesInheritance: true, ngImport: i0, template: `
483
- <div class="flex justify-start mt-2 mr-2 items-center">
484
- @if(selectedRowCount > 0) {
485
- <button
486
- *ngIf="!field.props?.['hideDelete']"
487
- mat-icon-button
488
- type="button"
489
- (click)="removeSelectedRows()"
490
- matTooltip="{{ field.props?.['deleteButtonTooltip']|translate }}"
491
- [disabled]="isButtonsDisabled"
492
- >
493
- <mat-icon class="icon">{{ field.props?.['deleteButtonIcon'] }}</mat-icon>
494
- </button>
495
-
496
- <button
497
- mat-icon-button
498
- *ngIf="!field.props?.['hideEdit']"
499
- type="button"
500
- (click)="editDialog()"
501
- matTooltip="{{ field.props?.['editButtonTooltip'] | translate}}"
502
- [disabled]="isButtonsDisabled">
503
- <mat-icon>
504
- {{ field.props?.['editButtonIcon'] }}
505
- </mat-icon>
506
- </button>
507
- }
508
- <button
509
- *ngIf="!field.props?.['hideAdd'] && (props['maxRows'] ? rowData.length < getMaxRows() : true)"
510
- mat-button
511
- type="button"
512
- (click)="openDialog()"
513
- matTooltip="{{ field.props?.['addButtonTooltip'] | translate}}"
514
- [disabled]="isButtonsDisabled"
515
- >
516
- <mat-icon>
517
- {{ field.props?.['addButtonIcon'] }}
518
- </mat-icon>
519
- <span>{{field.props?.['addBtnLabel'] | translate}}</span>
520
- </button>
521
- </div>
522
- <ag-grid-angular
523
- class="ag-theme-alpine"
524
- [rowData]="rowData"
525
- [formlyAttributes]="field"
526
- [columnDefs]="columnDefs"
527
- [defaultColDef]="defaultColDef"
528
- [suppressRowClickSelection]="true"
529
- rowSelection="multiple"
530
- (gridReady)="onGridReady($event)"
531
- [domLayout]="rowData.length > 5 ? 'normal' : 'autoHeight'"
532
- (rowSelected)="onRowSelected($event)"
533
- [style.height]="rowData.length > 5 ? '300px' : 'auto'"
534
- [getRowStyle]="getRowStyle"
535
- [gridOptions]="{ suppressMovableColumns : true }"
536
- >
537
- </ag-grid-angular>
538
- `, isInline: true, styles: ["ag-grid-angular{margin-top:16px;width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormlyModule }, { kind: "directive", type: i5.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { kind: "ngmodule", type: MatSnackBarModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: MatDialogModule }, { kind: "ngmodule", type: MatTableModule }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: AgGridModule }, { kind: "component", type: i7.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "columnMenu", "suppressMenuHide", "enableBrowserTooltips", "tooltipTrigger", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "tooltipShowMode", "tooltipInteraction", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "suppressCutToClipboard", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "dataTypeDefinitions", "maintainColumnOrder", "enableStrictPivotColumnOrder", "suppressFieldDotNotation", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressMoveWhenColumnDragging", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "autoSizeStrategy", "components", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterNavigatesVertically", "enterNavigatesVerticallyAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "quickFilterText", "cacheQuickFilter", "includeHiddenColumnsInQuickFilter", "quickFilterParser", "quickFilterMatcher", "applyQuickFilterBeforePivotOrAgg", "excludeChildrenWhenTreeDataFiltering", "enableAdvancedFilter", "advancedFilterModel", "includeHiddenColumnsInAdvancedFilter", "advancedFilterParent", "advancedFilterBuilderParams", "suppressAdvancedFilterEval", "suppressSetFilterByDefault", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "chartToolPanelsDef", "chartMenuItems", "loadingCellRenderer", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "dragAndDropImageComponent", "dragAndDropImageComponentParams", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "loading", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationPageSizeSelector", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotMaxGeneratedColumns", "pivotDefaultExpanded", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "alwaysAggregateAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDuration", "cellFlashDelay", "cellFadeDuration", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererParams", "embedFullWidthRows", "suppressGroupMaintainValueType", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupLockGroupColumns", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupTotalRow", "grandTotalRow", "suppressStickyTotalRow", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "groupAllowUnbalanced", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "suppressGroupRowsSticky", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "suppressServerSideInfiniteScroll", "suppressServerSideFullWidthLoadingRow", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideEnableClientSideSort", "serverSideOnlyRefreshFilteredGroups", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSidePivotResultFieldSeparator", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "cellSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellFocus", "suppressHeaderFocus", "selectionColumnDef", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "gridId", "deltaSort", "treeDataDisplayType", "enableGroupEdit", "initialState", "theme", "loadThemeGoogleFonts", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processUnpinnedColumns", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "focusGridInnerElement", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "getLocaleText", "getDocument", "paginationNumberFormatter", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "getChildCount", "getServerSideGroupLevelParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "columnMenuVisibleChanged", "contextMenuVisibleChanged", "cutStart", "cutEnd", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "columnHeaderMouseOver", "columnHeaderMouseLeave", "columnHeaderClicked", "columnHeaderContextMenu", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "undoStarted", "undoEnded", "redoStarted", "redoEnded", "cellSelectionDeleteStart", "cellSelectionDeleteEnd", "rangeDeleteStart", "rangeDeleteEnd", "fillStart", "fillEnd", "filterOpened", "filterChanged", "filterModified", "advancedFilterBuilderVisibleChanged", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "dragCancelled", "stateUpdated", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "rowDragCancel", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pivotMaxColumnsExceeded", "pinnedRowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "storeRefreshed", "headerFocused", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "cellSelectionChanged", "tooltipShow", "tooltipHide", "sortChanged"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i9.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }] }); }
539
- }
540
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TabularFormComponent, decorators: [{
541
- type: Component,
542
- args: [{ selector: 'mu-formly-add-dialog-type', standalone: true, imports: [CommonModule, FormlyModule, MatSnackBarModule, TranslateModule, ReactiveFormsModule, MatDialogModule, MatTableModule, MatButtonModule,
543
- MatDialogModule, AgGridModule, TranslateModule, MatIconModule, MatTooltipModule
544
- ], providers: [DatePipe], template: `
545
- <div class="flex justify-start mt-2 mr-2 items-center">
546
- @if(selectedRowCount > 0) {
547
- <button
548
- *ngIf="!field.props?.['hideDelete']"
549
- mat-icon-button
550
- type="button"
551
- (click)="removeSelectedRows()"
552
- matTooltip="{{ field.props?.['deleteButtonTooltip']|translate }}"
553
- [disabled]="isButtonsDisabled"
554
- >
555
- <mat-icon class="icon">{{ field.props?.['deleteButtonIcon'] }}</mat-icon>
556
- </button>
557
-
558
- <button
559
- mat-icon-button
560
- *ngIf="!field.props?.['hideEdit']"
561
- type="button"
562
- (click)="editDialog()"
563
- matTooltip="{{ field.props?.['editButtonTooltip'] | translate}}"
564
- [disabled]="isButtonsDisabled">
565
- <mat-icon>
566
- {{ field.props?.['editButtonIcon'] }}
567
- </mat-icon>
568
- </button>
569
- }
570
- <button
571
- *ngIf="!field.props?.['hideAdd'] && (props['maxRows'] ? rowData.length < getMaxRows() : true)"
572
- mat-button
573
- type="button"
574
- (click)="openDialog()"
575
- matTooltip="{{ field.props?.['addButtonTooltip'] | translate}}"
576
- [disabled]="isButtonsDisabled"
577
- >
578
- <mat-icon>
579
- {{ field.props?.['addButtonIcon'] }}
580
- </mat-icon>
581
- <span>{{field.props?.['addBtnLabel'] | translate}}</span>
582
- </button>
583
- </div>
584
- <ag-grid-angular
585
- class="ag-theme-alpine"
586
- [rowData]="rowData"
587
- [formlyAttributes]="field"
588
- [columnDefs]="columnDefs"
589
- [defaultColDef]="defaultColDef"
590
- [suppressRowClickSelection]="true"
591
- rowSelection="multiple"
592
- (gridReady)="onGridReady($event)"
593
- [domLayout]="rowData.length > 5 ? 'normal' : 'autoHeight'"
594
- (rowSelected)="onRowSelected($event)"
595
- [style.height]="rowData.length > 5 ? '300px' : 'auto'"
596
- [getRowStyle]="getRowStyle"
597
- [gridOptions]="{ suppressMovableColumns : true }"
598
- >
599
- </ag-grid-angular>
600
- `, styles: ["ag-grid-angular{margin-top:16px;width:100%}\n"] }]
601
- }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.MatSnackBar }, { type: i0.ChangeDetectorRef }, { type: i3.TranslateService }, { type: i4.DatePipe }] });
602
- function updateModel(obj, targetKey, newValue, action) {
603
- for (const key in obj) {
604
- if (key === targetKey) {
605
- if (action === 'push') {
606
- if (Array.isArray(obj[key])) {
607
- obj[key].push(newValue);
608
- }
609
- else if (obj[key] !== undefined) {
610
- obj[key] = [obj[key], newValue];
611
- }
612
- else {
613
- obj[key] = [newValue];
614
- }
615
- }
616
- else {
617
- obj[key] = newValue;
618
- }
619
- return true;
620
- }
621
- if (typeof obj[key] === 'object' && obj[key] !== null) {
622
- const result = updateModel(obj[key], targetKey, newValue, action);
623
- if (result)
624
- return true;
625
- }
626
- }
627
- return false;
628
- }
629
- function findNestedKey(obj, targetKey) {
630
- for (const key in obj) {
631
- if (key === targetKey)
632
- return obj[key];
633
- if (typeof obj[key] === 'object') {
634
- const result = findNestedKey(obj[key], targetKey);
635
- if (result)
636
- return result;
637
- }
638
- }
639
- return undefined;
640
- }
641
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabular-form.type.js","sourceRoot":"","sources":["../../../../../../libs/form/src/lib/types/tabular-form.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnInit } from '@angular/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { MatDialog, MatDialogModule } from '@angular/material/dialog';\nimport { MatTableModule } from '@angular/material/table';\nimport { MatSnackBar, MatSnackBarModule } from '@angular/material/snack-bar';\nimport { CommonModule, DatePipe } from '@angular/common';\nimport { FieldArrayType, FormlyModule } from '@ngx-formly/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { TabularFormDialogComponent } from './tabular-form-dialog.component';\nimport { MatButtonModule } from '@angular/material/button';\nimport { TranslateModule, TranslateService } from '@ngx-translate/core';\nimport { AgGridModule } from 'ag-grid-angular';\nimport { ColDef } from 'ag-grid-community';\nimport { CustomFormlyFieldConfig } from '../models/custom-form-field.model';\nimport { GridApi, RowSelectedEvent } from 'ag-grid-community';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { deepEqual, flattenJson } from '../utils/formly.utils';\nimport { ViewFileDialogComponent } from './view-file-dialog.component';\nimport { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component';\n\n@Component({\n  selector: 'mu-formly-add-dialog-type',\n  standalone: true,\n  imports: [CommonModule, FormlyModule, MatSnackBarModule, TranslateModule, ReactiveFormsModule, MatDialogModule, MatTableModule, MatButtonModule,\n    MatDialogModule, AgGridModule, TranslateModule,MatIconModule,MatTooltipModule\n  ],\n  providers: [DatePipe],\n  template: `\n    <div class=\"flex justify-start mt-2 mr-2 items-center\">\n      @if(selectedRowCount > 0) {\n        <button\n          *ngIf=\"!field.props?.['hideDelete']\"\n          mat-icon-button\n          type=\"button\"\n          (click)=\"removeSelectedRows()\"\n          matTooltip=\"{{ field.props?.['deleteButtonTooltip']|translate }}\"\n          [disabled]=\"isButtonsDisabled\"\n          >\n         <mat-icon class=\"icon\">{{ field.props?.['deleteButtonIcon'] }}</mat-icon>\n         </button>\n\n        <button \n          mat-icon-button\n          *ngIf=\"!field.props?.['hideEdit']\"\n          type=\"button\"\n          (click)=\"editDialog()\"\n          matTooltip=\"{{ field.props?.['editButtonTooltip'] | translate}}\"\n          [disabled]=\"isButtonsDisabled\">\n          <mat-icon>\n            {{ field.props?.['editButtonIcon'] }}\n          </mat-icon>\n        </button>\n      }\n      <button\n        *ngIf=\"!field.props?.['hideAdd'] && (props['maxRows'] ? rowData.length < getMaxRows() : true)\"\n        mat-button\n        type=\"button\"\n        (click)=\"openDialog()\"\n        matTooltip=\"{{ field.props?.['addButtonTooltip'] | translate}}\"\n        [disabled]=\"isButtonsDisabled\"\n      >\n        <mat-icon>\n          {{ field.props?.['addButtonIcon'] }}\n        </mat-icon>\n        <span>{{field.props?.['addBtnLabel'] | translate}}</span>\n      </button>\n      </div>\n        <ag-grid-angular\n            class=\"ag-theme-alpine\"\n            [rowData]=\"rowData\"\n            [formlyAttributes]=\"field\"\n            [columnDefs]=\"columnDefs\"\n            [defaultColDef]=\"defaultColDef\"\n            [suppressRowClickSelection]=\"true\"\n            rowSelection=\"multiple\"\n            (gridReady)=\"onGridReady($event)\"\n            [domLayout]=\"rowData.length > 5 ? 'normal' : 'autoHeight'\"\n            (rowSelected)=\"onRowSelected($event)\"\n            [style.height]=\"rowData.length > 5 ? '300px' : 'auto'\"\n            [getRowStyle]=\"getRowStyle\"\n            [gridOptions]=\"{ suppressMovableColumns : true }\"\n            >\n        </ag-grid-angular>\n  `,\n  styles: [`\n    ag-grid-angular {\n      margin-top: 16px;\n      width: 100%;\n    }\n  `]\n})\nexport class TabularFormComponent extends FieldArrayType<CustomFormlyFieldConfig> implements OnInit {\n  selectedRowCount = 0;\n  isButtonsDisabled = false;\n  columnDefs: ColDef[] = [];\n  rowData: Record<string, any>[] = [];\n  gridApi!: GridApi;\n  defaultColDef = {\n    sortable: true,\n    filter: true,\n    resizable: true,\n    flex: 1,\n    minWidth: 150,\n    wrapHeaderText: true,\n    autoHeaderHeight: true\n  };\n  oldValue!: any;\n  constructor(\n    private dialog: MatDialog,\n    private snackBar: MatSnackBar,\n    private cd: ChangeDetectorRef,\n    private translateService: TranslateService,\n    private datePipe: DatePipe) {\n    super();\n  }\n\n  ngOnInit(): void {\n    if(this.options.formState.showOldValues) {\n      const oldValues = flattenJson(this.options.formState.oldValues);\n      this.oldValue = oldValues?.[this.field.key as string];\n    }\n\n    if(this.field?.enabledForRoles) {\n      this.isButtonsDisabled = !this.options.formState?.userRoles?.some((role: any) => this.field?.enabledForRoles?.includes(role));\n    }\n\n    if (this.field?.props?.['columnDefs']) {\n      if(this.options.formState?.showOldValues) {\n        this.columnDefs = [\n          {\n            headerCheckboxSelection: !this.isButtonsDisabled,\n            checkboxSelection: (params) => {\n              return !this.isButtonsDisabled && !params.data.isOldData\n            },\n            headerName: '',\n            width: 40,\n            maxWidth: 40,\n            filter: false,\n            resizable:false\n          },\n          {\n            headerName: '',\n            width: 40,\n            maxWidth: 60,\n            filter: false,\n            resizable:false,\n            field: 'isChanged',\n            cellRenderer: (params: any) => {\n              if (params.value) {\n                return `<i class=\"material-icons cursor-pointer mt-[9px]\" style=\"color: red;\">edit</i>`;\n              } else {\n                return `<i class=\"material-icons cursor-pointer mt-[9px]\" style=\"color: black;\">visibility</i>`;\n              }\n            },\n            onCellClicked: (params) => {\n              this.showChangedValues(params);\n            },\n            tooltipValueGetter: (params: any) => {\n              if (params.value) {\n                return 'This row data is changed, Please click on this to view the changed details';\n              }\n              return '';\n            },\n\n          },\n          ...this.translateLabels(this.field?.props?.['columnDefs'])\n        ]\n      } else {\n        this.columnDefs = [\n          {\n            headerCheckboxSelection: !this.isButtonsDisabled,\n            checkboxSelection: !this.isButtonsDisabled,\n            headerName: '',\n            width: 40,\n            maxWidth: 40,\n            filter: false,\n            resizable:false\n          },\n          {\n            headerName: '',\n            field: 'view',\n            width: 50,\n            maxWidth: 50,\n            filter: false,\n            resizable:false,\n            cellRenderer: () => {\n              return `<i class=\"material-icons cursor-pointer mt-[9px]\" style=\"color: black;\">visibility</i>`;\n            },\n            onCellClicked: (params) => {\n              this.showChangedValues(params);\n            }\n          },\n          ...this.translateLabels(this.field?.props?.['columnDefs'])\n        ];\n      }\n\n      this.columnDefs = this.columnDefs?.map(colDef => {\n        if (colDef?.type === 'date') {\n          return {\n            ...colDef,\n            valueFormatter: ((params:any) => this.formatDate(params.value))\n          };\n        }\n        if(colDef?.field?.includes('FileName')) {\n          return {\n            ...colDef,\n            cellRenderer: (params: any) => {\n              if(params.value) {\n                return `<a href=\"javascript:void(0)\" style=\"color: blue; text-decoration: underline;\">\n                  ${params.value}\n                </a>`;\n              } else {\n                return '';\n              }\n            },\n            onCellClicked: (params) => {\n              this.onFilenameClick(params);\n            },\n          }\n        }\n        return colDef;\n      })\n      const gridData = findNestedKey(this.field.parent?.model, this.field.key);\n      this.rowData = Array.isArray(gridData) ? gridData : [];\n      if(this.field.props?.['rowData']) {\n        this.field.props?.['rowData']?.asObservable()?.pipe()?.subscribe((data: any) => {\n          if(data[0]?.id) {\n            if(this.rowData.find((row: any) => row.id == data[0]?.id)) {\n              this.rowData = [...this.rowData]\n            } else {\n              this.rowData = [...this.rowData, ...data];\n            }\n          }\n        })\n      }\n      if(this.field.props?.['updateRowData']) {\n        this.field.props?.['updateRowData']?.asObservable()?.pipe()?.subscribe((data: any) => {\n          const updatedRows = this.rowData.map((row: any) => {\n            const newRow = data.find((eachRow: any) => eachRow.id == row.id);\n            const newRowData = {\n              ...row,\n              ...(newRow ?? {})\n            };\n            return newRowData;\n          });\n          this.rowData = [...updatedRows];\n          this.gridApi?.selectAll();\n          this.gridApi?.deselectAll();\n        });\n      }\n    }\n  }\n  onGridReady(params: any): void {\n    this.gridApi = params.api;\n    this.updateSelectedRowCount();\n  }\n\n  openDialog(): void {\n    if (this.field && this.field.props?.['dialogOpened']) {\n      this.field.props?.['dialogOpened'](event, this.field);\n    }\n    const dialogRef = this.dialog.open(TabularFormDialogComponent, {\n      width: this.props?.['dialogWidth'] ?? '75%',\n      maxWidth: '100%',\n      height: this.props?.['dialogHeight'] ?? '85%',\n      data: { fieldConfig: this.field.fieldArray.fieldGroup, label: this.field.props?.addLabel??'Add', formState: this.options?.formState, tabularProps: this.field.props,\n        parentModel: this.field.parent?.model\n      },\n      disableClose: true,\n      autoFocus: false\n    });\n\n    dialogRef.afterClosed().subscribe(result => {\n      if (result) {\n        result.id = this.generateRandomNumber();\n        if(this.options.formState.showOldValues) {\n          result.addedNewRow = true;\n        }\n        if (this.props?.['isSequentialNumGenerationRequired']) {\n          result.sequentialNumberId = `000${this.generateSequentialIdNumber(this.field.parent?.model)}`;\n        }\n        this.addRowToGrid(result);\n      }\n      if (this.field && this.field.props?.['dialogClosed']) {\n        this.field.props?.['dialogClosed'](event, this.field);\n      }\n    });\n\n    dialogRef.componentInstance.saveData.subscribe((data: any) => {\n      data.id = this.generateRandomNumber();\n      if(this.options.formState.showOldValues) {\n        data.addedNewRow = true;\n      }\n      updateModel(this.field.parent?.model, this.field.key, data, 'push');\n      this.addRowToGrid(data);\n    });\n  }\n\n  generateRandomNumber(): number {\n    return Math.floor(1000 + Math.random() * 9000);\n  }\n\n  addRowToGrid(data: any): void {\n    if (this.rowData.length > this.getMaxRows()) {\n      this.snackBar.open(`Cannot add more than ${this.getMaxRows()} rows`, 'Close', {\n        duration: 3000\n      });\n      return;\n    }\n    for (const key in data) {\n      if (data[key] instanceof Object) {\n        if (data[key]?.fileName) {\n          data[`${key}FileName`] = data[key].fileName;\n        }\n      }\n    }\n    if (this.columnDefs.length === 0) {\n      this.columnDefs = [\n        {\n          headerCheckboxSelection: true,\n          checkboxSelection: true,\n          headerName: '',\n          width: 40,\n          maxWidth: 40,\n          resizable:false,\n          filter: false\n        },\n        ...Object.keys(data)\n          .filter(key => {\n            const fieldConfig = this.findFieldConfigByKey(this.field.fieldGroup || [], key);\n            return key !== 'id' && fieldConfig?.type !== 'mu-button';\n          })\n          .map(key => {\n            const label = this.findLabelInNestedFields(this.field.fieldGroup || [], key);\n            return {\n              field: key,\n              headerName: label\n            };\n          })\n      ];\n    }\n    if(this.rowData.find((row: any) => row.id == data.id)) {\n      this.rowData = [...this.rowData]\n    } else {\n      this.rowData = [...this.rowData, data];\n    }\n    this.add(null, data);\n    this.cd.detectChanges();\n    this.snackBar.open(\n      this.translateService.instant('MNL_TABULAR_FORM.DATA_ADDED_SUCCESSFULLY'),\n      'Close',\n      {\n        duration: 0,\n      }\n    );\n    this.gridApi.selectAll();\n    this.gridApi.deselectAll();\n  }\n\n  findFieldConfigByKey(fieldConfigs: any[], key: string): any {\n    for (const field of fieldConfigs) {\n      if (field.key === key) {\n        return field;\n      }\n      if (field.fieldGroup) {\n        const foundField = this.findFieldConfigByKey(field.fieldGroup, key);\n        if (foundField) {\n          return foundField;\n        }\n      }\n    }\n    return null;\n  }\n\n  getMaxRows(): number {\n    return this.to['maxRows'];\n  }\n\n  findLabelInNestedFields(fieldConfigs: any[], key: string): string {\n    for (const field of fieldConfigs) {\n      if (field.key === key) {\n        return field.props?.label || key;\n      }\n      if (field.fieldGroup) {\n        const label = this.findLabelInNestedFields(field.fieldGroup, key);\n        if (label) {\n          return label;\n        }\n      }\n    }\n    return key;\n  }\n\n  removeSelectedRows() {\n    if(this.options.formState.showOldValues) {\n      const selectedData = this.gridApi.getSelectedNodes().map(node => node.data);\n      if(!selectedData.every(data => data.addedNewRow)) {\n        this.snackBar.open(\n          this.translateService.instant(\n            'MNL_TABULAR_FORM.NO_ACCESS_TO_DELETE_OLD_RECORDS'\n          ),\n          'Ok',\n          {\n            duration: 0,\n            panelClass: ['error-snackbar'],\n          }\n        );\n        return;\n      }\n    }\n    const dialog = this.dialog.open(ConfirmationDialogComponent, {\n      width: '50%',\n      height: '28%',\n      data: { title: 'Are you sure to delete?'}\n    });\n    dialog.afterClosed().subscribe((res) => {\n      if(res) {\n        const selectedNodes = this.gridApi.getSelectedNodes();\n        const selectedData = selectedNodes.map(node => node.data);\n        this.rowData = this.rowData.filter(row => !selectedData.includes(row));\n        updateModel(this.field.parent?.model, this.field.key, this.rowData, 'assign')\n    \n        this.gridApi.applyTransaction({\n          remove: selectedData\n        });\n        this.updateSelectedRowCount();\n      }\n    });\n  }\n\n  onRowSelected(event: RowSelectedEvent): void {\n    this.updateSelectedRowCount();\n  }\n\n  updateSelectedRowCount(): void {\n    this.selectedRowCount = this.gridApi.getSelectedNodes().length;\n  }\n\n  translateLabels(\n    columnDefs: any[]\n  ): any[] {\n    return columnDefs.map((column) => {\n      return {\n        ...column,\n        headerName: this.translateService.instant(column.headerName)\n      }\n    })\n  }\n\n  editDialog() {\n    const selectedNodes = this.gridApi.getSelectedNodes();\n    const selectedData = selectedNodes.map(node => node.data);\n    if (selectedData?.length > 1) {\n      this.snackBar.open(\n        this.translateService.instant(\n          'MNL_TABULAR_FORM.MULTI_ROW_EDIT_ERROR'\n        )\n        , 'Ok', {\n        duration: 5000,\n      });\n      return;\n    }\n    if (this.field && this.field.props?.['dialogOpened']) {\n      this.field.props?.['dialogOpened'](event, this.field);\n    }\n    const dialogRef = this.dialog.open(TabularFormDialogComponent, {\n      width: this.props?.['dialogWidth'] ?? '75%',\n      maxWidth: '100%',\n      height: this.props?.['dialogHeight'] ?? '85%',\n      data: { fieldConfig: this.field.fieldArray.fieldGroup, label: this.field.props?.editLabel??'Edit', formState: this.options?.formState, selectedRowData: selectedData[0], tabularProps: this.field.props, parentModel: this.field.parent?.model },\n      disableClose: true,\n      autoFocus: false\n    });\n    dialogRef.afterClosed().subscribe(result => {\n      if (result) {\n        this.rowData = this.rowData.map((rowRecord) => {\n          if (rowRecord?.['id'] === result?.id) {\n            if(this.options.formState?.showOldValues) {\n              const oldRowValue = this.oldValue.find((record: any) => record.id === result?.id);\n              if(oldRowValue) {\n                oldRowValue['isChanged'] = false;\n                result['isChanged'] = false;\n                const mergdOld = {\n                  ...result,\n                  ...oldRowValue\n                }\n                const eq = deepEqual(mergdOld, result);\n                rowRecord['isChanged'] = !eq;\n                result['isChanged'] = !eq;\n              }\n            }\n            const updatedRow = {\n              ...rowRecord,\n              ...result,\n            };\n            Object.keys(updatedRow).forEach(key => {\n              if (updatedRow[key] instanceof Object) {\n                if (updatedRow[key]?.fileName) {\n                  updatedRow[`${key}FileName`] = updatedRow[key].fileName;\n                }\n              }\n            });\n            return updatedRow;\n          }\n          return rowRecord;\n        });\n        updateModel(this.field.parent?.model, this.field.key, this.rowData, 'assign');\n        this.cd.detectChanges();\n      }\n      this.updateSelectedRowCount();\n      this.cd.detectChanges();\n      if (this.field && this.field.props?.['tabularDataEdited']) {\n        this.field.props?.['tabularDataEdited'](event, this.field);\n      }\n      if (this.field && this.field.props?.['dialogClosed']) {\n        this.field.props?.['dialogClosed'](event, this.field);\n      }\n    });\n  }\n\n  formatDate(date: string): string {\n    if(date) {\n      const d = new Date(date);\n      const day = String(d.getDate()).padStart(2, '0');\n      const monthNames = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n      const month = monthNames[d.getMonth()];\n      const year = d.getFullYear();\n      return `${day}-${month}-${year}`;\n    } else {\n      return '';\n    }\n  }\n\n  onFilenameClick(params: any) {\n    const uploadedFileNameKey = Object.keys(params.data).filter(key => key.endsWith('FileName'));\n    const uploadedFileObjectKey = uploadedFileNameKey[0]?.replace(/FileName$/, \"\");\n    if(uploadedFileObjectKey) this.viewFile(params.data[uploadedFileObjectKey]);\n  }\n\n  viewFile(element:any) {\n      const dialogRef = this.dialog.open(ViewFileDialogComponent, {\n        width: '75%',\n        maxWidth: '95%',\n        height: '85%',\n        data: element\n      });\n  }\n\n  showChangedValues(params: any) {\n    const formState = {\n      ...this.options.formState,\n      userRoles: []\n    }\n    this.dialog.open(TabularFormDialogComponent, {\n      width: this.props?.['dialogWidth'] ?? '75%',\n      maxWidth: '95%',\n      height: '85%',\n      data: { fieldConfig: this.field.fieldArray.fieldGroup, label: this.field.props?.viewLabel??'View', formState: formState, selectedRowData: params.data, hideUpdateBtn: true, parentModel: this.field.parent?.model, tabularProps: this.field.props },\n      disableClose: true\n    });\n  }\n\n  generateSequentialIdNumber(parentModel: any) {\n    if (parentModel?.[this.props?.['parenetModelKeyToGenerateSequentialNumber']]?.length) {\n      const latestRecordIdNumber = parentModel?.[this.props?.['parenetModelKeyToGenerateSequentialNumber']]?.sort((a: { sequentialNumberId: number; }, b: { sequentialNumberId: number; }) => +(b?.sequentialNumberId) - +(a?.sequentialNumberId))?.find((parenData: { sequentialNumberId: any; }) => +(parenData?.sequentialNumberId));\n      return +(latestRecordIdNumber?.sequentialNumberId) + 1;\n    }\n    return 1;\n  }\n\n  getRowStyle = (params: any) => {\n    if(this.options.formState.showOldValues) {\n      if (params.data?.isChanged) {\n        return { backgroundColor: '#ffcccc' };\n      }\n      if (params.data?.addedNewRow) {\n        return { backgroundColor: '#F0EBAD80' };\n      }\n    }\n    return undefined;\n  };\n}\n\nfunction updateModel(obj: any, targetKey: any, newValue: any, action: string) {\n  for (const key in obj) {\n    if (key === targetKey) {\n      if (action === 'push') {\n        if (Array.isArray(obj[key])) {\n          obj[key].push(newValue);\n        } else if (obj[key] !== undefined) {\n          obj[key] = [obj[key], newValue];\n        } else {\n          obj[key] = [newValue];\n        }\n      } else {\n        obj[key] = newValue;\n      }\n\n      return true;\n    }\n    if (typeof obj[key] === 'object' && obj[key] !== null) {\n      const result = updateModel(obj[key], targetKey, newValue, action);\n      if (result) return true;\n    }\n  }\n  return false;\n}\n\nfunction findNestedKey(obj: any, targetKey: any): any {\n  for (const key in obj) {\n    if (key === targetKey) return obj[key];\n    if (typeof obj[key] === 'object') {\n      const result = findNestedKey(obj[key], targetKey);\n      if (result) return result;\n    }\n  }\n  return undefined;\n}"]}