@mediusinc/mng-commons 5.4.0-rc.0 → 5.4.0-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/core/helpers/object.mjs +8 -1
- package/esm2022/table/api/data-providers/table.data-provider.mjs +12 -6
- package/esm2022/table/api/models/table-event.model.mjs +1 -1
- package/esm2022/table/components/table/table.component.mjs +14 -7
- package/esm2022/tableview/action/components/action/action.component.mjs +2 -2
- package/esm2022/tableview/action/components/editor/injector-context/action-editor-injector-context.component.mjs +31 -17
- package/esm2022/tableview/action/components/table/action-table.component.mjs +4 -4
- package/esm2022/tableview/action/services/view-container.service.mjs +1 -1
- package/esm2022/tableview/api/action/models/execution/view-container.model.mjs +1 -1
- package/esm2022/tableview/api/editor/data-providers/editor.data-provider.mjs +9 -2
- package/esm2022/tableview/api/editor/descriptors/editor.descriptor.mjs +18 -1
- package/esm2022/tableview/api/editor/models/form-editor.event.mjs +1 -1
- package/esm2022/tableview/api/editor/models/form-editor.interface.mjs +1 -1
- package/esm2022/tableview/api/tableview/data-providers/tableview.data-provider.mjs +18 -6
- package/esm2022/tableview/editor/components/editor/auto-save-status/auto-save-status.component.mjs +82 -0
- package/esm2022/tableview/editor/components/editor/form-editor.component.mjs +164 -14
- package/esm2022/tableview/editor/helpers/editor-autosave.mjs +49 -0
- package/esm2022/tableview/editor/models/editor-auto-save-preview.model.mjs +2 -0
- package/esm2022/tableview/editor/services/form-editor.service.mjs +1 -1
- package/esm2022/tableview/index.mjs +3 -1
- package/fesm2022/mediusinc-mng-commons-core.mjs +7 -0
- package/fesm2022/mediusinc-mng-commons-core.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table-api.mjs +11 -5
- package/fesm2022/mediusinc-mng-commons-table-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table.mjs +13 -6
- package/fesm2022/mediusinc-mng-commons-table.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs +42 -6
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview.mjs +322 -40
- package/fesm2022/mediusinc-mng-commons-tableview.mjs.map +1 -1
- package/i18n/en.json +14 -0
- package/i18n/sl.json +14 -0
- package/package.json +1 -1
- package/table/api/data-providers/table.data-provider.d.ts +14 -5
- package/table/api/models/table-event.model.d.ts +4 -3
- package/table/components/table/table.component.d.ts +11 -2
- package/tableview/action/components/editor/injector-context/action-editor-injector-context.component.d.ts +4 -0
- package/tableview/action/components/table/action-table.component.d.ts +2 -2
- package/tableview/action/services/view-container.service.d.ts +6 -5
- package/tableview/api/action/models/execution/view-container.model.d.ts +7 -24
- package/tableview/api/editor/data-providers/editor.data-provider.d.ts +10 -1
- package/tableview/api/editor/descriptors/editor.descriptor.d.ts +5 -0
- package/tableview/api/editor/descriptors/field-base.descriptor.d.ts +1 -1
- package/tableview/api/editor/descriptors/field.descriptor.d.ts +1 -1
- package/tableview/api/editor/models/form-editor.event.d.ts +9 -0
- package/tableview/api/editor/models/form-editor.interface.d.ts +2 -2
- package/tableview/api/tableview/data-providers/tableview.data-provider.d.ts +10 -3
- package/tableview/editor/components/editor/auto-save-status/auto-save-status.component.d.ts +10 -0
- package/tableview/editor/components/editor/form-editor.component.d.ts +51 -4
- package/tableview/editor/helpers/editor-autosave.d.ts +17 -0
- package/tableview/editor/models/editor-auto-save-preview.model.d.ts +10 -0
- package/tableview/editor/services/form-editor.service.d.ts +2 -2
- package/tableview/index.d.ts +2 -0
- package/version-info.json +5 -5
|
@@ -1,23 +1,29 @@
|
|
|
1
|
-
import { AsyncPipe } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, DestroyRef, computed, effect, inject, input, output, signal, untracked, viewChild } from '@angular/core';
|
|
3
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
1
|
+
import { AsyncPipe, DatePipe } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, DestroyRef, booleanAttribute, computed, effect, inject, input, model, output, signal, untracked, viewChild } from '@angular/core';
|
|
3
|
+
import { outputFromObservable, takeUntilDestroyed, toSignal } from '@angular/core/rxjs-interop';
|
|
4
4
|
import { FormArray, FormGroup, ReactiveFormsModule, UntypedFormGroup } from '@angular/forms';
|
|
5
|
+
import { Router } from '@angular/router';
|
|
5
6
|
import { FormlyConfig, FormlyModule } from '@ngx-formly/core';
|
|
6
|
-
import { TranslateService } from '@ngx-translate/core';
|
|
7
|
+
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
7
8
|
import { ButtonModule } from 'primeng/button';
|
|
8
9
|
import { MessagesModule } from 'primeng/messages';
|
|
9
|
-
import { BehaviorSubject, debounceTime, distinctUntilChanged } from 'rxjs';
|
|
10
|
+
import { BehaviorSubject, debounceTime, distinctUntilChanged, tap } from 'rxjs';
|
|
10
11
|
import { map } from 'rxjs/operators';
|
|
11
|
-
import { CommonsService, LoggerService, objectDeepCopy } from '@mediusinc/mng-commons/core';
|
|
12
|
+
import { CommonsService, CommonsStorageService, LoggerService, StyleLevelEnum, StyleSizeEnum, objectDeepCopy } from '@mediusinc/mng-commons/core';
|
|
13
|
+
import { ButtonStyleBuilder, ButtonStyleRoundedEnum } from '@mediusinc/mng-commons/form/api';
|
|
12
14
|
import { FormEventTypeEnum, FormFieldEventComponentSubtype, TableviewEditorTypeEnum } from '@mediusinc/mng-commons/tableview/api';
|
|
15
|
+
import { generateAutosaveEditorKey } from '../../helpers/editor-autosave';
|
|
13
16
|
import { createFormlyConfigFromDescriptor } from '../../helpers/editor-formly';
|
|
14
17
|
import { getFormEditorInfoMessage, getFormEditorWarningMessage } from '../../helpers/notification';
|
|
15
18
|
import { FormEditorService, provideFormComponent } from '../../services/form-editor.service';
|
|
19
|
+
import { EditorAutoSaveStatusComponent } from './auto-save-status/auto-save-status.component';
|
|
16
20
|
import * as i0 from "@angular/core";
|
|
17
21
|
import * as i1 from "@ngx-formly/core";
|
|
18
22
|
import * as i2 from "@angular/forms";
|
|
19
23
|
import * as i3 from "primeng/messages";
|
|
20
24
|
import * as i4 from "primeng/button";
|
|
25
|
+
import * as i5 from "primeng/api";
|
|
26
|
+
import * as i6 from "@ngx-translate/core";
|
|
21
27
|
export class FormEditorComponent {
|
|
22
28
|
get parent() {
|
|
23
29
|
return this.formService.parent;
|
|
@@ -44,16 +50,26 @@ export class FormEditorComponent {
|
|
|
44
50
|
this.formlyConfig = inject(FormlyConfig);
|
|
45
51
|
this.translateService = inject(TranslateService);
|
|
46
52
|
this.commons = inject(CommonsService);
|
|
47
|
-
this.
|
|
53
|
+
this.cmpTypeName = 'FormEditorComponent';
|
|
54
|
+
this.logger = inject(LoggerService).create(this.cmpTypeName);
|
|
48
55
|
this.destroyRef = inject(DestroyRef);
|
|
49
56
|
this.formService = inject((FormEditorService));
|
|
57
|
+
this.commonsStorageService = inject(CommonsStorageService);
|
|
58
|
+
this.router = inject(Router);
|
|
59
|
+
this.autoSaveStorageKeyCompInit = true;
|
|
60
|
+
this.autoSaveStorageKey = computed(() => generateAutosaveEditorKey(this.descriptor(), this.item(), this.router.url, { editorId: this.editorId(), itemId: this.itemId() }));
|
|
50
61
|
this.descriptor = input.required();
|
|
51
|
-
this.submitLoading = input(false);
|
|
52
|
-
this.item =
|
|
53
|
-
this.isFormDisabled = input(false);
|
|
62
|
+
this.submitLoading = input(false, { transform: booleanAttribute });
|
|
63
|
+
this.item = model(undefined);
|
|
64
|
+
this.isFormDisabled = input(false, { transform: booleanAttribute });
|
|
65
|
+
this.editorId = input(undefined);
|
|
66
|
+
this.itemId = input(undefined);
|
|
67
|
+
this.showAutoSaveStatus = input(true, { transform: booleanAttribute });
|
|
54
68
|
// event outputs
|
|
55
69
|
this.formSubmit = output();
|
|
56
70
|
this.valueChange = output();
|
|
71
|
+
this.autoSaveStatusSubject = new BehaviorSubject({ state: 'initial', timestamp: new Date() });
|
|
72
|
+
this.autoSaveStatus = outputFromObservable(this.autoSaveStatusSubject.asObservable());
|
|
57
73
|
// content and view queries
|
|
58
74
|
this.submitButtonElementRef = viewChild('submitButton');
|
|
59
75
|
// formly specifics
|
|
@@ -71,6 +87,27 @@ export class FormEditorComponent {
|
|
|
71
87
|
this._formlyInitialItem = {}; // initialized in ngOnInit, should not be changed after
|
|
72
88
|
this.setterFields = computed(() => this.descriptor().fields.filter(f => typeof f.setter === 'function'));
|
|
73
89
|
this.formMessages = signal([]);
|
|
90
|
+
// autosave
|
|
91
|
+
this.restoreLocalStateButtonStyle = ButtonStyleBuilder.create(StyleLevelEnum.Success, StyleSizeEnum.Small).build();
|
|
92
|
+
this.previewLocalStateButtonStyle = ButtonStyleBuilder.create(StyleLevelEnum.Info, StyleSizeEnum.Small).build();
|
|
93
|
+
this.clearLocalStateButtonStyle = ButtonStyleBuilder.create(StyleLevelEnum.Danger, StyleSizeEnum.Small)
|
|
94
|
+
.withRoundedButton(ButtonStyleRoundedEnum.SQUARE)
|
|
95
|
+
.withTextButton()
|
|
96
|
+
.build();
|
|
97
|
+
this.autoSaveRestore = signal(null);
|
|
98
|
+
this.autoSave = toSignal(this.autoSaveStatusSubject);
|
|
99
|
+
this.autoSavePreviewButtonLabel = computed(() => {
|
|
100
|
+
switch (this.autoSave()?.state) {
|
|
101
|
+
case 'preview':
|
|
102
|
+
return 'mngEditor.autoSave.restore.previewCurrent';
|
|
103
|
+
case 'previewCurrent':
|
|
104
|
+
return 'mngEditor.autoSave.restore.previewAutosaved';
|
|
105
|
+
default:
|
|
106
|
+
return 'mngEditor.autoSave.restore.preview';
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
this.autoSaveShowRestore = computed(() => this.autoSaveRestore()?.saved != null);
|
|
110
|
+
this.autoSavePreviewDisabledForm = signal(false);
|
|
74
111
|
this.formService.init(this);
|
|
75
112
|
effect(() => {
|
|
76
113
|
const item = this.item();
|
|
@@ -82,11 +119,22 @@ export class FormEditorComponent {
|
|
|
82
119
|
// resetModel uses signal like concept
|
|
83
120
|
{ allowSignalWrites: true });
|
|
84
121
|
effect(() => {
|
|
85
|
-
this._formlyOptions.formState.disabled =
|
|
122
|
+
this._formlyOptions.formState.disabled =
|
|
123
|
+
this.isFormDisabled() || this.autoSavePreviewDisabledForm() || this._formlyOptions.formState.descriptor?.disabled === true || this._formlyOptions.formState.details;
|
|
86
124
|
untracked(() => {
|
|
87
125
|
this._formlyStateDisabledSubject.next(this._formlyOptions.formState.disabled);
|
|
88
126
|
});
|
|
89
127
|
});
|
|
128
|
+
effect(() => {
|
|
129
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
130
|
+
const key = this.autoSaveStorageKey();
|
|
131
|
+
untracked(() => {
|
|
132
|
+
this.autoSaveStopValueChangeListen();
|
|
133
|
+
this.autoSaveLoadSavedFromStorage();
|
|
134
|
+
this.autoSaveStartEventChangeListen(this.autoSaveStorageKeyCompInit);
|
|
135
|
+
this.autoSaveStorageKeyCompInit = false;
|
|
136
|
+
});
|
|
137
|
+
});
|
|
90
138
|
}
|
|
91
139
|
ngOnInit() {
|
|
92
140
|
// init form state
|
|
@@ -156,6 +204,7 @@ export class FormEditorComponent {
|
|
|
156
204
|
submitValid: true,
|
|
157
205
|
submitValue: formSubmitItem
|
|
158
206
|
});
|
|
207
|
+
this.onAutoSaveDismiss();
|
|
159
208
|
}
|
|
160
209
|
else {
|
|
161
210
|
// find and mark invalid tabs
|
|
@@ -251,6 +300,63 @@ export class FormEditorComponent {
|
|
|
251
300
|
return false;
|
|
252
301
|
}
|
|
253
302
|
}
|
|
303
|
+
/**
|
|
304
|
+
* Restores the saved local state.
|
|
305
|
+
* If local storage keys exist for local state and local timestamp, restore their corresponding values.
|
|
306
|
+
*/
|
|
307
|
+
onAutoSaveRestore() {
|
|
308
|
+
const restore = this.autoSaveRestore();
|
|
309
|
+
if (restore?.saved) {
|
|
310
|
+
this.autoSaveStopValueChangeListen();
|
|
311
|
+
this.resetFormModel(restore.saved);
|
|
312
|
+
this.autoSaveRestore.set(null);
|
|
313
|
+
this.autoSaveStatusSubject.next({ state: 'restored', timestamp: restore.savedAt ?? new Date() });
|
|
314
|
+
this.autoSavePreviewDisabledForm.set(false);
|
|
315
|
+
this.autoSaveStartEventChangeListen();
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
/**
|
|
319
|
+
* Previews the saved local state.
|
|
320
|
+
* If local storage keys exist for local state and local timestamp, restore their corresponding values.
|
|
321
|
+
*/
|
|
322
|
+
onAutoSavePreview() {
|
|
323
|
+
if (!this.autoSaveRestore()?.saved) {
|
|
324
|
+
return;
|
|
325
|
+
}
|
|
326
|
+
this.autoSaveStopValueChangeListen();
|
|
327
|
+
this.autoSavePreviewDisabledForm.set(true);
|
|
328
|
+
const state = this.autoSaveStatusSubject.value.state;
|
|
329
|
+
if (state !== 'preview' && state !== 'previewCurrent') {
|
|
330
|
+
// must store original value from current value form
|
|
331
|
+
this.autoSaveRestore.update(i => ({ ...i, original: this.getFormValue() }));
|
|
332
|
+
}
|
|
333
|
+
const restore = this.autoSaveRestore();
|
|
334
|
+
if (state === 'preview' && restore?.original) {
|
|
335
|
+
this.resetFormModel(restore.original);
|
|
336
|
+
this.autoSaveStatusSubject.next({ state: 'previewCurrent' });
|
|
337
|
+
}
|
|
338
|
+
else if (state !== 'preview' && restore?.saved) {
|
|
339
|
+
this.resetFormModel(restore.saved);
|
|
340
|
+
this.autoSaveStatusSubject.next({ state: 'preview', timestamp: restore.savedAt ?? new Date() });
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
/**
|
|
344
|
+
* Removes local state from local storage.
|
|
345
|
+
* If local storage keys exist for local state and local timestamp, remove their corresponding values.
|
|
346
|
+
*/
|
|
347
|
+
onAutoSaveDismiss() {
|
|
348
|
+
if (this.autoSaveStorageKey()) {
|
|
349
|
+
const restore = this.autoSaveRestore();
|
|
350
|
+
if (this.autoSaveStatusSubject.value.state === 'preview' && restore?.original) {
|
|
351
|
+
this.resetFormModel(restore.original);
|
|
352
|
+
this.autoSaveStatusSubject.next({ state: 'initial', timestamp: new Date() });
|
|
353
|
+
}
|
|
354
|
+
this.commonsStorageService.removeItem(this.cmpTypeName, this.autoSaveStorageKey());
|
|
355
|
+
this.autoSaveRestore.set(null);
|
|
356
|
+
this.autoSavePreviewDisabledForm.set(false);
|
|
357
|
+
this.autoSaveStartEventChangeListen();
|
|
358
|
+
}
|
|
359
|
+
}
|
|
254
360
|
getFormModelFromItem(item) {
|
|
255
361
|
const formModel = objectDeepCopy(item, { mapGettersToProperties: true }) ?? {};
|
|
256
362
|
const descriptor = this.descriptor();
|
|
@@ -311,11 +417,55 @@ export class FormEditorComponent {
|
|
|
311
417
|
}
|
|
312
418
|
return false;
|
|
313
419
|
}
|
|
420
|
+
autoSaveStartEventChangeListen(init = false) {
|
|
421
|
+
if (!this.descriptor().autoSave) {
|
|
422
|
+
return;
|
|
423
|
+
}
|
|
424
|
+
setTimeout(() => {
|
|
425
|
+
if (!this.autoSaveEventsSubscription) {
|
|
426
|
+
this.autoSaveEventsSubscription = this._form.valueChanges
|
|
427
|
+
.pipe(debounceTime(250), distinctUntilChanged(),
|
|
428
|
+
// skip first one on init
|
|
429
|
+
tap(() => {
|
|
430
|
+
if (this.autoSaveStatusSubject.value.state !== 'saved' && this.autoSaveStatusSubject.value.state !== 'preview')
|
|
431
|
+
this.autoSaveStatusSubject.next({ ...this.autoSaveStatusSubject.value, state: 'saving' });
|
|
432
|
+
}), debounceTime(750), takeUntilDestroyed(this.destroyRef))
|
|
433
|
+
.subscribe(() => {
|
|
434
|
+
this.autoSaveSaveToStorage();
|
|
435
|
+
});
|
|
436
|
+
}
|
|
437
|
+
}, init ? 0 : 500 // delay initial event listening for all the initializations to take place
|
|
438
|
+
);
|
|
439
|
+
}
|
|
440
|
+
autoSaveStopValueChangeListen() {
|
|
441
|
+
this.autoSaveEventsSubscription?.unsubscribe();
|
|
442
|
+
this.autoSaveEventsSubscription = undefined;
|
|
443
|
+
}
|
|
444
|
+
/**
|
|
445
|
+
* Saves the form value to localStorage if autoSave is enabled and the required keys are defined.
|
|
446
|
+
* @returns {void}
|
|
447
|
+
*/
|
|
448
|
+
autoSaveSaveToStorage() {
|
|
449
|
+
if (this.descriptor().autoSave !== true || this.autoSaveStatusSubject.value.state === 'preview' || this.autoSaveStatusSubject.value.state === 'previewCurrent') {
|
|
450
|
+
return;
|
|
451
|
+
}
|
|
452
|
+
this.commonsStorageService.setItem(this.cmpTypeName, this.autoSaveStorageKey(), { saved: this.getFormValue(), savedAt: new Date() });
|
|
453
|
+
this.autoSaveStatusSubject.next({ state: 'saved', timestamp: new Date() });
|
|
454
|
+
}
|
|
455
|
+
/**
|
|
456
|
+
* Loads the value from the local storage if available
|
|
457
|
+
*/
|
|
458
|
+
autoSaveLoadSavedFromStorage() {
|
|
459
|
+
const { autoSave, model } = this.descriptor();
|
|
460
|
+
if (autoSave && model.i18nBaseKey) {
|
|
461
|
+
this.autoSaveRestore.set(this.commonsStorageService.getItem(this.cmpTypeName, this.autoSaveStorageKey()) ?? null);
|
|
462
|
+
}
|
|
463
|
+
}
|
|
314
464
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: FormEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
315
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.
|
|
465
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: FormEditorComponent, isStandalone: true, selector: "mng-form-editor", inputs: { descriptor: { classPropertyName: "descriptor", publicName: "descriptor", isSignal: true, isRequired: true, transformFunction: null }, submitLoading: { classPropertyName: "submitLoading", publicName: "submitLoading", isSignal: true, isRequired: false, transformFunction: null }, item: { classPropertyName: "item", publicName: "item", isSignal: true, isRequired: false, transformFunction: null }, isFormDisabled: { classPropertyName: "isFormDisabled", publicName: "isFormDisabled", isSignal: true, isRequired: false, transformFunction: null }, editorId: { classPropertyName: "editorId", publicName: "editorId", isSignal: true, isRequired: false, transformFunction: null }, itemId: { classPropertyName: "itemId", publicName: "itemId", isSignal: true, isRequired: false, transformFunction: null }, showAutoSaveStatus: { classPropertyName: "showAutoSaveStatus", publicName: "showAutoSaveStatus", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { item: "itemChange", formSubmit: "formSubmit", valueChange: "valueChange", autoSaveStatus: "autoSaveStatus" }, providers: [provideFormComponent()], viewQueries: [{ propertyName: "submitButtonElementRef", first: true, predicate: ["submitButton"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (autoSaveShowRestore()) {\n <p-messages severity=\"warn\">\n <ng-template pTemplate>\n <div class=\"flex flex-grow-1 justify-content-between align-items-center\">\n <h6 class=\"m-0 p-0\">\n <em class=\"pi pi-save mr-4\"></em>\n {{\n 'mngEditor.autoSave.restore.title'\n | translate: {lastChange: autoSaveRestore()?.savedAt ? (autoSaveRestore()?.savedAt! | date: 'dd. MM. YYYY HH:mm:ss') : ''}\n }}\n </h6>\n <div>\n <p-button\n icon=\"pi pi-sync\"\n size=\"small\"\n [label]=\"'mngEditor.autoSave.restore.restore' | translate\"\n [styleClass]=\"restoreLocalStateButtonStyle\"\n [text]=\"true\"\n (click)=\"onAutoSaveRestore()\"></p-button>\n @if (autoSave()?.state !== 'preview' || autoSave()?.state !== 'previewCurrent') {\n <p-button\n icon=\"pi pi-eye\"\n size=\"small\"\n [label]=\"autoSavePreviewButtonLabel() | translate\"\n [styleClass]=\"previewLocalStateButtonStyle\"\n [text]=\"true\"\n (click)=\"onAutoSavePreview()\"></p-button>\n }\n <p-button\n icon=\"pi pi-times\"\n size=\"small\"\n [label]=\"'mngEditor.autoSave.restore.dismiss' | translate\"\n [styleClass]=\"clearLocalStateButtonStyle\"\n (click)=\"onAutoSaveDismiss()\"></p-button>\n </div>\n </div>\n </ng-template>\n </p-messages>\n}\n\n<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formlyFields\" [options]=\"formlyOptions\" [model]=\"formlyInitialItem\"></formly-form>\n <button #submitButton pButton type=\"submit\" class=\"hidden\" [disabled]=\"form.disabled\" [loading]=\"submitLoading()\" loadingIcon=\"pi pi-spin pi-spinner\"></button>\n</form>\n<p-messages [value]=\"formMessages()\" [enableService]=\"false\"></p-messages>\n\n@if (descriptor().autoSave && showAutoSaveStatus()) {\n <mng-editor-auto-save-status [status]=\"autoSave()\"></mng-editor-auto-save-status>\n}\n", dependencies: [{ kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i1.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MessagesModule }, { kind: "component", type: i3.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange", "onClose"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i5.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "pipe", type: DatePipe, name: "date" }, { kind: "component", type: EditorAutoSaveStatusComponent, selector: "mng-editor-auto-save-status", inputs: ["status"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
316
466
|
}
|
|
317
467
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: FormEditorComponent, decorators: [{
|
|
318
468
|
type: Component,
|
|
319
|
-
args: [{ standalone: true, selector: 'mng-form-editor', imports: [FormlyModule, ReactiveFormsModule, MessagesModule, AsyncPipe, ButtonModule], providers: [provideFormComponent()], changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formlyFields\" [options]=\"formlyOptions\" [model]=\"formlyInitialItem\"></formly-form>\n <button #submitButton pButton type=\"submit\" class=\"hidden\" [disabled]=\"form.disabled\" [loading]=\"submitLoading()\" loadingIcon=\"pi pi-spin pi-spinner\"></button>\n</form>\n<p-messages [value]=\"formMessages()\" [enableService]=\"false\"></p-messages>\n" }]
|
|
469
|
+
args: [{ standalone: true, selector: 'mng-form-editor', imports: [FormlyModule, ReactiveFormsModule, MessagesModule, AsyncPipe, ButtonModule, TranslateModule, DatePipe, EditorAutoSaveStatusComponent], providers: [provideFormComponent()], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (autoSaveShowRestore()) {\n <p-messages severity=\"warn\">\n <ng-template pTemplate>\n <div class=\"flex flex-grow-1 justify-content-between align-items-center\">\n <h6 class=\"m-0 p-0\">\n <em class=\"pi pi-save mr-4\"></em>\n {{\n 'mngEditor.autoSave.restore.title'\n | translate: {lastChange: autoSaveRestore()?.savedAt ? (autoSaveRestore()?.savedAt! | date: 'dd. MM. YYYY HH:mm:ss') : ''}\n }}\n </h6>\n <div>\n <p-button\n icon=\"pi pi-sync\"\n size=\"small\"\n [label]=\"'mngEditor.autoSave.restore.restore' | translate\"\n [styleClass]=\"restoreLocalStateButtonStyle\"\n [text]=\"true\"\n (click)=\"onAutoSaveRestore()\"></p-button>\n @if (autoSave()?.state !== 'preview' || autoSave()?.state !== 'previewCurrent') {\n <p-button\n icon=\"pi pi-eye\"\n size=\"small\"\n [label]=\"autoSavePreviewButtonLabel() | translate\"\n [styleClass]=\"previewLocalStateButtonStyle\"\n [text]=\"true\"\n (click)=\"onAutoSavePreview()\"></p-button>\n }\n <p-button\n icon=\"pi pi-times\"\n size=\"small\"\n [label]=\"'mngEditor.autoSave.restore.dismiss' | translate\"\n [styleClass]=\"clearLocalStateButtonStyle\"\n (click)=\"onAutoSaveDismiss()\"></p-button>\n </div>\n </div>\n </ng-template>\n </p-messages>\n}\n\n<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formlyFields\" [options]=\"formlyOptions\" [model]=\"formlyInitialItem\"></formly-form>\n <button #submitButton pButton type=\"submit\" class=\"hidden\" [disabled]=\"form.disabled\" [loading]=\"submitLoading()\" loadingIcon=\"pi pi-spin pi-spinner\"></button>\n</form>\n<p-messages [value]=\"formMessages()\" [enableService]=\"false\"></p-messages>\n\n@if (descriptor().autoSave && showAutoSaveStatus()) {\n <mng-editor-auto-save-status [status]=\"autoSave()\"></mng-editor-auto-save-status>\n}\n" }]
|
|
320
470
|
}], ctorParameters: () => [] });
|
|
321
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-editor.component.js","sourceRoot":"","sources":["../../../../../../tableview/src/editor/components/editor/form-editor.component.ts","../../../../../../tableview/src/editor/components/editor/form-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, DestroyRef, ElementRef, OnDestroy, OnInit, computed, effect, inject, input, output, signal, untracked, viewChild} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {AbstractControl, FormArray, FormGroup, ReactiveFormsModule, UntypedFormGroup} from '@angular/forms';\n\nimport {FormlyConfig, FormlyFieldConfig, FormlyModule} from '@ngx-formly/core';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Message} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {MessagesModule} from 'primeng/messages';\nimport {BehaviorSubject, debounceTime, distinctUntilChanged} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {CommonsService, LoggerService, objectDeepCopy} from '@mediusinc/mng-commons/core';\nimport {\n    CommonsFormlyFormOptions,\n    EditorDescriptorInst,\n    FormEditorPatchFieldValueOpts,\n    FormEditorResetFieldValueOpts,\n    FormEditorResetFormModelOpts,\n    FormEditorSetFieldValueOpts,\n    FormEditorSubmitEvent,\n    FormEventTypeEnum,\n    FormFieldEventComponentSubtype,\n    IFormEditorComponent,\n    TableviewEditorTypeEnum\n} from '@mediusinc/mng-commons/tableview/api';\n\nimport {createFormlyConfigFromDescriptor} from '../../helpers/editor-formly';\nimport {getFormEditorInfoMessage, getFormEditorWarningMessage} from '../../helpers/notification';\nimport {FormEditorService, provideFormComponent} from '../../services/form-editor.service';\n\n@Component({\n    standalone: true,\n    selector: 'mng-form-editor',\n    templateUrl: './form-editor.component.html',\n    imports: [FormlyModule, ReactiveFormsModule, MessagesModule, AsyncPipe, ButtonModule],\n    providers: [provideFormComponent()],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormEditorComponent<Item = any, ParentItem = any> implements IFormEditorComponent<Item, ParentItem>, OnInit, OnDestroy {\n    private readonly formlyConfig = inject(FormlyConfig);\n    private readonly translateService = inject(TranslateService);\n    private readonly commons = inject(CommonsService);\n    private readonly logger = inject(LoggerService).create('FormEditorComponent');\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly formService = inject(FormEditorService<Item, ParentItem>);\n\n    public descriptor = input.required<EditorDescriptorInst<Item>>();\n    public submitLoading = input(false);\n    public item = input<Item | undefined>(undefined);\n    public isFormDisabled = input(false);\n\n    // event outputs\n    public formSubmit = output<FormEditorSubmitEvent<Item>>();\n    public valueChange = output<Item>();\n\n    // content and view queries\n    public submitButtonElementRef = viewChild<ElementRef | undefined>('submitButton');\n\n    // formly specifics\n    private readonly _form = new UntypedFormGroup({});\n    private readonly _formlyStateDisabledSubject = new BehaviorSubject(false);\n    private readonly _formlyOptions: CommonsFormlyFormOptions<Item> = {\n        formState: {\n            add: false,\n            edit: false,\n            disabled: false,\n            disabled$: this._formlyStateDisabledSubject.asObservable().pipe(distinctUntilChanged())\n        }\n    };\n    private _formlyFields: FormlyFieldConfig[] = []; // initialized in ngOnInit, should not be changed after\n    private _formlyInitialItem = {}; // initialized in ngOnInit, should not be changed after\n    private initialItemInput: Item | undefined;\n\n    private setterFields = computed(() => this.descriptor().fields.filter(f => typeof f.setter === 'function'));\n\n    public formMessages = signal<Message[]>([]);\n\n    get parent() {\n        return this.formService.parent;\n    }\n\n    get form(): FormGroup<{[K in keyof Item]: AbstractControl<Item[K]>}> {\n        return this._form;\n    }\n\n    get formUnsafe(): UntypedFormGroup {\n        return this._form;\n    }\n\n    get formlyOptions() {\n        return this._formlyOptions;\n    }\n\n    get formlyFields() {\n        return this._formlyFields;\n    }\n\n    /**\n     * Only used for form initialization. Further changes should be done using {resetFormModel}.\n     */\n    get formlyInitialItem() {\n        return this._formlyInitialItem;\n    }\n\n    constructor() {\n        this.formService.init(this);\n\n        effect(\n            () => {\n                const item = this.item();\n                if (item !== this.initialItemInput) {\n                    // new item is different from the one the form was initialized with. Must trigger reset of form model.\n                    this.resetFormModel(item);\n                }\n            },\n            // resetModel uses signal like concept\n            {allowSignalWrites: true}\n        );\n\n        effect(() => {\n            this._formlyOptions.formState.disabled = this.isFormDisabled() || this._formlyOptions.formState.descriptor?.disabled === true || this._formlyOptions.formState.details;\n            untracked(() => {\n                this._formlyStateDisabledSubject.next(this._formlyOptions.formState.disabled);\n            });\n        });\n    }\n\n    public ngOnInit() {\n        // init form state\n        if (this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Add) {\n            this._formlyOptions.formState.add = true;\n        } else if (this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Edit) {\n            this._formlyOptions.formState.edit = true;\n        } else if (this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Details) {\n            this._formlyOptions.formState.details = true;\n        }\n        this._formlyOptions.formState.descriptor = this.descriptor();\n\n        // init fields for formly\n        this._formlyFields = createFormlyConfigFromDescriptor(this.descriptor(), this.formlyConfig, this);\n\n        // int form model (only initial, no further changes to formModel should be allowed!)\n        this.initialItemInput = this.item();\n        this._formlyInitialItem = this.getFormModelFromItem(this.item());\n\n        // handle localizations edit/add message\n        if (\n            this.descriptor().isLocalized &&\n            (this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Add || this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Edit)\n        ) {\n            this.formMessages.set([\n                ...this.formMessages(),\n                getFormEditorInfoMessage(this.translateService, 'mngEditor.localizations.addInDefaultLanguageTitle', 'mngEditor.localizations.addInDefaultLanguageDescription', {\n                    defaultLanguage: this.commons.getDefaultLocale()\n                })\n            ]);\n        }\n\n        // emit lifecycle event\n        this.descriptor().nextEvent(FormEventTypeEnum.ComponentLifecycle, this as IFormEditorComponent<any>, {\n            eventSubtype: FormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this._form.valueChanges\n            .pipe(\n                debounceTime(100),\n                distinctUntilChanged(),\n                map(() => this._form.getRawValue()),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe(v => {\n                this.valueChange?.emit(v);\n                this.descriptor().nextEvent(FormEventTypeEnum.ValueChange, this as IFormEditorComponent<any>, {\n                    value: v,\n                    formValue: () => this.getFormValue()\n                });\n            });\n\n        // mark form as pristine, should be done in next event hook to allow formly to initialize first\n        setTimeout(() => {\n            this._form.markAsPristine();\n        });\n    }\n\n    public ngOnDestroy() {\n        // emit lifecycle event\n        this.descriptor().nextEvent(FormEventTypeEnum.ComponentLifecycle, this as IFormEditorComponent<any>, {\n            eventSubtype: FormFieldEventComponentSubtype.ON_DESTROY\n        });\n    }\n\n    public submit() {\n        this.submitButtonElementRef()?.nativeElement.click();\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    public onSubmit(event: Event) {\n        this._formlyOptions.formState.submittedOn = Date.now();\n        this.formMessages.set([]);\n\n        const formSubmitItem = this.getFormValue();\n        if (this._form.valid) {\n            this.formSubmit.emit({\n                success: true,\n                formItem: formSubmitItem\n            });\n            this.descriptor().nextEvent(FormEventTypeEnum.Submit, this as IFormEditorComponent<any>, {\n                submitValid: true,\n                submitValue: formSubmitItem\n            });\n        } else {\n            // find and mark invalid tabs\n            const formFields = this._formlyFields;\n            if (formFields[0].type === 'tabs' && formFields[0].fieldGroup) {\n                for (const tab of formFields[0].fieldGroup) {\n                    this._formlyOptions.formState['tab_' + (tab.id ? tab.id : tab.key ?? '') + '_invalid'] = this.isAnyFieldInvalid(tab.fieldGroup);\n                }\n            }\n\n            const event: FormEditorSubmitEvent<Item> = {success: false, formItem: formSubmitItem};\n            event.success = false;\n            this.formMessages().push(getFormEditorWarningMessage(this.translateService, 'mngEditor.invalidFormToastTitle', 'mngEditor.invalidFormToastMessage'));\n\n            this.formSubmit.emit(event);\n            this.descriptor().nextEvent(FormEventTypeEnum.Submit, this as IFormEditorComponent<any>, {\n                submitValid: false,\n                submitValue: formSubmitItem\n            });\n        }\n    }\n\n    public getFormValue(opts?: {omitSetters?: boolean}): Item {\n        const formValue = objectDeepCopy(this._form.getRawValue(), {mapGettersToProperties: true});\n\n        if (opts?.omitSetters !== true) {\n            this.setterFields().forEach(field => {\n                const splitPath = field.property.split('.');\n                let fieldValue = formValue;\n                for (let i = 0; i < splitPath.length - 1; i++) {\n                    const currentSubPath = splitPath[i];\n                    if (typeof fieldValue[currentSubPath] !== 'object') {\n                        fieldValue[currentSubPath] = {};\n                    }\n\n                    fieldValue = fieldValue[currentSubPath];\n                }\n\n                fieldValue = fieldValue[splitPath[splitPath.length - 1]];\n                field.setter?.(formValue, fieldValue);\n            });\n        }\n\n        return formValue;\n    }\n\n    public resetFormModel(item?: Item, opts?: FormEditorResetFormModelOpts) {\n        this._formlyOptions.resetModel?.(this.getFormModelFromItem(item));\n\n        if (opts?.markAsPristine !== false) {\n            // mark form as pristine, should be done in next event hook to allow formly to initialize first\n            setTimeout(() => {\n                this._form.markAsPristine({onlySelf: opts?.onlySelf});\n            });\n        }\n    }\n\n    public getField(key: keyof Item) {\n        return this.getFieldUnsafe(key as string);\n    }\n\n    public getFieldUnsafe(key: string) {\n        return this.findFormField(this._form, key.split('.'));\n    }\n\n    public setFieldValue<Property extends keyof Item>(key: Property, value: Item[Property], opts?: FormEditorSetFieldValueOpts) {\n        return this.setFieldValueUnsafe(key as string, value, opts);\n    }\n\n    public setFieldValueUnsafe(key: string, value: any, opts?: FormEditorSetFieldValueOpts) {\n        const control = this.getFieldUnsafe(key);\n        if (control) {\n            control.setValue(value, opts);\n            return true;\n        } else {\n            this.logger.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public patchFieldValue<Property extends keyof Item>(key: Property, value: Item[Property], opts?: FormEditorPatchFieldValueOpts) {\n        return this.patchFieldValueUnsafe(key as string, value, opts);\n    }\n\n    public patchFieldValueUnsafe(key: string, value: any, opts?: FormEditorPatchFieldValueOpts) {\n        const control = this.getFieldUnsafe(key);\n        if (control) {\n            control.patchValue(value, opts);\n            return true;\n        } else {\n            this.logger.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public resetFieldValue<Property extends keyof Item>(key: Property, value?: Item[Property], opts?: FormEditorResetFieldValueOpts) {\n        return this.resetFieldValueUnsafe(key as string, value, opts);\n    }\n\n    public resetFieldValueUnsafe(key: string, value?: any, opts?: FormEditorResetFieldValueOpts) {\n        const control = this.getFieldUnsafe(key);\n        if (control) {\n            control.reset(value, opts);\n            return true;\n        } else {\n            this.logger.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    private getFormModelFromItem(item: Item | undefined): any {\n        const formModel = (objectDeepCopy(item, {mapGettersToProperties: true}) as Record<string, any>) ?? {};\n\n        const descriptor = this.descriptor();\n        descriptor.fields.forEach(field => {\n            if (field.getter && item) {\n                const splitPath = field.property.split('.');\n                let currentObject = formModel;\n\n                for (let i = 0; i < splitPath.length; i++) {\n                    const currentSubPath = splitPath[i];\n                    if (i === splitPath.length - 1) {\n                        currentObject[currentSubPath] = field.getter(item?.[field.property as keyof object], item);\n                    } else {\n                        if (typeof currentObject[currentSubPath] !== 'object') {\n                            currentObject[currentSubPath] = {};\n                        }\n\n                        currentObject = currentObject[currentSubPath];\n                    }\n                }\n            }\n        });\n\n        return formModel;\n    }\n\n    private findFormField(control: AbstractControl, keyPath: string[]): AbstractControl | null {\n        if (keyPath.length === 0) {\n            return control;\n        }\n        if (keyPath.length === 1) {\n            return control.get(keyPath[0]);\n        }\n        let nextControl: AbstractControl | null = null;\n        if (control instanceof FormGroup) {\n            nextControl = control.get(keyPath[0]);\n        } else if (control instanceof FormArray) {\n            const idx = +keyPath[0];\n            if (!isNaN(idx)) {\n                nextControl = control.at(idx);\n            }\n        }\n\n        if (!control) {\n            return null;\n        }\n        return this.findFormField(nextControl!, keyPath.slice(1));\n    }\n\n    private isAnyFieldInvalid(fields: FormlyFieldConfig[] = []): boolean {\n        for (const field of fields) {\n            let fieldInvalid = false;\n            if (Array.isArray(field.fieldGroup)) {\n                fieldInvalid = this.isAnyFieldInvalid(field.fieldGroup);\n            } else if (typeof field.type !== 'undefined') {\n                fieldInvalid = !field.formControl?.valid;\n            }\n            if (fieldInvalid) {\n                return true;\n            }\n        }\n        return false;\n    }\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n    <formly-form [form]=\"form\" [fields]=\"formlyFields\" [options]=\"formlyOptions\" [model]=\"formlyInitialItem\"></formly-form>\n    <button #submitButton pButton type=\"submit\" class=\"hidden\" [disabled]=\"form.disabled\" [loading]=\"submitLoading()\" loadingIcon=\"pi pi-spin pi-spinner\"></button>\n</form>\n<p-messages [value]=\"formMessages()\" [enableService]=\"false\"></p-messages>\n"]}
|
|
471
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-editor.component.js","sourceRoot":"","sources":["../../../../../../tableview/src/editor/components/editor/form-editor.component.ts","../../../../../../tableview/src/editor/components/editor/form-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, DatePipe} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    ElementRef,\n    OnDestroy,\n    OnInit,\n    booleanAttribute,\n    computed,\n    effect,\n    inject,\n    input,\n    model,\n    output,\n    signal,\n    untracked,\n    viewChild\n} from '@angular/core';\nimport {outputFromObservable, takeUntilDestroyed, toSignal} from '@angular/core/rxjs-interop';\nimport {AbstractControl, FormArray, FormGroup, ReactiveFormsModule, UntypedFormGroup} from '@angular/forms';\nimport {Router} from '@angular/router';\n\nimport {FormlyConfig, FormlyFieldConfig, FormlyModule} from '@ngx-formly/core';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {Message} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {MessagesModule} from 'primeng/messages';\nimport {BehaviorSubject, Subscription, debounceTime, distinctUntilChanged, tap} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {CommonsService, CommonsStorageService, IdType, LoggerService, StyleLevelEnum, StyleSizeEnum, objectDeepCopy} from '@mediusinc/mng-commons/core';\nimport {ButtonStyleBuilder, ButtonStyleRoundedEnum} from '@mediusinc/mng-commons/form/api';\nimport {\n    CommonsFormlyFormOptions,\n    EditorDescriptorInst,\n    FormEditorPatchFieldValueOpts,\n    FormEditorResetFieldValueOpts,\n    FormEditorResetFormModelOpts,\n    FormEditorSetFieldValueOpts,\n    FormEditorSubmitEvent,\n    FormEventTypeEnum,\n    FormFieldEventComponentSubtype,\n    IFormEditorComponent,\n    TableviewEditorTypeEnum\n} from '@mediusinc/mng-commons/tableview/api';\n\nimport {generateAutosaveEditorKey} from '../../helpers/editor-autosave';\nimport {createFormlyConfigFromDescriptor} from '../../helpers/editor-formly';\nimport {getFormEditorInfoMessage, getFormEditorWarningMessage} from '../../helpers/notification';\nimport {EditorAutoSavePreviewModel, EditorAutoSaveStatus} from '../../models/editor-auto-save-preview.model';\nimport {FormEditorService, provideFormComponent} from '../../services/form-editor.service';\nimport {EditorAutoSaveStatusComponent} from './auto-save-status/auto-save-status.component';\n\n@Component({\n    standalone: true,\n    selector: 'mng-form-editor',\n    templateUrl: './form-editor.component.html',\n    imports: [FormlyModule, ReactiveFormsModule, MessagesModule, AsyncPipe, ButtonModule, TranslateModule, DatePipe, EditorAutoSaveStatusComponent],\n    providers: [provideFormComponent()],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormEditorComponent<Item = any, ParentItem = any> implements IFormEditorComponent<Item, ParentItem>, OnInit, OnDestroy {\n    private readonly formlyConfig = inject(FormlyConfig);\n    private readonly translateService = inject(TranslateService);\n    private readonly commons = inject(CommonsService);\n    public readonly cmpTypeName = 'FormEditorComponent';\n    private readonly logger = inject(LoggerService).create(this.cmpTypeName);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly formService = inject(FormEditorService<Item, ParentItem>);\n\n    private readonly commonsStorageService = inject(CommonsStorageService);\n    private readonly router = inject(Router);\n\n    private autoSaveStorageKeyCompInit = true;\n    private autoSaveStorageKey = computed(() => generateAutosaveEditorKey(this.descriptor(), this.item(), this.router.url, {editorId: this.editorId(), itemId: this.itemId()}));\n\n    public descriptor = input.required<EditorDescriptorInst<Item>>();\n    public submitLoading = input(false, {transform: booleanAttribute});\n    public item = model<Item | undefined>(undefined);\n    public isFormDisabled = input(false, {transform: booleanAttribute});\n    public editorId = input<string | undefined>(undefined);\n    public itemId = input<IdType | undefined>(undefined);\n    public showAutoSaveStatus = input(true, {transform: booleanAttribute});\n\n    // event outputs\n    public formSubmit = output<FormEditorSubmitEvent<Item>>();\n    public valueChange = output<Item>();\n    private autoSaveStatusSubject = new BehaviorSubject<EditorAutoSaveStatus>({state: 'initial', timestamp: new Date()});\n    public autoSaveStatus = outputFromObservable(this.autoSaveStatusSubject.asObservable());\n\n    // content and view queries\n    public submitButtonElementRef = viewChild<ElementRef | undefined>('submitButton');\n\n    // formly specifics\n    private readonly _form = new UntypedFormGroup({});\n    private readonly _formlyStateDisabledSubject = new BehaviorSubject(false);\n    private readonly _formlyOptions: CommonsFormlyFormOptions<Item> = {\n        formState: {\n            add: false,\n            edit: false,\n            disabled: false,\n            disabled$: this._formlyStateDisabledSubject.asObservable().pipe(distinctUntilChanged())\n        }\n    };\n    private _formlyFields: FormlyFieldConfig[] = []; // initialized in ngOnInit, should not be changed after\n    private _formlyInitialItem = {}; // initialized in ngOnInit, should not be changed after\n    private initialItemInput: Item | undefined;\n\n    private setterFields = computed(() => this.descriptor().fields.filter(f => typeof f.setter === 'function'));\n\n    public formMessages = signal<Message[]>([]);\n\n    // autosave\n    public readonly restoreLocalStateButtonStyle = ButtonStyleBuilder.create(StyleLevelEnum.Success, StyleSizeEnum.Small).build();\n    public readonly previewLocalStateButtonStyle = ButtonStyleBuilder.create(StyleLevelEnum.Info, StyleSizeEnum.Small).build();\n    public readonly clearLocalStateButtonStyle = ButtonStyleBuilder.create(StyleLevelEnum.Danger, StyleSizeEnum.Small)\n        .withRoundedButton(ButtonStyleRoundedEnum.SQUARE)\n        .withTextButton()\n        .build();\n    public autoSaveRestore = signal<EditorAutoSavePreviewModel<Item> | null>(null);\n    public autoSave = toSignal(this.autoSaveStatusSubject);\n    public autoSavePreviewButtonLabel = computed(() => {\n        switch (this.autoSave()?.state) {\n            case 'preview':\n                return 'mngEditor.autoSave.restore.previewCurrent';\n            case 'previewCurrent':\n                return 'mngEditor.autoSave.restore.previewAutosaved';\n            default:\n                return 'mngEditor.autoSave.restore.preview';\n        }\n    });\n    public autoSaveShowRestore = computed(() => this.autoSaveRestore()?.saved != null);\n    private autoSavePreviewDisabledForm = signal(false);\n    private autoSaveEventsSubscription?: Subscription;\n\n    get parent() {\n        return this.formService.parent;\n    }\n\n    get form(): FormGroup<{[K in keyof Item]: AbstractControl<Item[K]>}> {\n        return this._form;\n    }\n\n    get formUnsafe(): UntypedFormGroup {\n        return this._form;\n    }\n\n    get formlyOptions() {\n        return this._formlyOptions;\n    }\n\n    get formlyFields() {\n        return this._formlyFields;\n    }\n\n    /**\n     * Only used for form initialization. Further changes should be done using {resetFormModel}.\n     */\n    get formlyInitialItem() {\n        return this._formlyInitialItem;\n    }\n\n    constructor() {\n        this.formService.init(this);\n\n        effect(\n            () => {\n                const item = this.item();\n                if (item !== this.initialItemInput) {\n                    // new item is different from the one the form was initialized with. Must trigger reset of form model.\n                    this.resetFormModel(item);\n                }\n            },\n            // resetModel uses signal like concept\n            {allowSignalWrites: true}\n        );\n\n        effect(() => {\n            this._formlyOptions.formState.disabled =\n                this.isFormDisabled() || this.autoSavePreviewDisabledForm() || this._formlyOptions.formState.descriptor?.disabled === true || this._formlyOptions.formState.details;\n            untracked(() => {\n                this._formlyStateDisabledSubject.next(this._formlyOptions.formState.disabled);\n            });\n        });\n\n        effect(() => {\n            // eslint-disable-next-line @typescript-eslint/no-unused-vars\n            const key = this.autoSaveStorageKey();\n            untracked(() => {\n                this.autoSaveStopValueChangeListen();\n                this.autoSaveLoadSavedFromStorage();\n                this.autoSaveStartEventChangeListen(this.autoSaveStorageKeyCompInit);\n                this.autoSaveStorageKeyCompInit = false;\n            });\n        });\n    }\n\n    public ngOnInit() {\n        // init form state\n        if (this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Add) {\n            this._formlyOptions.formState.add = true;\n        } else if (this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Edit) {\n            this._formlyOptions.formState.edit = true;\n        } else if (this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Details) {\n            this._formlyOptions.formState.details = true;\n        }\n        this._formlyOptions.formState.descriptor = this.descriptor();\n\n        // init fields for formly\n        this._formlyFields = createFormlyConfigFromDescriptor(this.descriptor(), this.formlyConfig, this);\n\n        // int form model (only initial, no further changes to formModel should be allowed!)\n        this.initialItemInput = this.item();\n        this._formlyInitialItem = this.getFormModelFromItem(this.item());\n\n        // handle localizations edit/add message\n        if (\n            this.descriptor().isLocalized &&\n            (this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Add || this.descriptor().tableviewEditorType === TableviewEditorTypeEnum.Edit)\n        ) {\n            this.formMessages.set([\n                ...this.formMessages(),\n                getFormEditorInfoMessage(this.translateService, 'mngEditor.localizations.addInDefaultLanguageTitle', 'mngEditor.localizations.addInDefaultLanguageDescription', {\n                    defaultLanguage: this.commons.getDefaultLocale()\n                })\n            ]);\n        }\n\n        // emit lifecycle event\n        this.descriptor().nextEvent(FormEventTypeEnum.ComponentLifecycle, this as IFormEditorComponent<any>, {\n            eventSubtype: FormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this._form.valueChanges\n            .pipe(\n                debounceTime(100),\n                distinctUntilChanged(),\n                map(() => this._form.getRawValue()),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe(v => {\n                this.valueChange?.emit(v);\n                this.descriptor().nextEvent(FormEventTypeEnum.ValueChange, this as IFormEditorComponent<any>, {\n                    value: v,\n                    formValue: () => this.getFormValue()\n                });\n            });\n\n        // mark form as pristine, should be done in next event hook to allow formly to initialize first\n        setTimeout(() => {\n            this._form.markAsPristine();\n        });\n    }\n\n    public ngOnDestroy() {\n        // emit lifecycle event\n        this.descriptor().nextEvent(FormEventTypeEnum.ComponentLifecycle, this as IFormEditorComponent<any>, {\n            eventSubtype: FormFieldEventComponentSubtype.ON_DESTROY\n        });\n    }\n\n    public submit() {\n        this.submitButtonElementRef()?.nativeElement.click();\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    public onSubmit(event: Event) {\n        this._formlyOptions.formState.submittedOn = Date.now();\n        this.formMessages.set([]);\n\n        const formSubmitItem = this.getFormValue();\n        if (this._form.valid) {\n            this.formSubmit.emit({\n                success: true,\n                formItem: formSubmitItem\n            });\n            this.descriptor().nextEvent(FormEventTypeEnum.Submit, this as IFormEditorComponent<any>, {\n                submitValid: true,\n                submitValue: formSubmitItem\n            });\n            this.onAutoSaveDismiss();\n        } else {\n            // find and mark invalid tabs\n            const formFields = this._formlyFields;\n            if (formFields[0].type === 'tabs' && formFields[0].fieldGroup) {\n                for (const tab of formFields[0].fieldGroup) {\n                    this._formlyOptions.formState['tab_' + (tab.id ? tab.id : tab.key ?? '') + '_invalid'] = this.isAnyFieldInvalid(tab.fieldGroup);\n                }\n            }\n\n            const event: FormEditorSubmitEvent<Item> = {success: false, formItem: formSubmitItem};\n            event.success = false;\n            this.formMessages().push(getFormEditorWarningMessage(this.translateService, 'mngEditor.invalidFormToastTitle', 'mngEditor.invalidFormToastMessage'));\n\n            this.formSubmit.emit(event);\n            this.descriptor().nextEvent(FormEventTypeEnum.Submit, this as IFormEditorComponent<any>, {\n                submitValid: false,\n                submitValue: formSubmitItem\n            });\n        }\n    }\n\n    public getFormValue(opts?: {omitSetters?: boolean}): Item {\n        const formValue = objectDeepCopy(this._form.getRawValue(), {mapGettersToProperties: true});\n\n        if (opts?.omitSetters !== true) {\n            this.setterFields().forEach(field => {\n                const splitPath = field.property.split('.');\n                let fieldValue = formValue;\n                for (let i = 0; i < splitPath.length - 1; i++) {\n                    const currentSubPath = splitPath[i];\n                    if (typeof fieldValue[currentSubPath] !== 'object') {\n                        fieldValue[currentSubPath] = {};\n                    }\n\n                    fieldValue = fieldValue[currentSubPath];\n                }\n\n                fieldValue = fieldValue[splitPath[splitPath.length - 1]];\n                field.setter?.(formValue, fieldValue);\n            });\n        }\n\n        return formValue;\n    }\n\n    public resetFormModel(item?: Item, opts?: FormEditorResetFormModelOpts) {\n        this._formlyOptions.resetModel?.(this.getFormModelFromItem(item));\n\n        if (opts?.markAsPristine !== false) {\n            // mark form as pristine, should be done in next event hook to allow formly to initialize first\n            setTimeout(() => {\n                this._form.markAsPristine({onlySelf: opts?.onlySelf});\n            });\n        }\n    }\n\n    public getField(key: keyof Item) {\n        return this.getFieldUnsafe(key as string);\n    }\n\n    public getFieldUnsafe(key: string) {\n        return this.findFormField(this._form, key.split('.'));\n    }\n\n    public setFieldValue<Property extends keyof Item>(key: Property, value: Item[Property], opts?: FormEditorSetFieldValueOpts) {\n        return this.setFieldValueUnsafe(key as string, value, opts);\n    }\n\n    public setFieldValueUnsafe(key: string, value: any, opts?: FormEditorSetFieldValueOpts) {\n        const control = this.getFieldUnsafe(key);\n        if (control) {\n            control.setValue(value, opts);\n            return true;\n        } else {\n            this.logger.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public patchFieldValue<Property extends keyof Item>(key: Property, value: Item[Property], opts?: FormEditorPatchFieldValueOpts) {\n        return this.patchFieldValueUnsafe(key as string, value, opts);\n    }\n\n    public patchFieldValueUnsafe(key: string, value: any, opts?: FormEditorPatchFieldValueOpts) {\n        const control = this.getFieldUnsafe(key);\n        if (control) {\n            control.patchValue(value, opts);\n            return true;\n        } else {\n            this.logger.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public resetFieldValue<Property extends keyof Item>(key: Property, value?: Item[Property], opts?: FormEditorResetFieldValueOpts) {\n        return this.resetFieldValueUnsafe(key as string, value, opts);\n    }\n\n    public resetFieldValueUnsafe(key: string, value?: any, opts?: FormEditorResetFieldValueOpts) {\n        const control = this.getFieldUnsafe(key);\n        if (control) {\n            control.reset(value, opts);\n            return true;\n        } else {\n            this.logger.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    /**\n     * Restores the saved local state.\n     * If local storage keys exist for local state and local timestamp, restore their corresponding values.\n     */\n    public onAutoSaveRestore() {\n        const restore = this.autoSaveRestore();\n        if (restore?.saved) {\n            this.autoSaveStopValueChangeListen();\n            this.resetFormModel(restore.saved);\n            this.autoSaveRestore.set(null);\n            this.autoSaveStatusSubject.next({state: 'restored', timestamp: restore.savedAt ?? new Date()});\n            this.autoSavePreviewDisabledForm.set(false);\n            this.autoSaveStartEventChangeListen();\n        }\n    }\n\n    /**\n     * Previews the saved local state.\n     * If local storage keys exist for local state and local timestamp, restore their corresponding values.\n     */\n    public onAutoSavePreview() {\n        if (!this.autoSaveRestore()?.saved) {\n            return;\n        }\n\n        this.autoSaveStopValueChangeListen();\n        this.autoSavePreviewDisabledForm.set(true);\n        const state = this.autoSaveStatusSubject.value.state;\n        if (state !== 'preview' && state !== 'previewCurrent') {\n            // must store original value from current value form\n            this.autoSaveRestore.update(i => ({...i, original: this.getFormValue()}));\n        }\n\n        const restore = this.autoSaveRestore();\n        if (state === 'preview' && restore?.original) {\n            this.resetFormModel(restore.original);\n            this.autoSaveStatusSubject.next({state: 'previewCurrent'});\n        } else if (state !== 'preview' && restore?.saved) {\n            this.resetFormModel(restore.saved);\n            this.autoSaveStatusSubject.next({state: 'preview', timestamp: restore.savedAt ?? new Date()});\n        }\n    }\n\n    /**\n     * Removes local state from local storage.\n     * If local storage keys exist for local state and local timestamp, remove their corresponding values.\n     */\n    public onAutoSaveDismiss(): void {\n        if (this.autoSaveStorageKey()) {\n            const restore = this.autoSaveRestore();\n            if (this.autoSaveStatusSubject.value.state === 'preview' && restore?.original) {\n                this.resetFormModel(restore.original);\n                this.autoSaveStatusSubject.next({state: 'initial', timestamp: new Date()});\n            }\n            this.commonsStorageService.removeItem(this.cmpTypeName, this.autoSaveStorageKey());\n            this.autoSaveRestore.set(null);\n            this.autoSavePreviewDisabledForm.set(false);\n            this.autoSaveStartEventChangeListen();\n        }\n    }\n\n    private getFormModelFromItem(item: Item | undefined): any {\n        const formModel = (objectDeepCopy(item, {mapGettersToProperties: true}) as Record<string, any>) ?? {};\n\n        const descriptor = this.descriptor();\n        descriptor.fields.forEach(field => {\n            if (field.getter && item) {\n                const splitPath = field.property.split('.');\n                let currentObject = formModel;\n\n                for (let i = 0; i < splitPath.length; i++) {\n                    const currentSubPath = splitPath[i];\n                    if (i === splitPath.length - 1) {\n                        currentObject[currentSubPath] = field.getter(item?.[field.property as keyof object], item);\n                    } else {\n                        if (typeof currentObject[currentSubPath] !== 'object') {\n                            currentObject[currentSubPath] = {};\n                        }\n\n                        currentObject = currentObject[currentSubPath];\n                    }\n                }\n            }\n        });\n\n        return formModel;\n    }\n\n    private findFormField(control: AbstractControl, keyPath: string[]): AbstractControl | null {\n        if (keyPath.length === 0) {\n            return control;\n        }\n        if (keyPath.length === 1) {\n            return control.get(keyPath[0]);\n        }\n        let nextControl: AbstractControl | null = null;\n        if (control instanceof FormGroup) {\n            nextControl = control.get(keyPath[0]);\n        } else if (control instanceof FormArray) {\n            const idx = +keyPath[0];\n            if (!isNaN(idx)) {\n                nextControl = control.at(idx);\n            }\n        }\n\n        if (!control) {\n            return null;\n        }\n        return this.findFormField(nextControl!, keyPath.slice(1));\n    }\n\n    private isAnyFieldInvalid(fields: FormlyFieldConfig[] = []): boolean {\n        for (const field of fields) {\n            let fieldInvalid = false;\n            if (Array.isArray(field.fieldGroup)) {\n                fieldInvalid = this.isAnyFieldInvalid(field.fieldGroup);\n            } else if (typeof field.type !== 'undefined') {\n                fieldInvalid = !field.formControl?.valid;\n            }\n            if (fieldInvalid) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    private autoSaveStartEventChangeListen(init = false) {\n        if (!this.descriptor().autoSave) {\n            return;\n        }\n\n        setTimeout(\n            () => {\n                if (!this.autoSaveEventsSubscription) {\n                    this.autoSaveEventsSubscription = this._form.valueChanges\n                        .pipe(\n                            debounceTime(250),\n                            distinctUntilChanged(),\n                            // skip first one on init\n                            tap(() => {\n                                if (this.autoSaveStatusSubject.value.state !== 'saved' && this.autoSaveStatusSubject.value.state !== 'preview')\n                                    this.autoSaveStatusSubject.next({...this.autoSaveStatusSubject.value, state: 'saving'});\n                            }),\n                            debounceTime(750),\n                            takeUntilDestroyed(this.destroyRef)\n                        )\n                        .subscribe(() => {\n                            this.autoSaveSaveToStorage();\n                        });\n                }\n            },\n            init ? 0 : 500 // delay initial event listening for all the initializations to take place\n        );\n    }\n\n    private autoSaveStopValueChangeListen() {\n        this.autoSaveEventsSubscription?.unsubscribe();\n        this.autoSaveEventsSubscription = undefined;\n    }\n\n    /**\n     * Saves the form value to localStorage if autoSave is enabled and the required keys are defined.\n     * @returns {void}\n     */\n    private autoSaveSaveToStorage(): void {\n        if (this.descriptor().autoSave !== true || this.autoSaveStatusSubject.value.state === 'preview' || this.autoSaveStatusSubject.value.state === 'previewCurrent') {\n            return;\n        }\n\n        this.commonsStorageService.setItem<EditorAutoSavePreviewModel<Item>>(this.cmpTypeName, this.autoSaveStorageKey(), {saved: this.getFormValue(), savedAt: new Date()});\n        this.autoSaveStatusSubject.next({state: 'saved', timestamp: new Date()});\n    }\n\n    /**\n     * Loads the value from the local storage if available\n     */\n    private autoSaveLoadSavedFromStorage(): void {\n        const {autoSave, model} = this.descriptor();\n        if (autoSave && model.i18nBaseKey) {\n            this.autoSaveRestore.set(this.commonsStorageService.getItem<EditorAutoSavePreviewModel<Item>>(this.cmpTypeName, this.autoSaveStorageKey()) ?? null);\n        }\n    }\n}\n","@if (autoSaveShowRestore()) {\n    <p-messages severity=\"warn\">\n        <ng-template pTemplate>\n            <div class=\"flex flex-grow-1 justify-content-between align-items-center\">\n                <h6 class=\"m-0 p-0\">\n                    <em class=\"pi pi-save mr-4\"></em>\n                    {{\n                        'mngEditor.autoSave.restore.title'\n                            | translate: {lastChange: autoSaveRestore()?.savedAt ? (autoSaveRestore()?.savedAt! | date: 'dd. MM. YYYY HH:mm:ss') : ''}\n                    }}\n                </h6>\n                <div>\n                    <p-button\n                        icon=\"pi pi-sync\"\n                        size=\"small\"\n                        [label]=\"'mngEditor.autoSave.restore.restore' | translate\"\n                        [styleClass]=\"restoreLocalStateButtonStyle\"\n                        [text]=\"true\"\n                        (click)=\"onAutoSaveRestore()\"></p-button>\n                    @if (autoSave()?.state !== 'preview' || autoSave()?.state !== 'previewCurrent') {\n                        <p-button\n                            icon=\"pi pi-eye\"\n                            size=\"small\"\n                            [label]=\"autoSavePreviewButtonLabel() | translate\"\n                            [styleClass]=\"previewLocalStateButtonStyle\"\n                            [text]=\"true\"\n                            (click)=\"onAutoSavePreview()\"></p-button>\n                    }\n                    <p-button\n                        icon=\"pi pi-times\"\n                        size=\"small\"\n                        [label]=\"'mngEditor.autoSave.restore.dismiss' | translate\"\n                        [styleClass]=\"clearLocalStateButtonStyle\"\n                        (click)=\"onAutoSaveDismiss()\"></p-button>\n                </div>\n            </div>\n        </ng-template>\n    </p-messages>\n}\n\n<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n    <formly-form [form]=\"form\" [fields]=\"formlyFields\" [options]=\"formlyOptions\" [model]=\"formlyInitialItem\"></formly-form>\n    <button #submitButton pButton type=\"submit\" class=\"hidden\" [disabled]=\"form.disabled\" [loading]=\"submitLoading()\" loadingIcon=\"pi pi-spin pi-spinner\"></button>\n</form>\n<p-messages [value]=\"formMessages()\" [enableService]=\"false\"></p-messages>\n\n@if (descriptor().autoSave && showAutoSaveStatus()) {\n    <mng-editor-auto-save-status [status]=\"autoSave()\"></mng-editor-auto-save-status>\n}\n"]}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { TableviewEditorTypeEnum } from '@mediusinc/mng-commons/tableview/api';
|
|
2
|
+
/**
|
|
3
|
+
* Generates a unique key for autosave data of an editor.
|
|
4
|
+
*
|
|
5
|
+
* @param {EditorDescriptorInst<Item>} descriptor - The editor descriptor instance.
|
|
6
|
+
* @param {Item | undefined} item - The item associated with the editor.
|
|
7
|
+
* @param {string} url - The URL of the editor.
|
|
8
|
+
* @param {Object} [opts] - An optional object containing additional options.
|
|
9
|
+
* @param {string} [opts.editorId] - The custom editor ID.
|
|
10
|
+
* @param {IdType} [opts.itemId] - The custom item ID.
|
|
11
|
+
* @return {string} - The generated autosave editor key.
|
|
12
|
+
*/
|
|
13
|
+
export function generateAutosaveEditorKey(descriptor, item, url, opts) {
|
|
14
|
+
const autoSaveIdentifier = descriptor.autoSaveIdentifier ?? url;
|
|
15
|
+
const editorId = generateEditorId(descriptor, opts?.editorId);
|
|
16
|
+
const itemId = generateItemId(descriptor, item, opts?.itemId);
|
|
17
|
+
return `autoSave~~${editorId}${itemId}~~${autoSaveIdentifier}`;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Generates an ID for the editor based on the provided parameters.
|
|
21
|
+
*
|
|
22
|
+
* @template Item - The type of the item.
|
|
23
|
+
* @param {EditorDescriptorInst<Item>} descriptor - The editor descriptor instance.
|
|
24
|
+
* @param {string} [editorId] - The optional editor ID.
|
|
25
|
+
* @returns {string} - The generated editor ID.
|
|
26
|
+
*/
|
|
27
|
+
function generateEditorId({ model, tableviewEditorType }, editorId) {
|
|
28
|
+
if (editorId !== undefined) {
|
|
29
|
+
return editorId;
|
|
30
|
+
}
|
|
31
|
+
const editorTypeString = TableviewEditorTypeEnum[tableviewEditorType ?? TableviewEditorTypeEnum.None];
|
|
32
|
+
return `${model.i18nBaseKey}::${editorTypeString}`;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Generates an item ID.
|
|
36
|
+
*
|
|
37
|
+
* @param {EditorDescriptorInst<Item>} model - The model descriptor.
|
|
38
|
+
* @param {Item} [item] - The item to generate an ID for.
|
|
39
|
+
* @param {IdType} [itemId] - The existing item ID (if any).
|
|
40
|
+
* @returns {string} - The generated item ID, prefixed with "::" or an empty string if no item ID exists.
|
|
41
|
+
*/
|
|
42
|
+
function generateItemId({ model }, item, itemId) {
|
|
43
|
+
if (itemId === undefined && item) {
|
|
44
|
+
const idProperty = model?.idProperty;
|
|
45
|
+
itemId = item?.[idProperty]?.toString();
|
|
46
|
+
}
|
|
47
|
+
return itemId ? `::${itemId}` : '';
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLWF1dG9zYXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vdGFibGV2aWV3L3NyYy9lZGl0b3IvaGVscGVycy9lZGl0b3ItYXV0b3NhdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUF1Qix1QkFBdUIsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBRW5HOzs7Ozs7Ozs7O0dBVUc7QUFDSCxNQUFNLFVBQVUseUJBQXlCLENBQU8sVUFBc0MsRUFBRSxJQUFzQixFQUFFLEdBQVcsRUFBRSxJQUEyQztJQUNwSyxNQUFNLGtCQUFrQixHQUFHLFVBQVUsQ0FBQyxrQkFBa0IsSUFBSSxHQUFHLENBQUM7SUFDaEUsTUFBTSxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQztJQUM5RCxNQUFNLE1BQU0sR0FBRyxjQUFjLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDOUQsT0FBTyxhQUFhLFFBQVEsR0FBRyxNQUFNLEtBQUssa0JBQWtCLEVBQUUsQ0FBQztBQUNuRSxDQUFDO0FBRUQ7Ozs7Ozs7R0FPRztBQUNILFNBQVMsZ0JBQWdCLENBQU8sRUFBQyxLQUFLLEVBQUUsbUJBQW1CLEVBQTZCLEVBQUUsUUFBaUI7SUFDdkcsSUFBSSxRQUFRLEtBQUssU0FBUyxFQUFFLENBQUM7UUFDekIsT0FBTyxRQUFRLENBQUM7SUFDcEIsQ0FBQztJQUNELE1BQU0sZ0JBQWdCLEdBQUcsdUJBQXVCLENBQUMsbUJBQW1CLElBQUksdUJBQXVCLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdEcsT0FBTyxHQUFHLEtBQUssQ0FBQyxXQUFXLEtBQUssZ0JBQWdCLEVBQUUsQ0FBQztBQUN2RCxDQUFDO0FBRUQ7Ozs7Ozs7R0FPRztBQUNILFNBQVMsY0FBYyxDQUFPLEVBQUMsS0FBSyxFQUE2QixFQUFFLElBQVcsRUFBRSxNQUFlO0lBQzNGLElBQUksTUFBTSxLQUFLLFNBQVMsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUMvQixNQUFNLFVBQVUsR0FBRyxLQUFLLEVBQUUsVUFBVSxDQUFDO1FBQ3JDLE1BQU0sR0FBRyxJQUFJLEVBQUUsQ0FBQyxVQUErQixDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUM7SUFDakUsQ0FBQztJQUNELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxLQUFLLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7QUFDdkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SWRUeXBlfSBmcm9tICdAbWVkaXVzaW5jL21uZy1jb21tb25zL2NvcmUnO1xuaW1wb3J0IHtFZGl0b3JEZXNjcmlwdG9ySW5zdCwgVGFibGV2aWV3RWRpdG9yVHlwZUVudW19IGZyb20gJ0BtZWRpdXNpbmMvbW5nLWNvbW1vbnMvdGFibGV2aWV3L2FwaSc7XG5cbi8qKlxuICogR2VuZXJhdGVzIGEgdW5pcXVlIGtleSBmb3IgYXV0b3NhdmUgZGF0YSBvZiBhbiBlZGl0b3IuXG4gKlxuICogQHBhcmFtIHtFZGl0b3JEZXNjcmlwdG9ySW5zdDxJdGVtPn0gZGVzY3JpcHRvciAtIFRoZSBlZGl0b3IgZGVzY3JpcHRvciBpbnN0YW5jZS5cbiAqIEBwYXJhbSB7SXRlbSB8IHVuZGVmaW5lZH0gaXRlbSAtIFRoZSBpdGVtIGFzc29jaWF0ZWQgd2l0aCB0aGUgZWRpdG9yLlxuICogQHBhcmFtIHtzdHJpbmd9IHVybCAtIFRoZSBVUkwgb2YgdGhlIGVkaXRvci5cbiAqIEBwYXJhbSB7T2JqZWN0fSBbb3B0c10gLSBBbiBvcHRpb25hbCBvYmplY3QgY29udGFpbmluZyBhZGRpdGlvbmFsIG9wdGlvbnMuXG4gKiBAcGFyYW0ge3N0cmluZ30gW29wdHMuZWRpdG9ySWRdIC0gVGhlIGN1c3RvbSBlZGl0b3IgSUQuXG4gKiBAcGFyYW0ge0lkVHlwZX0gW29wdHMuaXRlbUlkXSAtIFRoZSBjdXN0b20gaXRlbSBJRC5cbiAqIEByZXR1cm4ge3N0cmluZ30gLSBUaGUgZ2VuZXJhdGVkIGF1dG9zYXZlIGVkaXRvciBrZXkuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZUF1dG9zYXZlRWRpdG9yS2V5PEl0ZW0+KGRlc2NyaXB0b3I6IEVkaXRvckRlc2NyaXB0b3JJbnN0PEl0ZW0+LCBpdGVtOiBJdGVtIHwgdW5kZWZpbmVkLCB1cmw6IHN0cmluZywgb3B0cz86IHtlZGl0b3JJZD86IHN0cmluZzsgaXRlbUlkPzogSWRUeXBlfSk6IHN0cmluZyB7XG4gICAgY29uc3QgYXV0b1NhdmVJZGVudGlmaWVyID0gZGVzY3JpcHRvci5hdXRvU2F2ZUlkZW50aWZpZXIgPz8gdXJsO1xuICAgIGNvbnN0IGVkaXRvcklkID0gZ2VuZXJhdGVFZGl0b3JJZChkZXNjcmlwdG9yLCBvcHRzPy5lZGl0b3JJZCk7XG4gICAgY29uc3QgaXRlbUlkID0gZ2VuZXJhdGVJdGVtSWQoZGVzY3JpcHRvciwgaXRlbSwgb3B0cz8uaXRlbUlkKTtcbiAgICByZXR1cm4gYGF1dG9TYXZlfn4ke2VkaXRvcklkfSR7aXRlbUlkfX5+JHthdXRvU2F2ZUlkZW50aWZpZXJ9YDtcbn1cblxuLyoqXG4gKiBHZW5lcmF0ZXMgYW4gSUQgZm9yIHRoZSBlZGl0b3IgYmFzZWQgb24gdGhlIHByb3ZpZGVkIHBhcmFtZXRlcnMuXG4gKlxuICogQHRlbXBsYXRlIEl0ZW0gLSBUaGUgdHlwZSBvZiB0aGUgaXRlbS5cbiAqIEBwYXJhbSB7RWRpdG9yRGVzY3JpcHRvckluc3Q8SXRlbT59IGRlc2NyaXB0b3IgLSBUaGUgZWRpdG9yIGRlc2NyaXB0b3IgaW5zdGFuY2UuXG4gKiBAcGFyYW0ge3N0cmluZ30gW2VkaXRvcklkXSAtIFRoZSBvcHRpb25hbCBlZGl0b3IgSUQuXG4gKiBAcmV0dXJucyB7c3RyaW5nfSAtIFRoZSBnZW5lcmF0ZWQgZWRpdG9yIElELlxuICovXG5mdW5jdGlvbiBnZW5lcmF0ZUVkaXRvcklkPEl0ZW0+KHttb2RlbCwgdGFibGV2aWV3RWRpdG9yVHlwZX06IEVkaXRvckRlc2NyaXB0b3JJbnN0PEl0ZW0+LCBlZGl0b3JJZD86IHN0cmluZyk6IHN0cmluZyB7XG4gICAgaWYgKGVkaXRvcklkICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgcmV0dXJuIGVkaXRvcklkO1xuICAgIH1cbiAgICBjb25zdCBlZGl0b3JUeXBlU3RyaW5nID0gVGFibGV2aWV3RWRpdG9yVHlwZUVudW1bdGFibGV2aWV3RWRpdG9yVHlwZSA/PyBUYWJsZXZpZXdFZGl0b3JUeXBlRW51bS5Ob25lXTtcbiAgICByZXR1cm4gYCR7bW9kZWwuaTE4bkJhc2VLZXl9Ojoke2VkaXRvclR5cGVTdHJpbmd9YDtcbn1cblxuLyoqXG4gKiBHZW5lcmF0ZXMgYW4gaXRlbSBJRC5cbiAqXG4gKiBAcGFyYW0ge0VkaXRvckRlc2NyaXB0b3JJbnN0PEl0ZW0+fSBtb2RlbCAtIFRoZSBtb2RlbCBkZXNjcmlwdG9yLlxuICogQHBhcmFtIHtJdGVtfSBbaXRlbV0gLSBUaGUgaXRlbSB0byBnZW5lcmF0ZSBhbiBJRCBmb3IuXG4gKiBAcGFyYW0ge0lkVHlwZX0gW2l0ZW1JZF0gLSBUaGUgZXhpc3RpbmcgaXRlbSBJRCAoaWYgYW55KS5cbiAqIEByZXR1cm5zIHtzdHJpbmd9IC0gVGhlIGdlbmVyYXRlZCBpdGVtIElELCBwcmVmaXhlZCB3aXRoIFwiOjpcIiBvciBhbiBlbXB0eSBzdHJpbmcgaWYgbm8gaXRlbSBJRCBleGlzdHMuXG4gKi9cbmZ1bmN0aW9uIGdlbmVyYXRlSXRlbUlkPEl0ZW0+KHttb2RlbH06IEVkaXRvckRlc2NyaXB0b3JJbnN0PEl0ZW0+LCBpdGVtPzogSXRlbSwgaXRlbUlkPzogSWRUeXBlKTogc3RyaW5nIHtcbiAgICBpZiAoaXRlbUlkID09PSB1bmRlZmluZWQgJiYgaXRlbSkge1xuICAgICAgICBjb25zdCBpZFByb3BlcnR5ID0gbW9kZWw/LmlkUHJvcGVydHk7XG4gICAgICAgIGl0ZW1JZCA9IGl0ZW0/LltpZFByb3BlcnR5IGFzIGtleW9mIHR5cGVvZiBpdGVtXT8udG9TdHJpbmcoKTtcbiAgICB9XG4gICAgcmV0dXJuIGl0ZW1JZCA/IGA6OiR7aXRlbUlkfWAgOiAnJztcbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLWF1dG8tc2F2ZS1wcmV2aWV3Lm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vdGFibGV2aWV3L3NyYy9lZGl0b3IvbW9kZWxzL2VkaXRvci1hdXRvLXNhdmUtcHJldmlldy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBFZGl0b3JBdXRvU2F2ZVByZXZpZXdNb2RlbDxJdGVtPiB7XG4gICAgc2F2ZWQ/OiBJdGVtO1xuICAgIG9yaWdpbmFsPzogSXRlbTtcbiAgICBzYXZlZEF0PzogRGF0ZTtcbn1cblxuZXhwb3J0IHR5cGUgRWRpdG9yQXV0b1NhdmVTdGF0ZXMgPSAnaW5pdGlhbCcgfCAnc2F2ZWQnIHwgJ3NhdmluZycgfCAncHJldmlldycgfCAncHJldmlld0N1cnJlbnQnIHwgJ3Jlc3RvcmVkJztcblxuZXhwb3J0IGludGVyZmFjZSBFZGl0b3JBdXRvU2F2ZVN0YXR1cyB7XG4gICAgc3RhdGU6IEVkaXRvckF1dG9TYXZlU3RhdGVzO1xuICAgIHRpbWVzdGFtcD86IERhdGU7XG59XG4iXX0=
|
|
@@ -93,4 +93,4 @@ export function provideFormComponent() {
|
|
|
93
93
|
deps: [Injector]
|
|
94
94
|
};
|
|
95
95
|
}
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-editor.service.js","sourceRoot":"","sources":["../../../../../tableview/src/editor/services/form-editor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable, Injector, InputSignal, InputSignalWithTransform, Provider, WritableSignal} from '@angular/core';\nimport {AbstractControl, FormGroup, UntypedFormGroup} from '@angular/forms';\n\nimport {FormlyFieldConfig, FormlyFormOptions} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\n\nimport {CommonsInternalError} from '@mediusinc/mng-commons/core';\nimport {CommonsFormlyFormOptions, EditorDescriptorInst, FormEditorGetFormValueOpts, FormEditorResetFormModelOpts, IFormEditorComponent} from '@mediusinc/mng-commons/tableview/api';\n\n@Injectable()\nexport class FormEditorService<Item, ParentItem = any> implements IFormEditorComponent<Item, ParentItem> {\n    private readonly _parentForm?: FormEditorService<ParentItem, any>;\n    private _formComponent?: IFormEditorComponent<Item>;\n\n    public get parent(): IFormEditorComponent<ParentItem> | undefined {\n        return this._parentForm;\n    }\n\n    public get parentService() {\n        return this._parentForm;\n    }\n\n    public get formComponent(): IFormEditorComponent<Item> {\n        if (!this._formComponent) {\n            throw new CommonsInternalError(`Form service was not initialized`);\n        }\n        return this._formComponent;\n    }\n\n    public get descriptor(): InputSignal<EditorDescriptorInst<Item>> {\n        return this.formComponent.descriptor;\n    }\n\n    public get isFormDisabled(): InputSignalWithTransform<boolean, unknown> {\n        return this.formComponent.isFormDisabled;\n    }\n\n    public get formMessages(): WritableSignal<Message[]> {\n        return this.formComponent.formMessages;\n    }\n\n    public get form(): FormGroup<{\n        [K in keyof Item]: AbstractControl<Item[K]>;\n    }> {\n        return this.formComponent.form;\n    }\n\n    public get formUnsafe(): UntypedFormGroup {\n        return this.formComponent.formUnsafe;\n    }\n\n    public get formlyOptions(): FormlyFormOptions & CommonsFormlyFormOptions<Item> {\n        return this.formComponent.formlyOptions;\n    }\n\n    public get formlyFields(): FormlyFieldConfig[] {\n        return this.formComponent.formlyFields;\n    }\n\n    public get formlyInitialItem(): any {\n        return this.formComponent.formlyInitialItem;\n    }\n\n    public submit(): void {\n        this.formComponent.submit();\n    }\n\n    public getFormValue(opts?: FormEditorGetFormValueOpts): Item {\n        return this.formComponent.getFormValue(opts);\n    }\n\n    public resetFormModel(item?: Item, opts?: FormEditorResetFormModelOpts): void {\n        this.formComponent.resetFormModel(item, opts);\n    }\n\n    public getField(key: keyof Item): AbstractControl | null {\n        return this.formComponent.getField(key);\n    }\n\n    public getFieldUnsafe(key: string): AbstractControl | null {\n        return this.formComponent.getFieldUnsafe(key);\n    }\n\n    public setFieldValue<Property extends keyof Item>(key: Property, value: Item[Property]): boolean {\n        return this.formComponent.setFieldValue(key, value);\n    }\n\n    public setFieldValueUnsafe(key: string, value: any): boolean {\n        return this.formComponent.setFieldValueUnsafe(key, value);\n    }\n\n    public patchFieldValue<Property extends keyof Item>(key: Property, value: Item[Property]): boolean {\n        return this.formComponent.patchFieldValue(key, value);\n    }\n\n    public patchFieldValueUnsafe(key: string, value: any): boolean {\n        return this.formComponent.patchFieldValueUnsafe(key, value);\n    }\n\n    public resetFieldValue<Property extends keyof Item>(key: Property, value?: Item[Property]): boolean {\n        return this.formComponent.resetFieldValue(key, value);\n    }\n\n    public resetFieldValueUnsafe(key: string, value?: any): boolean {\n        return this.formComponent.resetFieldValueUnsafe(key, value);\n    }\n\n    public constructor(parentForm?: FormEditorService<ParentItem>) {\n        this._parentForm = parentForm;\n    }\n\n    public init(formComponent: IFormEditorComponent<Item>) {\n        this._formComponent = formComponent;\n    }\n}\n\nexport function provideFormComponent(): Provider {\n    return {\n        provide: FormEditorService,\n        useFactory: (injector: Injector) => {\n            const parent = injector.get(FormEditorService, null, {optional: true, skipSelf: true});\n            return new FormEditorService<any>(parent ?? undefined);\n        },\n        deps: [Injector]\n    };\n}\n"]}
|