@dignite-ng/expand.dynamic-form 0.0.7 → 0.0.8

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 (28) hide show
  1. package/esm2022/lib/components/dynamic/dynamic.component.mjs +3 -3
  2. package/esm2022/lib/components/from/form-control-group.mjs +20 -3
  3. package/esm2022/lib/components/from/index.mjs +3 -3
  4. package/esm2022/lib/components/from/matrix/index.mjs +4 -0
  5. package/esm2022/lib/components/from/matrix/matrix-config.component.mjs +225 -0
  6. package/esm2022/lib/components/from/matrix/matrix-config.mjs +50 -0
  7. package/esm2022/lib/components/from/matrix/matrix-control.component.mjs +110 -0
  8. package/esm2022/lib/components/from/select/select-config.component.mjs +1 -1
  9. package/esm2022/lib/components/from/table/index.mjs +4 -0
  10. package/esm2022/lib/components/from/table/table-config.component.mjs +171 -0
  11. package/esm2022/lib/components/from/table/table-config.mjs +38 -0
  12. package/esm2022/lib/components/from/table/table-control.component.mjs +112 -0
  13. package/esm2022/lib/dynamic-form.module.mjs +22 -6
  14. package/fesm2022/dignite-ng-expand.dynamic-form.mjs +715 -21
  15. package/fesm2022/dignite-ng-expand.dynamic-form.mjs.map +1 -1
  16. package/lib/components/dynamic/dynamic.component.d.ts +2 -2
  17. package/lib/components/from/form-control-group.d.ts +1 -1
  18. package/lib/components/from/index.d.ts +2 -0
  19. package/lib/components/from/matrix/index.d.ts +3 -0
  20. package/lib/components/from/matrix/matrix-config.component.d.ts +72 -0
  21. package/lib/components/from/matrix/matrix-config.d.ts +24 -0
  22. package/lib/components/from/matrix/matrix-control.component.d.ts +39 -0
  23. package/lib/components/from/table/index.d.ts +3 -0
  24. package/lib/components/from/table/table-config.component.d.ts +57 -0
  25. package/lib/components/from/table/table-config.d.ts +18 -0
  26. package/lib/components/from/table/table-control.component.d.ts +36 -0
  27. package/lib/dynamic-form.module.d.ts +11 -8
  28. package/package.json +1 -1
@@ -96,12 +96,12 @@ class DynamicComponent {
96
96
  instance.culture = this._culture;
97
97
  }
98
98
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
99
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DynamicComponent, selector: "df-dynamic", inputs: { selected: "selected", type: "type", entity: "entity", culture: "culture", parentFiledName: "parentFiledName", fields: "fields" }, viewQueries: [{ propertyName: "FormControlRef", first: true, predicate: ["FormControlRef"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "FormComponentsRef", first: true, predicate: ["FormComponentsRef"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<template #FormControlRef></template>\n<template #FormComponentsRef></template>", styles: [""] });
99
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DynamicComponent, isStandalone: true, selector: "df-dynamic", inputs: { selected: "selected", type: "type", entity: "entity", culture: "culture", parentFiledName: "parentFiledName", fields: "fields" }, viewQueries: [{ propertyName: "FormControlRef", first: true, predicate: ["FormControlRef"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "FormComponentsRef", first: true, predicate: ["FormComponentsRef"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<template #FormControlRef></template>\n<template #FormComponentsRef></template>", styles: [""] });
100
100
  }
101
101
  export { DynamicComponent };
102
102
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicComponent, decorators: [{
103
103
  type: Component,
104
- args: [{ selector: 'df-dynamic', template: "<template #FormControlRef></template>\n<template #FormComponentsRef></template>" }]
104
+ args: [{ selector: 'df-dynamic', standalone: true, template: "<template #FormControlRef></template>\n<template #FormComponentsRef></template>" }]
105
105
  }], propDecorators: { selected: [{
106
106
  type: Input
107
107
  }], type: [{
@@ -121,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
121
121
  type: ViewChild,
122
122
  args: ['FormComponentsRef', { read: ViewContainerRef, static: true }]
123
123
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic.component.js","sourceRoot":"","sources":["../../../../../../projects/dynamic-form/src/lib/components/dynamic/dynamic.component.ts","../../../../../../projects/dynamic-form/src/lib/components/dynamic/dynamic.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, Input, ViewChild, ViewContainerRef } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { FieldControlGroupInterfaces } from '../../interfaces';\nimport { FieldControlGroup } from '../from';\n\n@Component({\n  selector: 'df-dynamic',\n  templateUrl: './dynamic.component.html',\n  styleUrls: ['./dynamic.component.scss']\n})\nexport class DynamicComponent {\n\n\n  /**选择的表单信息 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    this._selected = v || '';\n   \n    if(v) this.dataLoaded(1)\n  }\n\n\n  /**表单控件类型 */\n  _type: string\n  @Input()\n  public set type(v: string) {\n    this._type = v;\n    if(v) this.dataLoaded(2)\n  }\n\n  /**表单实体 */\n  _entity: FormGroup | undefined\n  @Input()\n  public set entity(v: any) {\n    if(v) {\n      this._entity = v;\n     \n      this.dataLoaded(3)\n    }\n  }\n  /**语言 */\n  _culture: FormGroup | undefined\n  @Input()\n  public set culture(v: any) {\n    this._culture = v;\n    if(v) this.dataLoaded(6)\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n    if(v) this.dataLoaded(4)\n  }\n\n  /**字段配置列表 */\n  _fields: any = ''\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n    if(v) this.dataLoaded(5)\n  }\n\n\n  /**表单控件模板-动态表单配置组件 */\n  @ViewChild('FormControlRef', { read: ViewContainerRef, static: true }) FormControlRef: ViewContainerRef;\n\n  /**表单控件模板-动态表单组件 */\n  @ViewChild('FormComponentsRef', { read: ViewContainerRef, static: true }) FormComponentsRef: ViewContainerRef;\n\n  /**表单控件组 */\n  _fieldControlGroup: FieldControlGroupInterfaces[] = FieldControlGroup\n\n\n  /**数据加载完成 */\n  dataLoaded(val) {\n    if (this._entity) {\n      if (this._type) {\n        let fieldControlItem = this._fieldControlGroup.find(el => el.name === this._type)\n        this.loadfieldConfigComponent(fieldControlItem)\n      }\n      if (this._fields && this._parentFiledName) {\n        /**表单控件组中的项 */\n        let fieldControlItem = this._fieldControlGroup.find(el => el.name === this._fields.field.formControlName)\n        this.loadfieldComponent(fieldControlItem)\n      }\n    }\n  }\n\n\n\n  /**加载动态表单配置组件 */\n  loadfieldConfigComponent(FieldControlItem?: FieldControlGroupInterfaces) {\n    //清空了容器中的所有组件\n    this.FormControlRef?.clear();\n    if (!FieldControlItem || !FieldControlItem.fieldConfigComponent) return\n    //在容器中创建组件\n    const { instance } = this.FormControlRef?.createComponent(FieldControlItem.fieldConfigComponent);//创建组件模板\n    /**向创建的组件模板中传值 */\n    instance.Entity = this._entity\n    instance.selected = this._selected\n    instance.type = this._type\n  }\n\n  /**加载动态表单组件 */\n  loadfieldComponent(FieldControlItem?: FieldControlGroupInterfaces) {\n    // this.FormControlRef.clear\n    //清空了容器中的所有组件\n    this.FormComponentsRef?.clear();\n    if (!FieldControlItem || !FieldControlItem.fieldComponent) return\n    //在容器中创建组件\n    const { instance } = this.FormComponentsRef?.createComponent(FieldControlItem.fieldComponent);//创建组件模板\n    \n    // this.formConfigCompoent = instance\n    /**向创建的组件模板中传值 */\n    instance.entity = this._entity\n    instance.fields = this._fields\n    instance.parentFiledName = this._parentFiledName\n    instance.selected = this._selected\n    instance.culture = this._culture\n  }\n}\n","<template #FormControlRef></template>\n<template #FormComponentsRef></template>"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic.component.js","sourceRoot":"","sources":["../../../../../../projects/dynamic-form/src/lib/components/dynamic/dynamic.component.ts","../../../../../../projects/dynamic-form/src/lib/components/dynamic/dynamic.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, Input, ViewChild, ViewContainerRef } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport type{ FieldControlGroupInterfaces } from '../../interfaces';\nimport { FieldControlGroup } from '../from';\n\n@Component({\n  selector: 'df-dynamic',\n  standalone:true,\n  templateUrl: './dynamic.component.html',\n  styleUrls: ['./dynamic.component.scss']\n})\nexport class DynamicComponent {\n\n\n  /**选择的表单信息 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    this._selected = v || '';\n   \n    if(v) this.dataLoaded(1)\n  }\n\n\n  /**表单控件类型 */\n  _type: string\n  @Input()\n  public set type(v: string) {\n    this._type = v;\n    if(v) this.dataLoaded(2)\n  }\n\n  /**表单实体 */\n  _entity: FormGroup | undefined\n  @Input()\n  public set entity(v: any) {\n    if(v) {\n      this._entity = v;\n     \n      this.dataLoaded(3)\n    }\n  }\n  /**语言 */\n  _culture: FormGroup | undefined\n  @Input()\n  public set culture(v: any) {\n    this._culture = v;\n    if(v) this.dataLoaded(6)\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n    if(v) this.dataLoaded(4)\n  }\n\n  /**字段配置列表 */\n  _fields: any = ''\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n    if(v) this.dataLoaded(5)\n  }\n\n\n  /**表单控件模板-动态表单配置组件 */\n  @ViewChild('FormControlRef', { read: ViewContainerRef, static: true }) FormControlRef: ViewContainerRef;\n\n  /**表单控件模板-动态表单组件 */\n  @ViewChild('FormComponentsRef', { read: ViewContainerRef, static: true }) FormComponentsRef: ViewContainerRef;\n\n  /**表单控件组 */\n  _fieldControlGroup: FieldControlGroupInterfaces[] = FieldControlGroup\n\n\n  /**数据加载完成 */\n  dataLoaded(val) {\n    if (this._entity) {\n      if (this._type) {\n        let fieldControlItem = this._fieldControlGroup.find(el => el.name === this._type)\n        this.loadfieldConfigComponent(fieldControlItem)\n      }\n      if (this._fields && this._parentFiledName) {\n        /**表单控件组中的项 */\n        let fieldControlItem = this._fieldControlGroup.find(el => el.name === this._fields.field.formControlName)\n        this.loadfieldComponent(fieldControlItem)\n      }\n    }\n  }\n\n\n\n  /**加载动态表单配置组件 */\n  loadfieldConfigComponent(FieldControlItem?: FieldControlGroupInterfaces) {\n    //清空了容器中的所有组件\n    this.FormControlRef?.clear();\n    if (!FieldControlItem || !FieldControlItem.fieldConfigComponent) return\n    //在容器中创建组件\n    const { instance } = this.FormControlRef?.createComponent(FieldControlItem.fieldConfigComponent);//创建组件模板\n    /**向创建的组件模板中传值 */\n    instance.Entity = this._entity\n    instance.selected = this._selected\n    instance.type = this._type\n  }\n\n  /**加载动态表单组件 */\n  loadfieldComponent(FieldControlItem?: FieldControlGroupInterfaces) {\n    // this.FormControlRef.clear\n    //清空了容器中的所有组件\n    this.FormComponentsRef?.clear();\n    if (!FieldControlItem || !FieldControlItem.fieldComponent) return\n    //在容器中创建组件\n    const { instance } = this.FormComponentsRef?.createComponent(FieldControlItem.fieldComponent);//创建组件模板\n    \n    // this.formConfigCompoent = instance\n    /**向创建的组件模板中传值 */\n    instance.entity = this._entity\n    instance.fields = this._fields\n    instance.parentFiledName = this._parentFiledName\n    instance.selected = this._selected\n    instance.culture = this._culture\n  }\n}\n","<template #FormControlRef></template>\n<template #FormComponentsRef></template>"]}
@@ -2,10 +2,12 @@ import { CkEditorConfigComponent, CkEditorControlComponent } from "./ck-editor";
2
2
  import { DateEditConfigComponent } from "./date-edit/date-edit-config.component";
3
3
  import { DateEditControlComponent } from "./date-edit/date-edit-control.component";
4
4
  import { FileExplorerConfigComponent, FileExplorerControlComponent } from "./file-explorer";
5
+ import { MatrixConfigComponent, MatrixControlComponent } from "./matrix";
5
6
  import { NumbericEditConfigComponent } from "./numeric-edit/numberic-edit-config.component";
6
7
  import { NumbericEditControlComponent } from "./numeric-edit/numberic-edit-control.component";
7
8
  import { SelectConfigComponent, SelectControlComponent } from "./select";
8
9
  import { SwitchConfigComponent, SwitchControlComponent } from "./switch";
10
+ import { TableConfigComponent, TableControlComponent } from "./table";
9
11
  import { TextEditComponent, TextEditConfigComponent } from "./text-edit";
10
12
  /**
11
13
  * 表单控件分组-包含配置,控件,显示的数组
@@ -42,6 +44,20 @@ export const FieldControlGroup = [
42
44
  fieldComponent: DateEditControlComponent,
43
45
  // fieldViewComponent:TextBoxViewComponent,
44
46
  },
47
+ {
48
+ displayName: '表格',
49
+ name: 'Table',
50
+ fieldConfigComponent: TableConfigComponent,
51
+ fieldComponent: TableControlComponent,
52
+ // fieldViewComponent:TextBoxViewComponent,
53
+ },
54
+ {
55
+ displayName: '矩阵',
56
+ name: 'Matrix',
57
+ fieldConfigComponent: MatrixConfigComponent,
58
+ fieldComponent: MatrixControlComponent,
59
+ // fieldViewComponent:TextBoxViewComponent,
60
+ },
45
61
  {
46
62
  displayName: '文件管理',
47
63
  name: 'FileExplorer',
@@ -57,9 +73,10 @@ export const FieldControlGroup = [
57
73
  },
58
74
  ];
59
75
  export function getExcludeAssignControl(typeName) {
60
- return FieldControlGroup.filter(el => el.name !== typeName);
76
+ // return FieldControlGroup.filter(el => el.name !== typeName)
77
+ return FieldControlGroup;
61
78
  }
62
- export function AddFieldControlGroup(array) {
79
+ export function AddFieldControlGroup(array = []) {
63
80
  FieldControlGroup.push(...array);
64
81
  }
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1jb250cm9sLWdyb3VwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9mcm9tL2Zvcm0tY29udHJvbC1ncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDaEYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDakYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbkYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLDRCQUE0QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDNUYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDNUYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDOUYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLHNCQUFzQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN6RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFekU7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBa0M7SUFDNUQ7UUFDSSxXQUFXLEVBQUUsS0FBSztRQUNsQixJQUFJLEVBQUUsVUFBVTtRQUNoQixvQkFBb0IsRUFBRSx1QkFBdUI7UUFDN0MsY0FBYyxFQUFFLGlCQUFpQjtRQUNqQywyQ0FBMkM7S0FDOUMsRUFBRTtRQUNDLFdBQVcsRUFBRSxJQUFJO1FBQ2pCLElBQUksRUFBRSxRQUFRO1FBQ2Qsb0JBQW9CLEVBQUUscUJBQXFCO1FBQzNDLGNBQWMsRUFBRSxzQkFBc0I7UUFDdEMsMkNBQTJDO0tBQzlDLEVBQUU7UUFDQyxXQUFXLEVBQUUsSUFBSTtRQUNqQixJQUFJLEVBQUUsUUFBUTtRQUNkLG9CQUFvQixFQUFFLHFCQUFxQjtRQUMzQyxjQUFjLEVBQUUsc0JBQXNCO1FBQ3RDLDJDQUEyQztLQUM5QyxFQUFFO1FBQ0MsV0FBVyxFQUFFLElBQUk7UUFDakIsSUFBSSxFQUFFLGFBQWE7UUFDbkIsb0JBQW9CLEVBQUUsMkJBQTJCO1FBQ2pELGNBQWMsRUFBRSw0QkFBNEI7UUFDNUMsMkNBQTJDO0tBQzlDLEVBQUU7UUFDQyxXQUFXLEVBQUUsSUFBSTtRQUNqQixJQUFJLEVBQUUsVUFBVTtRQUNoQixvQkFBb0IsRUFBRSx1QkFBdUI7UUFDN0MsY0FBYyxFQUFFLHdCQUF3QjtRQUN4QywyQ0FBMkM7S0FDOUM7SUFFQTtRQUNHLFdBQVcsRUFBRSxNQUFNO1FBQ25CLElBQUksRUFBRSxjQUFjO1FBQ3BCLG9CQUFvQixFQUFFLDJCQUEyQjtRQUNqRCxjQUFjLEVBQUUsNEJBQTRCO1FBQzVDLDJDQUEyQztLQUM5QyxFQUFFO1FBQ0MsV0FBVyxFQUFFLFVBQVU7UUFDdkIsSUFBSSxFQUFFLFVBQVU7UUFDaEIsb0JBQW9CLEVBQUUsdUJBQXVCO1FBQzdDLGNBQWMsRUFBRSx3QkFBd0I7UUFDeEMsMkNBQTJDO0tBQzlDO0NBQ0osQ0FBQztBQUNGLE1BQU0sVUFBVSx1QkFBdUIsQ0FBQyxRQUFRO0lBQzVDLE9BQU8saUJBQWlCLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQTtBQUMvRCxDQUFDO0FBRUQsTUFBTSxVQUFVLG9CQUFvQixDQUFDLEtBQUs7SUFDdEMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUE7QUFDcEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZpZWxkQ29udHJvbEdyb3VwSW50ZXJmYWNlcyB9IGZyb20gXCIuLi8uLi9pbnRlcmZhY2VzXCI7XHJcbmltcG9ydCB7IENrRWRpdG9yQ29uZmlnQ29tcG9uZW50LCBDa0VkaXRvckNvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9jay1lZGl0b3JcIjtcclxuaW1wb3J0IHsgRGF0ZUVkaXRDb25maWdDb21wb25lbnQgfSBmcm9tIFwiLi9kYXRlLWVkaXQvZGF0ZS1lZGl0LWNvbmZpZy5jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgRGF0ZUVkaXRDb250cm9sQ29tcG9uZW50IH0gZnJvbSBcIi4vZGF0ZS1lZGl0L2RhdGUtZWRpdC1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBGaWxlRXhwbG9yZXJDb25maWdDb21wb25lbnQsIEZpbGVFeHBsb3JlckNvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9maWxlLWV4cGxvcmVyXCI7XHJcbmltcG9ydCB7IE51bWJlcmljRWRpdENvbmZpZ0NvbXBvbmVudCB9IGZyb20gXCIuL251bWVyaWMtZWRpdC9udW1iZXJpYy1lZGl0LWNvbmZpZy5jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgTnVtYmVyaWNFZGl0Q29udHJvbENvbXBvbmVudCB9IGZyb20gXCIuL251bWVyaWMtZWRpdC9udW1iZXJpYy1lZGl0LWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IFNlbGVjdENvbmZpZ0NvbXBvbmVudCwgU2VsZWN0Q29udHJvbENvbXBvbmVudCB9IGZyb20gXCIuL3NlbGVjdFwiO1xyXG5pbXBvcnQgeyBTd2l0Y2hDb25maWdDb21wb25lbnQsIFN3aXRjaENvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9zd2l0Y2hcIjtcclxuaW1wb3J0IHsgVGV4dEVkaXRDb21wb25lbnQsIFRleHRFZGl0Q29uZmlnQ29tcG9uZW50IH0gZnJvbSBcIi4vdGV4dC1lZGl0XCI7XHJcblxyXG4vKipcclxuICog6KGo5Y2V5o6n5Lu25YiG57uELeWMheWQq+mFjee9ru+8jOaOp+S7tu+8jOaYvuekuueahOaVsOe7hFxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IEZpZWxkQ29udHJvbEdyb3VwOiBGaWVsZENvbnRyb2xHcm91cEludGVyZmFjZXNbXSA9IFtcclxuICAgIHtcclxuICAgICAgICBkaXNwbGF5TmFtZTogJ+aWh+acrOahhicsXHJcbiAgICAgICAgbmFtZTogJ1RleHRFZGl0JyxcclxuICAgICAgICBmaWVsZENvbmZpZ0NvbXBvbmVudDogVGV4dEVkaXRDb25maWdDb21wb25lbnQsXHJcbiAgICAgICAgZmllbGRDb21wb25lbnQ6IFRleHRFZGl0Q29tcG9uZW50LFxyXG4gICAgICAgIC8vIGZpZWxkVmlld0NvbXBvbmVudDpUZXh0Qm94Vmlld0NvbXBvbmVudCxcclxuICAgIH0sIHtcclxuICAgICAgICBkaXNwbGF5TmFtZTogJ+W8gOWFsycsXHJcbiAgICAgICAgbmFtZTogJ1N3aXRjaCcsXHJcbiAgICAgICAgZmllbGRDb25maWdDb21wb25lbnQ6IFN3aXRjaENvbmZpZ0NvbXBvbmVudCxcclxuICAgICAgICBmaWVsZENvbXBvbmVudDogU3dpdGNoQ29udHJvbENvbXBvbmVudCxcclxuICAgICAgICAvLyBmaWVsZFZpZXdDb21wb25lbnQ6VGV4dEJveFZpZXdDb21wb25lbnQsXHJcbiAgICB9LCB7XHJcbiAgICAgICAgZGlzcGxheU5hbWU6ICfpgInmi6knLFxyXG4gICAgICAgIG5hbWU6ICdTZWxlY3QnLFxyXG4gICAgICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBTZWxlY3RDb25maWdDb21wb25lbnQsXHJcbiAgICAgICAgZmllbGRDb21wb25lbnQ6IFNlbGVjdENvbnRyb2xDb21wb25lbnQsXHJcbiAgICAgICAgLy8gZmllbGRWaWV3Q29tcG9uZW50OlRleHRCb3hWaWV3Q29tcG9uZW50LFxyXG4gICAgfSwge1xyXG4gICAgICAgIGRpc3BsYXlOYW1lOiAn5pWw5a2XJyxcclxuICAgICAgICBuYW1lOiAnTnVtZXJpY0VkaXQnLFxyXG4gICAgICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBOdW1iZXJpY0VkaXRDb25maWdDb21wb25lbnQsXHJcbiAgICAgICAgZmllbGRDb21wb25lbnQ6IE51bWJlcmljRWRpdENvbnRyb2xDb21wb25lbnQsXHJcbiAgICAgICAgLy8gZmllbGRWaWV3Q29tcG9uZW50OlRleHRCb3hWaWV3Q29tcG9uZW50LFxyXG4gICAgfSwge1xyXG4gICAgICAgIGRpc3BsYXlOYW1lOiAn5pel5pyfJyxcclxuICAgICAgICBuYW1lOiAnRGF0ZUVkaXQnLFxyXG4gICAgICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBEYXRlRWRpdENvbmZpZ0NvbXBvbmVudCxcclxuICAgICAgICBmaWVsZENvbXBvbmVudDogRGF0ZUVkaXRDb250cm9sQ29tcG9uZW50LFxyXG4gICAgICAgIC8vIGZpZWxkVmlld0NvbXBvbmVudDpUZXh0Qm94Vmlld0NvbXBvbmVudCxcclxuICAgIH0sXHJcblxyXG4gICAgIHtcclxuICAgICAgICBkaXNwbGF5TmFtZTogJ+aWh+S7tueuoeeQhicsXHJcbiAgICAgICAgbmFtZTogJ0ZpbGVFeHBsb3JlcicsXHJcbiAgICAgICAgZmllbGRDb25maWdDb21wb25lbnQ6IEZpbGVFeHBsb3JlckNvbmZpZ0NvbXBvbmVudCxcclxuICAgICAgICBmaWVsZENvbXBvbmVudDogRmlsZUV4cGxvcmVyQ29udHJvbENvbXBvbmVudCxcclxuICAgICAgICAvLyBmaWVsZFZpZXdDb21wb25lbnQ6VGV4dEJveFZpZXdDb21wb25lbnQsXHJcbiAgICB9LCB7XHJcbiAgICAgICAgZGlzcGxheU5hbWU6ICdDa0VkaXRvcicsXHJcbiAgICAgICAgbmFtZTogJ0NrRWRpdG9yJyxcclxuICAgICAgICBmaWVsZENvbmZpZ0NvbXBvbmVudDogQ2tFZGl0b3JDb25maWdDb21wb25lbnQsXHJcbiAgICAgICAgZmllbGRDb21wb25lbnQ6IENrRWRpdG9yQ29udHJvbENvbXBvbmVudCxcclxuICAgICAgICAvLyBmaWVsZFZpZXdDb21wb25lbnQ6VGV4dEJveFZpZXdDb21wb25lbnQsXHJcbiAgICB9LFxyXG5dO1xyXG5leHBvcnQgZnVuY3Rpb24gZ2V0RXhjbHVkZUFzc2lnbkNvbnRyb2wodHlwZU5hbWUpIHtcclxuICAgIHJldHVybiBGaWVsZENvbnRyb2xHcm91cC5maWx0ZXIoZWwgPT4gZWwubmFtZSAhPT0gdHlwZU5hbWUpXHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBBZGRGaWVsZENvbnRyb2xHcm91cChhcnJheSkge1xyXG4gICAgRmllbGRDb250cm9sR3JvdXAucHVzaCguLi5hcnJheSlcclxufSJdfQ==
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1jb250cm9sLWdyb3VwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9mcm9tL2Zvcm0tY29udHJvbC1ncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDaEYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDakYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbkYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLDRCQUE0QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDNUYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLHNCQUFzQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3pFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQzVGLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQzlGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN6RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDekUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLHFCQUFxQixFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ3RFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUV6RTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFrQztJQUM1RDtRQUNJLFdBQVcsRUFBRSxLQUFLO1FBQ2xCLElBQUksRUFBRSxVQUFVO1FBQ2hCLG9CQUFvQixFQUFFLHVCQUF1QjtRQUM3QyxjQUFjLEVBQUUsaUJBQWlCO1FBQ2pDLDJDQUEyQztLQUM5QyxFQUFFO1FBQ0MsV0FBVyxFQUFFLElBQUk7UUFDakIsSUFBSSxFQUFFLFFBQVE7UUFDZCxvQkFBb0IsRUFBRSxxQkFBcUI7UUFDM0MsY0FBYyxFQUFFLHNCQUFzQjtRQUN0QywyQ0FBMkM7S0FDOUMsRUFBRTtRQUNDLFdBQVcsRUFBRSxJQUFJO1FBQ2pCLElBQUksRUFBRSxRQUFRO1FBQ2Qsb0JBQW9CLEVBQUUscUJBQXFCO1FBQzNDLGNBQWMsRUFBRSxzQkFBc0I7UUFDdEMsMkNBQTJDO0tBQzlDLEVBQUU7UUFDQyxXQUFXLEVBQUUsSUFBSTtRQUNqQixJQUFJLEVBQUUsYUFBYTtRQUNuQixvQkFBb0IsRUFBRSwyQkFBMkI7UUFDakQsY0FBYyxFQUFFLDRCQUE0QjtRQUM1QywyQ0FBMkM7S0FDOUMsRUFBRTtRQUNDLFdBQVcsRUFBRSxJQUFJO1FBQ2pCLElBQUksRUFBRSxVQUFVO1FBQ2hCLG9CQUFvQixFQUFFLHVCQUF1QjtRQUM3QyxjQUFjLEVBQUUsd0JBQXdCO1FBQ3hDLDJDQUEyQztLQUM5QztJQUNEO1FBQ0ksV0FBVyxFQUFFLElBQUk7UUFDakIsSUFBSSxFQUFFLE9BQU87UUFDYixvQkFBb0IsRUFBRSxvQkFBb0I7UUFDMUMsY0FBYyxFQUFFLHFCQUFxQjtRQUNyQywyQ0FBMkM7S0FDOUM7SUFDRDtRQUNJLFdBQVcsRUFBRSxJQUFJO1FBQ2pCLElBQUksRUFBRSxRQUFRO1FBQ2Qsb0JBQW9CLEVBQUUscUJBQXFCO1FBQzNDLGNBQWMsRUFBRSxzQkFBc0I7UUFDdEMsMkNBQTJDO0tBQzlDO0lBQ0E7UUFDRyxXQUFXLEVBQUUsTUFBTTtRQUNuQixJQUFJLEVBQUUsY0FBYztRQUNwQixvQkFBb0IsRUFBRSwyQkFBMkI7UUFDakQsY0FBYyxFQUFFLDRCQUE0QjtRQUM1QywyQ0FBMkM7S0FDOUMsRUFBRTtRQUNDLFdBQVcsRUFBRSxVQUFVO1FBQ3ZCLElBQUksRUFBRSxVQUFVO1FBQ2hCLG9CQUFvQixFQUFFLHVCQUF1QjtRQUM3QyxjQUFjLEVBQUUsd0JBQXdCO1FBQ3hDLDJDQUEyQztLQUM5QztDQUNKLENBQUM7QUFDRixNQUFNLFVBQVUsdUJBQXVCLENBQUMsUUFBUTtJQUM1Qyw4REFBOEQ7SUFDOUQsT0FBTyxpQkFBaUIsQ0FBQTtBQUM1QixDQUFDO0FBRUQsTUFBTSxVQUFVLG9CQUFvQixDQUFDLEtBQUssR0FBQyxFQUFFO0lBQ3pDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFBO0FBQ3BDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBpbXBvcnQgeyBUYWJsZUNvbmZpZ0NvbXBvbmVudCwgVGFibGVDb250cm9sQ29tcG9uZW50LCBNYXRyaXhDb25maWdDb21wb25lbnQsIE1hdHJpeENvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiQGRpZ25pdGUtbmcvZXhwYW5kLmNtc1wiO1xyXG5pbXBvcnQgIHsgRmllbGRDb250cm9sR3JvdXBJbnRlcmZhY2VzIH0gZnJvbSBcIi4uLy4uL2ludGVyZmFjZXNcIjtcclxuaW1wb3J0IHsgQ2tFZGl0b3JDb25maWdDb21wb25lbnQsIENrRWRpdG9yQ29udHJvbENvbXBvbmVudCB9IGZyb20gXCIuL2NrLWVkaXRvclwiO1xyXG5pbXBvcnQgeyBEYXRlRWRpdENvbmZpZ0NvbXBvbmVudCB9IGZyb20gXCIuL2RhdGUtZWRpdC9kYXRlLWVkaXQtY29uZmlnLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBEYXRlRWRpdENvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9kYXRlLWVkaXQvZGF0ZS1lZGl0LWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IEZpbGVFeHBsb3JlckNvbmZpZ0NvbXBvbmVudCwgRmlsZUV4cGxvcmVyQ29udHJvbENvbXBvbmVudCB9IGZyb20gXCIuL2ZpbGUtZXhwbG9yZXJcIjtcclxuaW1wb3J0IHsgTWF0cml4Q29uZmlnQ29tcG9uZW50LCBNYXRyaXhDb250cm9sQ29tcG9uZW50IH0gZnJvbSBcIi4vbWF0cml4XCI7XHJcbmltcG9ydCB7IE51bWJlcmljRWRpdENvbmZpZ0NvbXBvbmVudCB9IGZyb20gXCIuL251bWVyaWMtZWRpdC9udW1iZXJpYy1lZGl0LWNvbmZpZy5jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgTnVtYmVyaWNFZGl0Q29udHJvbENvbXBvbmVudCB9IGZyb20gXCIuL251bWVyaWMtZWRpdC9udW1iZXJpYy1lZGl0LWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IFNlbGVjdENvbmZpZ0NvbXBvbmVudCwgU2VsZWN0Q29udHJvbENvbXBvbmVudCB9IGZyb20gXCIuL3NlbGVjdFwiO1xyXG5pbXBvcnQgeyBTd2l0Y2hDb25maWdDb21wb25lbnQsIFN3aXRjaENvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9zd2l0Y2hcIjtcclxuaW1wb3J0IHsgVGFibGVDb25maWdDb21wb25lbnQsIFRhYmxlQ29udHJvbENvbXBvbmVudCB9IGZyb20gXCIuL3RhYmxlXCI7XHJcbmltcG9ydCB7IFRleHRFZGl0Q29tcG9uZW50LCBUZXh0RWRpdENvbmZpZ0NvbXBvbmVudCB9IGZyb20gXCIuL3RleHQtZWRpdFwiO1xyXG5cclxuLyoqXHJcbiAqIOihqOWNleaOp+S7tuWIhue7hC3ljIXlkKvphY3nva7vvIzmjqfku7bvvIzmmL7npLrnmoTmlbDnu4RcclxuICovXHJcbmV4cG9ydCBjb25zdCBGaWVsZENvbnRyb2xHcm91cDogRmllbGRDb250cm9sR3JvdXBJbnRlcmZhY2VzW10gPSBbXHJcbiAgICB7XHJcbiAgICAgICAgZGlzcGxheU5hbWU6ICfmlofmnKzmoYYnLFxyXG4gICAgICAgIG5hbWU6ICdUZXh0RWRpdCcsXHJcbiAgICAgICAgZmllbGRDb25maWdDb21wb25lbnQ6IFRleHRFZGl0Q29uZmlnQ29tcG9uZW50LFxyXG4gICAgICAgIGZpZWxkQ29tcG9uZW50OiBUZXh0RWRpdENvbXBvbmVudCxcclxuICAgICAgICAvLyBmaWVsZFZpZXdDb21wb25lbnQ6VGV4dEJveFZpZXdDb21wb25lbnQsXHJcbiAgICB9LCB7XHJcbiAgICAgICAgZGlzcGxheU5hbWU6ICflvIDlhbMnLFxyXG4gICAgICAgIG5hbWU6ICdTd2l0Y2gnLFxyXG4gICAgICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBTd2l0Y2hDb25maWdDb21wb25lbnQsXHJcbiAgICAgICAgZmllbGRDb21wb25lbnQ6IFN3aXRjaENvbnRyb2xDb21wb25lbnQsXHJcbiAgICAgICAgLy8gZmllbGRWaWV3Q29tcG9uZW50OlRleHRCb3hWaWV3Q29tcG9uZW50LFxyXG4gICAgfSwge1xyXG4gICAgICAgIGRpc3BsYXlOYW1lOiAn6YCJ5oupJyxcclxuICAgICAgICBuYW1lOiAnU2VsZWN0JyxcclxuICAgICAgICBmaWVsZENvbmZpZ0NvbXBvbmVudDogU2VsZWN0Q29uZmlnQ29tcG9uZW50LFxyXG4gICAgICAgIGZpZWxkQ29tcG9uZW50OiBTZWxlY3RDb250cm9sQ29tcG9uZW50LFxyXG4gICAgICAgIC8vIGZpZWxkVmlld0NvbXBvbmVudDpUZXh0Qm94Vmlld0NvbXBvbmVudCxcclxuICAgIH0sIHtcclxuICAgICAgICBkaXNwbGF5TmFtZTogJ+aVsOWtlycsXHJcbiAgICAgICAgbmFtZTogJ051bWVyaWNFZGl0JyxcclxuICAgICAgICBmaWVsZENvbmZpZ0NvbXBvbmVudDogTnVtYmVyaWNFZGl0Q29uZmlnQ29tcG9uZW50LFxyXG4gICAgICAgIGZpZWxkQ29tcG9uZW50OiBOdW1iZXJpY0VkaXRDb250cm9sQ29tcG9uZW50LFxyXG4gICAgICAgIC8vIGZpZWxkVmlld0NvbXBvbmVudDpUZXh0Qm94Vmlld0NvbXBvbmVudCxcclxuICAgIH0sIHtcclxuICAgICAgICBkaXNwbGF5TmFtZTogJ+aXpeacnycsXHJcbiAgICAgICAgbmFtZTogJ0RhdGVFZGl0JyxcclxuICAgICAgICBmaWVsZENvbmZpZ0NvbXBvbmVudDogRGF0ZUVkaXRDb25maWdDb21wb25lbnQsXHJcbiAgICAgICAgZmllbGRDb21wb25lbnQ6IERhdGVFZGl0Q29udHJvbENvbXBvbmVudCxcclxuICAgICAgICAvLyBmaWVsZFZpZXdDb21wb25lbnQ6VGV4dEJveFZpZXdDb21wb25lbnQsXHJcbiAgICB9LFxyXG4gICAge1xyXG4gICAgICAgIGRpc3BsYXlOYW1lOiAn6KGo5qC8JyxcclxuICAgICAgICBuYW1lOiAnVGFibGUnLFxyXG4gICAgICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBUYWJsZUNvbmZpZ0NvbXBvbmVudCxcclxuICAgICAgICBmaWVsZENvbXBvbmVudDogVGFibGVDb250cm9sQ29tcG9uZW50LFxyXG4gICAgICAgIC8vIGZpZWxkVmlld0NvbXBvbmVudDpUZXh0Qm94Vmlld0NvbXBvbmVudCxcclxuICAgIH0sXHJcbiAgICB7XHJcbiAgICAgICAgZGlzcGxheU5hbWU6ICfnn6npmLUnLFxyXG4gICAgICAgIG5hbWU6ICdNYXRyaXgnLFxyXG4gICAgICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBNYXRyaXhDb25maWdDb21wb25lbnQsXHJcbiAgICAgICAgZmllbGRDb21wb25lbnQ6IE1hdHJpeENvbnRyb2xDb21wb25lbnQsXHJcbiAgICAgICAgLy8gZmllbGRWaWV3Q29tcG9uZW50OlRleHRCb3hWaWV3Q29tcG9uZW50LFxyXG4gICAgfSwgXHJcbiAgICAge1xyXG4gICAgICAgIGRpc3BsYXlOYW1lOiAn5paH5Lu2566h55CGJyxcclxuICAgICAgICBuYW1lOiAnRmlsZUV4cGxvcmVyJyxcclxuICAgICAgICBmaWVsZENvbmZpZ0NvbXBvbmVudDogRmlsZUV4cGxvcmVyQ29uZmlnQ29tcG9uZW50LFxyXG4gICAgICAgIGZpZWxkQ29tcG9uZW50OiBGaWxlRXhwbG9yZXJDb250cm9sQ29tcG9uZW50LFxyXG4gICAgICAgIC8vIGZpZWxkVmlld0NvbXBvbmVudDpUZXh0Qm94Vmlld0NvbXBvbmVudCxcclxuICAgIH0sIHtcclxuICAgICAgICBkaXNwbGF5TmFtZTogJ0NrRWRpdG9yJyxcclxuICAgICAgICBuYW1lOiAnQ2tFZGl0b3InLFxyXG4gICAgICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBDa0VkaXRvckNvbmZpZ0NvbXBvbmVudCxcclxuICAgICAgICBmaWVsZENvbXBvbmVudDogQ2tFZGl0b3JDb250cm9sQ29tcG9uZW50LFxyXG4gICAgICAgIC8vIGZpZWxkVmlld0NvbXBvbmVudDpUZXh0Qm94Vmlld0NvbXBvbmVudCxcclxuICAgIH0sXHJcbl07XHJcbmV4cG9ydCBmdW5jdGlvbiBnZXRFeGNsdWRlQXNzaWduQ29udHJvbCh0eXBlTmFtZSkge1xyXG4gICAgLy8gcmV0dXJuIEZpZWxkQ29udHJvbEdyb3VwLmZpbHRlcihlbCA9PiBlbC5uYW1lICE9PSB0eXBlTmFtZSlcclxuICAgIHJldHVybiBGaWVsZENvbnRyb2xHcm91cFxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gQWRkRmllbGRDb250cm9sR3JvdXAoYXJyYXk9W10pIHtcclxuICAgIEZpZWxkQ29udHJvbEdyb3VwLnB1c2goLi4uYXJyYXkpXHJcbn0iXX0=
@@ -6,6 +6,6 @@ export * from './date-edit';
6
6
  export * from './file-explorer';
7
7
  export * from './form-control-group';
8
8
  export * from './select';
9
- // export * from './matrix'
10
- // export * from './table'
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zyb20vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUE7QUFDM0IsY0FBYyxVQUFVLENBQUE7QUFDeEIsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixjQUFjLGFBQWEsQ0FBQTtBQUMzQixjQUFjLGFBQWEsQ0FBQTtBQUMzQixjQUFjLGlCQUFpQixDQUFBO0FBQy9CLGNBQWMsc0JBQXNCLENBQUE7QUFDcEMsY0FBYyxVQUFVLENBQUE7QUFDeEIsMkJBQTJCO0FBQzNCLDBCQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdGV4dC1lZGl0J1xyXG5leHBvcnQgKiBmcm9tICcuL3N3aXRjaCdcclxuZXhwb3J0ICogZnJvbSAnLi9udW1lcmljLWVkaXQnXHJcbmV4cG9ydCAqIGZyb20gJy4vY2stZWRpdG9yJ1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGUtZWRpdCdcclxuZXhwb3J0ICogZnJvbSAnLi9maWxlLWV4cGxvcmVyJ1xyXG5leHBvcnQgKiBmcm9tICcuL2Zvcm0tY29udHJvbC1ncm91cCdcclxuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QnXHJcbi8vIGV4cG9ydCAqIGZyb20gJy4vbWF0cml4J1xyXG4vLyBleHBvcnQgKiBmcm9tICcuL3RhYmxlJyJdfQ==
9
+ export * from './matrix';
10
+ export * from './table';
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zyb20vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUE7QUFDM0IsY0FBYyxVQUFVLENBQUE7QUFDeEIsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixjQUFjLGFBQWEsQ0FBQTtBQUMzQixjQUFjLGFBQWEsQ0FBQTtBQUMzQixjQUFjLGlCQUFpQixDQUFBO0FBQy9CLGNBQWMsc0JBQXNCLENBQUE7QUFDcEMsY0FBYyxVQUFVLENBQUE7QUFDeEIsY0FBYyxVQUFVLENBQUE7QUFDeEIsY0FBYyxTQUFTLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RleHQtZWRpdCdcclxuZXhwb3J0ICogZnJvbSAnLi9zd2l0Y2gnXHJcbmV4cG9ydCAqIGZyb20gJy4vbnVtZXJpYy1lZGl0J1xyXG5leHBvcnQgKiBmcm9tICcuL2NrLWVkaXRvcidcclxuZXhwb3J0ICogZnJvbSAnLi9kYXRlLWVkaXQnXHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS1leHBsb3JlcidcclxuZXhwb3J0ICogZnJvbSAnLi9mb3JtLWNvbnRyb2wtZ3JvdXAnXHJcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0J1xyXG5leHBvcnQgKiBmcm9tICcuL21hdHJpeCdcclxuZXhwb3J0ICogZnJvbSAnLi90YWJsZSciXX0=
@@ -0,0 +1,4 @@
1
+ export * from './matrix-config';
2
+ export * from './matrix-control.component';
3
+ export * from './matrix-config.component';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zyb20vbWF0cml4L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUE7QUFDL0IsY0FBYyw0QkFBNEIsQ0FBQTtBQUMxQyxjQUFjLDJCQUEyQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9tYXRyaXgtY29uZmlnJ1xyXG5leHBvcnQgKiBmcm9tICcuL21hdHJpeC1jb250cm9sLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9tYXRyaXgtY29uZmlnLmNvbXBvbmVudCciXX0=
@@ -0,0 +1,225 @@
1
+ import { Component, Input, ViewChild } from '@angular/core';
2
+ import { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';
3
+ import { MatrixConfig, MatrixItemConfig } from './matrix-config';
4
+ import { getExcludeAssignControl } from '../form-control-group';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/forms";
7
+ import * as i2 from "../../../services";
8
+ import * as i3 from "@angular/common";
9
+ import * as i4 from "@abp/ng.core";
10
+ import * as i5 from "@ngx-validate/core";
11
+ import * as i6 from "@abp/ng.theme.shared";
12
+ import * as i7 from "@ng-bootstrap/ng-bootstrap";
13
+ class MatrixConfigComponent {
14
+ fb;
15
+ _DfApiService;
16
+ constructor(fb, _DfApiService) {
17
+ this.fb = fb;
18
+ this._DfApiService = _DfApiService;
19
+ }
20
+ /**表单控件组 */
21
+ _FieldControlGroup;
22
+ /**表单控件类型 */
23
+ _type;
24
+ set type(v) {
25
+ this._type = v;
26
+ this.dataLoaded();
27
+ }
28
+ /**表单实体 */
29
+ _Entity;
30
+ set Entity(v) {
31
+ this._Entity = v;
32
+ this.dataLoaded();
33
+ }
34
+ /**选择的表单信息 */
35
+ _selected;
36
+ set selected(v) {
37
+ if (v) {
38
+ this._selected = v;
39
+ this.dataLoaded();
40
+ }
41
+ }
42
+ submitclick;
43
+ async dataLoaded() {
44
+ if (this._Entity && this._type) {
45
+ await this.AfterInit();
46
+ this.submitclick.nativeElement.click();
47
+ }
48
+ }
49
+ AfterInit() {
50
+ return new Promise(async (resolve, rejects) => {
51
+ this._FieldControlGroup = getExcludeAssignControl(this._type);
52
+ // this._FieldControlGroup = getExcludeAssignControl(this._type)
53
+ this._Entity.setControl('formConfiguration', this.fb.group(new MatrixConfig()));
54
+ await this.setSelectValue();
55
+ this.formConfiguration.patchValue(this._selected.formConfiguration);
56
+ resolve(true);
57
+ });
58
+ }
59
+ setSelectValue() {
60
+ return new Promise((resolve, rejects) => {
61
+ if (this._selected && this._selected.formControlName == this._type) {
62
+ this._selected.formConfiguration['MatrixBlockTypes'].forEach(((el, index) => {
63
+ this.addMatrixBlockTypeItem(el);
64
+ el.fields.forEach((elf, indexf) => {
65
+ this.addMatrixFieldItem(elf, index);
66
+ });
67
+ }));
68
+ resolve(true);
69
+ }
70
+ });
71
+ }
72
+ /**获取表单配置 */
73
+ get formConfiguration() {
74
+ return this._Entity.get('formConfiguration');
75
+ }
76
+ /**获取表单配置下的矩阵块表单数组 */
77
+ get MatrixBlockTypes() {
78
+ return this.formConfiguration.controls['MatrixBlockTypes'];
79
+ }
80
+ /**模态框-状态 */
81
+ matrixModalOpen = false;
82
+ /**模态框-是否正在编辑 */
83
+ isMatrixModalEdit = false;
84
+ /**模态框-用于确定模态的繁忙状态是否为真 */
85
+ modalBusy = false;
86
+ /**模态框-表单 */
87
+ matrixModalForm;
88
+ /**表单控件模板-用于在form外提交submit */
89
+ matrixModalModalSubmit;
90
+ /**矩阵块-选择的下标 */
91
+ selectMatrixBlockIndex = 0;
92
+ /**矩阵块-选择的矩阵下字段的下标 */
93
+ selectMatrixFieldIndex = 0;
94
+ /**模态框-状态改变 */
95
+ matrixModalVisibleChange(event) {
96
+ if (!event) {
97
+ this.isMatrixModalEdit = false;
98
+ this.matrixModalForm = undefined;
99
+ return;
100
+ }
101
+ }
102
+ /**矩阵块--新增-打开模态框 */
103
+ addMatrixBlockType() {
104
+ this.matrixModalForm = this.fb.group(new MatrixItemConfig());
105
+ this.matrixModalOpen = true;
106
+ }
107
+ /**模态框--矩阵表单保存提交 */
108
+ createOrEditSave() {
109
+ let input = this.matrixModalForm.value;
110
+ if (!this.matrixModalForm.valid)
111
+ return;
112
+ if (this.isMatrixModalEdit) {
113
+ let MatrixBlockTypesItem = this.MatrixBlockTypes.at(this.selectMatrixBlockIndex);
114
+ MatrixBlockTypesItem.patchValue({
115
+ ...input
116
+ });
117
+ }
118
+ else {
119
+ this.addMatrixBlockTypeItem(input);
120
+ }
121
+ this.matrixModalOpen = false;
122
+ }
123
+ /**新增矩阵块-向数组表单中增加项 */
124
+ addMatrixBlockTypeItem(input) {
125
+ this.MatrixBlockTypes.push(new FormGroup({
126
+ displayName: new FormControl(input.displayName, Validators.required),
127
+ name: new FormControl(input.name, Validators.required),
128
+ fields: new FormArray([])
129
+ }));
130
+ }
131
+ /**编辑矩阵块 */
132
+ EditMatrixBlock(input) {
133
+ this.matrixModalForm = this.fb.group(new MatrixItemConfig());
134
+ this.matrixModalForm.patchValue({
135
+ ...input
136
+ });
137
+ this.matrixModalOpen = true;
138
+ this.isMatrixModalEdit = true;
139
+ }
140
+ /**删除矩阵块 */
141
+ DeleteMatrixBlock(index) {
142
+ this.MatrixBlockTypes.removeAt(index);
143
+ }
144
+ /**矩阵块-选择 */
145
+ selectMatrixBlockChange(index) {
146
+ this.selectMatrixBlockIndex = index;
147
+ }
148
+ /**矩阵字段-新增 */
149
+ addMatrixField() {
150
+ this.addMatrixFieldItem('', this.selectMatrixBlockIndex);
151
+ }
152
+ /**矩阵字段-新增矩阵字段项 */
153
+ addMatrixFieldItem(input = '', selectMatrixBlockIndex) {
154
+ /**矩阵下标的矩阵项Form */
155
+ let MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(selectMatrixBlockIndex);
156
+ let MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields');
157
+ MatrixFieldItemForm.push(this.fb.group({
158
+ /**字段名称 Display name of this field */
159
+ displayName: [input.displayName, [Validators.required]],
160
+ /**字段唯一名称 Unique Name*/
161
+ name: [input.name, [Validators.required]],
162
+ /**描述 说明 */
163
+ description: [input.description, []],
164
+ /**FieldType字段类型 表单控件名称 */
165
+ formControlName: [input.formControlName || 'TextEdit', [Validators.required]],
166
+ //动态表单配置
167
+ formConfiguration: new FormGroup({}),
168
+ }));
169
+ }
170
+ /**删除矩阵字段项 */
171
+ deleteMatrixField(MatrixFieldForm, index) {
172
+ MatrixFieldForm.removeAt(index);
173
+ this.selectMatrixFieldIndex = 0;
174
+ }
175
+ /**矩阵字段-选择 */
176
+ selectMatrixFieldChange(MatrixBlockIndex, MatrixFieldIndex) {
177
+ this.selectMatrixFieldIndex = MatrixFieldIndex;
178
+ }
179
+ get nameInput() {
180
+ return this.matrixModalForm?.get('name');
181
+ }
182
+ get FieldnameInput() {
183
+ let MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(this.selectMatrixBlockIndex);
184
+ let MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields');
185
+ return MatrixFieldItemForm.at(this.selectMatrixFieldIndex).get('name');
186
+ }
187
+ /**矩阵displayNameInput字段失去焦点 */
188
+ displayNameInputBlur(event) {
189
+ let value = event.target.value;
190
+ let pinyin = this._DfApiService.chineseToPinyin(value);
191
+ let nameInput = this.nameInput;
192
+ if (nameInput.value)
193
+ return;
194
+ nameInput.patchValue(pinyin);
195
+ }
196
+ /**矩阵displayNameInput字段失去焦点 */
197
+ MatrixFieldDisplayNameInputBlur(event) {
198
+ let value = event.target.value;
199
+ let pinyin = this._DfApiService.chineseToPinyin(value);
200
+ let FieldnameInput = this.FieldnameInput;
201
+ if (FieldnameInput.value)
202
+ return;
203
+ FieldnameInput.patchValue(pinyin);
204
+ }
205
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MatrixConfigComponent, deps: [{ token: i1.FormBuilder }, { token: i2.DfApiService }], target: i0.ɵɵFactoryTarget.Component });
206
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MatrixConfigComponent, selector: "df-matrix-config", inputs: { type: "type", Entity: "Entity", selected: "selected" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }, { propertyName: "matrixModalModalSubmit", first: true, predicate: ["matrixModalModalSubmit"], descendants: true }], ngImport: i0, template: "<form [formGroup]=\"_Entity\">\n <div formGroupName=\"formConfiguration\">\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'Cms::::FormControl:Matrix' | abpLocalization}}</label>\n <div class=\"row\">\n <div class=\"col-md-3\">\n <div class=\"list-group\">\n <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n aria-current=\"true\">\n {{'Cms::MatrixBlockType' | abpLocalization}}\n <button class=\"btn btn-light btn-sm p-0\" (click.stop)=\"addMatrixBlockType()\">\n <i class=\"fas fa-plus-circle p-1\"></i>\n </button>\n </li>\n <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n <button type=\"button\" (click.stop)=\"selectMatrixBlockChange(i)\"\n class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action \"\n [class.active]=\"i===selectMatrixBlockIndex\">\n <div>\n <div>{{item.value.displayName}}</div>\n <div>{{item.value.name}}</div>\n </div>\n <div ngbDropdown class=\"d-inline-block\">\n <button type=\"button\" class=\"btn btn-light btn-sm\" id=\"dropdownBasic1\"\n style=\"z-index: 8;\" ngbDropdownToggle></button>\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"z-index: 9;\">\n <button ngbDropdownItem\n (click.stop)=\"EditMatrixBlock(item.value)\">{{'AbpUi::Edit' | abpLocalization}}</button>\n <button ngbDropdownItem\n (click.stop)=\"DeleteMatrixBlock(i)\">{{'AbpUi::Delete' | abpLocalization}}</button>\n </div>\n </div>\n </button>\n </ng-container>\n </div>\n </div>\n <div class=\"col-md-3\">\n <div class=\"list-group\" *ngIf=\"MatrixBlockTypes?.controls.length>0\">\n <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n aria-current=\"true\">\n {{'Cms::Fields' | abpLocalization}}\n <button class=\"btn btn-light btn-sm p-0\" (click.stop)=\"addMatrixField()\">\n <i class=\"fas fa-plus-circle p-1\"></i>\n </button>\n </li>\n <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n <ng-container *ngIf=\"i === selectMatrixBlockIndex\">\n <ng-container *ngFor=\"let el of item.controls['fields'].controls;let fi =index\">\n <button type=\"button\" (click.stop)=\"selectMatrixFieldChange(i,fi)\"\n class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action \"\n [class.active]=\"fi===selectMatrixFieldIndex\">\n <div>\n <div>{{el.value.displayName}}</div>\n <div>{{el.value.name}}</div>\n </div>\n <button type=\"button\"\n (click.stop)=\"deleteMatrixField(item.controls['fields'],fi)\"\n class=\"btn btn-sm btn-li\">{{'AbpUi::Delete' | abpLocalization}}</button>\n </button>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n <div class=\"col-md-6\" formArrayName=\"MatrixBlockTypes\">\n <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n <div [formGroupName]=\"i\" [hidden]=\"i !== selectMatrixBlockIndex\">\n <div formArrayName=\"fields\">\n <ng-container *ngFor=\"let item of item.controls['fields'].controls;let fi =index\">\n <div [formGroupName]=\"fi\" [hidden]=\"fi !== selectMatrixFieldIndex\">\n <div class=\"mb-2\">\n <label class=\"form-label\"\n for=\"displayName\">{{'Cms::DisplayName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n (blur)=\"MatrixFieldDisplayNameInputBlur($event)\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\"\n for=\"name\">{{'DigniteAbpForms::FieldName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n <div class=\"form-text\">\n {{'DigniteAbpForms::FieldNameHelpText' | abpLocalization}}</div>\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\"\n 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\"\n for=\"formControlName\">{{'Cms::FieldType' | abpLocalization}}</label>\n <select class=\"form-select\" formControlName=\"formControlName\">\n <ng-container *ngFor=\"let item of _FieldControlGroup;let i =index\">\n <option [value]=\"item.name\">{{item.displayName}}</option>\n </ng-container>\n </select>\n </div>\n <ng-container *ngIf=\"item.value.formControlName&&item\">\n <df-dynamic [type]=\"item.value.formControlName\" [entity]=\"item\"\n [selected]=\"_selected?_selected['formConfiguration']['MatrixBlockTypes'][i]['fields'][fi]:''\"></df-dynamic>\n </ng-container>\n\n\n </div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </div>\n\n </div>\n </div>\n <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n #submitclick></button>\n </div>\n</form>\n\n\n\n<abp-modal [(visible)]=\"matrixModalOpen\" [busy]=\"modalBusy\" (visibleChange)=\"matrixModalVisibleChange($event)\" >\n <ng-template #abpHeader>\n <h3>{{isMatrixEdit?('AbpUi::Edit' | abpLocalization):('Cms::New' | abpLocalization)}}</h3>\n </ng-template>\n <ng-template #abpBody>\n <ng-template #loaderRef>\n <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n </ng-template>\n <ng-container *ngIf=\"matrixModalForm; else loaderRef\">\n <form class=\"sites-modal-form\" #myForm=\"ngForm\" [formGroup]=\"matrixModalForm\"\n (ngSubmit)=\"createOrEditSave()\">\n <button type=\"submit\" #matrixModalModalSubmit style=\"display: none\"></button>\n <div class=\"mb-2\">\n <label class=\"form-label\" for=\"displayName\">{{'Cms::DisplayName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n (blur)=\"displayNameInputBlur($event)\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\" for=\"name\">{{'Cms::Name' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n </div>\n </form>\n </ng-container>\n </ng-template>\n <ng-template #abpFooter>\n <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n <abp-button iconClass=\"fa fa-check\"\n (click)=\"matrixModalModalSubmit.nativeElement.click()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n </ng-template>\n</abp-modal>", styles: [""], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { 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: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i1.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "directive", type: i4.FormSubmitDirective, selector: "form[ngSubmit][formGroup]", inputs: ["debounce", "notValidateOnSubmit", "markAsDirtyWhenSubmit"], outputs: ["ngSubmit"] }, { kind: "directive", type: i4.InitDirective, selector: "[abpInit]", outputs: ["abpInit"] }, { kind: "directive", type: i4.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "directive", type: i5.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i5.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i6.ButtonComponent, selector: "abp-button", inputs: ["buttonId", "buttonClass", "buttonType", "formName", "iconClass", "loading", "disabled", "attributes"], outputs: ["click", "focus", "blur", "abpClick", "abpFocus", "abpBlur"] }, { kind: "component", type: i6.ModalComponent, selector: "abp-modal", inputs: ["visible", "busy", "options", "suppressUnsavedChangesWarning"], outputs: ["visibleChange", "init", "appear", "disappear"] }, { kind: "directive", type: i6.ModalCloseDirective, selector: "[abpClose]" }, { kind: "directive", type: i7.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i7.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i7.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "directive", type: i7.NgbDropdownItem, selector: "[ngbDropdownItem]", inputs: ["disabled"] }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }] });
207
+ }
208
+ export { MatrixConfigComponent };
209
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MatrixConfigComponent, decorators: [{
210
+ type: Component,
211
+ args: [{ selector: 'df-matrix-config', template: "<form [formGroup]=\"_Entity\">\n <div formGroupName=\"formConfiguration\">\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'Cms::::FormControl:Matrix' | abpLocalization}}</label>\n <div class=\"row\">\n <div class=\"col-md-3\">\n <div class=\"list-group\">\n <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n aria-current=\"true\">\n {{'Cms::MatrixBlockType' | abpLocalization}}\n <button class=\"btn btn-light btn-sm p-0\" (click.stop)=\"addMatrixBlockType()\">\n <i class=\"fas fa-plus-circle p-1\"></i>\n </button>\n </li>\n <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n <button type=\"button\" (click.stop)=\"selectMatrixBlockChange(i)\"\n class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action \"\n [class.active]=\"i===selectMatrixBlockIndex\">\n <div>\n <div>{{item.value.displayName}}</div>\n <div>{{item.value.name}}</div>\n </div>\n <div ngbDropdown class=\"d-inline-block\">\n <button type=\"button\" class=\"btn btn-light btn-sm\" id=\"dropdownBasic1\"\n style=\"z-index: 8;\" ngbDropdownToggle></button>\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"z-index: 9;\">\n <button ngbDropdownItem\n (click.stop)=\"EditMatrixBlock(item.value)\">{{'AbpUi::Edit' | abpLocalization}}</button>\n <button ngbDropdownItem\n (click.stop)=\"DeleteMatrixBlock(i)\">{{'AbpUi::Delete' | abpLocalization}}</button>\n </div>\n </div>\n </button>\n </ng-container>\n </div>\n </div>\n <div class=\"col-md-3\">\n <div class=\"list-group\" *ngIf=\"MatrixBlockTypes?.controls.length>0\">\n <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n aria-current=\"true\">\n {{'Cms::Fields' | abpLocalization}}\n <button class=\"btn btn-light btn-sm p-0\" (click.stop)=\"addMatrixField()\">\n <i class=\"fas fa-plus-circle p-1\"></i>\n </button>\n </li>\n <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n <ng-container *ngIf=\"i === selectMatrixBlockIndex\">\n <ng-container *ngFor=\"let el of item.controls['fields'].controls;let fi =index\">\n <button type=\"button\" (click.stop)=\"selectMatrixFieldChange(i,fi)\"\n class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action \"\n [class.active]=\"fi===selectMatrixFieldIndex\">\n <div>\n <div>{{el.value.displayName}}</div>\n <div>{{el.value.name}}</div>\n </div>\n <button type=\"button\"\n (click.stop)=\"deleteMatrixField(item.controls['fields'],fi)\"\n class=\"btn btn-sm btn-li\">{{'AbpUi::Delete' | abpLocalization}}</button>\n </button>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n <div class=\"col-md-6\" formArrayName=\"MatrixBlockTypes\">\n <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n <div [formGroupName]=\"i\" [hidden]=\"i !== selectMatrixBlockIndex\">\n <div formArrayName=\"fields\">\n <ng-container *ngFor=\"let item of item.controls['fields'].controls;let fi =index\">\n <div [formGroupName]=\"fi\" [hidden]=\"fi !== selectMatrixFieldIndex\">\n <div class=\"mb-2\">\n <label class=\"form-label\"\n for=\"displayName\">{{'Cms::DisplayName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n (blur)=\"MatrixFieldDisplayNameInputBlur($event)\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\"\n for=\"name\">{{'DigniteAbpForms::FieldName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n <div class=\"form-text\">\n {{'DigniteAbpForms::FieldNameHelpText' | abpLocalization}}</div>\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\"\n 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\"\n for=\"formControlName\">{{'Cms::FieldType' | abpLocalization}}</label>\n <select class=\"form-select\" formControlName=\"formControlName\">\n <ng-container *ngFor=\"let item of _FieldControlGroup;let i =index\">\n <option [value]=\"item.name\">{{item.displayName}}</option>\n </ng-container>\n </select>\n </div>\n <ng-container *ngIf=\"item.value.formControlName&&item\">\n <df-dynamic [type]=\"item.value.formControlName\" [entity]=\"item\"\n [selected]=\"_selected?_selected['formConfiguration']['MatrixBlockTypes'][i]['fields'][fi]:''\"></df-dynamic>\n </ng-container>\n\n\n </div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </div>\n\n </div>\n </div>\n <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n #submitclick></button>\n </div>\n</form>\n\n\n\n<abp-modal [(visible)]=\"matrixModalOpen\" [busy]=\"modalBusy\" (visibleChange)=\"matrixModalVisibleChange($event)\" >\n <ng-template #abpHeader>\n <h3>{{isMatrixEdit?('AbpUi::Edit' | abpLocalization):('Cms::New' | abpLocalization)}}</h3>\n </ng-template>\n <ng-template #abpBody>\n <ng-template #loaderRef>\n <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n </ng-template>\n <ng-container *ngIf=\"matrixModalForm; else loaderRef\">\n <form class=\"sites-modal-form\" #myForm=\"ngForm\" [formGroup]=\"matrixModalForm\"\n (ngSubmit)=\"createOrEditSave()\">\n <button type=\"submit\" #matrixModalModalSubmit style=\"display: none\"></button>\n <div class=\"mb-2\">\n <label class=\"form-label\" for=\"displayName\">{{'Cms::DisplayName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n (blur)=\"displayNameInputBlur($event)\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\" for=\"name\">{{'Cms::Name' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n </div>\n </form>\n </ng-container>\n </ng-template>\n <ng-template #abpFooter>\n <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n <abp-button iconClass=\"fa fa-check\"\n (click)=\"matrixModalModalSubmit.nativeElement.click()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n </ng-template>\n</abp-modal>" }]
212
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.DfApiService }]; }, propDecorators: { type: [{
213
+ type: Input
214
+ }], Entity: [{
215
+ type: Input
216
+ }], selected: [{
217
+ type: Input
218
+ }], submitclick: [{
219
+ type: ViewChild,
220
+ args: ['submitclick', { static: true }]
221
+ }], matrixModalModalSubmit: [{
222
+ type: ViewChild,
223
+ args: ['matrixModalModalSubmit', { static: false }]
224
+ }] } });
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrix-config.component.js","sourceRoot":"","sources":["../../../../../../../projects/dynamic-form/src/lib/components/from/matrix/matrix-config.component.ts","../../../../../../../projects/dynamic-form/src/lib/components/from/matrix/matrix-config.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Inject, Input, ViewChild } from '@angular/core';\nimport { FormArray, FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { MatrixConfig, MatrixItemConfig } from './matrix-config';\nimport { DfApiService, } from '../../../services';\nimport { getExcludeAssignControl } from '../form-control-group';\n\n@Component({\n  selector: 'df-matrix-config',\n  templateUrl: './matrix-config.component.html',\n  styleUrls: ['./matrix-config.component.scss']\n})\nexport class MatrixConfigComponent {\n\n  constructor(\n    private fb: FormBuilder,\n    private _DfApiService: DfApiService,\n  ) {}\n\n  /**表单控件组 */\n  _FieldControlGroup: any[]\n  /**表单控件类型 */\n  _type: any\n  @Input()\n  public set type(v: any) {\n    this._type = v\n    this.dataLoaded()\n  }\n  /**表单实体 */\n  _Entity: FormGroup | undefined\n  @Input()\n  public set Entity(v: FormGroup) {\n    this._Entity = v;\n    this.dataLoaded()\n  }\n\n\n  /**选择的表单信息 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    \n    if (v) {\n      this._selected = v\n      this.dataLoaded()\n    }\n  }\n\n\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  async dataLoaded() {\n    if (this._Entity && this._type) {\n      await this.AfterInit()\n      this.submitclick.nativeElement.click();\n    }\n  }\n\n  AfterInit() {\n    return new Promise(async (resolve, rejects) => {\n      this._FieldControlGroup = getExcludeAssignControl(this._type)\n      // this._FieldControlGroup = getExcludeAssignControl(this._type)\n      this._Entity.setControl('formConfiguration', this.fb.group(new MatrixConfig()))\n      await this.setSelectValue()\n      this.formConfiguration.patchValue(this._selected.formConfiguration)\n      resolve(true)\n    })\n  }\n\n  setSelectValue() {\n    return new Promise((resolve, rejects) => {\n      if (this._selected && this._selected.formControlName == this._type) {\n        this._selected.formConfiguration['MatrixBlockTypes'].forEach(((el, index) => {\n          this.addMatrixBlockTypeItem(el)\n          el.fields.forEach((elf, indexf) => {\n            this.addMatrixFieldItem(elf, index)\n          })\n        }))\n        resolve(true)\n      }\n    })\n  }\n\n  /**获取表单配置 */\n  get formConfiguration() {\n    return this._Entity.get('formConfiguration') as FormGroup\n  }\n\n  /**获取表单配置下的矩阵块表单数组 */\n  get MatrixBlockTypes() {\n    return this.formConfiguration.controls['MatrixBlockTypes'] as FormArray\n  }\n\n\n  /**模态框-状态 */\n  matrixModalOpen: boolean = false\n  /**模态框-是否正在编辑 */\n  isMatrixModalEdit: any = false\n\n  /**模态框-用于确定模态的繁忙状态是否为真 */\n  modalBusy: boolean = false\n\n  /**模态框-表单 */\n  matrixModalForm: FormGroup | undefined;\n\n  /**表单控件模板-用于在form外提交submit */\n  @ViewChild('matrixModalModalSubmit', { static: false }) matrixModalModalSubmit: ElementRef;\n\n  /**矩阵块-选择的下标 */\n  selectMatrixBlockIndex: any = 0\n\n  /**矩阵块-选择的矩阵下字段的下标 */\n  selectMatrixFieldIndex: any = 0\n\n  /**模态框-状态改变 */\n  matrixModalVisibleChange(event) {\n    if (!event) {\n      this.isMatrixModalEdit = false\n      this.matrixModalForm = undefined\n      return\n    }\n  }\n\n\n  /**矩阵块--新增-打开模态框 */\n  addMatrixBlockType() {\n    this.matrixModalForm = this.fb.group(new MatrixItemConfig())\n    this.matrixModalOpen = true\n  }\n\n\n\n  /**模态框--矩阵表单保存提交 */\n  createOrEditSave() {\n    let input = this.matrixModalForm.value\n    if (!this.matrixModalForm.valid) return\n    if (this.isMatrixModalEdit) {\n      let MatrixBlockTypesItem = this.MatrixBlockTypes.at(this.selectMatrixBlockIndex) as FormGroup\n      MatrixBlockTypesItem.patchValue({\n        ...input\n      })\n    } else {\n      this.addMatrixBlockTypeItem(input)\n    }\n    this.matrixModalOpen = false\n  }\n  /**新增矩阵块-向数组表单中增加项 */\n  addMatrixBlockTypeItem(input) {\n    this.MatrixBlockTypes.push(new FormGroup({\n      displayName: new FormControl(input.displayName, Validators.required),\n      name: new FormControl(input.name, Validators.required),\n      fields: new FormArray([])\n    }))\n  }\n  /**编辑矩阵块 */\n  EditMatrixBlock(input) {\n    this.matrixModalForm = this.fb.group(new MatrixItemConfig())\n    this.matrixModalForm.patchValue({\n      ...input\n    })\n    this.matrixModalOpen = true\n    this.isMatrixModalEdit = true\n  }\n\n  /**删除矩阵块 */\n  DeleteMatrixBlock(index) {\n    this.MatrixBlockTypes.removeAt(index)\n  }\n\n  /**矩阵块-选择 */\n  selectMatrixBlockChange(index) {\n    this.selectMatrixBlockIndex = index\n  }\n\n  /**矩阵字段-新增 */\n  addMatrixField() {\n    this.addMatrixFieldItem('', this.selectMatrixBlockIndex)\n  }\n  /**矩阵字段-新增矩阵字段项 */\n  addMatrixFieldItem(input: any = '', selectMatrixBlockIndex) {\n    /**矩阵下标的矩阵项Form */\n    let MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(selectMatrixBlockIndex) as FormGroup\n    let MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields') as FormArray\n    MatrixFieldItemForm.push(this.fb.group({\n      /**字段名称 Display name of this field */\n      displayName: [input.displayName, [Validators.required]],\n      /**字段唯一名称 Unique Name*/\n      name: [input.name, [Validators.required]],\n      /**描述 说明 */\n      description: [input.description, []],\n      /**FieldType字段类型 表单控件名称 */\n      formControlName: [input.formControlName || 'TextEdit', [Validators.required]],\n       //动态表单配置\n      formConfiguration: new FormGroup({}),\n    }))\n\n  }\n\n   /**删除矩阵字段项 */\n  deleteMatrixField(MatrixFieldForm, index) {\n    MatrixFieldForm.removeAt(index)\n    this.selectMatrixFieldIndex = 0\n  }\n\n  /**矩阵字段-选择 */\n  selectMatrixFieldChange(MatrixBlockIndex, MatrixFieldIndex) {\n    this.selectMatrixFieldIndex = MatrixFieldIndex\n  }\n\n  get nameInput() {\n    return this.matrixModalForm?.get('name')\n  }\n  get FieldnameInput() {\n    let MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(this.selectMatrixBlockIndex) as FormGroup\n    let MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields') as FormArray\n    return MatrixFieldItemForm.at(this.selectMatrixFieldIndex).get('name')\n  }\n\n  /**矩阵displayNameInput字段失去焦点 */\n  displayNameInputBlur(event) {\n    let value = event.target.value\n    let pinyin = this._DfApiService.chineseToPinyin(value)\n    let nameInput = this.nameInput\n    if (nameInput.value) return\n    nameInput.patchValue(pinyin)\n  }\n  /**矩阵displayNameInput字段失去焦点 */\n  MatrixFieldDisplayNameInputBlur(event) {\n    let value = event.target.value\n    let pinyin = this._DfApiService.chineseToPinyin(value)\n    let FieldnameInput = this.FieldnameInput\n    if (FieldnameInput.value) return\n    FieldnameInput.patchValue(pinyin)\n  }\n}\n","<form [formGroup]=\"_Entity\">\n    <div formGroupName=\"formConfiguration\">\n        <div class=\"mb-2\">\n            <label class=\"form-label\">{{'Cms::::FormControl:Matrix' | abpLocalization}}</label>\n            <div class=\"row\">\n                <div class=\"col-md-3\">\n                    <div class=\"list-group\">\n                        <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n                            aria-current=\"true\">\n                            {{'Cms::MatrixBlockType' | abpLocalization}}\n                            <button class=\"btn btn-light btn-sm p-0\" (click.stop)=\"addMatrixBlockType()\">\n                                <i class=\"fas fa-plus-circle p-1\"></i>\n                            </button>\n                        </li>\n                        <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                            <button type=\"button\" (click.stop)=\"selectMatrixBlockChange(i)\"\n                                class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action \"\n                                [class.active]=\"i===selectMatrixBlockIndex\">\n                                <div>\n                                    <div>{{item.value.displayName}}</div>\n                                    <div>{{item.value.name}}</div>\n                                </div>\n                                <div ngbDropdown class=\"d-inline-block\">\n                                    <button type=\"button\" class=\"btn btn-light btn-sm\" id=\"dropdownBasic1\"\n                                        style=\"z-index: 8;\" ngbDropdownToggle></button>\n                                    <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"z-index: 9;\">\n                                        <button ngbDropdownItem\n                                            (click.stop)=\"EditMatrixBlock(item.value)\">{{'AbpUi::Edit' | abpLocalization}}</button>\n                                        <button ngbDropdownItem\n                                            (click.stop)=\"DeleteMatrixBlock(i)\">{{'AbpUi::Delete' | abpLocalization}}</button>\n                                    </div>\n                                </div>\n                            </button>\n                        </ng-container>\n                    </div>\n                </div>\n                <div class=\"col-md-3\">\n                    <div class=\"list-group\" *ngIf=\"MatrixBlockTypes?.controls.length>0\">\n                        <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n                            aria-current=\"true\">\n                            {{'Cms::Fields' | abpLocalization}}\n                            <button class=\"btn btn-light btn-sm p-0\" (click.stop)=\"addMatrixField()\">\n                                <i class=\"fas fa-plus-circle p-1\"></i>\n                            </button>\n                        </li>\n                        <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                            <ng-container *ngIf=\"i === selectMatrixBlockIndex\">\n                                <ng-container *ngFor=\"let el of item.controls['fields'].controls;let fi =index\">\n                                    <button type=\"button\" (click.stop)=\"selectMatrixFieldChange(i,fi)\"\n                                        class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action \"\n                                        [class.active]=\"fi===selectMatrixFieldIndex\">\n                                        <div>\n                                            <div>{{el.value.displayName}}</div>\n                                            <div>{{el.value.name}}</div>\n                                        </div>\n                                        <button type=\"button\"\n                                            (click.stop)=\"deleteMatrixField(item.controls['fields'],fi)\"\n                                            class=\"btn btn-sm btn-li\">{{'AbpUi::Delete' | abpLocalization}}</button>\n                                    </button>\n                                </ng-container>\n                            </ng-container>\n                        </ng-container>\n                    </div>\n                </div>\n                <div class=\"col-md-6\" formArrayName=\"MatrixBlockTypes\">\n                    <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                        <div [formGroupName]=\"i\" [hidden]=\"i !== selectMatrixBlockIndex\">\n                            <div formArrayName=\"fields\">\n                                <ng-container *ngFor=\"let item of item.controls['fields'].controls;let fi =index\">\n                                    <div [formGroupName]=\"fi\" [hidden]=\"fi !== selectMatrixFieldIndex\">\n                                        <div class=\"mb-2\">\n                                            <label class=\"form-label\"\n                                                for=\"displayName\">{{'Cms::DisplayName' | abpLocalization}}</label>\n                                            <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n                                                (blur)=\"MatrixFieldDisplayNameInputBlur($event)\">\n                                        </div>\n                                        <div class=\"mb-2\">\n                                            <label class=\"form-label\"\n                                                for=\"name\">{{'DigniteAbpForms::FieldName' | abpLocalization}}</label>\n                                            <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n                                            <div class=\"form-text\">\n                                                {{'DigniteAbpForms::FieldNameHelpText' | abpLocalization}}</div>\n                                        </div>\n                                        <div class=\"mb-2\">\n                                            <label class=\"form-label\"\n                                                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\"\n                                                for=\"formControlName\">{{'Cms::FieldType' | abpLocalization}}</label>\n                                            <select class=\"form-select\" formControlName=\"formControlName\">\n                                                <ng-container *ngFor=\"let item of _FieldControlGroup;let i =index\">\n                                                    <option [value]=\"item.name\">{{item.displayName}}</option>\n                                                </ng-container>\n                                            </select>\n                                        </div>\n                                        <ng-container *ngIf=\"item.value.formControlName&&item\">\n                                            <df-dynamic [type]=\"item.value.formControlName\" [entity]=\"item\"\n                                                [selected]=\"_selected?_selected['formConfiguration']['MatrixBlockTypes'][i]['fields'][fi]:''\"></df-dynamic>\n                                        </ng-container>\n\n\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </div>\n                    </ng-container>\n                </div>\n\n            </div>\n        </div>\n        <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n            #submitclick></button>\n    </div>\n</form>\n\n\n\n<abp-modal [(visible)]=\"matrixModalOpen\" [busy]=\"modalBusy\" (visibleChange)=\"matrixModalVisibleChange($event)\" >\n    <ng-template #abpHeader>\n        <h3>{{isMatrixEdit?('AbpUi::Edit' | abpLocalization):('Cms::New' | abpLocalization)}}</h3>\n    </ng-template>\n    <ng-template #abpBody>\n        <ng-template #loaderRef>\n            <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n        </ng-template>\n        <ng-container *ngIf=\"matrixModalForm; else loaderRef\">\n            <form class=\"sites-modal-form\" #myForm=\"ngForm\" [formGroup]=\"matrixModalForm\"\n                (ngSubmit)=\"createOrEditSave()\">\n                <button type=\"submit\" #matrixModalModalSubmit style=\"display: none\"></button>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\" for=\"displayName\">{{'Cms::DisplayName' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n                        (blur)=\"displayNameInputBlur($event)\">\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\" for=\"name\">{{'Cms::Name' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n                </div>\n            </form>\n        </ng-container>\n    </ng-template>\n    <ng-template #abpFooter>\n        <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n        <abp-button iconClass=\"fa fa-check\"\n            (click)=\"matrixModalModalSubmit.nativeElement.click()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n    </ng-template>\n</abp-modal>"]}
@@ -0,0 +1,50 @@
1
+ import { FormArray, FormGroup, Validators } from "@angular/forms";
2
+ export class MatrixConfig {
3
+ // 矩阵类型
4
+ 'MatrixBlockTypes' = new FormArray([]);
5
+ constructor(data) {
6
+ if (data) {
7
+ for (const key in data) {
8
+ if (data.hasOwnProperty(key)) {
9
+ this[key] = data[key];
10
+ }
11
+ }
12
+ }
13
+ }
14
+ }
15
+ export class MatrixItemConfig {
16
+ displayName = ['', [Validators.required]];
17
+ /**字段名字 */
18
+ name = ['', [Validators.required]];
19
+ constructor(data) {
20
+ if (data) {
21
+ for (const key in data) {
22
+ if (data.hasOwnProperty(key)) {
23
+ this[key] = data[key];
24
+ }
25
+ }
26
+ }
27
+ }
28
+ }
29
+ export class matrixFieldInputBase {
30
+ /**字段名称 Display name of this field */
31
+ displayName = ['', [Validators.required]];
32
+ /**字段唯一名称 Unique Name*/
33
+ name = ['', [Validators.required]];
34
+ /**描述 说明 */
35
+ description = ['', []];
36
+ /**FieldType字段类型 表单控件名称 */
37
+ formControlName = ['TextEdit', [Validators.required]];
38
+ /**动态表单配置 */
39
+ formConfiguration = new FormGroup({});
40
+ constructor(data) {
41
+ if (data) {
42
+ for (const key in data) {
43
+ if (data.hasOwnProperty(key)) {
44
+ this[key] = data[key];
45
+ }
46
+ }
47
+ }
48
+ }
49
+ }
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0cml4LWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2R5bmFtaWMtZm9ybS9zcmMvbGliL2NvbXBvbmVudHMvZnJvbS9tYXRyaXgvbWF0cml4LWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFlLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUUvRSxNQUFNLE9BQU8sWUFBWTtJQUNyQixPQUFPO0lBQ1Asa0JBQWtCLEdBQVEsSUFBSSxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUE7SUFFM0MsWUFBWSxJQUFtQjtRQUMzQixJQUFJLElBQUksRUFBRTtZQUNOLEtBQUssTUFBTSxHQUFHLElBQUksSUFBSSxFQUFFO2dCQUNwQixJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUU7b0JBQzFCLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7aUJBQ3pCO2FBQ0o7U0FDSjtJQUNMLENBQUM7Q0FDSjtBQUNELE1BQU0sT0FBTyxnQkFBZ0I7SUFFekIsV0FBVyxHQUFRLENBQUMsRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDL0MsVUFBVTtJQUNWLElBQUksR0FBUSxDQUFDLEVBQUUsRUFBRSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0lBRXhDLFlBQVksSUFBbUI7UUFDM0IsSUFBSSxJQUFJLEVBQUU7WUFDTixLQUFLLE1BQU0sR0FBRyxJQUFJLElBQUksRUFBRTtnQkFDcEIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxFQUFFO29CQUMxQixJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2lCQUN6QjthQUNKO1NBQ0o7SUFHTCxDQUFDO0NBQ0o7QUFJRCxNQUFNLE9BQU8sb0JBQW9CO0lBRzdCLHFDQUFxQztJQUNyQyxXQUFXLEdBQVEsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUMvQyx1QkFBdUI7SUFDdkIsSUFBSSxHQUFRLENBQUMsRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDeEMsV0FBVztJQUNYLFdBQVcsR0FBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM1QiwwQkFBMEI7SUFDMUIsZUFBZSxHQUFRLENBQUMsVUFBVSxFQUFFLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDNUQsWUFBWTtJQUNYLGlCQUFpQixHQUEwQixJQUFJLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQTtJQUc1RCxZQUFZLElBQTJCO1FBQ25DLElBQUksSUFBSSxFQUFFO1lBQ04sS0FBSyxNQUFNLEdBQUcsSUFBSSxJQUFJLEVBQUU7Z0JBQ3BCLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRTtvQkFDMUIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztpQkFDekI7YUFDSjtTQUNKO0lBRUwsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybUFycmF5LCBGb3JtQ29udHJvbCwgRm9ybUdyb3VwLCBWYWxpZGF0b3JzIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgTWF0cml4Q29uZmlnIHtcclxuICAgIC8vIOefqemYteexu+Wei1xyXG4gICAgJ01hdHJpeEJsb2NrVHlwZXMnOiBhbnkgPSBuZXcgRm9ybUFycmF5KFtdKVxyXG5cclxuICAgIGNvbnN0cnVjdG9yKGRhdGE/OiBNYXRyaXhDb25maWcpIHtcclxuICAgICAgICBpZiAoZGF0YSkge1xyXG4gICAgICAgICAgICBmb3IgKGNvbnN0IGtleSBpbiBkYXRhKSB7XHJcbiAgICAgICAgICAgICAgICBpZiAoZGF0YS5oYXNPd25Qcm9wZXJ0eShrZXkpKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpc1trZXldID0gZGF0YVtrZXldO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbmV4cG9ydCBjbGFzcyBNYXRyaXhJdGVtQ29uZmlnIHtcclxuICBcclxuICAgIGRpc3BsYXlOYW1lOiBhbnkgPSBbJycsIFtWYWxpZGF0b3JzLnJlcXVpcmVkXV07XHJcbiAgICAvKirlrZfmrrXlkI3lrZcgKi9cclxuICAgIG5hbWU6IGFueSA9IFsnJywgW1ZhbGlkYXRvcnMucmVxdWlyZWRdXTtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihkYXRhPzogTWF0cml4Q29uZmlnKSB7XHJcbiAgICAgICAgaWYgKGRhdGEpIHtcclxuICAgICAgICAgICAgZm9yIChjb25zdCBrZXkgaW4gZGF0YSkge1xyXG4gICAgICAgICAgICAgICAgaWYgKGRhdGEuaGFzT3duUHJvcGVydHkoa2V5KSkge1xyXG4gICAgICAgICAgICAgICAgICAgIHRoaXNba2V5XSA9IGRhdGFba2V5XTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuXHJcblxyXG4gICAgfVxyXG59XHJcblxyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBtYXRyaXhGaWVsZElucHV0QmFzZSB7XHJcblxyXG5cclxuICAgIC8qKuWtl+auteWQjeensCBEaXNwbGF5IG5hbWUgb2YgdGhpcyBmaWVsZCAqL1xyXG4gICAgZGlzcGxheU5hbWU6IGFueSA9IFsnJywgW1ZhbGlkYXRvcnMucmVxdWlyZWRdXTtcclxuICAgIC8qKuWtl+auteWUr+S4gOWQjeensCBVbmlxdWUgTmFtZSovXHJcbiAgICBuYW1lOiBhbnkgPSBbJycsIFtWYWxpZGF0b3JzLnJlcXVpcmVkXV07XHJcbiAgICAvKirmj4/ov7Ag6K+05piOICovXHJcbiAgICBkZXNjcmlwdGlvbjogYW55ID0gWycnLCBbXV07XHJcbiAgICAvKipGaWVsZFR5cGXlrZfmrrXnsbvlnosg6KGo5Y2V5o6n5Lu25ZCN56ewICovXHJcbiAgICBmb3JtQ29udHJvbE5hbWU6IGFueSA9IFsnVGV4dEVkaXQnLCBbVmFsaWRhdG9ycy5yZXF1aXJlZF1dO1xyXG4gICAvKirliqjmgIHooajljZXphY3nva4gKi9cclxuICAgIGZvcm1Db25maWd1cmF0aW9uOiBGb3JtR3JvdXAgfCB1bmRlZmluZWQgPSBuZXcgRm9ybUdyb3VwKHt9KVxyXG5cclxuXHJcbiAgICBjb25zdHJ1Y3RvcihkYXRhPzogbWF0cml4RmllbGRJbnB1dEJhc2UpIHtcclxuICAgICAgICBpZiAoZGF0YSkge1xyXG4gICAgICAgICAgICBmb3IgKGNvbnN0IGtleSBpbiBkYXRhKSB7XHJcbiAgICAgICAgICAgICAgICBpZiAoZGF0YS5oYXNPd25Qcm9wZXJ0eShrZXkpKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpc1trZXldID0gZGF0YVtrZXldO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG5cclxuICAgIH1cclxufSJdfQ==