@stemy/ngx-dynamic-form 19.1.13 → 19.2.0
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/fesm2022/stemy-ngx-dynamic-form-ui-nebular.mjs +4 -4
- package/fesm2022/stemy-ngx-dynamic-form-ui-nebular.mjs.map +1 -1
- package/fesm2022/stemy-ngx-dynamic-form.mjs +859 -1662
- package/fesm2022/stemy-ngx-dynamic-form.mjs.map +1 -1
- package/ngx-dynamic-form/common-types.d.ts +109 -26
- package/ngx-dynamic-form/components/dynamic-form/dynamic-form.component.d.ts +21 -0
- package/ngx-dynamic-form/components/dynamic-form-array/dynamic-form-array.component.d.ts +9 -0
- package/ngx-dynamic-form/components/dynamic-form-chips/dynamic-form-chips.component.d.ts +7 -0
- package/ngx-dynamic-form/components/dynamic-form-field/dynamic-form-field.component.d.ts +6 -0
- package/ngx-dynamic-form/components/dynamic-form-fieldset/dynamic-form-fieldset.component.d.ts +7 -0
- package/ngx-dynamic-form/components/dynamic-form-group/dynamic-form-group.component.d.ts +6 -0
- package/ngx-dynamic-form/components/dynamic-form-upload/dynamic-form-upload.component.d.ts +7 -0
- package/ngx-dynamic-form/directives/async-submit.directive.d.ts +17 -23
- package/ngx-dynamic-form/ngx-dynamic-form.imports.d.ts +5 -9
- package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +13 -11
- package/ngx-dynamic-form/services/dynamic-form-builder.service.d.ts +27 -0
- package/ngx-dynamic-form/services/dynamic-form.service.d.ts +28 -46
- package/ngx-dynamic-form/utils/customizer.d.ts +5 -12
- package/ngx-dynamic-form/utils/decorators.d.ts +10 -0
- package/ngx-dynamic-form/utils/misc.d.ts +2 -4
- package/ngx-dynamic-form/utils/validation.d.ts +13 -0
- package/package.json +21 -16
- package/public_api.d.ts +13 -18
- package/ui-nebular/index.d.ts +1 -5
- package/common-types.d.ts +0 -37
- package/components/base/dynamic-base-form-array.component.d.ts +0 -38
- package/components/base/dynamic-base-form-control-container.component.d.ts +0 -39
- package/components/base/dynamic-base-form-control.component.d.ts +0 -26
- package/components/base/dynamic-base-form-group.component.d.ts +0 -25
- package/components/base/dynamic-base-form.component.d.ts +0 -46
- package/components/base/dynamic-base-select.component.d.ts +0 -15
- package/directives/async-submit.directive.d.ts +0 -31
- package/esm2020/ngx-dynamic-form/common-types.mjs +0 -2
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-array.component.mjs +0 -104
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.mjs +0 -127
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control.component.mjs +0 -57
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-group.component.mjs +0 -75
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form.component.mjs +0 -182
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-select.component.mjs +0 -66
- package/esm2020/ngx-dynamic-form/directives/async-submit.directive.mjs +0 -116
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.imports.mjs +0 -26
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.module.mjs +0 -116
- package/esm2020/ngx-dynamic-form/services/dynamic-form.service.mjs +0 -615
- package/esm2020/ngx-dynamic-form/utils/creators.mjs +0 -67
- package/esm2020/ngx-dynamic-form/utils/customizer.mjs +0 -28
- package/esm2020/ngx-dynamic-form/utils/dynamic-editor.model.mjs +0 -14
- package/esm2020/ngx-dynamic-form/utils/dynamic-form-array.model.mjs +0 -128
- package/esm2020/ngx-dynamic-form/utils/dynamic-form-group.model.mjs +0 -26
- package/esm2020/ngx-dynamic-form/utils/dynamic-select.model.mjs +0 -59
- package/esm2020/ngx-dynamic-form/utils/form-select-subject.mjs +0 -26
- package/esm2020/ngx-dynamic-form/utils/form-subject.mjs +0 -29
- package/esm2020/ngx-dynamic-form/utils/misc.mjs +0 -47
- package/esm2020/ngx-dynamic-form/utils/validation-errors.mjs +0 -22
- package/esm2020/ngx-dynamic-form/utils/validators.mjs +0 -56
- package/esm2020/public_api.mjs +0 -21
- package/esm2020/stemy-ngx-dynamic-form.mjs +0 -5
- package/fesm2015/stemy-ngx-dynamic-form.mjs +0 -1927
- package/fesm2015/stemy-ngx-dynamic-form.mjs.map +0 -1
- package/fesm2020/stemy-ngx-dynamic-form.mjs +0 -1893
- package/fesm2020/stemy-ngx-dynamic-form.mjs.map +0 -1
- package/fesm2022/stemy-ngx-dynamic-form-src-ngx-dynamic-form-nebular.mjs +0 -50
- package/fesm2022/stemy-ngx-dynamic-form-src-ngx-dynamic-form-nebular.mjs.map +0 -1
- package/imports.d.ts +0 -12
- package/ngx-dynamic-form/components/base/dynamic-base-form-array.component.d.ts +0 -38
- package/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.d.ts +0 -39
- package/ngx-dynamic-form/components/base/dynamic-base-form-control.component.d.ts +0 -26
- package/ngx-dynamic-form/components/base/dynamic-base-form-group.component.d.ts +0 -25
- package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +0 -46
- package/ngx-dynamic-form/components/base/dynamic-base-select.component.d.ts +0 -15
- package/ngx-dynamic-form/services/dynamic-form-layout.service.d.ts +0 -7
- package/ngx-dynamic-form/utils/creators.d.ts +0 -18
- package/ngx-dynamic-form/utils/dynamic-editor.model.d.ts +0 -11
- package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +0 -69
- package/ngx-dynamic-form/utils/dynamic-form-group.model.d.ts +0 -14
- package/ngx-dynamic-form/utils/dynamic-select.model.d.ts +0 -39
- package/ngx-dynamic-form/utils/form-select-subject.d.ts +0 -6
- package/ngx-dynamic-form/utils/form-subject.d.ts +0 -10
- package/ngx-dynamic-form/utils/validators.d.ts +0 -8
- package/ngx-dynamic-form.imports.d.ts +0 -12
- package/ngx-dynamic-form.module.d.ts +0 -21
- package/services/dynamic-form.service.d.ts +0 -61
- package/src/ngx-dynamic-form/nebular/imports.d.ts +0 -4
- package/src/ngx-dynamic-form/nebular/index.d.ts +0 -5
- package/src/ngx-dynamic-form/nebular/ngx-dynamic-form.nebular.module.d.ts +0 -9
- package/src/ngx-dynamic-form/nebular/public_api.d.ts +0 -1
- package/stemy-ngx-dynamic-form.d.ts +0 -5
- package/ui-nebular/public_api.d.ts +0 -1
- package/utils/creators.d.ts +0 -18
- package/utils/customizer.d.ts +0 -14
- package/utils/dynamic-editor.model.d.ts +0 -11
- package/utils/dynamic-form-array.model.d.ts +0 -69
- package/utils/dynamic-form-group.model.d.ts +0 -14
- package/utils/dynamic-select.model.d.ts +0 -39
- package/utils/form-select-subject.d.ts +0 -6
- package/utils/form-subject.d.ts +0 -10
- package/utils/misc.d.ts +0 -11
- package/utils/validation-errors.d.ts +0 -11
- package/utils/validators.d.ts +0 -8
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from "@angular/core";
|
|
2
|
-
import { debounceTime } from "rxjs/operators";
|
|
3
|
-
import { DynamicFormControlComponent } from "@ng-dynamic-forms/core";
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@ng-dynamic-forms/core";
|
|
6
|
-
import * as i2 from "./dynamic-base-form.component";
|
|
7
|
-
export class DynamicBaseFormControlComponent extends DynamicFormControlComponent {
|
|
8
|
-
constructor(layoutService, validationService, form, injector, cdr) {
|
|
9
|
-
super(layoutService, validationService);
|
|
10
|
-
this.form = form;
|
|
11
|
-
this.injector = injector;
|
|
12
|
-
this.cdr = cdr;
|
|
13
|
-
this.blur = new EventEmitter();
|
|
14
|
-
this.change = new EventEmitter();
|
|
15
|
-
this.focus = new EventEmitter();
|
|
16
|
-
}
|
|
17
|
-
ngAfterViewInit() {
|
|
18
|
-
this.subscription = this.control.valueChanges.pipe(debounceTime(500)).subscribe(value => {
|
|
19
|
-
this.onValueChanged(value);
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
ngOnDestroy() {
|
|
23
|
-
if (!this.subscription)
|
|
24
|
-
return;
|
|
25
|
-
this.subscription.unsubscribe();
|
|
26
|
-
}
|
|
27
|
-
submit() {
|
|
28
|
-
this.form.submit();
|
|
29
|
-
}
|
|
30
|
-
onValueChanged(value) {
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
DynamicBaseFormControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormControlComponent, deps: [{ token: i1.DynamicFormLayoutService }, { token: i1.DynamicFormValidationService }, { token: i2.DynamicBaseFormComponent }, { token: i0.Injector }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
34
|
-
DynamicBaseFormControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseFormControlComponent, selector: "dynamic-base-form-control", inputs: { formLayout: "formLayout", group: "group", layout: "layout", model: "model" }, outputs: { blur: "blur", change: "change", focus: "focus" }, usesInheritance: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
35
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormControlComponent, decorators: [{
|
|
36
|
-
type: Component,
|
|
37
|
-
args: [{
|
|
38
|
-
selector: "dynamic-base-form-control",
|
|
39
|
-
template: "",
|
|
40
|
-
changeDetection: ChangeDetectionStrategy.OnPush
|
|
41
|
-
}]
|
|
42
|
-
}], ctorParameters: function () { return [{ type: i1.DynamicFormLayoutService }, { type: i1.DynamicFormValidationService }, { type: i2.DynamicBaseFormComponent }, { type: i0.Injector }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { formLayout: [{
|
|
43
|
-
type: Input
|
|
44
|
-
}], group: [{
|
|
45
|
-
type: Input
|
|
46
|
-
}], layout: [{
|
|
47
|
-
type: Input
|
|
48
|
-
}], model: [{
|
|
49
|
-
type: Input
|
|
50
|
-
}], blur: [{
|
|
51
|
-
type: Output
|
|
52
|
-
}], change: [{
|
|
53
|
-
type: Output
|
|
54
|
-
}], focus: [{
|
|
55
|
-
type: Output
|
|
56
|
-
}] } });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1iYXNlLWZvcm0tY29udHJvbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbmd4LWR5bmFtaWMtZm9ybS9jb21wb25lbnRzL2Jhc2UvZHluYW1pYy1iYXNlLWZvcm0tY29udHJvbC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVILHVCQUF1QixFQUV2QixTQUFTLEVBQ1QsWUFBWSxFQUVaLEtBQUssRUFFTCxNQUFNLEVBQ1QsTUFBTSxlQUFlLENBQUM7QUFHdkIsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzVDLE9BQU8sRUFDSCwyQkFBMkIsRUFNOUIsTUFBTSx3QkFBd0IsQ0FBQzs7OztBQVFoQyxNQUFNLE9BQU8sK0JBQW1FLFNBQVEsMkJBQTJCO0lBYS9HLFlBQVksYUFBdUMsRUFBRSxpQkFBK0MsRUFDL0UsSUFBOEIsRUFBVyxRQUFrQixFQUFXLEdBQXNCO1FBQzdHLEtBQUssQ0FBQyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztRQUR2QixTQUFJLEdBQUosSUFBSSxDQUEwQjtRQUFXLGFBQVEsR0FBUixRQUFRLENBQVU7UUFBVyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUU3RyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFDcEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUN6QyxDQUFDO0lBRUQsZUFBZTtRQUNYLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNwRixJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVk7WUFBRSxPQUFPO1FBQy9CLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDcEMsQ0FBQztJQUVELE1BQU07UUFDRixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFUyxjQUFjLENBQUMsS0FBVTtJQUVuQyxDQUFDOzs0SEF0Q1EsK0JBQStCO2dIQUEvQiwrQkFBK0IsNk9BSDlCLEVBQUU7MkZBR0gsK0JBQStCO2tCQUwzQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSwyQkFBMkI7b0JBQ3JDLFFBQVEsRUFBRSxFQUFFO29CQUNaLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNsRDt3UEFHWSxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUVJLElBQUk7c0JBQWIsTUFBTTtnQkFDRyxNQUFNO3NCQUFmLE1BQU07Z0JBQ0csS0FBSztzQkFBZCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICAgIEFmdGVyVmlld0luaXQsXHJcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICAgIENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgQ29tcG9uZW50LFxyXG4gICAgRXZlbnRFbWl0dGVyLFxyXG4gICAgSW5qZWN0b3IsXHJcbiAgICBJbnB1dCxcclxuICAgIE9uRGVzdHJveSxcclxuICAgIE91dHB1dFxyXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Rm9ybUdyb3VwfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHtTdWJzY3JpcHRpb259IGZyb20gXCJyeGpzXCI7XHJcbmltcG9ydCB7ZGVib3VuY2VUaW1lfSBmcm9tIFwicnhqcy9vcGVyYXRvcnNcIjtcclxuaW1wb3J0IHtcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbENvbXBvbmVudCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbExheW91dCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbE1vZGVsLFxyXG4gICAgRHluYW1pY0Zvcm1MYXlvdXQsXHJcbiAgICBEeW5hbWljRm9ybUxheW91dFNlcnZpY2UsXHJcbiAgICBEeW5hbWljRm9ybVZhbGlkYXRpb25TZXJ2aWNlXHJcbn0gZnJvbSBcIkBuZy1keW5hbWljLWZvcm1zL2NvcmVcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Db21wb25lbnR9IGZyb20gXCIuL2R5bmFtaWMtYmFzZS1mb3JtLmNvbXBvbmVudFwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJkeW5hbWljLWJhc2UtZm9ybS1jb250cm9sXCIsXHJcbiAgICB0ZW1wbGF0ZTogXCJcIixcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEeW5hbWljQmFzZUZvcm1Db250cm9sQ29tcG9uZW50PFQgZXh0ZW5kcyBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbD4gZXh0ZW5kcyBEeW5hbWljRm9ybUNvbnRyb2xDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xyXG5cclxuICAgIEBJbnB1dCgpIGZvcm1MYXlvdXQ6IER5bmFtaWNGb3JtTGF5b3V0O1xyXG4gICAgQElucHV0KCkgZ3JvdXA6IEZvcm1Hcm91cDtcclxuICAgIEBJbnB1dCgpIGxheW91dDogRHluYW1pY0Zvcm1Db250cm9sTGF5b3V0O1xyXG4gICAgQElucHV0KCkgbW9kZWw6IFQ7XHJcblxyXG4gICAgQE91dHB1dCgpIGJsdXI6IEV2ZW50RW1pdHRlcjxhbnk+O1xyXG4gICAgQE91dHB1dCgpIGNoYW5nZTogRXZlbnRFbWl0dGVyPGFueT47XHJcbiAgICBAT3V0cHV0KCkgZm9jdXM6IEV2ZW50RW1pdHRlcjxhbnk+O1xyXG5cclxuICAgIHByb3RlY3RlZCBzdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihsYXlvdXRTZXJ2aWNlOiBEeW5hbWljRm9ybUxheW91dFNlcnZpY2UsIHZhbGlkYXRpb25TZXJ2aWNlOiBEeW5hbWljRm9ybVZhbGlkYXRpb25TZXJ2aWNlLFxyXG4gICAgICAgICAgICAgICAgcmVhZG9ubHkgZm9ybTogRHluYW1pY0Jhc2VGb3JtQ29tcG9uZW50LCByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IsIHJlYWRvbmx5IGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgICAgICBzdXBlcihsYXlvdXRTZXJ2aWNlLCB2YWxpZGF0aW9uU2VydmljZSk7XHJcbiAgICAgICAgdGhpcy5ibHVyID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICAgICAgdGhpcy5jaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICAgICAgICB0aGlzLmZvY3VzID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy5jb250cm9sLnZhbHVlQ2hhbmdlcy5waXBlKGRlYm91bmNlVGltZSg1MDApKS5zdWJzY3JpYmUodmFsdWUgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLm9uVmFsdWVDaGFuZ2VkKHZhbHVlKTtcclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgICAgICBpZiAoIXRoaXMuc3Vic2NyaXB0aW9uKSByZXR1cm47XHJcbiAgICAgICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICAgIH1cclxuXHJcbiAgICBzdWJtaXQoKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5mb3JtLnN1Ym1pdCgpO1xyXG4gICAgfVxyXG5cclxuICAgIHByb3RlY3RlZCBvblZhbHVlQ2hhbmdlZCh2YWx1ZTogYW55KTogdm9pZCB7XHJcblxyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, ViewChildren } from "@angular/core";
|
|
2
|
-
import { DynamicFormControlContainerComponent, DynamicFormGroupComponent, DynamicFormValueControlModel } from "@ng-dynamic-forms/core";
|
|
3
|
-
import { collectPathAble } from "../../utils/misc";
|
|
4
|
-
import { DynamicFormArrayModel } from "../../utils/dynamic-form-array.model";
|
|
5
|
-
import { DynamicFormGroupModel } from "../../utils/dynamic-form-group.model";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@ng-dynamic-forms/core";
|
|
8
|
-
export class DynamicBaseFormGroupComponent extends DynamicFormGroupComponent {
|
|
9
|
-
constructor(layoutService, validationService) {
|
|
10
|
-
super(layoutService, validationService);
|
|
11
|
-
this.layoutService = layoutService;
|
|
12
|
-
this.validationService = validationService;
|
|
13
|
-
this.blur = new EventEmitter();
|
|
14
|
-
this.change = new EventEmitter();
|
|
15
|
-
this.customEvent = new EventEmitter();
|
|
16
|
-
this.focus = new EventEmitter();
|
|
17
|
-
}
|
|
18
|
-
getClass(context, place, model) {
|
|
19
|
-
return [
|
|
20
|
-
context == "element" ? this.getModelClass(model) : null,
|
|
21
|
-
context == "element" ? this.getAdditionalClass(model) : null,
|
|
22
|
-
super.getClass(context, place, model)
|
|
23
|
-
].filter(cls => !!cls).join(" ");
|
|
24
|
-
}
|
|
25
|
-
getModelClass(model) {
|
|
26
|
-
const parts = collectPathAble(model, p => p.id);
|
|
27
|
-
if (parts.length == 0)
|
|
28
|
-
return "";
|
|
29
|
-
if (model instanceof DynamicFormGroupModel) {
|
|
30
|
-
return `form-group-${parts.join("-")}`;
|
|
31
|
-
}
|
|
32
|
-
return `form-control-${parts.join("-")}`;
|
|
33
|
-
}
|
|
34
|
-
getAdditionalClass(model) {
|
|
35
|
-
if (model instanceof DynamicFormArrayModel) {
|
|
36
|
-
return model.additional?.classes;
|
|
37
|
-
}
|
|
38
|
-
if (model instanceof DynamicFormValueControlModel) {
|
|
39
|
-
return model.additional?.classes;
|
|
40
|
-
}
|
|
41
|
-
return null;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
DynamicBaseFormGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormGroupComponent, deps: [{ token: i1.DynamicFormLayoutService }, { token: i1.DynamicFormValidationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
45
|
-
DynamicBaseFormGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseFormGroupComponent, selector: "dynamic-base-form-group", inputs: { formLayout: "formLayout", group: "group", layout: "layout", model: "model", templates: "templates" }, outputs: { blur: "blur", change: "change", customEvent: "customEvent", focus: "focus" }, viewQueries: [{ propertyName: "components", predicate: i0.forwardRef(function () { return DynamicFormControlContainerComponent; }), descendants: true }], usesInheritance: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
46
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormGroupComponent, decorators: [{
|
|
47
|
-
type: Component,
|
|
48
|
-
args: [{
|
|
49
|
-
selector: "dynamic-base-form-group",
|
|
50
|
-
template: "",
|
|
51
|
-
changeDetection: ChangeDetectionStrategy.OnPush
|
|
52
|
-
}]
|
|
53
|
-
}], ctorParameters: function () { return [{ type: i1.DynamicFormLayoutService }, { type: i1.DynamicFormValidationService }]; }, propDecorators: { formLayout: [{
|
|
54
|
-
type: Input
|
|
55
|
-
}], group: [{
|
|
56
|
-
type: Input
|
|
57
|
-
}], layout: [{
|
|
58
|
-
type: Input
|
|
59
|
-
}], model: [{
|
|
60
|
-
type: Input
|
|
61
|
-
}], templates: [{
|
|
62
|
-
type: Input
|
|
63
|
-
}], blur: [{
|
|
64
|
-
type: Output
|
|
65
|
-
}], change: [{
|
|
66
|
-
type: Output
|
|
67
|
-
}], customEvent: [{
|
|
68
|
-
type: Output
|
|
69
|
-
}], focus: [{
|
|
70
|
-
type: Output
|
|
71
|
-
}], components: [{
|
|
72
|
-
type: ViewChildren,
|
|
73
|
-
args: [forwardRef(() => DynamicFormControlContainerComponent)]
|
|
74
|
-
}] } });
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1iYXNlLWZvcm0tZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL25neC1keW5hbWljLWZvcm0vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLWdyb3VwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osVUFBVSxFQUNWLEtBQUssRUFDTCxNQUFNLEVBRU4sWUFBWSxFQUNmLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFDSCxvQ0FBb0MsRUFNcEMseUJBQXlCLEVBSXpCLDRCQUE0QixFQUUvQixNQUFNLHdCQUF3QixDQUFDO0FBQ2hDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQztBQUMzRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQzs7O0FBTzNFLE1BQU0sT0FBTyw2QkFBOEIsU0FBUSx5QkFBeUI7SUFnQnhFLFlBQXNCLGFBQXVDLEVBQ3ZDLGlCQUErQztRQUNqRSxLQUFLLENBQUMsYUFBYSxFQUFFLGlCQUFpQixDQUFDLENBQUM7UUFGdEIsa0JBQWEsR0FBYixhQUFhLENBQTBCO1FBQ3ZDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBOEI7UUFUM0QsU0FBSSxHQUFzQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBQzdDLFdBQU0sR0FBc0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUMvQyxnQkFBVyxHQUFnRCxJQUFJLFlBQVksRUFBRSxDQUFDO1FBQzlFLFVBQUssR0FBc0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQVF4RCxDQUFDO0lBRUQsUUFBUSxDQUFDLE9BQXdDLEVBQUUsS0FBb0MsRUFBRSxLQUErQjtRQUNwSCxPQUFPO1lBQ0gsT0FBTyxJQUFJLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSTtZQUN2RCxPQUFPLElBQUksU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUk7WUFDNUQsS0FBSyxDQUFDLFFBQVEsQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLEtBQUssQ0FBQztTQUN4QyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVTLGFBQWEsQ0FBQyxLQUErQjtRQUNuRCxNQUFNLEtBQUssR0FBRyxlQUFlLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ2hELElBQUksS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDO1lBQUUsT0FBTyxFQUFFLENBQUM7UUFDakMsSUFBSSxLQUFLLFlBQVkscUJBQXFCLEVBQUU7WUFDeEMsT0FBTyxjQUFjLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztTQUMxQztRQUNELE9BQU8sZ0JBQWdCLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztJQUM3QyxDQUFDO0lBRVMsa0JBQWtCLENBQUMsS0FBK0I7UUFDeEQsSUFBSSxLQUFLLFlBQVkscUJBQXFCLEVBQUU7WUFDeEMsT0FBTyxLQUFLLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQztTQUNwQztRQUNELElBQUksS0FBSyxZQUFZLDRCQUE0QixFQUFFO1lBQy9DLE9BQU8sS0FBSyxDQUFDLFVBQVUsRUFBRSxPQUFPLENBQUM7U0FDcEM7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDOzswSEE5Q1EsNkJBQTZCOzhHQUE3Qiw2QkFBNkIsMFVBYVAsb0NBQW9DLDJFQWhCekQsRUFBRTsyRkFHSCw2QkFBNkI7a0JBTHpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHlCQUF5QjtvQkFDbkMsUUFBUSxFQUFFLEVBQUU7b0JBQ1osZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEOzBKQUdZLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFFSSxJQUFJO3NCQUFiLE1BQU07Z0JBQ0csTUFBTTtzQkFBZixNQUFNO2dCQUNHLFdBQVc7c0JBQXBCLE1BQU07Z0JBQ0csS0FBSztzQkFBZCxNQUFNO2dCQUdQLFVBQVU7c0JBRFQsWUFBWTt1QkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsb0NBQW9DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgICBDb21wb25lbnQsXHJcbiAgICBFdmVudEVtaXR0ZXIsXHJcbiAgICBmb3J3YXJkUmVmLFxyXG4gICAgSW5wdXQsXHJcbiAgICBPdXRwdXQsXHJcbiAgICBRdWVyeUxpc3QsXHJcbiAgICBWaWV3Q2hpbGRyZW5cclxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0Zvcm1Hcm91cH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7XHJcbiAgICBEeW5hbWljRm9ybUNvbnRyb2xDb250YWluZXJDb21wb25lbnQsXHJcbiAgICBEeW5hbWljRm9ybUNvbnRyb2xDdXN0b21FdmVudCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbExheW91dCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbExheW91dENvbnRleHQsXHJcbiAgICBEeW5hbWljRm9ybUNvbnRyb2xMYXlvdXRQbGFjZSxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbE1vZGVsLFxyXG4gICAgRHluYW1pY0Zvcm1Hcm91cENvbXBvbmVudCxcclxuICAgIER5bmFtaWNGb3JtTGF5b3V0LFxyXG4gICAgRHluYW1pY0Zvcm1MYXlvdXRTZXJ2aWNlLFxyXG4gICAgRHluYW1pY0Zvcm1WYWxpZGF0aW9uU2VydmljZSxcclxuICAgIER5bmFtaWNGb3JtVmFsdWVDb250cm9sTW9kZWwsXHJcbiAgICBEeW5hbWljVGVtcGxhdGVEaXJlY3RpdmVcclxufSBmcm9tIFwiQG5nLWR5bmFtaWMtZm9ybXMvY29yZVwiO1xyXG5pbXBvcnQge2NvbGxlY3RQYXRoQWJsZX0gZnJvbSBcIi4uLy4uL3V0aWxzL21pc2NcIjtcclxuaW1wb3J0IHtEeW5hbWljRm9ybUFycmF5TW9kZWx9IGZyb20gXCIuLi8uLi91dGlscy9keW5hbWljLWZvcm0tYXJyYXkubW9kZWxcIjtcclxuaW1wb3J0IHtEeW5hbWljRm9ybUdyb3VwTW9kZWx9IGZyb20gXCIuLi8uLi91dGlscy9keW5hbWljLWZvcm0tZ3JvdXAubW9kZWxcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6IFwiZHluYW1pYy1iYXNlLWZvcm0tZ3JvdXBcIixcclxuICAgIHRlbXBsYXRlOiBcIlwiLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIER5bmFtaWNCYXNlRm9ybUdyb3VwQ29tcG9uZW50IGV4dGVuZHMgRHluYW1pY0Zvcm1Hcm91cENvbXBvbmVudCB7XHJcblxyXG4gICAgQElucHV0KCkgZm9ybUxheW91dDogRHluYW1pY0Zvcm1MYXlvdXQ7XHJcbiAgICBASW5wdXQoKSBncm91cDogRm9ybUdyb3VwO1xyXG4gICAgQElucHV0KCkgbGF5b3V0OiBEeW5hbWljRm9ybUNvbnRyb2xMYXlvdXQ7XHJcbiAgICBASW5wdXQoKSBtb2RlbDogRHluYW1pY0Zvcm1Hcm91cE1vZGVsO1xyXG4gICAgQElucHV0KCkgdGVtcGxhdGVzOiBRdWVyeUxpc3Q8RHluYW1pY1RlbXBsYXRlRGlyZWN0aXZlPiB8IER5bmFtaWNUZW1wbGF0ZURpcmVjdGl2ZVtdIHwgdW5kZWZpbmVkO1xyXG5cclxuICAgIEBPdXRwdXQoKSBibHVyOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICAgIEBPdXRwdXQoKSBjaGFuZ2U6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gICAgQE91dHB1dCgpIGN1c3RvbUV2ZW50OiBFdmVudEVtaXR0ZXI8RHluYW1pY0Zvcm1Db250cm9sQ3VzdG9tRXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gICAgQE91dHB1dCgpIGZvY3VzOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuXHJcbiAgICBAVmlld0NoaWxkcmVuKGZvcndhcmRSZWYoKCkgPT4gRHluYW1pY0Zvcm1Db250cm9sQ29udGFpbmVyQ29tcG9uZW50KSlcclxuICAgIGNvbXBvbmVudHM6IFF1ZXJ5TGlzdDxEeW5hbWljRm9ybUNvbnRyb2xDb250YWluZXJDb21wb25lbnQ+O1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBsYXlvdXRTZXJ2aWNlOiBEeW5hbWljRm9ybUxheW91dFNlcnZpY2UsXHJcbiAgICAgICAgICAgICAgICBwcm90ZWN0ZWQgdmFsaWRhdGlvblNlcnZpY2U6IER5bmFtaWNGb3JtVmFsaWRhdGlvblNlcnZpY2UpIHtcclxuICAgICAgICBzdXBlcihsYXlvdXRTZXJ2aWNlLCB2YWxpZGF0aW9uU2VydmljZSk7XHJcbiAgICB9XHJcblxyXG4gICAgZ2V0Q2xhc3MoY29udGV4dDogRHluYW1pY0Zvcm1Db250cm9sTGF5b3V0Q29udGV4dCwgcGxhY2U6IER5bmFtaWNGb3JtQ29udHJvbExheW91dFBsYWNlLCBtb2RlbD86IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsKTogc3RyaW5nIHtcclxuICAgICAgICByZXR1cm4gW1xyXG4gICAgICAgICAgICBjb250ZXh0ID09IFwiZWxlbWVudFwiID8gdGhpcy5nZXRNb2RlbENsYXNzKG1vZGVsKSA6IG51bGwsXHJcbiAgICAgICAgICAgIGNvbnRleHQgPT0gXCJlbGVtZW50XCIgPyB0aGlzLmdldEFkZGl0aW9uYWxDbGFzcyhtb2RlbCkgOiBudWxsLFxyXG4gICAgICAgICAgICBzdXBlci5nZXRDbGFzcyhjb250ZXh0LCBwbGFjZSwgbW9kZWwpXHJcbiAgICAgICAgXS5maWx0ZXIoY2xzID0+ICEhY2xzKS5qb2luKFwiIFwiKTtcclxuICAgIH1cclxuXHJcbiAgICBwcm90ZWN0ZWQgZ2V0TW9kZWxDbGFzcyhtb2RlbD86IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsKTogc3RyaW5nIHtcclxuICAgICAgICBjb25zdCBwYXJ0cyA9IGNvbGxlY3RQYXRoQWJsZShtb2RlbCwgcCA9PiBwLmlkKTtcclxuICAgICAgICBpZiAocGFydHMubGVuZ3RoID09IDApIHJldHVybiBcIlwiO1xyXG4gICAgICAgIGlmIChtb2RlbCBpbnN0YW5jZW9mIER5bmFtaWNGb3JtR3JvdXBNb2RlbCkge1xyXG4gICAgICAgICAgICByZXR1cm4gYGZvcm0tZ3JvdXAtJHtwYXJ0cy5qb2luKFwiLVwiKX1gO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gYGZvcm0tY29udHJvbC0ke3BhcnRzLmpvaW4oXCItXCIpfWA7XHJcbiAgICB9XHJcblxyXG4gICAgcHJvdGVjdGVkIGdldEFkZGl0aW9uYWxDbGFzcyhtb2RlbD86IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsKTogc3RyaW5nIHtcclxuICAgICAgICBpZiAobW9kZWwgaW5zdGFuY2VvZiBEeW5hbWljRm9ybUFycmF5TW9kZWwpIHtcclxuICAgICAgICAgICAgcmV0dXJuIG1vZGVsLmFkZGl0aW9uYWw/LmNsYXNzZXM7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChtb2RlbCBpbnN0YW5jZW9mIER5bmFtaWNGb3JtVmFsdWVDb250cm9sTW9kZWwpIHtcclxuICAgICAgICAgICAgcmV0dXJuIG1vZGVsLmFkZGl0aW9uYWw/LmNsYXNzZXM7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Inject, Input, Output, QueryList, ViewChildren } from "@angular/core";
|
|
2
|
-
import { Subscription } from "rxjs";
|
|
3
|
-
import { debounceTime, groupBy, mergeMap } from "rxjs/operators";
|
|
4
|
-
import { first } from "rxjs/operators";
|
|
5
|
-
import { DynamicFormComponent, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
6
|
-
import { EventsService, ObservableUtils } from "@stemy/ngx-utils";
|
|
7
|
-
import { collectPathAble } from "../../utils/misc";
|
|
8
|
-
import { DynamicFormGroupModel } from "../../utils/dynamic-form-group.model";
|
|
9
|
-
import { DynamicFormService } from "../../services/dynamic-form.service";
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "@ng-dynamic-forms/core";
|
|
12
|
-
import * as i2 from "../../services/dynamic-form.service";
|
|
13
|
-
import * as i3 from "@stemy/ngx-utils";
|
|
14
|
-
export class DynamicBaseFormComponent extends DynamicFormComponent {
|
|
15
|
-
constructor(formService, events, changeDetectorRef, componentService) {
|
|
16
|
-
super(changeDetectorRef, componentService);
|
|
17
|
-
this.formService = formService;
|
|
18
|
-
this.events = events;
|
|
19
|
-
this.blur = new EventEmitter();
|
|
20
|
-
this.change = new EventEmitter();
|
|
21
|
-
this.focus = new EventEmitter();
|
|
22
|
-
this.onValueChange = new EventEmitter();
|
|
23
|
-
this.onStatusChange = new EventEmitter();
|
|
24
|
-
this.onSubmit = new EventEmitter();
|
|
25
|
-
this.onDetectChanges = new EventEmitter();
|
|
26
|
-
this.templates = new QueryList();
|
|
27
|
-
this.subscription = new Subscription();
|
|
28
|
-
this.groupSubscription = new Subscription();
|
|
29
|
-
this.labelPrefix = "label";
|
|
30
|
-
this.getComponentType = () => null;
|
|
31
|
-
}
|
|
32
|
-
get status() {
|
|
33
|
-
return !this.group ? null : this.group.status;
|
|
34
|
-
}
|
|
35
|
-
submit() {
|
|
36
|
-
this.onSubmit.emit(this);
|
|
37
|
-
}
|
|
38
|
-
ngOnChanges(changes) {
|
|
39
|
-
this.groupSubscription.unsubscribe();
|
|
40
|
-
if (this.group) {
|
|
41
|
-
this.groupSubscription = ObservableUtils.multiSubscription(this.group.statusChanges.subscribe(() => {
|
|
42
|
-
this.onStatusChange.emit(this);
|
|
43
|
-
}), this.group.valueChanges.pipe(debounceTime(500)).subscribe(() => {
|
|
44
|
-
this.formService.notifyChanges(this.model, this.group);
|
|
45
|
-
}), this.change.pipe(groupBy(ev => ev.model))
|
|
46
|
-
.pipe(mergeMap(t => t.pipe(debounceTime(500))))
|
|
47
|
-
.subscribe(ev => {
|
|
48
|
-
this.onValueChange.emit({ ...ev, form: this });
|
|
49
|
-
}));
|
|
50
|
-
}
|
|
51
|
-
if (changes.groupModel) {
|
|
52
|
-
this.model = this.groupModel?.group;
|
|
53
|
-
}
|
|
54
|
-
if (changes.model) {
|
|
55
|
-
this.groupModel = new DynamicFormGroupModel({ id: "root", group: this.model });
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
ngAfterViewInit() {
|
|
59
|
-
this.subscription = ObservableUtils.multiSubscription(ObservableUtils.subscribe({
|
|
60
|
-
subjects: [this.contentTemplates.changes, this.viewTemplates.changes],
|
|
61
|
-
cb: () => {
|
|
62
|
-
const templates = this.contentTemplates.toArray().concat(this.viewTemplates.toArray());
|
|
63
|
-
this.templates.reset(templates);
|
|
64
|
-
}
|
|
65
|
-
}), this.events.languageChanged.subscribe(() => {
|
|
66
|
-
this.formService.notifyChanges(this.model, this.group);
|
|
67
|
-
this.formService.detectChanges(this);
|
|
68
|
-
}));
|
|
69
|
-
}
|
|
70
|
-
ngOnDestroy() {
|
|
71
|
-
super.ngOnDestroy();
|
|
72
|
-
this.subscription.unsubscribe();
|
|
73
|
-
this.groupSubscription.unsubscribe();
|
|
74
|
-
}
|
|
75
|
-
detectChanges() {
|
|
76
|
-
super.detectChanges();
|
|
77
|
-
this.onDetectChanges.emit(this);
|
|
78
|
-
}
|
|
79
|
-
insertFormArrayGroup(index, formArray, formArrayModel) {
|
|
80
|
-
this.formService.insertFormArrayGroup(index, formArray, formArrayModel);
|
|
81
|
-
this.detectChanges();
|
|
82
|
-
}
|
|
83
|
-
cloneFormArrayGroup(index, formArray, formArrayModel) {
|
|
84
|
-
this.formService.cloneFormArrayGroup(index, formArray, formArrayModel);
|
|
85
|
-
this.detectChanges();
|
|
86
|
-
}
|
|
87
|
-
removeFormArrayGroup(index, formArray, formArrayModel) {
|
|
88
|
-
this.formService.removeFormArrayGroup(index, formArray, formArrayModel);
|
|
89
|
-
this.detectChanges();
|
|
90
|
-
}
|
|
91
|
-
moveFormArrayGroup(index, step, formArray, formArrayModel) {
|
|
92
|
-
this.formService.moveFormArrayGroup(index, step, formArray, formArrayModel);
|
|
93
|
-
this.detectChanges();
|
|
94
|
-
}
|
|
95
|
-
clearFormArray(formArray, formArrayModel) {
|
|
96
|
-
this.formService.clearFormArray(formArray, formArrayModel);
|
|
97
|
-
this.detectChanges();
|
|
98
|
-
}
|
|
99
|
-
getClass(model) {
|
|
100
|
-
const parts = collectPathAble(model, p => p.id);
|
|
101
|
-
if (parts.length == 0)
|
|
102
|
-
return "";
|
|
103
|
-
if (model instanceof DynamicFormGroupModel) {
|
|
104
|
-
return `form-group-${parts.join("-")}`;
|
|
105
|
-
}
|
|
106
|
-
return `form-control-${parts.join("-")}`;
|
|
107
|
-
}
|
|
108
|
-
validate(showErrors = true) {
|
|
109
|
-
if (!this.group)
|
|
110
|
-
return Promise.resolve();
|
|
111
|
-
return new Promise((resolve, reject) => {
|
|
112
|
-
this.group.statusChanges.pipe(first(status => status == "VALID" || status == "INVALID")).subscribe(status => {
|
|
113
|
-
if (showErrors) {
|
|
114
|
-
this.formService.showErrors(this);
|
|
115
|
-
}
|
|
116
|
-
if (status == "VALID") {
|
|
117
|
-
resolve(null);
|
|
118
|
-
return;
|
|
119
|
-
}
|
|
120
|
-
reject(null);
|
|
121
|
-
});
|
|
122
|
-
this.group.updateValueAndValidity();
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
async serialize(validate) {
|
|
126
|
-
if (!this.group)
|
|
127
|
-
return null;
|
|
128
|
-
if (validate) {
|
|
129
|
-
await this.validate();
|
|
130
|
-
}
|
|
131
|
-
return await this.formService.serialize(this.model, this.group);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
DynamicBaseFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormComponent, deps: [{ token: DynamicFormService }, { token: EventsService }, { token: i0.ChangeDetectorRef }, { token: i1.DynamicFormComponentService }], target: i0.ɵɵFactoryTarget.Component });
|
|
135
|
-
DynamicBaseFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseFormComponent, selector: "dynamic-base-form", inputs: { group: "group", groupModel: "groupModel", model: "model", layout: "layout", labelPrefix: "labelPrefix", getComponentType: "getComponentType" }, outputs: { blur: "blur", change: "change", focus: "focus", onValueChange: "onValueChange", onStatusChange: "onStatusChange", onSubmit: "onSubmit", onDetectChanges: "onDetectChanges" }, queries: [{ propertyName: "contentTemplates", predicate: DynamicTemplateDirective }], viewQueries: [{ propertyName: "viewTemplates", predicate: DynamicTemplateDirective, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.Default });
|
|
136
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormComponent, decorators: [{
|
|
137
|
-
type: Component,
|
|
138
|
-
args: [{
|
|
139
|
-
selector: "dynamic-base-form",
|
|
140
|
-
template: "",
|
|
141
|
-
changeDetection: ChangeDetectionStrategy.Default
|
|
142
|
-
}]
|
|
143
|
-
}], ctorParameters: function () { return [{ type: i2.DynamicFormService, decorators: [{
|
|
144
|
-
type: Inject,
|
|
145
|
-
args: [DynamicFormService]
|
|
146
|
-
}] }, { type: i3.EventsService, decorators: [{
|
|
147
|
-
type: Inject,
|
|
148
|
-
args: [EventsService]
|
|
149
|
-
}] }, { type: i0.ChangeDetectorRef }, { type: i1.DynamicFormComponentService }]; }, propDecorators: { group: [{
|
|
150
|
-
type: Input
|
|
151
|
-
}], groupModel: [{
|
|
152
|
-
type: Input
|
|
153
|
-
}], model: [{
|
|
154
|
-
type: Input
|
|
155
|
-
}], layout: [{
|
|
156
|
-
type: Input
|
|
157
|
-
}], labelPrefix: [{
|
|
158
|
-
type: Input
|
|
159
|
-
}], getComponentType: [{
|
|
160
|
-
type: Input
|
|
161
|
-
}], blur: [{
|
|
162
|
-
type: Output
|
|
163
|
-
}], change: [{
|
|
164
|
-
type: Output
|
|
165
|
-
}], focus: [{
|
|
166
|
-
type: Output
|
|
167
|
-
}], contentTemplates: [{
|
|
168
|
-
type: ContentChildren,
|
|
169
|
-
args: [DynamicTemplateDirective]
|
|
170
|
-
}], viewTemplates: [{
|
|
171
|
-
type: ViewChildren,
|
|
172
|
-
args: [DynamicTemplateDirective]
|
|
173
|
-
}], onValueChange: [{
|
|
174
|
-
type: Output
|
|
175
|
-
}], onStatusChange: [{
|
|
176
|
-
type: Output
|
|
177
|
-
}], onSubmit: [{
|
|
178
|
-
type: Output
|
|
179
|
-
}], onDetectChanges: [{
|
|
180
|
-
type: Output
|
|
181
|
-
}] } });
|
|
182
|
-
//# 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,\r\n    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormArray, FormGroup} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {debounceTime, groupBy, mergeMap} from \"rxjs/operators\";\r\nimport {first} from \"rxjs/operators\";\r\nimport {\r\n    DynamicFormComponent,\r\n    DynamicFormComponentService,\r\n    DynamicFormControlEvent,\r\n    DynamicFormControlModel,\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, GetFormControlComponentType, IDynamicForm, IDynamicFormEvent} from \"../../common-types\";\r\nimport {collectPathAble} from \"../../utils/misc\";\r\nimport {DynamicFormGroupModel} from \"../../utils/dynamic-form-group.model\";\r\nimport {DynamicFormArrayModel} from \"../../utils/dynamic-form-array.model\";\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() groupModel: DynamicFormGroupModel;\r\n    @Input() model: DynamicFormModel;\r\n    @Input() layout: DynamicFormLayout;\r\n    @Input() labelPrefix: string;\r\n    @Input() getComponentType: GetFormControlComponentType;\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 onValueChange: EventEmitter<IDynamicFormEvent>;\r\n    @Output() readonly onStatusChange: EventEmitter<IDynamicForm>;\r\n    @Output() readonly onSubmit: EventEmitter<IDynamicForm>;\r\n    @Output() readonly onDetectChanges: EventEmitter<IDynamicForm>;\r\n\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.onValueChange = new EventEmitter<IDynamicFormEvent>();\r\n        this.onStatusChange = new EventEmitter<IDynamicForm>();\r\n        this.onSubmit = new EventEmitter<IDynamicForm>();\r\n        this.onDetectChanges = new EventEmitter<IDynamicForm>();\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        this.getComponentType = () => null;\r\n    }\r\n\r\n    submit(): void {\r\n        this.onSubmit.emit(this);\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.pipe(debounceTime(500)).subscribe(() => {\r\n                    this.formService.notifyChanges(this.model, this.group);\r\n                }),\r\n                this.change.pipe(groupBy(ev => ev.model))\r\n                    .pipe(mergeMap(t => t.pipe(debounceTime(500))))\r\n                    .subscribe(ev => {\r\n                        this.onValueChange.emit({...ev, form: this});\r\n                    })\r\n            );\r\n        }\r\n        if (changes.groupModel) {\r\n            this.model = this.groupModel?.group;\r\n        }\r\n        if (changes.model) {\r\n            this.groupModel = new DynamicFormGroupModel({id: \"root\", group: this.model});\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.notifyChanges(this.model, this.group);\r\n                this.formService.detectChanges(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    detectChanges(): void {\r\n        super.detectChanges();\r\n        this.onDetectChanges.emit(this);\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.detectChanges();\r\n    }\r\n\r\n    cloneFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.cloneFormArrayGroup(index, formArray, formArrayModel);\r\n        this.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.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.detectChanges();\r\n    }\r\n\r\n    clearFormArray(formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.clearFormArray(formArray, formArrayModel);\r\n        this.detectChanges();\r\n    }\r\n\r\n    getClass(model?: DynamicFormControlModel): string {\r\n        const parts = collectPathAble(model, p => p.id);\r\n        if (parts.length == 0) return \"\";\r\n        if (model instanceof DynamicFormGroupModel) {\r\n            return `form-group-${parts.join(\"-\")}`;\r\n        }\r\n        return `form-control-${parts.join(\"-\")}`;\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,66 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component } from "@angular/core";
|
|
2
|
-
import { BehaviorSubject } from "rxjs";
|
|
3
|
-
import { DynamicBaseFormControlComponent } from "./dynamic-base-form-control.component";
|
|
4
|
-
import { replaceSpecialChars } from "../../utils/misc";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class DynamicBaseSelectComponent extends DynamicBaseFormControlComponent {
|
|
7
|
-
ngOnInit() {
|
|
8
|
-
this.groups$ = new BehaviorSubject([]);
|
|
9
|
-
this.subscription = this.model.options$.subscribe(options => {
|
|
10
|
-
const groupBy = this.model.inline || !this.model.multiple ? this.model.groupBy : null;
|
|
11
|
-
const grouped = options.reduce((res, option) => {
|
|
12
|
-
const key = replaceSpecialChars(groupBy ? option.props[this.model.groupBy] || "default" : "default", "-");
|
|
13
|
-
res[key] = res[key] || [];
|
|
14
|
-
res[key].push(option);
|
|
15
|
-
return res;
|
|
16
|
-
}, {});
|
|
17
|
-
const groups = Object.keys(grouped).map(group => {
|
|
18
|
-
return {
|
|
19
|
-
group,
|
|
20
|
-
options: grouped[group]
|
|
21
|
-
};
|
|
22
|
-
});
|
|
23
|
-
this.hasOptions = groups.length > 0;
|
|
24
|
-
this.groups$.next(groups);
|
|
25
|
-
this.cdr.detectChanges();
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
ngOnDestroy() {
|
|
29
|
-
if (this.subscription)
|
|
30
|
-
this.subscription.unsubscribe();
|
|
31
|
-
}
|
|
32
|
-
isSelected(option) {
|
|
33
|
-
if (this.model.multiple) {
|
|
34
|
-
return this.control.value?.indexOf(option.value) >= 0;
|
|
35
|
-
}
|
|
36
|
-
return this.control.value == option.value;
|
|
37
|
-
}
|
|
38
|
-
selectToggle(option, state) {
|
|
39
|
-
if (this.model.multiple) {
|
|
40
|
-
const value = Array.from(this.control.value || []);
|
|
41
|
-
const index = value.indexOf(option.value);
|
|
42
|
-
if (index >= 0) {
|
|
43
|
-
value.splice(index, 1);
|
|
44
|
-
}
|
|
45
|
-
if (state) {
|
|
46
|
-
value.push(option.value);
|
|
47
|
-
}
|
|
48
|
-
this.control.setValue(value);
|
|
49
|
-
this.onChange(value);
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
this.control.setValue(option.value);
|
|
53
|
-
this.onChange(option.value);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
DynamicBaseSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseSelectComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
57
|
-
DynamicBaseSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseSelectComponent, selector: "dynamic-base-select", usesInheritance: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
58
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseSelectComponent, decorators: [{
|
|
59
|
-
type: Component,
|
|
60
|
-
args: [{
|
|
61
|
-
selector: "dynamic-base-select",
|
|
62
|
-
template: "",
|
|
63
|
-
changeDetection: ChangeDetectionStrategy.OnPush
|
|
64
|
-
}]
|
|
65
|
-
}] });
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1iYXNlLXNlbGVjdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbmd4LWR5bmFtaWMtZm9ybS9jb21wb25lbnRzL2Jhc2UvZHluYW1pYy1iYXNlLXNlbGVjdC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBb0IsTUFBTSxlQUFlLENBQUM7QUFDcEYsT0FBTyxFQUFDLGVBQWUsRUFBZSxNQUFNLE1BQU0sQ0FBQztBQUNuRCxPQUFPLEVBQUMsK0JBQStCLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUV0RixPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPckQsTUFBTSxPQUFPLDBCQUEyQixTQUFRLCtCQUF3RDtJQU9wRyxRQUFRO1FBQ0osSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLGVBQWUsQ0FBZ0MsRUFBRSxDQUFDLENBQUM7UUFDdEUsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDeEQsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztZQUN0RixNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxFQUFFO2dCQUMzQyxNQUFNLEdBQUcsR0FBRyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsRUFBRSxHQUFHLENBQUMsQ0FBQztnQkFDMUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQzFCLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7Z0JBQ3RCLE9BQU8sR0FBRyxDQUFDO1lBQ2YsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ1AsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzVDLE9BQU87b0JBQ0gsS0FBSztvQkFDTCxPQUFPLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQztpQkFDMUIsQ0FBQztZQUNOLENBQUMsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLFVBQVUsR0FBRyxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztZQUNwQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUMxQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQzdCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLElBQUksQ0FBQyxZQUFZO1lBQ2pCLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDeEMsQ0FBQztJQUVELFVBQVUsQ0FBQyxNQUE4QjtRQUNyQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDekQ7UUFDRCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxJQUFJLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFDOUMsQ0FBQztJQUVELFlBQVksQ0FBQyxNQUE4QixFQUFFLEtBQWM7UUFDdkQsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRTtZQUNyQixNQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1lBQ25ELE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzFDLElBQUksS0FBSyxJQUFJLENBQUMsRUFBRTtnQkFDWixLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQzthQUMxQjtZQUNELElBQUksS0FBSyxFQUFFO2dCQUNQLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO2FBQzVCO1lBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDN0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNyQixPQUFPO1NBQ1Y7UUFDRCxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEMsQ0FBQzs7dUhBekRRLDBCQUEwQjsyR0FBMUIsMEJBQTBCLGtGQUh6QixFQUFFOzJGQUdILDBCQUEwQjtrQkFMdEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixRQUFRLEVBQUUsRUFBRTtvQkFDWixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uRGVzdHJveSwgT25Jbml0fSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdCwgU3Vic2NyaXB0aW9ufSBmcm9tIFwicnhqc1wiO1xyXG5pbXBvcnQge0R5bmFtaWNCYXNlRm9ybUNvbnRyb2xDb21wb25lbnR9IGZyb20gXCIuL2R5bmFtaWMtYmFzZS1mb3JtLWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7RHluYW1pY0Zvcm1PcHRpb24sIER5bmFtaWNGb3JtT3B0aW9uR3JvdXAsIER5bmFtaWNTZWxlY3RNb2RlbH0gZnJvbSBcIi4uLy4uL3V0aWxzL2R5bmFtaWMtc2VsZWN0Lm1vZGVsXCI7XHJcbmltcG9ydCB7cmVwbGFjZVNwZWNpYWxDaGFyc30gZnJvbSBcIi4uLy4uL3V0aWxzL21pc2NcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6IFwiZHluYW1pYy1iYXNlLXNlbGVjdFwiLFxyXG4gICAgdGVtcGxhdGU6IFwiXCIsXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRHluYW1pY0Jhc2VTZWxlY3RDb21wb25lbnQgZXh0ZW5kcyBEeW5hbWljQmFzZUZvcm1Db250cm9sQ29tcG9uZW50PER5bmFtaWNTZWxlY3RNb2RlbDxhbnk+PiBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcclxuXHJcbiAgICBncm91cHMkOiBCZWhhdmlvclN1YmplY3Q8RHluYW1pY0Zvcm1PcHRpb25Hcm91cDxhbnk+W10+O1xyXG4gICAgaGFzT3B0aW9uczogYm9vbGVhbjtcclxuXHJcbiAgICBwcm90ZWN0ZWQgc3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb247XHJcblxyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5ncm91cHMkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxEeW5hbWljRm9ybU9wdGlvbkdyb3VwPGFueT5bXT4oW10pO1xyXG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy5tb2RlbC5vcHRpb25zJC5zdWJzY3JpYmUob3B0aW9ucyA9PiB7XHJcbiAgICAgICAgICAgIGNvbnN0IGdyb3VwQnkgPSB0aGlzLm1vZGVsLmlubGluZSB8fCAhdGhpcy5tb2RlbC5tdWx0aXBsZSA/IHRoaXMubW9kZWwuZ3JvdXBCeSA6IG51bGw7XHJcbiAgICAgICAgICAgIGNvbnN0IGdyb3VwZWQgPSBvcHRpb25zLnJlZHVjZSgocmVzLCBvcHRpb24pID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IGtleSA9IHJlcGxhY2VTcGVjaWFsQ2hhcnMoZ3JvdXBCeSA/IG9wdGlvbi5wcm9wc1t0aGlzLm1vZGVsLmdyb3VwQnldIHx8IFwiZGVmYXVsdFwiIDogXCJkZWZhdWx0XCIsIFwiLVwiKTtcclxuICAgICAgICAgICAgICAgIHJlc1trZXldID0gcmVzW2tleV0gfHwgW107XHJcbiAgICAgICAgICAgICAgICByZXNba2V5XS5wdXNoKG9wdGlvbik7XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gcmVzO1xyXG4gICAgICAgICAgICB9LCB7fSk7XHJcbiAgICAgICAgICAgIGNvbnN0IGdyb3VwcyA9IE9iamVjdC5rZXlzKGdyb3VwZWQpLm1hcChncm91cCA9PiB7XHJcbiAgICAgICAgICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICAgICAgICAgIGdyb3VwLFxyXG4gICAgICAgICAgICAgICAgICAgIG9wdGlvbnM6IGdyb3VwZWRbZ3JvdXBdXHJcbiAgICAgICAgICAgICAgICB9O1xyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgdGhpcy5oYXNPcHRpb25zID0gZ3JvdXBzLmxlbmd0aCA+IDA7XHJcbiAgICAgICAgICAgIHRoaXMuZ3JvdXBzJC5uZXh0KGdyb3Vwcyk7XHJcbiAgICAgICAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgICAgICBpZiAodGhpcy5zdWJzY3JpcHRpb24pXHJcbiAgICAgICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XHJcbiAgICB9XHJcblxyXG4gICAgaXNTZWxlY3RlZChvcHRpb246IER5bmFtaWNGb3JtT3B0aW9uPGFueT4pOiBib29sZWFuIHtcclxuICAgICAgICBpZiAodGhpcy5tb2RlbC5tdWx0aXBsZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5jb250cm9sLnZhbHVlPy5pbmRleE9mKG9wdGlvbi52YWx1ZSkgPj0gMDtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuY29udHJvbC52YWx1ZSA9PSBvcHRpb24udmFsdWU7XHJcbiAgICB9XHJcblxyXG4gICAgc2VsZWN0VG9nZ2xlKG9wdGlvbjogRHluYW1pY0Zvcm1PcHRpb248YW55Piwgc3RhdGU6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgICAgICBpZiAodGhpcy5tb2RlbC5tdWx0aXBsZSkge1xyXG4gICAgICAgICAgICBjb25zdCB2YWx1ZSA9IEFycmF5LmZyb20odGhpcy5jb250cm9sLnZhbHVlIHx8IFtdKTtcclxuICAgICAgICAgICAgY29uc3QgaW5kZXggPSB2YWx1ZS5pbmRleE9mKG9wdGlvbi52YWx1ZSk7XHJcbiAgICAgICAgICAgIGlmIChpbmRleCA+PSAwKSB7XHJcbiAgICAgICAgICAgICAgICB2YWx1ZS5zcGxpY2UoaW5kZXgsIDEpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIGlmIChzdGF0ZSkge1xyXG4gICAgICAgICAgICAgICAgdmFsdWUucHVzaChvcHRpb24udmFsdWUpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIHRoaXMuY29udHJvbC5zZXRWYWx1ZSh2YWx1ZSk7XHJcbiAgICAgICAgICAgIHRoaXMub25DaGFuZ2UodmFsdWUpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHRoaXMuY29udHJvbC5zZXRWYWx1ZShvcHRpb24udmFsdWUpO1xyXG4gICAgICAgIHRoaXMub25DaGFuZ2Uob3B0aW9uLnZhbHVlKTtcclxuICAgIH1cclxufVxyXG4iXX0=
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
import { Directive, EventEmitter, HostBinding, HostListener, Inject, Input, Output } from "@angular/core";
|
|
2
|
-
import { debounceTime } from "rxjs/operators";
|
|
3
|
-
import { TOASTER_SERVICE } from "@stemy/ngx-utils";
|
|
4
|
-
import { getFormValidationErrors } from "../utils/validation-errors";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class AsyncSubmitDirective {
|
|
7
|
-
constructor(toaster, cdr, elem, renderer) {
|
|
8
|
-
this.toaster = toaster;
|
|
9
|
-
this.cdr = cdr;
|
|
10
|
-
this.elem = elem;
|
|
11
|
-
this.renderer = renderer;
|
|
12
|
-
this.onSuccess = new EventEmitter();
|
|
13
|
-
this.onError = new EventEmitter();
|
|
14
|
-
if (elem.nativeElement.tagName !== "BUTTON")
|
|
15
|
-
return;
|
|
16
|
-
renderer.setAttribute(elem.nativeElement, "type", "button");
|
|
17
|
-
}
|
|
18
|
-
get isDisabled() {
|
|
19
|
-
return this.disabled;
|
|
20
|
-
}
|
|
21
|
-
set isDisabled(value) {
|
|
22
|
-
this.disabled = value;
|
|
23
|
-
if (value) {
|
|
24
|
-
this.renderer.setAttribute(this.elem.nativeElement, "disabled", "disabled");
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
this.renderer.removeAttribute(this.elem.nativeElement, "disabled");
|
|
28
|
-
}
|
|
29
|
-
get isLoading() {
|
|
30
|
-
return this.loading;
|
|
31
|
-
}
|
|
32
|
-
ngOnInit() {
|
|
33
|
-
if (!this.form)
|
|
34
|
-
return;
|
|
35
|
-
this.isDisabled = this.form.status !== "VALID";
|
|
36
|
-
this.cdr.detectChanges();
|
|
37
|
-
this.onStatusChange = this.form.onStatusChange.subscribe(() => {
|
|
38
|
-
this.isDisabled = this.form.status !== "VALID";
|
|
39
|
-
this.cdr.detectChanges();
|
|
40
|
-
if (!this.callback || this.form.status == "PENDING")
|
|
41
|
-
return;
|
|
42
|
-
if (!this.disabled) {
|
|
43
|
-
this.callback();
|
|
44
|
-
}
|
|
45
|
-
this.callback = null;
|
|
46
|
-
});
|
|
47
|
-
this.onSubmit = this.form.onSubmit.pipe(debounceTime(200)).subscribe(() => this.callMethod());
|
|
48
|
-
}
|
|
49
|
-
ngOnDestroy() {
|
|
50
|
-
if (this.onStatusChange)
|
|
51
|
-
this.onStatusChange.unsubscribe();
|
|
52
|
-
if (this.onSubmit)
|
|
53
|
-
this.onSubmit.unsubscribe();
|
|
54
|
-
}
|
|
55
|
-
click() {
|
|
56
|
-
this.callback = () => this.callMethod();
|
|
57
|
-
if (this.form.status === "INVALID") {
|
|
58
|
-
console.log(getFormValidationErrors(this.form.group.controls));
|
|
59
|
-
}
|
|
60
|
-
if (this.form.status !== "VALID" && this.form.status !== "INVALID")
|
|
61
|
-
return;
|
|
62
|
-
this.callback();
|
|
63
|
-
this.callback = null;
|
|
64
|
-
}
|
|
65
|
-
callMethod() {
|
|
66
|
-
if (this.loading)
|
|
67
|
-
return;
|
|
68
|
-
this.loading = true;
|
|
69
|
-
this.method(this.form, this.context).then(result => {
|
|
70
|
-
this.loading = false;
|
|
71
|
-
if (result) {
|
|
72
|
-
this.onSuccess.emit(result);
|
|
73
|
-
this.toaster.success(result.message, result.context);
|
|
74
|
-
}
|
|
75
|
-
}, reason => {
|
|
76
|
-
if (!reason || !reason.message)
|
|
77
|
-
throw new Error("Reason must implement IAsyncMessage interface");
|
|
78
|
-
this.loading = false;
|
|
79
|
-
this.onError.emit(reason);
|
|
80
|
-
this.toaster.error(reason.message, reason.context);
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
AsyncSubmitDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AsyncSubmitDirective, deps: [{ token: TOASTER_SERVICE }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
85
|
-
AsyncSubmitDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: AsyncSubmitDirective, selector: "[async-submit]", inputs: { method: ["async-submit", "method"], form: "form", context: "context" }, outputs: { onSuccess: "onSuccess", onError: "onError" }, host: { listeners: { "click": "click()" }, properties: { "class.disabled": "this.isDisabled", "class.loading": "this.isLoading" } }, exportAs: ["async-submit"], ngImport: i0 });
|
|
86
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AsyncSubmitDirective, decorators: [{
|
|
87
|
-
type: Directive,
|
|
88
|
-
args: [{
|
|
89
|
-
selector: "[async-submit]",
|
|
90
|
-
exportAs: "async-submit"
|
|
91
|
-
}]
|
|
92
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
93
|
-
type: Inject,
|
|
94
|
-
args: [TOASTER_SERVICE]
|
|
95
|
-
}] }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { method: [{
|
|
96
|
-
type: Input,
|
|
97
|
-
args: ["async-submit"]
|
|
98
|
-
}], form: [{
|
|
99
|
-
type: Input
|
|
100
|
-
}], context: [{
|
|
101
|
-
type: Input
|
|
102
|
-
}], onSuccess: [{
|
|
103
|
-
type: Output
|
|
104
|
-
}], onError: [{
|
|
105
|
-
type: Output
|
|
106
|
-
}], isDisabled: [{
|
|
107
|
-
type: HostBinding,
|
|
108
|
-
args: ["class.disabled"]
|
|
109
|
-
}], isLoading: [{
|
|
110
|
-
type: HostBinding,
|
|
111
|
-
args: ["class.loading"]
|
|
112
|
-
}], click: [{
|
|
113
|
-
type: HostListener,
|
|
114
|
-
args: ["click"]
|
|
115
|
-
}] } });
|
|
116
|
-
//# 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 {debounceTime} from \"rxjs/operators\";\r\nimport {IAsyncMessage, IToasterService, TOASTER_SERVICE} from \"@stemy/ngx-utils\";\r\nimport {AsyncSubmitMethod, IDynamicForm} from \"../common-types\";\r\nimport {getFormValidationErrors} from \"../utils/validation-errors\";\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: IDynamicForm;\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.pipe(debounceTime(200)).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 === \"INVALID\") {\r\n            console.log(getFormValidationErrors(this.form.group.controls));\r\n        }\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"]}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { AsyncSubmitDirective } from "./directives/async-submit.directive";
|
|
2
|
-
import { DynamicBaseFormComponent } from "./components/base/dynamic-base-form.component";
|
|
3
|
-
import { DynamicBaseFormArrayComponent } from "./components/base/dynamic-base-form-array.component";
|
|
4
|
-
import { DynamicBaseFormControlComponent } from "./components/base/dynamic-base-form-control.component";
|
|
5
|
-
import { DynamicBaseFormControlContainerComponent } from "./components/base/dynamic-base-form-control-container.component";
|
|
6
|
-
import { DynamicBaseFormGroupComponent } from "./components/base/dynamic-base-form-group.component";
|
|
7
|
-
import { DynamicBaseSelectComponent } from "./components/base/dynamic-base-select.component";
|
|
8
|
-
// --- Components ---
|
|
9
|
-
export const components = [
|
|
10
|
-
DynamicBaseFormComponent,
|
|
11
|
-
DynamicBaseFormArrayComponent,
|
|
12
|
-
DynamicBaseFormControlComponent,
|
|
13
|
-
DynamicBaseFormControlContainerComponent,
|
|
14
|
-
DynamicBaseFormGroupComponent,
|
|
15
|
-
DynamicBaseSelectComponent
|
|
16
|
-
];
|
|
17
|
-
// --- Directives ---
|
|
18
|
-
export const directives = [
|
|
19
|
-
AsyncSubmitDirective,
|
|
20
|
-
];
|
|
21
|
-
// --- Pipes ---
|
|
22
|
-
export const pipes = [];
|
|
23
|
-
export function defaultFormControlProvider() {
|
|
24
|
-
return () => null;
|
|
25
|
-
}
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWR5bmFtaWMtZm9ybS5pbXBvcnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL25neC1keW5hbWljLWZvcm0vbmd4LWR5bmFtaWMtZm9ybS5pbXBvcnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBRXpFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLCtDQUErQyxDQUFDO0FBQ3ZGLE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQ2xHLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLHVEQUF1RCxDQUFDO0FBQ3RHLE9BQU8sRUFDSCx3Q0FBd0MsRUFDM0MsTUFBTSxpRUFBaUUsQ0FBQztBQUN6RSxPQUFPLEVBQUMsNkJBQTZCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUNsRyxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQUUzRixxQkFBcUI7QUFDckIsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3RCLHdCQUF3QjtJQUN4Qiw2QkFBNkI7SUFDN0IsK0JBQStCO0lBQy9CLHdDQUF3QztJQUN4Qyw2QkFBNkI7SUFDN0IsMEJBQTBCO0NBQzdCLENBQUM7QUFFRixxQkFBcUI7QUFDckIsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3RCLG9CQUFvQjtDQUN2QixDQUFDO0FBRUYsZ0JBQWdCO0FBQ2hCLE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBRyxFQUFFLENBQUM7QUFFeEIsTUFBTSxVQUFVLDBCQUEwQjtJQUN0QyxPQUFPLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQztBQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEeW5hbWljRm9ybUNvbnRyb2xNYXBGbn0gZnJvbSBcIkBuZy1keW5hbWljLWZvcm1zL2NvcmVcIjtcclxuXHJcbmltcG9ydCB7QXN5bmNTdWJtaXREaXJlY3RpdmV9IGZyb20gXCIuL2RpcmVjdGl2ZXMvYXN5bmMtc3VibWl0LmRpcmVjdGl2ZVwiO1xyXG5cclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Db21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1BcnJheUNvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLWFycmF5LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0R5bmFtaWNCYXNlRm9ybUNvbnRyb2xDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge1xyXG4gICAgRHluYW1pY0Jhc2VGb3JtQ29udHJvbENvbnRhaW5lckNvbXBvbmVudFxyXG59IGZyb20gXCIuL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS1jb250cm9sLWNvbnRhaW5lci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Hcm91cENvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLWdyb3VwLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0R5bmFtaWNCYXNlU2VsZWN0Q29tcG9uZW50fSBmcm9tIFwiLi9jb21wb25lbnRzL2Jhc2UvZHluYW1pYy1iYXNlLXNlbGVjdC5jb21wb25lbnRcIjtcclxuXHJcbi8vIC0tLSBDb21wb25lbnRzIC0tLVxyXG5leHBvcnQgY29uc3QgY29tcG9uZW50cyA9IFtcclxuICAgIER5bmFtaWNCYXNlRm9ybUNvbXBvbmVudCxcclxuICAgIER5bmFtaWNCYXNlRm9ybUFycmF5Q29tcG9uZW50LFxyXG4gICAgRHluYW1pY0Jhc2VGb3JtQ29udHJvbENvbXBvbmVudCxcclxuICAgIER5bmFtaWNCYXNlRm9ybUNvbnRyb2xDb250YWluZXJDb21wb25lbnQsXHJcbiAgICBEeW5hbWljQmFzZUZvcm1Hcm91cENvbXBvbmVudCxcclxuICAgIER5bmFtaWNCYXNlU2VsZWN0Q29tcG9uZW50XHJcbl07XHJcblxyXG4vLyAtLS0gRGlyZWN0aXZlcyAtLS1cclxuZXhwb3J0IGNvbnN0IGRpcmVjdGl2ZXMgPSBbXHJcbiAgICBBc3luY1N1Ym1pdERpcmVjdGl2ZSxcclxuXTtcclxuXHJcbi8vIC0tLSBQaXBlcyAtLS1cclxuZXhwb3J0IGNvbnN0IHBpcGVzID0gW107XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gZGVmYXVsdEZvcm1Db250cm9sUHJvdmlkZXIoKTogRHluYW1pY0Zvcm1Db250cm9sTWFwRm4ge1xyXG4gICAgcmV0dXJuICgpID0+IG51bGw7XHJcbn1cclxuIl19
|