@stemy/ngx-dynamic-form 12.0.0 → 13.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. package/esm2020/ngx-dynamic-form/common-types.mjs +97 -0
  2. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-array.component.mjs +85 -0
  3. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.mjs +109 -0
  4. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-group.component.mjs +74 -0
  5. package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form.component.mjs +158 -0
  6. package/esm2020/ngx-dynamic-form/directives/async-submit.directive.mjs +111 -0
  7. package/esm2020/ngx-dynamic-form/ngx-dynamic-form.imports.mjs +22 -0
  8. package/esm2020/ngx-dynamic-form/ngx-dynamic-form.module.mjs +115 -0
  9. package/esm2020/ngx-dynamic-form/services/dynamic-form.service.mjs +451 -0
  10. package/esm2020/ngx-dynamic-form/utils/dynamic-form-array.model.mjs +16 -0
  11. package/esm2020/ngx-dynamic-form/utils/form-select-subject.mjs +23 -0
  12. package/esm2020/ngx-dynamic-form/utils/form-subject.mjs +29 -0
  13. package/esm2020/ngx-dynamic-form/utils/misc.mjs +20 -0
  14. package/esm2020/ngx-dynamic-form/utils/validators.mjs +56 -0
  15. package/esm2020/public_api.mjs +14 -0
  16. package/esm2020/stemy-ngx-dynamic-form.mjs +5 -0
  17. package/fesm2015/stemy-ngx-dynamic-form.mjs +1341 -0
  18. package/fesm2015/stemy-ngx-dynamic-form.mjs.map +1 -0
  19. package/fesm2020/stemy-ngx-dynamic-form.mjs +1313 -0
  20. package/fesm2020/stemy-ngx-dynamic-form.mjs.map +1 -0
  21. package/ngx-dynamic-form/common-types.d.ts +42 -262
  22. package/ngx-dynamic-form/components/base/dynamic-base-form-array.component.d.ts +29 -0
  23. package/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.d.ts +41 -0
  24. package/ngx-dynamic-form/components/base/dynamic-base-form-group.component.d.ts +24 -0
  25. package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +41 -0
  26. package/ngx-dynamic-form/directives/async-submit.directive.d.ts +10 -3
  27. package/ngx-dynamic-form/ngx-dynamic-form.imports.d.ts +10 -0
  28. package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +14 -17
  29. package/ngx-dynamic-form/services/dynamic-form.service.d.ts +47 -10
  30. package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +22 -0
  31. package/ngx-dynamic-form/utils/form-select-subject.d.ts +6 -0
  32. package/ngx-dynamic-form/utils/form-subject.d.ts +10 -0
  33. package/ngx-dynamic-form/utils/misc.d.ts +5 -0
  34. package/ngx-dynamic-form/utils/validators.d.ts +8 -0
  35. package/package.json +42 -22
  36. package/public_api.d.ts +10 -14
  37. package/stemy-ngx-dynamic-form.d.ts +1 -3
  38. package/bundles/stemy-ngx-dynamic-form.umd.js +0 -2344
  39. package/bundles/stemy-ngx-dynamic-form.umd.js.map +0 -1
  40. package/esm2015/ngx-dynamic-form/common-types.js +0 -590
  41. package/esm2015/ngx-dynamic-form/components/base/dynamic-form-base.component.js +0 -87
  42. package/esm2015/ngx-dynamic-form/components/dynamic-form/dynamic-form.component.js +0 -91
  43. package/esm2015/ngx-dynamic-form/components/dynamic-form-file/dynamic-form-file.component.js +0 -112
  44. package/esm2015/ngx-dynamic-form/components/dynamic-form-group/dynamic-form-group.component.js +0 -19
  45. package/esm2015/ngx-dynamic-form/components/dynamic-form-input/dynamic-form-input.component.js +0 -69
  46. package/esm2015/ngx-dynamic-form/components/dynamic-form-model/dynamic-form-model.component.js +0 -23
  47. package/esm2015/ngx-dynamic-form/components/dynamic-form-select/dynamic-form-select.component.js +0 -73
  48. package/esm2015/ngx-dynamic-form/components/dynamic-form-static/dynamic-form-static.component.js +0 -20
  49. package/esm2015/ngx-dynamic-form/components/dynamic-forms/dynamic-forms.component.js +0 -134
  50. package/esm2015/ngx-dynamic-form/directives/async-submit.directive.js +0 -89
  51. package/esm2015/ngx-dynamic-form/directives/dynamic-form-control.directive.js +0 -32
  52. package/esm2015/ngx-dynamic-form/directives/dynamic-form-group.directive.js +0 -40
  53. package/esm2015/ngx-dynamic-form/directives/dynamic-form-template.directive.js +0 -38
  54. package/esm2015/ngx-dynamic-form/ngx-dynamic-form.module.js +0 -83
  55. package/esm2015/ngx-dynamic-form/services/dynamic-form.service.js +0 -48
  56. package/esm2015/ngx-dynamic-form/services/form-utilities.js +0 -108
  57. package/esm2015/ngx-dynamic-form/services/open-api.service.js +0 -130
  58. package/esm2015/public_api.js +0 -18
  59. package/esm2015/stemy-ngx-dynamic-form.js +0 -8
  60. package/fesm2015/stemy-ngx-dynamic-form.js +0 -1731
  61. package/fesm2015/stemy-ngx-dynamic-form.js.map +0 -1
  62. package/ngx-dynamic-form/components/base/dynamic-form-base.component.d.ts +0 -44
  63. package/ngx-dynamic-form/components/dynamic-form/dynamic-form.component.d.ts +0 -21
  64. package/ngx-dynamic-form/components/dynamic-form-file/dynamic-form-file.component.d.ts +0 -16
  65. package/ngx-dynamic-form/components/dynamic-form-group/dynamic-form-group.component.d.ts +0 -6
  66. package/ngx-dynamic-form/components/dynamic-form-input/dynamic-form-input.component.d.ts +0 -12
  67. package/ngx-dynamic-form/components/dynamic-form-model/dynamic-form-model.component.d.ts +0 -6
  68. package/ngx-dynamic-form/components/dynamic-form-select/dynamic-form-select.component.d.ts +0 -9
  69. package/ngx-dynamic-form/components/dynamic-form-static/dynamic-form-static.component.d.ts +0 -5
  70. package/ngx-dynamic-form/components/dynamic-forms/dynamic-forms.component.d.ts +0 -26
  71. package/ngx-dynamic-form/directives/dynamic-form-control.directive.d.ts +0 -12
  72. package/ngx-dynamic-form/directives/dynamic-form-group.directive.d.ts +0 -14
  73. package/ngx-dynamic-form/directives/dynamic-form-template.directive.d.ts +0 -16
  74. package/ngx-dynamic-form/services/form-utilities.d.ts +0 -19
  75. package/ngx-dynamic-form/services/open-api.service.d.ts +0 -37
  76. package/stemy-ngx-dynamic-form.metadata.json +0 -1
@@ -0,0 +1,158 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Inject, Input, Output, QueryList, ViewChild, ViewChildren } from "@angular/core";
2
+ import { NgForm } from "@angular/forms";
3
+ import { Subscription } from "rxjs";
4
+ import { first } from "rxjs/operators";
5
+ import { DynamicFormComponent, DynamicFormGroupModel, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
6
+ import { EventsService, ObservableUtils } from "@stemy/ngx-utils";
7
+ import { DynamicFormService } from "../../services/dynamic-form.service";
8
+ import { collectPathAble } from "../../utils/misc";
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@ng-dynamic-forms/core";
11
+ import * as i2 from "../../services/dynamic-form.service";
12
+ import * as i3 from "@stemy/ngx-utils";
13
+ export class DynamicBaseFormComponent extends DynamicFormComponent {
14
+ constructor(formService, events, changeDetectorRef, componentService) {
15
+ super(changeDetectorRef, componentService);
16
+ this.formService = formService;
17
+ this.events = events;
18
+ this.blur = new EventEmitter();
19
+ this.change = new EventEmitter();
20
+ this.focus = new EventEmitter();
21
+ this.onValueChange = new EventEmitter();
22
+ this.onStatusChange = new EventEmitter();
23
+ this.onSubmit = new EventEmitter();
24
+ this.templates = new QueryList();
25
+ this.subscription = new Subscription();
26
+ this.groupSubscription = new Subscription();
27
+ this.labelPrefix = "label";
28
+ }
29
+ get status() {
30
+ return !this.group ? null : this.group.status;
31
+ }
32
+ ngOnChanges(changes) {
33
+ this.groupSubscription.unsubscribe();
34
+ if (this.group) {
35
+ this.groupSubscription = ObservableUtils.multiSubscription(this.group.statusChanges.subscribe(() => {
36
+ this.onStatusChange.emit(this);
37
+ }), this.group.valueChanges.subscribe(() => {
38
+ this.formService.notifyChanges(this.model, this.group, this.model);
39
+ }), this.change.subscribe(ev => {
40
+ this.onValueChange.emit({ ...ev, form: this });
41
+ }));
42
+ }
43
+ }
44
+ ngAfterViewInit() {
45
+ this.subscription = ObservableUtils.multiSubscription(ObservableUtils.subscribe({
46
+ subjects: [this.contentTemplates.changes, this.viewTemplates.changes],
47
+ cb: () => {
48
+ const templates = this.contentTemplates.toArray().concat(this.viewTemplates.toArray());
49
+ this.templates.reset(templates);
50
+ }
51
+ }), this.events.languageChanged.subscribe(() => {
52
+ this.formService.detectChanges(this);
53
+ }), this.ngForm.ngSubmit.subscribe(() => {
54
+ this.onSubmit.emit(this);
55
+ }));
56
+ }
57
+ ngOnDestroy() {
58
+ super.ngOnDestroy();
59
+ this.subscription.unsubscribe();
60
+ this.groupSubscription.unsubscribe();
61
+ }
62
+ insertFormArrayGroup(index, formArray, formArrayModel) {
63
+ this.formService.insertFormArrayGroup(index, formArray, formArrayModel);
64
+ this.changeDetectorRef.detectChanges();
65
+ }
66
+ removeFormArrayGroup(index, formArray, formArrayModel) {
67
+ this.formService.removeFormArrayGroup(index, formArray, formArrayModel);
68
+ this.changeDetectorRef.detectChanges();
69
+ }
70
+ moveFormArrayGroup(index, step, formArray, formArrayModel) {
71
+ this.formService.moveFormArrayGroup(index, step, formArray, formArrayModel);
72
+ this.changeDetectorRef.detectChanges();
73
+ }
74
+ clearFormArray(formArray, formArrayModel) {
75
+ this.formService.clearFormArray(formArray, formArrayModel);
76
+ this.changeDetectorRef.detectChanges();
77
+ }
78
+ getClass(model) {
79
+ const parts = collectPathAble(model, p => p.id);
80
+ if (parts.length == 0)
81
+ return "";
82
+ if (model instanceof DynamicFormGroupModel) {
83
+ return `form-group-${parts.join("-")}`;
84
+ }
85
+ return `form-control-${parts.join("-")}`;
86
+ }
87
+ validate(showErrors = true) {
88
+ if (!this.group)
89
+ return Promise.resolve();
90
+ return new Promise((resolve, reject) => {
91
+ this.group.statusChanges.pipe(first(status => status == "VALID" || status == "INVALID")).subscribe(status => {
92
+ if (showErrors) {
93
+ this.formService.showErrors(this);
94
+ }
95
+ if (status == "VALID") {
96
+ resolve(null);
97
+ return;
98
+ }
99
+ reject(null);
100
+ });
101
+ this.group.updateValueAndValidity();
102
+ });
103
+ }
104
+ async serialize(validate) {
105
+ if (!this.group)
106
+ return null;
107
+ if (validate) {
108
+ await this.validate();
109
+ }
110
+ return await this.formService.serialize(this.model, this.group);
111
+ }
112
+ }
113
+ 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 });
114
+ DynamicBaseFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseFormComponent, selector: "dynamic-base-form", inputs: { group: "group", model: "model", layout: "layout", labelPrefix: "labelPrefix" }, outputs: { blur: "blur", change: "change", focus: "focus", onValueChange: "onValueChange", onStatusChange: "onStatusChange", onSubmit: "onSubmit" }, queries: [{ propertyName: "contentTemplates", predicate: DynamicTemplateDirective }], viewQueries: [{ propertyName: "ngForm", first: true, predicate: NgForm, descendants: true }, { propertyName: "viewTemplates", predicate: DynamicTemplateDirective, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.Default });
115
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormComponent, decorators: [{
116
+ type: Component,
117
+ args: [{
118
+ selector: "dynamic-base-form",
119
+ template: "",
120
+ changeDetection: ChangeDetectionStrategy.Default
121
+ }]
122
+ }], ctorParameters: function () { return [{ type: i2.DynamicFormService, decorators: [{
123
+ type: Inject,
124
+ args: [DynamicFormService]
125
+ }] }, { type: i3.EventsService, decorators: [{
126
+ type: Inject,
127
+ args: [EventsService]
128
+ }] }, { type: i0.ChangeDetectorRef }, { type: i1.DynamicFormComponentService }]; }, propDecorators: { group: [{
129
+ type: Input
130
+ }], model: [{
131
+ type: Input
132
+ }], layout: [{
133
+ type: Input
134
+ }], labelPrefix: [{
135
+ type: Input
136
+ }], blur: [{
137
+ type: Output
138
+ }], change: [{
139
+ type: Output
140
+ }], focus: [{
141
+ type: Output
142
+ }], contentTemplates: [{
143
+ type: ContentChildren,
144
+ args: [DynamicTemplateDirective]
145
+ }], viewTemplates: [{
146
+ type: ViewChildren,
147
+ args: [DynamicTemplateDirective]
148
+ }], onValueChange: [{
149
+ type: Output
150
+ }], onStatusChange: [{
151
+ type: Output
152
+ }], onSubmit: [{
153
+ type: Output
154
+ }], ngForm: [{
155
+ type: ViewChild,
156
+ args: [NgForm]
157
+ }] } });
158
+ //# 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    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    DynamicFormControlModel,\r\n    DynamicFormGroupModel,\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, IDynamicFormEvent} from \"../../common-types\";\r\nimport {DynamicFormService} from \"../../services/dynamic-form.service\";\r\nimport {collectPathAble} from \"../../utils/misc\";\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 onValueChange: EventEmitter<IDynamicFormEvent>;\r\n    @Output() readonly onStatusChange: EventEmitter<IDynamicForm>;\r\n    @Output() readonly onSubmit: EventEmitter<IDynamicForm>;\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.onValueChange = new EventEmitter<IDynamicFormEvent>();\r\n        this.onStatusChange = new EventEmitter<IDynamicForm>();\r\n        this.onSubmit = 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    }\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.formService.notifyChanges(this.model, this.group, this.model);\r\n                }),\r\n                this.change.subscribe(ev => {\r\n                    this.onValueChange.emit({...ev, form: this});\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    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"]}
@@ -0,0 +1,111 @@
1
+ import { Directive, EventEmitter, HostBinding, HostListener, Inject, Input, Output } from "@angular/core";
2
+ import { TOASTER_SERVICE } from "@stemy/ngx-utils";
3
+ import * as i0 from "@angular/core";
4
+ export class AsyncSubmitDirective {
5
+ constructor(toaster, cdr, elem, renderer) {
6
+ this.toaster = toaster;
7
+ this.cdr = cdr;
8
+ this.elem = elem;
9
+ this.renderer = renderer;
10
+ this.onSuccess = new EventEmitter();
11
+ this.onError = new EventEmitter();
12
+ if (elem.nativeElement.tagName !== "BUTTON")
13
+ return;
14
+ renderer.setAttribute(elem.nativeElement, "type", "button");
15
+ }
16
+ get isDisabled() {
17
+ return this.disabled;
18
+ }
19
+ set isDisabled(value) {
20
+ this.disabled = value;
21
+ if (value) {
22
+ this.renderer.setAttribute(this.elem.nativeElement, "disabled", "disabled");
23
+ return;
24
+ }
25
+ this.renderer.removeAttribute(this.elem.nativeElement, "disabled");
26
+ }
27
+ get isLoading() {
28
+ return this.loading;
29
+ }
30
+ ngOnInit() {
31
+ if (!this.form)
32
+ return;
33
+ this.isDisabled = this.form.status !== "VALID";
34
+ this.cdr.detectChanges();
35
+ this.onStatusChange = this.form.onStatusChange.subscribe(() => {
36
+ this.isDisabled = this.form.status !== "VALID";
37
+ this.cdr.detectChanges();
38
+ if (!this.callback || this.form.status == "PENDING")
39
+ return;
40
+ if (!this.disabled) {
41
+ this.callback();
42
+ }
43
+ this.callback = null;
44
+ });
45
+ this.onSubmit = this.form.onSubmit.subscribe(() => this.callMethod());
46
+ }
47
+ ngOnDestroy() {
48
+ if (this.onStatusChange)
49
+ this.onStatusChange.unsubscribe();
50
+ if (this.onSubmit)
51
+ this.onSubmit.unsubscribe();
52
+ }
53
+ click() {
54
+ this.callback = () => this.callMethod();
55
+ if (this.form.status !== "VALID" && this.form.status !== "INVALID")
56
+ return;
57
+ this.callback();
58
+ this.callback = null;
59
+ }
60
+ callMethod() {
61
+ if (this.loading)
62
+ return;
63
+ this.loading = true;
64
+ this.method(this.form, this.context).then(result => {
65
+ this.loading = false;
66
+ if (result) {
67
+ this.onSuccess.emit(result);
68
+ this.toaster.success(result.message, result.context);
69
+ }
70
+ }, reason => {
71
+ if (!reason || !reason.message)
72
+ throw new Error("Reason must implement IAsyncMessage interface");
73
+ this.loading = false;
74
+ this.onError.emit(reason);
75
+ this.toaster.error(reason.message, reason.context);
76
+ });
77
+ }
78
+ }
79
+ 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 });
80
+ 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 });
81
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: AsyncSubmitDirective, decorators: [{
82
+ type: Directive,
83
+ args: [{
84
+ selector: "[async-submit]",
85
+ exportAs: "async-submit"
86
+ }]
87
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
88
+ type: Inject,
89
+ args: [TOASTER_SERVICE]
90
+ }] }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { method: [{
91
+ type: Input,
92
+ args: ["async-submit"]
93
+ }], form: [{
94
+ type: Input
95
+ }], context: [{
96
+ type: Input
97
+ }], onSuccess: [{
98
+ type: Output
99
+ }], onError: [{
100
+ type: Output
101
+ }], isDisabled: [{
102
+ type: HostBinding,
103
+ args: ["class.disabled"]
104
+ }], isLoading: [{
105
+ type: HostBinding,
106
+ args: ["class.loading"]
107
+ }], click: [{
108
+ type: HostListener,
109
+ args: ["click"]
110
+ }] } });
111
+ //# 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":"AAAA,OAAO,EAEH,SAAS,EAET,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,MAAM,EAET,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAiC,eAAe,EAAC,MAAM,kBAAkB,CAAC;;AAOjF,MAAM,OAAO,oBAAoB;IAkC7B,YAA6C,OAAwB,EAChD,GAAsB,EACtB,IAAgB,EAChB,QAAmB;QAHK,YAAO,GAAP,OAAO,CAAiB;QAChD,QAAG,GAAH,GAAG,CAAmB;QACtB,SAAI,GAAJ,IAAI,CAAY;QAChB,aAAQ,GAAR,QAAQ,CAAW;QACpC,IAAI,CAAC,SAAS,GAAG,IAAI,YAAY,EAAiB,CAAC;QACnD,IAAI,CAAC,OAAO,GAAG,IAAI,YAAY,EAAiB,CAAC;QACjD,IAAI,IAAI,CAAC,aAAa,CAAC,OAAO,KAAK,QAAQ;YAAE,OAAO;QACpD,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;IAChE,CAAC;IA3BD,IACI,UAAU;QACV,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED,IAAI,UAAU,CAAC,KAAc;QACzB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;YAC5E,OAAO;SACV;QACD,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;IACvE,CAAC;IAED,IACI,SAAS;QACT,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAYD,QAAQ;QACJ,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,OAAO;QACvB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC;QAC/C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,GAAG,EAAE;YAC1D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC;YAC/C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,SAAS;gBAAE,OAAO;YAC5D,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;gBAChB,IAAI,CAAC,QAAQ,EAAE,CAAC;aACnB;YACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACzB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;IAC1E,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,cAAc;YAAE,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;QAC3D,IAAI,IAAI,CAAC,QAAQ;YAAE,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IACnD,CAAC;IAGD,KAAK;QACD,IAAI,CAAC,QAAQ,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;QACxC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS;YAAE,OAAO;QAC3E,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACzB,CAAC;IAED,UAAU;QACN,IAAI,IAAI,CAAC,OAAO;YAAE,OAAO;QACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;YAC/C,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,MAAM,EAAE;gBACR,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC5B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;aACxD;QACL,CAAC,EAAE,MAAM,CAAC,EAAE;YACR,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO;gBAC1B,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;YACrE,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC1B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;IACP,CAAC;;iHAzFQ,oBAAoB,kBAkCT,eAAe;qGAlC1B,oBAAoB;2FAApB,oBAAoB;kBAJhC,SAAS;mBAAC;oBACP,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ,EAAE,cAAc;iBAC3B;;0BAmCgB,MAAM;2BAAC,eAAe;6HAhCZ,MAAM;sBAA5B,KAAK;uBAAC,cAAc;gBACZ,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAEI,SAAS;sBAAlB,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBASH,UAAU;sBADb,WAAW;uBAAC,gBAAgB;gBAezB,SAAS;sBADZ,WAAW;uBAAC,eAAe;gBAqC5B,KAAK;sBADJ,YAAY;uBAAC,OAAO","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, IDynamicForm} 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: 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.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"]}
@@ -0,0 +1,22 @@
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 { DynamicBaseFormControlContainerComponent } from "./components/base/dynamic-base-form-control-container.component";
5
+ import { DynamicBaseFormGroupComponent } from "./components/base/dynamic-base-form-group.component";
6
+ // --- Components ---
7
+ export const components = [
8
+ DynamicBaseFormComponent,
9
+ DynamicBaseFormArrayComponent,
10
+ DynamicBaseFormControlContainerComponent,
11
+ DynamicBaseFormGroupComponent
12
+ ];
13
+ // --- Directives ---
14
+ export const directives = [
15
+ AsyncSubmitDirective,
16
+ ];
17
+ // --- Pipes ---
18
+ export const pipes = [];
19
+ export function defaultFormControlProvider() {
20
+ return () => null;
21
+ }
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWR5bmFtaWMtZm9ybS5pbXBvcnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL25neC1keW5hbWljLWZvcm0vbmd4LWR5bmFtaWMtZm9ybS5pbXBvcnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBRXpFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLCtDQUErQyxDQUFDO0FBQ3ZGLE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQ2xHLE9BQU8sRUFDSCx3Q0FBd0MsRUFDM0MsTUFBTSxpRUFBaUUsQ0FBQztBQUN6RSxPQUFPLEVBQUMsNkJBQTZCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUdsRyxxQkFBcUI7QUFDckIsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3RCLHdCQUF3QjtJQUN4Qiw2QkFBNkI7SUFDN0Isd0NBQXdDO0lBQ3hDLDZCQUE2QjtDQUNoQyxDQUFDO0FBRUYscUJBQXFCO0FBQ3JCLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRztJQUN0QixvQkFBb0I7Q0FDdkIsQ0FBQztBQUVGLGdCQUFnQjtBQUNoQixNQUFNLENBQUMsTUFBTSxLQUFLLEdBQUcsRUFBRSxDQUFDO0FBRXhCLE1BQU0sVUFBVSwwQkFBMEI7SUFDdEMsT0FBTyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUM7QUFDdEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXN5bmNTdWJtaXREaXJlY3RpdmV9IGZyb20gXCIuL2RpcmVjdGl2ZXMvYXN5bmMtc3VibWl0LmRpcmVjdGl2ZVwiO1xyXG5cclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Db21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1BcnJheUNvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLWFycmF5LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge1xyXG4gICAgRHluYW1pY0Jhc2VGb3JtQ29udHJvbENvbnRhaW5lckNvbXBvbmVudFxyXG59IGZyb20gXCIuL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS1jb250cm9sLWNvbnRhaW5lci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Hcm91cENvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLWdyb3VwLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0R5bmFtaWNGb3JtQ29udHJvbE1hcEZufSBmcm9tIFwiQG5nLWR5bmFtaWMtZm9ybXMvY29yZS9saWIvc2VydmljZS9keW5hbWljLWZvcm0tY29tcG9uZW50LnNlcnZpY2VcIjtcclxuXHJcbi8vIC0tLSBDb21wb25lbnRzIC0tLVxyXG5leHBvcnQgY29uc3QgY29tcG9uZW50cyA9IFtcclxuICAgIER5bmFtaWNCYXNlRm9ybUNvbXBvbmVudCxcclxuICAgIER5bmFtaWNCYXNlRm9ybUFycmF5Q29tcG9uZW50LFxyXG4gICAgRHluYW1pY0Jhc2VGb3JtQ29udHJvbENvbnRhaW5lckNvbXBvbmVudCxcclxuICAgIER5bmFtaWNCYXNlRm9ybUdyb3VwQ29tcG9uZW50XHJcbl07XHJcblxyXG4vLyAtLS0gRGlyZWN0aXZlcyAtLS1cclxuZXhwb3J0IGNvbnN0IGRpcmVjdGl2ZXMgPSBbXHJcbiAgICBBc3luY1N1Ym1pdERpcmVjdGl2ZSxcclxuXTtcclxuXHJcbi8vIC0tLSBQaXBlcyAtLS1cclxuZXhwb3J0IGNvbnN0IHBpcGVzID0gW107XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gZGVmYXVsdEZvcm1Db250cm9sUHJvdmlkZXIoKTogRHluYW1pY0Zvcm1Db250cm9sTWFwRm4ge1xyXG4gICAgcmV0dXJuICgpID0+IG51bGw7XHJcbn1cclxuIl19
@@ -0,0 +1,115 @@
1
+ import { Injector, NgModule } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { FormsModule, NG_VALIDATORS, ReactiveFormsModule } from "@angular/forms";
4
+ import { DYNAMIC_FORM_CONTROL_MAP_FN, DYNAMIC_VALIDATORS, DynamicFormService as BaseDynamicFormService } from "@ng-dynamic-forms/core";
5
+ import { NgxUtilsModule } from "@stemy/ngx-utils";
6
+ import { validateItemsMaxLength, validateItemsMaxValue, validateItemsMinLength, validateItemsMinValue, validateJSON, validatePhone, validateRequiredTranslation } from "./utils/validators";
7
+ import { DynamicFormService } from "./services/dynamic-form.service";
8
+ import { components, defaultFormControlProvider, directives, pipes } from "./ngx-dynamic-form.imports";
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "./components/base/dynamic-base-form.component";
11
+ import * as i2 from "./components/base/dynamic-base-form-array.component";
12
+ import * as i3 from "./components/base/dynamic-base-form-control-container.component";
13
+ import * as i4 from "./components/base/dynamic-base-form-group.component";
14
+ import * as i5 from "./directives/async-submit.directive";
15
+ export class NgxDynamicFormModule {
16
+ static forRoot(config) {
17
+ return {
18
+ ngModule: NgxDynamicFormModule,
19
+ providers: [
20
+ DynamicFormService,
21
+ {
22
+ provide: BaseDynamicFormService,
23
+ useExisting: DynamicFormService
24
+ },
25
+ {
26
+ provide: DYNAMIC_FORM_CONTROL_MAP_FN,
27
+ useFactory: (config?.controlProvider || defaultFormControlProvider),
28
+ deps: [Injector]
29
+ }
30
+ ]
31
+ };
32
+ }
33
+ }
34
+ NgxDynamicFormModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: NgxDynamicFormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
35
+ NgxDynamicFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: NgxDynamicFormModule, declarations: [i1.DynamicBaseFormComponent, i2.DynamicBaseFormArrayComponent, i3.DynamicBaseFormControlContainerComponent, i4.DynamicBaseFormGroupComponent, i5.AsyncSubmitDirective], imports: [CommonModule,
36
+ FormsModule,
37
+ ReactiveFormsModule,
38
+ NgxUtilsModule], exports: [i1.DynamicBaseFormComponent, i2.DynamicBaseFormArrayComponent, i3.DynamicBaseFormControlContainerComponent, i4.DynamicBaseFormGroupComponent, i5.AsyncSubmitDirective, FormsModule,
39
+ ReactiveFormsModule,
40
+ NgxUtilsModule] });
41
+ NgxDynamicFormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: NgxDynamicFormModule, providers: [
42
+ ...pipes,
43
+ { provide: NG_VALIDATORS, useValue: validateJSON, multi: true },
44
+ { provide: NG_VALIDATORS, useValue: validateRequiredTranslation, multi: true },
45
+ { provide: NG_VALIDATORS, useValue: validateItemsMinLength, multi: true },
46
+ { provide: NG_VALIDATORS, useValue: validateItemsMaxLength, multi: true },
47
+ { provide: NG_VALIDATORS, useValue: validateItemsMinValue, multi: true },
48
+ { provide: NG_VALIDATORS, useValue: validateItemsMaxValue, multi: true },
49
+ {
50
+ provide: DYNAMIC_VALIDATORS,
51
+ useValue: new Map([
52
+ ["json", validateJSON],
53
+ ["requiredTranslation", validateRequiredTranslation],
54
+ ["phone", validatePhone],
55
+ ["itemsMinLength", validateItemsMinLength],
56
+ ["itemsMaxLength", validateItemsMaxLength],
57
+ ["itemsMinValue", validateItemsMinValue],
58
+ ["itemsMaxValue", validateItemsMaxValue],
59
+ ])
60
+ }
61
+ ], imports: [[
62
+ CommonModule,
63
+ FormsModule,
64
+ ReactiveFormsModule,
65
+ NgxUtilsModule
66
+ ], FormsModule,
67
+ ReactiveFormsModule,
68
+ NgxUtilsModule] });
69
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: NgxDynamicFormModule, decorators: [{
70
+ type: NgModule,
71
+ args: [{
72
+ declarations: [
73
+ ...components,
74
+ ...directives,
75
+ ...pipes
76
+ ],
77
+ imports: [
78
+ CommonModule,
79
+ FormsModule,
80
+ ReactiveFormsModule,
81
+ NgxUtilsModule
82
+ ],
83
+ exports: [
84
+ ...components,
85
+ ...directives,
86
+ ...pipes,
87
+ FormsModule,
88
+ ReactiveFormsModule,
89
+ NgxUtilsModule
90
+ ],
91
+ entryComponents: components,
92
+ providers: [
93
+ ...pipes,
94
+ { provide: NG_VALIDATORS, useValue: validateJSON, multi: true },
95
+ { provide: NG_VALIDATORS, useValue: validateRequiredTranslation, multi: true },
96
+ { provide: NG_VALIDATORS, useValue: validateItemsMinLength, multi: true },
97
+ { provide: NG_VALIDATORS, useValue: validateItemsMaxLength, multi: true },
98
+ { provide: NG_VALIDATORS, useValue: validateItemsMinValue, multi: true },
99
+ { provide: NG_VALIDATORS, useValue: validateItemsMaxValue, multi: true },
100
+ {
101
+ provide: DYNAMIC_VALIDATORS,
102
+ useValue: new Map([
103
+ ["json", validateJSON],
104
+ ["requiredTranslation", validateRequiredTranslation],
105
+ ["phone", validatePhone],
106
+ ["itemsMinLength", validateItemsMinLength],
107
+ ["itemsMaxLength", validateItemsMaxLength],
108
+ ["itemsMinValue", validateItemsMinValue],
109
+ ["itemsMaxValue", validateItemsMaxValue],
110
+ ])
111
+ }
112
+ ]
113
+ }]
114
+ }] });
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-dynamic-form.module.js","sourceRoot":"","sources":["../../../src/ngx-dynamic-form/ngx-dynamic-form.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injector, ModuleWithProviders, NgModule} from \"@angular/core\";\r\nimport {CommonModule} from \"@angular/common\";\r\nimport {FormsModule, NG_VALIDATORS, ReactiveFormsModule} from \"@angular/forms\";\r\nimport {\r\n    DYNAMIC_FORM_CONTROL_MAP_FN,\r\n    DYNAMIC_VALIDATORS,\r\n    DynamicFormService as BaseDynamicFormService,\r\n    Validator,\r\n    ValidatorFactory\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {NgxUtilsModule} from \"@stemy/ngx-utils\";\r\n\r\nimport {\r\n    validateItemsMaxLength,\r\n    validateItemsMaxValue,\r\n    validateItemsMinLength,\r\n    validateItemsMinValue,\r\n    validateJSON,\r\n    validatePhone,\r\n    validateRequiredTranslation\r\n} from \"./utils/validators\";\r\nimport {DynamicFormService} from \"./services/dynamic-form.service\";\r\nimport {components, defaultFormControlProvider, directives, pipes} from \"./ngx-dynamic-form.imports\";\r\nimport {IDynamicFormModuleConfig} from \"./common-types\";\r\n\r\n@NgModule({\r\n    declarations: [\r\n        ...components,\r\n        ...directives,\r\n        ...pipes\r\n    ],\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        NgxUtilsModule\r\n    ],\r\n    exports: [\r\n        ...components,\r\n        ...directives,\r\n        ...pipes,\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        NgxUtilsModule\r\n    ],\r\n    entryComponents: components,\r\n    providers: [\r\n        ...pipes,\r\n        {provide: NG_VALIDATORS, useValue: validateJSON, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateRequiredTranslation, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateItemsMinLength, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateItemsMaxLength, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateItemsMinValue, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateItemsMaxValue, multi: true},\r\n        {\r\n            provide: DYNAMIC_VALIDATORS,\r\n            useValue: new Map<string, Validator | ValidatorFactory>([\r\n                [\"json\", validateJSON],\r\n                [\"requiredTranslation\", validateRequiredTranslation],\r\n                [\"phone\", validatePhone],\r\n                [\"itemsMinLength\", validateItemsMinLength],\r\n                [\"itemsMaxLength\", validateItemsMaxLength],\r\n                [\"itemsMinValue\", validateItemsMinValue],\r\n                [\"itemsMaxValue\", validateItemsMaxValue],\r\n            ])\r\n        }\r\n    ]\r\n})\r\nexport class NgxDynamicFormModule {\r\n\r\n    static forRoot(config?: IDynamicFormModuleConfig): ModuleWithProviders<NgxDynamicFormModule> {\r\n        return {\r\n            ngModule: NgxDynamicFormModule,\r\n            providers: [\r\n                DynamicFormService,\r\n                {\r\n                    provide: BaseDynamicFormService,\r\n                    useExisting: DynamicFormService\r\n                },\r\n                {\r\n                    provide: DYNAMIC_FORM_CONTROL_MAP_FN,\r\n                    useFactory: (config?.controlProvider || defaultFormControlProvider),\r\n                    deps: [Injector]\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}\r\n"]}