@ngxs/form-plugin 3.8.2 → 18.0.0-dev.master-f4c2c19
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/esm2022/src/actions.mjs +61 -0
- package/esm2022/src/directive.mjs +177 -0
- package/esm2022/src/form.module.mjs +34 -0
- package/esm2022/src/form.plugin.mjs +64 -0
- package/esm2022/src/public_api.mjs +5 -0
- package/{fesm2015/ngxs-form-plugin.js → fesm2022/ngxs-form-plugin.mjs} +50 -45
- package/fesm2022/ngxs-form-plugin.mjs.map +1 -0
- package/package.json +20 -14
- package/src/directive.d.ts +3 -3
- package/src/form.module.d.ts +3 -3
- package/src/form.plugin.d.ts +1 -1
- package/src/public_api.d.ts +2 -2
- package/bundles/ngxs-form-plugin.umd.js +0 -399
- package/bundles/ngxs-form-plugin.umd.js.map +0 -1
- package/esm2015/src/actions.js +0 -61
- package/esm2015/src/directive.js +0 -176
- package/esm2015/src/form.module.js +0 -32
- package/esm2015/src/form.plugin.js +0 -61
- package/esm2015/src/public_api.js +0 -5
- package/fesm2015/ngxs-form-plugin.js.map +0 -1
- package/ngxs-form-plugin.d.ts +0 -5
- /package/{esm2015/index.js → esm2022/index.mjs} +0 -0
- /package/{esm2015/ngxs-form-plugin.js → esm2022/ngxs-form-plugin.mjs} +0 -0
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
export class UpdateFormStatus {
|
|
2
|
+
static { this.type = '[Forms] Update Form Status'; }
|
|
3
|
+
constructor(payload) {
|
|
4
|
+
this.payload = payload;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
export class UpdateFormValue {
|
|
8
|
+
static { this.type = '[Forms] Update Form Value'; }
|
|
9
|
+
constructor(payload) {
|
|
10
|
+
this.payload = payload;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export class UpdateForm {
|
|
14
|
+
static { this.type = '[Forms] Update Form'; }
|
|
15
|
+
constructor(payload) {
|
|
16
|
+
this.payload = payload;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
export class UpdateFormDirty {
|
|
20
|
+
static { this.type = '[Forms] Update Form Dirty'; }
|
|
21
|
+
constructor(payload) {
|
|
22
|
+
this.payload = payload;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
export class SetFormDirty {
|
|
26
|
+
static { this.type = '[Forms] Set Form Dirty'; }
|
|
27
|
+
constructor(payload) {
|
|
28
|
+
this.payload = payload;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export class SetFormPristine {
|
|
32
|
+
static { this.type = '[Forms] Set Form Pristine'; }
|
|
33
|
+
constructor(payload) {
|
|
34
|
+
this.payload = payload;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
export class UpdateFormErrors {
|
|
38
|
+
static { this.type = '[Forms] Update Form Errors'; }
|
|
39
|
+
constructor(payload) {
|
|
40
|
+
this.payload = payload;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
export class SetFormDisabled {
|
|
44
|
+
static { this.type = '[Forms] Set Form Disabled'; }
|
|
45
|
+
constructor(payload) {
|
|
46
|
+
this.payload = payload;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
export class SetFormEnabled {
|
|
50
|
+
static { this.type = '[Forms] Set Form Enabled'; }
|
|
51
|
+
constructor(payload) {
|
|
52
|
+
this.payload = payload;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
export class ResetForm {
|
|
56
|
+
static { this.type = '[Forms] Reset Form'; }
|
|
57
|
+
constructor(payload) {
|
|
58
|
+
this.payload = payload;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2Zvcm0tcGx1Z2luL3NyYy9hY3Rpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxnQkFBZ0I7YUFDWCxTQUFJLEdBQUcsNEJBQTRCLENBQUM7SUFFcEQsWUFDUyxPQUdOO1FBSE0sWUFBTyxHQUFQLE9BQU8sQ0FHYjtJQUNBLENBQUM7O0FBR04sTUFBTSxPQUFPLGVBQWU7YUFDVixTQUFJLEdBQUcsMkJBQTJCLENBQUM7SUFFbkQsWUFBbUIsT0FBNEQ7UUFBNUQsWUFBTyxHQUFQLE9BQU8sQ0FBcUQ7SUFBRyxDQUFDOztBQUdyRixNQUFNLE9BQU8sVUFBVTthQUNMLFNBQUksR0FBRyxxQkFBcUIsQ0FBQztJQUU3QyxZQUNTLE9BTU47UUFOTSxZQUFPLEdBQVAsT0FBTyxDQU1iO0lBQ0EsQ0FBQzs7QUFHTixNQUFNLE9BQU8sZUFBZTthQUNWLFNBQUksR0FBRywyQkFBMkIsQ0FBQztJQUVuRCxZQUFtQixPQUFnRDtRQUFoRCxZQUFPLEdBQVAsT0FBTyxDQUF5QztJQUFHLENBQUM7O0FBR3pFLE1BQU0sT0FBTyxZQUFZO2FBQ1AsU0FBSSxHQUFHLHdCQUF3QixDQUFDO0lBRWhELFlBQW1CLE9BQWU7UUFBZixZQUFPLEdBQVAsT0FBTyxDQUFRO0lBQUcsQ0FBQzs7QUFHeEMsTUFBTSxPQUFPLGVBQWU7YUFDVixTQUFJLEdBQUcsMkJBQTJCLENBQUM7SUFFbkQsWUFBbUIsT0FBZTtRQUFmLFlBQU8sR0FBUCxPQUFPLENBQVE7SUFBRyxDQUFDOztBQUd4QyxNQUFNLE9BQU8sZ0JBQWdCO2FBQ1gsU0FBSSxHQUFHLDRCQUE0QixDQUFDO0lBRXBELFlBQW1CLE9BQWlFO1FBQWpFLFlBQU8sR0FBUCxPQUFPLENBQTBEO0lBQUcsQ0FBQzs7QUFHMUYsTUFBTSxPQUFPLGVBQWU7YUFDVixTQUFJLEdBQUcsMkJBQTJCLENBQUM7SUFFbkQsWUFBbUIsT0FBZTtRQUFmLFlBQU8sR0FBUCxPQUFPLENBQVE7SUFBRyxDQUFDOztBQUd4QyxNQUFNLE9BQU8sY0FBYzthQUNULFNBQUksR0FBRywwQkFBMEIsQ0FBQztJQUVsRCxZQUFtQixPQUFlO1FBQWYsWUFBTyxHQUFQLE9BQU8sQ0FBUTtJQUFHLENBQUM7O0FBR3hDLE1BQU0sT0FBTyxTQUFTO2FBQ0osU0FBSSxHQUFHLG9CQUFvQixDQUFDO0lBRTVDLFlBQW1CLE9BQXNDO1FBQXRDLFlBQU8sR0FBUCxPQUFPLENBQStCO0lBQUcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBVcGRhdGVGb3JtU3RhdHVzIHtcbiAgc3RhdGljIHJlYWRvbmx5IHR5cGUgPSAnW0Zvcm1zXSBVcGRhdGUgRm9ybSBTdGF0dXMnO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBwYXlsb2FkOiB7XG4gICAgICBzdGF0dXM6IHN0cmluZyB8IG51bGw7XG4gICAgICBwYXRoOiBzdHJpbmc7XG4gICAgfVxuICApIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBVcGRhdGVGb3JtVmFsdWUge1xuICBzdGF0aWMgcmVhZG9ubHkgdHlwZSA9ICdbRm9ybXNdIFVwZGF0ZSBGb3JtIFZhbHVlJztcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgcGF5bG9hZDogeyB2YWx1ZTogYW55OyBwYXRoOiBzdHJpbmc7IHByb3BlcnR5UGF0aD86IHN0cmluZyB9KSB7fVxufVxuXG5leHBvcnQgY2xhc3MgVXBkYXRlRm9ybSB7XG4gIHN0YXRpYyByZWFkb25seSB0eXBlID0gJ1tGb3Jtc10gVXBkYXRlIEZvcm0nO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBwYXlsb2FkOiB7XG4gICAgICB2YWx1ZTogYW55O1xuICAgICAgZXJyb3JzOiB7IFtrOiBzdHJpbmddOiBzdHJpbmcgfSB8IG51bGw7XG4gICAgICBkaXJ0eTogYm9vbGVhbiB8IG51bGw7XG4gICAgICBzdGF0dXM6IHN0cmluZyB8IG51bGw7XG4gICAgICBwYXRoOiBzdHJpbmc7XG4gICAgfVxuICApIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBVcGRhdGVGb3JtRGlydHkge1xuICBzdGF0aWMgcmVhZG9ubHkgdHlwZSA9ICdbRm9ybXNdIFVwZGF0ZSBGb3JtIERpcnR5JztcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgcGF5bG9hZDogeyBkaXJ0eTogYm9vbGVhbiB8IG51bGw7IHBhdGg6IHN0cmluZyB9KSB7fVxufVxuXG5leHBvcnQgY2xhc3MgU2V0Rm9ybURpcnR5IHtcbiAgc3RhdGljIHJlYWRvbmx5IHR5cGUgPSAnW0Zvcm1zXSBTZXQgRm9ybSBEaXJ0eSc7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHBheWxvYWQ6IHN0cmluZykge31cbn1cblxuZXhwb3J0IGNsYXNzIFNldEZvcm1QcmlzdGluZSB7XG4gIHN0YXRpYyByZWFkb25seSB0eXBlID0gJ1tGb3Jtc10gU2V0IEZvcm0gUHJpc3RpbmUnO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBwYXlsb2FkOiBzdHJpbmcpIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBVcGRhdGVGb3JtRXJyb3JzIHtcbiAgc3RhdGljIHJlYWRvbmx5IHR5cGUgPSAnW0Zvcm1zXSBVcGRhdGUgRm9ybSBFcnJvcnMnO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBwYXlsb2FkOiB7IGVycm9yczogeyBbazogc3RyaW5nXTogc3RyaW5nIH0gfCBudWxsOyBwYXRoOiBzdHJpbmcgfSkge31cbn1cblxuZXhwb3J0IGNsYXNzIFNldEZvcm1EaXNhYmxlZCB7XG4gIHN0YXRpYyByZWFkb25seSB0eXBlID0gJ1tGb3Jtc10gU2V0IEZvcm0gRGlzYWJsZWQnO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBwYXlsb2FkOiBzdHJpbmcpIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBTZXRGb3JtRW5hYmxlZCB7XG4gIHN0YXRpYyByZWFkb25seSB0eXBlID0gJ1tGb3Jtc10gU2V0IEZvcm0gRW5hYmxlZCc7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHBheWxvYWQ6IHN0cmluZykge31cbn1cblxuZXhwb3J0IGNsYXNzIFJlc2V0Rm9ybSB7XG4gIHN0YXRpYyByZWFkb25seSB0eXBlID0gJ1tGb3Jtc10gUmVzZXQgRm9ybSc7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHBheWxvYWQ6IHsgcGF0aDogc3RyaW5nOyB2YWx1ZT86IGFueSB9KSB7fVxufVxuIl19
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import { ChangeDetectorRef, Directive, Input } from '@angular/core';
|
|
2
|
+
import { FormGroupDirective } from '@angular/forms';
|
|
3
|
+
import { Actions, ofActionDispatched, Store } from '@ngxs/store';
|
|
4
|
+
import { getValue } from '@ngxs/store/plugins';
|
|
5
|
+
import { ReplaySubject } from 'rxjs';
|
|
6
|
+
import { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';
|
|
7
|
+
import { ResetForm, UpdateForm, UpdateFormDirty, UpdateFormErrors, UpdateFormStatus, UpdateFormValue } from './actions';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@ngxs/store";
|
|
10
|
+
import * as i2 from "@angular/forms";
|
|
11
|
+
export class NgxsFormDirective {
|
|
12
|
+
set debounce(debounce) {
|
|
13
|
+
this._debounce = Number(debounce);
|
|
14
|
+
}
|
|
15
|
+
get debounce() {
|
|
16
|
+
return this._debounce;
|
|
17
|
+
}
|
|
18
|
+
set clearDestroy(val) {
|
|
19
|
+
this._clearDestroy = val != null && `${val}` !== 'false';
|
|
20
|
+
}
|
|
21
|
+
get clearDestroy() {
|
|
22
|
+
return this._clearDestroy;
|
|
23
|
+
}
|
|
24
|
+
constructor(_actions$, _store, _formGroupDirective, _cd) {
|
|
25
|
+
this._actions$ = _actions$;
|
|
26
|
+
this._store = _store;
|
|
27
|
+
this._formGroupDirective = _formGroupDirective;
|
|
28
|
+
this._cd = _cd;
|
|
29
|
+
this.path = null;
|
|
30
|
+
this._debounce = 100;
|
|
31
|
+
this._clearDestroy = false;
|
|
32
|
+
this._updating = false;
|
|
33
|
+
this._destroy$ = new ReplaySubject(1);
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this._actions$
|
|
37
|
+
.pipe(ofActionDispatched(ResetForm), filter((action) => action.payload.path === this.path), takeUntil(this._destroy$))
|
|
38
|
+
.subscribe(({ payload: { value } }) => {
|
|
39
|
+
this.form.reset(value);
|
|
40
|
+
this.updateFormStateWithRawValue(true);
|
|
41
|
+
this._cd.markForCheck();
|
|
42
|
+
});
|
|
43
|
+
this.getStateStream(`${this.path}.model`).subscribe(model => {
|
|
44
|
+
if (this._updating || !model) {
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
this.form.patchValue(model);
|
|
48
|
+
this._cd.markForCheck();
|
|
49
|
+
});
|
|
50
|
+
this.getStateStream(`${this.path}.dirty`).subscribe(dirty => {
|
|
51
|
+
if (this.form.dirty === dirty || typeof dirty !== 'boolean') {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
if (dirty) {
|
|
55
|
+
this.form.markAsDirty();
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
this.form.markAsPristine();
|
|
59
|
+
}
|
|
60
|
+
this._cd.markForCheck();
|
|
61
|
+
});
|
|
62
|
+
// On first state change, sync form model, status and dirty with state
|
|
63
|
+
this._store
|
|
64
|
+
.selectOnce(state => getValue(state, this.path))
|
|
65
|
+
.subscribe(() => {
|
|
66
|
+
this._store.dispatch([
|
|
67
|
+
new UpdateFormValue({
|
|
68
|
+
path: this.path,
|
|
69
|
+
value: this.form.getRawValue()
|
|
70
|
+
}),
|
|
71
|
+
new UpdateFormStatus({
|
|
72
|
+
path: this.path,
|
|
73
|
+
status: this.form.status
|
|
74
|
+
}),
|
|
75
|
+
new UpdateFormDirty({
|
|
76
|
+
path: this.path,
|
|
77
|
+
dirty: this.form.dirty
|
|
78
|
+
})
|
|
79
|
+
]);
|
|
80
|
+
});
|
|
81
|
+
this.getStateStream(`${this.path}.disabled`).subscribe(disabled => {
|
|
82
|
+
if (this.form.disabled === disabled || typeof disabled !== 'boolean') {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (disabled) {
|
|
86
|
+
this.form.disable();
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
this.form.enable();
|
|
90
|
+
}
|
|
91
|
+
this._cd.markForCheck();
|
|
92
|
+
});
|
|
93
|
+
this._formGroupDirective
|
|
94
|
+
.valueChanges.pipe(distinctUntilChanged((a, b) => JSON.stringify(a) === JSON.stringify(b)), this.debounceChange())
|
|
95
|
+
.subscribe(() => {
|
|
96
|
+
this.updateFormStateWithRawValue();
|
|
97
|
+
});
|
|
98
|
+
this._formGroupDirective
|
|
99
|
+
.statusChanges.pipe(distinctUntilChanged(), this.debounceChange())
|
|
100
|
+
.subscribe((status) => {
|
|
101
|
+
this._store.dispatch(new UpdateFormStatus({
|
|
102
|
+
status,
|
|
103
|
+
path: this.path
|
|
104
|
+
}));
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
updateFormStateWithRawValue(withFormStatus) {
|
|
108
|
+
if (this._updating)
|
|
109
|
+
return;
|
|
110
|
+
const value = this._formGroupDirective.control.getRawValue();
|
|
111
|
+
const actions = [
|
|
112
|
+
new UpdateFormValue({
|
|
113
|
+
path: this.path,
|
|
114
|
+
value
|
|
115
|
+
}),
|
|
116
|
+
new UpdateFormDirty({
|
|
117
|
+
path: this.path,
|
|
118
|
+
dirty: this._formGroupDirective.dirty
|
|
119
|
+
}),
|
|
120
|
+
new UpdateFormErrors({
|
|
121
|
+
path: this.path,
|
|
122
|
+
errors: this._formGroupDirective.errors
|
|
123
|
+
})
|
|
124
|
+
];
|
|
125
|
+
if (withFormStatus) {
|
|
126
|
+
actions.push(new UpdateFormStatus({
|
|
127
|
+
path: this.path,
|
|
128
|
+
status: this._formGroupDirective.status
|
|
129
|
+
}));
|
|
130
|
+
}
|
|
131
|
+
this._updating = true;
|
|
132
|
+
this._store.dispatch(actions).subscribe({
|
|
133
|
+
error: () => (this._updating = false),
|
|
134
|
+
complete: () => (this._updating = false)
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
ngOnDestroy() {
|
|
138
|
+
this._destroy$.next();
|
|
139
|
+
if (this.clearDestroy) {
|
|
140
|
+
this._store.dispatch(new UpdateForm({
|
|
141
|
+
path: this.path,
|
|
142
|
+
value: null,
|
|
143
|
+
dirty: null,
|
|
144
|
+
status: null,
|
|
145
|
+
errors: null
|
|
146
|
+
}));
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
debounceChange() {
|
|
150
|
+
const skipDebounceTime = this._formGroupDirective.control.updateOn !== 'change' || this._debounce < 0;
|
|
151
|
+
return skipDebounceTime
|
|
152
|
+
? (change) => change.pipe(takeUntil(this._destroy$))
|
|
153
|
+
: (change) => change.pipe(debounceTime(this._debounce), takeUntil(this._destroy$));
|
|
154
|
+
}
|
|
155
|
+
get form() {
|
|
156
|
+
return this._formGroupDirective.form;
|
|
157
|
+
}
|
|
158
|
+
getStateStream(path) {
|
|
159
|
+
return this._store.select(state => getValue(state, path)).pipe(takeUntil(this._destroy$));
|
|
160
|
+
}
|
|
161
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormDirective, deps: [{ token: i1.Actions }, { token: i1.Store }, { token: i2.FormGroupDirective }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
162
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.3", type: NgxsFormDirective, isStandalone: true, selector: "[ngxsForm]", inputs: { path: ["ngxsForm", "path"], debounce: ["ngxsFormDebounce", "debounce"], clearDestroy: ["ngxsFormClearOnDestroy", "clearDestroy"] }, ngImport: i0 }); }
|
|
163
|
+
}
|
|
164
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormDirective, decorators: [{
|
|
165
|
+
type: Directive,
|
|
166
|
+
args: [{ selector: '[ngxsForm]', standalone: true }]
|
|
167
|
+
}], ctorParameters: () => [{ type: i1.Actions }, { type: i1.Store }, { type: i2.FormGroupDirective }, { type: i0.ChangeDetectorRef }], propDecorators: { path: [{
|
|
168
|
+
type: Input,
|
|
169
|
+
args: ['ngxsForm']
|
|
170
|
+
}], debounce: [{
|
|
171
|
+
type: Input,
|
|
172
|
+
args: ['ngxsFormDebounce']
|
|
173
|
+
}], clearDestroy: [{
|
|
174
|
+
type: Input,
|
|
175
|
+
args: ['ngxsFormClearOnDestroy']
|
|
176
|
+
}] } });
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvZm9ybS1wbHVnaW4vc3JjL2RpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDdkYsT0FBTyxFQUFhLGtCQUFrQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDL0QsT0FBTyxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxLQUFLLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDakUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQy9DLE9BQU8sRUFBYyxhQUFhLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakQsT0FBTyxFQUFFLFlBQVksRUFBRSxvQkFBb0IsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDdkYsT0FBTyxFQUNMLFNBQVMsRUFDVCxVQUFVLEVBQ1YsZUFBZSxFQUNmLGdCQUFnQixFQUNoQixnQkFBZ0IsRUFDaEIsZUFBZSxFQUNoQixNQUFNLFdBQVcsQ0FBQzs7OztBQUduQixNQUFNLE9BQU8saUJBQWlCO0lBSTVCLElBQ0ksUUFBUSxDQUFDLFFBQXlCO1FBQ3BDLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFDRCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztJQUdELElBQ0ksWUFBWSxDQUFDLEdBQVk7UUFDM0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxHQUFHLElBQUksSUFBSSxJQUFJLEdBQUcsR0FBRyxFQUFFLEtBQUssT0FBTyxDQUFDO0lBQzNELENBQUM7SUFDRCxJQUFJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDNUIs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TyxjQUFjLENBQUMsSUFBWTtRQUNqQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDNUYsQ0FBQztpSUFoTVUsaUJBQWlCO3FIQUFqQixpQkFBaUI7OzJGQUFqQixpQkFBaUI7a0JBRDdCLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUU7aUtBR3JELElBQUk7c0JBREgsS0FBSzt1QkFBQyxVQUFVO2dCQUliLFFBQVE7c0JBRFgsS0FBSzt1QkFBQyxrQkFBa0I7Z0JBVXJCLFlBQVk7c0JBRGYsS0FBSzt1QkFBQyx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgRGlyZWN0aXZlLCBJbnB1dCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1Hcm91cCwgRm9ybUdyb3VwRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQWN0aW9ucywgb2ZBY3Rpb25EaXNwYXRjaGVkLCBTdG9yZSB9IGZyb20gJ0BuZ3hzL3N0b3JlJztcbmltcG9ydCB7IGdldFZhbHVlIH0gZnJvbSAnQG5neHMvc3RvcmUvcGx1Z2lucyc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBSZXBsYXlTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBkZWJvdW5jZVRpbWUsIGRpc3RpbmN0VW50aWxDaGFuZ2VkLCBmaWx0ZXIsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7XG4gIFJlc2V0Rm9ybSxcbiAgVXBkYXRlRm9ybSxcbiAgVXBkYXRlRm9ybURpcnR5LFxuICBVcGRhdGVGb3JtRXJyb3JzLFxuICBVcGRhdGVGb3JtU3RhdHVzLFxuICBVcGRhdGVGb3JtVmFsdWVcbn0gZnJvbSAnLi9hY3Rpb25zJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnW25neHNGb3JtXScsIHN0YW5kYWxvbmU6IHRydWUgfSlcbmV4cG9ydCBjbGFzcyBOZ3hzRm9ybURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgQElucHV0KCduZ3hzRm9ybScpXG4gIHBhdGg6IHN0cmluZyA9IG51bGwhO1xuXG4gIEBJbnB1dCgnbmd4c0Zvcm1EZWJvdW5jZScpXG4gIHNldCBkZWJvdW5jZShkZWJvdW5jZTogc3RyaW5nIHwgbnVtYmVyKSB7XG4gICAgdGhpcy5fZGVib3VuY2UgPSBOdW1iZXIoZGVib3VuY2UpO1xuICB9XG4gIGdldCBkZWJvdW5jZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fZGVib3VuY2U7XG4gIH1cbiAgcHJpdmF0ZSBfZGVib3VuY2UgPSAxMDA7XG5cbiAgQElucHV0KCduZ3hzRm9ybUNsZWFyT25EZXN0cm95JylcbiAgc2V0IGNsZWFyRGVzdHJveSh2YWw6IGJvb2xlYW4pIHtcbiAgICB0aGlzLl9jbGVhckRlc3Ryb3kgPSB2YWwgIT0gbnVsbCAmJiBgJHt2YWx9YCAhPT0gJ2ZhbHNlJztcbiAgfVxuICBnZXQgY2xlYXJEZXN0cm95KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl9jbGVhckRlc3Ryb3k7XG4gIH1cbiAgcHJpdmF0ZSBfY2xlYXJEZXN0cm95ID0gZmFsc2U7XG5cbiAgcHJpdmF0ZSBfdXBkYXRpbmcgPSBmYWxzZTtcblxuICBwcml2YXRlIHJlYWRvbmx5IF9kZXN0cm95JCA9IG5ldyBSZXBsYXlTdWJqZWN0PHZvaWQ+KDEpO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgX2FjdGlvbnMkOiBBY3Rpb25zLFxuICAgIHByaXZhdGUgX3N0b3JlOiBTdG9yZSxcbiAgICBwcml2YXRlIF9mb3JtR3JvdXBEaXJlY3RpdmU6IEZvcm1Hcm91cERpcmVjdGl2ZSxcbiAgICBwcml2YXRlIF9jZDogQ2hhbmdlRGV0ZWN0b3JSZWZcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuX2FjdGlvbnMkXG4gICAgICAucGlwZShcbiAgICAgICAgb2ZBY3Rpb25EaXNwYXRjaGVkKFJlc2V0Rm9ybSksXG4gICAgICAgIGZpbHRlcigoYWN0aW9uOiBSZXNldEZvcm0pID0+IGFjdGlvbi5wYXlsb2FkLnBhdGggPT09IHRoaXMucGF0aCksXG4gICAgICAgIHRha2VVbnRpbCh0aGlzLl9kZXN0cm95JClcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKHsgcGF5bG9hZDogeyB2YWx1ZSB9IH06IFJlc2V0Rm9ybSkgPT4ge1xuICAgICAgICB0aGlzLmZvcm0ucmVzZXQodmFsdWUpO1xuICAgICAgICB0aGlzLnVwZGF0ZUZvcm1TdGF0ZVdpdGhSYXdWYWx1ZSh0cnVlKTtcbiAgICAgICAgdGhpcy5fY2QubWFya0ZvckNoZWNrKCk7XG4gICAgICB9KTtcblxuICAgIHRoaXMuZ2V0U3RhdGVTdHJlYW0oYCR7dGhpcy5wYXRofS5tb2RlbGApLnN1YnNjcmliZShtb2RlbCA9PiB7XG4gICAgICBpZiAodGhpcy5fdXBkYXRpbmcgfHwgIW1vZGVsKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgdGhpcy5mb3JtLnBhdGNoVmFsdWUobW9kZWwpO1xuICAgICAgdGhpcy5fY2QubWFya0ZvckNoZWNrKCk7XG4gICAgfSk7XG5cbiAgICB0aGlzLmdldFN0YXRlU3RyZWFtKGAke3RoaXMucGF0aH0uZGlydHlgKS5zdWJzY3JpYmUoZGlydHkgPT4ge1xuICAgICAgaWYgKHRoaXMuZm9ybS5kaXJ0eSA9PT0gZGlydHkgfHwgdHlwZW9mIGRpcnR5ICE9PSAnYm9vbGVhbicpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBpZiAoZGlydHkpIHtcbiAgICAgICAgdGhpcy5mb3JtLm1hcmtBc0RpcnR5KCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aGlzLmZvcm0ubWFya0FzUHJpc3RpbmUoKTtcbiAgICAgIH1cblxuICAgICAgdGhpcy5fY2QubWFya0ZvckNoZWNrKCk7XG4gICAgfSk7XG5cbiAgICAvLyBPbiBmaXJzdCBzdGF0ZSBjaGFuZ2UsIHN5bmMgZm9ybSBtb2RlbCwgc3RhdHVzIGFuZCBkaXJ0eSB3aXRoIHN0YXRlXG4gICAgdGhpcy5fc3RvcmVcbiAgICAgIC5zZWxlY3RPbmNlKHN0YXRlID0+IGdldFZhbHVlKHN0YXRlLCB0aGlzLnBhdGgpKVxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgIHRoaXMuX3N0b3JlLmRpc3BhdGNoKFtcbiAgICAgICAgICBuZXcgVXBkYXRlRm9ybVZhbHVlKHtcbiAgICAgICAgICAgIHBhdGg6IHRoaXMucGF0aCxcbiAgICAgICAgICAgIHZhbHVlOiB0aGlzLmZvcm0uZ2V0UmF3VmFsdWUoKVxuICAgICAgICAgIH0pLFxuICAgICAgICAgIG5ldyBVcGRhdGVGb3JtU3RhdHVzKHtcbiAgICAgICAgICAgIHBhdGg6IHRoaXMucGF0aCxcbiAgICAgICAgICAgIHN0YXR1czogdGhpcy5mb3JtLnN0YXR1c1xuICAgICAgICAgIH0pLFxuICAgICAgICAgIG5ldyBVcGRhdGVGb3JtRGlydHkoe1xuICAgICAgICAgICAgcGF0aDogdGhpcy5wYXRoLFxuICAgICAgICAgICAgZGlydHk6IHRoaXMuZm9ybS5kaXJ0eVxuICAgICAgICAgIH0pXG4gICAgICAgIF0pO1xuICAgICAgfSk7XG5cbiAgICB0aGlzLmdldFN0YXRlU3RyZWFtKGAke3RoaXMucGF0aH0uZGlzYWJsZWRgKS5zdWJzY3JpYmUoZGlzYWJsZWQgPT4ge1xuICAgICAgaWYgKHRoaXMuZm9ybS5kaXNhYmxlZCA9PT0gZGlzYWJsZWQgfHwgdHlwZW9mIGRpc2FibGVkICE9PSAnYm9vbGVhbicpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBpZiAoZGlzYWJsZWQpIHtcbiAgICAgICAgdGhpcy5mb3JtLmRpc2FibGUoKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRoaXMuZm9ybS5lbmFibGUoKTtcbiAgICAgIH1cblxuICAgICAgdGhpcy5fY2QubWFya0ZvckNoZWNrKCk7XG4gICAgfSk7XG5cbiAgICB0aGlzLl9mb3JtR3JvdXBEaXJlY3RpdmVcbiAgICAgIC52YWx1ZUNoYW5nZXMhLnBpcGUoXG4gICAgICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKChhLCBiKSA9PiBKU09OLnN0cmluZ2lmeShhKSA9PT0gSlNPTi5zdHJpbmdpZnkoYikpLFxuICAgICAgICB0aGlzLmRlYm91bmNlQ2hhbmdlKClcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLnVwZGF0ZUZvcm1TdGF0ZVdpdGhSYXdWYWx1ZSgpO1xuICAgICAgfSk7XG5cbiAgICB0aGlzLl9mb3JtR3JvdXBEaXJlY3RpdmVcbiAgICAgIC5zdGF0dXNDaGFuZ2VzIS5waXBlKGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksIHRoaXMuZGVib3VuY2VDaGFuZ2UoKSlcbiAgICAgIC5zdWJzY3JpYmUoKHN0YXR1czogc3RyaW5nKSA9PiB7XG4gICAgICAgIHRoaXMuX3N0b3JlLmRpc3BhdGNoKFxuICAgICAgICAgIG5ldyBVcGRhdGVGb3JtU3RhdHVzKHtcbiAgICAgICAgICAgIHN0YXR1cyxcbiAgICAgICAgICAgIHBhdGg6IHRoaXMucGF0aFxuICAgICAgICAgIH0pXG4gICAgICAgICk7XG4gICAgICB9KTtcbiAgfVxuXG4gIHVwZGF0ZUZvcm1TdGF0ZVdpdGhSYXdWYWx1ZSh3aXRoRm9ybVN0YXR1cz86IGJvb2xlYW4pIHtcbiAgICBpZiAodGhpcy5fdXBkYXRpbmcpIHJldHVybjtcblxuICAgIGNvbnN0IHZhbHVlID0gdGhpcy5fZm9ybUdyb3VwRGlyZWN0aXZlLmNvbnRyb2wuZ2V0UmF3VmFsdWUoKTtcblxuICAgIGNvbnN0IGFjdGlvbnM6IGFueVtdID0gW1xuICAgICAgbmV3IFVwZGF0ZUZvcm1WYWx1ZSh7XG4gICAgICAgIHBhdGg6IHRoaXMucGF0aCxcbiAgICAgICAgdmFsdWVcbiAgICAgIH0pLFxuICAgICAgbmV3IFVwZGF0ZUZvcm1EaXJ0eSh7XG4gICAgICAgIHBhdGg6IHRoaXMucGF0aCxcbiAgICAgICAgZGlydHk6IHRoaXMuX2Zvcm1Hcm91cERpcmVjdGl2ZS5kaXJ0eVxuICAgICAgfSksXG4gICAgICBuZXcgVXBkYXRlRm9ybUVycm9ycyh7XG4gICAgICAgIHBhdGg6IHRoaXMucGF0aCxcbiAgICAgICAgZXJyb3JzOiB0aGlzLl9mb3JtR3JvdXBEaXJlY3RpdmUuZXJyb3JzXG4gICAgICB9KVxuICAgIF07XG5cbiAgICBpZiAod2l0aEZvcm1TdGF0dXMpIHtcbiAgICAgIGFjdGlvbnMucHVzaChcbiAgICAgICAgbmV3IFVwZGF0ZUZvcm1TdGF0dXMoe1xuICAgICAgICAgIHBhdGg6IHRoaXMucGF0aCxcbiAgICAgICAgICBzdGF0dXM6IHRoaXMuX2Zvcm1Hcm91cERpcmVjdGl2ZS5zdGF0dXNcbiAgICAgICAgfSlcbiAgICAgICk7XG4gICAgfVxuXG4gICAgdGhpcy5fdXBkYXRpbmcgPSB0cnVlO1xuICAgIHRoaXMuX3N0b3JlLmRpc3BhdGNoKGFjdGlvbnMpLnN1YnNjcmliZSh7XG4gICAgICBlcnJvcjogKCkgPT4gKHRoaXMuX3VwZGF0aW5nID0gZmFsc2UpLFxuICAgICAgY29tcGxldGU6ICgpID0+ICh0aGlzLl91cGRhdGluZyA9IGZhbHNlKVxuICAgIH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5fZGVzdHJveSQubmV4dCgpO1xuXG4gICAgaWYgKHRoaXMuY2xlYXJEZXN0cm95KSB7XG4gICAgICB0aGlzLl9zdG9yZS5kaXNwYXRjaChcbiAgICAgICAgbmV3IFVwZGF0ZUZvcm0oe1xuICAgICAgICAgIHBhdGg6IHRoaXMucGF0aCxcbiAgICAgICAgICB2YWx1ZTogbnVsbCxcbiAgICAgICAgICBkaXJ0eTogbnVsbCxcbiAgICAgICAgICBzdGF0dXM6IG51bGwsXG4gICAgICAgICAgZXJyb3JzOiBudWxsXG4gICAgICAgIH0pXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgZGVib3VuY2VDaGFuZ2UoKSB7XG4gICAgY29uc3Qgc2tpcERlYm91bmNlVGltZSA9XG4gICAgICB0aGlzLl9mb3JtR3JvdXBEaXJlY3RpdmUuY29udHJvbC51cGRhdGVPbiAhPT0gJ2NoYW5nZScgfHwgdGhpcy5fZGVib3VuY2UgPCAwO1xuXG4gICAgcmV0dXJuIHNraXBEZWJvdW5jZVRpbWVcbiAgICAgID8gKGNoYW5nZTogT2JzZXJ2YWJsZTxhbnk+KSA9PiBjaGFuZ2UucGlwZSh0YWtlVW50aWwodGhpcy5fZGVzdHJveSQpKVxuICAgICAgOiAoY2hhbmdlOiBPYnNlcnZhYmxlPGFueT4pID0+XG4gICAgICAgICAgY2hhbmdlLnBpcGUoZGVib3VuY2VUaW1lKHRoaXMuX2RlYm91bmNlKSwgdGFrZVVudGlsKHRoaXMuX2Rlc3Ryb3kkKSk7XG4gIH1cblxuICBwcml2YXRlIGdldCBmb3JtKCk6IEZvcm1Hcm91cCB7XG4gICAgcmV0dXJuIHRoaXMuX2Zvcm1Hcm91cERpcmVjdGl2ZS5mb3JtO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXRTdGF0ZVN0cmVhbShwYXRoOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gdGhpcy5fc3RvcmUuc2VsZWN0KHN0YXRlID0+IGdldFZhbHVlKHN0YXRlLCBwYXRoKSkucGlwZSh0YWtlVW50aWwodGhpcy5fZGVzdHJveSQpKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { NgModule, makeEnvironmentProviders } from '@angular/core';
|
|
2
|
+
import { withNgxsPlugin } from '@ngxs/store';
|
|
3
|
+
import { NGXS_PLUGINS } from '@ngxs/store/plugins';
|
|
4
|
+
import { NgxsFormPlugin } from './form.plugin';
|
|
5
|
+
import { NgxsFormDirective } from './directive';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class NgxsFormPluginModule {
|
|
8
|
+
static forRoot() {
|
|
9
|
+
return {
|
|
10
|
+
ngModule: NgxsFormPluginModule,
|
|
11
|
+
providers: [
|
|
12
|
+
{
|
|
13
|
+
provide: NGXS_PLUGINS,
|
|
14
|
+
useClass: NgxsFormPlugin,
|
|
15
|
+
multi: true
|
|
16
|
+
}
|
|
17
|
+
]
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPluginModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
21
|
+
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPluginModule, imports: [NgxsFormDirective], exports: [NgxsFormDirective] }); }
|
|
22
|
+
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPluginModule }); }
|
|
23
|
+
}
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPluginModule, decorators: [{
|
|
25
|
+
type: NgModule,
|
|
26
|
+
args: [{
|
|
27
|
+
imports: [NgxsFormDirective],
|
|
28
|
+
exports: [NgxsFormDirective]
|
|
29
|
+
}]
|
|
30
|
+
}] });
|
|
31
|
+
export function withNgxsFormPlugin() {
|
|
32
|
+
return makeEnvironmentProviders([withNgxsPlugin(NgxsFormPlugin)]);
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9mb3JtLXBsdWdpbi9zcmMvZm9ybS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFFBQVEsRUFHUix3QkFBd0IsRUFDekIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFbkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxhQUFhLENBQUM7O0FBTWhELE1BQU0sT0FBTyxvQkFBb0I7SUFDL0IsTUFBTSxDQUFDLE9BQU87UUFDWixPQUFPO1lBQ0wsUUFBUSxFQUFFLG9CQUFvQjtZQUM5QixTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLFlBQVk7b0JBQ3JCLFFBQVEsRUFBRSxjQUFjO29CQUN4QixLQUFLLEVBQUUsSUFBSTtpQkFDWjthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7aUlBWlUsb0JBQW9CO2tJQUFwQixvQkFBb0IsWUFIckIsaUJBQWlCLGFBQ2pCLGlCQUFpQjtrSUFFaEIsb0JBQW9COzsyRkFBcEIsb0JBQW9CO2tCQUpoQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO29CQUM1QixPQUFPLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztpQkFDN0I7O0FBZ0JELE1BQU0sVUFBVSxrQkFBa0I7SUFDaEMsT0FBTyx3QkFBd0IsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDcEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIE5nTW9kdWxlLFxuICBNb2R1bGVXaXRoUHJvdmlkZXJzLFxuICBFbnZpcm9ubWVudFByb3ZpZGVycyxcbiAgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgd2l0aE5neHNQbHVnaW4gfSBmcm9tICdAbmd4cy9zdG9yZSc7XG5pbXBvcnQgeyBOR1hTX1BMVUdJTlMgfSBmcm9tICdAbmd4cy9zdG9yZS9wbHVnaW5zJztcblxuaW1wb3J0IHsgTmd4c0Zvcm1QbHVnaW4gfSBmcm9tICcuL2Zvcm0ucGx1Z2luJztcbmltcG9ydCB7IE5neHNGb3JtRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbTmd4c0Zvcm1EaXJlY3RpdmVdLFxuICBleHBvcnRzOiBbTmd4c0Zvcm1EaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIE5neHNGb3JtUGx1Z2luTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVyczxOZ3hzRm9ybVBsdWdpbk1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogTmd4c0Zvcm1QbHVnaW5Nb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgIHByb3ZpZGU6IE5HWFNfUExVR0lOUyxcbiAgICAgICAgICB1c2VDbGFzczogTmd4c0Zvcm1QbHVnaW4sXG4gICAgICAgICAgbXVsdGk6IHRydWVcbiAgICAgICAgfVxuICAgICAgXVxuICAgIH07XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHdpdGhOZ3hzRm9ybVBsdWdpbigpOiBFbnZpcm9ubWVudFByb3ZpZGVycyB7XG4gIHJldHVybiBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMoW3dpdGhOZ3hzUGx1Z2luKE5neHNGb3JtUGx1Z2luKV0pO1xufVxuIl19
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { getActionTypeFromInstance, getValue, setValue } from '@ngxs/store/plugins';
|
|
3
|
+
import { ResetForm, SetFormDirty, SetFormDisabled, SetFormEnabled, SetFormPristine, UpdateForm, UpdateFormDirty, UpdateFormErrors, UpdateFormStatus, UpdateFormValue } from './actions';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class NgxsFormPlugin {
|
|
6
|
+
handle(state, event, next) {
|
|
7
|
+
const type = getActionTypeFromInstance(event);
|
|
8
|
+
let nextState = state;
|
|
9
|
+
if (type === UpdateFormValue.type || type === UpdateForm.type || type === ResetForm.type) {
|
|
10
|
+
const { value } = event.payload;
|
|
11
|
+
const payloadValue = Array.isArray(value)
|
|
12
|
+
? value.slice()
|
|
13
|
+
: isObjectLike(value)
|
|
14
|
+
? { ...value }
|
|
15
|
+
: value;
|
|
16
|
+
const path = this.joinPathWithPropertyPath(event);
|
|
17
|
+
nextState = setValue(nextState, path, payloadValue);
|
|
18
|
+
}
|
|
19
|
+
if (type === ResetForm.type) {
|
|
20
|
+
const model = getValue(nextState, `${event.payload.path}.model`);
|
|
21
|
+
nextState = setValue(nextState, `${event.payload.path}`, { model: model });
|
|
22
|
+
}
|
|
23
|
+
if (type === UpdateFormStatus.type || type === UpdateForm.type) {
|
|
24
|
+
nextState = setValue(nextState, `${event.payload.path}.status`, event.payload.status);
|
|
25
|
+
}
|
|
26
|
+
if (type === UpdateFormErrors.type || type === UpdateForm.type) {
|
|
27
|
+
nextState = setValue(nextState, `${event.payload.path}.errors`, {
|
|
28
|
+
...event.payload.errors
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
if (type === UpdateFormDirty.type || type === UpdateForm.type) {
|
|
32
|
+
nextState = setValue(nextState, `${event.payload.path}.dirty`, event.payload.dirty);
|
|
33
|
+
}
|
|
34
|
+
if (type === SetFormDirty.type) {
|
|
35
|
+
nextState = setValue(nextState, `${event.payload}.dirty`, true);
|
|
36
|
+
}
|
|
37
|
+
if (type === SetFormPristine.type) {
|
|
38
|
+
nextState = setValue(nextState, `${event.payload}.dirty`, false);
|
|
39
|
+
}
|
|
40
|
+
if (type === SetFormDisabled.type) {
|
|
41
|
+
nextState = setValue(nextState, `${event.payload}.disabled`, true);
|
|
42
|
+
}
|
|
43
|
+
if (type === SetFormEnabled.type) {
|
|
44
|
+
nextState = setValue(nextState, `${event.payload}.disabled`, false);
|
|
45
|
+
}
|
|
46
|
+
return next(nextState, event);
|
|
47
|
+
}
|
|
48
|
+
joinPathWithPropertyPath({ payload }) {
|
|
49
|
+
let path = `${payload.path}.model`;
|
|
50
|
+
if (payload.propertyPath) {
|
|
51
|
+
path += `.${payload.propertyPath}`;
|
|
52
|
+
}
|
|
53
|
+
return path;
|
|
54
|
+
}
|
|
55
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPlugin, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
56
|
+
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPlugin }); }
|
|
57
|
+
}
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPlugin, decorators: [{
|
|
59
|
+
type: Injectable
|
|
60
|
+
}] });
|
|
61
|
+
function isObjectLike(target) {
|
|
62
|
+
return target !== null && typeof target === 'object';
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9mb3JtLXBsdWdpbi9zcmMvZm9ybS5wbHVnaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQ0wseUJBQXlCLEVBQ3pCLFFBQVEsRUFHUixRQUFRLEVBQ1QsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixlQUFlLEVBQ2YsY0FBYyxFQUNkLGVBQWUsRUFDZixVQUFVLEVBQ1YsZUFBZSxFQUNmLGdCQUFnQixFQUNoQixnQkFBZ0IsRUFDaEIsZUFBZSxFQUNoQixNQUFNLFdBQVcsQ0FBQzs7QUFHbkIsTUFBTSxPQUFPLGNBQWM7SUFDekIsTUFBTSxDQUFDLEtBQVUsRUFBRSxLQUFVLEVBQUUsSUFBc0I7UUFDbkQsTUFBTSxJQUFJLEdBQUcseUJBQXlCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFOUMsSUFBSSxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBRXRCLElBQUksSUFBSSxLQUFLLGVBQWUsQ0FBQyxJQUFJLElBQUksSUFBSSxLQUFLLFVBQVUsQ0FBQyxJQUFJLElBQUksSUFBSSxLQUFLLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUN6RixNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQztZQUNoQyxNQUFNLFlBQVksR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQztnQkFDdkMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUU7Z0JBQ2YsQ0FBQyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUM7b0JBQ25CLENBQUMsQ0FBQyxFQUFFLEdBQUcsS0FBSyxFQUFFO29CQUNkLENBQUMsQ0FBQyxLQUFLLENBQUM7WUFDWixNQUFNLElBQUksR0FBRyxJQUFJLENB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OzsyRkFBZCxjQUFjO2tCQUQxQixVQUFVOztBQW1FWCxTQUFTLFlBQVksQ0FBQyxNQUFlO0lBQ25DLE9BQU8sTUFBTSxLQUFLLElBQUksSUFBSSxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUM7QUFDdkQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIGdldEFjdGlvblR5cGVGcm9tSW5zdGFuY2UsXG4gIGdldFZhbHVlLFxuICBOZ3hzTmV4dFBsdWdpbkZuLFxuICBOZ3hzUGx1Z2luLFxuICBzZXRWYWx1ZVxufSBmcm9tICdAbmd4cy9zdG9yZS9wbHVnaW5zJztcbmltcG9ydCB7XG4gIFJlc2V0Rm9ybSxcbiAgU2V0Rm9ybURpcnR5LFxuICBTZXRGb3JtRGlzYWJsZWQsXG4gIFNldEZvcm1FbmFibGVkLFxuICBTZXRGb3JtUHJpc3RpbmUsXG4gIFVwZGF0ZUZvcm0sXG4gIFVwZGF0ZUZvcm1EaXJ0eSxcbiAgVXBkYXRlRm9ybUVycm9ycyxcbiAgVXBkYXRlRm9ybVN0YXR1cyxcbiAgVXBkYXRlRm9ybVZhbHVlXG59IGZyb20gJy4vYWN0aW9ucyc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBOZ3hzRm9ybVBsdWdpbiBpbXBsZW1lbnRzIE5neHNQbHVnaW4ge1xuICBoYW5kbGUoc3RhdGU6IGFueSwgZXZlbnQ6IGFueSwgbmV4dDogTmd4c05leHRQbHVnaW5Gbikge1xuICAgIGNvbnN0IHR5cGUgPSBnZXRBY3Rpb25UeXBlRnJvbUluc3RhbmNlKGV2ZW50KTtcblxuICAgIGxldCBuZXh0U3RhdGUgPSBzdGF0ZTtcblxuICAgIGlmICh0eXBlID09PSBVcGRhdGVGb3JtVmFsdWUudHlwZSB8fCB0eXBlID09PSBVcGRhdGVGb3JtLnR5cGUgfHwgdHlwZSA9PT0gUmVzZXRGb3JtLnR5cGUpIHtcbiAgICAgIGNvbnN0IHsgdmFsdWUgfSA9IGV2ZW50LnBheWxvYWQ7XG4gICAgICBjb25zdCBwYXlsb2FkVmFsdWUgPSBBcnJheS5pc0FycmF5KHZhbHVlKVxuICAgICAgICA/IHZhbHVlLnNsaWNlKClcbiAgICAgICAgOiBpc09iamVjdExpa2UodmFsdWUpXG4gICAgICAgICAgPyB7IC4uLnZhbHVlIH1cbiAgICAgICAgICA6IHZhbHVlO1xuICAgICAgY29uc3QgcGF0aCA9IHRoaXMuam9pblBhdGhXaXRoUHJvcGVydHlQYXRoKGV2ZW50KTtcbiAgICAgIG5leHRTdGF0ZSA9IHNldFZhbHVlKG5leHRTdGF0ZSwgcGF0aCwgcGF5bG9hZFZhbHVlKTtcbiAgICB9XG5cbiAgICBpZiAodHlwZSA9PT0gUmVzZXRGb3JtLnR5cGUpIHtcbiAgICAgIGNvbnN0IG1vZGVsID0gZ2V0VmFsdWUobmV4dFN0YXRlLCBgJHtldmVudC5wYXlsb2FkLnBhdGh9Lm1vZGVsYCk7XG4gICAgICBuZXh0U3RhdGUgPSBzZXRWYWx1ZShuZXh0U3RhdGUsIGAke2V2ZW50LnBheWxvYWQucGF0aH1gLCB7IG1vZGVsOiBtb2RlbCB9KTtcbiAgICB9XG5cbiAgICBpZiAodHlwZSA9PT0gVXBkYXRlRm9ybVN0YXR1cy50eXBlIHx8IHR5cGUgPT09IFVwZGF0ZUZvcm0udHlwZSkge1xuICAgICAgbmV4dFN0YXRlID0gc2V0VmFsdWUobmV4dFN0YXRlLCBgJHtldmVudC5wYXlsb2FkLnBhdGh9LnN0YXR1c2AsIGV2ZW50LnBheWxvYWQuc3RhdHVzKTtcbiAgICB9XG5cbiAgICBpZiAodHlwZSA9PT0gVXBkYXRlRm9ybUVycm9ycy50eXBlIHx8IHR5cGUgPT09IFVwZGF0ZUZvcm0udHlwZSkge1xuICAgICAgbmV4dFN0YXRlID0gc2V0VmFsdWUobmV4dFN0YXRlLCBgJHtldmVudC5wYXlsb2FkLnBhdGh9LmVycm9yc2AsIHtcbiAgICAgICAgLi4uZXZlbnQucGF5bG9hZC5lcnJvcnNcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIGlmICh0eXBlID09PSBVcGRhdGVGb3JtRGlydHkudHlwZSB8fCB0eXBlID09PSBVcGRhdGVGb3JtLnR5cGUpIHtcbiAgICAgIG5leHRTdGF0ZSA9IHNldFZhbHVlKG5leHRTdGF0ZSwgYCR7ZXZlbnQucGF5bG9hZC5wYXRofS5kaXJ0eWAsIGV2ZW50LnBheWxvYWQuZGlydHkpO1xuICAgIH1cblxuICAgIGlmICh0eXBlID09PSBTZXRGb3JtRGlydHkudHlwZSkge1xuICAgICAgbmV4dFN0YXRlID0gc2V0VmFsdWUobmV4dFN0YXRlLCBgJHtldmVudC5wYXlsb2FkfS5kaXJ0eWAsIHRydWUpO1xuICAgIH1cblxuICAgIGlmICh0eXBlID09PSBTZXRGb3JtUHJpc3RpbmUudHlwZSkge1xuICAgICAgbmV4dFN0YXRlID0gc2V0VmFsdWUobmV4dFN0YXRlLCBgJHtldmVudC5wYXlsb2FkfS5kaXJ0eWAsIGZhbHNlKTtcbiAgICB9XG5cbiAgICBpZiAodHlwZSA9PT0gU2V0Rm9ybURpc2FibGVkLnR5cGUpIHtcbiAgICAgIG5leHRTdGF0ZSA9IHNldFZhbHVlKG5leHRTdGF0ZSwgYCR7ZXZlbnQucGF5bG9hZH0uZGlzYWJsZWRgLCB0cnVlKTtcbiAgICB9XG5cbiAgICBpZiAodHlwZSA9PT0gU2V0Rm9ybUVuYWJsZWQudHlwZSkge1xuICAgICAgbmV4dFN0YXRlID0gc2V0VmFsdWUobmV4dFN0YXRlLCBgJHtldmVudC5wYXlsb2FkfS5kaXNhYmxlZGAsIGZhbHNlKTtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV4dChuZXh0U3RhdGUsIGV2ZW50KTtcbiAgfVxuXG4gIHByaXZhdGUgam9pblBhdGhXaXRoUHJvcGVydHlQYXRoKHsgcGF5bG9hZCB9OiBVcGRhdGVGb3JtVmFsdWUpOiBzdHJpbmcge1xuICAgIGxldCBwYXRoID0gYCR7cGF5bG9hZC5wYXRofS5tb2RlbGA7XG5cbiAgICBpZiAocGF5bG9hZC5wcm9wZXJ0eVBhdGgpIHtcbiAgICAgIHBhdGggKz0gYC4ke3BheWxvYWQucHJvcGVydHlQYXRofWA7XG4gICAgfVxuXG4gICAgcmV0dXJuIHBhdGg7XG4gIH1cbn1cblxuZnVuY3Rpb24gaXNPYmplY3RMaWtlKHRhcmdldDogdW5rbm93bik6IHRhcmdldCBpcyBvYmplY3Qge1xuICByZXR1cm4gdGFyZ2V0ICE9PSBudWxsICYmIHR5cGVvZiB0YXJnZXQgPT09ICdvYmplY3QnO1xufVxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { NgxsFormPluginModule, withNgxsFormPlugin } from './form.module';
|
|
2
|
+
export { NgxsFormPlugin } from './form.plugin';
|
|
3
|
+
export { NgxsFormDirective } from './directive';
|
|
4
|
+
export * from './actions';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2Zvcm0tcGx1Z2luL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUNoRCxjQUFjLFdBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IE5neHNGb3JtUGx1Z2luTW9kdWxlLCB3aXRoTmd4c0Zvcm1QbHVnaW4gfSBmcm9tICcuL2Zvcm0ubW9kdWxlJztcbmV4cG9ydCB7IE5neHNGb3JtUGx1Z2luIH0gZnJvbSAnLi9mb3JtLnBsdWdpbic7XG5leHBvcnQgeyBOZ3hzRm9ybURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vYWN0aW9ucyc7XG4iXX0=
|
|
@@ -1,72 +1,72 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Injectable, Directive, Input, NgModule } from '@angular/core';
|
|
2
|
+
import { Injectable, Directive, Input, NgModule, makeEnvironmentProviders } from '@angular/core';
|
|
3
3
|
import * as i1 from '@ngxs/store';
|
|
4
|
-
import {
|
|
4
|
+
import { ofActionDispatched, withNgxsPlugin } from '@ngxs/store';
|
|
5
|
+
import { getActionTypeFromInstance, setValue, getValue, NGXS_PLUGINS } from '@ngxs/store/plugins';
|
|
5
6
|
import * as i2 from '@angular/forms';
|
|
6
|
-
import {
|
|
7
|
-
import { Subject } from 'rxjs';
|
|
7
|
+
import { ReplaySubject } from 'rxjs';
|
|
8
8
|
import { filter, takeUntil, distinctUntilChanged, debounceTime } from 'rxjs/operators';
|
|
9
9
|
|
|
10
10
|
class UpdateFormStatus {
|
|
11
|
+
static { this.type = '[Forms] Update Form Status'; }
|
|
11
12
|
constructor(payload) {
|
|
12
13
|
this.payload = payload;
|
|
13
14
|
}
|
|
14
15
|
}
|
|
15
|
-
UpdateFormStatus.type = '[Forms] Update Form Status';
|
|
16
16
|
class UpdateFormValue {
|
|
17
|
+
static { this.type = '[Forms] Update Form Value'; }
|
|
17
18
|
constructor(payload) {
|
|
18
19
|
this.payload = payload;
|
|
19
20
|
}
|
|
20
21
|
}
|
|
21
|
-
UpdateFormValue.type = '[Forms] Update Form Value';
|
|
22
22
|
class UpdateForm {
|
|
23
|
+
static { this.type = '[Forms] Update Form'; }
|
|
23
24
|
constructor(payload) {
|
|
24
25
|
this.payload = payload;
|
|
25
26
|
}
|
|
26
27
|
}
|
|
27
|
-
UpdateForm.type = '[Forms] Update Form';
|
|
28
28
|
class UpdateFormDirty {
|
|
29
|
+
static { this.type = '[Forms] Update Form Dirty'; }
|
|
29
30
|
constructor(payload) {
|
|
30
31
|
this.payload = payload;
|
|
31
32
|
}
|
|
32
33
|
}
|
|
33
|
-
UpdateFormDirty.type = '[Forms] Update Form Dirty';
|
|
34
34
|
class SetFormDirty {
|
|
35
|
+
static { this.type = '[Forms] Set Form Dirty'; }
|
|
35
36
|
constructor(payload) {
|
|
36
37
|
this.payload = payload;
|
|
37
38
|
}
|
|
38
39
|
}
|
|
39
|
-
SetFormDirty.type = '[Forms] Set Form Dirty';
|
|
40
40
|
class SetFormPristine {
|
|
41
|
+
static { this.type = '[Forms] Set Form Pristine'; }
|
|
41
42
|
constructor(payload) {
|
|
42
43
|
this.payload = payload;
|
|
43
44
|
}
|
|
44
45
|
}
|
|
45
|
-
SetFormPristine.type = '[Forms] Set Form Pristine';
|
|
46
46
|
class UpdateFormErrors {
|
|
47
|
+
static { this.type = '[Forms] Update Form Errors'; }
|
|
47
48
|
constructor(payload) {
|
|
48
49
|
this.payload = payload;
|
|
49
50
|
}
|
|
50
51
|
}
|
|
51
|
-
UpdateFormErrors.type = '[Forms] Update Form Errors';
|
|
52
52
|
class SetFormDisabled {
|
|
53
|
+
static { this.type = '[Forms] Set Form Disabled'; }
|
|
53
54
|
constructor(payload) {
|
|
54
55
|
this.payload = payload;
|
|
55
56
|
}
|
|
56
57
|
}
|
|
57
|
-
SetFormDisabled.type = '[Forms] Set Form Disabled';
|
|
58
58
|
class SetFormEnabled {
|
|
59
|
+
static { this.type = '[Forms] Set Form Enabled'; }
|
|
59
60
|
constructor(payload) {
|
|
60
61
|
this.payload = payload;
|
|
61
62
|
}
|
|
62
63
|
}
|
|
63
|
-
SetFormEnabled.type = '[Forms] Set Form Enabled';
|
|
64
64
|
class ResetForm {
|
|
65
|
+
static { this.type = '[Forms] Reset Form'; }
|
|
65
66
|
constructor(payload) {
|
|
66
67
|
this.payload = payload;
|
|
67
68
|
}
|
|
68
69
|
}
|
|
69
|
-
ResetForm.type = '[Forms] Reset Form';
|
|
70
70
|
|
|
71
71
|
class NgxsFormPlugin {
|
|
72
72
|
handle(state, event, next) {
|
|
@@ -77,7 +77,8 @@ class NgxsFormPlugin {
|
|
|
77
77
|
const payloadValue = Array.isArray(value)
|
|
78
78
|
? value.slice()
|
|
79
79
|
: isObjectLike(value)
|
|
80
|
-
?
|
|
80
|
+
? { ...value }
|
|
81
|
+
: value;
|
|
81
82
|
const path = this.joinPathWithPropertyPath(event);
|
|
82
83
|
nextState = setValue(nextState, path, payloadValue);
|
|
83
84
|
}
|
|
@@ -89,7 +90,9 @@ class NgxsFormPlugin {
|
|
|
89
90
|
nextState = setValue(nextState, `${event.payload.path}.status`, event.payload.status);
|
|
90
91
|
}
|
|
91
92
|
if (type === UpdateFormErrors.type || type === UpdateForm.type) {
|
|
92
|
-
nextState = setValue(nextState, `${event.payload.path}.errors`,
|
|
93
|
+
nextState = setValue(nextState, `${event.payload.path}.errors`, {
|
|
94
|
+
...event.payload.errors
|
|
95
|
+
});
|
|
93
96
|
}
|
|
94
97
|
if (type === UpdateFormDirty.type || type === UpdateForm.type) {
|
|
95
98
|
nextState = setValue(nextState, `${event.payload.path}.dirty`, event.payload.dirty);
|
|
@@ -115,28 +118,17 @@ class NgxsFormPlugin {
|
|
|
115
118
|
}
|
|
116
119
|
return path;
|
|
117
120
|
}
|
|
121
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPlugin, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
122
|
+
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPlugin }); }
|
|
118
123
|
}
|
|
119
|
-
|
|
120
|
-
/** @nocollapse */ NgxsFormPlugin.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NgxsFormPlugin });
|
|
121
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NgxsFormPlugin, decorators: [{
|
|
124
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPlugin, decorators: [{
|
|
122
125
|
type: Injectable
|
|
123
126
|
}] });
|
|
124
127
|
function isObjectLike(target) {
|
|
125
128
|
return target !== null && typeof target === 'object';
|
|
126
129
|
}
|
|
127
130
|
|
|
128
|
-
class
|
|
129
|
-
constructor(_actions$, _store, _formGroupDirective, _cd) {
|
|
130
|
-
this._actions$ = _actions$;
|
|
131
|
-
this._store = _store;
|
|
132
|
-
this._formGroupDirective = _formGroupDirective;
|
|
133
|
-
this._cd = _cd;
|
|
134
|
-
this.path = null;
|
|
135
|
-
this._debounce = 100;
|
|
136
|
-
this._clearDestroy = false;
|
|
137
|
-
this._updating = false;
|
|
138
|
-
this._destroy$ = new Subject();
|
|
139
|
-
}
|
|
131
|
+
class NgxsFormDirective {
|
|
140
132
|
set debounce(debounce) {
|
|
141
133
|
this._debounce = Number(debounce);
|
|
142
134
|
}
|
|
@@ -149,6 +141,17 @@ class FormDirective {
|
|
|
149
141
|
get clearDestroy() {
|
|
150
142
|
return this._clearDestroy;
|
|
151
143
|
}
|
|
144
|
+
constructor(_actions$, _store, _formGroupDirective, _cd) {
|
|
145
|
+
this._actions$ = _actions$;
|
|
146
|
+
this._store = _store;
|
|
147
|
+
this._formGroupDirective = _formGroupDirective;
|
|
148
|
+
this._cd = _cd;
|
|
149
|
+
this.path = null;
|
|
150
|
+
this._debounce = 100;
|
|
151
|
+
this._clearDestroy = false;
|
|
152
|
+
this._updating = false;
|
|
153
|
+
this._destroy$ = new ReplaySubject(1);
|
|
154
|
+
}
|
|
152
155
|
ngOnInit() {
|
|
153
156
|
this._actions$
|
|
154
157
|
.pipe(ofActionDispatched(ResetForm), filter((action) => action.payload.path === this.path), takeUntil(this._destroy$))
|
|
@@ -275,13 +278,13 @@ class FormDirective {
|
|
|
275
278
|
getStateStream(path) {
|
|
276
279
|
return this._store.select(state => getValue(state, path)).pipe(takeUntil(this._destroy$));
|
|
277
280
|
}
|
|
281
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormDirective, deps: [{ token: i1.Actions }, { token: i1.Store }, { token: i2.FormGroupDirective }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
282
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.3", type: NgxsFormDirective, isStandalone: true, selector: "[ngxsForm]", inputs: { path: ["ngxsForm", "path"], debounce: ["ngxsFormDebounce", "debounce"], clearDestroy: ["ngxsFormClearOnDestroy", "clearDestroy"] }, ngImport: i0 }); }
|
|
278
283
|
}
|
|
279
|
-
|
|
280
|
-
/** @nocollapse */ FormDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: FormDirective, selector: "[ngxsForm]", inputs: { path: ["ngxsForm", "path"], debounce: ["ngxsFormDebounce", "debounce"], clearDestroy: ["ngxsFormClearOnDestroy", "clearDestroy"] }, ngImport: i0 });
|
|
281
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FormDirective, decorators: [{
|
|
284
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormDirective, decorators: [{
|
|
282
285
|
type: Directive,
|
|
283
|
-
args: [{ selector: '[ngxsForm]' }]
|
|
284
|
-
}], ctorParameters:
|
|
286
|
+
args: [{ selector: '[ngxsForm]', standalone: true }]
|
|
287
|
+
}], ctorParameters: () => [{ type: i1.Actions }, { type: i1.Store }, { type: i2.FormGroupDirective }, { type: i0.ChangeDetectorRef }], propDecorators: { path: [{
|
|
285
288
|
type: Input,
|
|
286
289
|
args: ['ngxsForm']
|
|
287
290
|
}], debounce: [{
|
|
@@ -305,18 +308,20 @@ class NgxsFormPluginModule {
|
|
|
305
308
|
]
|
|
306
309
|
};
|
|
307
310
|
}
|
|
311
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPluginModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
312
|
+
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPluginModule, imports: [NgxsFormDirective], exports: [NgxsFormDirective] }); }
|
|
313
|
+
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPluginModule }); }
|
|
308
314
|
}
|
|
309
|
-
|
|
310
|
-
/** @nocollapse */ NgxsFormPluginModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NgxsFormPluginModule, declarations: [FormDirective], imports: [ReactiveFormsModule], exports: [FormDirective] });
|
|
311
|
-
/** @nocollapse */ NgxsFormPluginModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NgxsFormPluginModule, imports: [[ReactiveFormsModule]] });
|
|
312
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NgxsFormPluginModule, decorators: [{
|
|
315
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: NgxsFormPluginModule, decorators: [{
|
|
313
316
|
type: NgModule,
|
|
314
317
|
args: [{
|
|
315
|
-
imports: [
|
|
316
|
-
|
|
317
|
-
exports: [FormDirective]
|
|
318
|
+
imports: [NgxsFormDirective],
|
|
319
|
+
exports: [NgxsFormDirective]
|
|
318
320
|
}]
|
|
319
321
|
}] });
|
|
322
|
+
function withNgxsFormPlugin() {
|
|
323
|
+
return makeEnvironmentProviders([withNgxsPlugin(NgxsFormPlugin)]);
|
|
324
|
+
}
|
|
320
325
|
|
|
321
326
|
/**
|
|
322
327
|
* The public api for consumers of @ngxs/form-plugin
|
|
@@ -326,5 +331,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
326
331
|
* Generated bundle index. Do not edit.
|
|
327
332
|
*/
|
|
328
333
|
|
|
329
|
-
export { NgxsFormPlugin, NgxsFormPluginModule, ResetForm, SetFormDirty, SetFormDisabled, SetFormEnabled, SetFormPristine, UpdateForm, UpdateFormDirty, UpdateFormErrors, UpdateFormStatus, UpdateFormValue,
|
|
330
|
-
//# sourceMappingURL=ngxs-form-plugin.
|
|
334
|
+
export { NgxsFormDirective, NgxsFormPlugin, NgxsFormPluginModule, ResetForm, SetFormDirty, SetFormDisabled, SetFormEnabled, SetFormPristine, UpdateForm, UpdateFormDirty, UpdateFormErrors, UpdateFormStatus, UpdateFormValue, withNgxsFormPlugin };
|
|
335
|
+
//# sourceMappingURL=ngxs-form-plugin.mjs.map
|