@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.
Files changed (32) hide show
  1. package/README.md +27 -27
  2. package/bundles/stemy-ngx-dynamic-form.umd.js +1400 -1390
  3. package/bundles/stemy-ngx-dynamic-form.umd.js.map +1 -1
  4. package/bundles/stemy-ngx-dynamic-form.umd.min.js +1 -1
  5. package/bundles/stemy-ngx-dynamic-form.umd.min.js.map +1 -1
  6. package/esm2015/ngx-dynamic-form/common-types.js +134 -134
  7. package/esm2015/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.js +91 -91
  8. package/esm2015/ngx-dynamic-form/components/base/dynamic-base-form.component.js +129 -129
  9. package/esm2015/ngx-dynamic-form/directives/async-submit.directive.js +100 -100
  10. package/esm2015/ngx-dynamic-form/ngx-dynamic-form.module.js +82 -82
  11. package/esm2015/ngx-dynamic-form/services/dynamic-form-validation.service.js +11 -11
  12. package/esm2015/ngx-dynamic-form/services/dynamic-form.service.js +393 -383
  13. package/esm2015/ngx-dynamic-form/utils/dynamic-form-array.model.js +8 -8
  14. package/esm2015/ngx-dynamic-form/utils/form-subject.js +18 -18
  15. package/esm2015/ngx-dynamic-form/utils/validators.js +28 -28
  16. package/esm2015/public_api.js +9 -9
  17. package/esm2015/stemy-ngx-dynamic-form.js +6 -6
  18. package/fesm2015/stemy-ngx-dynamic-form.js +936 -926
  19. package/fesm2015/stemy-ngx-dynamic-form.js.map +1 -1
  20. package/ngx-dynamic-form/common-types.d.ts +148 -148
  21. package/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.d.ts +37 -37
  22. package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +37 -37
  23. package/ngx-dynamic-form/directives/async-submit.directive.d.ts +27 -27
  24. package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +10 -10
  25. package/ngx-dynamic-form/services/dynamic-form-validation.service.d.ts +5 -5
  26. package/ngx-dynamic-form/services/dynamic-form.service.d.ts +40 -40
  27. package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +12 -12
  28. package/ngx-dynamic-form/utils/form-subject.d.ts +8 -8
  29. package/ngx-dynamic-form/utils/validators.d.ts +4 -4
  30. package/package.json +12 -12
  31. package/public_api.d.ts +8 -8
  32. 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":";AAAA,OAAO,EAEH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,eAAe,EACf,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,MAAM,EACN,SAAS,EACM,SAAS,EACxB,YAAY,EACf,MAAM,eAAe,CAAC;AACvB,OAAO,EAAuB,MAAM,EAAC,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAC,YAAY,EAAC,MAAM,MAAM,CAAC;AAClC,OAAO,EAAC,KAAK,EAAC,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAEH,oBAAoB,EACpB,2BAA2B,EAI3B,wBAAwB,EAC3B,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAC,aAAa,EAAE,eAAe,EAAC,MAAM,kBAAkB,CAAC;AAEhE,OAAO,EAAC,kBAAkB,EAAC,MAAM,qCAAqC,CAAC;AAOvE,MAAM,OAAO,wBAAyB,SAAQ,oBAAoB;IA2B9D,YAAiD,WAA+B,EACpC,MAAqB,EACrD,iBAAoC,EACpC,gBAA6C;QACrD,KAAK,CAAC,iBAAiB,EAAE,gBAAgB,CAAC,CAAC;QAJE,gBAAW,GAAX,WAAW,CAAoB;QACpC,WAAM,GAAN,MAAM,CAAe;QAI7D,IAAI,CAAC,IAAI,GAAG,IAAI,YAAY,EAA2B,CAAC;QACxD,IAAI,CAAC,MAAM,GAAG,IAAI,YAAY,EAA2B,CAAC;QAC1D,IAAI,CAAC,KAAK,GAAG,IAAI,YAAY,EAA2B,CAAC;QACzD,IAAI,CAAC,cAAc,GAAG,IAAI,YAAY,EAAoB,CAAC;QAC3D,IAAI,CAAC,aAAa,GAAG,IAAI,YAAY,EAAoB,CAAC;QAC1D,IAAI,CAAC,QAAQ,GAAG,IAAI,YAAY,EAAoB,CAAC;QACrD,IAAI,CAAC,SAAS,GAAG,IAAI,SAAS,EAA4B,CAAC;QAC3D,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QACvC,IAAI,CAAC,iBAAiB,GAAG,IAAI,YAAY,EAAE,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC;IAC/B,CAAC;IA5BD,IAAI,MAAM;QACN,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAA0B,CAAC;IACtE,CAAC;IA4BD,WAAW,CAAC,OAAsB;QAC9B,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;QACrC,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,iBAAiB,GAAG,eAAe,CAAC,iBAAiB,CACtD,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,EAAE;gBACpC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnC,CAAC,CAAC,EACF,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;gBACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC9B,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3D,CAAC,CAAC,CACL,CAAC;SACL;IACL,CAAC;IAED,eAAe;QACX,IAAI,CAAC,YAAY,GAAG,eAAe,CAAC,iBAAiB,CACjD,eAAe,CAAC,SAAS,CACrB;YACI,QAAQ,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC;YACrE,EAAE,EAAE,GAAG,EAAE;gBACL,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;gBACvF,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YACpC,CAAC;SACJ,CACJ,EACD,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,CAAA;QACxC,CAAC,CAAC,EACF,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;IACzC,CAAC;IAED,oBAAoB,CAAC,KAAa,EAAE,SAAoB,EAAE,cAAqC;QAC3F,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,KAAK,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC;QACxE,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IAC3C,CAAC;IAED,oBAAoB,CAAC,KAAa,EAAE,SAAoB,EAAE,cAAqC;QAC3F,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,KAAK,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC;QACxE,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IAC3C,CAAC;IAED,kBAAkB,CAAC,KAAa,EAAE,IAAY,EAAE,SAAoB,EAAE,cAAqC;QACvG,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC;QAC5E,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IAC3C,CAAC;IAED,cAAc,CAAC,SAAoB,EAAE,cAAqC;QACtE,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;QAC3D,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IAC3C,CAAC;IAED,QAAQ,CAAC,aAAsB,IAAI;QAC/B,IAAI,CAAC,IAAI,CAAC,KAAK;YAAE,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;QAC1C,OAAO,IAAI,OAAO,CAAM,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACxC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,IAAI,OAAO,IAAI,MAAM,IAAI,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;gBACxG,IAAI,UAAU,EAAE;oBACZ,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;iBACrC;gBACD,IAAI,MAAM,IAAI,OAAO,EAAE;oBACnB,OAAO,CAAC,IAAI,CAAC,CAAC;oBACd,OAAO;iBACV;gBACD,MAAM,CAAC,IAAI,CAAC,CAAC;YACjB,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,KAAK,CAAC,sBAAsB,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;IACP,CAAC;IAEK,SAAS,CAAC,QAAkB;;YAC9B,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,OAAO,IAAI,CAAC;YAC7B,IAAI,QAAQ,EAAE;gBACV,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;aACzB;YACD,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QACpE,CAAC;KAAA;;;YArIJ,SAAS,SAAC;gBACP,QAAQ,EAAE,mBAAmB;gBAC7B,QAAQ,EAAE,EAAE;gBACZ,eAAe,EAAE,uBAAuB,CAAC,OAAO;aACnD;;;YANO,kBAAkB,uBAkCT,MAAM,SAAC,kBAAkB;YApClC,aAAa,uBAqCJ,MAAM,SAAC,aAAa;YA7DjC,iBAAiB;YAkBjB,2BAA2B;;;oBAiB1B,KAAK;oBACL,KAAK;qBACL,KAAK;0BACL,KAAK;mBAEL,MAAM;qBACN,MAAM;oBACN,MAAM;+BAEN,eAAe,SAAC,wBAAwB;4BACxC,YAAY,SAAC,wBAAwB;6BAMrC,MAAM;4BACN,MAAM;uBACN,MAAM;qBAEN,SAAS,SAAC,MAAM","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,{"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 {\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2\n} from \"@angular/core\";\nimport {Subscription} from \"rxjs\";\nimport {IAsyncMessage, IToasterService, TOASTER_SERVICE} from \"@stemy/ngx-utils\";\nimport {AsyncSubmitMethod, IDynamicFormBase} from \"../common-types\";\n\n@Directive({\n    selector: \"[async-submit]\",\n    exportAs: \"async-submit\"\n})\nexport class AsyncSubmitDirective implements OnInit, OnDestroy {\n\n    @Input(\"async-submit\") method: AsyncSubmitMethod;\n    @Input() form: IDynamicFormBase;\n    @Input() context: any;\n\n    @Output() onSuccess: EventEmitter<IAsyncMessage>;\n    @Output() onError: EventEmitter<IAsyncMessage>;\n\n    private loading: boolean;\n    private disabled: boolean;\n    private callback: Function;\n    private onStatusChange: Subscription;\n    private onSubmit: Subscription;\n\n    @HostBinding(\"class.disabled\")\n    get isDisabled(): boolean {\n        return this.disabled;\n    }\n\n    set isDisabled(value: boolean) {\n        this.disabled = value;\n        if (value) {\n            this.renderer.setAttribute(this.elem.nativeElement, \"disabled\", \"disabled\");\n            return;\n        }\n        this.renderer.removeAttribute(this.elem.nativeElement, \"disabled\");\n    }\n\n    @HostBinding(\"class.loading\")\n    get isLoading(): boolean {\n        return this.loading;\n    }\n\n    constructor(@Inject(TOASTER_SERVICE) private toaster: IToasterService,\n                readonly cdr: ChangeDetectorRef,\n                readonly elem: ElementRef,\n                readonly renderer: Renderer2) {\n        this.onSuccess = new EventEmitter<IAsyncMessage>();\n        this.onError = new EventEmitter<IAsyncMessage>();\n        if (elem.nativeElement.tagName !== \"BUTTON\") return;\n        renderer.setAttribute(elem.nativeElement, \"type\", \"button\");\n    }\n\n    ngOnInit(): void {\n        if (!this.form) return;\n        this.isDisabled = this.form.status !== \"VALID\";\n        this.cdr.detectChanges();\n        this.onStatusChange = this.form.onStatusChange.subscribe(() => {\n            this.isDisabled = this.form.status !== \"VALID\";\n            this.cdr.detectChanges();\n            if (!this.callback || this.form.status == \"PENDING\") return;\n            if (!this.disabled) {\n                this.callback();\n            }\n            this.callback = null;\n        });\n        this.onSubmit = this.form.onSubmit.subscribe(() => this.callMethod());\n    }\n\n    ngOnDestroy(): void {\n        if (this.onStatusChange) this.onStatusChange.unsubscribe();\n        if (this.onSubmit) this.onSubmit.unsubscribe();\n    }\n\n    @HostListener(\"click\")\n    click(): void {\n        this.callback = () => this.callMethod();\n        if (this.form.status !== \"VALID\" && this.form.status !== \"INVALID\") return;\n        this.callback();\n        this.callback = null;\n    }\n\n    callMethod(): void {\n        if (this.loading) return;\n        this.loading = true;\n        this.method(this.form, this.context).then(result => {\n            this.loading = false;\n            if (result) {\n                this.onSuccess.emit(result);\n                this.toaster.success(result.message, result.context);\n            }\n        }, reason => {\n            if (!reason || !reason.message)\n                throw new Error(\"Reason must implement IAsyncMessage interface\");\n            this.loading = false;\n            this.onError.emit(reason);\n            this.toaster.error(reason.message, reason.context);\n        });\n    }\n}\n"]}
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"]}