@dignite-ng/expand.cms 3.1.11 → 3.1.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -20,7 +20,7 @@ export class CreateOrEditFieldComponent {
|
|
|
20
20
|
this.fromControlList = [];
|
|
21
21
|
}
|
|
22
22
|
set selected(v) {
|
|
23
|
-
this._selected = JSON.parse(JSON.stringify(v));
|
|
23
|
+
this._selected = v ? JSON.parse(JSON.stringify(v)) : v;
|
|
24
24
|
}
|
|
25
25
|
set form(v) {
|
|
26
26
|
this.formEntity = v;
|
|
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
107
107
|
type: ViewChild,
|
|
108
108
|
args: ['submitclick', { static: true }]
|
|
109
109
|
}] } });
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/fields/create-or-edit-field.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/fields/create-or-edit-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\r\nimport { AfterContentInit, Component, ElementRef, Input,  ViewChild } from '@angular/core';\r\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors } from '@angular/forms';\r\nimport { ToPinyinService } from '@dignite-ng/expand.core';\r\nimport { Observable } from 'rxjs';\r\nimport { LocalizationService } from '@abp/ng.core';\r\n\r\n@Component({\r\n  selector: 'cms-create-or-edit-field',\r\n  templateUrl: './create-or-edit-field.component.html',\r\n  styleUrl: './create-or-edit-field.component.scss',\r\n})\r\nexport class CreateOrEditFieldComponent implements AfterContentInit {\r\n  constructor(private _ToPinyinService: ToPinyinService,private _LocalizationService:LocalizationService) {}\r\n\r\n  _selected: any;\r\n  @Input()\r\n  public set selected(v: any) {\r\n    this._selected = JSON.parse(JSON.stringify(v));\r\n  }\r\n\r\n  @Input() public service: any;\r\n\r\n  formEntity: FormGroup | undefined;\r\n  @Input()\r\n  public set form(v: FormGroup | undefined) {\r\n    this.formEntity = v;\r\n  }\r\n\r\n\r\n\r\n  async ngAfterContentInit(): Promise<void> {\r\n    //Called after ngOnInit when the component's or directive's content has been initialized.\r\n    //Add 'implements AfterContentInit' to the class.\r\n    this.getfieldGroupsList = await this.service.getfieldGroups();\r\n    this.fromControlList = await this.service.getControlsfieldTypes();\r\n    this.nameInput.addAsyncValidators([this.repetitionAsyncValidator()])\r\n    if(!this.formControlNameInput.value&&this.fromControlList.length>0){\r\n      this.formControlNameInput.patchValue(this.fromControlList[0].name)\r\n    }\r\n     console.log(this._selected,'_selected')\r\n    this.submitclick.nativeElement.click()\r\n  }\r\n\r\n  /**字段分组列表 */\r\n  getfieldGroupsList: any[] = [];\r\n  /**表单控件列表 */\r\n  fromControlList: any[] = [];\r\n\r\n  get nameInput() {\r\n    return this.formEntity?.get('name') as FormControl;\r\n  }\r\n  get formControlNameInput() {\r\n    return this.formEntity?.get('formControlName') as FormControl;\r\n  }\r\n  get formConfigurationInput(){\r\n    return this.formEntity?.get('formConfiguration') as FormGroup;\r\n  }\r\n\r\n  /**获取提交按钮替身，用于真实触发表单提交 */\r\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\r\n\r\n  /**字段标签input失去标点生成字段名字 */\r\n  disPlayNameInputBlur(event) {\r\n    const value = event.target.value;\r\n    const pinyin = this._ToPinyinService.get(value);\r\n    const nameInput = this.nameInput;\r\n    if (nameInput.value) return;\r\n    nameInput.patchValue(pinyin);\r\n  }\r\n\r\n  /**异步验证，验证别名 */\r\n  repetitionAsyncValidator() {\r\n    return (\r\n      ctrl: AbstractControl,\r\n    ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\r\n      return new Promise(resolve => {\r\n        if (ctrl.value == this._selected?.name || !ctrl.value) {\r\n          resolve(null);\r\n          return;\r\n        }\r\n        this.service.nameExists(ctrl.value).subscribe(res => {\r\n          if (res) {\r\n            resolve({\r\n              repetition: this._LocalizationService.instant(\r\n                `Cms::FieldName{0}AlreadyExist`,\r\n                ctrl.value,\r\n              ),\r\n            });\r\n          } else {\r\n            resolve(null);\r\n          }\r\n        });\r\n      });\r\n    };\r\n  }\r\n  /** */\r\n  changeFormControlName(e){\r\n    console.log(this._selected,'_selected')\r\n  //  for (const element in this.formConfigurationInput.controls) {\r\n  //     const control = this.formConfigurationInput.controls[element];\r\n  //     const value = control.value;\r\n  //     if (Array.isArray(value)) {\r\n  //       control.patchValue([]);\r\n  //     } else if (typeof value === 'boolean') {\r\n  //       control.patchValue(false);\r\n  //     } else {\r\n  //       control.patchValue('');\r\n  //     }\r\n  //   }\r\n  }\r\n}\r\n","<div class=\"card\">\r\n    <div class=\"card-body\">\r\n        <form [formGroup]=\"formEntity\">\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n                <select class=\"form-select\" formControlName=\"groupId\">\r\n                    <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n                    <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n                        <option [value]=\"item.id\">{{item.name}}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n                    abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n                    (blur)=\"disPlayNameInputBlur($event)\">\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n                <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n                    {{nameInput.errors?.repetition}}\r\n                </div>\r\n                <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n                    abpLocalization}}</small>\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n                <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"changeFormControlName($event)\">\r\n                    <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n                        <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            @if(formControlNameInput.value&&formEntity){\r\n            <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n                [form]=\"formEntity\"></df-dynamic-config>\r\n            }\r\n            <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n        </form>\r\n    </div>\r\n</div>"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/fields/create-or-edit-field.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/fields/create-or-edit-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\r\nimport { AfterContentInit, Component, ElementRef, Input,  ViewChild } from '@angular/core';\r\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors } from '@angular/forms';\r\nimport { ToPinyinService } from '@dignite-ng/expand.core';\r\nimport { Observable } from 'rxjs';\r\nimport { LocalizationService } from '@abp/ng.core';\r\n\r\n@Component({\r\n  selector: 'cms-create-or-edit-field',\r\n  templateUrl: './create-or-edit-field.component.html',\r\n  styleUrl: './create-or-edit-field.component.scss',\r\n})\r\nexport class CreateOrEditFieldComponent implements AfterContentInit {\r\n  constructor(private _ToPinyinService: ToPinyinService,private _LocalizationService:LocalizationService) {}\r\n\r\n  _selected: any;\r\n  @Input()\r\n  public set selected(v: any) {\r\n    this._selected = v?JSON.parse(JSON.stringify(v)):v;\r\n  }\r\n\r\n  @Input() public service: any;\r\n\r\n  formEntity: FormGroup | undefined;\r\n  @Input()\r\n  public set form(v: FormGroup | undefined) {\r\n    this.formEntity = v;\r\n  }\r\n\r\n\r\n\r\n  async ngAfterContentInit(): Promise<void> {\r\n    //Called after ngOnInit when the component's or directive's content has been initialized.\r\n    //Add 'implements AfterContentInit' to the class.\r\n    this.getfieldGroupsList = await this.service.getfieldGroups();\r\n    this.fromControlList = await this.service.getControlsfieldTypes();\r\n    this.nameInput.addAsyncValidators([this.repetitionAsyncValidator()])\r\n    if(!this.formControlNameInput.value&&this.fromControlList.length>0){\r\n      this.formControlNameInput.patchValue(this.fromControlList[0].name)\r\n    }\r\n     console.log(this._selected,'_selected')\r\n    this.submitclick.nativeElement.click()\r\n  }\r\n\r\n  /**字段分组列表 */\r\n  getfieldGroupsList: any[] = [];\r\n  /**表单控件列表 */\r\n  fromControlList: any[] = [];\r\n\r\n  get nameInput() {\r\n    return this.formEntity?.get('name') as FormControl;\r\n  }\r\n  get formControlNameInput() {\r\n    return this.formEntity?.get('formControlName') as FormControl;\r\n  }\r\n  get formConfigurationInput(){\r\n    return this.formEntity?.get('formConfiguration') as FormGroup;\r\n  }\r\n\r\n  /**获取提交按钮替身，用于真实触发表单提交 */\r\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\r\n\r\n  /**字段标签input失去标点生成字段名字 */\r\n  disPlayNameInputBlur(event) {\r\n    const value = event.target.value;\r\n    const pinyin = this._ToPinyinService.get(value);\r\n    const nameInput = this.nameInput;\r\n    if (nameInput.value) return;\r\n    nameInput.patchValue(pinyin);\r\n  }\r\n\r\n  /**异步验证，验证别名 */\r\n  repetitionAsyncValidator() {\r\n    return (\r\n      ctrl: AbstractControl,\r\n    ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\r\n      return new Promise(resolve => {\r\n        if (ctrl.value == this._selected?.name || !ctrl.value) {\r\n          resolve(null);\r\n          return;\r\n        }\r\n        this.service.nameExists(ctrl.value).subscribe(res => {\r\n          if (res) {\r\n            resolve({\r\n              repetition: this._LocalizationService.instant(\r\n                `Cms::FieldName{0}AlreadyExist`,\r\n                ctrl.value,\r\n              ),\r\n            });\r\n          } else {\r\n            resolve(null);\r\n          }\r\n        });\r\n      });\r\n    };\r\n  }\r\n  /** */\r\n  changeFormControlName(e){\r\n    console.log(this._selected,'_selected')\r\n  //  for (const element in this.formConfigurationInput.controls) {\r\n  //     const control = this.formConfigurationInput.controls[element];\r\n  //     const value = control.value;\r\n  //     if (Array.isArray(value)) {\r\n  //       control.patchValue([]);\r\n  //     } else if (typeof value === 'boolean') {\r\n  //       control.patchValue(false);\r\n  //     } else {\r\n  //       control.patchValue('');\r\n  //     }\r\n  //   }\r\n  }\r\n}\r\n","<div class=\"card\">\r\n    <div class=\"card-body\">\r\n        <form [formGroup]=\"formEntity\">\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"groupId\">{{'Cms::FieldGroup' | abpLocalization}}</label>\r\n                <select class=\"form-select\" formControlName=\"groupId\">\r\n                    <option value=\"\">{{'Cms::OptionalGrouping' | abpLocalization}}</option>\r\n                    <ng-container *ngFor=\"let item of getfieldGroupsList\">\r\n                        <option [value]=\"item.id\">{{item.name}}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"displayName\">*{{'AbpDynamicForm::FieldDisplayName' |\r\n                    abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"displayName\" required\r\n                    (blur)=\"disPlayNameInputBlur($event)\">\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"name\">*{{'AbpDynamicForm::FieldName' | abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"name\" required>\r\n                <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\r\n                    {{nameInput.errors?.repetition}}\r\n                </div>\r\n                <small class=\"form-text text-muted d-block \">{{'AbpDynamicForm::FieldNameHelpText' |\r\n                    abpLocalization}}</small>\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"description\">{{'Cms::Description' | abpLocalization}}</label>\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"description\">\r\n            </div>\r\n            <div class=\"mb-3\">\r\n                <label class=\"form-label\" for=\"formControlName\">*{{'Cms::FieldType' | abpLocalization}}</label>\r\n                <select class=\"form-select\" formControlName=\"formControlName\" (change)=\"changeFormControlName($event)\">\r\n                    <ng-container *ngFor=\"let item of fromControlList;let i =index\">\r\n                        <option [value]=\"item.name\">{{item.displayName|abpLocalization}}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            @if(formControlNameInput.value&&formEntity){\r\n            <df-dynamic-config [formGroup]=\"formEntity\" [selected]=\"_selected\" [type]=\"formControlNameInput.value\"\r\n                [form]=\"formEntity\"></df-dynamic-config>\r\n            }\r\n            <button form-type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n        </form>\r\n    </div>\r\n</div>"]}
|
|
@@ -2189,7 +2189,7 @@ class CreateOrEditFieldComponent {
|
|
|
2189
2189
|
this.fromControlList = [];
|
|
2190
2190
|
}
|
|
2191
2191
|
set selected(v) {
|
|
2192
|
-
this._selected = JSON.parse(JSON.stringify(v));
|
|
2192
|
+
this._selected = v ? JSON.parse(JSON.stringify(v)) : v;
|
|
2193
2193
|
}
|
|
2194
2194
|
set form(v) {
|
|
2195
2195
|
this.formEntity = v;
|