@ngxs/form-plugin 3.7.3-dev.master-10b0883 → 3.7.4

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.
@@ -1,328 +1,328 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
5
- import { ChangeDetectorRef, Directive, Input } from '@angular/core';
6
- import { FormGroupDirective } from '@angular/forms';
7
- import { Actions, getValue, ofActionDispatched, Store } from '@ngxs/store';
8
- import { Subject } from 'rxjs';
9
- import { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';
10
- import { ResetForm, UpdateForm, UpdateFormDirty, UpdateFormErrors, UpdateFormStatus, UpdateFormValue } from './actions';
11
- var FormDirective = /** @class */ (function () {
12
- function FormDirective(_actions$, _store, _formGroupDirective, _cd) {
13
- this._actions$ = _actions$;
14
- this._store = _store;
15
- this._formGroupDirective = _formGroupDirective;
16
- this._cd = _cd;
17
- this.path = (/** @type {?} */ (null));
18
- this.debounce = 100;
19
- this._clearDestroy = false;
20
- this._destroy$ = new Subject();
21
- this._updating = false;
22
- }
23
- Object.defineProperty(FormDirective.prototype, "clearDestroy", {
24
- get: /**
25
- * @return {?}
26
- */
27
- function () {
28
- return this._clearDestroy;
29
- },
30
- set: /**
31
- * @param {?} val
32
- * @return {?}
33
- */
34
- function (val) {
35
- this._clearDestroy = val != null && "" + val !== 'false';
36
- },
37
- enumerable: true,
38
- configurable: true
39
- });
40
- /**
41
- * @return {?}
42
- */
43
- FormDirective.prototype.ngOnInit = /**
44
- * @return {?}
45
- */
46
- function () {
47
- var _this = this;
48
- this._actions$
49
- .pipe(ofActionDispatched(ResetForm), filter((/**
50
- * @param {?} action
51
- * @return {?}
52
- */
53
- function (action) { return action.payload.path === _this.path; })), takeUntil(this._destroy$))
54
- .subscribe((/**
55
- * @param {?} __0
56
- * @return {?}
57
- */
58
- function (_a) {
59
- var value = _a.payload.value;
60
- _this.form.reset(value);
61
- _this.updateFormStateWithRawValue(true);
62
- _this._cd.markForCheck();
63
- }));
64
- this.getStateStream(this.path + ".model").subscribe((/**
65
- * @param {?} model
66
- * @return {?}
67
- */
68
- function (model) {
69
- if (_this._updating || !model) {
70
- return;
71
- }
72
- _this.form.patchValue(model);
73
- _this._cd.markForCheck();
74
- }));
75
- this.getStateStream(this.path + ".dirty").subscribe((/**
76
- * @param {?} dirty
77
- * @return {?}
78
- */
79
- function (dirty) {
80
- if (_this.form.dirty === dirty || typeof dirty !== 'boolean') {
81
- return;
82
- }
83
- if (dirty) {
84
- _this.form.markAsDirty();
85
- }
86
- else {
87
- _this.form.markAsPristine();
88
- }
89
- _this._cd.markForCheck();
90
- }));
91
- // On first state change, sync form model, status and dirty with state
92
- this._store
93
- .selectOnce((/**
94
- * @param {?} state
95
- * @return {?}
96
- */
97
- function (state) { return getValue(state, _this.path); }))
98
- .subscribe((/**
99
- * @return {?}
100
- */
101
- function () {
102
- _this._store.dispatch([
103
- new UpdateFormValue({
104
- path: _this.path,
105
- value: _this.form.getRawValue()
106
- }),
107
- new UpdateFormStatus({
108
- path: _this.path,
109
- status: _this.form.status
110
- }),
111
- new UpdateFormDirty({
112
- path: _this.path,
113
- dirty: _this.form.dirty
114
- })
115
- ]);
116
- }));
117
- this.getStateStream(this.path + ".disabled").subscribe((/**
118
- * @param {?} disabled
119
- * @return {?}
120
- */
121
- function (disabled) {
122
- if (_this.form.disabled === disabled || typeof disabled !== 'boolean') {
123
- return;
124
- }
125
- if (disabled) {
126
- _this.form.disable();
127
- }
128
- else {
129
- _this.form.enable();
130
- }
131
- _this._cd.markForCheck();
132
- }));
133
- (/** @type {?} */ (this._formGroupDirective.valueChanges)).pipe(this.debounceChange()).subscribe((/**
134
- * @return {?}
135
- */
136
- function () {
137
- _this.updateFormStateWithRawValue();
138
- }));
139
- (/** @type {?} */ (this._formGroupDirective
140
- .statusChanges)).pipe(distinctUntilChanged(), this.debounceChange())
141
- .subscribe((/**
142
- * @param {?} status
143
- * @return {?}
144
- */
145
- function (status) {
146
- _this._store.dispatch(new UpdateFormStatus({
147
- status: status,
148
- path: _this.path
149
- }));
150
- }));
151
- };
152
- /**
153
- * @param {?=} withFormStatus
154
- * @return {?}
155
- */
156
- FormDirective.prototype.updateFormStateWithRawValue = /**
157
- * @param {?=} withFormStatus
158
- * @return {?}
159
- */
160
- function (withFormStatus) {
161
- var _this = this;
162
- if (this._updating)
163
- return;
164
- /** @type {?} */
165
- var value = this._formGroupDirective.control.getRawValue();
166
- /** @type {?} */
167
- var actions = [
168
- new UpdateFormValue({
169
- path: this.path,
170
- value: value
171
- }),
172
- new UpdateFormDirty({
173
- path: this.path,
174
- dirty: this._formGroupDirective.dirty
175
- }),
176
- new UpdateFormErrors({
177
- path: this.path,
178
- errors: this._formGroupDirective.errors
179
- })
180
- ];
181
- if (withFormStatus) {
182
- actions.push(new UpdateFormStatus({
183
- path: this.path,
184
- status: this._formGroupDirective.status
185
- }));
186
- }
187
- this._updating = true;
188
- this._store.dispatch(actions).subscribe({
189
- error: (/**
190
- * @return {?}
191
- */
192
- function () { return (_this._updating = false); }),
193
- complete: (/**
194
- * @return {?}
195
- */
196
- function () { return (_this._updating = false); })
197
- });
198
- };
199
- /**
200
- * @return {?}
201
- */
202
- FormDirective.prototype.ngOnDestroy = /**
203
- * @return {?}
204
- */
205
- function () {
206
- this._destroy$.next();
207
- this._destroy$.complete();
208
- if (this.clearDestroy) {
209
- this._store.dispatch(new UpdateForm({
210
- path: this.path,
211
- value: null,
212
- dirty: null,
213
- status: null,
214
- errors: null
215
- }));
216
- }
217
- };
218
- /**
219
- * @private
220
- * @return {?}
221
- */
222
- FormDirective.prototype.debounceChange = /**
223
- * @private
224
- * @return {?}
225
- */
226
- function () {
227
- var _this = this;
228
- /** @type {?} */
229
- var skipDebounceTime = this._formGroupDirective.control.updateOn !== 'change' || this.debounce < 0;
230
- return skipDebounceTime
231
- ? (/**
232
- * @param {?} change
233
- * @return {?}
234
- */
235
- function (change) { return change.pipe(takeUntil(_this._destroy$)); })
236
- : (/**
237
- * @param {?} change
238
- * @return {?}
239
- */
240
- function (change) {
241
- return change.pipe(debounceTime(_this.debounce), takeUntil(_this._destroy$));
242
- });
243
- };
244
- Object.defineProperty(FormDirective.prototype, "form", {
245
- get: /**
246
- * @private
247
- * @return {?}
248
- */
249
- function () {
250
- return this._formGroupDirective.form;
251
- },
252
- enumerable: true,
253
- configurable: true
254
- });
255
- /**
256
- * @private
257
- * @param {?} path
258
- * @return {?}
259
- */
260
- FormDirective.prototype.getStateStream = /**
261
- * @private
262
- * @param {?} path
263
- * @return {?}
264
- */
265
- function (path) {
266
- return this._store.select((/**
267
- * @param {?} state
268
- * @return {?}
269
- */
270
- function (state) { return getValue(state, path); })).pipe(takeUntil(this._destroy$));
271
- };
272
- FormDirective.decorators = [
273
- { type: Directive, args: [{ selector: '[ngxsForm]' },] }
274
- ];
275
- /** @nocollapse */
276
- FormDirective.ctorParameters = function () { return [
277
- { type: Actions },
278
- { type: Store },
279
- { type: FormGroupDirective },
280
- { type: ChangeDetectorRef }
281
- ]; };
282
- FormDirective.propDecorators = {
283
- path: [{ type: Input, args: ['ngxsForm',] }],
284
- debounce: [{ type: Input, args: ['ngxsFormDebounce',] }],
285
- clearDestroy: [{ type: Input, args: ['ngxsFormClearOnDestroy',] }]
286
- };
287
- return FormDirective;
288
- }());
289
- export { FormDirective };
290
- if (false) {
291
- /** @type {?} */
292
- FormDirective.prototype.path;
293
- /** @type {?} */
294
- FormDirective.prototype.debounce;
295
- /** @type {?} */
296
- FormDirective.prototype._clearDestroy;
297
- /**
298
- * @type {?}
299
- * @private
300
- */
301
- FormDirective.prototype._destroy$;
302
- /**
303
- * @type {?}
304
- * @private
305
- */
306
- FormDirective.prototype._updating;
307
- /**
308
- * @type {?}
309
- * @private
310
- */
311
- FormDirective.prototype._actions$;
312
- /**
313
- * @type {?}
314
- * @private
315
- */
316
- FormDirective.prototype._store;
317
- /**
318
- * @type {?}
319
- * @private
320
- */
321
- FormDirective.prototype._formGroupDirective;
322
- /**
323
- * @type {?}
324
- * @private
325
- */
326
- FormDirective.prototype._cd;
327
- }
328
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"directive.js","sourceRoot":"ng://@ngxs/form-plugin/","sources":["src/directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, Input, OnDestroy, OnInit } from '@angular/core';\nimport { FormGroup, FormGroupDirective } from '@angular/forms';\nimport { Actions, getValue, ofActionDispatched, Store } from '@ngxs/store';\nimport { Observable, Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';\nimport {\n  ResetForm,\n  UpdateForm,\n  UpdateFormDirty,\n  UpdateFormErrors,\n  UpdateFormStatus,\n  UpdateFormValue\n} from './actions';\n\n@Directive({ selector: '[ngxsForm]' })\nexport class FormDirective implements OnInit, OnDestroy {\n  @Input('ngxsForm')\n  path: string = null!;\n\n  @Input('ngxsFormDebounce')\n  debounce = 100;\n\n  @Input('ngxsFormClearOnDestroy')\n  set clearDestroy(val: boolean) {\n    this._clearDestroy = val != null && `${val}` !== 'false';\n  }\n\n  get clearDestroy(): boolean {\n    return this._clearDestroy;\n  }\n\n  _clearDestroy = false;\n\n  private readonly _destroy$ = new Subject<void>();\n  private _updating = false;\n\n  constructor(\n    private _actions$: Actions,\n    private _store: Store,\n    private _formGroupDirective: FormGroupDirective,\n    private _cd: ChangeDetectorRef\n  ) {}\n\n  ngOnInit() {\n    this._actions$\n      .pipe(\n        ofActionDispatched(ResetForm),\n        filter((action: ResetForm) => action.payload.path === this.path),\n        takeUntil(this._destroy$)\n      )\n      .subscribe(({ payload: { value } }: ResetForm) => {\n        this.form.reset(value);\n        this.updateFormStateWithRawValue(true);\n        this._cd.markForCheck();\n      });\n\n    this.getStateStream(`${this.path}.model`).subscribe(model => {\n      if (this._updating || !model) {\n        return;\n      }\n\n      this.form.patchValue(model);\n      this._cd.markForCheck();\n    });\n\n    this.getStateStream(`${this.path}.dirty`).subscribe(dirty => {\n      if (this.form.dirty === dirty || typeof dirty !== 'boolean') {\n        return;\n      }\n\n      if (dirty) {\n        this.form.markAsDirty();\n      } else {\n        this.form.markAsPristine();\n      }\n\n      this._cd.markForCheck();\n    });\n\n    // On first state change, sync form model, status and dirty with state\n    this._store\n      .selectOnce(state => getValue(state, this.path))\n      .subscribe(() => {\n        this._store.dispatch([\n          new UpdateFormValue({\n            path: this.path,\n            value: this.form.getRawValue()\n          }),\n          new UpdateFormStatus({\n            path: this.path,\n            status: this.form.status\n          }),\n          new UpdateFormDirty({\n            path: this.path,\n            dirty: this.form.dirty\n          })\n        ]);\n      });\n\n    this.getStateStream(`${this.path}.disabled`).subscribe(disabled => {\n      if (this.form.disabled === disabled || typeof disabled !== 'boolean') {\n        return;\n      }\n\n      if (disabled) {\n        this.form.disable();\n      } else {\n        this.form.enable();\n      }\n\n      this._cd.markForCheck();\n    });\n\n    this._formGroupDirective.valueChanges!.pipe(this.debounceChange()).subscribe(() => {\n      this.updateFormStateWithRawValue();\n    });\n\n    this._formGroupDirective\n      .statusChanges!.pipe(distinctUntilChanged(), this.debounceChange())\n      .subscribe((status: string) => {\n        this._store.dispatch(\n          new UpdateFormStatus({\n            status,\n            path: this.path\n          })\n        );\n      });\n  }\n\n  updateFormStateWithRawValue(withFormStatus?: boolean) {\n    if (this._updating) return;\n\n    const value = this._formGroupDirective.control.getRawValue();\n\n    const actions: any[] = [\n      new UpdateFormValue({\n        path: this.path,\n        value\n      }),\n      new UpdateFormDirty({\n        path: this.path,\n        dirty: this._formGroupDirective.dirty\n      }),\n      new UpdateFormErrors({\n        path: this.path,\n        errors: this._formGroupDirective.errors\n      })\n    ];\n\n    if (withFormStatus) {\n      actions.push(\n        new UpdateFormStatus({\n          path: this.path,\n          status: this._formGroupDirective.status\n        })\n      );\n    }\n\n    this._updating = true;\n    this._store.dispatch(actions).subscribe({\n      error: () => (this._updating = false),\n      complete: () => (this._updating = false)\n    });\n  }\n  ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n\n    if (this.clearDestroy) {\n      this._store.dispatch(\n        new UpdateForm({\n          path: this.path,\n          value: null,\n          dirty: null,\n          status: null,\n          errors: null\n        })\n      );\n    }\n  }\n\n  private debounceChange() {\n    const skipDebounceTime =\n      this._formGroupDirective.control.updateOn !== 'change' || this.debounce < 0;\n\n    return skipDebounceTime\n      ? (change: Observable<any>) => change.pipe(takeUntil(this._destroy$))\n      : (change: Observable<any>) =>\n          change.pipe(debounceTime(this.debounce), takeUntil(this._destroy$));\n  }\n\n  private get form(): FormGroup {\n    return this._formGroupDirective.form;\n  }\n\n  private getStateStream(path: string) {\n    return this._store.select(state => getValue(state, path)).pipe(takeUntil(this._destroy$));\n  }\n}\n"]}
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
+ */
5
+ import { ChangeDetectorRef, Directive, Input } from '@angular/core';
6
+ import { FormGroupDirective } from '@angular/forms';
7
+ import { Actions, getValue, ofActionDispatched, Store } from '@ngxs/store';
8
+ import { Subject } from 'rxjs';
9
+ import { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';
10
+ import { ResetForm, UpdateForm, UpdateFormDirty, UpdateFormErrors, UpdateFormStatus, UpdateFormValue } from './actions';
11
+ var FormDirective = /** @class */ (function () {
12
+ function FormDirective(_actions$, _store, _formGroupDirective, _cd) {
13
+ this._actions$ = _actions$;
14
+ this._store = _store;
15
+ this._formGroupDirective = _formGroupDirective;
16
+ this._cd = _cd;
17
+ this.path = (/** @type {?} */ (null));
18
+ this.debounce = 100;
19
+ this._clearDestroy = false;
20
+ this._destroy$ = new Subject();
21
+ this._updating = false;
22
+ }
23
+ Object.defineProperty(FormDirective.prototype, "clearDestroy", {
24
+ get: /**
25
+ * @return {?}
26
+ */
27
+ function () {
28
+ return this._clearDestroy;
29
+ },
30
+ set: /**
31
+ * @param {?} val
32
+ * @return {?}
33
+ */
34
+ function (val) {
35
+ this._clearDestroy = val != null && "" + val !== 'false';
36
+ },
37
+ enumerable: true,
38
+ configurable: true
39
+ });
40
+ /**
41
+ * @return {?}
42
+ */
43
+ FormDirective.prototype.ngOnInit = /**
44
+ * @return {?}
45
+ */
46
+ function () {
47
+ var _this = this;
48
+ this._actions$
49
+ .pipe(ofActionDispatched(ResetForm), filter((/**
50
+ * @param {?} action
51
+ * @return {?}
52
+ */
53
+ function (action) { return action.payload.path === _this.path; })), takeUntil(this._destroy$))
54
+ .subscribe((/**
55
+ * @param {?} __0
56
+ * @return {?}
57
+ */
58
+ function (_a) {
59
+ var value = _a.payload.value;
60
+ _this.form.reset(value);
61
+ _this.updateFormStateWithRawValue(true);
62
+ _this._cd.markForCheck();
63
+ }));
64
+ this.getStateStream(this.path + ".model").subscribe((/**
65
+ * @param {?} model
66
+ * @return {?}
67
+ */
68
+ function (model) {
69
+ if (_this._updating || !model) {
70
+ return;
71
+ }
72
+ _this.form.patchValue(model);
73
+ _this._cd.markForCheck();
74
+ }));
75
+ this.getStateStream(this.path + ".dirty").subscribe((/**
76
+ * @param {?} dirty
77
+ * @return {?}
78
+ */
79
+ function (dirty) {
80
+ if (_this.form.dirty === dirty || typeof dirty !== 'boolean') {
81
+ return;
82
+ }
83
+ if (dirty) {
84
+ _this.form.markAsDirty();
85
+ }
86
+ else {
87
+ _this.form.markAsPristine();
88
+ }
89
+ _this._cd.markForCheck();
90
+ }));
91
+ // On first state change, sync form model, status and dirty with state
92
+ this._store
93
+ .selectOnce((/**
94
+ * @param {?} state
95
+ * @return {?}
96
+ */
97
+ function (state) { return getValue(state, _this.path); }))
98
+ .subscribe((/**
99
+ * @return {?}
100
+ */
101
+ function () {
102
+ _this._store.dispatch([
103
+ new UpdateFormValue({
104
+ path: _this.path,
105
+ value: _this.form.getRawValue()
106
+ }),
107
+ new UpdateFormStatus({
108
+ path: _this.path,
109
+ status: _this.form.status
110
+ }),
111
+ new UpdateFormDirty({
112
+ path: _this.path,
113
+ dirty: _this.form.dirty
114
+ })
115
+ ]);
116
+ }));
117
+ this.getStateStream(this.path + ".disabled").subscribe((/**
118
+ * @param {?} disabled
119
+ * @return {?}
120
+ */
121
+ function (disabled) {
122
+ if (_this.form.disabled === disabled || typeof disabled !== 'boolean') {
123
+ return;
124
+ }
125
+ if (disabled) {
126
+ _this.form.disable();
127
+ }
128
+ else {
129
+ _this.form.enable();
130
+ }
131
+ _this._cd.markForCheck();
132
+ }));
133
+ (/** @type {?} */ (this._formGroupDirective.valueChanges)).pipe(this.debounceChange()).subscribe((/**
134
+ * @return {?}
135
+ */
136
+ function () {
137
+ _this.updateFormStateWithRawValue();
138
+ }));
139
+ (/** @type {?} */ (this._formGroupDirective
140
+ .statusChanges)).pipe(distinctUntilChanged(), this.debounceChange())
141
+ .subscribe((/**
142
+ * @param {?} status
143
+ * @return {?}
144
+ */
145
+ function (status) {
146
+ _this._store.dispatch(new UpdateFormStatus({
147
+ status: status,
148
+ path: _this.path
149
+ }));
150
+ }));
151
+ };
152
+ /**
153
+ * @param {?=} withFormStatus
154
+ * @return {?}
155
+ */
156
+ FormDirective.prototype.updateFormStateWithRawValue = /**
157
+ * @param {?=} withFormStatus
158
+ * @return {?}
159
+ */
160
+ function (withFormStatus) {
161
+ var _this = this;
162
+ if (this._updating)
163
+ return;
164
+ /** @type {?} */
165
+ var value = this._formGroupDirective.control.getRawValue();
166
+ /** @type {?} */
167
+ var actions = [
168
+ new UpdateFormValue({
169
+ path: this.path,
170
+ value: value
171
+ }),
172
+ new UpdateFormDirty({
173
+ path: this.path,
174
+ dirty: this._formGroupDirective.dirty
175
+ }),
176
+ new UpdateFormErrors({
177
+ path: this.path,
178
+ errors: this._formGroupDirective.errors
179
+ })
180
+ ];
181
+ if (withFormStatus) {
182
+ actions.push(new UpdateFormStatus({
183
+ path: this.path,
184
+ status: this._formGroupDirective.status
185
+ }));
186
+ }
187
+ this._updating = true;
188
+ this._store.dispatch(actions).subscribe({
189
+ error: (/**
190
+ * @return {?}
191
+ */
192
+ function () { return (_this._updating = false); }),
193
+ complete: (/**
194
+ * @return {?}
195
+ */
196
+ function () { return (_this._updating = false); })
197
+ });
198
+ };
199
+ /**
200
+ * @return {?}
201
+ */
202
+ FormDirective.prototype.ngOnDestroy = /**
203
+ * @return {?}
204
+ */
205
+ function () {
206
+ this._destroy$.next();
207
+ this._destroy$.complete();
208
+ if (this.clearDestroy) {
209
+ this._store.dispatch(new UpdateForm({
210
+ path: this.path,
211
+ value: null,
212
+ dirty: null,
213
+ status: null,
214
+ errors: null
215
+ }));
216
+ }
217
+ };
218
+ /**
219
+ * @private
220
+ * @return {?}
221
+ */
222
+ FormDirective.prototype.debounceChange = /**
223
+ * @private
224
+ * @return {?}
225
+ */
226
+ function () {
227
+ var _this = this;
228
+ /** @type {?} */
229
+ var skipDebounceTime = this._formGroupDirective.control.updateOn !== 'change' || this.debounce < 0;
230
+ return skipDebounceTime
231
+ ? (/**
232
+ * @param {?} change
233
+ * @return {?}
234
+ */
235
+ function (change) { return change.pipe(takeUntil(_this._destroy$)); })
236
+ : (/**
237
+ * @param {?} change
238
+ * @return {?}
239
+ */
240
+ function (change) {
241
+ return change.pipe(debounceTime(_this.debounce), takeUntil(_this._destroy$));
242
+ });
243
+ };
244
+ Object.defineProperty(FormDirective.prototype, "form", {
245
+ get: /**
246
+ * @private
247
+ * @return {?}
248
+ */
249
+ function () {
250
+ return this._formGroupDirective.form;
251
+ },
252
+ enumerable: true,
253
+ configurable: true
254
+ });
255
+ /**
256
+ * @private
257
+ * @param {?} path
258
+ * @return {?}
259
+ */
260
+ FormDirective.prototype.getStateStream = /**
261
+ * @private
262
+ * @param {?} path
263
+ * @return {?}
264
+ */
265
+ function (path) {
266
+ return this._store.select((/**
267
+ * @param {?} state
268
+ * @return {?}
269
+ */
270
+ function (state) { return getValue(state, path); })).pipe(takeUntil(this._destroy$));
271
+ };
272
+ FormDirective.decorators = [
273
+ { type: Directive, args: [{ selector: '[ngxsForm]' },] }
274
+ ];
275
+ /** @nocollapse */
276
+ FormDirective.ctorParameters = function () { return [
277
+ { type: Actions },
278
+ { type: Store },
279
+ { type: FormGroupDirective },
280
+ { type: ChangeDetectorRef }
281
+ ]; };
282
+ FormDirective.propDecorators = {
283
+ path: [{ type: Input, args: ['ngxsForm',] }],
284
+ debounce: [{ type: Input, args: ['ngxsFormDebounce',] }],
285
+ clearDestroy: [{ type: Input, args: ['ngxsFormClearOnDestroy',] }]
286
+ };
287
+ return FormDirective;
288
+ }());
289
+ export { FormDirective };
290
+ if (false) {
291
+ /** @type {?} */
292
+ FormDirective.prototype.path;
293
+ /** @type {?} */
294
+ FormDirective.prototype.debounce;
295
+ /** @type {?} */
296
+ FormDirective.prototype._clearDestroy;
297
+ /**
298
+ * @type {?}
299
+ * @private
300
+ */
301
+ FormDirective.prototype._destroy$;
302
+ /**
303
+ * @type {?}
304
+ * @private
305
+ */
306
+ FormDirective.prototype._updating;
307
+ /**
308
+ * @type {?}
309
+ * @private
310
+ */
311
+ FormDirective.prototype._actions$;
312
+ /**
313
+ * @type {?}
314
+ * @private
315
+ */
316
+ FormDirective.prototype._store;
317
+ /**
318
+ * @type {?}
319
+ * @private
320
+ */
321
+ FormDirective.prototype._formGroupDirective;
322
+ /**
323
+ * @type {?}
324
+ * @private
325
+ */
326
+ FormDirective.prototype._cd;
327
+ }
328
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"directive.js","sourceRoot":"ng://@ngxs/form-plugin/","sources":["src/directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { FormGroup, FormGroupDirective } from '@angular/forms';\r\nimport { Actions, getValue, ofActionDispatched, Store } from '@ngxs/store';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';\r\nimport {\r\n  ResetForm,\r\n  UpdateForm,\r\n  UpdateFormDirty,\r\n  UpdateFormErrors,\r\n  UpdateFormStatus,\r\n  UpdateFormValue\r\n} from './actions';\r\n\r\n@Directive({ selector: '[ngxsForm]' })\r\nexport class FormDirective implements OnInit, OnDestroy {\r\n  @Input('ngxsForm')\r\n  path: string = null!;\r\n\r\n  @Input('ngxsFormDebounce')\r\n  debounce = 100;\r\n\r\n  @Input('ngxsFormClearOnDestroy')\r\n  set clearDestroy(val: boolean) {\r\n    this._clearDestroy = val != null && `${val}` !== 'false';\r\n  }\r\n\r\n  get clearDestroy(): boolean {\r\n    return this._clearDestroy;\r\n  }\r\n\r\n  _clearDestroy = false;\r\n\r\n  private readonly _destroy$ = new Subject<void>();\r\n  private _updating = false;\r\n\r\n  constructor(\r\n    private _actions$: Actions,\r\n    private _store: Store,\r\n    private _formGroupDirective: FormGroupDirective,\r\n    private _cd: ChangeDetectorRef\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this._actions$\r\n      .pipe(\r\n        ofActionDispatched(ResetForm),\r\n        filter((action: ResetForm) => action.payload.path === this.path),\r\n        takeUntil(this._destroy$)\r\n      )\r\n      .subscribe(({ payload: { value } }: ResetForm) => {\r\n        this.form.reset(value);\r\n        this.updateFormStateWithRawValue(true);\r\n        this._cd.markForCheck();\r\n      });\r\n\r\n    this.getStateStream(`${this.path}.model`).subscribe(model => {\r\n      if (this._updating || !model) {\r\n        return;\r\n      }\r\n\r\n      this.form.patchValue(model);\r\n      this._cd.markForCheck();\r\n    });\r\n\r\n    this.getStateStream(`${this.path}.dirty`).subscribe(dirty => {\r\n      if (this.form.dirty === dirty || typeof dirty !== 'boolean') {\r\n        return;\r\n      }\r\n\r\n      if (dirty) {\r\n        this.form.markAsDirty();\r\n      } else {\r\n        this.form.markAsPristine();\r\n      }\r\n\r\n      this._cd.markForCheck();\r\n    });\r\n\r\n    // On first state change, sync form model, status and dirty with state\r\n    this._store\r\n      .selectOnce(state => getValue(state, this.path))\r\n      .subscribe(() => {\r\n        this._store.dispatch([\r\n          new UpdateFormValue({\r\n            path: this.path,\r\n            value: this.form.getRawValue()\r\n          }),\r\n          new UpdateFormStatus({\r\n            path: this.path,\r\n            status: this.form.status\r\n          }),\r\n          new UpdateFormDirty({\r\n            path: this.path,\r\n            dirty: this.form.dirty\r\n          })\r\n        ]);\r\n      });\r\n\r\n    this.getStateStream(`${this.path}.disabled`).subscribe(disabled => {\r\n      if (this.form.disabled === disabled || typeof disabled !== 'boolean') {\r\n        return;\r\n      }\r\n\r\n      if (disabled) {\r\n        this.form.disable();\r\n      } else {\r\n        this.form.enable();\r\n      }\r\n\r\n      this._cd.markForCheck();\r\n    });\r\n\r\n    this._formGroupDirective.valueChanges!.pipe(this.debounceChange()).subscribe(() => {\r\n      this.updateFormStateWithRawValue();\r\n    });\r\n\r\n    this._formGroupDirective\r\n      .statusChanges!.pipe(distinctUntilChanged(), this.debounceChange())\r\n      .subscribe((status: string) => {\r\n        this._store.dispatch(\r\n          new UpdateFormStatus({\r\n            status,\r\n            path: this.path\r\n          })\r\n        );\r\n      });\r\n  }\r\n\r\n  updateFormStateWithRawValue(withFormStatus?: boolean) {\r\n    if (this._updating) return;\r\n\r\n    const value = this._formGroupDirective.control.getRawValue();\r\n\r\n    const actions: any[] = [\r\n      new UpdateFormValue({\r\n        path: this.path,\r\n        value\r\n      }),\r\n      new UpdateFormDirty({\r\n        path: this.path,\r\n        dirty: this._formGroupDirective.dirty\r\n      }),\r\n      new UpdateFormErrors({\r\n        path: this.path,\r\n        errors: this._formGroupDirective.errors\r\n      })\r\n    ];\r\n\r\n    if (withFormStatus) {\r\n      actions.push(\r\n        new UpdateFormStatus({\r\n          path: this.path,\r\n          status: this._formGroupDirective.status\r\n        })\r\n      );\r\n    }\r\n\r\n    this._updating = true;\r\n    this._store.dispatch(actions).subscribe({\r\n      error: () => (this._updating = false),\r\n      complete: () => (this._updating = false)\r\n    });\r\n  }\r\n  ngOnDestroy() {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n\r\n    if (this.clearDestroy) {\r\n      this._store.dispatch(\r\n        new UpdateForm({\r\n          path: this.path,\r\n          value: null,\r\n          dirty: null,\r\n          status: null,\r\n          errors: null\r\n        })\r\n      );\r\n    }\r\n  }\r\n\r\n  private debounceChange() {\r\n    const skipDebounceTime =\r\n      this._formGroupDirective.control.updateOn !== 'change' || this.debounce < 0;\r\n\r\n    return skipDebounceTime\r\n      ? (change: Observable<any>) => change.pipe(takeUntil(this._destroy$))\r\n      : (change: Observable<any>) =>\r\n          change.pipe(debounceTime(this.debounce), takeUntil(this._destroy$));\r\n  }\r\n\r\n  private get form(): FormGroup {\r\n    return this._formGroupDirective.form;\r\n  }\r\n\r\n  private getStateStream(path: string) {\r\n    return this._store.select(state => getValue(state, path)).pipe(takeUntil(this._destroy$));\r\n  }\r\n}\r\n"]}