@muraai/mnl-form 0.0.1-alpha-db495b1 → 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.
Files changed (61) hide show
  1. package/fesm2022/muraai-mnl-form.mjs +150 -143
  2. package/fesm2022/muraai-mnl-form.mjs.map +1 -1
  3. package/lib/types/upload-file.d.ts +1 -1
  4. package/lib/workflow-status/ workflow-status.module.d.ts +8 -8
  5. package/lib/workflow-status/workflow-status.component.d.ts +1 -1
  6. package/package.json +4 -5
  7. package/esm2022/lib/confirmation-dialog/confirmation-dialog.component.mjs +0 -34
  8. package/esm2022/lib/mnl-form/mnl-form-standalone.module.mjs +0 -155
  9. package/esm2022/lib/mnl-form/mnl-form.component.mjs +0 -199
  10. package/esm2022/lib/models/custom-form-field.model.mjs +0 -2
  11. package/esm2022/lib/models/workflow-status.model.mjs +0 -2
  12. package/esm2022/lib/services/graphql.service.mjs +0 -30
  13. package/esm2022/lib/services/scoring.service.mjs +0 -103
  14. package/esm2022/lib/types/action-button-renderer.component.mjs +0 -59
  15. package/esm2022/lib/types/autocomplete-type.component.mjs +0 -68
  16. package/esm2022/lib/types/button.type.mjs +0 -72
  17. package/esm2022/lib/types/comments.type.mjs +0 -102
  18. package/esm2022/lib/types/country-code-input.type.mjs +0 -181
  19. package/esm2022/lib/types/custom-date.type.mjs +0 -20
  20. package/esm2022/lib/types/custom-input.component.mjs +0 -62
  21. package/esm2022/lib/types/date-format.type.mjs +0 -196
  22. package/esm2022/lib/types/expansion-panel.types.mjs +0 -85
  23. package/esm2022/lib/types/formly-field-panel.type.mjs +0 -70
  24. package/esm2022/lib/types/grid-actionable.type.mjs +0 -197
  25. package/esm2022/lib/types/grid-formly-cell.component.mjs +0 -42
  26. package/esm2022/lib/types/grid.type.mjs +0 -125
  27. package/esm2022/lib/types/input.type.mjs +0 -43
  28. package/esm2022/lib/types/mu-helper-text.type.mjs +0 -331
  29. package/esm2022/lib/types/multi-select-autocomplete.mjs +0 -139
  30. package/esm2022/lib/types/multi-select-checkbox.component.mjs +0 -247
  31. package/esm2022/lib/types/radio.type.mjs +0 -71
  32. package/esm2022/lib/types/scrollable-tabs.types.mjs +0 -220
  33. package/esm2022/lib/types/select-api-auto-complete.component.mjs +0 -111
  34. package/esm2022/lib/types/select-autocomplete-redefined.component.mjs +0 -142
  35. package/esm2022/lib/types/select-autocomplete.type.mjs +0 -254
  36. package/esm2022/lib/types/stepper.type.mjs +0 -268
  37. package/esm2022/lib/types/table.types.mjs +0 -79
  38. package/esm2022/lib/types/tabs.types.mjs +0 -293
  39. package/esm2022/lib/types/tabular-form-dialog.component.mjs +0 -331
  40. package/esm2022/lib/types/tabular-form.type.mjs +0 -641
  41. package/esm2022/lib/types/upload-file.mjs +0 -524
  42. package/esm2022/lib/types/view-file-dialog.component.mjs +0 -90
  43. package/esm2022/lib/utils/formly.utils.mjs +0 -105
  44. package/esm2022/lib/validators/custom-email-validator.mjs +0 -18
  45. package/esm2022/lib/validators/ein-validators.mjs +0 -11
  46. package/esm2022/lib/validators/gst-validator.mjs +0 -11
  47. package/esm2022/lib/validators/normal-email-validator.mjs +0 -17
  48. package/esm2022/lib/validators/npi-validator.mjs +0 -11
  49. package/esm2022/lib/validators/pan-validator.mjs +0 -11
  50. package/esm2022/lib/validators/phone-number-validator.mjs +0 -22
  51. package/esm2022/lib/validators/select-validator.mjs +0 -7
  52. package/esm2022/lib/validators/tinSsn-validator.mjs +0 -12
  53. package/esm2022/lib/workflow-status/ workflow-status.module.mjs +0 -52
  54. package/esm2022/lib/workflow-status/workflow-status.component.mjs +0 -70
  55. package/esm2022/lib/wrappers/form-field-description-wrapper.component.mjs +0 -44
  56. package/esm2022/lib/wrappers/form-field-wrapper.component.mjs +0 -34
  57. package/esm2022/lib/wrappers/formly-wrapper-with-old-value.component.mjs +0 -140
  58. package/esm2022/lib/wrappers/prefix-suffix-wrapper.component.mjs +0 -95
  59. package/esm2022/lib/wrappers/prefix-sufix-extension.component.mjs +0 -9
  60. package/esm2022/muraai-mnl-form.mjs +0 -5
  61. package/esm2022/public-api.mjs +0 -12
@@ -1,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":["../../../../../../libs/form/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}"]}