@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,331 +0,0 @@
|
|
|
1
|
-
import { Breakpoints } from '@angular/cdk/layout';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { Component, DestroyRef, EventEmitter, inject, Inject, Output } from '@angular/core';
|
|
4
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
|
-
import { FormGroup, ReactiveFormsModule } from '@angular/forms';
|
|
6
|
-
import { MatButtonModule } from '@angular/material/button';
|
|
7
|
-
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
8
|
-
import { MAT_DIALOG_DATA, MatDialogModule } from '@angular/material/dialog';
|
|
9
|
-
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
10
|
-
import { MatInputModule } from '@angular/material/input';
|
|
11
|
-
import { MatRadioModule } from '@angular/material/radio';
|
|
12
|
-
import { MatSelectModule } from '@angular/material/select';
|
|
13
|
-
import { FormlyModule } from '@ngx-formly/core';
|
|
14
|
-
import { TranslateModule } from '@ngx-translate/core';
|
|
15
|
-
import { NgxSpinnerModule } from 'ngx-spinner';
|
|
16
|
-
import { forkJoin, of, take } from 'rxjs';
|
|
17
|
-
import { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component';
|
|
18
|
-
import * as i0 from "@angular/core";
|
|
19
|
-
import * as i1 from "@angular/material/dialog";
|
|
20
|
-
import * as i2 from "@ngx-formly/core";
|
|
21
|
-
import * as i3 from "@ngx-translate/core";
|
|
22
|
-
import * as i4 from "@angular/cdk/layout";
|
|
23
|
-
import * as i5 from "@angular/common";
|
|
24
|
-
import * as i6 from "@angular/material/button";
|
|
25
|
-
import * as i7 from "ngx-spinner";
|
|
26
|
-
export class TabularFormDialogComponent {
|
|
27
|
-
constructor(dialogRef, data, formlyBuilder, translateService, matDialog, hostElement, breakpointObserver) {
|
|
28
|
-
this.dialogRef = dialogRef;
|
|
29
|
-
this.data = data;
|
|
30
|
-
this.formlyBuilder = formlyBuilder;
|
|
31
|
-
this.translateService = translateService;
|
|
32
|
-
this.matDialog = matDialog;
|
|
33
|
-
this.hostElement = hostElement;
|
|
34
|
-
this.breakpointObserver = breakpointObserver;
|
|
35
|
-
this.form = new FormGroup({});
|
|
36
|
-
this.dialogLabel = '';
|
|
37
|
-
this.saveData = new EventEmitter();
|
|
38
|
-
this.destroyRef = inject(DestroyRef);
|
|
39
|
-
this.isMobileDevice = false;
|
|
40
|
-
this.breakpointObserver?.observe([Breakpoints.Handset]).pipe(takeUntilDestroyed(this.destroyRef)).subscribe((result) => {
|
|
41
|
-
this.isMobileDevice = result?.matches;
|
|
42
|
-
});
|
|
43
|
-
this.fieldConfig = data.fieldConfig;
|
|
44
|
-
this.selectedRowData = data.selectedRowData;
|
|
45
|
-
if (data?.selectedRowData) {
|
|
46
|
-
this.model = data?.selectedRowData;
|
|
47
|
-
}
|
|
48
|
-
this.propsOfDialog = data.tabularProps;
|
|
49
|
-
this.dialogLabel = data.label;
|
|
50
|
-
this.fields = this.translateFormConfig(data.fieldConfig);
|
|
51
|
-
this.options = {
|
|
52
|
-
...this.options,
|
|
53
|
-
formState: data?.formState
|
|
54
|
-
};
|
|
55
|
-
this.parentModel = data?.parentModel;
|
|
56
|
-
this.formlyBuilder.buildForm(this.form, this.fields, this.model, this.options);
|
|
57
|
-
this.updateDependentFieldsFullName(this.fields);
|
|
58
|
-
}
|
|
59
|
-
resetForm() {
|
|
60
|
-
this.form.reset();
|
|
61
|
-
}
|
|
62
|
-
onSave() {
|
|
63
|
-
if (this.form.valid) {
|
|
64
|
-
if (this.fields[0]?.confirmationDialogProps?.length) {
|
|
65
|
-
const confirmationDialogs = this.fields[0].confirmationDialogProps
|
|
66
|
-
.filter((confirmationDialogProp) => confirmationDialogProp?.enableConfirmation)
|
|
67
|
-
.map((confirmationDialogProp) => {
|
|
68
|
-
if (!confirmationDialogProp?.enableConfirmationDialogForRoles?.length ||
|
|
69
|
-
confirmationDialogProp?.enableConfirmationDialogForRoles?.some((role) => this.options?.formState?.userRoles?.includes(role))) {
|
|
70
|
-
if (confirmationDialogProp?.showForChangeRequestOnly) {
|
|
71
|
-
if (this.options.formState.showOldValues) {
|
|
72
|
-
const dialogRef = this.matDialog.open(ConfirmationDialogComponent, {
|
|
73
|
-
minWidth: confirmationDialogProp?.['minWidth'] ?? '40%',
|
|
74
|
-
maxWidth: confirmationDialogProp?.['maxWidth'] ?? '100%',
|
|
75
|
-
minHeight: confirmationDialogProp?.['minHeight'] ?? '30%',
|
|
76
|
-
maxHeight: confirmationDialogProp?.['maxHeight'] ?? '40%',
|
|
77
|
-
data: {
|
|
78
|
-
title: this.translateService.instant(confirmationDialogProp?.data?.title),
|
|
79
|
-
showOk: true
|
|
80
|
-
},
|
|
81
|
-
disableClose: true
|
|
82
|
-
});
|
|
83
|
-
return dialogRef.afterClosed().pipe(take(1));
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
const dialogRef = this.matDialog.open(ConfirmationDialogComponent, {
|
|
88
|
-
width: confirmationDialogProp?.['width'] ?? '30%',
|
|
89
|
-
minHeight: confirmationDialogProp?.['minHeight'] ?? '30%',
|
|
90
|
-
maxHeight: confirmationDialogProp?.['maxHeight'] ?? '40%',
|
|
91
|
-
data: {
|
|
92
|
-
title: this.translateService.instant(confirmationDialogProp?.data?.title),
|
|
93
|
-
showOk: true
|
|
94
|
-
},
|
|
95
|
-
disableClose: true
|
|
96
|
-
});
|
|
97
|
-
return dialogRef.afterClosed().pipe(take(1));
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
return of(true);
|
|
101
|
-
});
|
|
102
|
-
if (confirmationDialogs.length) {
|
|
103
|
-
forkJoin(confirmationDialogs)
|
|
104
|
-
.pipe(take(1))
|
|
105
|
-
.subscribe(() => {
|
|
106
|
-
this.dialogRef.close({
|
|
107
|
-
...this.model,
|
|
108
|
-
...this.form.value,
|
|
109
|
-
});
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
else {
|
|
113
|
-
this.dialogRef.close({
|
|
114
|
-
...this.model,
|
|
115
|
-
...this.form.value,
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
else {
|
|
120
|
-
this.dialogRef.close({
|
|
121
|
-
...this.model,
|
|
122
|
-
...this.form.value,
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
onCancel() {
|
|
128
|
-
this.dialogRef.close();
|
|
129
|
-
}
|
|
130
|
-
onSaveAddNew() {
|
|
131
|
-
if (this.form.valid) {
|
|
132
|
-
const dataToSave = {
|
|
133
|
-
...this.model,
|
|
134
|
-
...this.form.getRawValue(),
|
|
135
|
-
};
|
|
136
|
-
if (this.fields[0]?.confirmationDialogProps?.length) {
|
|
137
|
-
const confirmationDialogs = this.fields[0].confirmationDialogProps
|
|
138
|
-
.filter((confirmationDialogProp) => confirmationDialogProp?.enableConfirmation)
|
|
139
|
-
.map((confirmationDialogProp) => {
|
|
140
|
-
if (!confirmationDialogProp?.enableConfirmationDialogForRoles
|
|
141
|
-
?.length ||
|
|
142
|
-
confirmationDialogProp?.enableConfirmationDialogForRoles?.some((role) => this.options?.formState?.userRoles?.includes(role))) {
|
|
143
|
-
if (confirmationDialogProp?.showForChangeRequestOnly) {
|
|
144
|
-
if (this.options.formState.showOldValues) {
|
|
145
|
-
const dialogRef = this.matDialog.open(ConfirmationDialogComponent, {
|
|
146
|
-
width: confirmationDialogProp?.['width'] ?? '30%',
|
|
147
|
-
minHeight: confirmationDialogProp?.['minHeight'] ?? '30%',
|
|
148
|
-
maxHeight: confirmationDialogProp?.['maxHeight'] ?? '40%',
|
|
149
|
-
data: {
|
|
150
|
-
title: this.translateService.instant(confirmationDialogProp?.data?.title),
|
|
151
|
-
showOk: true,
|
|
152
|
-
},
|
|
153
|
-
disableClose: true,
|
|
154
|
-
});
|
|
155
|
-
return dialogRef.afterClosed().pipe(take(1));
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
else {
|
|
159
|
-
const dialogRef = this.matDialog.open(ConfirmationDialogComponent, {
|
|
160
|
-
width: confirmationDialogProp?.['width'] ?? '30%',
|
|
161
|
-
minHeight: confirmationDialogProp?.['minHeight'] ?? '30%',
|
|
162
|
-
maxHeight: confirmationDialogProp?.['maxHeight'] ?? '40%',
|
|
163
|
-
data: {
|
|
164
|
-
title: this.translateService.instant(confirmationDialogProp?.data?.title),
|
|
165
|
-
showOk: true,
|
|
166
|
-
},
|
|
167
|
-
disableClose: true,
|
|
168
|
-
});
|
|
169
|
-
return dialogRef.afterClosed().pipe(take(1));
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
return of(true);
|
|
173
|
-
});
|
|
174
|
-
if (confirmationDialogs.length) {
|
|
175
|
-
forkJoin(confirmationDialogs)
|
|
176
|
-
.pipe(take(1))
|
|
177
|
-
.subscribe(() => {
|
|
178
|
-
if (this.propsOfDialog?.['isSequentialNumGenerationRequired']) {
|
|
179
|
-
dataToSave.sequentialNumberId = `000${this.generateSequentialIdNumber(this.parentModel)}`;
|
|
180
|
-
}
|
|
181
|
-
this.saveData.emit(dataToSave);
|
|
182
|
-
this.resetForm();
|
|
183
|
-
});
|
|
184
|
-
}
|
|
185
|
-
else {
|
|
186
|
-
if (this.propsOfDialog?.['isSequentialNumGenerationRequired']) {
|
|
187
|
-
dataToSave.sequentialNumberId = `000${this.generateSequentialIdNumber(this.parentModel)}`;
|
|
188
|
-
}
|
|
189
|
-
this.saveData.emit(dataToSave);
|
|
190
|
-
this.resetForm();
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
else {
|
|
194
|
-
if (this.propsOfDialog?.['isSequentialNumGenerationRequired']) {
|
|
195
|
-
dataToSave.sequentialNumberId = `000${this.generateSequentialIdNumber(this.parentModel)}`;
|
|
196
|
-
}
|
|
197
|
-
this.saveData.emit(dataToSave);
|
|
198
|
-
this.resetForm();
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
translateFormConfig(config) {
|
|
203
|
-
return config.map((field) => {
|
|
204
|
-
if (field.props?.label) {
|
|
205
|
-
field.expressions = {
|
|
206
|
-
...field.expressions,
|
|
207
|
-
'props.label': this.translateService.stream(field.props.label || ''),
|
|
208
|
-
'props.tooltip': this.translateService.stream(field.props.label || ''),
|
|
209
|
-
};
|
|
210
|
-
}
|
|
211
|
-
if (field.props?.placeholder) {
|
|
212
|
-
field.expressions = {
|
|
213
|
-
...field.expressions,
|
|
214
|
-
'props.placeholder': this.translateService.stream(field.props.placeholder || ''),
|
|
215
|
-
};
|
|
216
|
-
}
|
|
217
|
-
if (field.fieldGroup) {
|
|
218
|
-
this.translateFormConfig(field.fieldGroup);
|
|
219
|
-
}
|
|
220
|
-
return field;
|
|
221
|
-
});
|
|
222
|
-
}
|
|
223
|
-
onModelChange(event) {
|
|
224
|
-
this.model = event;
|
|
225
|
-
this.subscribeToDependencies(this.fields, this.form, this.model);
|
|
226
|
-
}
|
|
227
|
-
subscribeToDependencies(fields, form, vendorModel) {
|
|
228
|
-
fields.forEach((field) => {
|
|
229
|
-
if (field.fieldGroup) {
|
|
230
|
-
this.subscribeToDependencies(field.fieldGroup, form, vendorModel);
|
|
231
|
-
}
|
|
232
|
-
});
|
|
233
|
-
}
|
|
234
|
-
updateDependentFieldsFullName(fields) {
|
|
235
|
-
fields.forEach((field) => {
|
|
236
|
-
if (field.formControl && field.updateTabularField) {
|
|
237
|
-
field.formControl.valueChanges.subscribe((value) => {
|
|
238
|
-
this.updateLabelValueForField(field, value);
|
|
239
|
-
});
|
|
240
|
-
}
|
|
241
|
-
if (field.fieldGroup) {
|
|
242
|
-
this.updateDependentFieldsFullName(field.fieldGroup);
|
|
243
|
-
}
|
|
244
|
-
});
|
|
245
|
-
}
|
|
246
|
-
updateLabelValueForField(field, value) {
|
|
247
|
-
const options$ = field.props?.options;
|
|
248
|
-
if (options$ && typeof options$.subscribe === 'function') {
|
|
249
|
-
options$.subscribe((options) => {
|
|
250
|
-
const updateFieldKey = field.updateTabularField;
|
|
251
|
-
const selectedOption = options.find((option) => option.value === value);
|
|
252
|
-
if (selectedOption) {
|
|
253
|
-
this.model[updateFieldKey] = selectedOption.label;
|
|
254
|
-
}
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
isFilesUploaded() {
|
|
259
|
-
return true;
|
|
260
|
-
}
|
|
261
|
-
generateSequentialIdNumber(parentModel) {
|
|
262
|
-
if (parentModel?.[this.propsOfDialog?.['parenetModelKeyToGenerateSequentialNumber']]?.length) {
|
|
263
|
-
const latestRecordIdNumber = parentModel?.[this.propsOfDialog?.['parenetModelKeyToGenerateSequentialNumber']]?.sort((a, b) => +(b?.sequentialNumberId) - +(a?.sequentialNumberId))?.find((parenData) => +(parenData?.sequentialNumberId));
|
|
264
|
-
return +(latestRecordIdNumber?.sequentialNumberId) + 1;
|
|
265
|
-
}
|
|
266
|
-
return 1;
|
|
267
|
-
}
|
|
268
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TabularFormDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.FormlyFormBuilder }, { token: i3.TranslateService }, { token: i1.MatDialog }, { token: i0.ElementRef }, { token: i4.BreakpointObserver }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
269
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: TabularFormDialogComponent, isStandalone: true, selector: "mu-app-add-data-dialog", outputs: { saveData: "saveData" }, ngImport: i0, template: `
|
|
270
|
-
<h1 mat-dialog-title>{{ dialogLabel | translate}}</h1>
|
|
271
|
-
<div mat-dialog-content class="min-h-max !pt-1 !flex">
|
|
272
|
-
<formly-form
|
|
273
|
-
[ngStyle]="{'width': (propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice) ? '50%' : ''}"
|
|
274
|
-
[form]="form"
|
|
275
|
-
[fields]="fields"
|
|
276
|
-
[model]="model"
|
|
277
|
-
[options]="options"
|
|
278
|
-
(modelChange)="onModelChange($event)"
|
|
279
|
-
></formly-form>
|
|
280
|
-
<iframe id="dialogIframe" *ngIf="propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice" [ngStyle]="{'width': (propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice) ? '50%' : ''}" frameborder="0"></iframe>
|
|
281
|
-
</div>
|
|
282
|
-
<div mat-dialog-actions>
|
|
283
|
-
<button mat-button (click)="onCancel()">{{'TABULAR_FORM_DIALOG.CANCEL' | translate}}</button>
|
|
284
|
-
<button mat-button *ngIf="!selectedRowData && !propsOfDialog.hideSaveAndAddNew" (click)="onSaveAddNew()" [disabled]="form.invalid || !isFilesUploaded()">{{'TABULAR_FORM_DIALOG.SAVE_AND_NEW' | translate}}</button>
|
|
285
|
-
<button mat-button *ngIf="!selectedRowData" (click)="onSave()" [disabled]="form.invalid || !isFilesUploaded()">{{'TABULAR_FORM_DIALOG.ADD' | translate}}</button>
|
|
286
|
-
<button mat-button *ngIf="selectedRowData && !data.hideUpdateBtn" (click)="onSave()" [disabled]="form.invalid || !isFilesUploaded()">{{'TABULAR_FORM_DIALOG.EDIT' | translate}}</button>
|
|
287
|
-
</div>
|
|
288
|
-
<ngx-spinner name="tabular-dialog" bdColor="rgba(0, 0, 0, 0.2)" size="medium" color="#fff" template="<img src='assets/images/lupin-icongif.gif' style='height: 70px !important;'/>"
|
|
289
|
-
[fullScreen]="true">
|
|
290
|
-
</ngx-spinner>
|
|
291
|
-
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatInputModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: MatRadioModule }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i2.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { 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: "ngmodule", type: NgxSpinnerModule }, { kind: "component", type: i7.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["bdColor", "size", "color", "type", "fullScreen", "name", "zIndex", "template", "showSpinner", "disableAnimation"] }] }); }
|
|
292
|
-
}
|
|
293
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TabularFormDialogComponent, decorators: [{
|
|
294
|
-
type: Component,
|
|
295
|
-
args: [{
|
|
296
|
-
selector: 'mu-app-add-data-dialog',
|
|
297
|
-
standalone: true,
|
|
298
|
-
imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, MatSelectModule, MatRadioModule, MatCheckboxModule,
|
|
299
|
-
MatDialogModule, FormlyModule, TranslateModule, MatButtonModule, NgxSpinnerModule
|
|
300
|
-
],
|
|
301
|
-
template: `
|
|
302
|
-
<h1 mat-dialog-title>{{ dialogLabel | translate}}</h1>
|
|
303
|
-
<div mat-dialog-content class="min-h-max !pt-1 !flex">
|
|
304
|
-
<formly-form
|
|
305
|
-
[ngStyle]="{'width': (propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice) ? '50%' : ''}"
|
|
306
|
-
[form]="form"
|
|
307
|
-
[fields]="fields"
|
|
308
|
-
[model]="model"
|
|
309
|
-
[options]="options"
|
|
310
|
-
(modelChange)="onModelChange($event)"
|
|
311
|
-
></formly-form>
|
|
312
|
-
<iframe id="dialogIframe" *ngIf="propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice" [ngStyle]="{'width': (propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice) ? '50%' : ''}" frameborder="0"></iframe>
|
|
313
|
-
</div>
|
|
314
|
-
<div mat-dialog-actions>
|
|
315
|
-
<button mat-button (click)="onCancel()">{{'TABULAR_FORM_DIALOG.CANCEL' | translate}}</button>
|
|
316
|
-
<button mat-button *ngIf="!selectedRowData && !propsOfDialog.hideSaveAndAddNew" (click)="onSaveAddNew()" [disabled]="form.invalid || !isFilesUploaded()">{{'TABULAR_FORM_DIALOG.SAVE_AND_NEW' | translate}}</button>
|
|
317
|
-
<button mat-button *ngIf="!selectedRowData" (click)="onSave()" [disabled]="form.invalid || !isFilesUploaded()">{{'TABULAR_FORM_DIALOG.ADD' | translate}}</button>
|
|
318
|
-
<button mat-button *ngIf="selectedRowData && !data.hideUpdateBtn" (click)="onSave()" [disabled]="form.invalid || !isFilesUploaded()">{{'TABULAR_FORM_DIALOG.EDIT' | translate}}</button>
|
|
319
|
-
</div>
|
|
320
|
-
<ngx-spinner name="tabular-dialog" bdColor="rgba(0, 0, 0, 0.2)" size="medium" color="#fff" template="<img src='assets/images/lupin-icongif.gif' style='height: 70px !important;'/>"
|
|
321
|
-
[fullScreen]="true">
|
|
322
|
-
</ngx-spinner>
|
|
323
|
-
`
|
|
324
|
-
}]
|
|
325
|
-
}], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
326
|
-
type: Inject,
|
|
327
|
-
args: [MAT_DIALOG_DATA]
|
|
328
|
-
}] }, { type: i2.FormlyFormBuilder }, { type: i3.TranslateService }, { type: i1.MatDialog }, { type: i0.ElementRef }, { type: i4.BreakpointObserver }], propDecorators: { saveData: [{
|
|
329
|
-
type: Output
|
|
330
|
-
}] } });
|
|
331
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabular-form-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/form-lib/src/lib/types/tabular-form-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\nimport { CommonModule } from '@angular/common';\nimport { Component, DestroyRef, ElementRef, EventEmitter, inject, Inject, Output } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatRadioModule } from '@angular/material/radio';\nimport { MatSelectModule } from '@angular/material/select';\nimport { FormlyFormBuilder, FormlyModule } from '@ngx-formly/core';\nimport { TranslateModule, TranslateService } from '@ngx-translate/core';\nimport { NgxSpinnerModule } from 'ngx-spinner';\nimport { forkJoin, of, take } from 'rxjs';\nimport { ConfirmationDialogComponent } from '../confirmation-dialog/confirmation-dialog.component';\nimport { CustomFormlyFieldConfig } from '../models/custom-form-field.model';\n\n@Component({\n  selector: 'mu-app-add-data-dialog',\n  standalone: true,\n  imports: [CommonModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, MatSelectModule, MatRadioModule, MatCheckboxModule,\n    MatDialogModule, FormlyModule, TranslateModule, MatButtonModule, NgxSpinnerModule\n  ],\n  template: `\n    <h1 mat-dialog-title>{{ dialogLabel | translate}}</h1>\n    <div mat-dialog-content class=\"min-h-max !pt-1 !flex\">\n      <formly-form\n        [ngStyle]=\"{'width': (propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice) ? '50%' : ''}\"\n                [form]=\"form\"\n                [fields]=\"fields\"\n                [model]=\"model\"\n                [options]=\"options\"\n                (modelChange)=\"onModelChange($event)\"\n        ></formly-form>\n        <iframe id=\"dialogIframe\" *ngIf=\"propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice\" [ngStyle]=\"{'width': (propsOfDialog && propsOfDialog?.viewDocSideBySide && !isMobileDevice) ? '50%' : ''}\" frameborder=\"0\"></iframe>\n    </div>\n    <div mat-dialog-actions>\n      <button mat-button (click)=\"onCancel()\">{{'TABULAR_FORM_DIALOG.CANCEL' | translate}}</button>\n      <button mat-button *ngIf=\"!selectedRowData && !propsOfDialog.hideSaveAndAddNew\" (click)=\"onSaveAddNew()\" [disabled]=\"form.invalid || !isFilesUploaded()\">{{'TABULAR_FORM_DIALOG.SAVE_AND_NEW' | translate}}</button>\n      <button mat-button *ngIf=\"!selectedRowData\" (click)=\"onSave()\" [disabled]=\"form.invalid || !isFilesUploaded()\">{{'TABULAR_FORM_DIALOG.ADD' | translate}}</button>\n      <button mat-button *ngIf=\"selectedRowData && !data.hideUpdateBtn\" (click)=\"onSave()\" [disabled]=\"form.invalid || !isFilesUploaded()\">{{'TABULAR_FORM_DIALOG.EDIT' | translate}}</button>\n    </div>\n    <ngx-spinner name=\"tabular-dialog\" bdColor=\"rgba(0, 0, 0, 0.2)\" size=\"medium\" color=\"#fff\" template=\"<img src='assets/images/lupin-icongif.gif' style='height: 70px !important;'/>\"\n      [fullScreen]=\"true\">\n    </ngx-spinner>\n  `\n})\nexport class TabularFormDialogComponent {\n  form = new FormGroup({});\n  fieldConfig: any[];\n  fields!: CustomFormlyFieldConfig[];\n  model: any;\n  options: any;\n  dialogLabel= '';\n  @Output() saveData = new EventEmitter<any>();\n  selectedRowData:any;\n  destroyRef = inject(DestroyRef);\n  propsOfDialog: any;\n  parentModel: any;\n  isMobileDevice = false;\n\n  constructor(\n    public dialogRef: MatDialogRef<TabularFormDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any,\n    private formlyBuilder: FormlyFormBuilder,\n    private translateService: TranslateService,\n    private matDialog: MatDialog,\n    private hostElement: ElementRef,\n    private breakpointObserver: BreakpointObserver,\n  ) {\n    this.breakpointObserver?.observe([Breakpoints.Handset]).pipe(takeUntilDestroyed(this.destroyRef)).subscribe((result) => {\n      this.isMobileDevice = result?.matches;\n    });\n    this.fieldConfig = data.fieldConfig;\n    this.selectedRowData = data.selectedRowData;\n    if (data?.selectedRowData) {\n      this.model = data?.selectedRowData;\n    }\n    this.propsOfDialog = data.tabularProps;\n    this.dialogLabel = data.label;\n    this.fields = this.translateFormConfig(data.fieldConfig);\n    this.options = {\n      ...this.options,\n      formState: data?.formState\n    }\n    this.parentModel = data?.parentModel;\n\n    this.formlyBuilder.buildForm(this.form, this.fields, this.model, this.options);\n    this.updateDependentFieldsFullName(this.fields);\n  }\n\n\n  private resetForm(): void {\n    this.form.reset();\n  }\n\n  onSave(): void {\n    if (this.form.valid) {\n      if (this.fields[0]?.confirmationDialogProps?.length) {\n        const confirmationDialogs = this.fields[0].confirmationDialogProps\n          .filter((confirmationDialogProp: any) => confirmationDialogProp?.enableConfirmation)\n          .map((confirmationDialogProp: any) => {\n            if (\n              !confirmationDialogProp?.enableConfirmationDialogForRoles?.length ||\n              confirmationDialogProp?.enableConfirmationDialogForRoles?.some((role: string) => this.options?.formState?.userRoles?.includes(role))\n            ) {\n              if(confirmationDialogProp?.showForChangeRequestOnly) {\n                if(this.options.formState.showOldValues) {\n                  const dialogRef = this.matDialog.open(ConfirmationDialogComponent, {\n                    minWidth:confirmationDialogProp?.['minWidth'] ?? '40%',\n                    maxWidth: confirmationDialogProp?.['maxWidth'] ?? '100%',\n                    minHeight: confirmationDialogProp?.['minHeight'] ?? '30%',\n                    maxHeight: confirmationDialogProp?.['maxHeight'] ?? '40%',\n                    data: {\n                      title: this.translateService.instant(confirmationDialogProp?.data?.title),\n                      showOk: true\n                    },\n                    disableClose: true\n                  });\n\n                  return dialogRef.afterClosed().pipe(take(1));\n                }\n              } else {\n                const dialogRef = this.matDialog.open(ConfirmationDialogComponent, {\n                  width: confirmationDialogProp?.['width'] ?? '30%',\n                  minHeight: confirmationDialogProp?.['minHeight'] ?? '30%',\n                  maxHeight: confirmationDialogProp?.['maxHeight'] ?? '40%',\n                  data: {\n                    title: this.translateService.instant(confirmationDialogProp?.data?.title),\n                    showOk: true\n                  },\n                  disableClose: true\n                });\n\n                return dialogRef.afterClosed().pipe(take(1));\n              }\n            }\n            return of(true);\n          });\n\n        if (confirmationDialogs.length) {\n          forkJoin(confirmationDialogs)\n            .pipe(take(1))\n            .subscribe(() => {\n              this.dialogRef.close({\n                ...this.model,\n                ...this.form.value,\n              });\n            });\n        } else {\n          this.dialogRef.close({\n            ...this.model,\n            ...this.form.value,\n          });\n        }\n      } else {\n        this.dialogRef.close({\n          ...this.model,\n          ...this.form.value,\n        });\n      }\n    }\n  }\n\n  onCancel(): void {\n    this.dialogRef.close();\n  }\n\n  onSaveAddNew(): void {\n    if (this.form.valid) {\n      const dataToSave = {\n        ...this.model,\n        ...this.form.getRawValue(),\n      };\n\n      if (this.fields[0]?.confirmationDialogProps?.length) {\n        const confirmationDialogs = this.fields[0].confirmationDialogProps\n          .filter(\n            (confirmationDialogProp: any) =>\n              confirmationDialogProp?.enableConfirmation\n          )\n          .map((confirmationDialogProp: any) => {\n            if (\n              !confirmationDialogProp?.enableConfirmationDialogForRoles\n                ?.length ||\n              confirmationDialogProp?.enableConfirmationDialogForRoles?.some(\n                (role: string) =>\n                  this.options?.formState?.userRoles?.includes(role)\n              )\n            ) {\n              if (confirmationDialogProp?.showForChangeRequestOnly) {\n                if (this.options.formState.showOldValues) {\n                  const dialogRef = this.matDialog.open(\n                    ConfirmationDialogComponent,\n                    {\n                      width: confirmationDialogProp?.['width'] ?? '30%',\n                      minHeight: confirmationDialogProp?.['minHeight'] ?? '30%',\n                      maxHeight: confirmationDialogProp?.['maxHeight'] ?? '40%',\n                      data: {\n                        title: this.translateService.instant(\n                          confirmationDialogProp?.data?.title\n                        ),\n                        showOk: true,\n                      },\n                      disableClose: true,\n                    }\n                  );\n\n                  return dialogRef.afterClosed().pipe(take(1));\n                }\n              } else {\n                const dialogRef = this.matDialog.open(\n                  ConfirmationDialogComponent,\n                  {\n                    width: confirmationDialogProp?.['width'] ?? '30%',\n                    minHeight: confirmationDialogProp?.['minHeight'] ?? '30%',\n                    maxHeight: confirmationDialogProp?.['maxHeight'] ?? '40%',\n                    data: {\n                      title: this.translateService.instant(\n                        confirmationDialogProp?.data?.title\n                      ),\n                      showOk: true,\n                    },\n                    disableClose: true,\n                  }\n                );\n\n                return dialogRef.afterClosed().pipe(take(1));\n              }\n            }\n            return of(true);\n          });\n\n        if (confirmationDialogs.length) {\n          forkJoin(confirmationDialogs)\n            .pipe(take(1))\n            .subscribe(() => {\n              if (this.propsOfDialog?.['isSequentialNumGenerationRequired']) {\n                dataToSave.sequentialNumberId = `000${this.generateSequentialIdNumber(\n                  this.parentModel\n                )}`;\n              }\n              this.saveData.emit(dataToSave);\n              this.resetForm();\n            });\n        } else {\n          if (this.propsOfDialog?.['isSequentialNumGenerationRequired']) {\n            dataToSave.sequentialNumberId = `000${this.generateSequentialIdNumber(\n              this.parentModel\n            )}`;\n          }\n          this.saveData.emit(dataToSave);\n          this.resetForm();\n        }\n      } else {\n        if (this.propsOfDialog?.['isSequentialNumGenerationRequired']) {\n          dataToSave.sequentialNumberId = `000${this.generateSequentialIdNumber(\n            this.parentModel\n          )}`;\n        }\n        this.saveData.emit(dataToSave);\n        this.resetForm();\n      }\n    }\n  }\n\n  translateFormConfig(\n    config: CustomFormlyFieldConfig[]\n  ): CustomFormlyFieldConfig[] {\n    return config.map((field) => {\n      if (field.props?.label) {\n        field.expressions = {\n          ...field.expressions,\n          'props.label': this.translateService.stream(field.props.label || ''),\n          'props.tooltip': this.translateService.stream(\n            field.props.label || ''\n          ),\n        };\n      }\n      if (field.props?.placeholder) {\n        field.expressions = {\n          ...field.expressions,\n          'props.placeholder': this.translateService.stream(\n            field.props.placeholder || ''\n          ),\n        };\n      }\n      if (field.fieldGroup) {\n        this.translateFormConfig(field.fieldGroup);\n      }\n      return field;\n    });\n  }\n\n  onModelChange(event: any) {\n    this.model = event;\n    this.subscribeToDependencies(this.fields, this.form, this.model);\n  }\n\n  subscribeToDependencies(fields: CustomFormlyFieldConfig[], form: FormGroup, vendorModel: any) {\n    fields.forEach((field: any) => {\n      if (field.fieldGroup) {\n        this.subscribeToDependencies(field.fieldGroup, form, vendorModel);\n      }\n    });\n  }\n\n  updateDependentFieldsFullName(fields: any) {\n    fields.forEach((field: any) => {\n      if(field.formControl && field.updateTabularField) {\n        field.formControl.valueChanges.subscribe((value: any) => {\n          this.updateLabelValueForField(field, value);\n        });\n      }\n      if (field.fieldGroup) {\n        this.updateDependentFieldsFullName(field.fieldGroup);\n      }\n    });\n  }\n\n  updateLabelValueForField(field: any, value: any) {\n    const options$ = field.props?.options;\n    if (options$ && typeof options$.subscribe === 'function') {\n      options$.subscribe((options: any) => {\n        const updateFieldKey = field.updateTabularField;\n        const selectedOption = options.find((option: any) => option.value === value);\n        if (selectedOption) {\n          this.model[updateFieldKey] = selectedOption.label;\n        }\n      });\n    }\n  }\n\n  isFilesUploaded() {\n    return true;\n  }\n\n  generateSequentialIdNumber(parentModel: any) {\n    if (parentModel?.[this.propsOfDialog?.['parenetModelKeyToGenerateSequentialNumber']]?.length) {\n      const latestRecordIdNumber = parentModel?.[this.propsOfDialog?.['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}"]}
|