@dignite-ng/expand.dynamic-form 3.0.0-rc.7 → 3.0.0-rc.9
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-config.component.mjs +11 -0
- package/esm2022/lib/components/dynamic/dynamic-control.component.mjs +11 -0
- package/esm2022/lib/components/dynamic/dynamic-view.component.mjs +57 -0
- package/esm2022/lib/components/dynamic/dynamic.component.mjs +1 -1
- package/esm2022/lib/components/dynamic/index.mjs +4 -1
- package/esm2022/lib/components/form/date-edit/date-edit-view.component.mjs +40 -0
- package/esm2022/lib/components/form/form-control-group.mjs +11 -6
- package/esm2022/lib/components/form/numeric-edit/numeric-edit-view.component.mjs +39 -0
- package/esm2022/lib/components/form/select/select-config.component.mjs +16 -6
- package/esm2022/lib/components/form/select/select-control.component.mjs +16 -14
- package/esm2022/lib/components/form/select/select-view.component.mjs +44 -0
- package/esm2022/lib/components/form/switch/switch-view.component.mjs +40 -0
- package/esm2022/lib/components/form/text-edit/text-edit-view.component.mjs +39 -0
- package/esm2022/lib/components/form/text-edit/text-edit.component.mjs +3 -3
- package/esm2022/lib/dynamic-form.module.mjs +33 -3
- package/esm2022/lib/services/form-control.service.mjs +33 -0
- package/fesm2022/dignite-ng-expand.dynamic-form.mjs +350 -29
- package/fesm2022/dignite-ng-expand.dynamic-form.mjs.map +1 -1
- package/lib/components/dynamic/dynamic-config.component.d.ts +5 -0
- package/lib/components/dynamic/dynamic-control.component.d.ts +5 -0
- package/lib/components/dynamic/dynamic-view.component.d.ts +24 -0
- package/lib/components/dynamic/index.d.ts +3 -0
- package/lib/components/form/date-edit/date-edit-view.component.d.ts +17 -0
- package/lib/components/form/numeric-edit/numeric-edit-view.component.d.ts +17 -0
- package/lib/components/form/select/select-view.component.d.ts +17 -0
- package/lib/components/form/switch/switch-view.component.d.ts +17 -0
- package/lib/components/form/text-edit/text-edit-view.component.d.ts +17 -0
- package/lib/dynamic-form.module.d.ts +14 -6
- package/lib/services/form-control.service.d.ts +9 -0
- package/package.json +1 -1
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class DynamicConfigComponent {
|
|
4
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: DynamicConfigComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: DynamicConfigComponent, selector: "df-dynamic-config", ngImport: i0, template: "<p>dynamic-config works!</p>\r\n", styles: [""] }); }
|
|
6
|
+
}
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: DynamicConfigComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'df-dynamic-config', template: "<p>dynamic-config works!</p>\r\n" }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1jb25maWcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9keW5hbWljL2R5bmFtaWMtY29uZmlnLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2R5bmFtaWMtZm9ybS9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy9keW5hbWljLWNvbmZpZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU8xQyxNQUFNLE9BQU8sc0JBQXNCOzhHQUF0QixzQkFBc0I7a0dBQXRCLHNCQUFzQix5RENQbkMsa0NBQ0E7OzJGRE1hLHNCQUFzQjtrQkFMbEMsU0FBUzsrQkFDRSxtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZGYtZHluYW1pYy1jb25maWcnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9keW5hbWljLWNvbmZpZy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL2R5bmFtaWMtY29uZmlnLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgRHluYW1pY0NvbmZpZ0NvbXBvbmVudCB7XHJcblxyXG59XHJcbiIsIjxwPmR5bmFtaWMtY29uZmlnIHdvcmtzITwvcD5cclxuIl19
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class DynamicControlComponent {
|
|
4
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: DynamicControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: DynamicControlComponent, selector: "df-dynamic-control", ngImport: i0, template: "<p>dynamic-control works!</p>\r\n", styles: [""] }); }
|
|
6
|
+
}
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: DynamicControlComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'df-dynamic-control', template: "<p>dynamic-control works!</p>\r\n" }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2R5bmFtaWMtZm9ybS9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy9keW5hbWljLWNvbnRyb2wuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9keW5hbWljL2R5bmFtaWMtY29udHJvbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU8xQyxNQUFNLE9BQU8sdUJBQXVCOzhHQUF2Qix1QkFBdUI7a0dBQXZCLHVCQUF1QiwwRENQcEMsbUNBQ0E7OzJGRE1hLHVCQUF1QjtrQkFMbkMsU0FBUzsrQkFDRSxvQkFBb0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZGYtZHluYW1pYy1jb250cm9sJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZHluYW1pYy1jb250cm9sLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vZHluYW1pYy1jb250cm9sLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgRHluYW1pY0NvbnRyb2xDb21wb25lbnQge1xyXG5cclxufVxyXG4iLCI8cD5keW5hbWljLWNvbnRyb2wgd29ya3MhPC9wPlxyXG4iXX0=
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Component, Input, ViewChild, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../services/form-control.service";
|
|
4
|
+
export class DynamicViewComponent {
|
|
5
|
+
constructor(_FormControlService) {
|
|
6
|
+
this._FormControlService = _FormControlService;
|
|
7
|
+
/**是否显示再列表 */
|
|
8
|
+
this.showInList = false;
|
|
9
|
+
/**表单控件Value */
|
|
10
|
+
this._value = '';
|
|
11
|
+
}
|
|
12
|
+
set value(v) {
|
|
13
|
+
this._value = v;
|
|
14
|
+
// if(this._value) this.dataLoaded();
|
|
15
|
+
}
|
|
16
|
+
ngAfterContentInit() {
|
|
17
|
+
//Called after ngOnInit when the component's or directive's content has been initialized.
|
|
18
|
+
//Add 'implements AfterContentInit' to the class.
|
|
19
|
+
if (this.type && this._value) {
|
|
20
|
+
let _fieldControlGroup = this._FormControlService.AddFieldControlGroup();
|
|
21
|
+
let fieldControlItem = _fieldControlGroup.find(el => el.name === this.type);
|
|
22
|
+
this.loadViewComponent(fieldControlItem);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
/**加载动态展示组件 */
|
|
26
|
+
loadViewComponent(FieldControlItem) {
|
|
27
|
+
//清空了容器中的所有组件
|
|
28
|
+
this.FormTemplateRef?.clear();
|
|
29
|
+
if (!FieldControlItem || !FieldControlItem.fieldViewComponent)
|
|
30
|
+
return;
|
|
31
|
+
//在容器中创建组件
|
|
32
|
+
const { instance } = this.FormTemplateRef?.createComponent(FieldControlItem.fieldViewComponent); //创建组件模板
|
|
33
|
+
/**向创建的组件模板中传值 */
|
|
34
|
+
instance.type = this.type;
|
|
35
|
+
instance.value = this._value;
|
|
36
|
+
instance.fields = this.fields;
|
|
37
|
+
instance.showInList = this.showInList;
|
|
38
|
+
}
|
|
39
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: DynamicViewComponent, deps: [{ token: i1.FormControlService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: DynamicViewComponent, selector: "df-dynamic-view", inputs: { showInList: "showInList", fields: "fields", type: "type", value: "value" }, viewQueries: [{ propertyName: "FormTemplateRef", first: true, predicate: ["FormTemplateRef"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<template #FormTemplateRef></template>", styles: [""] }); }
|
|
41
|
+
}
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: DynamicViewComponent, decorators: [{
|
|
43
|
+
type: Component,
|
|
44
|
+
args: [{ selector: 'df-dynamic-view', template: "<template #FormTemplateRef></template>" }]
|
|
45
|
+
}], ctorParameters: () => [{ type: i1.FormControlService }], propDecorators: { showInList: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], fields: [{
|
|
48
|
+
type: Input
|
|
49
|
+
}], type: [{
|
|
50
|
+
type: Input
|
|
51
|
+
}], value: [{
|
|
52
|
+
type: Input
|
|
53
|
+
}], FormTemplateRef: [{
|
|
54
|
+
type: ViewChild,
|
|
55
|
+
args: ['FormTemplateRef', { read: ViewContainerRef, static: true }]
|
|
56
|
+
}] } });
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy12aWV3LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2R5bmFtaWMtZm9ybS9zcmMvbGliL2NvbXBvbmVudHMvZHluYW1pYy9keW5hbWljLXZpZXcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9keW5hbWljL2R5bmFtaWMtdmlldy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVM5RSxNQUFNLE9BQU8sb0JBQW9CO0lBQy9CLFlBQW9CLG1CQUF1QztRQUF2Qyx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQW9CO1FBRTNELGFBQWE7UUFDSixlQUFVLEdBQVksS0FBSyxDQUFDO1FBT3JDLGVBQWU7UUFDZixXQUFNLEdBQVEsRUFBRSxDQUFDO0lBWDZDLENBQUM7SUFZL0QsSUFDVyxLQUFLLENBQUMsQ0FBTTtRQUNyQixJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztRQUNoQixxQ0FBcUM7SUFDdkMsQ0FBQztJQU1ELGtCQUFrQjtRQUNoQix5RkFBeUY7UUFDekYsaURBQWlEO1FBQ2pELElBQUksSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDN0IsSUFBSSxrQkFBa0IsR0FBVSxJQUFJLENBQUMsbUJBQW1CLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztZQUNoRixJQUFJLGdCQUFnQixHQUFHLGtCQUFrQixDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzVFLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzNDLENBQUM7SUFDSCxDQUFDO0lBRUQsY0FBYztJQUNkLGlCQUFpQixDQUFDLGdCQUE4QztRQUM5RCxhQUFhO1FBQ2IsSUFBSSxDQUFDLGVBQWUsRUFBRSxLQUFLLEVBQUUsQ0FBQztRQUM5QixJQUFJLENBQUMsZ0JBQWdCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxrQkFBa0I7WUFBRSxPQUFPO1FBQ3RFLFVBQVU7UUFDVixNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQVEsSUFBSSxDQUFDLGVBQWUsRUFBRSxlQUFlLENBQzdELGdCQUFnQixDQUFDLGtCQUFrQixDQUNwQyxDQUFDLENBQUMsUUFBUTtRQUNYLGlCQUFpQjtRQUNqQixRQUFRLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUM7UUFDMUIsUUFBUSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQzdCLFFBQVEsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUM5QixRQUFRLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDeEMsQ0FBQzs4R0EvQ1Usb0JBQW9CO2tHQUFwQixvQkFBb0IsNE9Bb0JPLGdCQUFnQiwyQ0M3QnhELHdDQUFzQzs7MkZEU3pCLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxpQkFBaUI7dUZBUWxCLFVBQVU7c0JBQWxCLEtBQUs7Z0JBRUcsTUFBTTtzQkFBZCxLQUFLO2dCQUdHLElBQUk7c0JBQVosS0FBSztnQkFLSyxLQUFLO3NCQURmLEtBQUs7Z0JBUU4sZUFBZTtzQkFEZCxTQUFTO3VCQUFDLGlCQUFpQixFQUFFLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBWaWV3Q2hpbGQsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRm9ybUNvbnRyb2xTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZm9ybS1jb250cm9sLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBGaWVsZENvbnRyb2xHcm91cEludGVyZmFjZXMgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZGYtZHluYW1pYy12aWV3JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZHluYW1pYy12aWV3LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vZHluYW1pYy12aWV3LmNvbXBvbmVudC5zY3NzJyxcclxufSlcclxuZXhwb3J0IGNsYXNzIER5bmFtaWNWaWV3Q29tcG9uZW50IHtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9Gb3JtQ29udHJvbFNlcnZpY2U6IEZvcm1Db250cm9sU2VydmljZSkge31cclxuXHJcbiAgLyoq5piv5ZCm5pi+56S65YaN5YiX6KGoICovXHJcbiAgQElucHV0KCkgc2hvd0luTGlzdDogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIC8qKuihqOWNleWtl+auteaVsOaNriAqL1xyXG4gIEBJbnB1dCgpIGZpZWxkczogYW55O1xyXG5cclxuICAvKirooajljZXmjqfku7bnsbvlnosgKi9cclxuICBASW5wdXQoKSB0eXBlOiBhbnk7XHJcblxyXG4gIC8qKuihqOWNleaOp+S7tlZhbHVlICovXHJcbiAgX3ZhbHVlOiBhbnkgPSAnJztcclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZXQgdmFsdWUodjogYW55KSB7XHJcbiAgICB0aGlzLl92YWx1ZSA9IHY7XHJcbiAgICAvLyBpZih0aGlzLl92YWx1ZSkgdGhpcy5kYXRhTG9hZGVkKCk7XHJcbiAgfVxyXG5cclxuICAvKirooajljZXmjqfku7bmqKHmnb8t5Yqo5oCB6KGo5Y2V6YWN572u57uE5Lu2ICovXHJcbiAgQFZpZXdDaGlsZCgnRm9ybVRlbXBsYXRlUmVmJywgeyByZWFkOiBWaWV3Q29udGFpbmVyUmVmLCBzdGF0aWM6IHRydWUgfSlcclxuICBGb3JtVGVtcGxhdGVSZWY/OiBWaWV3Q29udGFpbmVyUmVmO1xyXG5cclxuICBuZ0FmdGVyQ29udGVudEluaXQoKTogdm9pZCB7XHJcbiAgICAvL0NhbGxlZCBhZnRlciBuZ09uSW5pdCB3aGVuIHRoZSBjb21wb25lbnQncyBvciBkaXJlY3RpdmUncyBjb250ZW50IGhhcyBiZWVuIGluaXRpYWxpemVkLlxyXG4gICAgLy9BZGQgJ2ltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCcgdG8gdGhlIGNsYXNzLlxyXG4gICAgaWYgKHRoaXMudHlwZSAmJiB0aGlzLl92YWx1ZSkge1xyXG4gICAgICBsZXQgX2ZpZWxkQ29udHJvbEdyb3VwOiBhbnlbXSA9IHRoaXMuX0Zvcm1Db250cm9sU2VydmljZS5BZGRGaWVsZENvbnRyb2xHcm91cCgpO1xyXG4gICAgICBsZXQgZmllbGRDb250cm9sSXRlbSA9IF9maWVsZENvbnRyb2xHcm91cC5maW5kKGVsID0+IGVsLm5hbWUgPT09IHRoaXMudHlwZSk7XHJcbiAgICAgIHRoaXMubG9hZFZpZXdDb21wb25lbnQoZmllbGRDb250cm9sSXRlbSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKirliqDovb3liqjmgIHlsZXnpLrnu4Tku7YgKi9cclxuICBsb2FkVmlld0NvbXBvbmVudChGaWVsZENvbnRyb2xJdGVtPzogRmllbGRDb250cm9sR3JvdXBJbnRlcmZhY2VzKSB7XHJcbiAgICAvL+a4heepuuS6huWuueWZqOS4reeahOaJgOaciee7hOS7tlxyXG4gICAgdGhpcy5Gb3JtVGVtcGxhdGVSZWY/LmNsZWFyKCk7XHJcbiAgICBpZiAoIUZpZWxkQ29udHJvbEl0ZW0gfHwgIUZpZWxkQ29udHJvbEl0ZW0uZmllbGRWaWV3Q29tcG9uZW50KSByZXR1cm47XHJcbiAgICAvL+WcqOWuueWZqOS4reWIm+W7uue7hOS7tlxyXG4gICAgY29uc3QgeyBpbnN0YW5jZSB9OiBhbnkgPSB0aGlzLkZvcm1UZW1wbGF0ZVJlZj8uY3JlYXRlQ29tcG9uZW50KFxyXG4gICAgICBGaWVsZENvbnRyb2xJdGVtLmZpZWxkVmlld0NvbXBvbmVudCxcclxuICAgICk7IC8v5Yib5bu657uE5Lu25qih5p2/XHJcbiAgICAvKirlkJHliJvlu7rnmoTnu4Tku7bmqKHmnb/kuK3kvKDlgLwgKi9cclxuICAgIGluc3RhbmNlLnR5cGUgPSB0aGlzLnR5cGU7XHJcbiAgICBpbnN0YW5jZS52YWx1ZSA9IHRoaXMuX3ZhbHVlO1xyXG4gICAgaW5zdGFuY2UuZmllbGRzID0gdGhpcy5maWVsZHM7XHJcbiAgICBpbnN0YW5jZS5zaG93SW5MaXN0ID0gdGhpcy5zaG93SW5MaXN0O1xyXG4gIH1cclxufVxyXG4iLCI8dGVtcGxhdGUgI0Zvcm1UZW1wbGF0ZVJlZj48L3RlbXBsYXRlPiJdfQ==
|
|
@@ -103,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
103
103
|
type: ViewChild,
|
|
104
104
|
args: ['FormComponentsRef', { read: ViewContainerRef, static: true }]
|
|
105
105
|
}] } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# 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 { AddFieldControlGroup, } from '../form';\n\n@Component({\n  selector: 'df-dynamic',\n  templateUrl: './dynamic.component.html',\n  styleUrls: ['./dynamic.component.scss'],\n})\nexport class DynamicComponent {\n\n  /**选择的表单信息 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    this._selected = v === undefined ? '' : v === null ? '' : v;\n  }\n\n  /**表单控件类型 */\n  _type: string;\n  @Input()\n  public set type(v: string) {\n    this._type = v;\n    if (this._entity) this.dataLoaded(3);\n  }\n\n  /**语言 */\n  _culture: FormGroup | undefined;\n  @Input()\n  public set culture(v: any) {\n    this._culture = v;\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any;\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n  }\n\n  /**字段配置列表 */\n  _fields: any = '';\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n  }\n  /**表单实体 */\n  _entity: FormGroup | undefined;\n  @Input()\n  public set entity(v: any) {\n    if (v) {\n      this._entity = v;\n      this.dataLoaded(3);\n    }\n  }\n\n  /**表单控件模板-动态表单配置组件 */\n  @ViewChild('FormControlRef', { read: ViewContainerRef, static: true })\n  FormControlRef?: ViewContainerRef;\n\n  /**表单控件模板-动态表单组件 */\n  @ViewChild('FormComponentsRef', { read: ViewContainerRef, static: true })\n  FormComponentsRef?: ViewContainerRef;\n\n  constructor(@Inject('MERGED_FORM_CONFIG') private mergedConfig: any[]) {}\n\n  /**数据加载完成 */\n  async dataLoaded(val) {\n    let _fieldControlGroup: any[] = AddFieldControlGroup(this.mergedConfig);\n    if (this._entity) {\n      //加载所有的动态表单组件\n      if (this._type) {\n        let fieldControlItem = _fieldControlGroup.find(el => el.name === this._type);\n        this.loadfieldConfigComponent(fieldControlItem);\n      }\n      if (this._fields && this._parentFiledName && this._culture) {\n      \n        /**表单控件组中的项 */\n        let fieldControlItem = _fieldControlGroup.find(\n          el => el.name === this._fields?.field?.formControlName\n        );\n        this.loadfieldComponent(fieldControlItem);\n      }\n    }\n  }\n\n  /**加载动态表单配置组件 */\n  loadfieldConfigComponent(FieldControlItem?: FieldControlGroupInterfaces) {\n   \n    \n    //清空了容器中的所有组件\n    this.FormControlRef?.clear();\n    if (!FieldControlItem || !FieldControlItem.fieldConfigComponent) return;\n    //在容器中创建组件\n    const { instance }:any = this.FormControlRef?.createComponent(\n      FieldControlItem.fieldConfigComponent\n    ); //创建组件模板\n    /**向创建的组件模板中传值 */\n    instance.selected = this._selected;\n    instance.type = this._type;\n    instance.Entity = this._entity;\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 }:any = this.FormComponentsRef?.createComponent(FieldControlItem.fieldComponent); //创建组件模板\n    /**向创建的组件模板中传值 */\n    instance.fields = this._fields;\n    instance.parentFiledName = this._parentFiledName;\n    instance.selected = this._selected;\n    instance.culture = this._culture;\n    instance.entity = this._entity;\n    \n  }\n}\n","<template #FormControlRef></template>\n<template #FormComponentsRef></template>"]}
|
|
@@ -1,2 +1,5 @@
|
|
|
1
1
|
export * from './dynamic.component';
|
|
2
|
-
|
|
2
|
+
export * from './dynamic-view.component';
|
|
3
|
+
export * from './dynamic-config.component';
|
|
4
|
+
export * from './dynamic-control.component';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw2QkFBNkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZHluYW1pYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtdmlldy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtY29uZmlnLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZHluYW1pYy1jb250cm9sLmNvbXBvbmVudCc7Il19
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@abp/ng.core";
|
|
5
|
+
export class DateEditViewComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
/**展示则内容 */
|
|
8
|
+
this.showValue = '';
|
|
9
|
+
/**是否显示再列表 */
|
|
10
|
+
this.showInList = false;
|
|
11
|
+
/**表单控件Value */
|
|
12
|
+
this._value = '';
|
|
13
|
+
}
|
|
14
|
+
set value(v) {
|
|
15
|
+
this._value = v;
|
|
16
|
+
}
|
|
17
|
+
async ngAfterContentInit() {
|
|
18
|
+
//Called after ngOnInit when the component's or directive's content has been initialized.
|
|
19
|
+
//Add 'implements AfterContentInit' to the class.
|
|
20
|
+
let valueOptions = this._value;
|
|
21
|
+
if (this.type && valueOptions) {
|
|
22
|
+
this.showValue = valueOptions;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: DateEditViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
26
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: DateEditViewComponent, selector: "df-date-edit-view", inputs: { showInList: "showInList", fields: "fields", type: "type", value: "value" }, ngImport: i0, template: "@if(showInList){\r\n{{showValue|shortDateTime}}\r\n} @else{\r\n<div class=\"mb-3\">\r\n <label class=\"form-label\" *ngIf=\"fields.displayName\">{{ fields.displayName }}</label>\r\n <div>\r\n {{showValue|shortDateTime}}\r\n </div>\r\n</div>\r\n}", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.ShortDateTimePipe, name: "shortDateTime" }] }); }
|
|
27
|
+
}
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: DateEditViewComponent, decorators: [{
|
|
29
|
+
type: Component,
|
|
30
|
+
args: [{ selector: 'df-date-edit-view', template: "@if(showInList){\r\n{{showValue|shortDateTime}}\r\n} @else{\r\n<div class=\"mb-3\">\r\n <label class=\"form-label\" *ngIf=\"fields.displayName\">{{ fields.displayName }}</label>\r\n <div>\r\n {{showValue|shortDateTime}}\r\n </div>\r\n</div>\r\n}" }]
|
|
31
|
+
}], propDecorators: { showInList: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], fields: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}], type: [{
|
|
36
|
+
type: Input
|
|
37
|
+
}], value: [{
|
|
38
|
+
type: Input
|
|
39
|
+
}] } });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1lZGl0LXZpZXcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2RhdGUtZWRpdC9kYXRlLWVkaXQtdmlldy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vZGF0ZS1lZGl0L2RhdGUtZWRpdC12aWV3LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBT2pELE1BQU0sT0FBTyxxQkFBcUI7SUFMbEM7UUFNRSxXQUFXO1FBQ1gsY0FBUyxHQUFRLEVBQUUsQ0FBQztRQUVwQixhQUFhO1FBQ0osZUFBVSxHQUFZLEtBQUssQ0FBQztRQU9yQyxlQUFlO1FBQ2YsV0FBTSxHQUFRLEVBQUUsQ0FBQztLQWNsQjtJQWJDLElBQ1csS0FBSyxDQUFDLENBQU07UUFDckIsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7SUFDbEIsQ0FBQztJQUVELEtBQUssQ0FBQyxrQkFBa0I7UUFDdEIseUZBQXlGO1FBQ3pGLGlEQUFpRDtRQUNqRCxJQUFJLFlBQVksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQy9CLElBQUksSUFBSSxDQUFDLElBQUksSUFBSSxZQUFZLEVBQUUsQ0FBQztZQUM5QixJQUFJLENBQUMsU0FBUyxHQUFHLFlBQVksQ0FBQztRQUNoQyxDQUFDO0lBQ0gsQ0FBQzs4R0ExQlUscUJBQXFCO2tHQUFyQixxQkFBcUIsK0lDUGxDLHVRQVNDOzsyRkRGWSxxQkFBcUI7a0JBTGpDLFNBQVM7K0JBQ0UsbUJBQW1COzhCQVNwQixVQUFVO3NCQUFsQixLQUFLO2dCQUVHLE1BQU07c0JBQWQsS0FBSztnQkFHRyxJQUFJO3NCQUFaLEtBQUs7Z0JBS0ssS0FBSztzQkFEZixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdkZi1kYXRlLWVkaXQtdmlldycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtZWRpdC12aWV3LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vZGF0ZS1lZGl0LXZpZXcuY29tcG9uZW50LnNjc3MnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZUVkaXRWaWV3Q29tcG9uZW50IHtcclxuICAvKirlsZXnpLrliJnlhoXlrrkgKi9cclxuICBzaG93VmFsdWU6IGFueSA9ICcnO1xyXG5cclxuICAvKirmmK/lkKbmmL7npLrlho3liJfooaggKi9cclxuICBASW5wdXQoKSBzaG93SW5MaXN0OiBib29sZWFuID0gZmFsc2U7XHJcbiAgLyoq6KGo5Y2V5a2X5q615pWw5o2uICovXHJcbiAgQElucHV0KCkgZmllbGRzOiBhbnk7XHJcblxyXG4gIC8qKuihqOWNleaOp+S7tuexu+WeiyAqL1xyXG4gIEBJbnB1dCgpIHR5cGU6IGFueTtcclxuXHJcbiAgLyoq6KGo5Y2V5o6n5Lu2VmFsdWUgKi9cclxuICBfdmFsdWU6IGFueSA9ICcnO1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNldCB2YWx1ZSh2OiBhbnkpIHtcclxuICAgIHRoaXMuX3ZhbHVlID0gdjtcclxuICB9XHJcblxyXG4gIGFzeW5jIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiBQcm9taXNlPHZvaWQ+IHtcclxuICAgIC8vQ2FsbGVkIGFmdGVyIG5nT25Jbml0IHdoZW4gdGhlIGNvbXBvbmVudCdzIG9yIGRpcmVjdGl2ZSdzIGNvbnRlbnQgaGFzIGJlZW4gaW5pdGlhbGl6ZWQuXHJcbiAgICAvL0FkZCAnaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0JyB0byB0aGUgY2xhc3MuXHJcbiAgICBsZXQgdmFsdWVPcHRpb25zID0gdGhpcy5fdmFsdWU7XHJcbiAgICBpZiAodGhpcy50eXBlICYmIHZhbHVlT3B0aW9ucykge1xyXG4gICAgICB0aGlzLnNob3dWYWx1ZSA9IHZhbHVlT3B0aW9ucztcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiQGlmKHNob3dJbkxpc3Qpe1xyXG57e3Nob3dWYWx1ZXxzaG9ydERhdGVUaW1lfX1cclxufSBAZWxzZXtcclxuPGRpdiBjbGFzcz1cIm1iLTNcIj5cclxuICAgIDxsYWJlbCBjbGFzcz1cImZvcm0tbGFiZWxcIiAqbmdJZj1cImZpZWxkcy5kaXNwbGF5TmFtZVwiPnt7IGZpZWxkcy5kaXNwbGF5TmFtZSB9fTwvbGFiZWw+XHJcbiAgICA8ZGl2PlxyXG4gICAgICAgIHt7c2hvd1ZhbHVlfHNob3J0RGF0ZVRpbWV9fVxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG59Il19
|
|
@@ -1,11 +1,16 @@
|
|
|
1
1
|
// 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
|
+
import { DateEditViewComponent } from './date-edit/date-edit-view.component';
|
|
4
5
|
import { NumbericEditConfigComponent } from './numeric-edit/numberic-edit-config.component';
|
|
5
6
|
import { NumbericEditControlComponent } from './numeric-edit/numberic-edit-control.component';
|
|
7
|
+
import { NumericEditViewComponent } from './numeric-edit/numeric-edit-view.component';
|
|
6
8
|
import { SelectConfigComponent, SelectControlComponent } from './select';
|
|
9
|
+
import { SelectViewComponent } from './select/select-view.component';
|
|
7
10
|
import { SwitchConfigComponent, SwitchControlComponent } from './switch';
|
|
11
|
+
import { SwitchViewComponent } from './switch/switch-view.component';
|
|
8
12
|
import { TextEditComponent, TextEditConfigComponent } from './text-edit';
|
|
13
|
+
import { TextEditViewComponent } from './text-edit/text-edit-view.component';
|
|
9
14
|
/**
|
|
10
15
|
* 表单控件分组-包含配置,控件,显示的数组
|
|
11
16
|
*/
|
|
@@ -15,35 +20,35 @@ export const FieldControlGroup = [
|
|
|
15
20
|
name: 'TextEdit',
|
|
16
21
|
fieldConfigComponent: TextEditConfigComponent,
|
|
17
22
|
fieldComponent: TextEditComponent,
|
|
18
|
-
|
|
23
|
+
fieldViewComponent: TextEditViewComponent,
|
|
19
24
|
},
|
|
20
25
|
{
|
|
21
26
|
displayName: '开关',
|
|
22
27
|
name: 'Switch',
|
|
23
28
|
fieldConfigComponent: SwitchConfigComponent,
|
|
24
29
|
fieldComponent: SwitchControlComponent,
|
|
25
|
-
|
|
30
|
+
fieldViewComponent: SwitchViewComponent,
|
|
26
31
|
},
|
|
27
32
|
{
|
|
28
33
|
displayName: '选择',
|
|
29
34
|
name: 'Select',
|
|
30
35
|
fieldConfigComponent: SelectConfigComponent,
|
|
31
36
|
fieldComponent: SelectControlComponent,
|
|
32
|
-
|
|
37
|
+
fieldViewComponent: SelectViewComponent,
|
|
33
38
|
},
|
|
34
39
|
{
|
|
35
40
|
displayName: '数字',
|
|
36
41
|
name: 'NumericEdit',
|
|
37
42
|
fieldConfigComponent: NumbericEditConfigComponent,
|
|
38
43
|
fieldComponent: NumbericEditControlComponent,
|
|
39
|
-
|
|
44
|
+
fieldViewComponent: NumericEditViewComponent,
|
|
40
45
|
},
|
|
41
46
|
{
|
|
42
47
|
displayName: '日期',
|
|
43
48
|
name: 'DateEdit',
|
|
44
49
|
fieldConfigComponent: DateEditConfigComponent,
|
|
45
50
|
fieldComponent: DateEditControlComponent,
|
|
46
|
-
|
|
51
|
+
fieldViewComponent: DateEditViewComponent,
|
|
47
52
|
},
|
|
48
53
|
];
|
|
49
54
|
export function AddFieldControlGroup(array = []) {
|
|
@@ -57,4 +62,4 @@ export function AddFieldControlGroup(array = []) {
|
|
|
57
62
|
}
|
|
58
63
|
return FieldControlGroup;
|
|
59
64
|
}
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1jb250cm9sLWdyb3VwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2Zvcm0tY29udHJvbC1ncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxtRkFBbUY7QUFDbkYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDakYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbkYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDN0UsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDNUYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDOUYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDdEYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLHNCQUFzQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN6RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDekUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFFN0U7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBa0M7SUFDOUQ7UUFDRSxXQUFXLEVBQUUsS0FBSztRQUNsQixJQUFJLEVBQUUsVUFBVTtRQUNoQixvQkFBb0IsRUFBRSx1QkFBdUI7UUFDN0MsY0FBYyxFQUFFLGlCQUFpQjtRQUNqQyxrQkFBa0IsRUFBQyxxQkFBcUI7S0FDekM7SUFDRDtRQUNFLFdBQVcsRUFBRSxJQUFJO1FBQ2pCLElBQUksRUFBRSxRQUFRO1FBQ2Qsb0JBQW9CLEVBQUUscUJBQXFCO1FBQzNDLGNBQWMsRUFBRSxzQkFBc0I7UUFDdEMsa0JBQWtCLEVBQUMsbUJBQW1CO0tBQ3ZDO0lBQ0Q7UUFDRSxXQUFXLEVBQUUsSUFBSTtRQUNqQixJQUFJLEVBQUUsUUFBUTtRQUNkLG9CQUFvQixFQUFFLHFCQUFxQjtRQUMzQyxjQUFjLEVBQUUsc0JBQXNCO1FBQ3RDLGtCQUFrQixFQUFDLG1CQUFtQjtLQUN2QztJQUNEO1FBQ0UsV0FBVyxFQUFFLElBQUk7UUFDakIsSUFBSSxFQUFFLGFBQWE7UUFDbkIsb0JBQW9CLEVBQUUsMkJBQTJCO1FBQ2pELGNBQWMsRUFBRSw0QkFBNEI7UUFDNUMsa0JBQWtCLEVBQUMsd0JBQXdCO0tBQzVDO0lBQ0Q7UUFDRSxXQUFXLEVBQUUsSUFBSTtRQUNqQixJQUFJLEVBQUUsVUFBVTtRQUNoQixvQkFBb0IsRUFBRSx1QkFBdUI7UUFDN0MsY0FBYyxFQUFFLHdCQUF3QjtRQUN4QyxrQkFBa0IsRUFBQyxxQkFBcUI7S0FDekM7Q0FDRixDQUFDO0FBR0YsTUFBTSxVQUFVLG9CQUFvQixDQUFDLFFBQWMsRUFBRTtJQUVuRCxLQUFLLE1BQU0sT0FBTyxJQUFJLEtBQUssRUFBRSxDQUFDO1FBQzVCLElBQUksSUFBSSxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFO1lBQzVDLE9BQU8sT0FBTyxDQUFDLElBQUksS0FBSyxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQ3ZDLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBRyxDQUFDLElBQUksRUFBQyxDQUFDO1lBQ1IsaUJBQWlCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2xDLENBQUM7SUFDSCxDQUFDO0lBQ0QsT0FBTyxpQkFBaUIsQ0FBQztBQUMzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRmllbGRDb250cm9sR3JvdXBJbnRlcmZhY2VzIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcyc7XHJcbi8vIGltcG9ydCB7IENrRWRpdG9yQ29uZmlnQ29tcG9uZW50LCBDa0VkaXRvckNvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9jay1lZGl0b3JcIjtcclxuaW1wb3J0IHsgRGF0ZUVkaXRDb25maWdDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtZWRpdC9kYXRlLWVkaXQtY29uZmlnLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERhdGVFZGl0Q29udHJvbENvbXBvbmVudCB9IGZyb20gJy4vZGF0ZS1lZGl0L2RhdGUtZWRpdC1jb250cm9sLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERhdGVFZGl0Vmlld0NvbXBvbmVudCB9IGZyb20gJy4vZGF0ZS1lZGl0L2RhdGUtZWRpdC12aWV3LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE51bWJlcmljRWRpdENvbmZpZ0NvbXBvbmVudCB9IGZyb20gJy4vbnVtZXJpYy1lZGl0L251bWJlcmljLWVkaXQtY29uZmlnLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE51bWJlcmljRWRpdENvbnRyb2xDb21wb25lbnQgfSBmcm9tICcuL251bWVyaWMtZWRpdC9udW1iZXJpYy1lZGl0LWNvbnRyb2wuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTnVtZXJpY0VkaXRWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9udW1lcmljLWVkaXQvbnVtZXJpYy1lZGl0LXZpZXcuY29tcG9uZW50JztcclxuaW1wb3J0IHsgU2VsZWN0Q29uZmlnQ29tcG9uZW50LCBTZWxlY3RDb250cm9sQ29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QnO1xyXG5pbXBvcnQgeyBTZWxlY3RWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3Qvc2VsZWN0LXZpZXcuY29tcG9uZW50JztcclxuaW1wb3J0IHsgU3dpdGNoQ29uZmlnQ29tcG9uZW50LCBTd2l0Y2hDb250cm9sQ29tcG9uZW50IH0gZnJvbSAnLi9zd2l0Y2gnO1xyXG5pbXBvcnQgeyBTd2l0Y2hWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9zd2l0Y2gvc3dpdGNoLXZpZXcuY29tcG9uZW50JztcclxuaW1wb3J0IHsgVGV4dEVkaXRDb21wb25lbnQsIFRleHRFZGl0Q29uZmlnQ29tcG9uZW50IH0gZnJvbSAnLi90ZXh0LWVkaXQnO1xyXG5pbXBvcnQgeyBUZXh0RWRpdFZpZXdDb21wb25lbnQgfSBmcm9tICcuL3RleHQtZWRpdC90ZXh0LWVkaXQtdmlldy5jb21wb25lbnQnO1xyXG5cclxuLyoqXHJcbiAqIOihqOWNleaOp+S7tuWIhue7hC3ljIXlkKvphY3nva7vvIzmjqfku7bvvIzmmL7npLrnmoTmlbDnu4RcclxuICovXHJcbmV4cG9ydCBjb25zdCBGaWVsZENvbnRyb2xHcm91cDogRmllbGRDb250cm9sR3JvdXBJbnRlcmZhY2VzW10gPSBbXHJcbiAge1xyXG4gICAgZGlzcGxheU5hbWU6ICfmlofmnKzmoYYnLFxyXG4gICAgbmFtZTogJ1RleHRFZGl0JyxcclxuICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBUZXh0RWRpdENvbmZpZ0NvbXBvbmVudCxcclxuICAgIGZpZWxkQ29tcG9uZW50OiBUZXh0RWRpdENvbXBvbmVudCxcclxuICAgIGZpZWxkVmlld0NvbXBvbmVudDpUZXh0RWRpdFZpZXdDb21wb25lbnQsXHJcbiAgfSxcclxuICB7XHJcbiAgICBkaXNwbGF5TmFtZTogJ+W8gOWFsycsXHJcbiAgICBuYW1lOiAnU3dpdGNoJyxcclxuICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBTd2l0Y2hDb25maWdDb21wb25lbnQsXHJcbiAgICBmaWVsZENvbXBvbmVudDogU3dpdGNoQ29udHJvbENvbXBvbmVudCxcclxuICAgIGZpZWxkVmlld0NvbXBvbmVudDpTd2l0Y2hWaWV3Q29tcG9uZW50LFxyXG4gIH0sXHJcbiAge1xyXG4gICAgZGlzcGxheU5hbWU6ICfpgInmi6knLFxyXG4gICAgbmFtZTogJ1NlbGVjdCcsXHJcbiAgICBmaWVsZENvbmZpZ0NvbXBvbmVudDogU2VsZWN0Q29uZmlnQ29tcG9uZW50LFxyXG4gICAgZmllbGRDb21wb25lbnQ6IFNlbGVjdENvbnRyb2xDb21wb25lbnQsXHJcbiAgICBmaWVsZFZpZXdDb21wb25lbnQ6U2VsZWN0Vmlld0NvbXBvbmVudCxcclxuICB9LFxyXG4gIHtcclxuICAgIGRpc3BsYXlOYW1lOiAn5pWw5a2XJyxcclxuICAgIG5hbWU6ICdOdW1lcmljRWRpdCcsXHJcbiAgICBmaWVsZENvbmZpZ0NvbXBvbmVudDogTnVtYmVyaWNFZGl0Q29uZmlnQ29tcG9uZW50LFxyXG4gICAgZmllbGRDb21wb25lbnQ6IE51bWJlcmljRWRpdENvbnRyb2xDb21wb25lbnQsXHJcbiAgICBmaWVsZFZpZXdDb21wb25lbnQ6TnVtZXJpY0VkaXRWaWV3Q29tcG9uZW50LFxyXG4gIH0sXHJcbiAge1xyXG4gICAgZGlzcGxheU5hbWU6ICfml6XmnJ8nLFxyXG4gICAgbmFtZTogJ0RhdGVFZGl0JyxcclxuICAgIGZpZWxkQ29uZmlnQ29tcG9uZW50OiBEYXRlRWRpdENvbmZpZ0NvbXBvbmVudCxcclxuICAgIGZpZWxkQ29tcG9uZW50OiBEYXRlRWRpdENvbnRyb2xDb21wb25lbnQsXHJcbiAgICBmaWVsZFZpZXdDb21wb25lbnQ6RGF0ZUVkaXRWaWV3Q29tcG9uZW50LFxyXG4gIH0sXHJcbl07XHJcblxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIEFkZEZpZWxkQ29udHJvbEdyb3VwKGFycmF5OmFueVtdID0gW10pIHtcclxuXHJcbiAgZm9yIChjb25zdCBlbGVtZW50IG9mIGFycmF5KSB7XHJcbiAgICBsZXQgZmluZCA9IEZpZWxkQ29udHJvbEdyb3VwLmZpbmQoKGNvbnRyb2wpID0+IHtcclxuICAgICAgcmV0dXJuIGNvbnRyb2wubmFtZSA9PT0gZWxlbWVudC5uYW1lO1xyXG4gICAgfSk7XHJcbiAgICBpZighZmluZCl7XHJcbiAgICAgIEZpZWxkQ29udHJvbEdyb3VwLnB1c2goZWxlbWVudCk7XHJcbiAgICB9XHJcbiAgfVxyXG4gIHJldHVybiBGaWVsZENvbnRyb2xHcm91cDtcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class NumericEditViewComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
/**展示则内容 */
|
|
7
|
+
this.showValue = '';
|
|
8
|
+
/**是否显示再列表 */
|
|
9
|
+
this.showInList = false;
|
|
10
|
+
/**表单控件Value */
|
|
11
|
+
this._value = '';
|
|
12
|
+
}
|
|
13
|
+
set value(v) {
|
|
14
|
+
this._value = v;
|
|
15
|
+
}
|
|
16
|
+
async ngAfterContentInit() {
|
|
17
|
+
//Called after ngOnInit when the component's or directive's content has been initialized.
|
|
18
|
+
//Add 'implements AfterContentInit' to the class.
|
|
19
|
+
let valueOptions = this._value;
|
|
20
|
+
if (this.type && valueOptions) {
|
|
21
|
+
this.showValue = valueOptions;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: NumericEditViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
25
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: NumericEditViewComponent, selector: "df-numeric-edit-view", inputs: { showInList: "showInList", fields: "fields", type: "type", value: "value" }, ngImport: i0, template: "@if(showInList){\r\n{{showValue}}\r\n} @else{\r\n<div class=\"mb-3\">\r\n <label class=\"form-label\" *ngIf=\"fields.displayName\">{{ fields.displayName }}</label>\r\n <div>\r\n {{showValue}}\r\n </div>\r\n</div>\r\n}", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
26
|
+
}
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: NumericEditViewComponent, decorators: [{
|
|
28
|
+
type: Component,
|
|
29
|
+
args: [{ selector: 'df-numeric-edit-view', template: "@if(showInList){\r\n{{showValue}}\r\n} @else{\r\n<div class=\"mb-3\">\r\n <label class=\"form-label\" *ngIf=\"fields.displayName\">{{ fields.displayName }}</label>\r\n <div>\r\n {{showValue}}\r\n </div>\r\n</div>\r\n}" }]
|
|
30
|
+
}], propDecorators: { showInList: [{
|
|
31
|
+
type: Input
|
|
32
|
+
}], fields: [{
|
|
33
|
+
type: Input
|
|
34
|
+
}], type: [{
|
|
35
|
+
type: Input
|
|
36
|
+
}], value: [{
|
|
37
|
+
type: Input
|
|
38
|
+
}] } });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtZXJpYy1lZGl0LXZpZXcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHluYW1pYy1mb3JtL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL251bWVyaWMtZWRpdC9udW1lcmljLWVkaXQtdmlldy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9keW5hbWljLWZvcm0vc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vbnVtZXJpYy1lZGl0L251bWVyaWMtZWRpdC12aWV3LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFPakQsTUFBTSxPQUFPLHdCQUF3QjtJQUxyQztRQU1FLFdBQVc7UUFDWCxjQUFTLEdBQVEsRUFBRSxDQUFDO1FBRXBCLGFBQWE7UUFDSixlQUFVLEdBQVksS0FBSyxDQUFDO1FBT3JDLGVBQWU7UUFDZixXQUFNLEdBQVEsRUFBRSxDQUFDO0tBY2xCO0lBYkMsSUFDVyxLQUFLLENBQUMsQ0FBTTtRQUNyQixJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztJQUNsQixDQUFDO0lBRUQsS0FBSyxDQUFDLGtCQUFrQjtRQUN0Qix5RkFBeUY7UUFDekYsaURBQWlEO1FBQ2pELElBQUksWUFBWSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDL0IsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLFlBQVksRUFBRSxDQUFDO1lBQzlCLElBQUksQ0FBQyxTQUFTLEdBQUcsWUFBWSxDQUFDO1FBQ2hDLENBQUM7SUFDSCxDQUFDOzhHQTFCVSx3QkFBd0I7a0dBQXhCLHdCQUF3QixrSkNQckMsMk9BU0M7OzJGREZZLHdCQUF3QjtrQkFMcEMsU0FBUzsrQkFDRSxzQkFBc0I7OEJBU3ZCLFVBQVU7c0JBQWxCLEtBQUs7Z0JBRUcsTUFBTTtzQkFBZCxLQUFLO2dCQUdHLElBQUk7c0JBQVosS0FBSztnQkFLSyxLQUFLO3NCQURmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2RmLW51bWVyaWMtZWRpdC12aWV3JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vbnVtZXJpYy1lZGl0LXZpZXcuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9udW1lcmljLWVkaXQtdmlldy5jb21wb25lbnQuc2NzcycsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOdW1lcmljRWRpdFZpZXdDb21wb25lbnQge1xyXG4gIC8qKuWxleekuuWImeWGheWuuSAqL1xyXG4gIHNob3dWYWx1ZTogYW55ID0gJyc7XHJcblxyXG4gIC8qKuaYr+WQpuaYvuekuuWGjeWIl+ihqCAqL1xyXG4gIEBJbnB1dCgpIHNob3dJbkxpc3Q6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAvKirooajljZXlrZfmrrXmlbDmja4gKi9cclxuICBASW5wdXQoKSBmaWVsZHM6IGFueTtcclxuXHJcbiAgLyoq6KGo5Y2V5o6n5Lu257G75Z6LICovXHJcbiAgQElucHV0KCkgdHlwZTogYW55O1xyXG5cclxuICAvKirooajljZXmjqfku7ZWYWx1ZSAqL1xyXG4gIF92YWx1ZTogYW55ID0gJyc7XHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2V0IHZhbHVlKHY6IGFueSkge1xyXG4gICAgdGhpcy5fdmFsdWUgPSB2O1xyXG4gIH1cclxuXHJcbiAgYXN5bmMgbmdBZnRlckNvbnRlbnRJbml0KCk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgLy9DYWxsZWQgYWZ0ZXIgbmdPbkluaXQgd2hlbiB0aGUgY29tcG9uZW50J3Mgb3IgZGlyZWN0aXZlJ3MgY29udGVudCBoYXMgYmVlbiBpbml0aWFsaXplZC5cclxuICAgIC8vQWRkICdpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQnIHRvIHRoZSBjbGFzcy5cclxuICAgIGxldCB2YWx1ZU9wdGlvbnMgPSB0aGlzLl92YWx1ZTtcclxuICAgIGlmICh0aGlzLnR5cGUgJiYgdmFsdWVPcHRpb25zKSB7XHJcbiAgICAgIHRoaXMuc2hvd1ZhbHVlID0gdmFsdWVPcHRpb25zO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iLCJAaWYoc2hvd0luTGlzdCl7XHJcbnt7c2hvd1ZhbHVlfX1cclxufSBAZWxzZXtcclxuPGRpdiBjbGFzcz1cIm1iLTNcIj5cclxuICAgIDxsYWJlbCBjbGFzcz1cImZvcm0tbGFiZWxcIiAqbmdJZj1cImZpZWxkcy5kaXNwbGF5TmFtZVwiPnt7IGZpZWxkcy5kaXNwbGF5TmFtZSB9fTwvbGFiZWw+XHJcbiAgICA8ZGl2PlxyXG4gICAgICAgIHt7c2hvd1ZhbHVlfX1cclxuICAgIDwvZGl2PlxyXG48L2Rpdj5cclxufSJdfQ==
|
|
@@ -24,7 +24,7 @@ export class SelectConfigComponent {
|
|
|
24
24
|
this.dataLoaded();
|
|
25
25
|
}
|
|
26
26
|
get formConfiguration() {
|
|
27
|
-
return this._Entity
|
|
27
|
+
return this._Entity?.get('formConfiguration');
|
|
28
28
|
}
|
|
29
29
|
get SelectOptions() {
|
|
30
30
|
return this.formConfiguration.controls['Select.Options'];
|
|
@@ -50,11 +50,21 @@ export class SelectConfigComponent {
|
|
|
50
50
|
}
|
|
51
51
|
AfterInit() {
|
|
52
52
|
return new Promise((resolve, rejects) => {
|
|
53
|
-
this._Entity
|
|
53
|
+
this._Entity?.setControl('formConfiguration', this.fb.group(new SelectConfig()));
|
|
54
54
|
if (this._selected && this._selected.formControlName == this._type) {
|
|
55
|
-
this._selected.formConfiguration['Select.Options']?.forEach(el => {
|
|
55
|
+
// this._selected.formConfiguration['Select.Options']?.forEach(el => {
|
|
56
|
+
// console.log(this._selected.formConfiguration,'el',el);
|
|
57
|
+
// this.addSelectOptions();
|
|
58
|
+
// });
|
|
59
|
+
for (const element of this._selected.formConfiguration['Select.Options']) {
|
|
60
|
+
for (const key in element) {
|
|
61
|
+
const item = element[key];
|
|
62
|
+
const capitalizedKey = key.charAt(0).toUpperCase() + key.slice(1);
|
|
63
|
+
element[capitalizedKey] = item;
|
|
64
|
+
}
|
|
56
65
|
this.addSelectOptions();
|
|
57
|
-
}
|
|
66
|
+
}
|
|
67
|
+
// console.log(this._selected.formConfiguration['Select.Options'],'111111')
|
|
58
68
|
this.formConfiguration.patchValue({
|
|
59
69
|
...this._selected.formConfiguration,
|
|
60
70
|
});
|
|
@@ -68,7 +78,7 @@ export class SelectConfigComponent {
|
|
|
68
78
|
textChange(event, index) {
|
|
69
79
|
let SelectOptionsItem = this.SelectOptions.at(index);
|
|
70
80
|
let value = event.target.value;
|
|
71
|
-
if (SelectOptionsItem.get('Value')
|
|
81
|
+
if (SelectOptionsItem.get('Value')?.value)
|
|
72
82
|
return;
|
|
73
83
|
SelectOptionsItem.patchValue({
|
|
74
84
|
Value: this._DfApiService.chineseToPinyin(value),
|
|
@@ -90,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
90
100
|
type: ViewChild,
|
|
91
101
|
args: ['submitclick', { static: true }]
|
|
92
102
|
}] } });
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-config.component.js","sourceRoot":"","sources":["../../../../../../../projects/dynamic-form/src/lib/components/form/select/select-config.component.ts","../../../../../../../projects/dynamic-form/src/lib/components/form/select/select-config.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { FormArray, FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { SelectConfig } from './select-config';\nimport { DfApiService } from '../../../services';\n\n@Component({\n  selector: 'df-select-config',\n\n  templateUrl: './select-config.component.html',\n  styleUrls: ['./select-config.component.scss'],\n})\nexport class SelectConfigComponent {\n  constructor(private fb: FormBuilder, private _DfApiService: DfApiService) {}\n  /**表单控件类型 */\n  _type: any;\n  @Input()\n  public set type(v: any) {\n    this._type = v;\n  }\n\n  /**选择的表单信息 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    this._selected = v;\n  }\n\n  /**表单实体 */\n  _Entity: FormGroup | undefined;\n  @Input()\n  public set Entity(v: FormGroup) {\n    this._Entity = v;\n    this.dataLoaded();\n  }\n  get formConfiguration() {\n    return this._Entity.get('formConfiguration') as FormGroup;\n  }\n  get SelectOptions() {\n    return this.formConfiguration.controls['Select.Options'] as FormArray;\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n  private cdr = inject(ChangeDetectorRef);\n  async dataLoaded() {\n    if (this._Entity && this._type) {\n      await this.AfterInit();\n      this.cdr.detectChanges(); // 手动触发变更检测\n      this.submitclick?.nativeElement?.click();\n    }\n  }\n  /**增加选项 */\n  addSelectOptions() {\n    this.SelectOptions.push(\n      new FormGroup({\n        Text: new FormControl('', Validators.required),\n        Value: new FormControl('', Validators.required),\n        Selected: new FormControl(false),\n      })\n    );\n  }\n  /**删除某个选项 */\n  deleteSelectOptions(index) {\n    this.SelectOptions.removeAt(index);\n  }\n\n  AfterInit() {\n    return new Promise((resolve, rejects) => {\n      this._Entity.setControl('formConfiguration', this.fb.group(new SelectConfig()));\n      if (this._selected && this._selected.formControlName == this._type) {\n        this._selected.formConfiguration['Select.Options']?.forEach(el => {\n          this.addSelectOptions();\n        });\n        this.formConfiguration.patchValue({\n          ...this._selected.formConfiguration,\n        });\n      } else {\n        this.addSelectOptions();\n      }\n      resolve(true);\n    });\n  }\n\n  textChange(event, index) {\n    let SelectOptionsItem = this.SelectOptions.at(index);\n    let value = event.target.value;\n    if (SelectOptionsItem.get('Value').value) return;\n    SelectOptionsItem.patchValue({\n      Value: this._DfApiService.chineseToPinyin(value),\n    });\n  }\n}\n","<form [formGroup]=\"_Entity\">\n    <div formGroupName=\"formConfiguration\">\n        <div class=\"mb-3\">\n            <label class=\"form-label\">{{'DigniteAbpForms::SelectListItem' | abpLocalization}}</label>\n            <table class=\"table\">\n                <thead>\n                    <tr>\n                        <th scope=\"col\">{{'DigniteAbpForms::SelectListItemText' | abpLocalization}}</th>\n                        <th scope=\"col\">{{'DigniteAbpForms::SelectListItemValue' | abpLocalization}}</th>\n                        <th scope=\"col\">{{'DigniteAbpForms::Selected' | abpLocalization}}</th>\n                        <th scope=\"col\" style=\"width: 1%;\">\n                            <button class=\"btn btn-light btn-sm\" (click.stop)=\"addSelectOptions()\">\n                                <i class=\"fas fa-plus-circle\"></i>\n                            </button>\n                        </th>\n                    </tr>\n                </thead>\n                <tbody formArrayName=\"Select.Options\">\n                    <ng-container *ngFor=\"let item of SelectOptions.controls;let i=index\">\n                        <tr [formGroupName]=\"i\">\n                            <td><input type=\"text\" class=\"form-control\" formControlName=\"Text\" (change)=\"textChange($event,i)\"></td>\n                            <td><input type=\"text\" class=\"form-control\" formControlName=\"Value\"></td>\n                            <td>\n                                <div class=\"form-check form-check-inline\">\n                                    <input class=\"form-check-input\" type=\"checkbox\"  formControlName=\"Selected\" id=\"selected\">\n                                </div>\n                            </td>\n                            <td scope=\"row\" style=\"width: 1%;\">\n                                <button class=\"btn btn-light btn-sm\" (click.stop)=\"deleteSelectOptions(i)\">\n                                    <i class=\"fas fa-minus\"></i>\n                                </button>\n                            </td>\n                        </tr> \n                    </ng-container>\n                    \n                    \n                </tbody>\n            </table>\n        </div>\n\n\n\n        <div class=\"mb-3\">\n            <label class=\"form-label\">{{'DigniteAbpForms::NullText' | abpLocalization}}</label>\n            <input type=\"text\" class=\"form-control\" formControlName=\"Select.NullText\">\n        </div>\n        <div class=\"mb-3\">\n            <div class=\"form-check form-check-inline\">\n                <input class=\"form-check-input\" type=\"checkbox\" formControlName=\"Select.Multiple\"\n                    id=\"Multiple\">\n                <label class=\"form-check-label\" for=\"Multiple\">\n                    {{'DigniteAbpForms::Multiple' | abpLocalization}}\n                </label>\n            </div>\n        </div>\n        <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n            #submitclick></button>\n    </div>\n</form>"]}
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-config.component.js","sourceRoot":"","sources":["../../../../../../../projects/dynamic-form/src/lib/components/form/select/select-config.component.ts","../../../../../../../projects/dynamic-form/src/lib/components/form/select/select-config.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAc,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnG,OAAO,EAA0B,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5F,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;;;;AAS/C,MAAM,OAAO,qBAAqB;IAChC,YAAoB,EAAe,EAAU,aAA2B;QAApD,OAAE,GAAF,EAAE,CAAa;QAAU,kBAAa,GAAb,aAAa,CAAc;QA6BhE,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IA7BmC,CAAC;IAG5E,IACW,IAAI,CAAC,CAAM;QACpB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACjB,CAAC;IAID,IACW,QAAQ,CAAC,CAAM;QACxB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;IAID,IACW,MAAM,CAAC,CAAY;QAC5B,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QACjB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IACD,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,mBAAmB,CAAc,CAAC;IAC7D,CAAC;IACD,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,gBAAgB,CAAc,CAAC;IACxE,CAAC;IAGD,KAAK,CAAC,UAAU;QACd,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC/B,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,WAAW;YACrC,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;QAC3C,CAAC;IACH,CAAC;IACD,UAAU;IACV,gBAAgB;QACd,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,SAAS,CAAC;YACZ,IAAI,EAAE,IAAI,WAAW,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;YAC9C,KAAK,EAAE,IAAI,WAAW,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;YAC/C,QAAQ,EAAE,IAAI,WAAW,CAAC,KAAK,CAAC;SACjC,CAAC,CACH,CAAC;IACJ,CAAC;IACD,YAAY;IACZ,mBAAmB,CAAC,KAAK;QACvB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAED,SAAS;QACP,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,mBAAmB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,YAAY,EAAE,CAAC,CAAC,CAAC;YACjF,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,eAAe,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBACnE,sEAAsE;gBACtE,2DAA2D;gBAE3D,6BAA6B;gBAC7B,MAAM;gBACN,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,EAAE,CAAC;oBACzE,KAAK,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;wBAC1B,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;wBAC1B,MAAM,cAAc,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;wBAClE,OAAO,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC;oBACjC,CAAC;oBACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,CAAC;gBACD,2EAA2E;gBAE3E,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC;oBAChC,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB;iBACpC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC;YACD,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU,CAAC,KAAK,EAAE,KAAK;QACrB,IAAI,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QACrD,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAC/B,IAAI,iBAAiB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,KAAK;YAAE,OAAO;QAClD,iBAAiB,CAAC,UAAU,CAAC;YAC3B,KAAK,EAAE,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,KAAK,CAAC;SACjD,CAAC,CAAC;IACL,CAAC;8GAzFU,qBAAqB;kGAArB,qBAAqB,oPCXlC,kiGA0DO;;2FD/CM,qBAAqB;kBANjC,SAAS;+BACE,kBAAkB;2GAUjB,IAAI;sBADd,KAAK;gBAQK,QAAQ;sBADlB,KAAK;gBAQK,MAAM;sBADhB,KAAK;gBAWsC,WAAW;sBAAtD,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { FormArray, FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { SelectConfig } from './select-config';\nimport { DfApiService } from '../../../services';\n\n@Component({\n  selector: 'df-select-config',\n\n  templateUrl: './select-config.component.html',\n  styleUrls: ['./select-config.component.scss'],\n})\nexport class SelectConfigComponent {\n  constructor(private fb: FormBuilder, private _DfApiService: DfApiService) {}\n  /**表单控件类型 */\n  _type: any;\n  @Input()\n  public set type(v: any) {\n    this._type = v;\n  }\n\n  /**选择的表单信息 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    this._selected = v;\n  }\n\n  /**表单实体 */\n  _Entity: FormGroup | undefined;\n  @Input()\n  public set Entity(v: FormGroup) {\n    this._Entity = v;\n    this.dataLoaded();\n  }\n  get formConfiguration() {\n    return this._Entity?.get('formConfiguration') as FormGroup;\n  }\n  get SelectOptions() {\n    return this.formConfiguration.controls['Select.Options'] as FormArray;\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n  private cdr = inject(ChangeDetectorRef);\n  async dataLoaded() {\n    if (this._Entity && this._type) {\n      await this.AfterInit();\n      this.cdr.detectChanges(); // 手动触发变更检测\n      this.submitclick?.nativeElement?.click();\n    }\n  }\n  /**增加选项 */\n  addSelectOptions() {\n    this.SelectOptions.push(\n      new FormGroup({\n        Text: new FormControl('', Validators.required),\n        Value: new FormControl('', Validators.required),\n        Selected: new FormControl(false),\n      })\n    );\n  }\n  /**删除某个选项 */\n  deleteSelectOptions(index) {\n    this.SelectOptions.removeAt(index);\n  }\n\n  AfterInit() {\n    return new Promise((resolve, rejects) => {\n      this._Entity?.setControl('formConfiguration', this.fb.group(new SelectConfig()));\n      if (this._selected && this._selected.formControlName == this._type) {\n        // this._selected.formConfiguration['Select.Options']?.forEach(el => {\n        //   console.log(this._selected.formConfiguration,'el',el);\n\n        //   this.addSelectOptions();\n        // });\n        for (const element of this._selected.formConfiguration['Select.Options']) {\n          for (const key in element) {\n            const item = element[key];\n            const capitalizedKey = key.charAt(0).toUpperCase() + key.slice(1);\n            element[capitalizedKey] = item;\n          }\n          this.addSelectOptions();\n        }\n        // console.log(this._selected.formConfiguration['Select.Options'],'111111')\n\n        this.formConfiguration.patchValue({\n          ...this._selected.formConfiguration,\n        });\n      } else {\n        this.addSelectOptions();\n      }\n      resolve(true);\n    });\n  }\n\n  textChange(event, index) {\n    let SelectOptionsItem = this.SelectOptions.at(index);\n    let value = event.target.value;\n    if (SelectOptionsItem.get('Value')?.value) return;\n    SelectOptionsItem.patchValue({\n      Value: this._DfApiService.chineseToPinyin(value),\n    });\n  }\n}\n","<form [formGroup]=\"_Entity\">\n    <div formGroupName=\"formConfiguration\">\n        <div class=\"mb-3\">\n            <label class=\"form-label\">{{'DigniteAbpForms::SelectListItem' | abpLocalization}}</label>\n            <table class=\"table\">\n                <thead>\n                    <tr>\n                        <th scope=\"col\">{{'DigniteAbpForms::SelectListItemText' | abpLocalization}}</th>\n                        <th scope=\"col\">{{'DigniteAbpForms::SelectListItemValue' | abpLocalization}}</th>\n                        <th scope=\"col\">{{'DigniteAbpForms::Selected' | abpLocalization}}</th>\n                        <th scope=\"col\" style=\"width: 1%;\">\n                            <button class=\"btn btn-light btn-sm\" (click.stop)=\"addSelectOptions()\">\n                                <i class=\"fas fa-plus-circle\"></i>\n                            </button>\n                        </th>\n                    </tr>\n                </thead>\n                <tbody formArrayName=\"Select.Options\">\n                    <ng-container *ngFor=\"let item of SelectOptions.controls;let i=index\">\n                        <tr [formGroupName]=\"i\">\n                            <td><input type=\"text\" class=\"form-control\" formControlName=\"Text\" (change)=\"textChange($event,i)\"></td>\n                            <td><input type=\"text\" class=\"form-control\" formControlName=\"Value\"></td>\n                            <td>\n                                <div class=\"form-check form-check-inline\">\n                                    <input class=\"form-check-input\" type=\"checkbox\"  formControlName=\"Selected\" id=\"selected\">\n                                </div>\n                            </td>\n                            <td scope=\"row\" style=\"width: 1%;\">\n                                <button class=\"btn btn-light btn-sm\" (click.stop)=\"deleteSelectOptions(i)\">\n                                    <i class=\"fas fa-minus\"></i>\n                                </button>\n                            </td>\n                        </tr> \n                    </ng-container>\n                    \n                    \n                </tbody>\n            </table>\n        </div>\n\n\n\n        <div class=\"mb-3\">\n            <label class=\"form-label\">{{'DigniteAbpForms::NullText' | abpLocalization}}</label>\n            <input type=\"text\" class=\"form-control\" formControlName=\"Select.NullText\">\n        </div>\n        <div class=\"mb-3\">\n            <div class=\"form-check form-check-inline\">\n                <input class=\"form-check-input\" type=\"checkbox\" formControlName=\"Select.Multiple\"\n                    id=\"Multiple\">\n                <label class=\"form-check-label\" for=\"Multiple\">\n                    {{'DigniteAbpForms::Multiple' | abpLocalization}}\n                </label>\n            </div>\n        </div>\n        <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n            #submitclick></button>\n    </div>\n</form>"]}
|
|
@@ -44,17 +44,19 @@ export class SelectControlComponent {
|
|
|
44
44
|
ValidatorsArray.push(Validators.required);
|
|
45
45
|
}
|
|
46
46
|
this.formConfiguration = this._fields.field.formConfiguration;
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
47
|
+
const isMultiple = this.formConfiguration['Select.Multiple'];
|
|
48
|
+
let selectValue = isMultiple ? [] : '';
|
|
49
|
+
console.log(this._fields.field.name, 'this.formConfigura', this.formConfiguration, this._selected);
|
|
50
|
+
for (const element of this.formConfiguration['Select.Options']) {
|
|
51
|
+
for (const key in element) {
|
|
52
|
+
const item = element[key];
|
|
53
|
+
const capitalizedKey = key.charAt(0).toUpperCase() + key.slice(1);
|
|
54
|
+
element[capitalizedKey] = item;
|
|
55
|
+
}
|
|
56
|
+
if (Array.isArray(this._selected) && element.Selected && this._selected.length === 0) {
|
|
57
|
+
selectValue = isMultiple ? [...selectValue, element.Value] : [element.Value];
|
|
58
|
+
this._selected = selectValue;
|
|
59
|
+
}
|
|
58
60
|
}
|
|
59
61
|
let newControl = this.fb.control(this._selected, ValidatorsArray);
|
|
60
62
|
this.extraProperties.setControl(this._fields.field.name, newControl);
|
|
@@ -67,11 +69,11 @@ export class SelectControlComponent {
|
|
|
67
69
|
this.extraProperties.removeControl(this._fields.field.name);
|
|
68
70
|
}
|
|
69
71
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: SelectControlComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
70
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: SelectControlComponent, selector: "df-select-control", inputs: { fields: "fields", parentFiledName: "parentFiledName", selected: "selected", entity: "entity" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\" class=\"selectcontrol\">\n <div class=\"mb-3\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ng-container *ngIf=\"formConfiguration['Select.Multiple']; else elseTemplate\">\n
|
|
72
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: SelectControlComponent, selector: "df-select-control", inputs: { fields: "fields", parentFiledName: "parentFiledName", selected: "selected", entity: "entity" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\" class=\"selectcontrol\">\n <div class=\"mb-3\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ng-container *ngIf=\"formConfiguration['Select.Multiple']; else elseTemplate\">\n <nz-select class=\"form-select form-select-multiple\" [nzMaxTagCount]=\"1\"\n nzShowSearch nzMode=\"multiple\"\n formControlName=\"{{_fields.field.name}}\">\n <nz-option *ngFor=\"let item of _fields.field.formConfiguration['Select.Options']\"\n [nzLabel]=\"item.Text\" [nzValue]=\"item.Value\"></nz-option>\n </nz-select>\n </ng-container>\n <ng-template #elseTemplate>\n <select class=\"form-select\" [multiple]=\"false\" formControlName=\"{{_fields.field.name}}\">\n <option [value]=\"\">{{formConfiguration['Select.NullText']}}</option>\n <ng-container *ngFor=\"let item of _fields.field.formConfiguration['Select.Options'];let i =index\">\n <option [value]=\"item.Value\">{{item.Text}}</option>\n </ng-container>\n </select>\n </ng-template>\n <small class=\"form-text text-muted d-block\"\n *ngIf=\"_fields.field.description\">{{_fields.field.description}}</small>\n </div>\n\n </div>\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>", styles: ["::ng-deep .selectcontrol nz-select{width:100%}::ng-deep .selectcontrol nz-select .ant-select-selector{background:transparent!important;border:none!important;padding:.275rem 1.25rem!important;box-shadow:none!important;height:auto!important}::ng-deep .selectcontrol nz-select .anticon-search,::ng-deep .selectcontrol nz-select .anticon-down{display:none}::ng-deep .selectcontrol .ant-select-multiple .ant-select-selection-item{max-width:40%!important}::ng-deep .was-validated .form-select-multiple{border-color:#4fbf67;padding-right:calc(1.5em + 1.35rem);background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%234fbf67' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e\");background-repeat:no-repeat;background-position:right calc(.375em + .3375rem) center;background-size:calc(.75em + .675rem) calc(.75em + .675rem)}\n"], 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.SelectMultipleControlValueAccessor, selector: "select[multiple][formControlName],select[multiple][formControl],select[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: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.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: i3.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i3.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i4.NzOptionComponent, selector: "nz-option", inputs: ["nzTitle", "nzLabel", "nzValue", "nzKey", "nzDisabled", "nzHide", "nzCustomContent"], exportAs: ["nzOption"] }, { kind: "component", type: i4.NzSelectComponent, selector: "nz-select", inputs: ["nzId", "nzSize", "nzStatus", "nzOptionHeightPx", "nzOptionOverflowSize", "nzDropdownClassName", "nzDropdownMatchSelectWidth", "nzDropdownStyle", "nzNotFoundContent", "nzPlaceHolder", "nzPlacement", "nzMaxTagCount", "nzDropdownRender", "nzCustomTemplate", "nzSuffixIcon", "nzClearIcon", "nzRemoveIcon", "nzMenuItemSelectedIcon", "nzTokenSeparators", "nzMaxTagPlaceholder", "nzMaxMultipleCount", "nzMode", "nzFilterOption", "compareWith", "nzAllowClear", "nzBorderless", "nzShowSearch", "nzLoading", "nzAutoFocus", "nzAutoClearSearchValue", "nzServerSearch", "nzDisabled", "nzOpen", "nzSelectOnTab", "nzBackdrop", "nzOptions", "nzShowArrow"], outputs: ["nzOnSearch", "nzScrollToBottom", "nzOpenChange", "nzBlur", "nzFocus"], exportAs: ["nzSelect"] }] }); }
|
|
71
73
|
}
|
|
72
74
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: SelectControlComponent, decorators: [{
|
|
73
75
|
type: Component,
|
|
74
|
-
args: [{ selector: 'df-select-control', template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\" class=\"selectcontrol\">\n <div class=\"mb-3\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ng-container *ngIf=\"formConfiguration['Select.Multiple']; else elseTemplate\">\n
|
|
76
|
+
args: [{ selector: 'df-select-control', template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\" class=\"selectcontrol\">\n <div class=\"mb-3\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ng-container *ngIf=\"formConfiguration['Select.Multiple']; else elseTemplate\">\n <nz-select class=\"form-select form-select-multiple\" [nzMaxTagCount]=\"1\"\n nzShowSearch nzMode=\"multiple\"\n formControlName=\"{{_fields.field.name}}\">\n <nz-option *ngFor=\"let item of _fields.field.formConfiguration['Select.Options']\"\n [nzLabel]=\"item.Text\" [nzValue]=\"item.Value\"></nz-option>\n </nz-select>\n </ng-container>\n <ng-template #elseTemplate>\n <select class=\"form-select\" [multiple]=\"false\" formControlName=\"{{_fields.field.name}}\">\n <option [value]=\"\">{{formConfiguration['Select.NullText']}}</option>\n <ng-container *ngFor=\"let item of _fields.field.formConfiguration['Select.Options'];let i =index\">\n <option [value]=\"item.Value\">{{item.Text}}</option>\n </ng-container>\n </select>\n </ng-template>\n <small class=\"form-text text-muted d-block\"\n *ngIf=\"_fields.field.description\">{{_fields.field.description}}</small>\n </div>\n\n </div>\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>", styles: ["::ng-deep .selectcontrol nz-select{width:100%}::ng-deep .selectcontrol nz-select .ant-select-selector{background:transparent!important;border:none!important;padding:.275rem 1.25rem!important;box-shadow:none!important;height:auto!important}::ng-deep .selectcontrol nz-select .anticon-search,::ng-deep .selectcontrol nz-select .anticon-down{display:none}::ng-deep .selectcontrol .ant-select-multiple .ant-select-selection-item{max-width:40%!important}::ng-deep .was-validated .form-select-multiple{border-color:#4fbf67;padding-right:calc(1.5em + 1.35rem);background-image:url(\"data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%234fbf67' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e\");background-repeat:no-repeat;background-position:right calc(.375em + .3375rem) center;background-size:calc(.75em + .675rem) calc(.75em + .675rem)}\n"] }]
|
|
75
77
|
}], ctorParameters: () => [{ type: i1.FormBuilder }], propDecorators: { fields: [{
|
|
76
78
|
type: Input
|
|
77
79
|
}], parentFiledName: [{
|
|
@@ -84,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
84
86
|
type: ViewChild,
|
|
85
87
|
args: ['submitclick', { static: true }]
|
|
86
88
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-control.component.js","sourceRoot":"","sources":["../../../../../../../projects/dynamic-form/src/lib/components/form/select/select-control.component.ts","../../../../../../../projects/dynamic-form/src/lib/components/form/select/select-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\n\n@Component({\n  selector: 'df-select-control',\n  templateUrl: './select-control.component.html',\n  styleUrls: ['./select-control.component.scss'],\n})\nexport class SelectControlComponent {\n  constructor(private fb: FormBuilder) {}\n\n  /**字段配置列表 */\n  _fields: any = '';\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any;\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n  }\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    this._selected = v;\n  }\n\n  /**表单实体 */\n  _entity: FormGroup | undefined;\n  @Input()\n  public set entity(v: any) {\n    this._entity = v;\n    this.dataLoaded();\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  get extraProperties() {\n    return this._entity?.get('extraProperties') as FormGroup;\n  }\n  private cdr = inject(ChangeDetectorRef);\n  /**数据加载完成 */\n  async dataLoaded() {\n    if (this._fields && this._entity) {\n      await this.AfterInit();\n      this.cdr.detectChanges(); // 手动触发变更检测\n      this.submitclick?.nativeElement?.click();\n    }\n  }\n \n  formConfiguration: any = '';\n  AfterInit() {\n    return new Promise((resolve, rejects) => {\n      let ValidatorsArray:any[] = [];\n      if (this._fields.required) {\n        ValidatorsArray.push(Validators.required);\n      }\n      this.formConfiguration = this._fields.field.formConfiguration;\n      if (!this._selected) {\n        const isMultiple = this.formConfiguration['Select.Multiple'];\n\n        let selectValue:any = isMultiple ? [] : '';\n        this.formConfiguration['Select.Options'].forEach(el => {\n          if (el.Selected) {\n            selectValue = isMultiple\n              ? [...selectValue, el.value || el.Value]\n              : [el.value || el.Value];\n          }\n        });\n\n        this._selected = selectValue;\n      }\n      let newControl = this.fb.control(this._selected, ValidatorsArray);\n      this.extraProperties.setControl(this._fields.field.name, newControl);\n      resolve(true);\n    });\n  }\n  ngOnDestroy(): void {\n    //Called once, before the instance is destroyed.\n    //Add 'implements OnDestroy' to the class.\n    this.extraProperties.removeControl(this._fields.field.name);\n  }\n}\n","<form [formGroup]=\"_entity\">\n    <div formGroupName=\"extraProperties\" class=\"selectcontrol\">\n        <div class=\"mb-3\">\n            <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n            <ng-container *ngIf=\"formConfiguration['Select.Multiple']; else elseTemplate\">\n                <!-- <select class=\"form-select\" multiple formControlName=\"{{_fields.field.name}}\">\n                    <ng-container *ngFor=\"let item of _fields.field.formConfiguration['Select.Options'];let i =index\">\n                        <option [value]=\"item.Value\">{{item.Text}}</option>\n                    </ng-container>\n                </select> -->\n                <nz-select class=\"form-select form-select-multiple\" [nzMaxTagCount]=\"1\"\n                    nzShowSearch nzMode=\"multiple\"\n                    formControlName=\"{{_fields.field.name}}\">\n                    <nz-option *ngFor=\"let item of _fields.field.formConfiguration['Select.Options']\"\n                        [nzLabel]=\"item.Text\" [nzValue]=\"item.Value\"></nz-option>\n                </nz-select>\n            </ng-container>\n            <ng-template #elseTemplate>\n                <select class=\"form-select\" [multiple]=\"false\" formControlName=\"{{_fields.field.name}}\">\n                    <option [value]=\"\">{{formConfiguration['Select.NullText']}}</option>\n                    <ng-container *ngFor=\"let item of _fields.field.formConfiguration['Select.Options'];let i =index\">\n                        <option [value]=\"item.Value\">{{item.Text}}</option>\n                    </ng-container>\n                </select>\n            </ng-template>\n            <small class=\"form-text text-muted d-block\"\n                *ngIf=\"_fields.field.description\">{{_fields.field.description}}</small>\n        </div>\n\n    </div>\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>"]}
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-control.component.js","sourceRoot":"","sources":["../../../../../../../projects/dynamic-form/src/lib/components/form/select/select-control.component.ts","../../../../../../../projects/dynamic-form/src/lib/components/form/select/select-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\n\n@Component({\n  selector: 'df-select-control',\n  templateUrl: './select-control.component.html',\n  styleUrls: ['./select-control.component.scss'],\n})\nexport class SelectControlComponent {\n  constructor(private fb: FormBuilder) {}\n\n  /**字段配置列表 */\n  _fields: any = '';\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any;\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n  }\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    this._selected = v;\n  }\n\n  /**表单实体 */\n  _entity: FormGroup | undefined;\n  @Input()\n  public set entity(v: any) {\n    this._entity = v;\n    this.dataLoaded();\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  get extraProperties() {\n    return this._entity?.get('extraProperties') as FormGroup;\n  }\n  private cdr = inject(ChangeDetectorRef);\n  /**数据加载完成 */\n  async dataLoaded() {\n    if (this._fields && this._entity) {\n      await this.AfterInit();\n      this.cdr.detectChanges(); // 手动触发变更检测\n      this.submitclick?.nativeElement?.click();\n    }\n  }\n\n  formConfiguration: any = '';\n  AfterInit() {\n    return new Promise((resolve, rejects) => {\n      let ValidatorsArray: any[] = [];\n      if (this._fields.required) {\n        ValidatorsArray.push(Validators.required);\n      }\n      this.formConfiguration = this._fields.field.formConfiguration;\n      const isMultiple = this.formConfiguration['Select.Multiple'];\n      let selectValue: any = isMultiple ? [] : '';\n      console.log(this._fields.field.name,'this.formConfigura', this.formConfiguration, this._selected);\n      for (const element of this.formConfiguration['Select.Options']) {\n        for (const key in element) {\n          const item = element[key];\n          const capitalizedKey = key.charAt(0).toUpperCase() + key.slice(1);\n          element[capitalizedKey] = item;\n        }\n        if(Array.isArray(this._selected)&&element.Selected&&this._selected.length===0){\n            selectValue = isMultiple ? [...selectValue, element.Value] : [element.Value];\n            this._selected = selectValue;\n        }\n      }\n      let newControl = this.fb.control(this._selected, ValidatorsArray);\n      this.extraProperties.setControl(this._fields.field.name, newControl);\n      resolve(true);\n    });\n  }\n  ngOnDestroy(): void {\n    //Called once, before the instance is destroyed.\n    //Add 'implements OnDestroy' to the class.\n    this.extraProperties.removeControl(this._fields.field.name);\n  }\n}\n","<form [formGroup]=\"_entity\">\n    <div formGroupName=\"extraProperties\" class=\"selectcontrol\">\n        <div class=\"mb-3\">\n            <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n            <ng-container *ngIf=\"formConfiguration['Select.Multiple']; else elseTemplate\">\n                <nz-select class=\"form-select form-select-multiple\" [nzMaxTagCount]=\"1\"\n                    nzShowSearch nzMode=\"multiple\"\n                    formControlName=\"{{_fields.field.name}}\">\n                    <nz-option *ngFor=\"let item of _fields.field.formConfiguration['Select.Options']\"\n                        [nzLabel]=\"item.Text\" [nzValue]=\"item.Value\"></nz-option>\n                </nz-select>\n            </ng-container>\n            <ng-template #elseTemplate>\n                <select class=\"form-select\" [multiple]=\"false\" formControlName=\"{{_fields.field.name}}\">\n                    <option [value]=\"\">{{formConfiguration['Select.NullText']}}</option>\n                    <ng-container *ngFor=\"let item of _fields.field.formConfiguration['Select.Options'];let i =index\">\n                        <option [value]=\"item.Value\">{{item.Text}}</option>\n                    </ng-container>\n                </select>\n            </ng-template>\n            <small class=\"form-text text-muted d-block\"\n                *ngIf=\"_fields.field.description\">{{_fields.field.description}}</small>\n        </div>\n\n    </div>\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>"]}
|