@dignite-ng/expand.cms 0.0.49 → 0.0.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/components/domains/domains.component.d.ts +7 -0
- package/config/components/site-language/site-language.component.d.ts +29 -0
- package/config/enums/route-names.d.ts +3 -2
- package/config/proxy/dignite/cms/admin/sites/index.d.ts +2 -0
- package/config/proxy/dignite/cms/admin/sites/models.d.ts +4 -0
- package/config/proxy/dignite/cms/admin/sites/site-admin.service.d.ts +13 -0
- package/config/proxy/dignite/cms/sites/models.d.ts +4 -0
- package/config/services/validators.service.d.ts +16 -0
- package/esm2022/config/cms-config.module.mjs +4 -4
- package/esm2022/config/components/domains/domains.component.mjs +22 -11
- package/esm2022/config/components/site-language/site-language.component.mjs +108 -0
- package/esm2022/config/enums/route-names.mjs +11 -2
- package/esm2022/config/providers/route.provider.mjs +17 -11
- package/esm2022/config/proxy/admin/domains/domain-admin.service.mjs +18 -19
- package/esm2022/config/proxy/dignite/cms/admin/sites/index.mjs +3 -0
- package/esm2022/config/proxy/dignite/cms/admin/sites/models.mjs +2 -0
- package/esm2022/config/proxy/dignite/cms/admin/sites/site-admin.service.mjs +27 -0
- package/esm2022/config/proxy/dignite/cms/sites/models.mjs +2 -0
- package/esm2022/config/services/validators.service.mjs +82 -0
- package/esm2022/lib/cms-routing.module.mjs +6 -6
- package/esm2022/lib/cms.module.mjs +16 -8
- package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +29 -44
- package/esm2022/lib/components/admin/entries/create-or-update-entry-input-base.mjs +20 -20
- package/esm2022/lib/components/admin/entries/create.component.mjs +25 -23
- package/esm2022/lib/components/admin/entries/edit.component.mjs +25 -23
- package/esm2022/lib/components/admin/entries/entries.component.mjs +36 -43
- package/esm2022/lib/components/admin/fields/create-field.component.mjs +18 -18
- package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +8 -15
- package/esm2022/lib/components/admin/fields/create-or-update-field-input-base.mjs +13 -13
- package/esm2022/lib/components/admin/fields/edit-field.component.mjs +20 -23
- package/esm2022/lib/components/admin/fields/field-group.component.mjs +35 -27
- package/esm2022/lib/components/admin/fields/fields.component.mjs +14 -20
- package/esm2022/lib/components/admin/sections/create-or-update-sections-input-base.mjs +15 -15
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.-entry-type-input-base.mjs +26 -26
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.component.mjs +43 -66
- package/esm2022/lib/components/admin/sections/sections.component.mjs +28 -25
- package/esm2022/lib/components/dynamic-form/entry/entry-config.component.mjs +10 -21
- package/esm2022/lib/components/dynamic-form/entry/entry-config.mjs +7 -7
- package/esm2022/lib/components/dynamic-form/entry/entry-control.component.mjs +9 -19
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.component.mjs +14 -30
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.mjs +16 -16
- package/esm2022/lib/components/dynamic-form/matrix/matrix-control.component.mjs +7 -22
- package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +8 -30
- package/esm2022/lib/components/dynamic-form/table/table-config.mjs +15 -15
- package/esm2022/lib/components/dynamic-form/table/table-control.component.mjs +6 -20
- package/esm2022/lib/constants/styles.mjs +6 -1
- package/esm2022/lib/proxy/admin/dynamic-forms/form-admin.service.mjs +8 -9
- package/esm2022/lib/proxy/admin/entries/entry-admin.service.mjs +56 -57
- package/esm2022/lib/proxy/admin/fields/field-admin.service.mjs +31 -32
- package/esm2022/lib/proxy/admin/fields/field-group-admin.service.mjs +27 -28
- package/esm2022/lib/proxy/admin/sections/entry-type-admin.service.mjs +27 -28
- package/esm2022/lib/proxy/admin/sections/section-admin.service.mjs +37 -38
- package/esm2022/lib/proxy/admin/settings/site-settings-admin.service.mjs +17 -18
- package/esm2022/lib/resolvers/extensions-props-action-token.resolver.mjs +132 -0
- package/esm2022/lib/resolvers/page-default-toolbar-actions.mjs +160 -0
- package/esm2022/lib/services/cms-api.service.mjs +3 -4
- package/esm2022/lib/services/cms.service.mjs +4 -5
- package/esm2022/lib/services/field-abstracts.service.mjs +7 -9
- package/esm2022/lib/services/simple-reuse-strategy.mjs +2 -2
- package/esm2022/lib/services/update-list.service.mjs +6 -5
- package/esm2022/lib/services/validators.service.mjs +83 -0
- package/esm2022/public-api.mjs +1 -4
- package/fesm2022/dignite-ng-expand.cms-config.mjs +265 -44
- package/fesm2022/dignite-ng-expand.cms-config.mjs.map +1 -1
- package/fesm2022/dignite-ng-expand.cms.mjs +856 -865
- package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
- package/lib/components/admin/entries/create.component.d.ts +7 -0
- package/lib/components/admin/entries/edit.component.d.ts +7 -0
- package/lib/components/admin/fields/create-field.component.d.ts +7 -0
- package/lib/components/admin/fields/create-or-edit-field.component.d.ts +3 -1
- package/lib/components/admin/fields/edit-field.component.d.ts +7 -0
- package/lib/components/admin/fields/field-group.component.d.ts +7 -0
- package/lib/components/admin/sections/entry-types/create-or-edit.component.d.ts +7 -0
- package/lib/components/admin/sections/sections.component.d.ts +7 -0
- package/lib/constants/styles.d.ts +1 -1
- package/lib/resolvers/extensions-props-action-token.resolver.d.ts +71 -0
- package/lib/services/validators.service.d.ts +16 -0
- package/package.json +1 -1
- package/esm2022/lib/toolbar/index.mjs +0 -3
- package/esm2022/lib/toolbar/toolbar-btn-default-action.mjs +0 -160
- package/esm2022/lib/toolbar/toolbar-config.mjs +0 -83
- package/lib/toolbar/index.d.ts +0 -2
- package/lib/toolbar/toolbar-config.d.ts +0 -56
- /package/lib/{toolbar/toolbar-btn-default-action.d.ts → resolvers/page-default-toolbar-actions.d.ts} +0 -0
|
@@ -3,6 +3,7 @@ import { Component, inject, ViewChild } from '@angular/core';
|
|
|
3
3
|
import { ECmsComponent } from '../../../enums';
|
|
4
4
|
import { UpdateListService } from '../../../services/update-list.service';
|
|
5
5
|
import { CreateOrUpdateFieldInputBase } from './create-or-update-field-input-base';
|
|
6
|
+
import { ValidatorsService } from '../../../services/validators.service';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/forms";
|
|
8
9
|
import * as i2 from "../../../proxy/admin/fields";
|
|
@@ -14,12 +15,6 @@ import * as i7 from "@ngx-validate/core";
|
|
|
14
15
|
import * as i8 from "@abp/ng.components/page";
|
|
15
16
|
import * as i9 from "./create-or-edit-field.component";
|
|
16
17
|
export class CreateFieldComponent {
|
|
17
|
-
fb;
|
|
18
|
-
_FieldAdminService;
|
|
19
|
-
toaster;
|
|
20
|
-
_location;
|
|
21
|
-
_LocalizationService;
|
|
22
|
-
_CmsApiService;
|
|
23
18
|
constructor(fb, _FieldAdminService, toaster, _location, _LocalizationService, _CmsApiService) {
|
|
24
19
|
this.fb = fb;
|
|
25
20
|
this._FieldAdminService = _FieldAdminService;
|
|
@@ -27,12 +22,16 @@ export class CreateFieldComponent {
|
|
|
27
22
|
this._location = _location;
|
|
28
23
|
this._LocalizationService = _LocalizationService;
|
|
29
24
|
this._CmsApiService = _CmsApiService;
|
|
25
|
+
this._UpdateListService = inject(UpdateListService);
|
|
26
|
+
this.isSubmit = false;
|
|
27
|
+
this._ValidatorsService = inject(ValidatorsService);
|
|
28
|
+
/**表单验证状态
|
|
29
|
+
* {
|
|
30
|
+
* title:true,
|
|
31
|
+
* }
|
|
32
|
+
*/
|
|
33
|
+
this.formValidation = '';
|
|
30
34
|
}
|
|
31
|
-
_UpdateListService = inject(UpdateListService);
|
|
32
|
-
/**表单实体 */
|
|
33
|
-
newEntity;
|
|
34
|
-
/**获取提交按钮替身,用于真实触发表单提交 */
|
|
35
|
-
submitclick;
|
|
36
35
|
ngOnInit() {
|
|
37
36
|
//Called after the constructor, initializing input properties, and the first call to ngOnChanges.
|
|
38
37
|
//Add 'implements OnInit' to the class.
|
|
@@ -43,11 +42,12 @@ export class CreateFieldComponent {
|
|
|
43
42
|
this.isSubmit = true;
|
|
44
43
|
this.submitclick.nativeElement.click();
|
|
45
44
|
}
|
|
46
|
-
isSubmit = false;
|
|
47
45
|
/**保存表单 */
|
|
48
46
|
save() {
|
|
49
47
|
let input = this.newEntity.value;
|
|
50
|
-
if (!this.isSubmit)
|
|
48
|
+
// if (!this.isSubmit) return;
|
|
49
|
+
this.formValidation = this._ValidatorsService.getFormValidationStatus(this.newEntity);
|
|
50
|
+
if (this._ValidatorsService.isCheckForm(this.formValidation))
|
|
51
51
|
return;
|
|
52
52
|
if (!this.newEntity.valid)
|
|
53
53
|
return;
|
|
@@ -57,13 +57,13 @@ export class CreateFieldComponent {
|
|
|
57
57
|
this._UpdateListService.updateList();
|
|
58
58
|
});
|
|
59
59
|
}
|
|
60
|
-
static
|
|
61
|
-
static
|
|
60
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateFieldComponent, deps: [{ token: i1.FormBuilder }, { token: i2.FieldAdminService }, { token: i3.ToasterService }, { token: i4.Location }, { token: i5.LocalizationService }, { token: i6.CmsApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
61
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: CreateFieldComponent, selector: "cms-create-field", providers: [
|
|
62
62
|
{
|
|
63
63
|
provide: EXTENSIONS_IDENTIFIER,
|
|
64
64
|
useValue: ECmsComponent.FieldsCreate,
|
|
65
65
|
},
|
|
66
|
-
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form
|
|
66
|
+
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"newEntity\" (keydown.enter)=\"$event.preventDefault()\" [class]=\"{'was-validated':formValidation}\" (submit)=\"save()\">\n <abp-page [title]=\"'Cms::CreateField' | abpLocalization\" [toolbar]=\"true\">\n <div class=\"create-field-page\">\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\n <div class=\"card\">\n <div class=\"card-body\">\n <cms-create-or-edit-field [Entity]=\"newEntity\"></cms-create-or-edit-field>\n </div>\n </div>\n </div>\n </abp-page>\n</form>", styles: ["::ng-deep .create-field-page .dignite_page{height:calc(100vh - 125px);overflow:auto}::ng-deep .create-field-page .form-control,::ng-deep .create-field-page .form-select{padding:.475rem 1.25rem}\n"], 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: ["Entity", "selected"] }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
67
67
|
}
|
|
68
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateFieldComponent, decorators: [{
|
|
69
69
|
type: Component,
|
|
@@ -72,9 +72,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
72
72
|
provide: EXTENSIONS_IDENTIFIER,
|
|
73
73
|
useValue: ECmsComponent.FieldsCreate,
|
|
74
74
|
},
|
|
75
|
-
], template: "<form
|
|
75
|
+
], template: "<form [formGroup]=\"newEntity\" (keydown.enter)=\"$event.preventDefault()\" [class]=\"{'was-validated':formValidation}\" (submit)=\"save()\">\n <abp-page [title]=\"'Cms::CreateField' | abpLocalization\" [toolbar]=\"true\">\n <div class=\"create-field-page\">\n <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\n <div class=\"card\">\n <div class=\"card-body\">\n <cms-create-or-edit-field [Entity]=\"newEntity\"></cms-create-or-edit-field>\n </div>\n </div>\n </div>\n </abp-page>\n</form>", styles: ["::ng-deep .create-field-page .dignite_page{height:calc(100vh - 125px);overflow:auto}::ng-deep .create-field-page .form-control,::ng-deep .create-field-page .form-select{padding:.475rem 1.25rem}\n"] }]
|
|
76
76
|
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.FieldAdminService }, { type: i3.ToasterService }, { type: i4.Location }, { type: i5.LocalizationService }, { type: i6.CmsApiService }], propDecorators: { submitclick: [{
|
|
77
77
|
type: ViewChild,
|
|
78
78
|
args: ['submitclick', { static: true }]
|
|
79
79
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWZpZWxkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Ntcy9zcmMvbGliL2NvbXBvbmVudHMvYWRtaW4vZmllbGRzL2NyZWF0ZS1maWVsZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbXMvc3JjL2xpYi9jb21wb25lbnRzL2FkbWluL2ZpZWxkcy9jcmVhdGUtZmllbGQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFJdEUsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFjLE1BQU0sZUFBZSxDQUFDO0FBSXpFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNuRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7Ozs7Ozs7Ozs7QUFjekUsTUFBTSxPQUFPLG9CQUFvQjtJQUUvQixZQUNVLEVBQWUsRUFDaEIsa0JBQXFDLEVBQ3BDLE9BQXVCLEVBQ3hCLFNBQW1CLEVBQ25CLG9CQUF5QyxFQUN6QyxjQUE2QjtRQUw1QixPQUFFLEdBQUYsRUFBRSxDQUFhO1FBQ2hCLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBbUI7UUFDcEMsWUFBTyxHQUFQLE9BQU8sQ0FBZ0I7UUFDeEIsY0FBUyxHQUFULFNBQVMsQ0FBVTtRQUNuQix5QkFBb0IsR0FBcEIsb0JBQW9CLENBQXFCO1FBQ3pDLG1CQUFjLEdBQWQsY0FBYyxDQUFlO1FBRzlCLHVCQUFrQixHQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFBO1FBbUJwRCxhQUFRLEdBQVMsS0FBSyxDQUFDO1FBRWYsdUJBQWtCLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDdkQ7Ozs7V0FJRztRQUNILG1CQUFjLEdBQVEsRUFBRSxDQUFDO0lBNUJyQixDQUFDO0lBU0wsUUFBUTtRQUNOLGlHQUFpRztRQUNqRyx1Q0FBdUM7UUFDdkMsSUFBSSxDQUFDLFNBQVMsR0FBRSxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxJQUFJLDRCQUE0QixFQUFFLENBQUMsQ0FBQTtJQUNuRSxDQUFDO0lBRUQsWUFBWTtJQUNaLGNBQWM7UUFDWixJQUFJLENBQUMsUUFBUSxHQUFDLElBQUksQ0FBQztRQUNuQixJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtJQUN4QyxDQUFDO0lBV0QsVUFBVTtJQUNWLElBQUk7UUFDRixJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQTtRQUNoQyw4QkFBOEI7UUFDOUIsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsdUJBQXVCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3RGLElBQUksSUFBSSxDQUFDLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDO1lBQUUsT0FBTztRQUVyRSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLO1lBQUUsT0FBTTtRQUNqQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUNwRCxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLDJCQUEyQixDQUFDLENBQUMsQ0FBQztZQUNuRixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUN6QyxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7OEdBckRVLG9CQUFvQjtrR0FBcEIsb0JBQW9CLDJDQVBwQjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxxQkFBcUI7Z0JBQzlCLFFBQVEsRUFBRSxhQUFhLENBQUMsWUFBWTthQUNyQztTQUNGLG9KQ3hCSCw4bUJBV087OzJGRGVNLG9CQUFvQjtrQkFYaEMsU0FBUzsrQkFDRSxrQkFBa0IsYUFHakI7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLHFCQUFxQjs0QkFDOUIsUUFBUSxFQUFFLGFBQWEsQ0FBQyxZQUFZO3lCQUNyQztxQkFDRjtrT0FtQjJDLFdBQVc7c0JBQXRELFNBQVM7dUJBQUMsYUFBYSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbIlxuaW1wb3J0IHsgRVhURU5TSU9OU19JREVOVElGSUVSIH0gZnJvbSAnQGFicC9uZy5jb21wb25lbnRzL2V4dGVuc2libGUnO1xuaW1wb3J0IHsgTG9jYWxpemF0aW9uU2VydmljZSB9IGZyb20gJ0BhYnAvbmcuY29yZSc7XG5pbXBvcnQgeyBUb2FzdGVyU2VydmljZSB9IGZyb20gJ0BhYnAvbmcudGhlbWUuc2hhcmVkJztcbmltcG9ydCB7IExvY2F0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgaW5qZWN0LCBWaWV3Q2hpbGQsIEVsZW1lbnRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1CdWlsZGVyLCBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBGaWVsZEFkbWluU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3Byb3h5L2FkbWluL2ZpZWxkcyc7XG5pbXBvcnQgeyBDbXNBcGlTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMnO1xuaW1wb3J0IHsgRUNtc0NvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL2VudW1zJztcbmltcG9ydCB7IFVwZGF0ZUxpc3RTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvdXBkYXRlLWxpc3Quc2VydmljZSc7XG5pbXBvcnQgeyBDcmVhdGVPclVwZGF0ZUZpZWxkSW5wdXRCYXNlIH0gZnJvbSAnLi9jcmVhdGUtb3ItdXBkYXRlLWZpZWxkLWlucHV0LWJhc2UnO1xuaW1wb3J0IHsgVmFsaWRhdG9yc1NlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcy92YWxpZGF0b3JzLnNlcnZpY2UnO1xuXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2Ntcy1jcmVhdGUtZmllbGQnLFxuICB0ZW1wbGF0ZVVybDogJy4vY3JlYXRlLWZpZWxkLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY3JlYXRlLWZpZWxkLmNvbXBvbmVudC5zY3NzJ10sXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IEVYVEVOU0lPTlNfSURFTlRJRklFUixcbiAgICAgIHVzZVZhbHVlOiBFQ21zQ29tcG9uZW50LkZpZWxkc0NyZWF0ZSxcbiAgICB9LFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIENyZWF0ZUZpZWxkQ29tcG9uZW50IHtcbiAgXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZmI6IEZvcm1CdWlsZGVyLFxuICAgIHB1YmxpYyBfRmllbGRBZG1pblNlcnZpY2U6IEZpZWxkQWRtaW5TZXJ2aWNlLFxuICAgIHByaXZhdGUgdG9hc3RlcjogVG9hc3RlclNlcnZpY2UsXG4gICAgcHVibGljIF9sb2NhdGlvbjogTG9jYXRpb24sXG4gICAgcHVibGljIF9Mb2NhbGl6YXRpb25TZXJ2aWNlOiBMb2NhbGl6YXRpb25TZXJ2aWNlLFxuICAgIHB1YmxpYyBfQ21zQXBpU2VydmljZTogQ21zQXBpU2VydmljZSxcbiAgIFxuICApIHsgfVxuICBwcml2YXRlIF9VcGRhdGVMaXN0U2VydmljZT1pbmplY3QoVXBkYXRlTGlzdFNlcnZpY2UpXG4gXG4gIC8qKuihqOWNleWunuS9kyAqL1xuICBuZXdFbnRpdHk6IEZvcm1Hcm91cCB8IHVuZGVmaW5lZCBcblxuICAvKirojrflj5bmj5DkuqTmjInpkq7mm7/ouqvvvIznlKjkuo7nnJ/lrp7op6blj5HooajljZXmj5DkuqQgKi9cbiAgQFZpZXdDaGlsZCgnc3VibWl0Y2xpY2snLCB7IHN0YXRpYzogdHJ1ZSB9KSBzdWJtaXRjbGljazogRWxlbWVudFJlZjtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAvL0NhbGxlZCBhZnRlciB0aGUgY29uc3RydWN0b3IsIGluaXRpYWxpemluZyBpbnB1dCBwcm9wZXJ0aWVzLCBhbmQgdGhlIGZpcnN0IGNhbGwgdG8gbmdPbkNoYW5nZXMuXG4gICAgLy9BZGQgJ2ltcGxlbWVudHMgT25Jbml0JyB0byB0aGUgY2xhc3MuXG4gICAgdGhpcy5uZXdFbnRpdHk9IHRoaXMuZmIuZ3JvdXAobmV3IENyZWF0ZU9yVXBkYXRlRmllbGRJbnB1dEJhc2UoKSlcbiAgfVxuXG4gIC8qKuinpuWPkeaPkOS6pOaMiemSriAqL1xuICBzdWJtaXRjbGlja0J0bigpe1xuICAgIHRoaXMuaXNTdWJtaXQ9dHJ1ZTtcbiAgICB0aGlzLnN1Ym1pdGNsaWNrLm5hdGl2ZUVsZW1lbnQuY2xpY2soKVxuICB9XG4gIGlzU3VibWl0OmJvb2xlYW49ZmFsc2U7XG5cbiAgcHJpdmF0ZSBfVmFsaWRhdG9yc1NlcnZpY2UgPSBpbmplY3QoVmFsaWRhdG9yc1NlcnZpY2UpO1xuICAvKirooajljZXpqozor4HnirbmgIFcbiAgICoge1xuICAgKiAgdGl0bGU6dHJ1ZSxcbiAgICogfVxuICAgKi9cbiAgZm9ybVZhbGlkYXRpb246IGFueSA9ICcnO1xuXG4gIC8qKuS/neWtmOihqOWNlSAqL1xuICBzYXZlKCkge1xuICAgIGxldCBpbnB1dCA9IHRoaXMubmV3RW50aXR5LnZhbHVlXG4gICAgLy8gaWYgKCF0aGlzLmlzU3VibWl0KSByZXR1cm47XG4gICAgdGhpcy5mb3JtVmFsaWRhdGlvbiA9IHRoaXMuX1ZhbGlkYXRvcnNTZXJ2aWNlLmdldEZvcm1WYWxpZGF0aW9uU3RhdHVzKHRoaXMubmV3RW50aXR5KTtcbiAgICBpZiAodGhpcy5fVmFsaWRhdG9yc1NlcnZpY2UuaXNDaGVja0Zvcm0odGhpcy5mb3JtVmFsaWRhdGlvbikpIHJldHVybjtcblxuICAgIGlmICghdGhpcy5uZXdFbnRpdHkudmFsaWQpIHJldHVyblxuICAgIHRoaXMuX0ZpZWxkQWRtaW5TZXJ2aWNlLmNyZWF0ZShpbnB1dCkuc3Vic2NyaWJlKHJlcyA9PiB7XG4gICAgICB0aGlzLnRvYXN0ZXIuc3VjY2Vzcyh0aGlzLl9Mb2NhbGl6YXRpb25TZXJ2aWNlLmluc3RhbnQoYENtc0tpdDo6U2F2ZWRTdWNjZXNzZnVsbHlgKSk7XG4gICAgICAgIHRoaXMuX2xvY2F0aW9uLmJhY2soKTtcbiAgICAgICAgdGhpcy5fVXBkYXRlTGlzdFNlcnZpY2UudXBkYXRlTGlzdCgpO1xuICAgIH0pXG4gIH1cblxufVxuIiwiPGZvcm0gIFtmb3JtR3JvdXBdPVwibmV3RW50aXR5XCIgKGtleWRvd24uZW50ZXIpPVwiJGV2ZW50LnByZXZlbnREZWZhdWx0KClcIiBbY2xhc3NdPVwieyd3YXMtdmFsaWRhdGVkJzpmb3JtVmFsaWRhdGlvbn1cIiAoc3VibWl0KT1cInNhdmUoKVwiPlxuICAgIDxhYnAtcGFnZSBbdGl0bGVdPVwiJ0Ntczo6Q3JlYXRlRmllbGQnIHwgYWJwTG9jYWxpemF0aW9uXCIgW3Rvb2xiYXJdPVwidHJ1ZVwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY3JlYXRlLWZpZWxkLXBhZ2VcIj5cbiAgICAgICAgICAgIDxidXR0b24gZm9ybS10eXBlPVwic3VibWl0XCIgc3R5bGU9XCJkaXNwbGF5OiBub25lO1wiICNzdWJtaXRjbGljaz48L2J1dHRvbj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjYXJkXCI+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNhcmQtYm9keVwiPlxuICAgICAgICAgICAgICAgICAgICA8Y21zLWNyZWF0ZS1vci1lZGl0LWZpZWxkIFtFbnRpdHldPVwibmV3RW50aXR5XCI+PC9jbXMtY3JlYXRlLW9yLWVkaXQtZmllbGQ+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgPC9hYnAtcGFnZT5cbjwvZm9ybT4iXX0=
|
|
@@ -10,12 +10,6 @@ import * as i6 from "@angular/forms";
|
|
|
10
10
|
import * as i7 from "@ngx-validate/core";
|
|
11
11
|
import * as i8 from "@dignite-ng/expand.dynamic-form";
|
|
12
12
|
export class CreateOrEditFieldComponent {
|
|
13
|
-
_FieldAbstractsService;
|
|
14
|
-
_CmsApiService;
|
|
15
|
-
_FieldAdminService;
|
|
16
|
-
_LocalizationService;
|
|
17
|
-
/**表单控件模板-动态表单配置组件 */
|
|
18
|
-
FormDynamicRef;
|
|
19
13
|
constructor(_FieldAbstractsService, _CmsApiService, _FieldAdminService, _LocalizationService) {
|
|
20
14
|
this._FieldAbstractsService = _FieldAbstractsService;
|
|
21
15
|
this._CmsApiService = _CmsApiService;
|
|
@@ -25,8 +19,6 @@ export class CreateOrEditFieldComponent {
|
|
|
25
19
|
this._FieldAbstractsService.getfieldGroupList();
|
|
26
20
|
}
|
|
27
21
|
}
|
|
28
|
-
/**表单实体 */
|
|
29
|
-
_Entity;
|
|
30
22
|
set Entity(v) {
|
|
31
23
|
if (v) {
|
|
32
24
|
this._Entity = v;
|
|
@@ -36,9 +28,6 @@ export class CreateOrEditFieldComponent {
|
|
|
36
28
|
get formControlName() {
|
|
37
29
|
return this._Entity.get('formControlName');
|
|
38
30
|
}
|
|
39
|
-
/**选择的表单信息 */
|
|
40
|
-
_selected_copy;
|
|
41
|
-
_selected;
|
|
42
31
|
set selected(v) {
|
|
43
32
|
if (v) {
|
|
44
33
|
this._selected = v || '';
|
|
@@ -61,6 +50,7 @@ export class CreateOrEditFieldComponent {
|
|
|
61
50
|
asyncValidators: [this.repetitionAsyncValidator()],
|
|
62
51
|
updateOn: 'change'
|
|
63
52
|
}));
|
|
53
|
+
this.submitclick?.nativeElement?.click();
|
|
64
54
|
}
|
|
65
55
|
}
|
|
66
56
|
/**name表单控件 */
|
|
@@ -102,18 +92,21 @@ export class CreateOrEditFieldComponent {
|
|
|
102
92
|
formControlNameChange(event) {
|
|
103
93
|
// this._selected='';
|
|
104
94
|
}
|
|
105
|
-
static
|
|
106
|
-
static
|
|
95
|
+
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 }); }
|
|
96
|
+
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: "FormDynamicRef", first: true, predicate: ["FormDynamicRef"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_Entity\">\n \n <div class=\"mb-2\">\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-2\">\n <label class=\"form-label\" for=\"displayName\">{{'DigniteAbpForms::FieldDisplayName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required (blur)=\"disPlayNameInputBlur($event)\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\" for=\"name\">{{'DigniteAbpForms::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 <div class=\"form-text\">{{'DigniteAbpForms::FieldNameHelpText' | abpLocalization}}</div>\n </div>\n <div class=\"mb-2\">\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-2\">\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}}</option>\n </ng-container>\n </select>\n </div>\n <ng-container *ngIf=\"_Entity.value.formControlName&&_Entity\"> \n <df-dynamic [type]=\"_Entity.value.formControlName\" [entity]=\"_Entity\" [selected]=\"_selected\"></df-dynamic>\n </ng-container>\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>", 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.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { 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", "entity", "culture", "parentFiledName", "fields"] }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
107
97
|
}
|
|
108
98
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditFieldComponent, decorators: [{
|
|
109
99
|
type: Component,
|
|
110
|
-
args: [{ selector: 'cms-create-or-edit-field', template: "<form [formGroup]=\"_Entity\">\n <div class=\"mb-2\">\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-2\">\n <label class=\"form-label\" for=\"displayName\">{{'DigniteAbpForms::FieldDisplayName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" (blur)=\"disPlayNameInputBlur($event)\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\" for=\"name\">{{'DigniteAbpForms::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 <div class=\"form-text\">{{'DigniteAbpForms::FieldNameHelpText' | abpLocalization}}</div>\n </div>\n <div class=\"mb-2\">\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-2\">\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}}</option>\n </ng-container>\n </select>\n </div>\n <ng-container *ngIf=\"_Entity.value.formControlName&&_Entity\"> \n <df-dynamic [type]=\"_Entity.value.formControlName\" [entity]=\"_Entity\" [selected]=\"_selected\"></df-dynamic>\n </ng-container>\n\n</form>" }]
|
|
100
|
+
args: [{ selector: 'cms-create-or-edit-field', template: "<form [formGroup]=\"_Entity\">\n \n <div class=\"mb-2\">\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-2\">\n <label class=\"form-label\" for=\"displayName\">{{'DigniteAbpForms::FieldDisplayName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required (blur)=\"disPlayNameInputBlur($event)\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\" for=\"name\">{{'DigniteAbpForms::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 <div class=\"form-text\">{{'DigniteAbpForms::FieldNameHelpText' | abpLocalization}}</div>\n </div>\n <div class=\"mb-2\">\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-2\">\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}}</option>\n </ng-container>\n </select>\n </div>\n <ng-container *ngIf=\"_Entity.value.formControlName&&_Entity\"> \n <df-dynamic [type]=\"_Entity.value.formControlName\" [entity]=\"_Entity\" [selected]=\"_selected\"></df-dynamic>\n </ng-container>\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>" }]
|
|
111
101
|
}], ctorParameters: () => [{ type: i1.FieldAbstractsService }, { type: i2.CmsApiService }, { type: i3.FieldAdminService }, { type: i4.LocalizationService }], propDecorators: { FormDynamicRef: [{
|
|
112
102
|
type: ViewChild,
|
|
113
103
|
args: ['FormDynamicRef', { read: ViewContainerRef, static: true }]
|
|
104
|
+
}], submitclick: [{
|
|
105
|
+
type: ViewChild,
|
|
106
|
+
args: ['submitclick', { static: true }]
|
|
114
107
|
}], Entity: [{
|
|
115
108
|
type: Input
|
|
116
109
|
}], selected: [{
|
|
117
110
|
type: Input
|
|
118
111
|
}] } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/fields/create-or-edit-field.component.ts","../../../../../../../projects/cms/src/lib/components/admin/fields/create-or-edit-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input,  ViewChild, ViewContainerRef } from '@angular/core';\nimport { FieldAbstractsService } from '../../../services/field-abstracts.service';\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors, Validators } from '@angular/forms';\nimport { CmsApiService } from '../../../services/cms-api.service';\nimport { Observable } from 'rxjs';\nimport { FieldAdminService } from '../../../proxy/admin/fields';\nimport { LocalizationService } from '@abp/ng.core';\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  /**表单控件模板-动态表单配置组件 */\n  @ViewChild('FormDynamicRef', { read: ViewContainerRef, static: true }) FormDynamicRef: ViewContainerRef;\n\n  constructor(\n    public _FieldAbstractsService: FieldAbstractsService,\n    private _CmsApiService: CmsApiService,\n    private _FieldAdminService: FieldAdminService,\n    private _LocalizationService: LocalizationService,\n  \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      this.dataLoaded()\n    }\n   \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('name', new FormControl(this.nameInput.value||'', {\n        validators: Validators.required,\n        asyncValidators: [this.repetitionAsyncValidator()] ,\n        updateOn: 'change'\n      }))\n    }\n  }\n\n\n  /**name表单控件 */\n  get nameInput() {\n    return this._Entity.get('name')\n  }\n\n  nameInputBlur(event){\n    let value = event.target.value\n    this.nameInput.patchValue(value)\n  }\n\n  /**字段标签input失去标点生成字段名字 */\n  disPlayNameInputBlur(event) {\n    let value = event.target.value\n    let pinyin = this._CmsApiService.chineseToPinyin(value)\n    let nameInput = this.nameInput\n    if (nameInput.value) return\n    nameInput.patchValue(pinyin)\n  }\n  /**定义异步验证方法 */\n  repetitionAsyncValidator() {\n    return (ctrl: AbstractControl): 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({ repetition: this._LocalizationService.instant(`Cms::FieldName{0}AlreadyExist`, ctrl.value) });\n          } else {\n            resolve(null);\n          }\n        })\n      });\n    };\n  }\n\n\n  formControlNameChange(event){\n    // this._selected='';\n  }\n\n}\n","<form [formGroup]=\"_Entity\">\n    <div class=\"mb-2\">\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-2\">\n        <label class=\"form-label\" for=\"displayName\">{{'DigniteAbpForms::FieldDisplayName' | abpLocalization}}</label>\n        <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" (blur)=\"disPlayNameInputBlur($event)\">\n    </div>\n    <div class=\"mb-2\">\n        <label class=\"form-label\" for=\"name\">{{'DigniteAbpForms::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        <div class=\"form-text\">{{'DigniteAbpForms::FieldNameHelpText' | abpLocalization}}</div>\n    </div>\n    <div class=\"mb-2\">\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-2\">\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}}</option>\n            </ng-container>\n        </select>\n    </div>\n    <ng-container *ngIf=\"_Entity.value.formControlName&&_Entity\"> \n        <df-dynamic [type]=\"_Entity.value.formControlName\" [entity]=\"_Entity\" [selected]=\"_selected\"></df-dynamic>\n    </ng-container>\n\n</form>"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/fields/create-or-edit-field.component.ts","../../../../../../../projects/cms/src/lib/components/admin/fields/create-or-edit-field.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,KAAK,EAAG,SAAS,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAE3F,OAAO,EAAmB,WAAW,EAA+B,UAAU,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;AAUvG,MAAM,OAAO,0BAA0B;IAQrC,YACS,sBAA6C,EAC5C,cAA6B,EAC7B,kBAAqC,EACrC,oBAAyC;QAH1C,2BAAsB,GAAtB,sBAAsB,CAAuB;QAC5C,mBAAc,GAAd,cAAc,CAAe;QAC7B,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,yBAAoB,GAApB,oBAAoB,CAAqB;QAGjD,IAAI,IAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC3D,IAAI,CAAC,sBAAsB,CAAC,iBAAiB,EAAE,CAAA;QACjD,CAAC;IACH,CAAC;IAGD,IACW,MAAM,CAAC,CAAwB;QACxC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;YACjB,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IACD,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAA;IAC5C,CAAC;IAID,IACW,QAAQ,CAAC,CAAM;QACxB,IAAG,CAAC,EAAE,CAAC;YACL,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,GAAC,CAAC,CAAA;YACrB,IAAI,CAAC,UAAU,EAAE,CAAA;QACnB,CAAC;IAEH,CAAC;IAGD,KAAK,CAAC,UAAU;QACd,IAAI,IAAI,CAAC,sBAAsB,CAAC,eAAe,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC5D,MAAM,IAAI,CAAC,sBAAsB,CAAC,kBAAkB,EAAE,CAAA;QACxD,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;gBAChC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC;oBACtB,eAAe,EAAE,IAAI,CAAC,sBAAsB,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,IAAI;iBACtE,CAAC,CAAA;YACJ,CAAC;YACD,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,IAAE,EAAE,EAAE;gBACxE,UAAU,EAAE,UAAU,CAAC,QAAQ;gBAC/B,eAAe,EAAE,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC;gBAClD,QAAQ,EAAE,QAAQ;aACnB,CAAC,CAAC,CAAA;YACH,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE,KAAK,EAAE,CAAA;QAC1C,CAAC;IACH,CAAC;IAGD,cAAc;IACd,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACjC,CAAC;IAED,aAAa,CAAC,KAAK;QACjB,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAA;QAC9B,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,CAAA;IAClC,CAAC;IAED,yBAAyB;IACzB,oBAAoB,CAAC,KAAK;QACxB,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAA;QAC9B,IAAI,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,KAAK,CAAC,CAAA;QACvD,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAA;QAC9B,IAAI,SAAS,CAAC,KAAK;YAAE,OAAM;QAC3B,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;IAC9B,CAAC;IACD,cAAc;IACd,wBAAwB;QACtB,OAAO,CAAC,IAAqB,EAA0E,EAAE;YACvG,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC3B,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,IAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;oBACpD,OAAO,CAAC,IAAI,CAAC,CAAC;oBACd,OAAM;gBACR,CAAC;gBACD,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBAC7D,IAAI,GAAG,EAAE,CAAC;wBACR,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,+BAA+B,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;oBAC1G,CAAC;yBAAM,CAAC;wBACN,OAAO,CAAC,IAAI,CAAC,CAAC;oBAChB,CAAC;gBACH,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;IAGD,qBAAqB,CAAC,KAAK;QACzB,qBAAqB;IACvB,CAAC;8GA1GU,0BAA0B;kGAA1B,0BAA0B,iNAGA,gBAAgB,sJCfvD,+zEAuCO;;2FD3BM,0BAA0B;kBALtC,SAAS;+BACE,0BAA0B;wLAOmC,cAAc;sBAApF,SAAS;uBAAC,gBAAgB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,EAAE;gBAGzB,WAAW;sBAAtD,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAgB/B,MAAM;sBADhB,KAAK;gBAcK,QAAQ;sBADlB,KAAK","sourcesContent":["import { Component, ElementRef, Input,  ViewChild, ViewContainerRef } from '@angular/core';\nimport { FieldAbstractsService } from '../../../services/field-abstracts.service';\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors, Validators } from '@angular/forms';\nimport { CmsApiService } from '../../../services/cms-api.service';\nimport { Observable } from 'rxjs';\nimport { FieldAdminService } from '../../../proxy/admin/fields';\nimport { LocalizationService } from '@abp/ng.core';\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  /**表单控件模板-动态表单配置组件 */\n  @ViewChild('FormDynamicRef', { read: ViewContainerRef, static: true }) 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  ) {\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      this.dataLoaded()\n    }\n   \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('name', new FormControl(this.nameInput.value||'', {\n        validators: Validators.required,\n        asyncValidators: [this.repetitionAsyncValidator()] ,\n        updateOn: 'change'\n      }))\n      this.submitclick?.nativeElement?.click()\n    }\n  }\n\n\n  /**name表单控件 */\n  get nameInput() {\n    return this._Entity.get('name')\n  }\n\n  nameInputBlur(event){\n    let value = event.target.value\n    this.nameInput.patchValue(value)\n  }\n\n  /**字段标签input失去标点生成字段名字 */\n  disPlayNameInputBlur(event) {\n    let value = event.target.value\n    let pinyin = this._CmsApiService.chineseToPinyin(value)\n    let nameInput = this.nameInput\n    if (nameInput.value) return\n    nameInput.patchValue(pinyin)\n  }\n  /**定义异步验证方法 */\n  repetitionAsyncValidator() {\n    return (ctrl: AbstractControl): 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({ repetition: this._LocalizationService.instant(`Cms::FieldName{0}AlreadyExist`, ctrl.value) });\n          } else {\n            resolve(null);\n          }\n        })\n      });\n    };\n  }\n\n\n  formControlNameChange(event){\n    // this._selected='';\n  }\n\n}\n","<form [formGroup]=\"_Entity\">\n  \n    <div class=\"mb-2\">\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-2\">\n        <label class=\"form-label\" for=\"displayName\">{{'DigniteAbpForms::FieldDisplayName' | abpLocalization}}</label>\n        <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required (blur)=\"disPlayNameInputBlur($event)\">\n    </div>\n    <div class=\"mb-2\">\n        <label class=\"form-label\" for=\"name\">{{'DigniteAbpForms::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        <div class=\"form-text\">{{'DigniteAbpForms::FieldNameHelpText' | abpLocalization}}</div>\n    </div>\n    <div class=\"mb-2\">\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-2\">\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}}</option>\n            </ng-container>\n        </select>\n    </div>\n    <ng-container *ngIf=\"_Entity.value.formControlName&&_Entity\"> \n        <df-dynamic [type]=\"_Entity.value.formControlName\" [entity]=\"_Entity\" [selected]=\"_selected\"></df-dynamic>\n    </ng-container>\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>"]}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import { FormGroup, Validators } from "@angular/forms";
|
|
2
2
|
export class CreateOrUpdateFieldInputBase {
|
|
3
|
-
/**分组id */
|
|
4
|
-
groupId = ['', []];
|
|
5
|
-
/**字段名称 Display name of this field */
|
|
6
|
-
displayName = ['', [Validators.required]];
|
|
7
|
-
/**字段唯一名称 Unique Name*/
|
|
8
|
-
name = ['', [Validators.required]];
|
|
9
|
-
/**描述 说明 */
|
|
10
|
-
description = ['', []];
|
|
11
|
-
/**FieldType字段类型 表单控件名称 */
|
|
12
|
-
formControlName = [undefined, [Validators.required]];
|
|
13
|
-
/**动态表单配置 */
|
|
14
|
-
formConfiguration = new FormGroup({});
|
|
15
3
|
constructor(data) {
|
|
4
|
+
/**分组id */
|
|
5
|
+
this.groupId = ['', []];
|
|
6
|
+
/**字段名称 Display name of this field */
|
|
7
|
+
this.displayName = ['', [Validators.required]];
|
|
8
|
+
/**字段唯一名称 Unique Name*/
|
|
9
|
+
this.name = ['', [Validators.required]];
|
|
10
|
+
/**描述 说明 */
|
|
11
|
+
this.description = ['', []];
|
|
12
|
+
/**FieldType字段类型 表单控件名称 */
|
|
13
|
+
this.formControlName = [undefined, [Validators.required]];
|
|
14
|
+
/**动态表单配置 */
|
|
15
|
+
this.formConfiguration = new FormGroup({});
|
|
16
16
|
if (data) {
|
|
17
17
|
for (const key in data) {
|
|
18
18
|
if (data.hasOwnProperty(key)) {
|
|
@@ -22,4 +22,4 @@ export class CreateOrUpdateFieldInputBase {
|
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
24
|
}
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLW9yLXVwZGF0ZS1maWVsZC1pbnB1dC1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY21zL3NyYy9saWIvY29tcG9uZW50cy9hZG1pbi9maWVsZHMvY3JlYXRlLW9yLXVwZGF0ZS1maWVsZC1pbnB1dC1iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkQsTUFBTSxPQUFPLDRCQUE0QjtJQW9CckMsWUFBWSxJQUFtQztRQW5CL0MsVUFBVTtRQUNWLFlBQU8sR0FBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUV4QixxQ0FBcUM7UUFDckMsZ0JBQVcsR0FBUSxDQUFDLEVBQUUsRUFBRSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1FBRS9DLHVCQUF1QjtRQUN2QixTQUFJLEdBQVEsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztRQUV4QyxXQUFXO1FBQ1gsZ0JBQVcsR0FBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUU1QiwwQkFBMEI7UUFDMUIsb0JBQWUsR0FBUSxDQUFDLFNBQVMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1FBRTFELFlBQVk7UUFDWixzQkFBaUIsR0FBMEIsSUFBSSxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUE7UUFJeEQsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNQLEtBQUssTUFBTSxHQUFHLElBQUksSUFBSSxFQUFFLENBQUM7Z0JBQ3JCLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO29CQUMzQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUMxQixDQUFDO1lBQ0wsQ0FBQztRQUNMLENBQUM7SUFFTCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JtR3JvdXAsIFZhbGlkYXRvcnMgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBDcmVhdGVPclVwZGF0ZUZpZWxkSW5wdXRCYXNlIHtcclxuICAgIC8qKuWIhue7hGlkICovXHJcbiAgICBncm91cElkOiBhbnkgPSBbJycsIFtdXTtcclxuXHJcbiAgICAvKirlrZfmrrXlkI3np7AgRGlzcGxheSBuYW1lIG9mIHRoaXMgZmllbGQgKi9cclxuICAgIGRpc3BsYXlOYW1lOiBhbnkgPSBbJycsIFtWYWxpZGF0b3JzLnJlcXVpcmVkXV07XHJcblxyXG4gICAgLyoq5a2X5q615ZSv5LiA5ZCN56ewIFVuaXF1ZSBOYW1lKi9cclxuICAgIG5hbWU6IGFueSA9IFsnJywgW1ZhbGlkYXRvcnMucmVxdWlyZWRdXTtcclxuXHJcbiAgICAvKirmj4/ov7Ag6K+05piOICovXHJcbiAgICBkZXNjcmlwdGlvbjogYW55ID0gWycnLCBbXV07XHJcblxyXG4gICAgLyoqRmllbGRUeXBl5a2X5q6157G75Z6LIOihqOWNleaOp+S7tuWQjeensCAqL1xyXG4gICAgZm9ybUNvbnRyb2xOYW1lOiBhbnkgPSBbdW5kZWZpbmVkLCBbVmFsaWRhdG9ycy5yZXF1aXJlZF1dO1xyXG5cclxuICAgIC8qKuWKqOaAgeihqOWNlemFjee9riAqL1xyXG4gICAgZm9ybUNvbmZpZ3VyYXRpb246IEZvcm1Hcm91cCB8IHVuZGVmaW5lZCA9IG5ldyBGb3JtR3JvdXAoe30pXHJcblxyXG5cclxuICAgIGNvbnN0cnVjdG9yKGRhdGE/OiBDcmVhdGVPclVwZGF0ZUZpZWxkSW5wdXRCYXNlKSB7XHJcbiAgICAgICAgaWYgKGRhdGEpIHtcclxuICAgICAgICAgICAgZm9yIChjb25zdCBrZXkgaW4gZGF0YSkge1xyXG4gICAgICAgICAgICAgICAgaWYgKGRhdGEuaGFzT3duUHJvcGVydHkoa2V5KSkge1xyXG4gICAgICAgICAgICAgICAgICAgIHRoaXNba2V5XSA9IGRhdGFba2V5XTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuXHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -3,6 +3,7 @@ import { Component, ViewChild, inject } from '@angular/core';
|
|
|
3
3
|
import { ECmsComponent } from '../../../enums';
|
|
4
4
|
import { UpdateListService } from '../../../services/update-list.service';
|
|
5
5
|
import { CreateOrUpdateFieldInputBase } from './create-or-update-field-input-base';
|
|
6
|
+
import { ValidatorsService } from '../../../services/validators.service';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/forms";
|
|
8
9
|
import * as i2 from "../../../services";
|
|
@@ -15,14 +16,6 @@ import * as i8 from "@ngx-validate/core";
|
|
|
15
16
|
import * as i9 from "@abp/ng.components/page";
|
|
16
17
|
import * as i10 from "./create-or-edit-field.component";
|
|
17
18
|
export class EditFieldComponent {
|
|
18
|
-
fb;
|
|
19
|
-
_FieldAbstractsService;
|
|
20
|
-
_FieldAdminService;
|
|
21
|
-
route;
|
|
22
|
-
toaster;
|
|
23
|
-
_location;
|
|
24
|
-
_LocalizationService;
|
|
25
|
-
_CmsApiService;
|
|
26
19
|
constructor(fb, _FieldAbstractsService, _FieldAdminService, route, toaster, _location, _LocalizationService, _CmsApiService) {
|
|
27
20
|
this.fb = fb;
|
|
28
21
|
this._FieldAbstractsService = _FieldAbstractsService;
|
|
@@ -32,15 +25,18 @@ export class EditFieldComponent {
|
|
|
32
25
|
this._location = _location;
|
|
33
26
|
this._LocalizationService = _LocalizationService;
|
|
34
27
|
this._CmsApiService = _CmsApiService;
|
|
28
|
+
/**字段id */
|
|
29
|
+
this.fieldId = '';
|
|
30
|
+
this._UpdateListService = inject(UpdateListService);
|
|
31
|
+
this.isSubmit = false;
|
|
32
|
+
this._ValidatorsService = inject(ValidatorsService);
|
|
33
|
+
/**表单验证状态
|
|
34
|
+
* {
|
|
35
|
+
* title:true,
|
|
36
|
+
* }
|
|
37
|
+
*/
|
|
38
|
+
this.formValidation = '';
|
|
35
39
|
}
|
|
36
|
-
/**表单实体 */
|
|
37
|
-
newEntity;
|
|
38
|
-
/**字段id */
|
|
39
|
-
fieldId = '';
|
|
40
|
-
/**字段详情 */
|
|
41
|
-
fieldDetails;
|
|
42
|
-
/**获取提交按钮替身,用于真实触发表单提交 */
|
|
43
|
-
submitclick;
|
|
44
40
|
async ngOnInit() {
|
|
45
41
|
const _fieldId = this.route.snapshot.params.id;
|
|
46
42
|
if (_fieldId) {
|
|
@@ -68,13 +64,14 @@ export class EditFieldComponent {
|
|
|
68
64
|
this.isSubmit = true;
|
|
69
65
|
this.submitclick.nativeElement.click();
|
|
70
66
|
}
|
|
71
|
-
_UpdateListService = inject(UpdateListService);
|
|
72
|
-
isSubmit = false;
|
|
73
67
|
/**保存表单 */
|
|
74
68
|
save() {
|
|
75
69
|
let input = this.newEntity.value;
|
|
76
70
|
if (!this.isSubmit)
|
|
77
71
|
return;
|
|
72
|
+
this.formValidation = this._ValidatorsService.getFormValidationStatus(this.newEntity);
|
|
73
|
+
if (this._ValidatorsService.isCheckForm(this.formValidation))
|
|
74
|
+
return;
|
|
78
75
|
if (!this.newEntity.valid)
|
|
79
76
|
return;
|
|
80
77
|
this._FieldAdminService.update(this.fieldId, input).subscribe(res => {
|
|
@@ -83,13 +80,13 @@ export class EditFieldComponent {
|
|
|
83
80
|
this._UpdateListService.updateList();
|
|
84
81
|
});
|
|
85
82
|
}
|
|
86
|
-
static
|
|
87
|
-
static
|
|
83
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: EditFieldComponent, deps: [{ token: i1.FormBuilder }, { token: i2.FieldAbstractsService }, { token: i3.FieldAdminService }, { token: i4.ActivatedRoute }, { token: i5.ToasterService }, { token: i6.Location }, { token: i7.LocalizationService }, { token: i2.CmsApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
84
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: EditFieldComponent, selector: "cms-edit-field", providers: [
|
|
88
85
|
{
|
|
89
86
|
provide: EXTENSIONS_IDENTIFIER,
|
|
90
87
|
useValue: ECmsComponent.FieldsEdit,
|
|
91
88
|
},
|
|
92
|
-
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (
|
|
89
|
+
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (keydown.enter)=\"$event.preventDefault()\" (submit)=\"save()\">\n <abp-page [title]=\"'Cms::EditField' | abpLocalization\" [toolbar]=\"true\">\n <div class=\"create-field-page\">\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n <!-- <div class=\"p-3 bg-white rounded-1\"> -->\n <div class=\"card\">\n <div class=\"card-body\">\n <ng-container *ngIf=\"newEntity&&fieldDetails\">\n <cms-create-or-edit-field [Entity]=\"newEntity\"\n [selected]=\"fieldDetails\"></cms-create-or-edit-field>\n </ng-container>\n </div>\n </div>\n </div>\n </abp-page>\n</form>", styles: [""], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: i8.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "component", type: i9.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i10.CreateOrEditFieldComponent, selector: "cms-create-or-edit-field", inputs: ["Entity", "selected"] }, { kind: "pipe", type: i7.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
93
90
|
}
|
|
94
91
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: EditFieldComponent, decorators: [{
|
|
95
92
|
type: Component,
|
|
@@ -98,9 +95,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
98
95
|
provide: EXTENSIONS_IDENTIFIER,
|
|
99
96
|
useValue: ECmsComponent.FieldsEdit,
|
|
100
97
|
},
|
|
101
|
-
], template: "<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (
|
|
98
|
+
], template: "<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (keydown.enter)=\"$event.preventDefault()\" (submit)=\"save()\">\n <abp-page [title]=\"'Cms::EditField' | abpLocalization\" [toolbar]=\"true\">\n <div class=\"create-field-page\">\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n <!-- <div class=\"p-3 bg-white rounded-1\"> -->\n <div class=\"card\">\n <div class=\"card-body\">\n <ng-container *ngIf=\"newEntity&&fieldDetails\">\n <cms-create-or-edit-field [Entity]=\"newEntity\"\n [selected]=\"fieldDetails\"></cms-create-or-edit-field>\n </ng-container>\n </div>\n </div>\n </div>\n </abp-page>\n</form>" }]
|
|
102
99
|
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.FieldAbstractsService }, { type: i3.FieldAdminService }, { type: i4.ActivatedRoute }, { type: i5.ToasterService }, { type: i6.Location }, { type: i7.LocalizationService }, { type: i2.CmsApiService }], propDecorators: { submitclick: [{
|
|
103
100
|
type: ViewChild,
|
|
104
101
|
args: ['submitclick', { static: true }]
|
|
105
102
|
}] } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/fields/edit-field.component.ts","../../../../../../../projects/cms/src/lib/components/admin/fields/edit-field.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AAItE,OAAO,EAAE,SAAS,EAAU,SAAS,EAAc,MAAM,EAAE,MAAM,eAAe,CAAC;AAKjF,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AAC1E,OAAO,EAAE,4BAA4B,EAAE,MAAM,qCAAqC,CAAC;AACnF,OAAO,EAAE,iBAAiB,EAAE,MAAM,sCAAsC,CAAC;;;;;;;;;;;;AAazE,MAAM,OAAO,kBAAkB;IAC7B,YACU,EAAe,EAChB,sBAA6C,EAC7C,kBAAqC,EACpC,KAAqB,EACrB,OAAuB,EACxB,SAAmB,EACnB,oBAAyC,EACzC,cAA6B;QAP5B,OAAE,GAAF,EAAE,CAAa;QAChB,2BAAsB,GAAtB,sBAAsB,CAAuB;QAC7C,uBAAkB,GAAlB,kBAAkB,CAAmB;QACpC,UAAK,GAAL,KAAK,CAAgB;QACrB,YAAO,GAAP,OAAO,CAAgB;QACxB,cAAS,GAAT,SAAS,CAAU;QACnB,yBAAoB,GAApB,oBAAoB,CAAqB;QACzC,mBAAc,GAAd,cAAc,CAAe;QAMtC,UAAU;QACV,YAAO,GAAW,EAAE,CAAC;QAqCb,uBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QACvD,aAAQ,GAAY,KAAK,CAAC;QAClB,uBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QACvD;;;;WAIG;QACH,mBAAc,GAAQ,EAAE,CAAC;IAnDtB,CAAC;IAcJ,KAAK,CAAC,QAAQ;QACZ,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAC/C,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;YACxB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,4BAA4B,EAAE,CAAC,CAAC;YACnE,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,kBAAkB,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;YAC3F,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;gBACxB,GAAG,IAAI,CAAC,YAAY;gBACpB,iBAAiB,EAAE,IAAI,CAAC,YAAY,CAAC,iBAAiB;aACvD,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,YAAY;IACZ,YAAY;QACV,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACxD,GAAG,CAAC,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC7C,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;gBACxB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY;IACZ,cAAc;QACZ,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACzC,CAAC;IAUD,UAAU;IACV,IAAI;QACF,IAAI,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QACjC,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC3B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACtF,IAAI,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC;YAAE,OAAO;QACrE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK;YAAE,OAAO;QAClC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAClE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,2BAA2B,CAAC,CAAC,CAAC;YACrF,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;YACtB,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;8GA1EU,kBAAkB;kGAAlB,kBAAkB,yCAPlB;YACT;gBACE,OAAO,EAAE,qBAAqB;gBAC9B,QAAQ,EAAE,aAAa,CAAC,UAAU;aACnC;SACF,oJCvBH,i0BAeO;;2FDUM,kBAAkB;kBAX9B,SAAS;+BACE,gBAAgB,aAGf;wBACT;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,QAAQ,EAAE,aAAa,CAAC,UAAU;yBACnC;qBACF;mSAwB2C,WAAW;sBAAtD,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';\nimport { LocalizationService } from '@abp/ng.core';\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport { Location } from '@angular/common';\nimport { Component, OnInit, ViewChild, ElementRef, inject } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { ActivatedRoute } from '@angular/router';\nimport { FieldAdminService } from '../../../proxy/admin/fields';\nimport { FieldAbstractsService, CmsApiService } from '../../../services';\nimport { ECmsComponent } from '../../../enums';\nimport { UpdateListService } from '../../../services/update-list.service';\nimport { CreateOrUpdateFieldInputBase } from './create-or-update-field-input-base';\nimport { ValidatorsService } from '../../../services/validators.service';\n\n@Component({\n  selector: 'cms-edit-field',\n  templateUrl: './edit-field.component.html',\n  styleUrls: ['./edit-field.component.scss'],\n  providers: [\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.FieldsEdit,\n    },\n  ],\n})\nexport class EditFieldComponent implements OnInit {\n  constructor(\n    private fb: FormBuilder,\n    public _FieldAbstractsService: FieldAbstractsService,\n    public _FieldAdminService: FieldAdminService,\n    private route: ActivatedRoute,\n    private toaster: ToasterService,\n    public _location: Location,\n    public _LocalizationService: LocalizationService,\n    public _CmsApiService: CmsApiService\n  ) {}\n\n  /**表单实体 */\n  newEntity: FormGroup | undefined;\n\n  /**字段id */\n  fieldId: string = '';\n\n  /**字段详情 */\n  fieldDetails: any;\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  async ngOnInit(): Promise<void> {\n    const _fieldId = this.route.snapshot.params.id;\n    if (_fieldId) {\n      this.fieldId = _fieldId;\n      this.newEntity = this.fb.group(new CreateOrUpdateFieldInputBase());\n      await Promise.all([this._FieldAbstractsService.getFromControlList(), this.getFieldEdit()]);\n      this.newEntity.patchValue({\n        ...this.fieldDetails,\n        formConfiguration: this.fieldDetails.formConfiguration,\n      });\n    }\n  }\n\n  /**获取字段详情 */\n  getFieldEdit() {\n    return new Promise((resolve, reject) => {\n      this._FieldAdminService.get(this.fieldId).subscribe(res => {\n        res.groupId = res.groupId ? res.groupId : '';\n        this.fieldDetails = res;\n        resolve(res);\n      });\n    });\n  }\n\n  /**触发提交按钮 */\n  submitclickBtn() {\n    this.isSubmit = true;\n    this.submitclick.nativeElement.click();\n  }\n  private _UpdateListService = inject(UpdateListService);\n  isSubmit: boolean = false;\n  private _ValidatorsService = inject(ValidatorsService);\n  /**表单验证状态\n   * {\n   *  title:true,\n   * }\n   */\n  formValidation: any = '';\n  /**保存表单 */\n  save() {\n    let input = this.newEntity.value;\n    if (!this.isSubmit) return;\n    this.formValidation = this._ValidatorsService.getFormValidationStatus(this.newEntity);\n    if (this._ValidatorsService.isCheckForm(this.formValidation)) return;\n    if (!this.newEntity.valid) return;\n    this._FieldAdminService.update(this.fieldId, input).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`CmsKit::SavedSuccessfully`));\n      this._location.back();\n      this._UpdateListService.updateList();\n    });\n  }\n}\n","<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (keydown.enter)=\"$event.preventDefault()\" (submit)=\"save()\">\n    <abp-page [title]=\"'Cms::EditField' | abpLocalization\" [toolbar]=\"true\">\n        <div class=\"create-field-page\">\n            <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n            <!-- <div class=\"p-3 bg-white rounded-1\"> -->\n            <div class=\"card\">\n                <div class=\"card-body\">\n                    <ng-container *ngIf=\"newEntity&&fieldDetails\">\n                        <cms-create-or-edit-field [Entity]=\"newEntity\"\n                            [selected]=\"fieldDetails\"></cms-create-or-edit-field>\n                    </ng-container>\n                </div>\n            </div>\n        </div>\n    </abp-page>\n</form>"]}
|