@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.
- package/esm2020/ngx-dynamic-form/common-types.mjs +97 -0
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-array.component.mjs +85 -0
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.mjs +109 -0
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-group.component.mjs +74 -0
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form.component.mjs +158 -0
- package/esm2020/ngx-dynamic-form/directives/async-submit.directive.mjs +111 -0
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.imports.mjs +22 -0
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.module.mjs +115 -0
- package/esm2020/ngx-dynamic-form/services/dynamic-form.service.mjs +451 -0
- package/esm2020/ngx-dynamic-form/utils/dynamic-form-array.model.mjs +16 -0
- package/esm2020/ngx-dynamic-form/utils/form-select-subject.mjs +23 -0
- package/esm2020/ngx-dynamic-form/utils/form-subject.mjs +29 -0
- package/esm2020/ngx-dynamic-form/utils/misc.mjs +20 -0
- package/esm2020/ngx-dynamic-form/utils/validators.mjs +56 -0
- package/esm2020/public_api.mjs +14 -0
- package/esm2020/stemy-ngx-dynamic-form.mjs +5 -0
- package/fesm2015/stemy-ngx-dynamic-form.mjs +1341 -0
- package/fesm2015/stemy-ngx-dynamic-form.mjs.map +1 -0
- package/fesm2020/stemy-ngx-dynamic-form.mjs +1313 -0
- package/fesm2020/stemy-ngx-dynamic-form.mjs.map +1 -0
- package/ngx-dynamic-form/common-types.d.ts +42 -262
- package/ngx-dynamic-form/components/base/dynamic-base-form-array.component.d.ts +29 -0
- package/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.d.ts +41 -0
- package/ngx-dynamic-form/components/base/dynamic-base-form-group.component.d.ts +24 -0
- package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +41 -0
- package/ngx-dynamic-form/directives/async-submit.directive.d.ts +10 -3
- package/ngx-dynamic-form/ngx-dynamic-form.imports.d.ts +10 -0
- package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +14 -17
- package/ngx-dynamic-form/services/dynamic-form.service.d.ts +47 -10
- package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +22 -0
- package/ngx-dynamic-form/utils/form-select-subject.d.ts +6 -0
- package/ngx-dynamic-form/utils/form-subject.d.ts +10 -0
- package/ngx-dynamic-form/utils/misc.d.ts +5 -0
- package/ngx-dynamic-form/utils/validators.d.ts +8 -0
- package/package.json +42 -22
- package/public_api.d.ts +10 -14
- package/stemy-ngx-dynamic-form.d.ts +1 -3
- package/bundles/stemy-ngx-dynamic-form.umd.js +0 -2344
- package/bundles/stemy-ngx-dynamic-form.umd.js.map +0 -1
- package/esm2015/ngx-dynamic-form/common-types.js +0 -590
- package/esm2015/ngx-dynamic-form/components/base/dynamic-form-base.component.js +0 -87
- package/esm2015/ngx-dynamic-form/components/dynamic-form/dynamic-form.component.js +0 -91
- package/esm2015/ngx-dynamic-form/components/dynamic-form-file/dynamic-form-file.component.js +0 -112
- package/esm2015/ngx-dynamic-form/components/dynamic-form-group/dynamic-form-group.component.js +0 -19
- package/esm2015/ngx-dynamic-form/components/dynamic-form-input/dynamic-form-input.component.js +0 -69
- package/esm2015/ngx-dynamic-form/components/dynamic-form-model/dynamic-form-model.component.js +0 -23
- package/esm2015/ngx-dynamic-form/components/dynamic-form-select/dynamic-form-select.component.js +0 -73
- package/esm2015/ngx-dynamic-form/components/dynamic-form-static/dynamic-form-static.component.js +0 -20
- package/esm2015/ngx-dynamic-form/components/dynamic-forms/dynamic-forms.component.js +0 -134
- package/esm2015/ngx-dynamic-form/directives/async-submit.directive.js +0 -89
- package/esm2015/ngx-dynamic-form/directives/dynamic-form-control.directive.js +0 -32
- package/esm2015/ngx-dynamic-form/directives/dynamic-form-group.directive.js +0 -40
- package/esm2015/ngx-dynamic-form/directives/dynamic-form-template.directive.js +0 -38
- package/esm2015/ngx-dynamic-form/ngx-dynamic-form.module.js +0 -83
- package/esm2015/ngx-dynamic-form/services/dynamic-form.service.js +0 -48
- package/esm2015/ngx-dynamic-form/services/form-utilities.js +0 -108
- package/esm2015/ngx-dynamic-form/services/open-api.service.js +0 -130
- package/esm2015/public_api.js +0 -18
- package/esm2015/stemy-ngx-dynamic-form.js +0 -8
- package/fesm2015/stemy-ngx-dynamic-form.js +0 -1731
- package/fesm2015/stemy-ngx-dynamic-form.js.map +0 -1
- package/ngx-dynamic-form/components/base/dynamic-form-base.component.d.ts +0 -44
- package/ngx-dynamic-form/components/dynamic-form/dynamic-form.component.d.ts +0 -21
- package/ngx-dynamic-form/components/dynamic-form-file/dynamic-form-file.component.d.ts +0 -16
- package/ngx-dynamic-form/components/dynamic-form-group/dynamic-form-group.component.d.ts +0 -6
- package/ngx-dynamic-form/components/dynamic-form-input/dynamic-form-input.component.d.ts +0 -12
- package/ngx-dynamic-form/components/dynamic-form-model/dynamic-form-model.component.d.ts +0 -6
- package/ngx-dynamic-form/components/dynamic-form-select/dynamic-form-select.component.d.ts +0 -9
- package/ngx-dynamic-form/components/dynamic-form-static/dynamic-form-static.component.d.ts +0 -5
- package/ngx-dynamic-form/components/dynamic-forms/dynamic-forms.component.d.ts +0 -26
- package/ngx-dynamic-form/directives/dynamic-form-control.directive.d.ts +0 -12
- package/ngx-dynamic-form/directives/dynamic-form-group.directive.d.ts +0 -14
- package/ngx-dynamic-form/directives/dynamic-form-template.directive.d.ts +0 -16
- package/ngx-dynamic-form/services/form-utilities.d.ts +0 -19
- package/ngx-dynamic-form/services/open-api.service.d.ts +0 -37
- 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":"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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, 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"]}
|