@mediusinc/mng-commons 0.21.0-rc.1 → 0.21.0-rc.2

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 (28) hide show
  1. package/assets/i18n/en.json +12 -2
  2. package/assets/i18n/sl.json +15 -5
  3. package/esm2020/lib/components/form/editor/form-editor.component.mjs +16 -13
  4. package/esm2020/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +5 -5
  5. package/esm2020/lib/components/tableview/table/table.component.mjs +4 -14
  6. package/esm2020/lib/data-providers/tableview.data-provider.mjs +1 -1
  7. package/esm2020/lib/descriptors/field.descriptor.mjs +2 -2
  8. package/esm2020/lib/descriptors/tableview.descriptor.mjs +5 -1
  9. package/esm2020/lib/mng-commons.module.mjs +5 -4
  10. package/esm2020/lib/pipes/index.mjs +2 -1
  11. package/esm2020/lib/pipes/mngLocaleDefaultRowClass.pipe.mjs +26 -0
  12. package/esm2020/lib/services/commons.service.mjs +2 -2
  13. package/esm2020/lib/utils/notification.util.mjs +6 -1
  14. package/fesm2015/mediusinc-mng-commons.mjs +75 -49
  15. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
  16. package/fesm2020/mediusinc-mng-commons.mjs +73 -48
  17. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
  18. package/lib/components/form/editor/form-editor.component.d.ts +3 -1
  19. package/lib/components/tableview/table/table.component.d.ts +0 -1
  20. package/lib/mng-commons.module.d.ts +43 -42
  21. package/lib/pipes/index.d.ts +1 -0
  22. package/lib/pipes/mngLocaleDefaultRowClass.pipe.d.ts +10 -0
  23. package/lib/utils/notification.util.d.ts +1 -0
  24. package/{mediusinc-mng-commons-0.21.0-rc.1.tgz → mediusinc-mng-commons-0.21.0-rc.2.tgz} +0 -0
  25. package/package.json +1 -1
  26. package/scss/mng-overrides/_theme_datatable.scss +6 -0
  27. package/scss/mng-overrides/_theme_forms.scss +8 -0
  28. package/version-info.json +5 -5
@@ -60,8 +60,9 @@
60
60
  },
61
61
  "showTranslations": "All translations",
62
62
  "localizations": {
63
- "addInDefaultLanguageTitle": "Warning",
64
- "addInDefaultLanguageDescription": "Adding a new value is supported only in default language."
63
+ "localizationTableviewTitle": "Translations: {{fieldName}}",
64
+ "addInDefaultLanguageTitle": "",
65
+ "addInDefaultLanguageDescription": "Localized item values will be saved in default language ({{defaultLanguage}}). To change values for different locales, open the translations dialog for desired field."
65
66
  },
66
67
  "imageUrlPlaceholder": "Insert image URL ...",
67
68
  "imageUrlAdd": "Add image URL"
@@ -138,6 +139,15 @@
138
139
  "export": {
139
140
  "title": "Export"
140
141
  },
142
+ "localization-details": {
143
+ "title": "Translations"
144
+ },
145
+ "localized-edit": {
146
+ "title": "Translations"
147
+ },
148
+ "localizations-add": {
149
+ "title": "Translations"
150
+ },
141
151
  "mngPrime": {
142
152
  "startsWith": "Starts with",
143
153
  "contains": "Contains",
@@ -23,8 +23,7 @@
23
23
  "general": "Splošno",
24
24
  "searchItem": "{{item}} - išči",
25
25
  "search": "Išči",
26
- "select": "Izberi",
27
- "missingTranslation": "Manjka prevod. Prikazana je privzeta vrednost."
26
+ "select": "Izberi"
28
27
  },
29
28
  "languages": {
30
29
  "en": "English",
@@ -58,10 +57,12 @@
58
57
  "pattern": "Vnos se mora ujemati z vzorcem '{{pattern}}'.",
59
58
  "email": "Neveljaven e-naslov."
60
59
  },
61
- "showTranslations": "Vsi prevodi",
62
60
  "localizations": {
63
- "addInDefaultLanguageTitle": "Pozor",
64
- "addInDefaultLanguageDescription": "Dodajanje nove vrednosti je podprto samo v standardnem jeziku."
61
+ "showTranslations": "Vsi prevodi",
62
+ "missingTranslation": "Manjka prevod. Prikazana je privzeta vrednost.",
63
+ "localizationTableviewTitle": "Prevodi: {{fieldName}}",
64
+ "addInDefaultLanguageTitle": "",
65
+ "addInDefaultLanguageDescription": "Lokalizirane vrednosti bodo shranjene v privzetem jeziku ({{defaultLanguage}}). Če želite urejati vrednosti za različne prevode, odprite pogovorno okno prevodov za želeno polje."
65
66
  },
66
67
  "imageUrlPlaceholder": "Vnesi URL do slike ...",
67
68
  "imageUrlAdd": "Dodaj URL slike"
@@ -138,6 +139,15 @@
138
139
  "export": {
139
140
  "title": "Izvozi"
140
141
  },
142
+ "localization-details": {
143
+ "title": "Prevodi"
144
+ },
145
+ "localized-edit": {
146
+ "title": "Prevodi"
147
+ },
148
+ "localizations-add": {
149
+ "title": "Prevodi"
150
+ },
141
151
  "mngPrime": {
142
152
  "startsWith": "Se začne z",
143
153
  "contains": "Vsebuje",
@@ -6,14 +6,16 @@ import { MngTemplateDirective } from '../../../directives';
6
6
  import { EditorFormlyUtil, NotificationUtil } from '../../../utils';
7
7
  import { MngFormEditorSubmitEvent } from '../models';
8
8
  import * as i0 from "@angular/core";
9
- import * as i1 from "@ngx-translate/core";
10
- import * as i2 from "@angular/forms";
11
- import * as i3 from "@ngx-formly/core";
12
- import * as i4 from "primeng/button";
13
- import * as i5 from "primeng/messages";
14
- import * as i6 from "@angular/common";
9
+ import * as i1 from "../../../services";
10
+ import * as i2 from "@ngx-translate/core";
11
+ import * as i3 from "@angular/forms";
12
+ import * as i4 from "@ngx-formly/core";
13
+ import * as i5 from "primeng/button";
14
+ import * as i6 from "primeng/messages";
15
+ import * as i7 from "@angular/common";
15
16
  export class MngFormEditorComponent {
16
- constructor(translateService) {
17
+ constructor(mngCommonsService, translateService) {
18
+ this.mngCommonsService = mngCommonsService;
17
19
  this.translateService = translateService;
18
20
  this.submitLoading = false;
19
21
  // extra features input
@@ -41,8 +43,9 @@ export class MngFormEditorComponent {
41
43
  this.formFields = EditorFormlyUtil.createFormlyConfigFromDescriptor(this.descriptor, this);
42
44
  this.updateFormState();
43
45
  // let the user know, that adding new value in table view with localizations is only supported in the default language
44
- if (this.descriptor.isLocalized && this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Add) {
45
- this.formMessages.push(NotificationUtil.getFormEditorWarningMessage(this.translateService, 'mngEditor.localizations.addInDefaultLanguageTitle', 'mngEditor.localizations.addInDefaultLanguageDescription'));
46
+ if (this.descriptor.isLocalized &&
47
+ (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Add || this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Edit)) {
48
+ this.formMessages.push(NotificationUtil.getFormEditorInfoMessage(this.translateService, 'mngEditor.localizations.addInDefaultLanguageTitle', 'mngEditor.localizations.addInDefaultLanguageDescription', { defaultLanguage: this.mngCommonsService.defaultDataLanguage }));
46
49
  }
47
50
  }
48
51
  ngOnDestroy() {
@@ -212,12 +215,12 @@ export class MngFormEditorComponent {
212
215
  }
213
216
  }
214
217
  }
215
- MngFormEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngFormEditorComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
216
- MngFormEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngFormEditorComponent, selector: "mng-form-editor", inputs: { descriptor: "descriptor", submitLoading: "submitLoading", item: "item", isSubmitButtonVisible: "isSubmitButtonVisible", isFormDisabled: "isFormDisabled" }, outputs: { formSubmitEventEmitter: "formSubmit" }, queries: [{ propertyName: "templates", predicate: MngTemplateDirective }], viewQueries: [{ propertyName: "submitButtonElementRef", first: true, predicate: ["submitButton"], descendants: true }], ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n", dependencies: [{ 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: "component", type: i3.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i5.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
218
+ MngFormEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngFormEditorComponent, deps: [{ token: i1.MngCommonsService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
219
+ MngFormEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngFormEditorComponent, selector: "mng-form-editor", inputs: { descriptor: "descriptor", submitLoading: "submitLoading", item: "item", isSubmitButtonVisible: "isSubmitButtonVisible", isFormDisabled: "isFormDisabled" }, outputs: { formSubmitEventEmitter: "formSubmit" }, queries: [{ propertyName: "templates", predicate: MngTemplateDirective }], viewQueries: [{ propertyName: "submitButtonElementRef", first: true, predicate: ["submitButton"], descendants: true }], ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n", dependencies: [{ kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "directive", type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i6.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
217
220
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngFormEditorComponent, decorators: [{
218
221
  type: Component,
219
222
  args: [{ selector: 'mng-form-editor', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n" }]
220
- }], ctorParameters: function () { return [{ type: i1.TranslateService }]; }, propDecorators: { descriptor: [{
223
+ }], ctorParameters: function () { return [{ type: i1.MngCommonsService }, { type: i2.TranslateService }]; }, propDecorators: { descriptor: [{
221
224
  type: Input
222
225
  }], submitLoading: [{
223
226
  type: Input
@@ -237,4 +240,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
237
240
  type: ViewChild,
238
241
  args: ['submitButton']
239
242
  }] } });
240
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-editor.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/editor/form-editor.component.ts","../../../../../../src/lib/components/form/editor/form-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, QueryList, ViewChild} from '@angular/core';\nimport {AbstractControl, FormArray, FormGroup} from '@angular/forms';\n\nimport {FormlyFieldConfig, FormlyFormOptions} from '@ngx-formly/core';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Message} from 'primeng/api';\nimport {Observable, Subscription, of} from 'rxjs';\n\nimport {EditorDescriptor} from '../../../descriptors';\nimport {TableviewEditorTypeEnum} from '../../../descriptors/types';\nimport {MngTemplateDirective} from '../../../directives';\nimport {EditorFormlyUtil, NotificationUtil} from '../../../utils';\nimport {MngFormlyFieldConfig} from '../formly/models';\nimport {IFormEditorComponent, MngFormEditorSubmitEvent} from '../models';\n\n@Component({\n    selector: 'mng-form-editor',\n    templateUrl: './form-editor.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormEditorComponent<T> implements IFormEditorComponent<T>, OnInit, OnDestroy {\n    // metadata and editor mode input\n    @Input() public descriptor!: EditorDescriptor<T>;\n    @Input() public submitLoading: Observable<boolean> | boolean = false;\n\n    // data source inputs;\n    @Input() public item?: T;\n\n    // extra features input\n    @Input() public isSubmitButtonVisible = false;\n    @Input() public isFormDisabled = null;\n\n    // event outputs\n    @Output('formSubmit') public formSubmitEventEmitter = new EventEmitter<MngFormEditorSubmitEvent<T>>();\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('submitButton') public submitButtonElementRef?: ElementRef;\n\n    public form: FormGroup = new FormGroup({});\n    public formOptions: FormlyFormOptions = {\n        formState: {\n            add: false,\n            edit: false,\n            disabled: false\n        }\n    };\n    public formFields!: FormlyFieldConfig[];\n    public formOrigItem?: T;\n    public formModel: any = {};\n    public formMessages: Message[] = [];\n    public submitLoading$!: Observable<boolean>;\n\n    private subscriptions: Subscription[] = [];\n\n    constructor(private translateService: TranslateService) {}\n\n    public ngOnInit() {\n        this.setInitialFormState();\n        this.resetFormModel(this.item);\n        this.submitLoading$ = this.submitLoading instanceof Observable ? this.submitLoading : of(this.submitLoading);\n\n        // init fields for formly\n        this.formFields = EditorFormlyUtil.createFormlyConfigFromDescriptor(this.descriptor, this);\n        this.updateFormState();\n\n        // let the user know, that adding new value in table view with localizations is only supported in the default language\n        if (this.descriptor.isLocalized && this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Add) {\n            this.formMessages.push(\n                NotificationUtil.getFormEditorWarningMessage(\n                    this.translateService,\n                    'mngEditor.localizations.addInDefaultLanguageTitle',\n                    'mngEditor.localizations.addInDefaultLanguageDescription'\n                )\n            );\n        }\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\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.formOptions.formState.submittedOn = Date.now();\n        this.formMessages = [];\n\n        const formSubmitItem = this.getFormValue();\n        if (this.form.valid) {\n            this.formSubmitEventEmitter.next(new MngFormEditorSubmitEvent(formSubmitItem));\n        } else {\n            // find and mark invalid tabs\n            if (this.formFields[0].type === 'tabs' && this.formFields[0].fieldGroup) {\n                for (const tab of this.formFields[0].fieldGroup) {\n                    const isInvalid = this.isAnyFieldInvalid(tab.fieldGroup);\n                    this.formOptions.formState['tab_' + (tab.id ? tab.id : (tab.props as MngFormlyFieldConfig).props.label) + '_invalid'] = isInvalid;\n                }\n            }\n            const event = new MngFormEditorSubmitEvent(formSubmitItem);\n            event.success = false;\n            this.formMessages.push(NotificationUtil.getFormEditorWarningMessage(this.translateService, 'mngEditor.invalidFormToastTitle', 'mngEditor.invalidFormToastMessage'));\n            this.formSubmitEventEmitter.next(event);\n        }\n    }\n\n    public getFormValue(): T {\n        const formValue = this.form.getRawValue();\n        this.descriptor.fields.forEach(field => {\n            if (field && field.setter) {\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        return formValue;\n    }\n\n    public resetFormModel(item?: T) {\n        this.formOrigItem = item;\n        // TODO: to check if this is ok, could be problems with dates, if so, try lodash\n        const formModel = JSON.parse(JSON.stringify(item ?? {}));\n\n        this.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);\n                    } else {\n                        if (typeof currentObject[currentSubPath] !== 'object') {\n                            currentObject[currentSubPath] = {};\n                        }\n\n                        currentObject = currentObject[currentSubPath];\n                    }\n                }\n            }\n        });\n        if (typeof this.formOptions.resetModel === 'function') {\n            // could not be initiated yet\n            this.formOptions.resetModel(this.formModel);\n        }\n        this.formModel = formModel;\n    }\n\n    public getFormField(key: string) {\n        return this.findFormField(this.form, key.split('.'));\n    }\n\n    public setFormFieldValue(key: string, value: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.setValue(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public patchFormFieldValue(key: string, value: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.patchValue(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public resetFormFieldValue(key: string, value?: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.reset(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\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 updateFormState() {\n        this.formOptions.formState.disabled = this.isFormDisabled !== null ? this.isFormDisabled === true : this.descriptor.disabled;\n    }\n\n    /**\n     * @private Sets form state based on editor descriptor type.\n     * Possible options are: disabled, add or edit.\n     */\n    private setInitialFormState(): void {\n        if (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Add) {\n            this.formOptions.formState.add = true;\n        } else if (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Edit) {\n            this.formOptions.formState.edit = true;\n        } else if (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Details) {\n            this.formOptions.formState.disabled = true;\n        }\n    }\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n    <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n    <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n"]}
243
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-editor.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/editor/form-editor.component.ts","../../../../../../src/lib/components/form/editor/form-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, QueryList, ViewChild} from '@angular/core';\nimport {AbstractControl, FormArray, FormGroup} from '@angular/forms';\n\nimport {FormlyFieldConfig, FormlyFormOptions} from '@ngx-formly/core';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Message} from 'primeng/api';\nimport {Observable, Subscription, of} from 'rxjs';\n\nimport {EditorDescriptor} from '../../../descriptors';\nimport {TableviewEditorTypeEnum} from '../../../descriptors/types';\nimport {MngTemplateDirective} from '../../../directives';\nimport {MngCommonsService} from '../../../services';\nimport {EditorFormlyUtil, NotificationUtil} from '../../../utils';\nimport {MngFormlyFieldConfig} from '../formly/models';\nimport {IFormEditorComponent, MngFormEditorSubmitEvent} from '../models';\n\n@Component({\n    selector: 'mng-form-editor',\n    templateUrl: './form-editor.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormEditorComponent<T> implements IFormEditorComponent<T>, OnInit, OnDestroy {\n    // metadata and editor mode input\n    @Input() public descriptor!: EditorDescriptor<T>;\n    @Input() public submitLoading: Observable<boolean> | boolean = false;\n\n    // data source inputs;\n    @Input() public item?: T;\n\n    // extra features input\n    @Input() public isSubmitButtonVisible = false;\n    @Input() public isFormDisabled = null;\n\n    // event outputs\n    @Output('formSubmit') public formSubmitEventEmitter = new EventEmitter<MngFormEditorSubmitEvent<T>>();\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('submitButton') public submitButtonElementRef?: ElementRef;\n\n    public form: FormGroup = new FormGroup({});\n    public formOptions: FormlyFormOptions = {\n        formState: {\n            add: false,\n            edit: false,\n            disabled: false\n        }\n    };\n    public formFields!: FormlyFieldConfig[];\n    public formOrigItem?: T;\n    public formModel: any = {};\n    public formMessages: Message[] = [];\n    public submitLoading$!: Observable<boolean>;\n\n    private subscriptions: Subscription[] = [];\n\n    constructor(private mngCommonsService: MngCommonsService, private translateService: TranslateService) {}\n\n    public ngOnInit() {\n        this.setInitialFormState();\n        this.resetFormModel(this.item);\n        this.submitLoading$ = this.submitLoading instanceof Observable ? this.submitLoading : of(this.submitLoading);\n\n        // init fields for formly\n        this.formFields = EditorFormlyUtil.createFormlyConfigFromDescriptor(this.descriptor, this);\n        this.updateFormState();\n\n        // let the user know, that adding new value in table view with localizations is only supported in the default language\n        if (\n            this.descriptor.isLocalized &&\n            (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Add || this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Edit)\n        ) {\n            this.formMessages.push(\n                NotificationUtil.getFormEditorInfoMessage(\n                    this.translateService,\n                    'mngEditor.localizations.addInDefaultLanguageTitle',\n                    'mngEditor.localizations.addInDefaultLanguageDescription',\n                    {defaultLanguage: this.mngCommonsService.defaultDataLanguage}\n                )\n            );\n        }\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\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.formOptions.formState.submittedOn = Date.now();\n        this.formMessages = [];\n\n        const formSubmitItem = this.getFormValue();\n        if (this.form.valid) {\n            this.formSubmitEventEmitter.next(new MngFormEditorSubmitEvent(formSubmitItem));\n        } else {\n            // find and mark invalid tabs\n            if (this.formFields[0].type === 'tabs' && this.formFields[0].fieldGroup) {\n                for (const tab of this.formFields[0].fieldGroup) {\n                    const isInvalid = this.isAnyFieldInvalid(tab.fieldGroup);\n                    this.formOptions.formState['tab_' + (tab.id ? tab.id : (tab.props as MngFormlyFieldConfig).props.label) + '_invalid'] = isInvalid;\n                }\n            }\n            const event = new MngFormEditorSubmitEvent(formSubmitItem);\n            event.success = false;\n            this.formMessages.push(NotificationUtil.getFormEditorWarningMessage(this.translateService, 'mngEditor.invalidFormToastTitle', 'mngEditor.invalidFormToastMessage'));\n            this.formSubmitEventEmitter.next(event);\n        }\n    }\n\n    public getFormValue(): T {\n        const formValue = this.form.getRawValue();\n        this.descriptor.fields.forEach(field => {\n            if (field && field.setter) {\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        return formValue;\n    }\n\n    public resetFormModel(item?: T) {\n        this.formOrigItem = item;\n        // TODO: to check if this is ok, could be problems with dates, if so, try lodash\n        const formModel = JSON.parse(JSON.stringify(item ?? {}));\n\n        this.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);\n                    } else {\n                        if (typeof currentObject[currentSubPath] !== 'object') {\n                            currentObject[currentSubPath] = {};\n                        }\n\n                        currentObject = currentObject[currentSubPath];\n                    }\n                }\n            }\n        });\n        if (typeof this.formOptions.resetModel === 'function') {\n            // could not be initiated yet\n            this.formOptions.resetModel(this.formModel);\n        }\n        this.formModel = formModel;\n    }\n\n    public getFormField(key: string) {\n        return this.findFormField(this.form, key.split('.'));\n    }\n\n    public setFormFieldValue(key: string, value: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.setValue(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public patchFormFieldValue(key: string, value: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.patchValue(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\n    }\n\n    public resetFormFieldValue(key: string, value?: any) {\n        const control = this.getFormField(key);\n        if (control) {\n            control.reset(value);\n            return true;\n        } else {\n            console.warn(`Value was not set, because field ${key} was not found.`);\n            return false;\n        }\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 updateFormState() {\n        this.formOptions.formState.disabled = this.isFormDisabled !== null ? this.isFormDisabled === true : this.descriptor.disabled;\n    }\n\n    /**\n     * @private Sets form state based on editor descriptor type.\n     * Possible options are: disabled, add or edit.\n     */\n    private setInitialFormState(): void {\n        if (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Add) {\n            this.formOptions.formState.add = true;\n        } else if (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Edit) {\n            this.formOptions.formState.edit = true;\n        } else if (this.descriptor.tableviewEditorType === TableviewEditorTypeEnum.Details) {\n            this.formOptions.formState.disabled = true;\n        }\n    }\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n    <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n    <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n"]}
@@ -20,7 +20,7 @@ export class MngFormlyFieldWrapperComponent extends FieldWrapper {
20
20
  .withDialogSize(StyleSizeEnum.Small)
21
21
  .withButtonDescriptor(new ActionButtonDescriptor()
22
22
  .withIcon('pi pi-language')
23
- .withLabel('mngEditor.showTranslations')
23
+ .withLabel('mngEditor.localizations.showTranslations')
24
24
  .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto')))
25
25
  .withFetchFunction(() => of(this.model));
26
26
  viewLocalizationsAction.withEditorActions([new ActionEditorSubmitDescriptor(viewLocalizationsAction, ActionEditorSubmitTypeEnum.Cancel)]);
@@ -33,7 +33,7 @@ export class MngFormlyFieldWrapperComponent extends FieldWrapper {
33
33
  .withDialogSize(StyleSizeEnum.Small)
34
34
  .withButtonDescriptor(new ActionButtonDescriptor()
35
35
  .withIcon('pi pi-language')
36
- .withLabel('mngEditor.showTranslations')
36
+ .withLabel('mngEditor.localizations.showTranslations')
37
37
  .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto')))
38
38
  .withFetchFunction(() => of(this.model))
39
39
  .withSubmitFunction(ctx => {
@@ -49,7 +49,7 @@ export class MngFormlyFieldWrapperComponent extends FieldWrapper {
49
49
  .withDialogSize(StyleSizeEnum.Small)
50
50
  .withButtonDescriptor(new ActionButtonDescriptor()
51
51
  .withIcon('pi pi-language')
52
- .withLabel('mngEditor.showTranslations')
52
+ .withLabel('mngEditor.localizations.showTranslations')
53
53
  .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto')))
54
54
  .withSubmitFunction(ctx => {
55
55
  this.form
@@ -62,7 +62,7 @@ export class MngFormlyFieldWrapperComponent extends FieldWrapper {
62
62
  }
63
63
  addMissingTranslationHelperText() {
64
64
  if (!this.model[this.props?.['descriptor'].property + 'Translated']) {
65
- this.props?.['descriptor']?.withHelpText('general.missingTranslation');
65
+ this.props?.['descriptor']?.withHelpText('mngEditor.localizations.missingTranslation');
66
66
  this.field.className += ' localized-input-border-orange';
67
67
  }
68
68
  else {
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
76
76
  type: Component,
77
77
  args: [{ selector: 'mng-formly-field-wrapper', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class]=\"props?.['descriptor']?.['fieldClassName'] ?? 'field'\">\n <div class=\"grid mt-0\">\n <label *ngIf=\"props?.label\" [for]=\"key\" class=\"col\" [class]=\"props?.['descriptor']?.['labelClassName'] ?? ''\"\n >{{ props!.label! | translate }} <span *ngIf=\"props.required && props['hideRequiredMarker'] !== true\">*</span></label\n >\n <mng-action *ngIf=\"props?.['descriptor']?.['_isLocalized']\" class=\"col text-right\" [action]=\"localizationAction\"></mng-action>\n </div>\n <ng-container #fieldComponent></ng-container>\n <small *ngIf=\"props?.['descriptor']?.['helpText']\">{{ props?.['descriptor']?.['helpText'] | translate }}</small>\n <small *ngIf=\"showError\" class=\"p-error\">\n <formly-validation-message [field]=\"field\"></formly-validation-message>\n </small>\n</div>\n" }]
78
78
  }] });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-wrapper.component.js","sourceRoot":"","sources":["../../../../../../../../src/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.ts","../../../../../../../../src/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, OnInit} from '@angular/core';\n\nimport {FieldWrapper} from '@ngx-formly/core';\nimport {of} from 'rxjs';\n\nimport {ActionButtonDescriptor, ActionDescriptor, ActionEditorDescriptor, ActionEditorSubmitDescriptor} from '../../../../../descriptors';\nimport {ActionEditorSubmitTypeEnum} from '../../../../../descriptors/types';\nimport {ButtonStyleBuilder} from '../../../../../styles';\nimport {StyleSizeEnum} from '../../../../../styles/models';\n\n@Component({\n    selector: 'mng-formly-field-wrapper',\n    templateUrl: './formly-field-wrapper.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormlyFieldWrapperComponent extends FieldWrapper implements OnInit {\n    public localizationAction!: ActionDescriptor<unknown>;\n\n    public ngOnInit() {\n        if (this.props?.['descriptor']?.isLocalized) {\n            if (this.formState.disabled) {\n                this.addMissingTranslationHelperText();\n                const viewLocalizationsAction = new ActionEditorDescriptor(this.props?.['descriptor']?.localizationTableview.detailsEditor, 'localization-details')\n                    .withDialogClassName('mng-field-dialog mng-action-editor-dialog')\n                    .withDialogSize(StyleSizeEnum.Small)\n                    .withButtonDescriptor(\n                        new ActionButtonDescriptor()\n                            .withIcon('pi pi-language')\n                            .withLabel('mngEditor.showTranslations')\n                            .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto'))\n                    )\n                    .withFetchFunction(() => of(this.model));\n                viewLocalizationsAction.withEditorActions([new ActionEditorSubmitDescriptor(viewLocalizationsAction, ActionEditorSubmitTypeEnum.Cancel)]);\n                this.localizationAction = viewLocalizationsAction;\n            } else if (this.formState.edit) {\n                this.addMissingTranslationHelperText();\n                this.localizationAction = new ActionEditorDescriptor(this.props?.['descriptor']?.localizationTableview.editEditor, 'localized-edit')\n                    .withDialogClassName('mng-field-dialog mng-action-editor-dialog')\n                    .withDialogSize(StyleSizeEnum.Small)\n                    .withButtonDescriptor(\n                        new ActionButtonDescriptor()\n                            .withIcon('pi pi-language')\n                            .withLabel('mngEditor.showTranslations')\n                            .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto'))\n                    )\n                    .withFetchFunction(() => of(this.model))\n                    .withSubmitFunction(ctx => {\n                        this.form\n                            .get(this.props?.['descriptor'].editor.localizationLocalizationProperty)!\n                            .patchValue((ctx.parameters.item as any)[this.props?.['descriptor'].editor.localizationLocalizationProperty]);\n                        return of(ctx.parameters.item);\n                    });\n            } else if (this.formState.add) {\n                this.localizationAction = new ActionEditorDescriptor(this.props?.['descriptor']?.localizationTableview.addEditor, 'localizations-add')\n                    .withDialogClassName('mng-field-dialog mng-action-editor-dialog')\n                    .withDialogSize(StyleSizeEnum.Small)\n                    .withButtonDescriptor(\n                        new ActionButtonDescriptor()\n                            .withIcon('pi pi-language')\n                            .withLabel('mngEditor.showTranslations')\n                            .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto'))\n                    )\n                    .withSubmitFunction(ctx => {\n                        this.form\n                            .get(this.props?.['descriptor'].editor.localizationLocalizationProperty)!\n                            .patchValue((ctx.parameters.item as any)[this.props?.['descriptor'].editor.localizationLocalizationProperty]);\n                        return of(ctx.parameters.item);\n                    });\n            }\n        }\n    }\n\n    private addMissingTranslationHelperText(): void {\n        if (!this.model[this.props?.['descriptor'].property + 'Translated']) {\n            this.props?.['descriptor']?.withHelpText('general.missingTranslation');\n            this.field.className += ' localized-input-border-orange';\n        } else {\n            this.props?.['descriptor']?.withHelpText('');\n        }\n    }\n}\n","<div [class]=\"props?.['descriptor']?.['fieldClassName'] ?? 'field'\">\n    <div class=\"grid mt-0\">\n        <label *ngIf=\"props?.label\" [for]=\"key\" class=\"col\" [class]=\"props?.['descriptor']?.['labelClassName'] ?? ''\"\n            >{{ props!.label! | translate }} <span *ngIf=\"props.required && props['hideRequiredMarker'] !== true\">*</span></label\n        >\n        <mng-action *ngIf=\"props?.['descriptor']?.['_isLocalized']\" class=\"col text-right\" [action]=\"localizationAction\"></mng-action>\n    </div>\n    <ng-container #fieldComponent></ng-container>\n    <small *ngIf=\"props?.['descriptor']?.['helpText']\">{{ props?.['descriptor']?.['helpText'] | translate }}</small>\n    <small *ngIf=\"showError\" class=\"p-error\">\n        <formly-validation-message [field]=\"field\"></formly-validation-message>\n    </small>\n</div>\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-wrapper.component.js","sourceRoot":"","sources":["../../../../../../../../src/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.ts","../../../../../../../../src/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, OnInit} from '@angular/core';\n\nimport {FieldWrapper} from '@ngx-formly/core';\nimport {of} from 'rxjs';\n\nimport {ActionButtonDescriptor, ActionDescriptor, ActionEditorDescriptor, ActionEditorSubmitDescriptor} from '../../../../../descriptors';\nimport {ActionEditorSubmitTypeEnum} from '../../../../../descriptors/types';\nimport {ButtonStyleBuilder} from '../../../../../styles';\nimport {StyleSizeEnum} from '../../../../../styles/models';\n\n@Component({\n    selector: 'mng-formly-field-wrapper',\n    templateUrl: './formly-field-wrapper.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormlyFieldWrapperComponent extends FieldWrapper implements OnInit {\n    public localizationAction!: ActionDescriptor<unknown>;\n\n    public ngOnInit() {\n        if (this.props?.['descriptor']?.isLocalized) {\n            if (this.formState.disabled) {\n                this.addMissingTranslationHelperText();\n                const viewLocalizationsAction = new ActionEditorDescriptor(this.props?.['descriptor']?.localizationTableview.detailsEditor, 'localization-details')\n                    .withDialogClassName('mng-field-dialog mng-action-editor-dialog')\n                    .withDialogSize(StyleSizeEnum.Small)\n                    .withButtonDescriptor(\n                        new ActionButtonDescriptor()\n                            .withIcon('pi pi-language')\n                            .withLabel('mngEditor.localizations.showTranslations')\n                            .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto'))\n                    )\n                    .withFetchFunction(() => of(this.model));\n                viewLocalizationsAction.withEditorActions([new ActionEditorSubmitDescriptor(viewLocalizationsAction, ActionEditorSubmitTypeEnum.Cancel)]);\n                this.localizationAction = viewLocalizationsAction;\n            } else if (this.formState.edit) {\n                this.addMissingTranslationHelperText();\n                this.localizationAction = new ActionEditorDescriptor(this.props?.['descriptor']?.localizationTableview.editEditor, 'localized-edit')\n                    .withDialogClassName('mng-field-dialog mng-action-editor-dialog')\n                    .withDialogSize(StyleSizeEnum.Small)\n                    .withButtonDescriptor(\n                        new ActionButtonDescriptor()\n                            .withIcon('pi pi-language')\n                            .withLabel('mngEditor.localizations.showTranslations')\n                            .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto'))\n                    )\n                    .withFetchFunction(() => of(this.model))\n                    .withSubmitFunction(ctx => {\n                        this.form\n                            .get(this.props?.['descriptor'].editor.localizationLocalizationProperty)!\n                            .patchValue((ctx.parameters.item as any)[this.props?.['descriptor'].editor.localizationLocalizationProperty]);\n                        return of(ctx.parameters.item);\n                    });\n            } else if (this.formState.add) {\n                this.localizationAction = new ActionEditorDescriptor(this.props?.['descriptor']?.localizationTableview.addEditor, 'localizations-add')\n                    .withDialogClassName('mng-field-dialog mng-action-editor-dialog')\n                    .withDialogSize(StyleSizeEnum.Small)\n                    .withButtonDescriptor(\n                        new ActionButtonDescriptor()\n                            .withIcon('pi pi-language')\n                            .withLabel('mngEditor.localizations.showTranslations')\n                            .withStyleClass(new ButtonStyleBuilder().withTextButton().withCustomClass('py-0 mb-1 w-auto'))\n                    )\n                    .withSubmitFunction(ctx => {\n                        this.form\n                            .get(this.props?.['descriptor'].editor.localizationLocalizationProperty)!\n                            .patchValue((ctx.parameters.item as any)[this.props?.['descriptor'].editor.localizationLocalizationProperty]);\n                        return of(ctx.parameters.item);\n                    });\n            }\n        }\n    }\n\n    private addMissingTranslationHelperText(): void {\n        if (!this.model[this.props?.['descriptor'].property + 'Translated']) {\n            this.props?.['descriptor']?.withHelpText('mngEditor.localizations.missingTranslation');\n            this.field.className += ' localized-input-border-orange';\n        } else {\n            this.props?.['descriptor']?.withHelpText('');\n        }\n    }\n}\n","<div [class]=\"props?.['descriptor']?.['fieldClassName'] ?? 'field'\">\n    <div class=\"grid mt-0\">\n        <label *ngIf=\"props?.label\" [for]=\"key\" class=\"col\" [class]=\"props?.['descriptor']?.['labelClassName'] ?? ''\"\n            >{{ props!.label! | translate }} <span *ngIf=\"props.required && props['hideRequiredMarker'] !== true\">*</span></label\n        >\n        <mng-action *ngIf=\"props?.['descriptor']?.['_isLocalized']\" class=\"col text-right\" [action]=\"localizationAction\"></mng-action>\n    </div>\n    <ng-container #fieldComponent></ng-container>\n    <small *ngIf=\"props?.['descriptor']?.['helpText']\">{{ props?.['descriptor']?.['helpText'] | translate }}</small>\n    <small *ngIf=\"showError\" class=\"p-error\">\n        <formly-validation-message [field]=\"field\"></formly-validation-message>\n    </small>\n</div>\n"]}