@dignite-ng/expand.dynamic-form 0.0.2
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/README.md +24 -0
- package/esm2022/dignite-ng-expand.dynamic-form.mjs +5 -0
- package/esm2022/lib/components/dynamic/dynamic.component.mjs +113 -0
- package/esm2022/lib/components/dynamic/index.mjs +2 -0
- package/esm2022/lib/components/from/ck-editor/ck-editor-config.component.mjs +65 -0
- package/esm2022/lib/components/from/ck-editor/ck-editor-config.mjs +18 -0
- package/esm2022/lib/components/from/ck-editor/ck-editor-control.component.mjs +139 -0
- package/esm2022/lib/components/from/ck-editor/ckEditorUpload.mjs +55 -0
- package/esm2022/lib/components/from/ck-editor/index.mjs +3 -0
- package/esm2022/lib/components/from/date-edit/date-edit-config.component.mjs +70 -0
- package/esm2022/lib/components/from/date-edit/date-edit-config.mjs +26 -0
- package/esm2022/lib/components/from/date-edit/date-edit-control.component.mjs +93 -0
- package/esm2022/lib/components/from/date-edit/index.mjs +3 -0
- package/esm2022/lib/components/from/file-explorer/file-explorer-config.component.mjs +68 -0
- package/esm2022/lib/components/from/file-explorer/file-explorer-config.mjs +18 -0
- package/esm2022/lib/components/from/file-explorer/file-explorer-control.component.mjs +102 -0
- package/esm2022/lib/components/from/file-explorer/index.mjs +3 -0
- package/esm2022/lib/components/from/form-control-group.mjs +79 -0
- package/esm2022/lib/components/from/index.mjs +11 -0
- package/esm2022/lib/components/from/numeric-edit/index.mjs +3 -0
- package/esm2022/lib/components/from/numeric-edit/numberic-edit-config.component.mjs +68 -0
- package/esm2022/lib/components/from/numeric-edit/numberic-edit-config.mjs +25 -0
- package/esm2022/lib/components/from/numeric-edit/numberic-edit-control.component.mjs +113 -0
- package/esm2022/lib/components/from/select/index.mjs +3 -0
- package/esm2022/lib/components/from/select/select-config.component.mjs +91 -0
- package/esm2022/lib/components/from/select/select-config.mjs +20 -0
- package/esm2022/lib/components/from/select/select-control.component.mjs +89 -0
- package/esm2022/lib/components/from/switch/index.mjs +3 -0
- package/esm2022/lib/components/from/switch/switch-config.component.mjs +68 -0
- package/esm2022/lib/components/from/switch/switch-config.mjs +15 -0
- package/esm2022/lib/components/from/switch/switch-control.component.mjs +77 -0
- package/esm2022/lib/components/from/text-edit/index.mjs +4 -0
- package/esm2022/lib/components/from/text-edit/text-edit-config.component.mjs +70 -0
- package/esm2022/lib/components/from/text-edit/text-edit-config.mjs +24 -0
- package/esm2022/lib/components/from/text-edit/text-edit.component.mjs +84 -0
- package/esm2022/lib/components/index.mjs +3 -0
- package/esm2022/lib/dynamic-form.module.mjs +107 -0
- package/esm2022/lib/enums/date-edit-interfaces.mjs +16 -0
- package/esm2022/lib/enums/index.mjs +3 -0
- package/esm2022/lib/enums/text-edit-mode.mjs +8 -0
- package/esm2022/lib/interfaces/form-config-interfaces.mjs +2 -0
- package/esm2022/lib/interfaces/index.mjs +2 -0
- package/esm2022/lib/proxy/dignite/file-explorer/directories/file-descriptor.service.mjs +48 -0
- package/esm2022/lib/proxy/dignite/file-explorer/directories/index.mjs +3 -0
- package/esm2022/lib/proxy/dignite/file-explorer/directories/models.mjs +2 -0
- package/esm2022/lib/proxy/dignite/file-explorer/files/file-descriptor.service.mjs +60 -0
- package/esm2022/lib/proxy/dignite/file-explorer/files/index.mjs +3 -0
- package/esm2022/lib/proxy/dignite/file-explorer/files/models.mjs +2 -0
- package/esm2022/lib/proxy/dignite/file-explorer/index.mjs +4 -0
- package/esm2022/lib/proxy/dignite/index.mjs +3 -0
- package/esm2022/lib/proxy/index.mjs +5 -0
- package/esm2022/lib/proxy/microsoft/asp-net-core/index.mjs +3 -0
- package/esm2022/lib/proxy/microsoft/asp-net-core/mvc/index.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/asp-net-core/mvc/models.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/extensions/index.mjs +3 -0
- package/esm2022/lib/proxy/microsoft/extensions/primitives/index.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/extensions/primitives/models.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/index.mjs +5 -0
- package/esm2022/lib/proxy/microsoft/net/http/headers/index.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/net/http/headers/models.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/net/http/index.mjs +3 -0
- package/esm2022/lib/proxy/microsoft/net/index.mjs +3 -0
- package/esm2022/lib/proxy/volo/abp/content/index.mjs +2 -0
- package/esm2022/lib/proxy/volo/abp/content/models.mjs +2 -0
- package/esm2022/lib/proxy/volo/abp/index.mjs +3 -0
- package/esm2022/lib/proxy/volo/index.mjs +3 -0
- package/esm2022/lib/services/df-api.service.mjs +82 -0
- package/esm2022/lib/services/index.mjs +2 -0
- package/esm2022/public-api.mjs +10 -0
- package/fesm2022/dignite-ng-expand.dynamic-form.mjs +1867 -0
- package/fesm2022/dignite-ng-expand.dynamic-form.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/dynamic/dynamic.component.d.ts +35 -0
- package/lib/components/dynamic/index.d.ts +1 -0
- package/lib/components/from/ck-editor/ck-editor-config.component.d.ts +21 -0
- package/lib/components/from/ck-editor/ck-editor-config.d.ts +7 -0
- package/lib/components/from/ck-editor/ck-editor-control.component.d.ts +51 -0
- package/lib/components/from/ck-editor/ckEditorUpload.d.ts +12 -0
- package/lib/components/from/ck-editor/index.d.ts +2 -0
- package/lib/components/from/date-edit/date-edit-config.component.d.ts +24 -0
- package/lib/components/from/date-edit/date-edit-config.d.ts +10 -0
- package/lib/components/from/date-edit/date-edit-control.component.d.ts +32 -0
- package/lib/components/from/date-edit/index.d.ts +2 -0
- package/lib/components/from/file-explorer/file-explorer-config.component.d.ts +22 -0
- package/lib/components/from/file-explorer/file-explorer-config.d.ts +7 -0
- package/lib/components/from/file-explorer/file-explorer-control.component.d.ts +34 -0
- package/lib/components/from/file-explorer/index.d.ts +2 -0
- package/lib/components/from/form-control-group.d.ts +7 -0
- package/lib/components/from/index.d.ts +8 -0
- package/lib/components/from/numeric-edit/index.d.ts +2 -0
- package/lib/components/from/numeric-edit/numberic-edit-config.component.d.ts +22 -0
- package/lib/components/from/numeric-edit/numberic-edit-config.d.ts +11 -0
- package/lib/components/from/numeric-edit/numberic-edit-control.component.d.ts +33 -0
- package/lib/components/from/select/index.d.ts +2 -0
- package/lib/components/from/select/select-config.component.d.ts +27 -0
- package/lib/components/from/select/select-config.d.ts +7 -0
- package/lib/components/from/select/select-control.component.d.ts +27 -0
- package/lib/components/from/switch/index.d.ts +2 -0
- package/lib/components/from/switch/switch-config.component.d.ts +22 -0
- package/lib/components/from/switch/switch-config.d.ts +5 -0
- package/lib/components/from/switch/switch-control.component.d.ts +26 -0
- package/lib/components/from/text-edit/index.d.ts +3 -0
- package/lib/components/from/text-edit/text-edit-config.component.d.ts +24 -0
- package/lib/components/from/text-edit/text-edit-config.d.ts +6 -0
- package/lib/components/from/text-edit/text-edit.component.d.ts +27 -0
- package/lib/components/index.d.ts +2 -0
- package/lib/dynamic-form.module.d.ts +28 -0
- package/lib/enums/date-edit-interfaces.d.ts +5 -0
- package/lib/enums/index.d.ts +2 -0
- package/lib/enums/text-edit-mode.d.ts +4 -0
- package/lib/interfaces/form-config-interfaces.d.ts +17 -0
- package/lib/interfaces/index.d.ts +1 -0
- package/lib/proxy/dignite/file-explorer/directories/file-descriptor.service.d.ts +17 -0
- package/lib/proxy/dignite/file-explorer/directories/index.d.ts +2 -0
- package/lib/proxy/dignite/file-explorer/directories/models.d.ts +29 -0
- package/lib/proxy/dignite/file-explorer/files/file-descriptor.service.d.ts +20 -0
- package/lib/proxy/dignite/file-explorer/files/index.d.ts +2 -0
- package/lib/proxy/dignite/file-explorer/files/models.d.ts +50 -0
- package/lib/proxy/dignite/file-explorer/index.d.ts +3 -0
- package/lib/proxy/dignite/index.d.ts +2 -0
- package/lib/proxy/index.d.ts +4 -0
- package/lib/proxy/microsoft/asp-net-core/index.d.ts +2 -0
- package/lib/proxy/microsoft/asp-net-core/mvc/index.d.ts +1 -0
- package/lib/proxy/microsoft/asp-net-core/mvc/models.d.ts +10 -0
- package/lib/proxy/microsoft/extensions/index.d.ts +2 -0
- package/lib/proxy/microsoft/extensions/primitives/index.d.ts +1 -0
- package/lib/proxy/microsoft/extensions/primitives/models.d.ts +8 -0
- package/lib/proxy/microsoft/index.d.ts +4 -0
- package/lib/proxy/microsoft/net/http/headers/index.d.ts +1 -0
- package/lib/proxy/microsoft/net/http/headers/models.d.ts +6 -0
- package/lib/proxy/microsoft/net/http/index.d.ts +2 -0
- package/lib/proxy/microsoft/net/index.d.ts +2 -0
- package/lib/proxy/volo/abp/content/index.d.ts +1 -0
- package/lib/proxy/volo/abp/content/models.d.ts +5 -0
- package/lib/proxy/volo/abp/index.d.ts +2 -0
- package/lib/proxy/volo/index.d.ts +2 -0
- package/lib/services/df-api.service.d.ts +18 -0
- package/lib/services/index.d.ts +1 -0
- package/package.json +37 -0
- package/public-api.d.ts +6 -0
package/README.md
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
# DynamicForm
|
|
2
|
+
|
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 16.2.0.
|
|
4
|
+
|
|
5
|
+
## Code scaffolding
|
|
6
|
+
|
|
7
|
+
Run `ng generate component component-name --project dynamic-form` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project dynamic-form`.
|
|
8
|
+
> Note: Don't forget to add `--project dynamic-form` or else it will be added to the default project in your `angular.json` file.
|
|
9
|
+
|
|
10
|
+
## Build
|
|
11
|
+
|
|
12
|
+
Run `ng build dynamic-form` to build the project. The build artifacts will be stored in the `dist/` directory.
|
|
13
|
+
|
|
14
|
+
## Publishing
|
|
15
|
+
|
|
16
|
+
After building your library with `ng build dynamic-form`, go to the dist folder `cd dist/dynamic-form` and run `npm publish`.
|
|
17
|
+
|
|
18
|
+
## Running unit tests
|
|
19
|
+
|
|
20
|
+
Run `ng test dynamic-form` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
|
21
|
+
|
|
22
|
+
## Further help
|
|
23
|
+
|
|
24
|
+
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlnbml0ZS1uZy1leHBhbmQuZHluYW1pYy1mb3JtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9kaWduaXRlLW5nLWV4cGFuZC5keW5hbWljLWZvcm0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { Component, Input, ViewChild, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { FieldControlGroup } from '../from';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
class DynamicComponent {
|
|
5
|
+
/**选择的表单信息 */
|
|
6
|
+
_selected;
|
|
7
|
+
set selected(v) {
|
|
8
|
+
this._selected = v || '';
|
|
9
|
+
if (v)
|
|
10
|
+
this.dataLoaded(1);
|
|
11
|
+
}
|
|
12
|
+
/**表单控件类型 */
|
|
13
|
+
_type;
|
|
14
|
+
set type(v) {
|
|
15
|
+
this._type = v;
|
|
16
|
+
if (v)
|
|
17
|
+
this.dataLoaded(2);
|
|
18
|
+
}
|
|
19
|
+
/**表单实体 */
|
|
20
|
+
_entity;
|
|
21
|
+
set entity(v) {
|
|
22
|
+
this._entity = v;
|
|
23
|
+
if (v)
|
|
24
|
+
this.dataLoaded(3);
|
|
25
|
+
}
|
|
26
|
+
/**父级字段名称,用于为表单设置控件赋值 */
|
|
27
|
+
_parentFiledName;
|
|
28
|
+
set parentFiledName(v) {
|
|
29
|
+
this._parentFiledName = v;
|
|
30
|
+
if (v)
|
|
31
|
+
this.dataLoaded(4);
|
|
32
|
+
}
|
|
33
|
+
/**字段配置列表 */
|
|
34
|
+
_fields = '';
|
|
35
|
+
set fields(v) {
|
|
36
|
+
this._fields = v;
|
|
37
|
+
if (v)
|
|
38
|
+
this.dataLoaded(5);
|
|
39
|
+
}
|
|
40
|
+
/**表单控件模板-动态赋值表单控件 */
|
|
41
|
+
FormControlRef;
|
|
42
|
+
/**表单控件模板-动态赋值表单控件 */
|
|
43
|
+
FormComponentsRef;
|
|
44
|
+
/**表单控件组 */
|
|
45
|
+
_fieldControlGroup = FieldControlGroup;
|
|
46
|
+
/**数据加载完成 */
|
|
47
|
+
dataLoaded(val) {
|
|
48
|
+
if (this._entity) {
|
|
49
|
+
if (this._type) {
|
|
50
|
+
let fieldControlItem = this._fieldControlGroup.find(el => el.name === this._type);
|
|
51
|
+
this.loadfieldConfigComponent(fieldControlItem);
|
|
52
|
+
}
|
|
53
|
+
if (this._fields && this._parentFiledName) {
|
|
54
|
+
/**表单控件组中的项 */
|
|
55
|
+
let fieldControlItem = this._fieldControlGroup.find(el => el.name === this._fields.field.formControlName);
|
|
56
|
+
this.loadfieldComponent(fieldControlItem);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
/**加载动态表单配置组件 */
|
|
61
|
+
loadfieldConfigComponent(FieldControlItem) {
|
|
62
|
+
//清空了容器中的所有组件
|
|
63
|
+
this.FormControlRef?.clear();
|
|
64
|
+
if (!FieldControlItem || !FieldControlItem.fieldConfigComponent)
|
|
65
|
+
return;
|
|
66
|
+
//在容器中创建组件
|
|
67
|
+
const { instance } = this.FormControlRef?.createComponent(FieldControlItem.fieldConfigComponent); //创建组件模板
|
|
68
|
+
/**向创建的组件模板中传值 */
|
|
69
|
+
instance.Entity = this._entity;
|
|
70
|
+
instance.selected = this._selected;
|
|
71
|
+
instance.type = this._type;
|
|
72
|
+
}
|
|
73
|
+
/**加载动态表单组件 */
|
|
74
|
+
loadfieldComponent(FieldControlItem) {
|
|
75
|
+
// this.FormControlRef.clear
|
|
76
|
+
//清空了容器中的所有组件
|
|
77
|
+
this.FormComponentsRef?.clear();
|
|
78
|
+
if (!FieldControlItem || !FieldControlItem.fieldComponent)
|
|
79
|
+
return;
|
|
80
|
+
//在容器中创建组件
|
|
81
|
+
const { instance } = this.FormComponentsRef?.createComponent(FieldControlItem.fieldComponent); //创建组件模板
|
|
82
|
+
// this.formConfigCompoent = instance
|
|
83
|
+
/**向创建的组件模板中传值 */
|
|
84
|
+
instance.entity = this._entity;
|
|
85
|
+
instance.fields = this._fields;
|
|
86
|
+
instance.parentFiledName = this._parentFiledName;
|
|
87
|
+
instance.selected = this._selected;
|
|
88
|
+
}
|
|
89
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DynamicComponent, selector: "df-dynamic", inputs: { selected: "selected", type: "type", entity: "entity", 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: [""] });
|
|
91
|
+
}
|
|
92
|
+
export { DynamicComponent };
|
|
93
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicComponent, decorators: [{
|
|
94
|
+
type: Component,
|
|
95
|
+
args: [{ selector: 'df-dynamic', template: "<template #FormControlRef></template>\n<template #FormComponentsRef></template>" }]
|
|
96
|
+
}], propDecorators: { selected: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], type: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], entity: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], parentFiledName: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], fields: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], FormControlRef: [{
|
|
107
|
+
type: ViewChild,
|
|
108
|
+
args: ['FormControlRef', { read: ViewContainerRef, static: true }]
|
|
109
|
+
}], FormComponentsRef: [{
|
|
110
|
+
type: ViewChild,
|
|
111
|
+
args: ['FormComponentsRef', { read: ViewContainerRef, static: true }]
|
|
112
|
+
}] } });
|
|
113
|
+
//# 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    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    this._entity = v;\n    if(v) this.dataLoaded(3)\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  @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   \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    // 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  }\n}\n","<template #FormControlRef></template>\n<template #FormComponentsRef></template>"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './dynamic.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZHluYW1pYy5jb21wb25lbnQnIl19
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { CkEditorConfig } from './ck-editor-config';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/forms";
|
|
5
|
+
import * as i2 from "@abp/ng.core";
|
|
6
|
+
import * as i3 from "@ngx-validate/core";
|
|
7
|
+
class CkEditorConfigComponent {
|
|
8
|
+
fb;
|
|
9
|
+
constructor(fb) {
|
|
10
|
+
this.fb = fb;
|
|
11
|
+
}
|
|
12
|
+
/**表单实体 */
|
|
13
|
+
Entity;
|
|
14
|
+
/**选择的表单信息 */
|
|
15
|
+
_selected;
|
|
16
|
+
set selected(v) {
|
|
17
|
+
this._selected = v || '';
|
|
18
|
+
this.dataLoaded();
|
|
19
|
+
}
|
|
20
|
+
/**表单控件类型 */
|
|
21
|
+
_type;
|
|
22
|
+
set type(v) {
|
|
23
|
+
this._type = v;
|
|
24
|
+
this.dataLoaded();
|
|
25
|
+
}
|
|
26
|
+
get formConfiguration() {
|
|
27
|
+
return this.Entity.get('formConfiguration');
|
|
28
|
+
}
|
|
29
|
+
submitclick;
|
|
30
|
+
async dataLoaded() {
|
|
31
|
+
// if (this.Entity && (this._selected || this._selected === '')) {
|
|
32
|
+
if (this.Entity && this._type) {
|
|
33
|
+
await this.AfterInit();
|
|
34
|
+
this.submitclick.nativeElement.click();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
AfterInit() {
|
|
38
|
+
return new Promise((resolve, rejects) => {
|
|
39
|
+
this.Entity.setControl('formConfiguration', this.fb.group(new CkEditorConfig()));
|
|
40
|
+
if (this._selected && this._selected.formControlName == this._type) {
|
|
41
|
+
this.formConfiguration.patchValue({
|
|
42
|
+
...this._selected.formConfiguration
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
resolve(true);
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CkEditorConfigComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CkEditorConfigComponent, selector: "df-ck-editor-config", inputs: { Entity: "Entity", selected: "selected", type: "type" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"Entity\">\n <div formGroupName=\"formConfiguration\">\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpDynamicFormsCkEditor::ImagesContainerName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"Ckeditor.ImagesContainerName\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpDynamicFormsCkEditor::InitialContent' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"Ckeditor.InitialContent\">\n </div>\n <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n #submitclick></button>\n </div>\n</form>", styles: [""], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { 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.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i2.InitDirective, selector: "[abpInit]", outputs: ["abpInit"] }, { kind: "directive", type: i3.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i3.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "pipe", type: i2.LocalizationPipe, name: "abpLocalization" }] });
|
|
50
|
+
}
|
|
51
|
+
export { CkEditorConfigComponent };
|
|
52
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CkEditorConfigComponent, decorators: [{
|
|
53
|
+
type: Component,
|
|
54
|
+
args: [{ selector: 'df-ck-editor-config', template: "<form [formGroup]=\"Entity\">\n <div formGroupName=\"formConfiguration\">\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpDynamicFormsCkEditor::ImagesContainerName' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"Ckeditor.ImagesContainerName\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpDynamicFormsCkEditor::InitialContent' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"Ckeditor.InitialContent\">\n </div>\n <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n #submitclick></button>\n </div>\n</form>" }]
|
|
55
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { Entity: [{
|
|
56
|
+
type: Input
|
|
57
|
+
}], selected: [{
|
|
58
|
+
type: Input
|
|
59
|
+
}], type: [{
|
|
60
|
+
type: Input
|
|
61
|
+
}], submitclick: [{
|
|
62
|
+
type: ViewChild,
|
|
63
|
+
args: ['submitclick', { static: true }]
|
|
64
|
+
}] } });
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2stZWRpdG9yLWNvbmZpZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zyb20vY2stZWRpdG9yL2NrLWVkaXRvci1jb25maWcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9mcm9tL2NrLWVkaXRvci9jay1lZGl0b3ItY29uZmlnLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV4RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7Ozs7O0FBRXBELE1BS2EsdUJBQXVCO0lBRXhCO0lBRFYsWUFDVSxFQUFlO1FBQWYsT0FBRSxHQUFGLEVBQUUsQ0FBYTtJQUNyQixDQUFDO0lBQ0wsVUFBVTtJQUNELE1BQU0sQ0FBdUI7SUFFdEMsYUFBYTtJQUNiLFNBQVMsQ0FBSztJQUNkLElBQ1csUUFBUSxDQUFDLENBQU07UUFDeEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLElBQUcsRUFBRSxDQUFBO1FBRXZCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQTtJQUNuQixDQUFDO0lBQ0QsWUFBWTtJQUNiLEtBQUssQ0FBSztJQUNWLElBQ1csSUFBSSxDQUFDLENBQU07UUFDcEIsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUE7UUFDZCxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7SUFDbkIsQ0FBQztJQUNBLElBQUksaUJBQWlCO1FBQ25CLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsbUJBQW1CLENBQWMsQ0FBQTtJQUMxRCxDQUFDO0lBQzJDLFdBQVcsQ0FBYTtJQUVwRSxLQUFLLENBQUMsVUFBVTtRQUNkLGtFQUFrRTtRQUNoRSxJQUFJLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLEtBQUssRUFBQztZQUM5QixNQUFNLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQTtZQUN0QixJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUN4QztJQUNILENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsRUFBRTtZQUN0QyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxtQkFBbUIsRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxJQUFJLGNBQWMsRUFBRSxDQUFDLENBQUMsQ0FBQTtZQUNoRixJQUFJLElBQUksQ0FBQyxTQUFTLElBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxlQUFlLElBQUUsSUFBSSxDQUFDLEtBQUssRUFBRTtnQkFDOUQsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQztvQkFDaEMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGlCQUFpQjtpQkFDcEMsQ0FBQyxDQUFBO2FBQ0g7WUFDRCxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDZixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7d0dBN0NVLHVCQUF1Qjs0RkFBdkIsdUJBQXVCLHVQQ1RwQyxxeEJBYU87O1NESk0sdUJBQXVCOzRGQUF2Qix1QkFBdUI7a0JBTG5DLFNBQVM7K0JBQ0UscUJBQXFCO2tHQVN0QixNQUFNO3NCQUFkLEtBQUs7Z0JBS0ssUUFBUTtzQkFEbEIsS0FBSztnQkFTSSxJQUFJO3NCQURkLEtBQUs7Z0JBUXVDLFdBQVc7c0JBQXRELFNBQVM7dUJBQUMsYUFBYSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUJ1aWxkZXIsIEZvcm1Db250cm9sLCBGb3JtR3JvdXAsIFZhbGlkYXRvcnMgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBDa0VkaXRvckNvbmZpZyB9IGZyb20gJy4vY2stZWRpdG9yLWNvbmZpZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2RmLWNrLWVkaXRvci1jb25maWcnLFxuICB0ZW1wbGF0ZVVybDogJy4vY2stZWRpdG9yLWNvbmZpZy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NrLWVkaXRvci1jb25maWcuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDa0VkaXRvckNvbmZpZ0NvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZmI6IEZvcm1CdWlsZGVyLFxuICApIHsgfVxuICAvKirooajljZXlrp7kvZMgKi9cbiAgQElucHV0KCkgRW50aXR5OiBGb3JtR3JvdXAgfCB1bmRlZmluZWRcblxuICAvKirpgInmi6nnmoTooajljZXkv6Hmga8gKi9cbiAgX3NlbGVjdGVkOiBhbnlcbiAgQElucHV0KClcbiAgcHVibGljIHNldCBzZWxlY3RlZCh2OiBhbnkpIHtcbiAgICB0aGlzLl9zZWxlY3RlZCA9IHYgfHwnJ1xuXG4gICAgdGhpcy5kYXRhTG9hZGVkKClcbiAgfVxuICAvKirooajljZXmjqfku7bnsbvlnosgKi9cbiBfdHlwZTogYW55XG4gQElucHV0KClcbiBwdWJsaWMgc2V0IHR5cGUodjogYW55KSB7XG4gICB0aGlzLl90eXBlID0gdlxuICAgdGhpcy5kYXRhTG9hZGVkKClcbiB9XG4gIGdldCBmb3JtQ29uZmlndXJhdGlvbigpIHtcbiAgICByZXR1cm4gdGhpcy5FbnRpdHkuZ2V0KCdmb3JtQ29uZmlndXJhdGlvbicpIGFzIEZvcm1Hcm91cFxuICB9XG4gIEBWaWV3Q2hpbGQoJ3N1Ym1pdGNsaWNrJywgeyBzdGF0aWM6IHRydWUgfSkgc3VibWl0Y2xpY2s6IEVsZW1lbnRSZWY7XG5cbiAgYXN5bmMgZGF0YUxvYWRlZCgpIHtcbiAgICAvLyBpZiAodGhpcy5FbnRpdHkgJiYgKHRoaXMuX3NlbGVjdGVkIHx8IHRoaXMuX3NlbGVjdGVkID09PSAnJykpIHtcbiAgICAgIGlmICh0aGlzLkVudGl0eSAmJiB0aGlzLl90eXBlKXtcbiAgICAgIGF3YWl0IHRoaXMuQWZ0ZXJJbml0KClcbiAgICAgIHRoaXMuc3VibWl0Y2xpY2submF0aXZlRWxlbWVudC5jbGljaygpO1xuICAgIH1cbiAgfVxuXG4gIEFmdGVySW5pdCgpIHtcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdHMpID0+IHtcbiAgICAgIHRoaXMuRW50aXR5LnNldENvbnRyb2woJ2Zvcm1Db25maWd1cmF0aW9uJywgdGhpcy5mYi5ncm91cChuZXcgQ2tFZGl0b3JDb25maWcoKSkpXG4gICAgICBpZiAodGhpcy5fc2VsZWN0ZWQmJnRoaXMuX3NlbGVjdGVkLmZvcm1Db250cm9sTmFtZT09dGhpcy5fdHlwZSkge1xuICAgICAgICB0aGlzLmZvcm1Db25maWd1cmF0aW9uLnBhdGNoVmFsdWUoe1xuICAgICAgICAgIC4uLnRoaXMuX3NlbGVjdGVkLmZvcm1Db25maWd1cmF0aW9uXG4gICAgICAgIH0pXG4gICAgICB9XG4gICAgICByZXNvbHZlKHRydWUpXG4gICAgfSlcbiAgfVxufVxuIiwiPGZvcm0gW2Zvcm1Hcm91cF09XCJFbnRpdHlcIj5cbiAgICA8ZGl2IGZvcm1Hcm91cE5hbWU9XCJmb3JtQ29uZmlndXJhdGlvblwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwibWItMlwiPlxuICAgICAgICAgICAgPGxhYmVsIGNsYXNzPVwiZm9ybS1sYWJlbFwiPnt7J0RpZ25pdGVBYnBEeW5hbWljRm9ybXNDa0VkaXRvcjo6SW1hZ2VzQ29udGFpbmVyTmFtZScgfCBhYnBMb2NhbGl6YXRpb259fTwvbGFiZWw+XG4gICAgICAgICAgICA8aW5wdXQgdHlwZT1cInRleHRcIiBjbGFzcz1cImZvcm0tY29udHJvbFwiIGZvcm1Db250cm9sTmFtZT1cIkNrZWRpdG9yLkltYWdlc0NvbnRhaW5lck5hbWVcIj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJtYi0yXCI+XG4gICAgICAgICAgICA8bGFiZWwgY2xhc3M9XCJmb3JtLWxhYmVsXCI+e3snRGlnbml0ZUFicER5bmFtaWNGb3Jtc0NrRWRpdG9yOjpJbml0aWFsQ29udGVudCcgfCBhYnBMb2NhbGl6YXRpb259fTwvbGFiZWw+XG4gICAgICAgICAgICA8aW5wdXQgdHlwZT1cInRleHRcIiBjbGFzcz1cImZvcm0tY29udHJvbFwiIGZvcm1Db250cm9sTmFtZT1cIkNrZWRpdG9yLkluaXRpYWxDb250ZW50XCI+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8YnV0dG9uIHR5cGU9XCJzdWJtaXRcIiAoYWJwSW5pdCk9XCJzdWJtaXRjbGljaz8ubmF0aXZlRWxlbWVudD8uY2xpY2soKVwiIHN0eWxlPVwiZGlzcGxheTogbm9uZTtcIlxuICAgICAgICAgICAgI3N1Ym1pdGNsaWNrPjwvYnV0dG9uPlxuICAgIDwvZGl2PlxuPC9mb3JtPiJdfQ==
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export class CkEditorConfig {
|
|
2
|
+
/**文件容器名称 */
|
|
3
|
+
// placeholder: any = new FormControl('', Validators.required);
|
|
4
|
+
'Ckeditor.ImagesContainerName' = ['', []];
|
|
5
|
+
/**多选 */
|
|
6
|
+
// placeholder: any = new FormControl('', Validators.required);
|
|
7
|
+
'Ckeditor.InitialContent' = ['', []];
|
|
8
|
+
constructor(data) {
|
|
9
|
+
if (data) {
|
|
10
|
+
for (const key in data) {
|
|
11
|
+
if (data.hasOwnProperty(key)) {
|
|
12
|
+
this[key] = data[key];
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2stZWRpdG9yLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2R5bmFtaWMtZm9ybS9zcmMvbGliL2NvbXBvbmVudHMvZnJvbS9jay1lZGl0b3IvY2stZWRpdG9yLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sY0FBYztJQUd2QixZQUFZO0lBQ1osK0RBQStEO0lBQy9ELDhCQUE4QixHQUFRLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzdDLFFBQVE7SUFDViwrREFBK0Q7SUFDL0QseUJBQXlCLEdBQVEsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFHMUMsWUFBWSxJQUFxQjtRQUM3QixJQUFJLElBQUksRUFBRTtZQUNOLEtBQUssTUFBTSxHQUFHLElBQUksSUFBSSxFQUFFO2dCQUNwQixJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUU7b0JBQzFCLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7aUJBQ3pCO2FBQ0o7U0FDSjtJQUdMLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvcm1Db250cm9sLCBWYWxpZGF0b3JzIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgQ2tFZGl0b3JDb25maWcge1xyXG5cclxuXHJcbiAgICAvKirmlofku7blrrnlmajlkI3np7AgKi9cclxuICAgIC8vIHBsYWNlaG9sZGVyOiBhbnkgPSBuZXcgRm9ybUNvbnRyb2woJycsIFZhbGlkYXRvcnMucmVxdWlyZWQpO1xyXG4gICAgJ0NrZWRpdG9yLkltYWdlc0NvbnRhaW5lck5hbWUnOiBhbnkgPSBbJycsIFtdXTtcclxuICAgICAgLyoq5aSa6YCJICovXHJcbiAgICAvLyBwbGFjZWhvbGRlcjogYW55ID0gbmV3IEZvcm1Db250cm9sKCcnLCBWYWxpZGF0b3JzLnJlcXVpcmVkKTtcclxuICAgICdDa2VkaXRvci5Jbml0aWFsQ29udGVudCc6IGFueSA9IFsnJywgW11dO1xyXG4gIFxyXG5cclxuICAgIGNvbnN0cnVjdG9yKGRhdGE/OiBDa0VkaXRvckNvbmZpZykge1xyXG4gICAgICAgIGlmIChkYXRhKSB7XHJcbiAgICAgICAgICAgIGZvciAoY29uc3Qga2V5IGluIGRhdGEpIHtcclxuICAgICAgICAgICAgICAgIGlmIChkYXRhLmhhc093blByb3BlcnR5KGtleSkpIHtcclxuICAgICAgICAgICAgICAgICAgICB0aGlzW2tleV0gPSBkYXRhW2tleV07XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcblxyXG5cclxuICAgIH1cclxufSJdfQ==
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
3
|
+
import ClassicEditor from '@ckeditor/ckeditor5-build-classic';
|
|
4
|
+
import { isBase64UploadAdapter } from './ckEditorUpload';
|
|
5
|
+
import { CKEditorModule } from '@ckeditor/ckeditor5-angular';
|
|
6
|
+
import { CoreModule } from '@abp/ng.core';
|
|
7
|
+
import { ThemeSharedModule } from '@abp/ng.theme.shared';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/forms";
|
|
10
|
+
import * as i2 from "@abp/ng.core";
|
|
11
|
+
import * as i3 from "@ckeditor/ckeditor5-angular";
|
|
12
|
+
import * as i4 from "@angular/common";
|
|
13
|
+
import * as i5 from "@ngx-validate/core";
|
|
14
|
+
class CkEditorControlComponent {
|
|
15
|
+
fb;
|
|
16
|
+
restService;
|
|
17
|
+
constructor(fb, restService) {
|
|
18
|
+
this.fb = fb;
|
|
19
|
+
this.restService = restService;
|
|
20
|
+
}
|
|
21
|
+
Editor = ClassicEditor;
|
|
22
|
+
/**富文本配置 */
|
|
23
|
+
editorConfig = {
|
|
24
|
+
language: 'zh-cn',
|
|
25
|
+
placeholder: '',
|
|
26
|
+
toolbar: {
|
|
27
|
+
removeItems: ['mediaEmbed'],
|
|
28
|
+
shouldNotGroupWhenFull: true
|
|
29
|
+
},
|
|
30
|
+
styles: [
|
|
31
|
+
'alignCenter',
|
|
32
|
+
'alignLeft',
|
|
33
|
+
'alignRight'
|
|
34
|
+
],
|
|
35
|
+
image: {
|
|
36
|
+
toolbar: [
|
|
37
|
+
'imageTextAlternative', 'toggleImageCaption', '|',
|
|
38
|
+
'imageStyle:inline', 'imageStyle:wrapText', 'imageStyle:breakText', 'imageStyle:side', '|',
|
|
39
|
+
,
|
|
40
|
+
'resizeImage'
|
|
41
|
+
],
|
|
42
|
+
insert: {
|
|
43
|
+
integrations: [
|
|
44
|
+
'insertImageViaUrl'
|
|
45
|
+
]
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
//**富文本加载完成 */
|
|
50
|
+
onReady(editor) {
|
|
51
|
+
let that = this;
|
|
52
|
+
editor.plugins.get('FileRepository').createUploadAdapter = function (loader) {
|
|
53
|
+
return new isBase64UploadAdapter(loader, that.imagesContainerName, that.restService);
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
/**富文本内容改变 */
|
|
57
|
+
onChange({ editor }) {
|
|
58
|
+
// const data = editor.getData();
|
|
59
|
+
// console.log(editor, 'onChangeonChange');
|
|
60
|
+
}
|
|
61
|
+
/**表单实体 */
|
|
62
|
+
_entity;
|
|
63
|
+
set entity(v) {
|
|
64
|
+
this._entity = v;
|
|
65
|
+
this.dataLoaded();
|
|
66
|
+
}
|
|
67
|
+
/**字段配置列表 */
|
|
68
|
+
_fields = '';
|
|
69
|
+
set fields(v) {
|
|
70
|
+
this._fields = v;
|
|
71
|
+
this.dataLoaded();
|
|
72
|
+
}
|
|
73
|
+
/**父级字段名称,用于为表单设置控件赋值 */
|
|
74
|
+
_parentFiledName;
|
|
75
|
+
set parentFiledName(v) {
|
|
76
|
+
this._parentFiledName = v;
|
|
77
|
+
this.dataLoaded();
|
|
78
|
+
}
|
|
79
|
+
/**父级字段名称,用于为表单设置控件赋值 */
|
|
80
|
+
_selected;
|
|
81
|
+
set selected(v) {
|
|
82
|
+
this._selected = v;
|
|
83
|
+
this.dataLoaded();
|
|
84
|
+
}
|
|
85
|
+
submitclick;
|
|
86
|
+
get extraProperties() {
|
|
87
|
+
return this._entity.get('extraProperties');
|
|
88
|
+
}
|
|
89
|
+
/**数据加载完成 */
|
|
90
|
+
async dataLoaded() {
|
|
91
|
+
if (this._fields && this._entity) {
|
|
92
|
+
await this.AfterInit();
|
|
93
|
+
this.submitclick.nativeElement.click();
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
/**图片容器名称 */
|
|
97
|
+
imagesContainerName;
|
|
98
|
+
AfterInit() {
|
|
99
|
+
return new Promise((resolve, rejects) => {
|
|
100
|
+
let ValidatorsArray = [];
|
|
101
|
+
if (this._fields.required) {
|
|
102
|
+
ValidatorsArray.push(Validators.required);
|
|
103
|
+
}
|
|
104
|
+
// if (this._fields.field.formConfiguration.limit) {
|
|
105
|
+
// ValidatorsArray.push(Validators.maxLength(this._fields.field.formConfiguration.limit))
|
|
106
|
+
// }
|
|
107
|
+
let newControl = this.fb.control(this._selected ? this._selected : this._fields.field.formConfiguration['Ckeditor.InitialContent'], ValidatorsArray);
|
|
108
|
+
this.extraProperties.setControl(this._fields.field.name, newControl);
|
|
109
|
+
this.imagesContainerName = this._fields.field.formConfiguration['Ckeditor.ImagesContainerName'];
|
|
110
|
+
// console.log(this._fields,'ceshiceshiceshiceshiceshi',this.extraProperties.value,this._entity.value,'this._selected',this._selected);
|
|
111
|
+
resolve(true);
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CkEditorControlComponent, deps: [{ token: i1.FormBuilder }, { token: i2.RestService }], target: i0.ɵɵFactoryTarget.Component });
|
|
115
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CkEditorControlComponent, isStandalone: true, selector: "df-ck-editor-control", inputs: { entity: "entity", fields: "fields", parentFiledName: "parentFiledName", selected: "selected" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\">\n <div class=\"mb-2\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ckeditor [editor]=\"Editor\" [config]=\"editorConfig\" formControlName=\"{{_fields.field.name}}\"\n (ready)=\"onReady($event)\" (change)=\"onChange($event)\" required=\"\" name=\"overview\"></ckeditor>\n <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\n </div>\n </div>\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>", styles: [""], dependencies: [{ kind: "ngmodule", type: CKEditorModule }, { kind: "component", type: i3.CKEditorComponent, selector: "ckeditor", inputs: ["editor", "config", "data", "tagName", "watchdog", "editorWatchdogConfig", "disableTwoWayDataBinding", "disabled"], outputs: ["ready", "change", "blur", "focus", "error"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { 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: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: CoreModule }, { kind: "directive", type: i4.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: "ngmodule", type: ThemeSharedModule }, { kind: "directive", type: i5.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i5.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "ngmodule", type: ReactiveFormsModule }] });
|
|
116
|
+
}
|
|
117
|
+
export { CkEditorControlComponent };
|
|
118
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CkEditorControlComponent, decorators: [{
|
|
119
|
+
type: Component,
|
|
120
|
+
args: [{ selector: 'df-ck-editor-control', standalone: true, imports: [
|
|
121
|
+
CKEditorModule,
|
|
122
|
+
FormsModule,
|
|
123
|
+
CoreModule,
|
|
124
|
+
ThemeSharedModule,
|
|
125
|
+
ReactiveFormsModule,
|
|
126
|
+
], template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\">\n <div class=\"mb-2\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ckeditor [editor]=\"Editor\" [config]=\"editorConfig\" formControlName=\"{{_fields.field.name}}\"\n (ready)=\"onReady($event)\" (change)=\"onChange($event)\" required=\"\" name=\"overview\"></ckeditor>\n <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\n </div>\n </div>\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>" }]
|
|
127
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.RestService }]; }, propDecorators: { entity: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}], fields: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], parentFiledName: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], selected: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], submitclick: [{
|
|
136
|
+
type: ViewChild,
|
|
137
|
+
args: ['submitclick', { static: true }]
|
|
138
|
+
}] } });
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ck-editor-control.component.js","sourceRoot":"","sources":["../../../../../../../projects/dynamic-form/src/lib/components/from/ck-editor/ck-editor-control.component.ts","../../../../../../../projects/dynamic-form/src/lib/components/from/ck-editor/ck-editor-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild, ViewContainerRef } from '@angular/core';\nimport { FormBuilder, FormGroup, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\nimport ClassicEditor from '@ckeditor/ckeditor5-build-classic';\nimport { isBase64UploadAdapter } from './ckEditorUpload';\nimport { CKEditorModule } from '@ckeditor/ckeditor5-angular';\nimport { CoreModule, RestService } from '@abp/ng.core';\nimport { ThemeSharedModule } from '@abp/ng.theme.shared';\n\n\n@Component({\n  selector: 'df-ck-editor-control',\n  templateUrl: './ck-editor-control.component.html',\n  styleUrls: ['./ck-editor-control.component.scss'],\n  standalone: true,\n  imports: [\n    CKEditorModule,\n    FormsModule,\n    CoreModule,\n    ThemeSharedModule,\n    ReactiveFormsModule,\n  ]\n})\nexport class CkEditorControlComponent {\n\n  constructor(\n    private fb: FormBuilder,\n    private restService: RestService,\n  ) { }\n  public Editor = ClassicEditor;\n\n  /**富文本配置 */\n  editorConfig = {\n    language: 'zh-cn',\n    placeholder: '',\n    toolbar: {\n      removeItems: ['mediaEmbed'],\n      shouldNotGroupWhenFull: true\n    },\n    styles: [\n      'alignCenter',\n      'alignLeft',\n      'alignRight'\n    ],\n    image: {\n      toolbar: [\n        'imageTextAlternative', 'toggleImageCaption', '|',\n        'imageStyle:inline', 'imageStyle:wrapText', 'imageStyle:breakText', 'imageStyle:side', '|',\n        , 'resizeImage'\n      ],\n      insert: {\n        integrations: [\n          'insertImageViaUrl'\n        ]\n      }\n\n    }\n  }\n  //**富文本加载完成 */\n  public onReady(editor: any): void {\n    let that = this\n    editor.plugins.get('FileRepository').createUploadAdapter = function (loader: any) {\n      return new isBase64UploadAdapter(loader, that.imagesContainerName,that.restService);\n    };\n  }\n  /**富文本内容改变 */\n  public onChange({ editor }: any) {\n    // const data = editor.getData();\n    // console.log(editor, 'onChangeonChange');\n  }\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n  /**表单实体 */\n  _entity: FormGroup | undefined\n  @Input()\n  public set entity(v: any) {\n    this._entity = v;\n    this.dataLoaded()\n  }\n\n  /**字段配置列表 */\n  _fields: any = ''\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n    this.dataLoaded()\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n    this.dataLoaded()\n  }\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    this._selected = v;\n    this.dataLoaded()\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n\n  get extraProperties() {\n    return this._entity.get('extraProperties') as FormGroup\n  }\n  /**数据加载完成 */\n  async dataLoaded() {\n    if (this._fields && this._entity) {\n      await this.AfterInit()\n      this.submitclick.nativeElement.click();\n    }\n  }\n  /**图片容器名称 */\n  imagesContainerName: any\n  AfterInit() {\n    return new Promise((resolve, rejects) => {\n      let ValidatorsArray = []\n      if (this._fields.required) {\n        ValidatorsArray.push(Validators.required)\n      }\n      // if (this._fields.field.formConfiguration.limit) {\n      //   ValidatorsArray.push(Validators.maxLength(this._fields.field.formConfiguration.limit))\n      // }\n\n      let newControl = this.fb.control(this._selected ? this._selected : this._fields.field.formConfiguration['Ckeditor.InitialContent'], ValidatorsArray)\n      this.extraProperties.setControl(this._fields.field.name, newControl)\n      this.imagesContainerName = this._fields.field.formConfiguration['Ckeditor.ImagesContainerName']\n      // console.log(this._fields,'ceshiceshiceshiceshiceshi',this.extraProperties.value,this._entity.value,'this._selected',this._selected);\n      resolve(true)\n    })\n  }\n}\n","<form [formGroup]=\"_entity\">\n    <div formGroupName=\"extraProperties\">\n        <div class=\"mb-2\">\n            <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n            <ckeditor [editor]=\"Editor\" [config]=\"editorConfig\" formControlName=\"{{_fields.field.name}}\"\n            (ready)=\"onReady($event)\" (change)=\"onChange($event)\" required=\"\" name=\"overview\"></ckeditor>\n            <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\n        </div>\n    </div>\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>"]}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
export class isBase64UploadAdapter {
|
|
2
|
+
reader = new FileReader();
|
|
3
|
+
restService;
|
|
4
|
+
loader;
|
|
5
|
+
ImagesContainerName;
|
|
6
|
+
Base64 = false;
|
|
7
|
+
constructor(loader, ImagesContainerName, restService) {
|
|
8
|
+
this.loader = loader;
|
|
9
|
+
this.ImagesContainerName = ImagesContainerName;
|
|
10
|
+
this.restService = restService;
|
|
11
|
+
console.log(this.restService, 11111111111, restService);
|
|
12
|
+
}
|
|
13
|
+
upload() {
|
|
14
|
+
return new Promise((resolve, reject) => {
|
|
15
|
+
const reader = this.reader;
|
|
16
|
+
if (this.Base64) {
|
|
17
|
+
reader.addEventListener('load', () => {
|
|
18
|
+
resolve({ default: reader.result });
|
|
19
|
+
});
|
|
20
|
+
reader.addEventListener('error', err => {
|
|
21
|
+
reject(err);
|
|
22
|
+
});
|
|
23
|
+
reader.addEventListener('abort', () => {
|
|
24
|
+
reject();
|
|
25
|
+
});
|
|
26
|
+
this.loader.file.then((file) => {
|
|
27
|
+
reader.readAsDataURL(file);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
this.loader.file.then((file) => {
|
|
32
|
+
var formData = new FormData();
|
|
33
|
+
formData.append('file', file, file.name);
|
|
34
|
+
this.createFile({
|
|
35
|
+
file: formData,
|
|
36
|
+
containerName: this.ImagesContainerName,
|
|
37
|
+
directoryId: '',
|
|
38
|
+
entityId: ''
|
|
39
|
+
}).subscribe((response) => {
|
|
40
|
+
resolve({ default: response.url });
|
|
41
|
+
}, (error) => {
|
|
42
|
+
reject(error);
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
createFile = (input, config) => this.restService.request({
|
|
49
|
+
method: 'POST',
|
|
50
|
+
url: '/api/file-explorer/files',
|
|
51
|
+
params: { containerName: input.containerName, cellName: input.cellName, directoryId: input.directoryId, entityId: input.entityId },
|
|
52
|
+
body: input.file,
|
|
53
|
+
}, { apiName: 'FileExplorer', ...config });
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tFZGl0b3JVcGxvYWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zyb20vY2stZWRpdG9yL2NrRWRpdG9yVXBsb2FkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE1BQU0sT0FBTyxxQkFBcUI7SUFDekIsTUFBTSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUM7SUFDakMsV0FBVyxDQUFZO0lBQ3ZCLE1BQU0sQ0FBTTtJQUNaLG1CQUFtQixDQUFNO0lBQ3pCLE1BQU0sR0FBWSxLQUFLLENBQUE7SUFDdkIsWUFDRSxNQUFXLEVBQ1gsbUJBQXdCLEVBQ3hCLFdBQXdCO1FBRXhCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxtQkFBbUIsQ0FBQTtRQUM5QyxJQUFJLENBQUMsV0FBVyxHQUFDLFdBQVcsQ0FBQTtRQUM1QixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUMsV0FBVyxFQUFDLFdBQVcsQ0FBQyxDQUFDO0lBRXhELENBQUM7SUFFTSxNQUFNO1FBRVgsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUNyQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1lBRTNCLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRTtnQkFDZixNQUFNLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRTtvQkFDbkMsT0FBTyxDQUFDLEVBQUUsT0FBTyxFQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO2dCQUN0QyxDQUFDLENBQUMsQ0FBQztnQkFFSCxNQUFNLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxFQUFFO29CQUNyQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ2QsQ0FBQyxDQUFDLENBQUM7Z0JBRUgsTUFBTSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUU7b0JBQ3BDLE1BQU0sRUFBRSxDQUFDO2dCQUNYLENBQUMsQ0FBQyxDQUFDO2dCQUVILElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQVUsRUFBRSxFQUFFO29CQUNuQyxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUM3QixDQUFDLENBQUMsQ0FBQzthQUNKO2lCQUFNO2dCQUNMLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQVUsRUFBRSxFQUFFO29CQUNuQyxJQUFJLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRSxDQUFDO29CQUM5QixRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO29CQUN6QyxJQUFJLENBQUMsVUFBVSxDQUFDO3dCQUNkLElBQUksRUFBRSxRQUFRO3dCQUNkLGFBQWEsRUFBRSxJQUFJLENBQUMsbUJBQW1CO3dCQUN2QyxXQUFXLEVBQUUsRUFBRTt3QkFDZixRQUFRLEVBQUUsRUFBRTtxQkFDYixDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsUUFBWSxFQUFDLEVBQUU7d0JBQzNCLE9BQU8sQ0FBQyxFQUFFLE9BQU8sRUFBRSxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQTtvQkFDcEMsQ0FBQyxFQUFDLENBQUMsS0FBSyxFQUFDLEVBQUU7d0JBQ1QsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUNoQixDQUFDLENBQUMsQ0FBQTtnQkFDSixDQUFDLENBQUMsQ0FBQzthQUNKO1FBRUgsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsVUFBVSxHQUFHLENBQUMsS0FBVSxFQUFFLE1BQTZCLEVBQUUsRUFBRSxDQUN6RCxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBeUI7UUFDL0MsTUFBTSxFQUFFLE1BQU07UUFDZCxHQUFHLEVBQUUsMEJBQTBCO1FBQy9CLE1BQU0sRUFBRSxFQUFFLGFBQWEsRUFBRSxLQUFLLENBQUMsYUFBYSxFQUFFLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUFFLFdBQVcsRUFBRSxLQUFLLENBQUMsV0FBVyxFQUFFLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUFFO1FBQ2xJLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSTtLQUNqQixFQUNDLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUFDLENBQUM7Q0FFN0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZXN0LCBSZXN0U2VydmljZSB9IGZyb20gXCJAYWJwL25nLmNvcmVcIjtcclxuaW1wb3J0IHsgRmlsZURlc2NyaXB0b3JEdG8gfSBmcm9tIFwiLi4vLi4vLi4vcHJveHkvZGlnbml0ZS9maWxlLWV4cGxvcmVyL2ZpbGVzXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgaXNCYXNlNjRVcGxvYWRBZGFwdGVyIHtcclxuICBwdWJsaWMgcmVhZGVyID0gbmV3IEZpbGVSZWFkZXIoKTtcclxuICByZXN0U2VydmljZTpSZXN0U2VydmljZVxyXG4gIGxvYWRlcjogYW55O1xyXG4gIEltYWdlc0NvbnRhaW5lck5hbWU6IGFueTtcclxuICBCYXNlNjQ6IGJvb2xlYW4gPSBmYWxzZVxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgbG9hZGVyOiBhbnksXHJcbiAgICBJbWFnZXNDb250YWluZXJOYW1lOiBhbnksXHJcbiAgICByZXN0U2VydmljZTogUmVzdFNlcnZpY2VcclxuICApIHtcclxuICAgIHRoaXMubG9hZGVyID0gbG9hZGVyO1xyXG4gICAgdGhpcy5JbWFnZXNDb250YWluZXJOYW1lID0gSW1hZ2VzQ29udGFpbmVyTmFtZVxyXG4gICAgdGhpcy5yZXN0U2VydmljZT1yZXN0U2VydmljZVxyXG4gICAgY29uc29sZS5sb2codGhpcy5yZXN0U2VydmljZSwxMTExMTExMTExMSxyZXN0U2VydmljZSk7XHJcbiAgICBcclxuICB9XHJcblxyXG4gIHB1YmxpYyB1cGxvYWQoKSB7XHJcblxyXG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcclxuICAgICAgY29uc3QgcmVhZGVyID0gdGhpcy5yZWFkZXI7XHJcblxyXG4gICAgICBpZiAodGhpcy5CYXNlNjQpIHtcclxuICAgICAgICByZWFkZXIuYWRkRXZlbnRMaXN0ZW5lcignbG9hZCcsICgpID0+IHtcclxuICAgICAgICAgIHJlc29sdmUoeyBkZWZhdWx0OiByZWFkZXIucmVzdWx0IH0pO1xyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgICByZWFkZXIuYWRkRXZlbnRMaXN0ZW5lcignZXJyb3InLCBlcnIgPT4ge1xyXG4gICAgICAgICAgcmVqZWN0KGVycik7XHJcbiAgICAgICAgfSk7XHJcblxyXG4gICAgICAgIHJlYWRlci5hZGRFdmVudExpc3RlbmVyKCdhYm9ydCcsICgpID0+IHtcclxuICAgICAgICAgIHJlamVjdCgpO1xyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgICB0aGlzLmxvYWRlci5maWxlLnRoZW4oKGZpbGU6IEJsb2IpID0+IHtcclxuICAgICAgICAgIHJlYWRlci5yZWFkQXNEYXRhVVJMKGZpbGUpO1xyXG4gICAgICAgIH0pO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIHRoaXMubG9hZGVyLmZpbGUudGhlbigoZmlsZTogRmlsZSkgPT4ge1xyXG4gICAgICAgICAgdmFyIGZvcm1EYXRhID0gbmV3IEZvcm1EYXRhKCk7XHJcbiAgICAgICAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGUnLCBmaWxlLCBmaWxlLm5hbWUpO1xyXG4gICAgICAgICAgdGhpcy5jcmVhdGVGaWxlKHtcclxuICAgICAgICAgICAgZmlsZTogZm9ybURhdGEsXHJcbiAgICAgICAgICAgIGNvbnRhaW5lck5hbWU6IHRoaXMuSW1hZ2VzQ29udGFpbmVyTmFtZSxcclxuICAgICAgICAgICAgZGlyZWN0b3J5SWQ6ICcnLFxyXG4gICAgICAgICAgICBlbnRpdHlJZDogJydcclxuICAgICAgICAgIH0pLnN1YnNjcmliZSgocmVzcG9uc2U6YW55KT0+e1xyXG4gICAgICAgICAgICByZXNvbHZlKHsgZGVmYXVsdDogcmVzcG9uc2UudXJsIH0pXHJcbiAgICAgICAgICB9LChlcnJvcik9PntcclxuICAgICAgICAgICAgcmVqZWN0KGVycm9yKTtcclxuICAgICAgICAgIH0pXHJcbiAgICAgICAgfSk7XHJcbiAgICAgIH1cclxuXHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGNyZWF0ZUZpbGUgPSAoaW5wdXQ6IGFueSwgY29uZmlnPzogUGFydGlhbDxSZXN0LkNvbmZpZz4pID0+XHJcbiAgICB0aGlzLnJlc3RTZXJ2aWNlLnJlcXVlc3Q8YW55LCBGaWxlRGVzY3JpcHRvckR0bz4oe1xyXG4gICAgICBtZXRob2Q6ICdQT1NUJyxcclxuICAgICAgdXJsOiAnL2FwaS9maWxlLWV4cGxvcmVyL2ZpbGVzJyxcclxuICAgICAgcGFyYW1zOiB7IGNvbnRhaW5lck5hbWU6IGlucHV0LmNvbnRhaW5lck5hbWUsIGNlbGxOYW1lOiBpbnB1dC5jZWxsTmFtZSwgZGlyZWN0b3J5SWQ6IGlucHV0LmRpcmVjdG9yeUlkLCBlbnRpdHlJZDogaW5wdXQuZW50aXR5SWQgfSxcclxuICAgICAgYm9keTogaW5wdXQuZmlsZSxcclxuICAgIH0sXHJcbiAgICAgIHsgYXBpTmFtZTogJ0ZpbGVFeHBsb3JlcicsIC4uLmNvbmZpZyB9KTtcclxuXHJcbn0iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './ck-editor-config.component';
|
|
2
|
+
export * from './ck-editor-control.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zyb20vY2stZWRpdG9yL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUE7QUFDNUMsY0FBYywrQkFBK0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2stZWRpdG9yLWNvbmZpZy5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vY2stZWRpdG9yLWNvbnRyb2wuY29tcG9uZW50JyJdfQ==
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { DateEditConfig } from './date-edit-config';
|
|
3
|
+
import { DateEditInterfaces } from '../../../enums/date-edit-interfaces';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@abp/ng.core";
|
|
7
|
+
import * as i3 from "@ngx-validate/core";
|
|
8
|
+
class DateEditConfigComponent {
|
|
9
|
+
fb;
|
|
10
|
+
constructor(fb) {
|
|
11
|
+
this.fb = fb;
|
|
12
|
+
}
|
|
13
|
+
_DateEditInterfaces = DateEditInterfaces;
|
|
14
|
+
/**表单控件类型 */
|
|
15
|
+
_type;
|
|
16
|
+
set type(v) {
|
|
17
|
+
this._type = v;
|
|
18
|
+
this.dataLoaded();
|
|
19
|
+
}
|
|
20
|
+
/**表单实体 */
|
|
21
|
+
_Entity;
|
|
22
|
+
set Entity(v) {
|
|
23
|
+
this._Entity = v;
|
|
24
|
+
this.dataLoaded();
|
|
25
|
+
}
|
|
26
|
+
/**选择的表单信息 */
|
|
27
|
+
_selected;
|
|
28
|
+
set selected(v) {
|
|
29
|
+
this._selected = v;
|
|
30
|
+
this.dataLoaded();
|
|
31
|
+
}
|
|
32
|
+
get formConfiguration() {
|
|
33
|
+
return this._Entity.get('formConfiguration');
|
|
34
|
+
}
|
|
35
|
+
submitclick;
|
|
36
|
+
async dataLoaded() {
|
|
37
|
+
if (this._Entity && this._type) {
|
|
38
|
+
await this.AfterInit();
|
|
39
|
+
this.submitclick.nativeElement.click();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
AfterInit() {
|
|
43
|
+
return new Promise((resolve, rejects) => {
|
|
44
|
+
this._Entity.setControl('formConfiguration', this.fb.group(new DateEditConfig()));
|
|
45
|
+
if (this._selected && this._selected.formControlName == this._type) {
|
|
46
|
+
this.formConfiguration.patchValue({
|
|
47
|
+
...this._selected.formConfiguration
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
resolve(true);
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DateEditConfigComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
54
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DateEditConfigComponent, selector: "df-date-edit-config", inputs: { type: "type", Entity: "Entity", selected: "selected" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_Entity\">\n <div formGroupName=\"formConfiguration\">\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpForms::DateEditMode' | abpLocalization}}</label>\n <div>\n <div class=\"form-check form-check-inline\">\n <input class=\"form-check-input\" type=\"radio\" [value]=\"_DateEditInterfaces.Date\"\n formControlName=\"DateEdit.InputMode\" id=\"flexRadioDefault1\">\n <label class=\"form-check-label\" for=\"flexRadioDefault1\">\n {{'DigniteAbpForms::Date' | abpLocalization}}\n </label>\n </div>\n <div class=\"form-check form-check-inline\">\n <input class=\"form-check-input\" type=\"radio\" [value]=\"_DateEditInterfaces.DateTime\"\n formControlName=\"DateEdit.InputMode\" id=\"flexRadioDefault2\">\n <label class=\"form-check-label\" for=\"flexRadioDefault2\">\n {{'DigniteAbpForms::DateTime' | abpLocalization}}\n </label>\n </div>\n <div class=\"form-check form-check-inline\">\n <input class=\"form-check-input\" type=\"radio\" [value]=\"_DateEditInterfaces.Month\"\n formControlName=\"DateEdit.InputMode\" id=\"flexRadioDefault3\">\n <label class=\"form-check-label\" for=\"flexRadioDefault3\">\n {{'DigniteAbpForms::Month' | abpLocalization}}\n </label>\n </div>\n </div>\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpForms::Min' | abpLocalization}}</label>\n <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"DateEdit.Min\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpForms::Max' | abpLocalization}}</label>\n <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"DateEdit.Max\">\n </div>\n <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n #submitclick></button>\n </div>\n</form>", styles: [""], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { 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.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { 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: 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: i2.InitDirective, selector: "[abpInit]", outputs: ["abpInit"] }, { kind: "directive", type: i3.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i3.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "pipe", type: i2.LocalizationPipe, name: "abpLocalization" }] });
|
|
55
|
+
}
|
|
56
|
+
export { DateEditConfigComponent };
|
|
57
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DateEditConfigComponent, decorators: [{
|
|
58
|
+
type: Component,
|
|
59
|
+
args: [{ selector: 'df-date-edit-config', template: "<form [formGroup]=\"_Entity\">\n <div formGroupName=\"formConfiguration\">\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpForms::DateEditMode' | abpLocalization}}</label>\n <div>\n <div class=\"form-check form-check-inline\">\n <input class=\"form-check-input\" type=\"radio\" [value]=\"_DateEditInterfaces.Date\"\n formControlName=\"DateEdit.InputMode\" id=\"flexRadioDefault1\">\n <label class=\"form-check-label\" for=\"flexRadioDefault1\">\n {{'DigniteAbpForms::Date' | abpLocalization}}\n </label>\n </div>\n <div class=\"form-check form-check-inline\">\n <input class=\"form-check-input\" type=\"radio\" [value]=\"_DateEditInterfaces.DateTime\"\n formControlName=\"DateEdit.InputMode\" id=\"flexRadioDefault2\">\n <label class=\"form-check-label\" for=\"flexRadioDefault2\">\n {{'DigniteAbpForms::DateTime' | abpLocalization}}\n </label>\n </div>\n <div class=\"form-check form-check-inline\">\n <input class=\"form-check-input\" type=\"radio\" [value]=\"_DateEditInterfaces.Month\"\n formControlName=\"DateEdit.InputMode\" id=\"flexRadioDefault3\">\n <label class=\"form-check-label\" for=\"flexRadioDefault3\">\n {{'DigniteAbpForms::Month' | abpLocalization}}\n </label>\n </div>\n </div>\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpForms::Min' | abpLocalization}}</label>\n <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"DateEdit.Min\">\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'DigniteAbpForms::Max' | abpLocalization}}</label>\n <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"DateEdit.Max\">\n </div>\n <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n #submitclick></button>\n </div>\n</form>" }]
|
|
60
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { type: [{
|
|
61
|
+
type: Input
|
|
62
|
+
}], Entity: [{
|
|
63
|
+
type: Input
|
|
64
|
+
}], selected: [{
|
|
65
|
+
type: Input
|
|
66
|
+
}], submitclick: [{
|
|
67
|
+
type: ViewChild,
|
|
68
|
+
args: ['submitclick', { static: true }]
|
|
69
|
+
}] } });
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1lZGl0LWNvbmZpZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zyb20vZGF0ZS1lZGl0L2RhdGUtZWRpdC1jb25maWcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9mcm9tL2RhdGUtZWRpdC9kYXRlLWVkaXQtY29uZmlnLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV4RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUNBQXFDLENBQUM7Ozs7O0FBRXpFLE1BS2EsdUJBQXVCO0lBRXhCO0lBRFYsWUFDVSxFQUFlO1FBQWYsT0FBRSxHQUFGLEVBQUUsQ0FBYTtJQUNyQixDQUFDO0lBQ0wsbUJBQW1CLEdBQUMsa0JBQWtCLENBQUE7SUFDdkMsWUFBWTtJQUNaLEtBQUssQ0FBSztJQUNWLElBQ1csSUFBSSxDQUFDLENBQU07UUFDcEIsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUE7UUFDZCxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7SUFDbkIsQ0FBQztJQUNELFVBQVU7SUFDVixPQUFPLENBQXVCO0lBQzlCLElBQ1csTUFBTSxDQUFDLENBQVk7UUFDNUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUM7UUFDakIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFBO0lBQ25CLENBQUM7SUFDQSxhQUFhO0lBQ2IsU0FBUyxDQUFLO0lBQ2QsSUFDVyxRQUFRLENBQUMsQ0FBTTtRQUN4QixJQUFJLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQTtRQUNsQixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7SUFDbkIsQ0FBQztJQUNELElBQUksaUJBQWlCO1FBQ25CLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQW1CLENBQWMsQ0FBQTtJQUMzRCxDQUFDO0lBQzJDLFdBQVcsQ0FBYTtJQUVwRSxLQUFLLENBQUMsVUFBVTtRQUNkLElBQUksSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQzlCLE1BQU0sSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFBO1lBQ3RCLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQ3hDO0lBQ0gsQ0FBQztJQUVELFNBQVM7UUFDUCxPQUFPLElBQUksT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxFQUFFO1lBQ3RDLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLG1CQUFtQixFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLElBQUksY0FBYyxFQUFFLENBQUMsQ0FBQyxDQUFBO1lBQ2pGLElBQUksSUFBSSxDQUFDLFNBQVMsSUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLGVBQWUsSUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFO2dCQUM5RCxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDO29CQUNoQyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsaUJBQWlCO2lCQUNwQyxDQUFDLENBQUE7YUFDSDtZQUNELE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUNmLENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQzt3R0FoRFUsdUJBQXVCOzRGQUF2Qix1QkFBdUIsdVBDVnBDLHd5RUF1Q087O1NEN0JNLHVCQUF1Qjs0RkFBdkIsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLHFCQUFxQjtrR0FZckIsSUFBSTtzQkFEZCxLQUFLO2dCQVFLLE1BQU07c0JBRGhCLEtBQUs7Z0JBUU0sUUFBUTtzQkFEbEIsS0FBSztnQkFRc0MsV0FBVztzQkFBdEQsU0FBUzt1QkFBQyxhQUFhLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3JtQnVpbGRlciwgRm9ybUNvbnRyb2wsIEZvcm1Hcm91cCwgVmFsaWRhdG9ycyB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IERhdGVFZGl0Q29uZmlnIH0gZnJvbSAnLi9kYXRlLWVkaXQtY29uZmlnJztcbmltcG9ydCB7IERhdGVFZGl0SW50ZXJmYWNlcyB9IGZyb20gJy4uLy4uLy4uL2VudW1zL2RhdGUtZWRpdC1pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGYtZGF0ZS1lZGl0LWNvbmZpZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9kYXRlLWVkaXQtY29uZmlnLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGF0ZS1lZGl0LWNvbmZpZy5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIERhdGVFZGl0Q29uZmlnQ29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBmYjogRm9ybUJ1aWxkZXIsXG4gICkgeyB9XG4gIF9EYXRlRWRpdEludGVyZmFjZXM9RGF0ZUVkaXRJbnRlcmZhY2VzXG4gLyoq6KGo5Y2V5o6n5Lu257G75Z6LICovXG4gX3R5cGU6IGFueVxuIEBJbnB1dCgpXG4gcHVibGljIHNldCB0eXBlKHY6IGFueSkge1xuICAgdGhpcy5fdHlwZSA9IHZcbiAgIHRoaXMuZGF0YUxvYWRlZCgpXG4gfVxuIC8qKuihqOWNleWunuS9kyAqL1xuIF9FbnRpdHk6IEZvcm1Hcm91cCB8IHVuZGVmaW5lZFxuIEBJbnB1dCgpXG4gcHVibGljIHNldCBFbnRpdHkodjogRm9ybUdyb3VwKSB7XG4gICB0aGlzLl9FbnRpdHkgPSB2O1xuICAgdGhpcy5kYXRhTG9hZGVkKClcbiB9XG4gIC8qKumAieaLqeeahOihqOWNleS/oeaBryAqL1xuICBfc2VsZWN0ZWQ6IGFueVxuICBASW5wdXQoKVxuICBwdWJsaWMgc2V0IHNlbGVjdGVkKHY6IGFueSkge1xuICAgIHRoaXMuX3NlbGVjdGVkID0gdlxuICAgIHRoaXMuZGF0YUxvYWRlZCgpXG4gIH1cbiAgZ2V0IGZvcm1Db25maWd1cmF0aW9uKCkge1xuICAgIHJldHVybiB0aGlzLl9FbnRpdHkuZ2V0KCdmb3JtQ29uZmlndXJhdGlvbicpIGFzIEZvcm1Hcm91cFxuICB9XG4gIEBWaWV3Q2hpbGQoJ3N1Ym1pdGNsaWNrJywgeyBzdGF0aWM6IHRydWUgfSkgc3VibWl0Y2xpY2s6IEVsZW1lbnRSZWY7XG5cbiAgYXN5bmMgZGF0YUxvYWRlZCgpIHtcbiAgICBpZiAodGhpcy5fRW50aXR5ICYmIHRoaXMuX3R5cGUpIHtcbiAgICAgIGF3YWl0IHRoaXMuQWZ0ZXJJbml0KClcbiAgICAgIHRoaXMuc3VibWl0Y2xpY2submF0aXZlRWxlbWVudC5jbGljaygpO1xuICAgIH1cbiAgfVxuXG4gIEFmdGVySW5pdCgpIHtcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdHMpID0+IHtcbiAgICAgIHRoaXMuX0VudGl0eS5zZXRDb250cm9sKCdmb3JtQ29uZmlndXJhdGlvbicsIHRoaXMuZmIuZ3JvdXAobmV3IERhdGVFZGl0Q29uZmlnKCkpKVxuICAgICAgaWYgKHRoaXMuX3NlbGVjdGVkJiZ0aGlzLl9zZWxlY3RlZC5mb3JtQ29udHJvbE5hbWU9PXRoaXMuX3R5cGUpIHtcbiAgICAgICAgdGhpcy5mb3JtQ29uZmlndXJhdGlvbi5wYXRjaFZhbHVlKHtcbiAgICAgICAgICAuLi50aGlzLl9zZWxlY3RlZC5mb3JtQ29uZmlndXJhdGlvblxuICAgICAgICB9KVxuICAgICAgfVxuICAgICAgcmVzb2x2ZSh0cnVlKVxuICAgIH0pXG4gIH1cblxufSBcbiIsIjxmb3JtIFtmb3JtR3JvdXBdPVwiX0VudGl0eVwiPlxuICAgIDxkaXYgZm9ybUdyb3VwTmFtZT1cImZvcm1Db25maWd1cmF0aW9uXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJtYi0yXCI+XG4gICAgICAgICAgICA8bGFiZWwgY2xhc3M9XCJmb3JtLWxhYmVsXCI+e3snRGlnbml0ZUFicEZvcm1zOjpEYXRlRWRpdE1vZGUnIHwgYWJwTG9jYWxpemF0aW9ufX08L2xhYmVsPlxuICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZm9ybS1jaGVjayBmb3JtLWNoZWNrLWlubGluZVwiPlxuICAgICAgICAgICAgICAgICAgICA8aW5wdXQgY2xhc3M9XCJmb3JtLWNoZWNrLWlucHV0XCIgdHlwZT1cInJhZGlvXCIgW3ZhbHVlXT1cIl9EYXRlRWRpdEludGVyZmFjZXMuRGF0ZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBmb3JtQ29udHJvbE5hbWU9XCJEYXRlRWRpdC5JbnB1dE1vZGVcIiBpZD1cImZsZXhSYWRpb0RlZmF1bHQxXCI+XG4gICAgICAgICAgICAgICAgICAgIDxsYWJlbCBjbGFzcz1cImZvcm0tY2hlY2stbGFiZWxcIiBmb3I9XCJmbGV4UmFkaW9EZWZhdWx0MVwiPlxuICAgICAgICAgICAgICAgICAgICAgICAge3snRGlnbml0ZUFicEZvcm1zOjpEYXRlJyB8IGFicExvY2FsaXphdGlvbn19XG4gICAgICAgICAgICAgICAgICAgIDwvbGFiZWw+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImZvcm0tY2hlY2sgZm9ybS1jaGVjay1pbmxpbmVcIj5cbiAgICAgICAgICAgICAgICAgICAgPGlucHV0IGNsYXNzPVwiZm9ybS1jaGVjay1pbnB1dFwiIHR5cGU9XCJyYWRpb1wiIFt2YWx1ZV09XCJfRGF0ZUVkaXRJbnRlcmZhY2VzLkRhdGVUaW1lXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cIkRhdGVFZGl0LklucHV0TW9kZVwiIGlkPVwiZmxleFJhZGlvRGVmYXVsdDJcIj5cbiAgICAgICAgICAgICAgICAgICAgPGxhYmVsIGNsYXNzPVwiZm9ybS1jaGVjay1sYWJlbFwiIGZvcj1cImZsZXhSYWRpb0RlZmF1bHQyXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICB7eydEaWduaXRlQWJwRm9ybXM6OkRhdGVUaW1lJyB8IGFicExvY2FsaXphdGlvbn19XG4gICAgICAgICAgICAgICAgICAgIDwvbGFiZWw+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImZvcm0tY2hlY2sgZm9ybS1jaGVjay1pbmxpbmVcIj5cbiAgICAgICAgICAgICAgICAgICAgPGlucHV0IGNsYXNzPVwiZm9ybS1jaGVjay1pbnB1dFwiIHR5cGU9XCJyYWRpb1wiIFt2YWx1ZV09XCJfRGF0ZUVkaXRJbnRlcmZhY2VzLk1vbnRoXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cIkRhdGVFZGl0LklucHV0TW9kZVwiIGlkPVwiZmxleFJhZGlvRGVmYXVsdDNcIj5cbiAgICAgICAgICAgICAgICAgICAgPGxhYmVsIGNsYXNzPVwiZm9ybS1jaGVjay1sYWJlbFwiIGZvcj1cImZsZXhSYWRpb0RlZmF1bHQzXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICB7eydEaWduaXRlQWJwRm9ybXM6Ok1vbnRoJyB8IGFicExvY2FsaXphdGlvbn19XG4gICAgICAgICAgICAgICAgICAgIDwvbGFiZWw+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJtYi0yXCI+XG4gICAgICAgICAgICA8bGFiZWwgY2xhc3M9XCJmb3JtLWxhYmVsXCI+e3snRGlnbml0ZUFicEZvcm1zOjpNaW4nIHwgYWJwTG9jYWxpemF0aW9ufX08L2xhYmVsPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJkYXRldGltZS1sb2NhbFwiIGNsYXNzPVwiZm9ybS1jb250cm9sXCIgc3RlcD1cIjFcIiBmb3JtQ29udHJvbE5hbWU9XCJEYXRlRWRpdC5NaW5cIj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJtYi0yXCI+XG4gICAgICAgICAgICA8bGFiZWwgY2xhc3M9XCJmb3JtLWxhYmVsXCI+e3snRGlnbml0ZUFicEZvcm1zOjpNYXgnIHwgYWJwTG9jYWxpemF0aW9ufX08L2xhYmVsPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJkYXRldGltZS1sb2NhbFwiIGNsYXNzPVwiZm9ybS1jb250cm9sXCIgc3RlcD1cIjFcIiBmb3JtQ29udHJvbE5hbWU9XCJEYXRlRWRpdC5NYXhcIj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxidXR0b24gdHlwZT1cInN1Ym1pdFwiIChhYnBJbml0KT1cInN1Ym1pdGNsaWNrPy5uYXRpdmVFbGVtZW50Py5jbGljaygpXCIgc3R5bGU9XCJkaXNwbGF5OiBub25lO1wiXG4gICAgICAgICAgICAjc3VibWl0Y2xpY2s+PC9idXR0b24+XG4gICAgPC9kaXY+XG48L2Zvcm0+Il19
|