@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.
- package/esm2022/lib/components/dynamic/dynamic.component.mjs +3 -3
- package/esm2022/lib/components/from/form-control-group.mjs +20 -3
- package/esm2022/lib/components/from/index.mjs +3 -3
- package/esm2022/lib/components/from/matrix/index.mjs +4 -0
- package/esm2022/lib/components/from/matrix/matrix-config.component.mjs +225 -0
- package/esm2022/lib/components/from/matrix/matrix-config.mjs +50 -0
- package/esm2022/lib/components/from/matrix/matrix-control.component.mjs +110 -0
- package/esm2022/lib/components/from/select/select-config.component.mjs +1 -1
- package/esm2022/lib/components/from/table/index.mjs +4 -0
- package/esm2022/lib/components/from/table/table-config.component.mjs +171 -0
- package/esm2022/lib/components/from/table/table-config.mjs +38 -0
- package/esm2022/lib/components/from/table/table-control.component.mjs +112 -0
- package/esm2022/lib/dynamic-form.module.mjs +22 -6
- package/fesm2022/dignite-ng-expand.dynamic-form.mjs +715 -21
- package/fesm2022/dignite-ng-expand.dynamic-form.mjs.map +1 -1
- package/lib/components/dynamic/dynamic.component.d.ts +2 -2
- package/lib/components/from/form-control-group.d.ts +1 -1
- package/lib/components/from/index.d.ts +2 -0
- package/lib/components/from/matrix/index.d.ts +3 -0
- package/lib/components/from/matrix/matrix-config.component.d.ts +72 -0
- package/lib/components/from/matrix/matrix-config.d.ts +24 -0
- package/lib/components/from/matrix/matrix-control.component.d.ts +39 -0
- package/lib/components/from/table/index.d.ts +3 -0
- package/lib/components/from/table/table-config.component.d.ts +57 -0
- package/lib/components/from/table/table-config.d.ts +18 -0
- package/lib/components/from/table/table-control.component.d.ts +36 -0
- package/lib/dynamic-form.module.d.ts +11 -8
- 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,
|
|
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":"AAAA,OAAO,EAAC,SAAS,EAAU,KAAK,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAGrF,OAAO,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;;AAE5C,MAMa,gBAAgB;IAG3B,aAAa;IACb,SAAS,CAAK;IACd,IACW,QAAQ,CAAC,CAAM;QACxB,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,EAAE,CAAC;QAEzB,IAAG,CAAC;YAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;IAC1B,CAAC;IAGD,YAAY;IACZ,KAAK,CAAQ;IACb,IACW,IAAI,CAAC,CAAS;QACvB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAG,CAAC;YAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;IAC1B,CAAC;IAED,UAAU;IACV,OAAO,CAAuB;IAC9B,IACW,MAAM,CAAC,CAAM;QACtB,IAAG,CAAC,EAAE;YACJ,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;YAEjB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;SACnB;IACH,CAAC;IACD,QAAQ;IACR,QAAQ,CAAuB;IAC/B,IACW,OAAO,CAAC,CAAM;QACvB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;QAClB,IAAG,CAAC;YAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;IAC1B,CAAC;IAED,wBAAwB;IACxB,gBAAgB,CAAK;IACrB,IACW,eAAe,CAAC,CAAM;QAC/B,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;QAC1B,IAAG,CAAC;YAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;IAC1B,CAAC;IAED,YAAY;IACZ,OAAO,GAAQ,EAAE,CAAA;IACjB,IACW,MAAM,CAAC,CAAM;QACtB,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QACjB,IAAG,CAAC;YAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;IAC1B,CAAC;IAGD,qBAAqB;IACkD,cAAc,CAAmB;IAExG,mBAAmB;IACuD,iBAAiB,CAAmB;IAE9G,WAAW;IACX,kBAAkB,GAAkC,iBAAiB,CAAA;IAGrE,YAAY;IACZ,UAAU,CAAC,GAAG;QACZ,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,IAAI,CAAC,KAAK,EAAE;gBACd,IAAI,gBAAgB,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,CAAA;gBACjF,IAAI,CAAC,wBAAwB,CAAC,gBAAgB,CAAC,CAAA;aAChD;YACD,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACzC,cAAc;gBACd,IAAI,gBAAgB,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,CAAA;gBACzG,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,CAAC,CAAA;aAC1C;SACF;IACH,CAAC;IAID,gBAAgB;IAChB,wBAAwB,CAAC,gBAA8C;QACrE,aAAa;QACb,IAAI,CAAC,cAAc,EAAE,KAAK,EAAE,CAAC;QAC7B,IAAI,CAAC,gBAAgB,IAAI,CAAC,gBAAgB,CAAC,oBAAoB;YAAE,OAAM;QACvE,UAAU;QACV,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,eAAe,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAAC,CAAA,QAAQ;QACzG,iBAAiB;QACjB,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAA;QAC9B,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAA;QAClC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAA;IAC5B,CAAC;IAED,cAAc;IACd,kBAAkB,CAAC,gBAA8C;QAC/D,4BAA4B;QAC5B,aAAa;QACb,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,gBAAgB,IAAI,CAAC,gBAAgB,CAAC,cAAc;YAAE,OAAM;QACjE,UAAU;QACV,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,iBAAiB,EAAE,eAAe,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC,CAAA,QAAQ;QAEtG,qCAAqC;QACrC,iBAAiB;QACjB,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAA;QAC9B,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAA;QAC9B,QAAQ,CAAC,eAAe,GAAG,IAAI,CAAC,gBAAgB,CAAA;QAChD,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAA;QAClC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAA;IAClC,CAAC;wGAhHU,gBAAgB;4FAAhB,gBAAgB,+SAyDU,gBAAgB,+HAGb,gBAAgB,2CCvE1D,iFACwC;;SDU3B,gBAAgB;4FAAhB,gBAAgB;kBAN5B,SAAS;+BACE,YAAY,cACX,IAAI;8BAUJ,QAAQ;sBADlB,KAAK;gBAWK,IAAI;sBADd,KAAK;gBASK,MAAM;sBADhB,KAAK;gBAWK,OAAO;sBADjB,KAAK;gBASK,eAAe;sBADzB,KAAK;gBASK,MAAM;sBADhB,KAAK;gBAQiE,cAAc;sBAApF,SAAS;uBAAC,gBAAgB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,EAAE;gBAGK,iBAAiB;sBAA1F,SAAS;uBAAC,mBAAmB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,EAAE","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,
|
|
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
|
-
|
|
10
|
-
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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==
|