@dignite-ng/expand.cms 3.0.0-rc.48 → 3.0.0-rc.50
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/config/providers/route.provider.d.ts +2 -3
- package/esm2022/config/providers/route.provider.mjs +3 -4
- package/esm2022/lib/cms-routing.module.mjs +3 -3
- package/esm2022/lib/cms.module.mjs +4 -4
- package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +18 -16
- package/esm2022/lib/components/admin/entries/create-or-update-entry-input-base.mjs +9 -1
- package/esm2022/lib/components/admin/entries/create.component.mjs +25 -63
- package/esm2022/lib/components/admin/entries/edit.component.mjs +28 -14
- package/esm2022/lib/components/admin/entries/entries.component.mjs +11 -16
- package/esm2022/lib/components/admin/fields/create-field.component.mjs +54 -54
- package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +44 -69
- package/esm2022/lib/components/admin/fields/edit-field.component.mjs +130 -73
- package/esm2022/lib/components/admin/fields/fields-form-config.mjs +50 -0
- package/esm2022/lib/components/admin/fields/fields-group.component.mjs +128 -0
- package/esm2022/lib/components/admin/fields/fields.component.mjs +61 -57
- package/esm2022/lib/components/admin/fields/index.mjs +3 -3
- package/esm2022/lib/components/admin/sections/create-or-edit-sections-modal.component.mjs +17 -15
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.component.mjs +59 -86
- package/esm2022/lib/components/admin/sections/sections.component.mjs +11 -14
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.component.mjs +32 -23
- package/esm2022/lib/components/dynamic-form/matrix/matrix-control.component.mjs +26 -11
- package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +50 -26
- package/esm2022/lib/components/dynamic-form/table/table-control.component.mjs +10 -10
- package/esm2022/lib/components/dynamic-form/table/table-view.component.mjs +3 -2
- package/esm2022/lib/resolvers/page-default-toolbar-actions.mjs +42 -37
- package/esm2022/lib/resolvers/table-default-entity-props.mjs +4 -4
- package/esm2022/lib/services/fields-data.service.mjs +100 -0
- package/esm2022/lib/services/form-controls.service.mjs +12 -10
- package/esm2022/lib/services/index.mjs +3 -4
- package/esm2022/lib/services/keys-convert-to-lowercase.service.mjs +40 -0
- package/fesm2022/dignite-ng-expand.cms-config.mjs +2 -3
- package/fesm2022/dignite-ng-expand.cms-config.mjs.map +1 -1
- package/fesm2022/dignite-ng-expand.cms.mjs +811 -784
- package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
- package/lib/cms.module.d.ts +2 -2
- package/lib/components/admin/entries/create-or-edit-entries.component.d.ts +3 -1
- package/lib/components/admin/entries/create-or-update-entry-input-base.d.ts +8 -0
- package/lib/components/admin/entries/create.component.d.ts +1 -2
- package/lib/components/admin/entries/edit.component.d.ts +1 -2
- package/lib/components/admin/entries/entries.component.d.ts +2 -1
- package/lib/components/admin/fields/create-field.component.d.ts +19 -22
- package/lib/components/admin/fields/create-or-edit-field.component.d.ts +20 -26
- package/lib/components/admin/fields/edit-field.component.d.ts +24 -30
- package/lib/components/admin/fields/fields-form-config.d.ts +19 -0
- package/lib/components/admin/fields/fields-group.component.d.ts +48 -0
- package/lib/components/admin/fields/fields.component.d.ts +18 -16
- package/lib/components/admin/fields/index.d.ts +1 -2
- package/lib/components/admin/sections/create-or-edit-sections-modal.component.d.ts +4 -1
- package/lib/components/admin/sections/entry-types/create-or-edit.component.d.ts +14 -9
- package/lib/components/admin/sections/sections.component.d.ts +1 -3
- package/lib/components/dynamic-form/matrix/matrix-config.component.d.ts +10 -4
- package/lib/components/dynamic-form/matrix/matrix-control.component.d.ts +7 -3
- package/lib/components/dynamic-form/table/table-config.component.d.ts +15 -5
- package/lib/components/dynamic-form/table/table-control.component.d.ts +3 -3
- package/lib/components/dynamic-form/table/table-view.component.d.ts +2 -1
- package/lib/resolvers/page-default-toolbar-actions.d.ts +9 -6
- package/lib/services/fields-data.service.d.ts +45 -0
- package/lib/services/form-controls.service.d.ts +3 -1
- package/lib/services/index.d.ts +2 -3
- package/lib/services/keys-convert-to-lowercase.service.d.ts +16 -0
- package/package.json +1 -1
- package/esm2022/lib/components/admin/fields/create-or-update-field-input-base.mjs +0 -18
- package/esm2022/lib/components/admin/fields/field-group.component.mjs +0 -144
- package/esm2022/lib/constants/styles.mjs +0 -19
- package/esm2022/lib/services/appent-content.mjs +0 -15
- package/esm2022/lib/services/cms-api.service.mjs +0 -94
- package/esm2022/lib/services/cms.service.mjs +0 -22
- package/esm2022/lib/services/field-abstracts.service.mjs +0 -48
- package/lib/components/admin/fields/create-or-update-field-input-base.d.ts +0 -15
- package/lib/components/admin/fields/field-group.component.d.ts +0 -58
- package/lib/constants/styles.d.ts +0 -2
- package/lib/services/appent-content.d.ts +0 -1
- package/lib/services/cms-api.service.d.ts +0 -23
- package/lib/services/cms.service.d.ts +0 -10
- package/lib/services/field-abstracts.service.d.ts +0 -20
|
@@ -1,92 +1,92 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-inferrable-types */
|
|
1
2
|
/* eslint-disable @angular-eslint/component-selector */
|
|
2
3
|
import { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';
|
|
4
|
+
import { Component, ElementRef, ViewChild } from '@angular/core';
|
|
5
|
+
import { ECmsComponent } from '../../../enums';
|
|
3
6
|
import { LocalizationService } from '@abp/ng.core';
|
|
4
7
|
import { ToasterService } from '@abp/ng.theme.shared';
|
|
5
|
-
import { Location } from '@angular/common';
|
|
6
|
-
import { Component, inject, ViewChild, ElementRef } from '@angular/core';
|
|
7
8
|
import { FormBuilder } from '@angular/forms';
|
|
8
|
-
import { CmsApiService } from '../../../services';
|
|
9
|
-
import { ECmsComponent } from '../../../enums';
|
|
10
|
-
import { UpdateListService } from '@dignite-ng/expand.core';
|
|
11
|
-
import { CreateOrUpdateFieldInputBase } from './create-or-update-field-input-base';
|
|
12
|
-
import { ValidatorsService } from '@dignite-ng/expand.core';
|
|
13
|
-
import { finalize } from 'rxjs';
|
|
14
|
-
import { FieldAdminService } from '../../../proxy/dignite/cms/admin/fields';
|
|
15
9
|
import { ActivatedRoute } from '@angular/router';
|
|
10
|
+
import { DigniteValidatorsService, LocationBackService, UpdateListService, } from '@dignite-ng/expand.core';
|
|
11
|
+
import { FieldsFormConfig, fieldToFormLabelMap } from './fields-form-config';
|
|
12
|
+
import { FieldsDataService } from '../../../services/fields-data.service';
|
|
16
13
|
import * as i0 from "@angular/core";
|
|
17
14
|
import * as i1 from "@angular/forms";
|
|
18
|
-
import * as i2 from "../../../
|
|
15
|
+
import * as i2 from "../../../services/fields-data.service";
|
|
19
16
|
import * as i3 from "@abp/ng.theme.shared";
|
|
20
|
-
import * as i4 from "@
|
|
17
|
+
import * as i4 from "@dignite-ng/expand.core";
|
|
21
18
|
import * as i5 from "@abp/ng.core";
|
|
22
|
-
import * as i6 from "
|
|
19
|
+
import * as i6 from "@angular/router";
|
|
23
20
|
import * as i7 from "@ngx-validate/core";
|
|
24
21
|
import * as i8 from "@abp/ng.components/page";
|
|
25
22
|
import * as i9 from "./create-or-edit-field.component";
|
|
26
23
|
export class CreateFieldComponent {
|
|
27
|
-
constructor(fb,
|
|
24
|
+
constructor(fb, _service, toaster, _LocationBackService, _LocalizationService, route, _UpdateListService, _DigniteValidatorsService) {
|
|
28
25
|
this.fb = fb;
|
|
29
|
-
this.
|
|
26
|
+
this._service = _service;
|
|
30
27
|
this.toaster = toaster;
|
|
31
|
-
this.
|
|
28
|
+
this._LocationBackService = _LocationBackService;
|
|
32
29
|
this._LocalizationService = _LocalizationService;
|
|
33
|
-
this.
|
|
34
|
-
this.
|
|
35
|
-
this.
|
|
36
|
-
|
|
37
|
-
this.
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
* title:true,
|
|
41
|
-
* }
|
|
42
|
-
*/
|
|
43
|
-
this.formValidation = '';
|
|
44
|
-
}
|
|
45
|
-
get groupIdInput() {
|
|
46
|
-
return this.newEntity?.get('groupId');
|
|
30
|
+
this.route = route;
|
|
31
|
+
this._UpdateListService = _UpdateListService;
|
|
32
|
+
this._DigniteValidatorsService = _DigniteValidatorsService;
|
|
33
|
+
/**表单是否触发验证 */
|
|
34
|
+
this.formValidation = false;
|
|
35
|
+
/**是否提交 */
|
|
36
|
+
this.isSubmitted = false;
|
|
47
37
|
}
|
|
48
|
-
ngOnInit() {
|
|
38
|
+
async ngOnInit() {
|
|
49
39
|
//Called after the constructor, initializing input properties, and the first call to ngOnChanges.
|
|
50
40
|
//Add 'implements OnInit' to the class.
|
|
51
41
|
const { groupId } = this.route.snapshot.queryParams;
|
|
52
|
-
this.
|
|
42
|
+
this.formEntity = this.fb.group(new FieldsFormConfig());
|
|
53
43
|
if (groupId) {
|
|
54
44
|
this.groupIdInput.patchValue(groupId);
|
|
55
45
|
}
|
|
56
46
|
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
this.
|
|
47
|
+
/**字段分组控件 */
|
|
48
|
+
get groupIdInput() {
|
|
49
|
+
return this.formEntity?.get('groupId');
|
|
60
50
|
}
|
|
61
|
-
|
|
51
|
+
/**提交表单 */
|
|
62
52
|
save() {
|
|
63
|
-
this.
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
53
|
+
console.log(this.formEntity.value, '提交表单', this.formEntity);
|
|
54
|
+
this.formValidation = true;
|
|
55
|
+
if (!this.formEntity.valid) {
|
|
56
|
+
this._DigniteValidatorsService.getErrorMessage({
|
|
57
|
+
form: this.formEntity,
|
|
58
|
+
map: fieldToFormLabelMap
|
|
59
|
+
});
|
|
68
60
|
return;
|
|
69
|
-
|
|
70
|
-
if (
|
|
61
|
+
}
|
|
62
|
+
if (this.isSubmitted)
|
|
71
63
|
return;
|
|
72
|
-
this.
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
this.
|
|
76
|
-
}))
|
|
77
|
-
.subscribe(res => {
|
|
64
|
+
this.isSubmitted = true;
|
|
65
|
+
const input = this.formEntity.value;
|
|
66
|
+
this._service.createField(input).subscribe(() => {
|
|
67
|
+
this.reset();
|
|
78
68
|
this.toaster.success(this._LocalizationService.instant(`AbpUi::SavedSuccessfully`));
|
|
79
|
-
this.
|
|
69
|
+
// this._LocationBackService.back();
|
|
70
|
+
this._LocationBackService.backTo({
|
|
71
|
+
url: `/cms/admin/fields`,
|
|
72
|
+
replenish: '/create',
|
|
73
|
+
});
|
|
80
74
|
this._UpdateListService.updateList();
|
|
75
|
+
}, () => {
|
|
76
|
+
this.reset();
|
|
81
77
|
});
|
|
82
78
|
}
|
|
83
|
-
|
|
79
|
+
/**重置表单 */
|
|
80
|
+
reset() {
|
|
81
|
+
this.isSubmitted = false;
|
|
82
|
+
}
|
|
83
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateFieldComponent, deps: [{ token: i1.FormBuilder }, { token: i2.FieldsDataService }, { token: i3.ToasterService }, { token: i4.LocationBackService }, { token: i5.LocalizationService }, { token: i6.ActivatedRoute }, { token: i4.UpdateListService }, { token: i4.DigniteValidatorsService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
84
84
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: CreateFieldComponent, selector: "cms-create-field", providers: [
|
|
85
85
|
{
|
|
86
86
|
provide: EXTENSIONS_IDENTIFIER,
|
|
87
87
|
useValue: ECmsComponent.FieldsCreate,
|
|
88
88
|
},
|
|
89
|
-
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<abp-page [title]=\"'Cms::CreateField' | abpLocalization\" [toolbar]=\"true\">\n
|
|
89
|
+
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<abp-page [title]=\"'Cms::CreateField' | 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 <cms-create-or-edit-field [service]=\"_service\" [form]=\"formEntity\"></cms-create-or-edit-field>\r\n </form>\r\n</abp-page>", styles: [""], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i7.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "component", type: i8.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i9.CreateOrEditFieldComponent, selector: "cms-create-or-edit-field", inputs: ["selected", "service", "form"] }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
90
90
|
}
|
|
91
91
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateFieldComponent, decorators: [{
|
|
92
92
|
type: Component,
|
|
@@ -95,9 +95,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
95
95
|
provide: EXTENSIONS_IDENTIFIER,
|
|
96
96
|
useValue: ECmsComponent.FieldsCreate,
|
|
97
97
|
},
|
|
98
|
-
], template: "<abp-page [title]=\"'Cms::CreateField' | abpLocalization\" [toolbar]=\"true\">\n
|
|
99
|
-
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.
|
|
98
|
+
], template: "<abp-page [title]=\"'Cms::CreateField' | 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 <cms-create-or-edit-field [service]=\"_service\" [form]=\"formEntity\"></cms-create-or-edit-field>\r\n </form>\r\n</abp-page>" }]
|
|
99
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.FieldsDataService }, { type: i3.ToasterService }, { type: i4.LocationBackService }, { type: i5.LocalizationService }, { type: i6.ActivatedRoute }, { type: i4.UpdateListService }, { type: i4.DigniteValidatorsService }], propDecorators: { submitclick: [{
|
|
100
100
|
type: ViewChild,
|
|
101
101
|
args: ['submitclick', { static: true }]
|
|
102
102
|
}] } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/fields/create-field.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/fields/create-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-inferrable-types */\r\n/* eslint-disable @angular-eslint/component-selector */\r\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';\r\nimport { Component, ElementRef,  OnInit, ViewChild } 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, FormControl, FormGroup } from '@angular/forms';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport {\r\n  DigniteValidatorsService,\r\n  LocationBackService,\r\n  UpdateListService,\r\n} from '@dignite-ng/expand.core';\r\nimport { FieldsFormConfig, fieldToFormLabelMap } from './fields-form-config';\r\nimport { FieldsDataService } from '../../../services/fields-data.service';\r\n\r\n@Component({\r\n  selector: 'cms-create-field',\r\n  templateUrl: './create-field.component.html',\r\n  styleUrl: './create-field.component.scss',\r\n  providers: [\r\n    {\r\n      provide: EXTENSIONS_IDENTIFIER,\r\n      useValue: ECmsComponent.FieldsCreate,\r\n    },\r\n  ],\r\n})\r\nexport class CreateFieldComponent 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 { groupId } = this.route.snapshot.queryParams;\r\n    this.formEntity = this.fb.group(new FieldsFormConfig());\r\n    if (groupId) {\r\n      this.groupIdInput.patchValue(groupId);\r\n    }\r\n  }\r\n\r\n  /**表单实体 */\r\n  formEntity: FormGroup | undefined;\r\n\r\n  /**表单是否触发验证 */\r\n  formValidation: boolean = false;\r\n\r\n  /**是否提交 */\r\n  isSubmitted: boolean = 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  save() {\r\n    console.log(this.formEntity.value, '提交表单', this.formEntity);\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    if (this.isSubmitted) return;\r\n    this.isSubmitted = true;\r\n    const input = this.formEntity.value;\r\n    this._service.createField(input).subscribe(\r\n      () => {\r\n        this.reset();\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: '/create',\r\n        });\r\n        this._UpdateListService.updateList();\r\n      },\r\n      () => {\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::CreateField' | 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        <cms-create-or-edit-field   [service]=\"_service\" [form]=\"formEntity\"></cms-create-or-edit-field>\r\n    </form>\r\n</abp-page>"]}
|
|
@@ -1,82 +1,57 @@
|
|
|
1
1
|
/* eslint-disable @angular-eslint/component-selector */
|
|
2
2
|
import { Component, ElementRef, Input, ViewChild } from '@angular/core';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import { CmsApiService } from '../../../services/cms-api.service';
|
|
3
|
+
import { FormGroup } from '@angular/forms';
|
|
4
|
+
import { ToPinyinService } from '@dignite-ng/expand.core';
|
|
6
5
|
import { LocalizationService } from '@abp/ng.core';
|
|
7
|
-
import { FieldAdminService } from '../../../proxy/dignite/cms/admin/fields';
|
|
8
6
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "
|
|
10
|
-
import * as i2 from "
|
|
11
|
-
import * as i3 from "
|
|
12
|
-
import * as i4 from "@
|
|
13
|
-
import * as i5 from "@
|
|
14
|
-
import * as i6 from "@
|
|
15
|
-
import * as i7 from "@ngx-validate/core";
|
|
16
|
-
import * as i8 from "@dignite-ng/expand.dynamic-form";
|
|
7
|
+
import * as i1 from "@dignite-ng/expand.core";
|
|
8
|
+
import * as i2 from "@abp/ng.core";
|
|
9
|
+
import * as i3 from "@angular/common";
|
|
10
|
+
import * as i4 from "@angular/forms";
|
|
11
|
+
import * as i5 from "@ngx-validate/core";
|
|
12
|
+
import * as i6 from "@dignite-ng/expand.dynamic-form";
|
|
17
13
|
export class CreateOrEditFieldComponent {
|
|
18
|
-
constructor(
|
|
19
|
-
this.
|
|
20
|
-
this._CmsApiService = _CmsApiService;
|
|
21
|
-
this._FieldAdminService = _FieldAdminService;
|
|
14
|
+
constructor(_ToPinyinService, _LocalizationService) {
|
|
15
|
+
this._ToPinyinService = _ToPinyinService;
|
|
22
16
|
this._LocalizationService = _LocalizationService;
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
set Entity(v) {
|
|
28
|
-
if (v) {
|
|
29
|
-
this._Entity = v;
|
|
30
|
-
this.dataLoaded();
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
get formControlName() {
|
|
34
|
-
return this._Entity.get('formControlName');
|
|
17
|
+
/**字段分组列表 */
|
|
18
|
+
this.getfieldGroupsList = [];
|
|
19
|
+
/**表单控件列表 */
|
|
20
|
+
this.fromControlList = [];
|
|
35
21
|
}
|
|
36
22
|
set selected(v) {
|
|
37
|
-
|
|
38
|
-
this._selected = v || '';
|
|
39
|
-
this._selected_copy = v;
|
|
40
|
-
}
|
|
23
|
+
this._selected = v;
|
|
41
24
|
}
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
this.
|
|
53
|
-
validators: Validators.required,
|
|
54
|
-
asyncValidators: [this.repetitionAsyncValidator()],
|
|
55
|
-
updateOn: 'change',
|
|
56
|
-
}));
|
|
57
|
-
setTimeout(() => {
|
|
58
|
-
// this.submitclick.nativeElement.click();
|
|
59
|
-
}, 0);
|
|
25
|
+
set form(v) {
|
|
26
|
+
this.formEntity = v;
|
|
27
|
+
}
|
|
28
|
+
async ngAfterContentInit() {
|
|
29
|
+
//Called after ngOnInit when the component's or directive's content has been initialized.
|
|
30
|
+
//Add 'implements AfterContentInit' to the class.
|
|
31
|
+
this.getfieldGroupsList = await this.service.getfieldGroups();
|
|
32
|
+
this.fromControlList = await this.service.getControlsfieldTypes();
|
|
33
|
+
this.nameInput.addAsyncValidators([this.repetitionAsyncValidator()]);
|
|
34
|
+
if (!this.formControlNameInput.value && this.fromControlList.length > 0) {
|
|
35
|
+
this.formControlNameInput.patchValue(this.fromControlList[0].name);
|
|
60
36
|
}
|
|
37
|
+
this.submitclick.nativeElement.click();
|
|
61
38
|
}
|
|
62
|
-
/**name表单控件 */
|
|
63
39
|
get nameInput() {
|
|
64
|
-
return this.
|
|
40
|
+
return this.formEntity?.get('name');
|
|
65
41
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
this.nameInput.patchValue(value);
|
|
42
|
+
get formControlNameInput() {
|
|
43
|
+
return this.formEntity?.get('formControlName');
|
|
69
44
|
}
|
|
70
45
|
/**字段标签input失去标点生成字段名字 */
|
|
71
46
|
disPlayNameInputBlur(event) {
|
|
72
47
|
const value = event.target.value;
|
|
73
|
-
const pinyin = this.
|
|
48
|
+
const pinyin = this._ToPinyinService.get(value);
|
|
74
49
|
const nameInput = this.nameInput;
|
|
75
50
|
if (nameInput.value)
|
|
76
51
|
return;
|
|
77
52
|
nameInput.patchValue(pinyin);
|
|
78
53
|
}
|
|
79
|
-
|
|
54
|
+
/**异步验证,验证别名 */
|
|
80
55
|
repetitionAsyncValidator() {
|
|
81
56
|
return (ctrl) => {
|
|
82
57
|
return new Promise(resolve => {
|
|
@@ -84,7 +59,7 @@ export class CreateOrEditFieldComponent {
|
|
|
84
59
|
resolve(null);
|
|
85
60
|
return;
|
|
86
61
|
}
|
|
87
|
-
this.
|
|
62
|
+
this.service.nameExists(ctrl.value).subscribe(res => {
|
|
88
63
|
if (res) {
|
|
89
64
|
resolve({
|
|
90
65
|
repetition: this._LocalizationService.instant(`Cms::FieldName{0}AlreadyExist`, ctrl.value),
|
|
@@ -97,20 +72,20 @@ export class CreateOrEditFieldComponent {
|
|
|
97
72
|
});
|
|
98
73
|
};
|
|
99
74
|
}
|
|
100
|
-
|
|
101
|
-
}
|
|
102
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditFieldComponent, deps: [{ token: i1.FieldAbstractsService }, { token: i2.CmsApiService }, { token: i3.FieldAdminService }, { token: i4.LocalizationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
103
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: CreateOrEditFieldComponent, selector: "cms-create-or-edit-field", inputs: { Entity: "Entity", selected: "selected" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<div [formGroup]=\"_Entity\" >\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\n <select class=\"form-select\" formControlName=\"groupId\">\n <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\n <ng-container *ngFor=\"let item of _FieldAbstractsService.fieldGroupList\">\n <option [value]=\"item.id\">{{item.name}}</option>\n </ng-container>\n </select>\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"displayName\">{{'AbpDynamicForm::FieldDisplayName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required (blur)=\"disPlayNameInputBlur($event)\">\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"name\">{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"name\" (input)=\"nameInputBlur($event)\">\n <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\n {{nameInput.errors?.repetition}}\n </div>\n <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' | abpLocalization}}</small>\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"description\">\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"formControlName\">{{'Cms::FieldType' | abpLocalization}}</label>\n <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"formControlNameChange($event)\">\n <ng-container *ngFor=\"let item of _FieldAbstractsService.fromControlList;let i =index\">\n <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\n </ng-container>\n </select>\n </div>\n <ng-container *ngIf=\"_Entity.value.formControlName&&_Entity\"> \n <df-dynamic [type]=\"_Entity.value.formControlName\" [selected]=\"_selected\" [entity]=\"_Entity\" ></df-dynamic>\n </ng-container>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i6.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i6.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: i6.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i6.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i7.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i7.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i8.DynamicComponent, selector: "df-dynamic", inputs: ["selected", "type", "culture", "parentFiledName", "fields", "entity"] }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
75
|
+
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" }] }); }
|
|
104
77
|
}
|
|
105
78
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditFieldComponent, decorators: [{
|
|
106
79
|
type: Component,
|
|
107
|
-
args: [{ selector: 'cms-create-or-edit-field', template: "<div
|
|
108
|
-
}], ctorParameters: () => [{ type: i1.
|
|
109
|
-
type: ViewChild,
|
|
110
|
-
args: ['submitclick', { static: true }]
|
|
111
|
-
}], Entity: [{
|
|
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>" }]
|
|
81
|
+
}], ctorParameters: () => [{ type: i1.ToPinyinService }, { type: i2.LocalizationService }], propDecorators: { selected: [{
|
|
112
82
|
type: Input
|
|
113
|
-
}],
|
|
83
|
+
}], service: [{
|
|
114
84
|
type: Input
|
|
85
|
+
}], form: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], submitclick: [{
|
|
88
|
+
type: ViewChild,
|
|
89
|
+
args: ['submitclick', { static: true }]
|
|
115
90
|
}] } });
|
|
116
|
-
//# 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 */\nimport { Component, ElementRef, Input, ViewChild, ViewContainerRef } from '@angular/core';\nimport { FieldAbstractsService } from '../../../services/field-abstracts.service';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  ValidationErrors,\n  Validators,\n} from '@angular/forms';\nimport { CmsApiService } from '../../../services/cms-api.service';\nimport { Observable } from 'rxjs';\nimport { LocalizationService } from '@abp/ng.core';\nimport { FieldAdminService } from '../../../proxy/dignite/cms/admin/fields';\n@Component({\n  selector: 'cms-create-or-edit-field',\n  templateUrl: './create-or-edit-field.component.html',\n  styleUrls: ['./create-or-edit-field.component.scss'],\n})\nexport class CreateOrEditFieldComponent {\n  /**表单控件模板-动态表单配置组件 */\n  // @ViewChild('FormDynamicRef', { read: ViewContainerRef, static: true })\n  // FormDynamicRef: ViewContainerRef;\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  constructor(\n    public _FieldAbstractsService: FieldAbstractsService,\n    private _CmsApiService: CmsApiService,\n    private _FieldAdminService: FieldAdminService,\n    private _LocalizationService: LocalizationService\n  ) {\n    if (this._FieldAbstractsService.fieldGroupList.length == 0) {\n      this._FieldAbstractsService.getfieldGroupList();\n    }\n  }\n  /**表单实体 */\n  _Entity: FormGroup | undefined;\n  @Input()\n  public set Entity(v: FormGroup | undefined) {\n    if (v) {\n      this._Entity = v;\n      this.dataLoaded();\n    }\n  }\n  get formControlName() {\n    return this._Entity.get('formControlName');\n  }\n  /**选择的表单信息 */\n  _selected_copy: any;\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    if (v) {\n      this._selected = v || '';\n      this._selected_copy = v;\n    }\n  }\n\n  async dataLoaded() {\n    if (this._FieldAbstractsService.fromControlList.length == 0) {\n      await this._FieldAbstractsService.getFromControlList();\n    }\n\n    if (this._Entity) {\n      if (!this.formControlName.value) {\n        this._Entity.patchValue({\n          formControlName: this._FieldAbstractsService.fromControlList[0]?.name,\n        });\n      }\n      this._Entity.setControl(\n        'name',\n        new FormControl(this.nameInput.value || '', {\n          validators: Validators.required,\n          asyncValidators: [this.repetitionAsyncValidator()],\n          updateOn: 'change',\n        })\n      );\n      setTimeout(() => {\n        // this.submitclick.nativeElement.click();\n      }, 0);\n    }\n  }\n\n  /**name表单控件 */\n  get nameInput() {\n    return this._Entity.get('name');\n  }\n\n  nameInputBlur(event) {\n    const value = event.target.value;\n    this.nameInput.patchValue(value);\n  }\n\n  /**字段标签input失去标点生成字段名字 */\n  disPlayNameInputBlur(event) {\n    const value = event.target.value;\n    const pinyin = this._CmsApiService.chineseToPinyin(value);\n    const nameInput = this.nameInput;\n    if (nameInput.value) return;\n    nameInput.patchValue(pinyin);\n  }\n  /**定义异步验证方法 */\n  repetitionAsyncValidator() {\n    return (\n      ctrl: AbstractControl\n    ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise(resolve => {\n        if (ctrl.value == this._selected?.name || !ctrl.value) {\n          resolve(null);\n          return;\n        }\n        this._FieldAdminService.nameExists(ctrl.value).subscribe(res => {\n          if (res) {\n            resolve({\n              repetition: this._LocalizationService.instant(\n                `Cms::FieldName{0}AlreadyExist`,\n                ctrl.value\n              ),\n            });\n          } else {\n            resolve(null);\n          }\n        });\n      });\n    };\n  }\n\n  formControlNameChange(event) {\n  }\n}\n","<div [formGroup]=\"_Entity\" >\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n    <div class=\"mb-3\">\n        <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\n        <select class=\"form-select\" formControlName=\"groupId\">\n            <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\n            <ng-container *ngFor=\"let item of _FieldAbstractsService.fieldGroupList\">\n                <option [value]=\"item.id\">{{item.name}}</option>\n            </ng-container>\n        </select>\n    </div>\n    <div class=\"mb-3\">\n        <label class=\"form-label\" for=\"displayName\">{{'AbpDynamicForm::FieldDisplayName' | abpLocalization}}</label>\n        <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required (blur)=\"disPlayNameInputBlur($event)\">\n    </div>\n    <div class=\"mb-3\">\n        <label class=\"form-label\" for=\"name\">{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\n        <input type=\"text\" class=\"form-control\" formControlName=\"name\" (input)=\"nameInputBlur($event)\">\n        <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\n            {{nameInput.errors?.repetition}}\n        </div>\n        <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' | abpLocalization}}</small>\n    </div>\n    <div class=\"mb-3\">\n        <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\n        <input type=\"text\" class=\"form-control\" formControlName=\"description\">\n    </div>\n    <div class=\"mb-3\">\n        <label class=\"form-label\" for=\"formControlName\">{{'Cms::FieldType' | abpLocalization}}</label>\n        <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"formControlNameChange($event)\">\n            <ng-container *ngFor=\"let item of _FieldAbstractsService.fromControlList;let i =index\">\n                <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\n            </ng-container>\n        </select>\n    </div>\n    <ng-container *ngIf=\"_Entity.value.formControlName&&_Entity\"> \n        <df-dynamic [type]=\"_Entity.value.formControlName\" [selected]=\"_selected\" [entity]=\"_Entity\" ></df-dynamic>\n    </ng-container>\n</div>"]}
|
|
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>"]}
|