@stemy/ngx-dynamic-form 10.2.18 → 10.2.22
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 +27 -27
- package/bundles/stemy-ngx-dynamic-form.umd.js +1400 -1390
- package/bundles/stemy-ngx-dynamic-form.umd.js.map +1 -1
- package/bundles/stemy-ngx-dynamic-form.umd.min.js +1 -1
- package/bundles/stemy-ngx-dynamic-form.umd.min.js.map +1 -1
- package/esm2015/ngx-dynamic-form/common-types.js +134 -134
- package/esm2015/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.js +91 -91
- package/esm2015/ngx-dynamic-form/components/base/dynamic-base-form.component.js +129 -129
- package/esm2015/ngx-dynamic-form/directives/async-submit.directive.js +100 -100
- package/esm2015/ngx-dynamic-form/ngx-dynamic-form.module.js +82 -82
- package/esm2015/ngx-dynamic-form/services/dynamic-form-validation.service.js +11 -11
- package/esm2015/ngx-dynamic-form/services/dynamic-form.service.js +393 -383
- package/esm2015/ngx-dynamic-form/utils/dynamic-form-array.model.js +8 -8
- package/esm2015/ngx-dynamic-form/utils/form-subject.js +18 -18
- package/esm2015/ngx-dynamic-form/utils/validators.js +28 -28
- package/esm2015/public_api.js +9 -9
- package/esm2015/stemy-ngx-dynamic-form.js +6 -6
- package/fesm2015/stemy-ngx-dynamic-form.js +936 -926
- package/fesm2015/stemy-ngx-dynamic-form.js.map +1 -1
- package/ngx-dynamic-form/common-types.d.ts +148 -148
- package/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.d.ts +37 -37
- package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +37 -37
- package/ngx-dynamic-form/directives/async-submit.directive.d.ts +27 -27
- package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +10 -10
- package/ngx-dynamic-form/services/dynamic-form-validation.service.d.ts +5 -5
- package/ngx-dynamic-form/services/dynamic-form.service.d.ts +40 -40
- package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +12 -12
- package/ngx-dynamic-form/utils/form-subject.d.ts +8 -8
- package/ngx-dynamic-form/utils/validators.d.ts +4 -4
- package/package.json +12 -12
- package/public_api.d.ts +8 -8
- package/stemy-ngx-dynamic-form.d.ts +6 -6
|
@@ -1,129 +1,129 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, EventEmitter, Inject, Input, Output, QueryList, ViewChild, ViewChildren } from "@angular/core";
|
|
3
|
-
import { NgForm } from "@angular/forms";
|
|
4
|
-
import { Subscription } from "rxjs";
|
|
5
|
-
import { first } from "rxjs/operators";
|
|
6
|
-
import { DynamicFormComponent, DynamicFormComponentService, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
7
|
-
import { EventsService, ObservableUtils } from "@stemy/ngx-utils";
|
|
8
|
-
import { DynamicFormService } from "../../services/dynamic-form.service";
|
|
9
|
-
export class DynamicBaseFormComponent extends DynamicFormComponent {
|
|
10
|
-
constructor(formService, events, changeDetectorRef, componentService) {
|
|
11
|
-
super(changeDetectorRef, componentService);
|
|
12
|
-
this.formService = formService;
|
|
13
|
-
this.events = events;
|
|
14
|
-
this.blur = new EventEmitter();
|
|
15
|
-
this.change = new EventEmitter();
|
|
16
|
-
this.focus = new EventEmitter();
|
|
17
|
-
this.onStatusChange = new EventEmitter();
|
|
18
|
-
this.onValueChange = new EventEmitter();
|
|
19
|
-
this.onSubmit = new EventEmitter();
|
|
20
|
-
this.templates = new QueryList();
|
|
21
|
-
this.subscription = new Subscription();
|
|
22
|
-
this.groupSubscription = new Subscription();
|
|
23
|
-
this.labelPrefix = "label";
|
|
24
|
-
}
|
|
25
|
-
get status() {
|
|
26
|
-
return !this.group ? null : this.group.status;
|
|
27
|
-
}
|
|
28
|
-
ngOnChanges(changes) {
|
|
29
|
-
this.groupSubscription.unsubscribe();
|
|
30
|
-
if (this.group) {
|
|
31
|
-
this.groupSubscription = ObservableUtils.multiSubscription(this.group.statusChanges.subscribe(() => {
|
|
32
|
-
this.onStatusChange.emit(this);
|
|
33
|
-
}), this.group.valueChanges.subscribe(() => {
|
|
34
|
-
this.onValueChange.emit(this);
|
|
35
|
-
this.formService.notifyChanges(this.model, this.group);
|
|
36
|
-
}));
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
ngAfterViewInit() {
|
|
40
|
-
this.subscription = ObservableUtils.multiSubscription(ObservableUtils.subscribe({
|
|
41
|
-
subjects: [this.contentTemplates.changes, this.viewTemplates.changes],
|
|
42
|
-
cb: () => {
|
|
43
|
-
const templates = this.contentTemplates.toArray().concat(this.viewTemplates.toArray());
|
|
44
|
-
this.templates.reset(templates);
|
|
45
|
-
}
|
|
46
|
-
}), this.events.languageChanged.subscribe(() => {
|
|
47
|
-
this.formService.detectChanges(this);
|
|
48
|
-
}), this.ngForm.ngSubmit.subscribe(() => {
|
|
49
|
-
this.onSubmit.emit(this);
|
|
50
|
-
}));
|
|
51
|
-
}
|
|
52
|
-
ngOnDestroy() {
|
|
53
|
-
super.ngOnDestroy();
|
|
54
|
-
this.subscription.unsubscribe();
|
|
55
|
-
this.groupSubscription.unsubscribe();
|
|
56
|
-
}
|
|
57
|
-
insertFormArrayGroup(index, formArray, formArrayModel) {
|
|
58
|
-
this.formService.insertFormArrayGroup(index, formArray, formArrayModel);
|
|
59
|
-
this.changeDetectorRef.detectChanges();
|
|
60
|
-
}
|
|
61
|
-
removeFormArrayGroup(index, formArray, formArrayModel) {
|
|
62
|
-
this.formService.removeFormArrayGroup(index, formArray, formArrayModel);
|
|
63
|
-
this.changeDetectorRef.detectChanges();
|
|
64
|
-
}
|
|
65
|
-
moveFormArrayGroup(index, step, formArray, formArrayModel) {
|
|
66
|
-
this.formService.moveFormArrayGroup(index, step, formArray, formArrayModel);
|
|
67
|
-
this.changeDetectorRef.detectChanges();
|
|
68
|
-
}
|
|
69
|
-
clearFormArray(formArray, formArrayModel) {
|
|
70
|
-
this.formService.clearFormArray(formArray, formArrayModel);
|
|
71
|
-
this.changeDetectorRef.detectChanges();
|
|
72
|
-
}
|
|
73
|
-
validate(showErrors = true) {
|
|
74
|
-
if (!this.group)
|
|
75
|
-
return Promise.resolve();
|
|
76
|
-
return new Promise((resolve, reject) => {
|
|
77
|
-
this.group.statusChanges.pipe(first(status => status == "VALID" || status == "INVALID")).subscribe(status => {
|
|
78
|
-
if (showErrors) {
|
|
79
|
-
this.formService.showErrors(this);
|
|
80
|
-
}
|
|
81
|
-
if (status == "VALID") {
|
|
82
|
-
resolve(null);
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
reject(null);
|
|
86
|
-
});
|
|
87
|
-
this.group.updateValueAndValidity();
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
serialize(validate) {
|
|
91
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
92
|
-
if (!this.group)
|
|
93
|
-
return null;
|
|
94
|
-
if (validate) {
|
|
95
|
-
yield this.validate();
|
|
96
|
-
}
|
|
97
|
-
return yield this.formService.serialize(this.model, this.group);
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
DynamicBaseFormComponent.decorators = [
|
|
102
|
-
{ type: Component, args: [{
|
|
103
|
-
selector: "dynamic-base-form",
|
|
104
|
-
template: "",
|
|
105
|
-
changeDetection: ChangeDetectionStrategy.Default
|
|
106
|
-
},] }
|
|
107
|
-
];
|
|
108
|
-
DynamicBaseFormComponent.ctorParameters = () => [
|
|
109
|
-
{ type: DynamicFormService, decorators: [{ type: Inject, args: [DynamicFormService,] }] },
|
|
110
|
-
{ type: EventsService, decorators: [{ type: Inject, args: [EventsService,] }] },
|
|
111
|
-
{ type: ChangeDetectorRef },
|
|
112
|
-
{ type: DynamicFormComponentService }
|
|
113
|
-
];
|
|
114
|
-
DynamicBaseFormComponent.propDecorators = {
|
|
115
|
-
group: [{ type: Input }],
|
|
116
|
-
model: [{ type: Input }],
|
|
117
|
-
layout: [{ type: Input }],
|
|
118
|
-
labelPrefix: [{ type: Input }],
|
|
119
|
-
blur: [{ type: Output }],
|
|
120
|
-
change: [{ type: Output }],
|
|
121
|
-
focus: [{ type: Output }],
|
|
122
|
-
contentTemplates: [{ type: ContentChildren, args: [DynamicTemplateDirective,] }],
|
|
123
|
-
viewTemplates: [{ type: ViewChildren, args: [DynamicTemplateDirective,] }],
|
|
124
|
-
onStatusChange: [{ type: Output }],
|
|
125
|
-
onValueChange: [{ type: Output }],
|
|
126
|
-
onSubmit: [{ type: Output }],
|
|
127
|
-
ngForm: [{ type: ViewChild, args: [NgForm,] }]
|
|
128
|
-
};
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    EventEmitter,\n    Inject,\n    Input,\n    OnChanges,\n    Output,\n    QueryList,\n    SimpleChanges, ViewChild,\n    ViewChildren\n} from \"@angular/core\";\nimport {FormArray, FormGroup, NgForm} from \"@angular/forms\";\nimport {Subscription} from \"rxjs\";\nimport {first} from \"rxjs/operators\";\nimport {\n    DynamicFormArrayModel,\n    DynamicFormComponent,\n    DynamicFormComponentService,\n    DynamicFormControlEvent,\n    DynamicFormLayout,\n    DynamicFormModel,\n    DynamicTemplateDirective\n} from \"@ng-dynamic-forms/core\";\nimport {EventsService, ObservableUtils} from \"@stemy/ngx-utils\";\nimport {DynamicFormState, IDynamicForm, IDynamicFormBase} from \"../../common-types\";\nimport {DynamicFormService} from \"../../services/dynamic-form.service\";\n\n@Component({\n    selector: \"dynamic-base-form\",\n    template: \"\",\n    changeDetection: ChangeDetectionStrategy.Default\n})\nexport class DynamicBaseFormComponent extends DynamicFormComponent implements OnChanges, AfterViewInit, IDynamicForm {\n\n    @Input() group: FormGroup;\n    @Input() model: DynamicFormModel;\n    @Input() layout: DynamicFormLayout;\n    @Input() labelPrefix: string;\n\n    @Output() blur: EventEmitter<DynamicFormControlEvent>;\n    @Output() change: EventEmitter<DynamicFormControlEvent>;\n    @Output() focus: EventEmitter<DynamicFormControlEvent>;\n\n    @ContentChildren(DynamicTemplateDirective) contentTemplates: QueryList<DynamicTemplateDirective>;\n    @ViewChildren(DynamicTemplateDirective) viewTemplates: QueryList<DynamicTemplateDirective>;\n\n    get status(): DynamicFormState {\n        return !this.group ? null : this.group.status as DynamicFormState;\n    }\n\n    @Output() readonly onStatusChange: EventEmitter<IDynamicFormBase>;\n    @Output() readonly onValueChange: EventEmitter<IDynamicFormBase>;\n    @Output() readonly onSubmit: EventEmitter<IDynamicFormBase>;\n\n    @ViewChild(NgForm)\n    protected ngForm: NgForm;\n    protected subscription: Subscription;\n    protected groupSubscription: Subscription;\n\n    constructor(@Inject(DynamicFormService) readonly formService: DynamicFormService,\n                @Inject(EventsService) readonly events: EventsService,\n                changeDetectorRef: ChangeDetectorRef,\n                componentService: DynamicFormComponentService,) {\n        super(changeDetectorRef, componentService);\n        this.blur = new EventEmitter<DynamicFormControlEvent>();\n        this.change = new EventEmitter<DynamicFormControlEvent>();\n        this.focus = new EventEmitter<DynamicFormControlEvent>();\n        this.onStatusChange = new EventEmitter<IDynamicFormBase>();\n        this.onValueChange = new EventEmitter<IDynamicFormBase>();\n        this.onSubmit = new EventEmitter<IDynamicFormBase>();\n        this.templates = new QueryList<DynamicTemplateDirective>();\n        this.subscription = new Subscription();\n        this.groupSubscription = new Subscription();\n        this.labelPrefix = \"label\";\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.groupSubscription.unsubscribe();\n        if (this.group) {\n            this.groupSubscription = ObservableUtils.multiSubscription(\n                this.group.statusChanges.subscribe(() => {\n                    this.onStatusChange.emit(this);\n                }),\n                this.group.valueChanges.subscribe(() => {\n                    this.onValueChange.emit(this);\n                    this.formService.notifyChanges(this.model, this.group);\n                })\n            );\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.subscription = ObservableUtils.multiSubscription(\n            ObservableUtils.subscribe(\n                {\n                    subjects: [this.contentTemplates.changes, this.viewTemplates.changes],\n                    cb: () => {\n                        const templates = this.contentTemplates.toArray().concat(this.viewTemplates.toArray());\n                        this.templates.reset(templates);\n                    }\n                }\n            ),\n            this.events.languageChanged.subscribe(() => {\n                this.formService.detectChanges(this)\n            }),\n            this.ngForm.ngSubmit.subscribe(() => {\n                this.onSubmit.emit(this);\n            })\n        );\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.subscription.unsubscribe();\n        this.groupSubscription.unsubscribe();\n    }\n\n    insertFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\n        this.formService.insertFormArrayGroup(index, formArray, formArrayModel);\n        this.changeDetectorRef.detectChanges();\n    }\n\n    removeFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\n        this.formService.removeFormArrayGroup(index, formArray, formArrayModel);\n        this.changeDetectorRef.detectChanges();\n    }\n\n    moveFormArrayGroup(index: number, step: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\n        this.formService.moveFormArrayGroup(index, step, formArray, formArrayModel);\n        this.changeDetectorRef.detectChanges();\n    }\n\n    clearFormArray(formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\n        this.formService.clearFormArray(formArray, formArrayModel);\n        this.changeDetectorRef.detectChanges();\n    }\n\n    validate(showErrors: boolean = true): Promise<any> {\n        if (!this.group) return Promise.resolve();\n        return new Promise<any>((resolve, reject) => {\n            this.group.statusChanges.pipe(first(status => status == \"VALID\" || status == \"INVALID\")).subscribe(status => {\n                if (showErrors) {\n                    this.formService.showErrors(this);\n                }\n                if (status == \"VALID\") {\n                    resolve(null);\n                    return;\n                }\n                reject(null);\n            });\n            this.group.updateValueAndValidity();\n        });\n    }\n\n    async serialize(validate?: boolean): Promise<any> {\n        if (!this.group) return null;\n        if (validate) {\n            await this.validate();\n        }\n        return await this.formService.serialize(this.model, this.group);\n    }\n}\n"]}
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, EventEmitter, Inject, Input, Output, QueryList, ViewChild, ViewChildren } from "@angular/core";
|
|
3
|
+
import { NgForm } from "@angular/forms";
|
|
4
|
+
import { Subscription } from "rxjs";
|
|
5
|
+
import { first } from "rxjs/operators";
|
|
6
|
+
import { DynamicFormComponent, DynamicFormComponentService, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
7
|
+
import { EventsService, ObservableUtils } from "@stemy/ngx-utils";
|
|
8
|
+
import { DynamicFormService } from "../../services/dynamic-form.service";
|
|
9
|
+
export class DynamicBaseFormComponent extends DynamicFormComponent {
|
|
10
|
+
constructor(formService, events, changeDetectorRef, componentService) {
|
|
11
|
+
super(changeDetectorRef, componentService);
|
|
12
|
+
this.formService = formService;
|
|
13
|
+
this.events = events;
|
|
14
|
+
this.blur = new EventEmitter();
|
|
15
|
+
this.change = new EventEmitter();
|
|
16
|
+
this.focus = new EventEmitter();
|
|
17
|
+
this.onStatusChange = new EventEmitter();
|
|
18
|
+
this.onValueChange = new EventEmitter();
|
|
19
|
+
this.onSubmit = new EventEmitter();
|
|
20
|
+
this.templates = new QueryList();
|
|
21
|
+
this.subscription = new Subscription();
|
|
22
|
+
this.groupSubscription = new Subscription();
|
|
23
|
+
this.labelPrefix = "label";
|
|
24
|
+
}
|
|
25
|
+
get status() {
|
|
26
|
+
return !this.group ? null : this.group.status;
|
|
27
|
+
}
|
|
28
|
+
ngOnChanges(changes) {
|
|
29
|
+
this.groupSubscription.unsubscribe();
|
|
30
|
+
if (this.group) {
|
|
31
|
+
this.groupSubscription = ObservableUtils.multiSubscription(this.group.statusChanges.subscribe(() => {
|
|
32
|
+
this.onStatusChange.emit(this);
|
|
33
|
+
}), this.group.valueChanges.subscribe(() => {
|
|
34
|
+
this.onValueChange.emit(this);
|
|
35
|
+
this.formService.notifyChanges(this.model, this.group);
|
|
36
|
+
}));
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
ngAfterViewInit() {
|
|
40
|
+
this.subscription = ObservableUtils.multiSubscription(ObservableUtils.subscribe({
|
|
41
|
+
subjects: [this.contentTemplates.changes, this.viewTemplates.changes],
|
|
42
|
+
cb: () => {
|
|
43
|
+
const templates = this.contentTemplates.toArray().concat(this.viewTemplates.toArray());
|
|
44
|
+
this.templates.reset(templates);
|
|
45
|
+
}
|
|
46
|
+
}), this.events.languageChanged.subscribe(() => {
|
|
47
|
+
this.formService.detectChanges(this);
|
|
48
|
+
}), this.ngForm.ngSubmit.subscribe(() => {
|
|
49
|
+
this.onSubmit.emit(this);
|
|
50
|
+
}));
|
|
51
|
+
}
|
|
52
|
+
ngOnDestroy() {
|
|
53
|
+
super.ngOnDestroy();
|
|
54
|
+
this.subscription.unsubscribe();
|
|
55
|
+
this.groupSubscription.unsubscribe();
|
|
56
|
+
}
|
|
57
|
+
insertFormArrayGroup(index, formArray, formArrayModel) {
|
|
58
|
+
this.formService.insertFormArrayGroup(index, formArray, formArrayModel);
|
|
59
|
+
this.changeDetectorRef.detectChanges();
|
|
60
|
+
}
|
|
61
|
+
removeFormArrayGroup(index, formArray, formArrayModel) {
|
|
62
|
+
this.formService.removeFormArrayGroup(index, formArray, formArrayModel);
|
|
63
|
+
this.changeDetectorRef.detectChanges();
|
|
64
|
+
}
|
|
65
|
+
moveFormArrayGroup(index, step, formArray, formArrayModel) {
|
|
66
|
+
this.formService.moveFormArrayGroup(index, step, formArray, formArrayModel);
|
|
67
|
+
this.changeDetectorRef.detectChanges();
|
|
68
|
+
}
|
|
69
|
+
clearFormArray(formArray, formArrayModel) {
|
|
70
|
+
this.formService.clearFormArray(formArray, formArrayModel);
|
|
71
|
+
this.changeDetectorRef.detectChanges();
|
|
72
|
+
}
|
|
73
|
+
validate(showErrors = true) {
|
|
74
|
+
if (!this.group)
|
|
75
|
+
return Promise.resolve();
|
|
76
|
+
return new Promise((resolve, reject) => {
|
|
77
|
+
this.group.statusChanges.pipe(first(status => status == "VALID" || status == "INVALID")).subscribe(status => {
|
|
78
|
+
if (showErrors) {
|
|
79
|
+
this.formService.showErrors(this);
|
|
80
|
+
}
|
|
81
|
+
if (status == "VALID") {
|
|
82
|
+
resolve(null);
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
reject(null);
|
|
86
|
+
});
|
|
87
|
+
this.group.updateValueAndValidity();
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
serialize(validate) {
|
|
91
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
92
|
+
if (!this.group)
|
|
93
|
+
return null;
|
|
94
|
+
if (validate) {
|
|
95
|
+
yield this.validate();
|
|
96
|
+
}
|
|
97
|
+
return yield this.formService.serialize(this.model, this.group);
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
DynamicBaseFormComponent.decorators = [
|
|
102
|
+
{ type: Component, args: [{
|
|
103
|
+
selector: "dynamic-base-form",
|
|
104
|
+
template: "",
|
|
105
|
+
changeDetection: ChangeDetectionStrategy.Default
|
|
106
|
+
},] }
|
|
107
|
+
];
|
|
108
|
+
DynamicBaseFormComponent.ctorParameters = () => [
|
|
109
|
+
{ type: DynamicFormService, decorators: [{ type: Inject, args: [DynamicFormService,] }] },
|
|
110
|
+
{ type: EventsService, decorators: [{ type: Inject, args: [EventsService,] }] },
|
|
111
|
+
{ type: ChangeDetectorRef },
|
|
112
|
+
{ type: DynamicFormComponentService }
|
|
113
|
+
];
|
|
114
|
+
DynamicBaseFormComponent.propDecorators = {
|
|
115
|
+
group: [{ type: Input }],
|
|
116
|
+
model: [{ type: Input }],
|
|
117
|
+
layout: [{ type: Input }],
|
|
118
|
+
labelPrefix: [{ type: Input }],
|
|
119
|
+
blur: [{ type: Output }],
|
|
120
|
+
change: [{ type: Output }],
|
|
121
|
+
focus: [{ type: Output }],
|
|
122
|
+
contentTemplates: [{ type: ContentChildren, args: [DynamicTemplateDirective,] }],
|
|
123
|
+
viewTemplates: [{ type: ViewChildren, args: [DynamicTemplateDirective,] }],
|
|
124
|
+
onStatusChange: [{ type: Output }],
|
|
125
|
+
onValueChange: [{ type: Output }],
|
|
126
|
+
onSubmit: [{ type: Output }],
|
|
127
|
+
ngForm: [{ type: ViewChild, args: [NgForm,] }]
|
|
128
|
+
};
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ContentChildren,\r\n    EventEmitter,\r\n    Inject,\r\n    Input,\r\n    OnChanges,\r\n    Output,\r\n    QueryList,\r\n    SimpleChanges, ViewChild,\r\n    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormArray, FormGroup, NgForm} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {first} from \"rxjs/operators\";\r\nimport {\r\n    DynamicFormArrayModel,\r\n    DynamicFormComponent,\r\n    DynamicFormComponentService,\r\n    DynamicFormControlEvent,\r\n    DynamicFormLayout,\r\n    DynamicFormModel,\r\n    DynamicTemplateDirective\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {EventsService, ObservableUtils} from \"@stemy/ngx-utils\";\r\nimport {DynamicFormState, IDynamicForm, IDynamicFormBase} from \"../../common-types\";\r\nimport {DynamicFormService} from \"../../services/dynamic-form.service\";\r\n\r\n@Component({\r\n    selector: \"dynamic-base-form\",\r\n    template: \"\",\r\n    changeDetection: ChangeDetectionStrategy.Default\r\n})\r\nexport class DynamicBaseFormComponent extends DynamicFormComponent implements OnChanges, AfterViewInit, IDynamicForm {\r\n\r\n    @Input() group: FormGroup;\r\n    @Input() model: DynamicFormModel;\r\n    @Input() layout: DynamicFormLayout;\r\n    @Input() labelPrefix: string;\r\n\r\n    @Output() blur: EventEmitter<DynamicFormControlEvent>;\r\n    @Output() change: EventEmitter<DynamicFormControlEvent>;\r\n    @Output() focus: EventEmitter<DynamicFormControlEvent>;\r\n\r\n    @ContentChildren(DynamicTemplateDirective) contentTemplates: QueryList<DynamicTemplateDirective>;\r\n    @ViewChildren(DynamicTemplateDirective) viewTemplates: QueryList<DynamicTemplateDirective>;\r\n\r\n    get status(): DynamicFormState {\r\n        return !this.group ? null : this.group.status as DynamicFormState;\r\n    }\r\n\r\n    @Output() readonly onStatusChange: EventEmitter<IDynamicFormBase>;\r\n    @Output() readonly onValueChange: EventEmitter<IDynamicFormBase>;\r\n    @Output() readonly onSubmit: EventEmitter<IDynamicFormBase>;\r\n\r\n    @ViewChild(NgForm)\r\n    protected ngForm: NgForm;\r\n    protected subscription: Subscription;\r\n    protected groupSubscription: Subscription;\r\n\r\n    constructor(@Inject(DynamicFormService) readonly formService: DynamicFormService,\r\n                @Inject(EventsService) readonly events: EventsService,\r\n                changeDetectorRef: ChangeDetectorRef,\r\n                componentService: DynamicFormComponentService,) {\r\n        super(changeDetectorRef, componentService);\r\n        this.blur = new EventEmitter<DynamicFormControlEvent>();\r\n        this.change = new EventEmitter<DynamicFormControlEvent>();\r\n        this.focus = new EventEmitter<DynamicFormControlEvent>();\r\n        this.onStatusChange = new EventEmitter<IDynamicFormBase>();\r\n        this.onValueChange = new EventEmitter<IDynamicFormBase>();\r\n        this.onSubmit = new EventEmitter<IDynamicFormBase>();\r\n        this.templates = new QueryList<DynamicTemplateDirective>();\r\n        this.subscription = new Subscription();\r\n        this.groupSubscription = new Subscription();\r\n        this.labelPrefix = \"label\";\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        this.groupSubscription.unsubscribe();\r\n        if (this.group) {\r\n            this.groupSubscription = ObservableUtils.multiSubscription(\r\n                this.group.statusChanges.subscribe(() => {\r\n                    this.onStatusChange.emit(this);\r\n                }),\r\n                this.group.valueChanges.subscribe(() => {\r\n                    this.onValueChange.emit(this);\r\n                    this.formService.notifyChanges(this.model, this.group);\r\n                })\r\n            );\r\n        }\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        this.subscription = ObservableUtils.multiSubscription(\r\n            ObservableUtils.subscribe(\r\n                {\r\n                    subjects: [this.contentTemplates.changes, this.viewTemplates.changes],\r\n                    cb: () => {\r\n                        const templates = this.contentTemplates.toArray().concat(this.viewTemplates.toArray());\r\n                        this.templates.reset(templates);\r\n                    }\r\n                }\r\n            ),\r\n            this.events.languageChanged.subscribe(() => {\r\n                this.formService.detectChanges(this)\r\n            }),\r\n            this.ngForm.ngSubmit.subscribe(() => {\r\n                this.onSubmit.emit(this);\r\n            })\r\n        );\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.subscription.unsubscribe();\r\n        this.groupSubscription.unsubscribe();\r\n    }\r\n\r\n    insertFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.insertFormArrayGroup(index, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    removeFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.removeFormArrayGroup(index, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    moveFormArrayGroup(index: number, step: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.moveFormArrayGroup(index, step, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    clearFormArray(formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.clearFormArray(formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    validate(showErrors: boolean = true): Promise<any> {\r\n        if (!this.group) return Promise.resolve();\r\n        return new Promise<any>((resolve, reject) => {\r\n            this.group.statusChanges.pipe(first(status => status == \"VALID\" || status == \"INVALID\")).subscribe(status => {\r\n                if (showErrors) {\r\n                    this.formService.showErrors(this);\r\n                }\r\n                if (status == \"VALID\") {\r\n                    resolve(null);\r\n                    return;\r\n                }\r\n                reject(null);\r\n            });\r\n            this.group.updateValueAndValidity();\r\n        });\r\n    }\r\n\r\n    async serialize(validate?: boolean): Promise<any> {\r\n        if (!this.group) return null;\r\n        if (validate) {\r\n            await this.validate();\r\n        }\r\n        return await this.formService.serialize(this.model, this.group);\r\n    }\r\n}\r\n"]}
|
|
@@ -1,100 +1,100 @@
|
|
|
1
|
-
import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, Output, Renderer2 } from "@angular/core";
|
|
2
|
-
import { TOASTER_SERVICE } from "@stemy/ngx-utils";
|
|
3
|
-
export class AsyncSubmitDirective {
|
|
4
|
-
constructor(toaster, cdr, elem, renderer) {
|
|
5
|
-
this.toaster = toaster;
|
|
6
|
-
this.cdr = cdr;
|
|
7
|
-
this.elem = elem;
|
|
8
|
-
this.renderer = renderer;
|
|
9
|
-
this.onSuccess = new EventEmitter();
|
|
10
|
-
this.onError = new EventEmitter();
|
|
11
|
-
if (elem.nativeElement.tagName !== "BUTTON")
|
|
12
|
-
return;
|
|
13
|
-
renderer.setAttribute(elem.nativeElement, "type", "button");
|
|
14
|
-
}
|
|
15
|
-
get isDisabled() {
|
|
16
|
-
return this.disabled;
|
|
17
|
-
}
|
|
18
|
-
set isDisabled(value) {
|
|
19
|
-
this.disabled = value;
|
|
20
|
-
if (value) {
|
|
21
|
-
this.renderer.setAttribute(this.elem.nativeElement, "disabled", "disabled");
|
|
22
|
-
return;
|
|
23
|
-
}
|
|
24
|
-
this.renderer.removeAttribute(this.elem.nativeElement, "disabled");
|
|
25
|
-
}
|
|
26
|
-
get isLoading() {
|
|
27
|
-
return this.loading;
|
|
28
|
-
}
|
|
29
|
-
ngOnInit() {
|
|
30
|
-
if (!this.form)
|
|
31
|
-
return;
|
|
32
|
-
this.isDisabled = this.form.status !== "VALID";
|
|
33
|
-
this.cdr.detectChanges();
|
|
34
|
-
this.onStatusChange = this.form.onStatusChange.subscribe(() => {
|
|
35
|
-
this.isDisabled = this.form.status !== "VALID";
|
|
36
|
-
this.cdr.detectChanges();
|
|
37
|
-
if (!this.callback || this.form.status == "PENDING")
|
|
38
|
-
return;
|
|
39
|
-
if (!this.disabled) {
|
|
40
|
-
this.callback();
|
|
41
|
-
}
|
|
42
|
-
this.callback = null;
|
|
43
|
-
});
|
|
44
|
-
this.onSubmit = this.form.onSubmit.subscribe(() => this.callMethod());
|
|
45
|
-
}
|
|
46
|
-
ngOnDestroy() {
|
|
47
|
-
if (this.onStatusChange)
|
|
48
|
-
this.onStatusChange.unsubscribe();
|
|
49
|
-
if (this.onSubmit)
|
|
50
|
-
this.onSubmit.unsubscribe();
|
|
51
|
-
}
|
|
52
|
-
click() {
|
|
53
|
-
this.callback = () => this.callMethod();
|
|
54
|
-
if (this.form.status !== "VALID" && this.form.status !== "INVALID")
|
|
55
|
-
return;
|
|
56
|
-
this.callback();
|
|
57
|
-
this.callback = null;
|
|
58
|
-
}
|
|
59
|
-
callMethod() {
|
|
60
|
-
if (this.loading)
|
|
61
|
-
return;
|
|
62
|
-
this.loading = true;
|
|
63
|
-
this.method(this.form, this.context).then(result => {
|
|
64
|
-
this.loading = false;
|
|
65
|
-
if (result) {
|
|
66
|
-
this.onSuccess.emit(result);
|
|
67
|
-
this.toaster.success(result.message, result.context);
|
|
68
|
-
}
|
|
69
|
-
}, reason => {
|
|
70
|
-
if (!reason || !reason.message)
|
|
71
|
-
throw new Error("Reason must implement IAsyncMessage interface");
|
|
72
|
-
this.loading = false;
|
|
73
|
-
this.onError.emit(reason);
|
|
74
|
-
this.toaster.error(reason.message, reason.context);
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
AsyncSubmitDirective.decorators = [
|
|
79
|
-
{ type: Directive, args: [{
|
|
80
|
-
selector: "[async-submit]",
|
|
81
|
-
exportAs: "async-submit"
|
|
82
|
-
},] }
|
|
83
|
-
];
|
|
84
|
-
AsyncSubmitDirective.ctorParameters = () => [
|
|
85
|
-
{ type: undefined, decorators: [{ type: Inject, args: [TOASTER_SERVICE,] }] },
|
|
86
|
-
{ type: ChangeDetectorRef },
|
|
87
|
-
{ type: ElementRef },
|
|
88
|
-
{ type: Renderer2 }
|
|
89
|
-
];
|
|
90
|
-
AsyncSubmitDirective.propDecorators = {
|
|
91
|
-
method: [{ type: Input, args: ["async-submit",] }],
|
|
92
|
-
form: [{ type: Input }],
|
|
93
|
-
context: [{ type: Input }],
|
|
94
|
-
onSuccess: [{ type: Output }],
|
|
95
|
-
onError: [{ type: Output }],
|
|
96
|
-
isDisabled: [{ type: HostBinding, args: ["class.disabled",] }],
|
|
97
|
-
isLoading: [{ type: HostBinding, args: ["class.loading",] }],
|
|
98
|
-
click: [{ type: HostListener, args: ["click",] }]
|
|
99
|
-
};
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, Output, Renderer2 } from "@angular/core";
|
|
2
|
+
import { TOASTER_SERVICE } from "@stemy/ngx-utils";
|
|
3
|
+
export class AsyncSubmitDirective {
|
|
4
|
+
constructor(toaster, cdr, elem, renderer) {
|
|
5
|
+
this.toaster = toaster;
|
|
6
|
+
this.cdr = cdr;
|
|
7
|
+
this.elem = elem;
|
|
8
|
+
this.renderer = renderer;
|
|
9
|
+
this.onSuccess = new EventEmitter();
|
|
10
|
+
this.onError = new EventEmitter();
|
|
11
|
+
if (elem.nativeElement.tagName !== "BUTTON")
|
|
12
|
+
return;
|
|
13
|
+
renderer.setAttribute(elem.nativeElement, "type", "button");
|
|
14
|
+
}
|
|
15
|
+
get isDisabled() {
|
|
16
|
+
return this.disabled;
|
|
17
|
+
}
|
|
18
|
+
set isDisabled(value) {
|
|
19
|
+
this.disabled = value;
|
|
20
|
+
if (value) {
|
|
21
|
+
this.renderer.setAttribute(this.elem.nativeElement, "disabled", "disabled");
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
this.renderer.removeAttribute(this.elem.nativeElement, "disabled");
|
|
25
|
+
}
|
|
26
|
+
get isLoading() {
|
|
27
|
+
return this.loading;
|
|
28
|
+
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
if (!this.form)
|
|
31
|
+
return;
|
|
32
|
+
this.isDisabled = this.form.status !== "VALID";
|
|
33
|
+
this.cdr.detectChanges();
|
|
34
|
+
this.onStatusChange = this.form.onStatusChange.subscribe(() => {
|
|
35
|
+
this.isDisabled = this.form.status !== "VALID";
|
|
36
|
+
this.cdr.detectChanges();
|
|
37
|
+
if (!this.callback || this.form.status == "PENDING")
|
|
38
|
+
return;
|
|
39
|
+
if (!this.disabled) {
|
|
40
|
+
this.callback();
|
|
41
|
+
}
|
|
42
|
+
this.callback = null;
|
|
43
|
+
});
|
|
44
|
+
this.onSubmit = this.form.onSubmit.subscribe(() => this.callMethod());
|
|
45
|
+
}
|
|
46
|
+
ngOnDestroy() {
|
|
47
|
+
if (this.onStatusChange)
|
|
48
|
+
this.onStatusChange.unsubscribe();
|
|
49
|
+
if (this.onSubmit)
|
|
50
|
+
this.onSubmit.unsubscribe();
|
|
51
|
+
}
|
|
52
|
+
click() {
|
|
53
|
+
this.callback = () => this.callMethod();
|
|
54
|
+
if (this.form.status !== "VALID" && this.form.status !== "INVALID")
|
|
55
|
+
return;
|
|
56
|
+
this.callback();
|
|
57
|
+
this.callback = null;
|
|
58
|
+
}
|
|
59
|
+
callMethod() {
|
|
60
|
+
if (this.loading)
|
|
61
|
+
return;
|
|
62
|
+
this.loading = true;
|
|
63
|
+
this.method(this.form, this.context).then(result => {
|
|
64
|
+
this.loading = false;
|
|
65
|
+
if (result) {
|
|
66
|
+
this.onSuccess.emit(result);
|
|
67
|
+
this.toaster.success(result.message, result.context);
|
|
68
|
+
}
|
|
69
|
+
}, reason => {
|
|
70
|
+
if (!reason || !reason.message)
|
|
71
|
+
throw new Error("Reason must implement IAsyncMessage interface");
|
|
72
|
+
this.loading = false;
|
|
73
|
+
this.onError.emit(reason);
|
|
74
|
+
this.toaster.error(reason.message, reason.context);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
AsyncSubmitDirective.decorators = [
|
|
79
|
+
{ type: Directive, args: [{
|
|
80
|
+
selector: "[async-submit]",
|
|
81
|
+
exportAs: "async-submit"
|
|
82
|
+
},] }
|
|
83
|
+
];
|
|
84
|
+
AsyncSubmitDirective.ctorParameters = () => [
|
|
85
|
+
{ type: undefined, decorators: [{ type: Inject, args: [TOASTER_SERVICE,] }] },
|
|
86
|
+
{ type: ChangeDetectorRef },
|
|
87
|
+
{ type: ElementRef },
|
|
88
|
+
{ type: Renderer2 }
|
|
89
|
+
];
|
|
90
|
+
AsyncSubmitDirective.propDecorators = {
|
|
91
|
+
method: [{ type: Input, args: ["async-submit",] }],
|
|
92
|
+
form: [{ type: Input }],
|
|
93
|
+
context: [{ type: Input }],
|
|
94
|
+
onSuccess: [{ type: Output }],
|
|
95
|
+
onError: [{ type: Output }],
|
|
96
|
+
isDisabled: [{ type: HostBinding, args: ["class.disabled",] }],
|
|
97
|
+
isLoading: [{ type: HostBinding, args: ["class.loading",] }],
|
|
98
|
+
click: [{ type: HostListener, args: ["click",] }]
|
|
99
|
+
};
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-submit.directive.js","sourceRoot":"","sources":["../../../../src/ngx-dynamic-form/directives/async-submit.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectorRef,\r\n    Directive,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostBinding,\r\n    HostListener,\r\n    Inject,\r\n    Input,\r\n    OnDestroy,\r\n    OnInit,\r\n    Output,\r\n    Renderer2\r\n} from \"@angular/core\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {IAsyncMessage, IToasterService, TOASTER_SERVICE} from \"@stemy/ngx-utils\";\r\nimport {AsyncSubmitMethod, IDynamicFormBase} from \"../common-types\";\r\n\r\n@Directive({\r\n    selector: \"[async-submit]\",\r\n    exportAs: \"async-submit\"\r\n})\r\nexport class AsyncSubmitDirective implements OnInit, OnDestroy {\r\n\r\n    @Input(\"async-submit\") method: AsyncSubmitMethod;\r\n    @Input() form: IDynamicFormBase;\r\n    @Input() context: any;\r\n\r\n    @Output() onSuccess: EventEmitter<IAsyncMessage>;\r\n    @Output() onError: EventEmitter<IAsyncMessage>;\r\n\r\n    private loading: boolean;\r\n    private disabled: boolean;\r\n    private callback: Function;\r\n    private onStatusChange: Subscription;\r\n    private onSubmit: Subscription;\r\n\r\n    @HostBinding(\"class.disabled\")\r\n    get isDisabled(): boolean {\r\n        return this.disabled;\r\n    }\r\n\r\n    set isDisabled(value: boolean) {\r\n        this.disabled = value;\r\n        if (value) {\r\n            this.renderer.setAttribute(this.elem.nativeElement, \"disabled\", \"disabled\");\r\n            return;\r\n        }\r\n        this.renderer.removeAttribute(this.elem.nativeElement, \"disabled\");\r\n    }\r\n\r\n    @HostBinding(\"class.loading\")\r\n    get isLoading(): boolean {\r\n        return this.loading;\r\n    }\r\n\r\n    constructor(@Inject(TOASTER_SERVICE) private toaster: IToasterService,\r\n                readonly cdr: ChangeDetectorRef,\r\n                readonly elem: ElementRef,\r\n                readonly renderer: Renderer2) {\r\n        this.onSuccess = new EventEmitter<IAsyncMessage>();\r\n        this.onError = new EventEmitter<IAsyncMessage>();\r\n        if (elem.nativeElement.tagName !== \"BUTTON\") return;\r\n        renderer.setAttribute(elem.nativeElement, \"type\", \"button\");\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (!this.form) return;\r\n        this.isDisabled = this.form.status !== \"VALID\";\r\n        this.cdr.detectChanges();\r\n        this.onStatusChange = this.form.onStatusChange.subscribe(() => {\r\n            this.isDisabled = this.form.status !== \"VALID\";\r\n            this.cdr.detectChanges();\r\n            if (!this.callback || this.form.status == \"PENDING\") return;\r\n            if (!this.disabled) {\r\n                this.callback();\r\n            }\r\n            this.callback = null;\r\n        });\r\n        this.onSubmit = this.form.onSubmit.subscribe(() => this.callMethod());\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.onStatusChange) this.onStatusChange.unsubscribe();\r\n        if (this.onSubmit) this.onSubmit.unsubscribe();\r\n    }\r\n\r\n    @HostListener(\"click\")\r\n    click(): void {\r\n        this.callback = () => this.callMethod();\r\n        if (this.form.status !== \"VALID\" && this.form.status !== \"INVALID\") return;\r\n        this.callback();\r\n        this.callback = null;\r\n    }\r\n\r\n    callMethod(): void {\r\n        if (this.loading) return;\r\n        this.loading = true;\r\n        this.method(this.form, this.context).then(result => {\r\n            this.loading = false;\r\n            if (result) {\r\n                this.onSuccess.emit(result);\r\n                this.toaster.success(result.message, result.context);\r\n            }\r\n        }, reason => {\r\n            if (!reason || !reason.message)\r\n                throw new Error(\"Reason must implement IAsyncMessage interface\");\r\n            this.loading = false;\r\n            this.onError.emit(reason);\r\n            this.toaster.error(reason.message, reason.context);\r\n        });\r\n    }\r\n}\r\n"]}
|