@muraai/mnl-form 0.0.1-alpha-32ca3fa → 0.0.1-alpha-11e96eb
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/README.md +5 -5
- package/fesm2022/muraai-mnl-form.mjs +152 -145
- package/fesm2022/muraai-mnl-form.mjs.map +1 -1
- package/lib/{formly-lib/formly-lib.component.d.ts → mnl-form/mnl-form.component.d.ts} +3 -3
- package/lib/types/upload-file.d.ts +1 -1
- package/lib/workflow-status/ workflow-status.module.d.ts +8 -8
- package/lib/workflow-status/workflow-status.component.d.ts +1 -1
- package/package.json +4 -5
- package/public-api.d.ts +2 -2
- package/esm2022/lib/confirmation-dialog/confirmation-dialog.component.mjs +0 -34
- package/esm2022/lib/formly-lib/formly-lib.component.mjs +0 -199
- package/esm2022/lib/formly-lib/formly-standalone.module.mjs +0 -155
- package/esm2022/lib/models/custom-form-field.model.mjs +0 -2
- package/esm2022/lib/models/workflow-status.model.mjs +0 -2
- package/esm2022/lib/services/graphql.service.mjs +0 -30
- package/esm2022/lib/services/scoring.service.mjs +0 -103
- package/esm2022/lib/types/action-button-renderer.component.mjs +0 -59
- package/esm2022/lib/types/autocomplete-type.component.mjs +0 -68
- package/esm2022/lib/types/button.type.mjs +0 -72
- package/esm2022/lib/types/comments.type.mjs +0 -102
- package/esm2022/lib/types/country-code-input.type.mjs +0 -181
- package/esm2022/lib/types/custom-date.type.mjs +0 -20
- package/esm2022/lib/types/custom-input.component.mjs +0 -62
- package/esm2022/lib/types/date-format.type.mjs +0 -196
- package/esm2022/lib/types/expansion-panel.types.mjs +0 -85
- package/esm2022/lib/types/formly-field-panel.type.mjs +0 -70
- package/esm2022/lib/types/grid-actionable.type.mjs +0 -197
- package/esm2022/lib/types/grid-formly-cell.component.mjs +0 -42
- package/esm2022/lib/types/grid.type.mjs +0 -125
- package/esm2022/lib/types/input.type.mjs +0 -43
- package/esm2022/lib/types/mu-helper-text.type.mjs +0 -331
- package/esm2022/lib/types/multi-select-autocomplete.mjs +0 -139
- package/esm2022/lib/types/multi-select-checkbox.component.mjs +0 -247
- package/esm2022/lib/types/radio.type.mjs +0 -71
- package/esm2022/lib/types/scrollable-tabs.types.mjs +0 -220
- package/esm2022/lib/types/select-api-auto-complete.component.mjs +0 -111
- package/esm2022/lib/types/select-autocomplete-redefined.component.mjs +0 -142
- package/esm2022/lib/types/select-autocomplete.type.mjs +0 -254
- package/esm2022/lib/types/stepper.type.mjs +0 -268
- package/esm2022/lib/types/table.types.mjs +0 -79
- package/esm2022/lib/types/tabs.types.mjs +0 -293
- package/esm2022/lib/types/tabular-form-dialog.component.mjs +0 -331
- package/esm2022/lib/types/tabular-form.type.mjs +0 -641
- package/esm2022/lib/types/upload-file.mjs +0 -524
- package/esm2022/lib/types/view-file-dialog.component.mjs +0 -90
- package/esm2022/lib/utils/formly.utils.mjs +0 -105
- package/esm2022/lib/validators/custom-email-validator.mjs +0 -18
- package/esm2022/lib/validators/ein-validators.mjs +0 -11
- package/esm2022/lib/validators/gst-validator.mjs +0 -11
- package/esm2022/lib/validators/normal-email-validator.mjs +0 -17
- package/esm2022/lib/validators/npi-validator.mjs +0 -11
- package/esm2022/lib/validators/pan-validator.mjs +0 -11
- package/esm2022/lib/validators/phone-number-validator.mjs +0 -22
- package/esm2022/lib/validators/select-validator.mjs +0 -7
- package/esm2022/lib/validators/tinSsn-validator.mjs +0 -12
- package/esm2022/lib/workflow-status/ workflow-status.module.mjs +0 -52
- package/esm2022/lib/workflow-status/workflow-status.component.mjs +0 -70
- package/esm2022/lib/wrappers/form-field-description-wrapper.component.mjs +0 -44
- package/esm2022/lib/wrappers/form-field-wrapper.component.mjs +0 -34
- package/esm2022/lib/wrappers/formly-wrapper-with-old-value.component.mjs +0 -140
- package/esm2022/lib/wrappers/prefix-suffix-wrapper.component.mjs +0 -95
- package/esm2022/lib/wrappers/prefix-sufix-extension.component.mjs +0 -9
- package/esm2022/muraai-mnl-form.mjs +0 -5
- package/esm2022/public-api.mjs +0 -12
- /package/lib/{formly-lib/formly-standalone.module.d.ts → mnl-form/mnl-form-standalone.module.d.ts} +0 -0
|
@@ -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":["../../../../../../projects/form-lib/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}"]}
|