@dignite-ng/expand.cms 3.1.9 → 3.1.12
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/lib/components/admin/entries/entries.component.mjs +7 -7
- package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +23 -4
- package/esm2022/lib/components/admin/fields/edit-field.component.mjs +1 -2
- package/fesm2022/dignite-ng-expand.cms.mjs +28 -10
- package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
- package/lib/components/admin/fields/create-or-edit-field.component.d.ts +3 -0
- package/package.json +1 -1
|
@@ -20,7 +20,7 @@ export class CreateOrEditFieldComponent {
|
|
|
20
20
|
this.fromControlList = [];
|
|
21
21
|
}
|
|
22
22
|
set selected(v) {
|
|
23
|
-
this._selected = v;
|
|
23
|
+
this._selected = v ? JSON.parse(JSON.stringify(v)) : v;
|
|
24
24
|
}
|
|
25
25
|
set form(v) {
|
|
26
26
|
this.formEntity = v;
|
|
@@ -34,6 +34,7 @@ export class CreateOrEditFieldComponent {
|
|
|
34
34
|
if (!this.formControlNameInput.value && this.fromControlList.length > 0) {
|
|
35
35
|
this.formControlNameInput.patchValue(this.fromControlList[0].name);
|
|
36
36
|
}
|
|
37
|
+
console.log(this._selected, '_selected');
|
|
37
38
|
this.submitclick.nativeElement.click();
|
|
38
39
|
}
|
|
39
40
|
get nameInput() {
|
|
@@ -42,6 +43,9 @@ export class CreateOrEditFieldComponent {
|
|
|
42
43
|
get formControlNameInput() {
|
|
43
44
|
return this.formEntity?.get('formControlName');
|
|
44
45
|
}
|
|
46
|
+
get formConfigurationInput() {
|
|
47
|
+
return this.formEntity?.get('formConfiguration');
|
|
48
|
+
}
|
|
45
49
|
/**字段标签input失去标点生成字段名字 */
|
|
46
50
|
disPlayNameInputBlur(event) {
|
|
47
51
|
const value = event.target.value;
|
|
@@ -72,12 +76,27 @@ export class CreateOrEditFieldComponent {
|
|
|
72
76
|
});
|
|
73
77
|
};
|
|
74
78
|
}
|
|
79
|
+
/** */
|
|
80
|
+
changeFormControlName(e) {
|
|
81
|
+
console.log(this._selected, '_selected');
|
|
82
|
+
// for (const element in this.formConfigurationInput.controls) {
|
|
83
|
+
// const control = this.formConfigurationInput.controls[element];
|
|
84
|
+
// const value = control.value;
|
|
85
|
+
// if (Array.isArray(value)) {
|
|
86
|
+
// control.patchValue([]);
|
|
87
|
+
// } else if (typeof value === 'boolean') {
|
|
88
|
+
// control.patchValue(false);
|
|
89
|
+
// } else {
|
|
90
|
+
// control.patchValue('');
|
|
91
|
+
// }
|
|
92
|
+
// }
|
|
93
|
+
}
|
|
75
94
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditFieldComponent, deps: [{ token: i1.ToPinyinService }, { token: i2.LocalizationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
76
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: CreateOrEditFieldComponent, selector: "cms-create-or-edit-field", inputs: { selected: "selected", service: "service", form: "form" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"card\">\r\n <div class=\"card-body\">\r\n <form [formGroup]=\"formEntity\">\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"groupId\">\r\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n <option [value]=\"item.id\">{{item.name}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n (blur)=\"disPlayNameInputBlur($event)\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n {{nameInput.errors?.repetition}}\r\n </div>\r\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n abpLocalization}}</small>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"formControlName\">\r\n <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n @if(formControlNameInput.value&&formEntity){\r\n <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n [form]=\"formEntity\"></df-dynamic-config>\r\n }\r\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n </form>\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i5.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i6.DynamicConfigComponent, selector: "df-dynamic-config", inputs: ["type", "selected", "form"] }, { kind: "pipe", type: i2.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
95
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: CreateOrEditFieldComponent, selector: "cms-create-or-edit-field", inputs: { selected: "selected", service: "service", form: "form" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"card\">\r\n <div class=\"card-body\">\r\n <form [formGroup]=\"formEntity\">\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"groupId\">\r\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n <option [value]=\"item.id\">{{item.name}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n (blur)=\"disPlayNameInputBlur($event)\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n {{nameInput.errors?.repetition}}\r\n </div>\r\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n abpLocalization}}</small>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"changeFormControlName($event)\">\r\n <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n @if(formControlNameInput.value&&formEntity){\r\n <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n [form]=\"formEntity\"></df-dynamic-config>\r\n }\r\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n </form>\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i5.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i6.DynamicConfigComponent, selector: "df-dynamic-config", inputs: ["type", "selected", "form"] }, { kind: "pipe", type: i2.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
77
96
|
}
|
|
78
97
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditFieldComponent, decorators: [{
|
|
79
98
|
type: Component,
|
|
80
|
-
args: [{ selector: 'cms-create-or-edit-field', template: "<div class=\"card\">\r\n <div class=\"card-body\">\r\n <form [formGroup]=\"formEntity\">\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"groupId\">\r\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n <option [value]=\"item.id\">{{item.name}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n (blur)=\"disPlayNameInputBlur($event)\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n {{nameInput.errors?.repetition}}\r\n </div>\r\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n abpLocalization}}</small>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"formControlName\">\r\n <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n @if(formControlNameInput.value&&formEntity){\r\n <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n [form]=\"formEntity\"></df-dynamic-config>\r\n }\r\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n </form>\r\n </div>\r\n</div>" }]
|
|
99
|
+
args: [{ selector: 'cms-create-or-edit-field', template: "<div class=\"card\">\r\n <div class=\"card-body\">\r\n <form [formGroup]=\"formEntity\">\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"groupId\">\r\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n <option [value]=\"item.id\">{{item.name}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n (blur)=\"disPlayNameInputBlur($event)\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n {{nameInput.errors?.repetition}}\r\n </div>\r\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n abpLocalization}}</small>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"changeFormControlName($event)\">\r\n <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n @if(formControlNameInput.value&&formEntity){\r\n <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n [form]=\"formEntity\"></df-dynamic-config>\r\n }\r\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n </form>\r\n </div>\r\n</div>" }]
|
|
81
100
|
}], ctorParameters: () => [{ type: i1.ToPinyinService }, { type: i2.LocalizationService }], propDecorators: { selected: [{
|
|
82
101
|
type: Input
|
|
83
102
|
}], service: [{
|
|
@@ -88,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
88
107
|
type: ViewChild,
|
|
89
108
|
args: ['submitclick', { static: true }]
|
|
90
109
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/fields/create-or-edit-field.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/fields/create-or-edit-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\r\nimport { AfterContentInit, Component, ElementRef, Input,  ViewChild } from '@angular/core';\r\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors } from '@angular/forms';\r\nimport { ToPinyinService } from '@dignite-ng/expand.core';\r\nimport { Observable } from 'rxjs';\r\nimport { LocalizationService } from '@abp/ng.core';\r\n\r\n@Component({\r\n  selector: 'cms-create-or-edit-field',\r\n  templateUrl: './create-or-edit-field.component.html',\r\n  styleUrl: './create-or-edit-field.component.scss',\r\n})\r\nexport class CreateOrEditFieldComponent implements AfterContentInit {\r\n  constructor(private _ToPinyinService: ToPinyinService,private _LocalizationService:LocalizationService) {}\r\n\r\n  _selected: any;\r\n  @Input()\r\n  public set selected(v: any) {\r\n    this._selected = v;\r\n  }\r\n\r\n  @Input() public service: any;\r\n\r\n  formEntity: FormGroup | undefined;\r\n  @Input()\r\n  public set form(v: FormGroup | undefined) {\r\n    this.formEntity = v;\r\n  }\r\n\r\n\r\n\r\n  async ngAfterContentInit(): Promise<void> {\r\n    //Called after ngOnInit when the component's or directive's content has been initialized.\r\n    //Add 'implements AfterContentInit' to the class.\r\n    this.getfieldGroupsList = await this.service.getfieldGroups();\r\n    this.fromControlList = await this.service.getControlsfieldTypes();\r\n    this.nameInput.addAsyncValidators([this.repetitionAsyncValidator()])\r\n    if(!this.formControlNameInput.value&&this.fromControlList.length>0){\r\n      this.formControlNameInput.patchValue(this.fromControlList[0].name)\r\n    }\r\n    this.submitclick.nativeElement.click()\r\n  }\r\n\r\n  /**字段分组列表 */\r\n  getfieldGroupsList: any[] = [];\r\n  /**表单控件列表 */\r\n  fromControlList: any[] = [];\r\n\r\n  get nameInput() {\r\n    return this.formEntity?.get('name') as FormControl;\r\n  }\r\n  get formControlNameInput() {\r\n    return this.formEntity?.get('formControlName') as FormControl;\r\n  }\r\n\r\n  /**获取提交按钮替身，用于真实触发表单提交 */\r\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\r\n\r\n  /**字段标签input失去标点生成字段名字 */\r\n  disPlayNameInputBlur(event) {\r\n    const value = event.target.value;\r\n    const pinyin = this._ToPinyinService.get(value);\r\n    const nameInput = this.nameInput;\r\n    if (nameInput.value) return;\r\n    nameInput.patchValue(pinyin);\r\n  }\r\n\r\n  /**异步验证，验证别名 */\r\n  repetitionAsyncValidator() {\r\n    return (\r\n      ctrl: AbstractControl,\r\n    ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\r\n      return new Promise(resolve => {\r\n        if (ctrl.value == this._selected?.name || !ctrl.value) {\r\n          resolve(null);\r\n          return;\r\n        }\r\n        this.service.nameExists(ctrl.value).subscribe(res => {\r\n          if (res) {\r\n            resolve({\r\n              repetition: this._LocalizationService.instant(\r\n                `Cms::FieldName{0}AlreadyExist`,\r\n                ctrl.value,\r\n              ),\r\n            });\r\n          } else {\r\n            resolve(null);\r\n          }\r\n        });\r\n      });\r\n    };\r\n  }\r\n}\r\n","<div class=\"card\">\r\n    <div class=\"card-body\">\r\n        <form [formGroup]=\"formEntity\">\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n                <select class=\"form-select\" formControlName=\"groupId\">\r\n                    <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n                    <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n                        <option [value]=\"item.id\">{{item.name}}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n                    abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n                    (blur)=\"disPlayNameInputBlur($event)\">\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n                <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n                    {{nameInput.errors?.repetition}}\r\n                </div>\r\n                <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n                    abpLocalization}}</small>\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n                <select class=\"form-select\" formControlName=\"formControlName\">\r\n                    <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n                        <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            @if(formControlNameInput.value&&formEntity){\r\n            <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n                [form]=\"formEntity\"></df-dynamic-config>\r\n            }\r\n            <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n        </form>\r\n    </div>\r\n</div>"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/fields/create-or-edit-field.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/fields/create-or-edit-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\r\nimport { AfterContentInit, Component, ElementRef, Input,  ViewChild } from '@angular/core';\r\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors } from '@angular/forms';\r\nimport { ToPinyinService } from '@dignite-ng/expand.core';\r\nimport { Observable } from 'rxjs';\r\nimport { LocalizationService } from '@abp/ng.core';\r\n\r\n@Component({\r\n  selector: 'cms-create-or-edit-field',\r\n  templateUrl: './create-or-edit-field.component.html',\r\n  styleUrl: './create-or-edit-field.component.scss',\r\n})\r\nexport class CreateOrEditFieldComponent implements AfterContentInit {\r\n  constructor(private _ToPinyinService: ToPinyinService,private _LocalizationService:LocalizationService) {}\r\n\r\n  _selected: any;\r\n  @Input()\r\n  public set selected(v: any) {\r\n    this._selected = v?JSON.parse(JSON.stringify(v)):v;\r\n  }\r\n\r\n  @Input() public service: any;\r\n\r\n  formEntity: FormGroup | undefined;\r\n  @Input()\r\n  public set form(v: FormGroup | undefined) {\r\n    this.formEntity = v;\r\n  }\r\n\r\n\r\n\r\n  async ngAfterContentInit(): Promise<void> {\r\n    //Called after ngOnInit when the component's or directive's content has been initialized.\r\n    //Add 'implements AfterContentInit' to the class.\r\n    this.getfieldGroupsList = await this.service.getfieldGroups();\r\n    this.fromControlList = await this.service.getControlsfieldTypes();\r\n    this.nameInput.addAsyncValidators([this.repetitionAsyncValidator()])\r\n    if(!this.formControlNameInput.value&&this.fromControlList.length>0){\r\n      this.formControlNameInput.patchValue(this.fromControlList[0].name)\r\n    }\r\n     console.log(this._selected,'_selected')\r\n    this.submitclick.nativeElement.click()\r\n  }\r\n\r\n  /**字段分组列表 */\r\n  getfieldGroupsList: any[] = [];\r\n  /**表单控件列表 */\r\n  fromControlList: any[] = [];\r\n\r\n  get nameInput() {\r\n    return this.formEntity?.get('name') as FormControl;\r\n  }\r\n  get formControlNameInput() {\r\n    return this.formEntity?.get('formControlName') as FormControl;\r\n  }\r\n  get formConfigurationInput(){\r\n    return this.formEntity?.get('formConfiguration') as FormGroup;\r\n  }\r\n\r\n  /**获取提交按钮替身，用于真实触发表单提交 */\r\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\r\n\r\n  /**字段标签input失去标点生成字段名字 */\r\n  disPlayNameInputBlur(event) {\r\n    const value = event.target.value;\r\n    const pinyin = this._ToPinyinService.get(value);\r\n    const nameInput = this.nameInput;\r\n    if (nameInput.value) return;\r\n    nameInput.patchValue(pinyin);\r\n  }\r\n\r\n  /**异步验证，验证别名 */\r\n  repetitionAsyncValidator() {\r\n    return (\r\n      ctrl: AbstractControl,\r\n    ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\r\n      return new Promise(resolve => {\r\n        if (ctrl.value == this._selected?.name || !ctrl.value) {\r\n          resolve(null);\r\n          return;\r\n        }\r\n        this.service.nameExists(ctrl.value).subscribe(res => {\r\n          if (res) {\r\n            resolve({\r\n              repetition: this._LocalizationService.instant(\r\n                `Cms::FieldName{0}AlreadyExist`,\r\n                ctrl.value,\r\n              ),\r\n            });\r\n          } else {\r\n            resolve(null);\r\n          }\r\n        });\r\n      });\r\n    };\r\n  }\r\n  /** */\r\n  changeFormControlName(e){\r\n    console.log(this._selected,'_selected')\r\n  //  for (const element in this.formConfigurationInput.controls) {\r\n  //     const control = this.formConfigurationInput.controls[element];\r\n  //     const value = control.value;\r\n  //     if (Array.isArray(value)) {\r\n  //       control.patchValue([]);\r\n  //     } else if (typeof value === 'boolean') {\r\n  //       control.patchValue(false);\r\n  //     } else {\r\n  //       control.patchValue('');\r\n  //     }\r\n  //   }\r\n  }\r\n}\r\n","<div class=\"card\">\r\n    <div class=\"card-body\">\r\n        <form [formGroup]=\"formEntity\">\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n                <select class=\"form-select\" formControlName=\"groupId\">\r\n                    <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n                    <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n                        <option [value]=\"item.id\">{{item.name}}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n                    abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n                    (blur)=\"disPlayNameInputBlur($event)\">\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n                <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n                    {{nameInput.errors?.repetition}}\r\n                </div>\r\n                <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n                    abpLocalization}}</small>\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n                <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"changeFormControlName($event)\">\r\n                    <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n                        <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            @if(formControlNameInput.value&&formEntity){\r\n            <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n                [form]=\"formEntity\"></df-dynamic-config>\r\n            }\r\n            <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n        </form>\r\n    </div>\r\n</div>"]}
|
|
@@ -127,7 +127,6 @@ export class EditFieldComponent {
|
|
|
127
127
|
return;
|
|
128
128
|
}
|
|
129
129
|
console.log(this.formEntity.value, '提交表单', this.formEntity);
|
|
130
|
-
// return
|
|
131
130
|
if (this.isSubmitted)
|
|
132
131
|
return;
|
|
133
132
|
this.isSubmitted = true;
|
|
@@ -171,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
171
170
|
type: ViewChild,
|
|
172
171
|
args: ['submitclick', { static: true }]
|
|
173
172
|
}] } });
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/fields/edit-field.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/fields/edit-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\r\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';\r\nimport { Component, ElementRef, ViewChild, OnInit } from '@angular/core';\r\nimport { ECmsComponent } from '../../../enums';\r\nimport { LocalizationService } from '@abp/ng.core';\r\nimport { ToasterService } from '@abp/ng.theme.shared';\r\nimport { FormBuilder, FormGroup, FormControl } from '@angular/forms';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport {\r\n  LocationBackService,\r\n  UpdateListService,\r\n  DigniteValidatorsService,\r\n} from '@dignite-ng/expand.core';\r\nimport { FieldsDataService } from '../../../services/fields-data.service';\r\nimport { FieldsFormConfig, fieldToFormLabelMap } from './fields-form-config';\r\n\r\n@Component({\r\n  selector: 'cms-edit-field',\r\n  templateUrl: './edit-field.component.html',\r\n  styleUrl: './edit-field.component.scss',\r\n  providers: [\r\n    {\r\n      provide: EXTENSIONS_IDENTIFIER,\r\n      useValue: ECmsComponent.FieldsEdit,\r\n    },\r\n  ],\r\n})\r\nexport class EditFieldComponent implements OnInit {\r\n  constructor(\r\n    private fb: FormBuilder,\r\n    public _service: FieldsDataService,\r\n    private toaster: ToasterService,\r\n    public _LocationBackService: LocationBackService,\r\n    public _LocalizationService: LocalizationService,\r\n    private route: ActivatedRoute,\r\n    private _UpdateListService: UpdateListService,\r\n    private _DigniteValidatorsService: DigniteValidatorsService,\r\n  ) {}\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    //Called after the constructor, initializing input properties, and the first call to ngOnChanges.\r\n    //Add 'implements OnInit' to the class.\r\n    const { id } = this.route.snapshot.params;\r\n    this.formEntity = this.fb.group(new FieldsFormConfig());\r\n    await this.getFieldDetails(id);\r\n    if (this.fieldDetail) {\r\n      this.formEntity.patchValue({\r\n        ...this.fieldDetail,\r\n        groupId: this.fieldDetail.groupId || '',\r\n      });\r\n    }\r\n  }\r\n\r\n  /**获取字段详情 */\r\n  getFieldDetails(id: string) {\r\n    return new Promise((resolve, reject) => {\r\n      this._service.getFieldDetail(id).subscribe(\r\n        res => {\r\n          this.fieldDetail = res;\r\n          resolve(res);\r\n        },\r\n        err => {\r\n          resolve('');\r\n        },\r\n      );\r\n    });\r\n  }\r\n\r\n  /**字段详情 */\r\n  fieldDetail: any = '';\r\n\r\n  /*\r\n  /**表单实体 */\r\n  formEntity: FormGroup | undefined;\r\n\r\n  /**表单是否触发验证 */\r\n  formValidation = false;\r\n\r\n  /**是否提交 */\r\n  isSubmitted = false;\r\n\r\n  /**获取提交按钮替身，用于真实触发表单提交 */\r\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\r\n\r\n  /**字段分组控件 */\r\n  get groupIdInput() {\r\n    return this.formEntity?.get('groupId') as FormControl;\r\n  }\r\n \r\n  // 获取错误信息\r\n  getErrorMessage(error: any,map:any): string {\r\n    // 获取本地化标签\r\n    const getLocalizedLabel = (path: string) => {\r\n      return this._LocalizationService.instant(map[path as keyof typeof map]);\r\n    };\r\n  \r\n    // 格式化数组索引\r\n    const formatArrayIndex = (item: string) => {\r\n      const regex = /\\[[0-9]+\\]/g;\r\n      const indexMatch = item.match(regex);\r\n      const [basePath] = item.split(regex);\r\n      return getLocalizedLabel(basePath) + (indexMatch ? indexMatch[0] : '');\r\n    };\r\n  \r\n    let errorMessage = '';\r\n    // 如果错误路径包含formConfiguration\r\n    if (error.path.includes('formConfiguration')) {\r\n      // 将错误路径中的formConfiguration-替换掉，并按-分割\r\n      const pathParts = error.path.replaceAll('formConfiguration-', '').split('-');\r\n      // 对分割后的路径进行格式化\r\n      const formattedParts = pathParts.map((part, index) => {\r\n        // 如果是最后一个路径且不是第一个路径\r\n        if (index === pathParts.length - 1 && index > 0) {\r\n          // 获取前一个路径\r\n          const prevPart = pathParts[index - 1];\r\n          // 将前一个路径按数组索引分割\r\n          const [prevBasePath] = prevPart.split(/\\[[0-9]+\\]/);\r\n          // 将当前路径按数组索引分割\r\n          const [currentBasePath] = part.split(/\\[[0-9]+\\]/);\r\n          // 组合前一个路径和当前路径\r\n          const combinedKey = `${prevBasePath}-${currentBasePath}`;\r\n          \r\n          // 如果map中存在组合后的路径，则返回本地化标签，否则返回格式化后的数组索引\r\n          return map[combinedKey as keyof typeof map]\r\n            ? getLocalizedLabel(combinedKey)\r\n            : formatArrayIndex(part);\r\n        }\r\n        // 否则返回格式化后的数组索引\r\n        return formatArrayIndex(part);\r\n      });\r\n      console.log(formattedParts, 'formattedParts',pathParts);\r\n      // 将格式化后的路径用-连接起来\r\n      errorMessage = formattedParts.join('-');\r\n    } else {\r\n      // 否则返回本地化标签\r\n      errorMessage = getLocalizedLabel(error.path);\r\n    }\r\n  \r\n    // 添加错误信息\r\n    errorMessage = `${errorMessage} ${this._LocalizationService.instant('AbpValidation::ThisFieldIsNotValid.')}`;\r\n    // 显示警告信息\r\n    this.toaster.warn(errorMessage);\r\n    return errorMessage;\r\n  }\r\n\r\n  /**提交表单 */\r\n  save() {\r\n  \r\n    this.formValidation = true;\r\n    if (!this.formEntity.valid) {\r\n      this._DigniteValidatorsService.getErrorMessage({\r\n        form:this.formEntity,\r\n        map:fieldToFormLabelMap\r\n      });\r\n      return;\r\n    }\r\n      console.log(this.formEntity.value, '提交表单', this.formEntity);\r\n    // return\r\n    if (this.isSubmitted) return;\r\n    this.isSubmitted = true;\r\n    const input = this.formEntity.value;\r\n    this._service.updateField(this.fieldDetail.id, input).subscribe({\r\n      next: () => {\r\n        this.toaster.success(this._LocalizationService.instant(`AbpUi::SavedSuccessfully`));\r\n        // this._LocationBackService.back();\r\n        this._LocationBackService.backTo({\r\n          url: `/cms/admin/fields`,\r\n          replenish: '/edit',\r\n        });\r\n        this._UpdateListService.updateList();\r\n      },\r\n      complete: () => {\r\n        this.reset();\r\n      },\r\n    });\r\n  }\r\n  /**重置表单 */\r\n  reset() {\r\n    this.isSubmitted = false;\r\n  }\r\n}\r\n","<abp-page [title]=\"'Cms::EditField' | abpLocalization\" [toolbar]=\"true\">\r\n    <form [formGroup]=\"formEntity\" [class.was-validated]=\"formValidation\" (submit)=\"save()\">\r\n        <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n        @if(fieldDetail){\r\n            <cms-create-or-edit-field  [selected]=\"fieldDetail\" [service]=\"_service\" [form]=\"formEntity\"></cms-create-or-edit-field>\r\n        }\r\n    </form>\r\n</abp-page>"]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/fields/edit-field.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/fields/edit-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\r\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';\r\nimport { Component, ElementRef, ViewChild, OnInit } from '@angular/core';\r\nimport { ECmsComponent } from '../../../enums';\r\nimport { LocalizationService } from '@abp/ng.core';\r\nimport { ToasterService } from '@abp/ng.theme.shared';\r\nimport { FormBuilder, FormGroup, FormControl } from '@angular/forms';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport {\r\n  LocationBackService,\r\n  UpdateListService,\r\n  DigniteValidatorsService,\r\n} from '@dignite-ng/expand.core';\r\nimport { FieldsDataService } from '../../../services/fields-data.service';\r\nimport { FieldsFormConfig, fieldToFormLabelMap } from './fields-form-config';\r\n\r\n@Component({\r\n  selector: 'cms-edit-field',\r\n  templateUrl: './edit-field.component.html',\r\n  styleUrl: './edit-field.component.scss',\r\n  providers: [\r\n    {\r\n      provide: EXTENSIONS_IDENTIFIER,\r\n      useValue: ECmsComponent.FieldsEdit,\r\n    },\r\n  ],\r\n})\r\nexport class EditFieldComponent implements OnInit {\r\n  constructor(\r\n    private fb: FormBuilder,\r\n    public _service: FieldsDataService,\r\n    private toaster: ToasterService,\r\n    public _LocationBackService: LocationBackService,\r\n    public _LocalizationService: LocalizationService,\r\n    private route: ActivatedRoute,\r\n    private _UpdateListService: UpdateListService,\r\n    private _DigniteValidatorsService: DigniteValidatorsService,\r\n  ) {}\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    //Called after the constructor, initializing input properties, and the first call to ngOnChanges.\r\n    //Add 'implements OnInit' to the class.\r\n    const { id } = this.route.snapshot.params;\r\n    this.formEntity = this.fb.group(new FieldsFormConfig());\r\n    await this.getFieldDetails(id);\r\n    if (this.fieldDetail) {\r\n      this.formEntity.patchValue({\r\n        ...this.fieldDetail,\r\n        groupId: this.fieldDetail.groupId || '',\r\n      });\r\n    }\r\n  }\r\n\r\n  /**获取字段详情 */\r\n  getFieldDetails(id: string) {\r\n    return new Promise((resolve, reject) => {\r\n      this._service.getFieldDetail(id).subscribe(\r\n        res => {\r\n          this.fieldDetail = res;\r\n          resolve(res);\r\n        },\r\n        err => {\r\n          resolve('');\r\n        },\r\n      );\r\n    });\r\n  }\r\n\r\n  /**字段详情 */\r\n  fieldDetail: any = '';\r\n\r\n  /*\r\n  /**表单实体 */\r\n  formEntity: FormGroup | undefined;\r\n\r\n  /**表单是否触发验证 */\r\n  formValidation = false;\r\n\r\n  /**是否提交 */\r\n  isSubmitted = false;\r\n\r\n  /**获取提交按钮替身，用于真实触发表单提交 */\r\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\r\n\r\n  /**字段分组控件 */\r\n  get groupIdInput() {\r\n    return this.formEntity?.get('groupId') as FormControl;\r\n  }\r\n \r\n  // 获取错误信息\r\n  getErrorMessage(error: any,map:any): string {\r\n    // 获取本地化标签\r\n    const getLocalizedLabel = (path: string) => {\r\n      return this._LocalizationService.instant(map[path as keyof typeof map]);\r\n    };\r\n  \r\n    // 格式化数组索引\r\n    const formatArrayIndex = (item: string) => {\r\n      const regex = /\\[[0-9]+\\]/g;\r\n      const indexMatch = item.match(regex);\r\n      const [basePath] = item.split(regex);\r\n      return getLocalizedLabel(basePath) + (indexMatch ? indexMatch[0] : '');\r\n    };\r\n  \r\n    let errorMessage = '';\r\n    // 如果错误路径包含formConfiguration\r\n    if (error.path.includes('formConfiguration')) {\r\n      // 将错误路径中的formConfiguration-替换掉，并按-分割\r\n      const pathParts = error.path.replaceAll('formConfiguration-', '').split('-');\r\n      // 对分割后的路径进行格式化\r\n      const formattedParts = pathParts.map((part, index) => {\r\n        // 如果是最后一个路径且不是第一个路径\r\n        if (index === pathParts.length - 1 && index > 0) {\r\n          // 获取前一个路径\r\n          const prevPart = pathParts[index - 1];\r\n          // 将前一个路径按数组索引分割\r\n          const [prevBasePath] = prevPart.split(/\\[[0-9]+\\]/);\r\n          // 将当前路径按数组索引分割\r\n          const [currentBasePath] = part.split(/\\[[0-9]+\\]/);\r\n          // 组合前一个路径和当前路径\r\n          const combinedKey = `${prevBasePath}-${currentBasePath}`;\r\n          \r\n          // 如果map中存在组合后的路径，则返回本地化标签，否则返回格式化后的数组索引\r\n          return map[combinedKey as keyof typeof map]\r\n            ? getLocalizedLabel(combinedKey)\r\n            : formatArrayIndex(part);\r\n        }\r\n        // 否则返回格式化后的数组索引\r\n        return formatArrayIndex(part);\r\n      });\r\n      console.log(formattedParts, 'formattedParts',pathParts);\r\n      // 将格式化后的路径用-连接起来\r\n      errorMessage = formattedParts.join('-');\r\n    } else {\r\n      // 否则返回本地化标签\r\n      errorMessage = getLocalizedLabel(error.path);\r\n    }\r\n  \r\n    // 添加错误信息\r\n    errorMessage = `${errorMessage} ${this._LocalizationService.instant('AbpValidation::ThisFieldIsNotValid.')}`;\r\n    // 显示警告信息\r\n    this.toaster.warn(errorMessage);\r\n    return errorMessage;\r\n  }\r\n\r\n  /**提交表单 */\r\n  save() {\r\n  \r\n    this.formValidation = true;\r\n    if (!this.formEntity.valid) {\r\n      this._DigniteValidatorsService.getErrorMessage({\r\n        form:this.formEntity,\r\n        map:fieldToFormLabelMap\r\n      });\r\n      return;\r\n    }\r\n      console.log(this.formEntity.value, '提交表单', this.formEntity);\r\n    if (this.isSubmitted) return;\r\n    this.isSubmitted = true;\r\n    const input = this.formEntity.value;\r\n    this._service.updateField(this.fieldDetail.id, input).subscribe({\r\n      next: () => {\r\n        this.toaster.success(this._LocalizationService.instant(`AbpUi::SavedSuccessfully`));\r\n        // this._LocationBackService.back();\r\n        this._LocationBackService.backTo({\r\n          url: `/cms/admin/fields`,\r\n          replenish: '/edit',\r\n        });\r\n        this._UpdateListService.updateList();\r\n      },\r\n      complete: () => {\r\n        this.reset();\r\n      },\r\n    });\r\n  }\r\n  /**重置表单 */\r\n  reset() {\r\n    this.isSubmitted = false;\r\n  }\r\n}\r\n","<abp-page [title]=\"'Cms::EditField' | abpLocalization\" [toolbar]=\"true\">\r\n    <form [formGroup]=\"formEntity\" [class.was-validated]=\"formValidation\" (submit)=\"save()\">\r\n        <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n        @if(fieldDetail){\r\n            <cms-create-or-edit-field  [selected]=\"fieldDetail\" [service]=\"_service\" [form]=\"formEntity\"></cms-create-or-edit-field>\r\n        }\r\n    </form>\r\n</abp-page>"]}
|
|
@@ -941,12 +941,6 @@ class EntriesComponent {
|
|
|
941
941
|
}
|
|
942
942
|
// 在原始平铺数据中查找目标节点
|
|
943
943
|
const targetItem = this.findItemById(this.copylistItem, this.dropTargetId);
|
|
944
|
-
// 验证目标节点存在且不是自己或子节点
|
|
945
|
-
if (!targetItem || this.isDescendantOrSelf(draggedItem.id, targetItem.id)) {
|
|
946
|
-
this.toaster.warn(this._LocalizationService.instant('Cms::CannotDragToSelfOrDescendant'));
|
|
947
|
-
this.clearDropState();
|
|
948
|
-
return;
|
|
949
|
-
}
|
|
950
944
|
console.log('拖拽节点:', draggedItem);
|
|
951
945
|
/*
|
|
952
946
|
拖拽位置:above-上方, below-下方, inside-内部
|
|
@@ -954,6 +948,12 @@ class EntriesComponent {
|
|
|
954
948
|
*/
|
|
955
949
|
console.log('目标节点:', targetItem);
|
|
956
950
|
console.log('位置:', this.dropPosition);
|
|
951
|
+
// 验证目标节点存在且不是自己或子节点
|
|
952
|
+
if (!targetItem || this.isDescendantOrSelf(draggedItem.id, targetItem.id)) {
|
|
953
|
+
this.toaster.warn(this._LocalizationService.instant('Cms::CannotDragToSelfOrDescendant'));
|
|
954
|
+
this.clearDropState();
|
|
955
|
+
return;
|
|
956
|
+
}
|
|
957
957
|
// 构建移动参数
|
|
958
958
|
const moveParams = {};
|
|
959
959
|
// 如果是放置到内部,设置parentId为目标节点ID
|
|
@@ -2189,7 +2189,7 @@ class CreateOrEditFieldComponent {
|
|
|
2189
2189
|
this.fromControlList = [];
|
|
2190
2190
|
}
|
|
2191
2191
|
set selected(v) {
|
|
2192
|
-
this._selected = v;
|
|
2192
|
+
this._selected = v ? JSON.parse(JSON.stringify(v)) : v;
|
|
2193
2193
|
}
|
|
2194
2194
|
set form(v) {
|
|
2195
2195
|
this.formEntity = v;
|
|
@@ -2203,6 +2203,7 @@ class CreateOrEditFieldComponent {
|
|
|
2203
2203
|
if (!this.formControlNameInput.value && this.fromControlList.length > 0) {
|
|
2204
2204
|
this.formControlNameInput.patchValue(this.fromControlList[0].name);
|
|
2205
2205
|
}
|
|
2206
|
+
console.log(this._selected, '_selected');
|
|
2206
2207
|
this.submitclick.nativeElement.click();
|
|
2207
2208
|
}
|
|
2208
2209
|
get nameInput() {
|
|
@@ -2211,6 +2212,9 @@ class CreateOrEditFieldComponent {
|
|
|
2211
2212
|
get formControlNameInput() {
|
|
2212
2213
|
return this.formEntity?.get('formControlName');
|
|
2213
2214
|
}
|
|
2215
|
+
get formConfigurationInput() {
|
|
2216
|
+
return this.formEntity?.get('formConfiguration');
|
|
2217
|
+
}
|
|
2214
2218
|
/**字段标签input失去标点生成字段名字 */
|
|
2215
2219
|
disPlayNameInputBlur(event) {
|
|
2216
2220
|
const value = event.target.value;
|
|
@@ -2241,12 +2245,27 @@ class CreateOrEditFieldComponent {
|
|
|
2241
2245
|
});
|
|
2242
2246
|
};
|
|
2243
2247
|
}
|
|
2248
|
+
/** */
|
|
2249
|
+
changeFormControlName(e) {
|
|
2250
|
+
console.log(this._selected, '_selected');
|
|
2251
|
+
// for (const element in this.formConfigurationInput.controls) {
|
|
2252
|
+
// const control = this.formConfigurationInput.controls[element];
|
|
2253
|
+
// const value = control.value;
|
|
2254
|
+
// if (Array.isArray(value)) {
|
|
2255
|
+
// control.patchValue([]);
|
|
2256
|
+
// } else if (typeof value === 'boolean') {
|
|
2257
|
+
// control.patchValue(false);
|
|
2258
|
+
// } else {
|
|
2259
|
+
// control.patchValue('');
|
|
2260
|
+
// }
|
|
2261
|
+
// }
|
|
2262
|
+
}
|
|
2244
2263
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditFieldComponent, deps: [{ token: i4.ToPinyinService }, { token: i1.LocalizationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2245
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: CreateOrEditFieldComponent, selector: "cms-create-or-edit-field", inputs: { selected: "selected", service: "service", form: "form" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"card\">\r\n <div class=\"card-body\">\r\n <form [formGroup]=\"formEntity\">\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"groupId\">\r\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n <option [value]=\"item.id\">{{item.name}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n (blur)=\"disPlayNameInputBlur($event)\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n {{nameInput.errors?.repetition}}\r\n </div>\r\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n abpLocalization}}</small>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"formControlName\">\r\n <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n @if(formControlNameInput.value&&formEntity){\r\n <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n [form]=\"formEntity\"></df-dynamic-config>\r\n }\r\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n </form>\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1$1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i6$1.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i6$1.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i6$2.DynamicConfigComponent, selector: "df-dynamic-config", inputs: ["type", "selected", "form"] }, { kind: "pipe", type: i1.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
2264
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: CreateOrEditFieldComponent, selector: "cms-create-or-edit-field", inputs: { selected: "selected", service: "service", form: "form" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"card\">\r\n <div class=\"card-body\">\r\n <form [formGroup]=\"formEntity\">\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"groupId\">\r\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n <option [value]=\"item.id\">{{item.name}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n (blur)=\"disPlayNameInputBlur($event)\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n {{nameInput.errors?.repetition}}\r\n </div>\r\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n abpLocalization}}</small>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"changeFormControlName($event)\">\r\n <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n @if(formControlNameInput.value&&formEntity){\r\n <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n [form]=\"formEntity\"></df-dynamic-config>\r\n }\r\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n </form>\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1$1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i6$1.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i6$1.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i6$2.DynamicConfigComponent, selector: "df-dynamic-config", inputs: ["type", "selected", "form"] }, { kind: "pipe", type: i1.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
2246
2265
|
}
|
|
2247
2266
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditFieldComponent, decorators: [{
|
|
2248
2267
|
type: Component,
|
|
2249
|
-
args: [{ selector: 'cms-create-or-edit-field', template: "<div class=\"card\">\r\n <div class=\"card-body\">\r\n <form [formGroup]=\"formEntity\">\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"groupId\">\r\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n <option [value]=\"item.id\">{{item.name}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n (blur)=\"disPlayNameInputBlur($event)\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n {{nameInput.errors?.repetition}}\r\n </div>\r\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n abpLocalization}}</small>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"formControlName\">\r\n <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n @if(formControlNameInput.value&&formEntity){\r\n <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n [form]=\"formEntity\"></df-dynamic-config>\r\n }\r\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n </form>\r\n </div>\r\n</div>" }]
|
|
2268
|
+
args: [{ selector: 'cms-create-or-edit-field', template: "<div class=\"card\">\r\n <div class=\"card-body\">\r\n <form [formGroup]=\"formEntity\">\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"groupId\">\r\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n <option [value]=\"item.id\">{{item.name}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n (blur)=\"disPlayNameInputBlur($event)\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n {{nameInput.errors?.repetition}}\r\n </div>\r\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n abpLocalization}}</small>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"changeFormControlName($event)\">\r\n <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n @if(formControlNameInput.value&&formEntity){\r\n <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n [form]=\"formEntity\"></df-dynamic-config>\r\n }\r\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n </form>\r\n </div>\r\n</div>" }]
|
|
2250
2269
|
}], ctorParameters: () => [{ type: i4.ToPinyinService }, { type: i1.LocalizationService }], propDecorators: { selected: [{
|
|
2251
2270
|
type: Input
|
|
2252
2271
|
}], service: [{
|
|
@@ -2450,7 +2469,6 @@ class EditFieldComponent {
|
|
|
2450
2469
|
return;
|
|
2451
2470
|
}
|
|
2452
2471
|
console.log(this.formEntity.value, '提交表单', this.formEntity);
|
|
2453
|
-
// return
|
|
2454
2472
|
if (this.isSubmitted)
|
|
2455
2473
|
return;
|
|
2456
2474
|
this.isSubmitted = true;
|