@ngxs/form-plugin 3.7.4 → 3.7.5

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