@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.
Files changed (75) hide show
  1. package/config/providers/route.provider.d.ts +2 -3
  2. package/esm2022/config/providers/route.provider.mjs +3 -4
  3. package/esm2022/lib/cms-routing.module.mjs +3 -3
  4. package/esm2022/lib/cms.module.mjs +4 -4
  5. package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +18 -16
  6. package/esm2022/lib/components/admin/entries/create-or-update-entry-input-base.mjs +9 -1
  7. package/esm2022/lib/components/admin/entries/create.component.mjs +25 -63
  8. package/esm2022/lib/components/admin/entries/edit.component.mjs +28 -14
  9. package/esm2022/lib/components/admin/entries/entries.component.mjs +11 -16
  10. package/esm2022/lib/components/admin/fields/create-field.component.mjs +54 -54
  11. package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +44 -69
  12. package/esm2022/lib/components/admin/fields/edit-field.component.mjs +130 -73
  13. package/esm2022/lib/components/admin/fields/fields-form-config.mjs +50 -0
  14. package/esm2022/lib/components/admin/fields/fields-group.component.mjs +128 -0
  15. package/esm2022/lib/components/admin/fields/fields.component.mjs +61 -57
  16. package/esm2022/lib/components/admin/fields/index.mjs +3 -3
  17. package/esm2022/lib/components/admin/sections/create-or-edit-sections-modal.component.mjs +17 -15
  18. package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.component.mjs +59 -86
  19. package/esm2022/lib/components/admin/sections/sections.component.mjs +11 -14
  20. package/esm2022/lib/components/dynamic-form/matrix/matrix-config.component.mjs +32 -23
  21. package/esm2022/lib/components/dynamic-form/matrix/matrix-control.component.mjs +26 -11
  22. package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +50 -26
  23. package/esm2022/lib/components/dynamic-form/table/table-control.component.mjs +10 -10
  24. package/esm2022/lib/components/dynamic-form/table/table-view.component.mjs +3 -2
  25. package/esm2022/lib/resolvers/page-default-toolbar-actions.mjs +42 -37
  26. package/esm2022/lib/resolvers/table-default-entity-props.mjs +4 -4
  27. package/esm2022/lib/services/fields-data.service.mjs +100 -0
  28. package/esm2022/lib/services/form-controls.service.mjs +12 -10
  29. package/esm2022/lib/services/index.mjs +3 -4
  30. package/esm2022/lib/services/keys-convert-to-lowercase.service.mjs +40 -0
  31. package/fesm2022/dignite-ng-expand.cms-config.mjs +2 -3
  32. package/fesm2022/dignite-ng-expand.cms-config.mjs.map +1 -1
  33. package/fesm2022/dignite-ng-expand.cms.mjs +811 -784
  34. package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
  35. package/lib/cms.module.d.ts +2 -2
  36. package/lib/components/admin/entries/create-or-edit-entries.component.d.ts +3 -1
  37. package/lib/components/admin/entries/create-or-update-entry-input-base.d.ts +8 -0
  38. package/lib/components/admin/entries/create.component.d.ts +1 -2
  39. package/lib/components/admin/entries/edit.component.d.ts +1 -2
  40. package/lib/components/admin/entries/entries.component.d.ts +2 -1
  41. package/lib/components/admin/fields/create-field.component.d.ts +19 -22
  42. package/lib/components/admin/fields/create-or-edit-field.component.d.ts +20 -26
  43. package/lib/components/admin/fields/edit-field.component.d.ts +24 -30
  44. package/lib/components/admin/fields/fields-form-config.d.ts +19 -0
  45. package/lib/components/admin/fields/fields-group.component.d.ts +48 -0
  46. package/lib/components/admin/fields/fields.component.d.ts +18 -16
  47. package/lib/components/admin/fields/index.d.ts +1 -2
  48. package/lib/components/admin/sections/create-or-edit-sections-modal.component.d.ts +4 -1
  49. package/lib/components/admin/sections/entry-types/create-or-edit.component.d.ts +14 -9
  50. package/lib/components/admin/sections/sections.component.d.ts +1 -3
  51. package/lib/components/dynamic-form/matrix/matrix-config.component.d.ts +10 -4
  52. package/lib/components/dynamic-form/matrix/matrix-control.component.d.ts +7 -3
  53. package/lib/components/dynamic-form/table/table-config.component.d.ts +15 -5
  54. package/lib/components/dynamic-form/table/table-control.component.d.ts +3 -3
  55. package/lib/components/dynamic-form/table/table-view.component.d.ts +2 -1
  56. package/lib/resolvers/page-default-toolbar-actions.d.ts +9 -6
  57. package/lib/services/fields-data.service.d.ts +45 -0
  58. package/lib/services/form-controls.service.d.ts +3 -1
  59. package/lib/services/index.d.ts +2 -3
  60. package/lib/services/keys-convert-to-lowercase.service.d.ts +16 -0
  61. package/package.json +1 -1
  62. package/esm2022/lib/components/admin/fields/create-or-update-field-input-base.mjs +0 -18
  63. package/esm2022/lib/components/admin/fields/field-group.component.mjs +0 -144
  64. package/esm2022/lib/constants/styles.mjs +0 -19
  65. package/esm2022/lib/services/appent-content.mjs +0 -15
  66. package/esm2022/lib/services/cms-api.service.mjs +0 -94
  67. package/esm2022/lib/services/cms.service.mjs +0 -22
  68. package/esm2022/lib/services/field-abstracts.service.mjs +0 -48
  69. package/lib/components/admin/fields/create-or-update-field-input-base.d.ts +0 -15
  70. package/lib/components/admin/fields/field-group.component.d.ts +0 -58
  71. package/lib/constants/styles.d.ts +0 -2
  72. package/lib/services/appent-content.d.ts +0 -1
  73. package/lib/services/cms-api.service.d.ts +0 -23
  74. package/lib/services/cms.service.d.ts +0 -10
  75. 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 "../../../proxy/dignite/cms/admin/fields";
15
+ import * as i2 from "../../../services/fields-data.service";
19
16
  import * as i3 from "@abp/ng.theme.shared";
20
- import * as i4 from "@angular/common";
17
+ import * as i4 from "@dignite-ng/expand.core";
21
18
  import * as i5 from "@abp/ng.core";
22
- import * as i6 from "../../../services";
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, _FieldAdminService, toaster, _location, _LocalizationService, _CmsApiService) {
24
+ constructor(fb, _service, toaster, _LocationBackService, _LocalizationService, route, _UpdateListService, _DigniteValidatorsService) {
28
25
  this.fb = fb;
29
- this._FieldAdminService = _FieldAdminService;
26
+ this._service = _service;
30
27
  this.toaster = toaster;
31
- this._location = _location;
28
+ this._LocationBackService = _LocationBackService;
32
29
  this._LocalizationService = _LocalizationService;
33
- this._CmsApiService = _CmsApiService;
34
- this.route = inject(ActivatedRoute);
35
- this._UpdateListService = inject(UpdateListService);
36
- this.isSubmit = false;
37
- this._ValidatorsService = inject(ValidatorsService);
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.newEntity = this.fb.group(new CreateOrUpdateFieldInputBase());
42
+ this.formEntity = this.fb.group(new FieldsFormConfig());
53
43
  if (groupId) {
54
44
  this.groupIdInput.patchValue(groupId);
55
45
  }
56
46
  }
57
- /**触发提交按钮 */
58
- submitclickBtn() {
59
- this.submitclick.nativeElement.click();
47
+ /**字段分组控件 */
48
+ get groupIdInput() {
49
+ return this.formEntity?.get('groupId');
60
50
  }
61
- /**保存表单 */
51
+ /**提交表单 */
62
52
  save() {
63
- this.formValidation = this._ValidatorsService.getFormValidationStatus(this.newEntity);
64
- if (this._ValidatorsService.isCheckForm(this.formValidation, 'Cms'))
65
- return;
66
- const input = this.newEntity.value;
67
- if (this.isSubmit)
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
- this.isSubmit = true;
70
- if (!this.newEntity.valid)
61
+ }
62
+ if (this.isSubmitted)
71
63
  return;
72
- this._FieldAdminService
73
- .create(input)
74
- .pipe(finalize(() => {
75
- this.isSubmit = false;
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._location.back();
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
- 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 }); }
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 <form [formGroup]=\"newEntity\" [class]=\"{'was-validated':formValidation}\" (ngSubmit)=\"save()\">\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 [formGroup]=\"newEntity\" [Entity]=\"newEntity\"></cms-create-or-edit-field>\n </div>\n </div>\n </div>\n </form>\n </abp-page>", 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: i5.FormSubmitDirective, selector: "form[ngSubmit][formGroup]", inputs: ["debounce", "notValidateOnSubmit", "markAsDirtyWhenSubmit"], outputs: ["ngSubmit"] }, { 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" }] }); }
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 <form [formGroup]=\"newEntity\" [class]=\"{'was-validated':formValidation}\" (ngSubmit)=\"save()\">\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 [formGroup]=\"newEntity\" [Entity]=\"newEntity\"></cms-create-or-edit-field>\n </div>\n </div>\n </div>\n </form>\n </abp-page>", 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"] }]
99
- }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.FieldAdminService }, { type: i3.ToasterService }, { type: i4.Location }, { type: i5.LocalizationService }, { type: i6.CmsApiService }], propDecorators: { submitclick: [{
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,{"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 @angular-eslint/component-selector */\nimport { 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, inject, ViewChild, ElementRef, OnInit } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\nimport { CmsApiService } from '../../../services';\nimport { ECmsComponent } from '../../../enums';\nimport { UpdateListService } from '@dignite-ng/expand.core';\nimport { CreateOrUpdateFieldInputBase } from './create-or-update-field-input-base';\nimport { ValidatorsService } from '@dignite-ng/expand.core';\nimport { finalize } from 'rxjs';\nimport { FieldAdminService } from '../../../proxy/dignite/cms/admin/fields';\nimport { ActivatedRoute } from '@angular/router';\n\n@Component({\n  selector: 'cms-create-field',\n  templateUrl: './create-field.component.html',\n  styleUrls: ['./create-field.component.scss'],\n  providers: [\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.FieldsCreate,\n    },\n  ],\n})\nexport class CreateFieldComponent implements OnInit{\n  private route = inject(ActivatedRoute);\n  constructor(\n    private fb: FormBuilder,\n    public _FieldAdminService: FieldAdminService,\n    private toaster: ToasterService,\n    public _location: Location,\n    public _LocalizationService: LocalizationService,\n    \n    public _CmsApiService: CmsApiService\n  ) {}\n  private _UpdateListService = inject(UpdateListService);\n\n  /**表单实体 */\n  newEntity: FormGroup | undefined;\n\n  get groupIdInput(){\n    return this.newEntity?.get('groupId') as FormControl;\n  }\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  ngOnInit(): void {\n    //Called after the constructor, initializing input properties, and the first call to ngOnChanges.\n    //Add 'implements OnInit' to the class.\n    const {groupId} = this.route.snapshot.queryParams;\n    this.newEntity = this.fb.group(new CreateOrUpdateFieldInputBase());\n    if(groupId){\n      this.groupIdInput.patchValue(groupId)\n    }\n   \n  }\n\n  /**触发提交按钮 */\n  submitclickBtn() {\n    this.submitclick.nativeElement.click();\n  }\n  isSubmit: boolean|any = false;\n\n  private _ValidatorsService = inject(ValidatorsService);\n  /**表单验证状态\n   * {\n   *  title:true,\n   * }\n   */\n  formValidation: any = '';\n\n  /**保存表单 */\n  save() {\n    this.formValidation = this._ValidatorsService.getFormValidationStatus(this.newEntity);\n    if (this._ValidatorsService.isCheckForm(this.formValidation, 'Cms')) return;\n    const input = this.newEntity.value;\n    \n    if (this.isSubmit) return;\n    this.isSubmit = true;\n    if (!this.newEntity.valid) return;\n    this._FieldAdminService\n      .create(input)\n      .pipe(\n        finalize(() => {\n          this.isSubmit = false;\n        })\n      )\n      .subscribe(res => {\n        this.toaster.success(this._LocalizationService.instant(`AbpUi::SavedSuccessfully`));\n        this._location.back();\n        this._UpdateListService.updateList();\n      });\n  }\n\n}\n","<abp-page [title]=\"'Cms::CreateField' | abpLocalization\" [toolbar]=\"true\">\n        <form  [formGroup]=\"newEntity\"  [class]=\"{'was-validated':formValidation}\" (ngSubmit)=\"save()\">\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  [formGroup]=\"newEntity\" [Entity]=\"newEntity\"></cms-create-or-edit-field>\n                </div>\n            </div>\n        </div>\n    </form>\n    </abp-page>"]}
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 { FieldAbstractsService } from '../../../services/field-abstracts.service';
4
- import { FormControl, FormGroup, Validators, } from '@angular/forms';
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 "../../../services/field-abstracts.service";
10
- import * as i2 from "../../../services/cms-api.service";
11
- import * as i3 from "../../../proxy/dignite/cms/admin/fields";
12
- import * as i4 from "@abp/ng.core";
13
- import * as i5 from "@angular/common";
14
- import * as i6 from "@angular/forms";
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(_FieldAbstractsService, _CmsApiService, _FieldAdminService, _LocalizationService) {
19
- this._FieldAbstractsService = _FieldAbstractsService;
20
- this._CmsApiService = _CmsApiService;
21
- this._FieldAdminService = _FieldAdminService;
14
+ constructor(_ToPinyinService, _LocalizationService) {
15
+ this._ToPinyinService = _ToPinyinService;
22
16
  this._LocalizationService = _LocalizationService;
23
- if (this._FieldAbstractsService.fieldGroupList.length == 0) {
24
- this._FieldAbstractsService.getfieldGroupList();
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
- if (v) {
38
- this._selected = v || '';
39
- this._selected_copy = v;
40
- }
23
+ this._selected = v;
41
24
  }
42
- async dataLoaded() {
43
- if (this._FieldAbstractsService.fromControlList.length == 0) {
44
- await this._FieldAbstractsService.getFromControlList();
45
- }
46
- if (this._Entity) {
47
- if (!this.formControlName.value) {
48
- this._Entity.patchValue({
49
- formControlName: this._FieldAbstractsService.fromControlList[0]?.name,
50
- });
51
- }
52
- this._Entity.setControl('name', new FormControl(this.nameInput.value || '', {
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._Entity.get('name');
40
+ return this.formEntity?.get('name');
65
41
  }
66
- nameInputBlur(event) {
67
- const value = event.target.value;
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._CmsApiService.chineseToPinyin(value);
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._FieldAdminService.nameExists(ctrl.value).subscribe(res => {
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
- formControlNameChange(event) {
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 [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>" }]
108
- }], ctorParameters: () => [{ type: i1.FieldAbstractsService }, { type: i2.CmsApiService }, { type: i3.FieldAdminService }, { type: i4.LocalizationService }], propDecorators: { submitclick: [{
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
- }], selected: [{
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>"]}