@ngxs/form-plugin 3.7.6 → 3.8.0-dev.master-c341c15

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,225 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
5
- var UpdateFormStatus = /** @class */ (function () {
6
- function UpdateFormStatus(payload) {
7
- this.payload = payload;
8
- }
9
- Object.defineProperty(UpdateFormStatus, "type", {
10
- get: /**
11
- * @return {?}
12
- */
13
- function () {
14
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
15
- return '[Forms] Update Form Status';
16
- },
17
- enumerable: true,
18
- configurable: true
19
- });
20
- return UpdateFormStatus;
21
- }());
22
- export { UpdateFormStatus };
23
- if (false) {
24
- /** @type {?} */
25
- UpdateFormStatus.prototype.payload;
26
- }
27
- var UpdateFormValue = /** @class */ (function () {
28
- function UpdateFormValue(payload) {
29
- this.payload = payload;
30
- }
31
- Object.defineProperty(UpdateFormValue, "type", {
32
- get: /**
33
- * @return {?}
34
- */
35
- function () {
36
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
37
- return '[Forms] Update Form Value';
38
- },
39
- enumerable: true,
40
- configurable: true
41
- });
42
- return UpdateFormValue;
43
- }());
44
- export { UpdateFormValue };
45
- if (false) {
46
- /** @type {?} */
47
- UpdateFormValue.prototype.payload;
48
- }
49
- var UpdateForm = /** @class */ (function () {
50
- function UpdateForm(payload) {
51
- this.payload = payload;
52
- }
53
- Object.defineProperty(UpdateForm, "type", {
54
- get: /**
55
- * @return {?}
56
- */
57
- function () {
58
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
59
- return '[Forms] Update Form';
60
- },
61
- enumerable: true,
62
- configurable: true
63
- });
64
- return UpdateForm;
65
- }());
66
- export { UpdateForm };
67
- if (false) {
68
- /** @type {?} */
69
- UpdateForm.prototype.payload;
70
- }
71
- var UpdateFormDirty = /** @class */ (function () {
72
- function UpdateFormDirty(payload) {
73
- this.payload = payload;
74
- }
75
- Object.defineProperty(UpdateFormDirty, "type", {
76
- get: /**
77
- * @return {?}
78
- */
79
- function () {
80
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
81
- return '[Forms] Update Form Dirty';
82
- },
83
- enumerable: true,
84
- configurable: true
85
- });
86
- return UpdateFormDirty;
87
- }());
88
- export { UpdateFormDirty };
89
- if (false) {
90
- /** @type {?} */
91
- UpdateFormDirty.prototype.payload;
92
- }
93
- var SetFormDirty = /** @class */ (function () {
94
- function SetFormDirty(payload) {
95
- this.payload = payload;
96
- }
97
- Object.defineProperty(SetFormDirty, "type", {
98
- get: /**
99
- * @return {?}
100
- */
101
- function () {
102
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
103
- return '[Forms] Set Form Dirty';
104
- },
105
- enumerable: true,
106
- configurable: true
107
- });
108
- return SetFormDirty;
109
- }());
110
- export { SetFormDirty };
111
- if (false) {
112
- /** @type {?} */
113
- SetFormDirty.prototype.payload;
114
- }
115
- var SetFormPristine = /** @class */ (function () {
116
- function SetFormPristine(payload) {
117
- this.payload = payload;
118
- }
119
- Object.defineProperty(SetFormPristine, "type", {
120
- get: /**
121
- * @return {?}
122
- */
123
- function () {
124
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
125
- return '[Forms] Set Form Pristine';
126
- },
127
- enumerable: true,
128
- configurable: true
129
- });
130
- return SetFormPristine;
131
- }());
132
- export { SetFormPristine };
133
- if (false) {
134
- /** @type {?} */
135
- SetFormPristine.prototype.payload;
136
- }
137
- var UpdateFormErrors = /** @class */ (function () {
138
- function UpdateFormErrors(payload) {
139
- this.payload = payload;
140
- }
141
- Object.defineProperty(UpdateFormErrors, "type", {
142
- get: /**
143
- * @return {?}
144
- */
145
- function () {
146
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
147
- return '[Forms] Update Form Errors';
148
- },
149
- enumerable: true,
150
- configurable: true
151
- });
152
- return UpdateFormErrors;
153
- }());
154
- export { UpdateFormErrors };
155
- if (false) {
156
- /** @type {?} */
157
- UpdateFormErrors.prototype.payload;
158
- }
159
- var SetFormDisabled = /** @class */ (function () {
160
- function SetFormDisabled(payload) {
161
- this.payload = payload;
162
- }
163
- Object.defineProperty(SetFormDisabled, "type", {
164
- get: /**
165
- * @return {?}
166
- */
167
- function () {
168
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
169
- return '[Forms] Set Form Disabled';
170
- },
171
- enumerable: true,
172
- configurable: true
173
- });
174
- return SetFormDisabled;
175
- }());
176
- export { SetFormDisabled };
177
- if (false) {
178
- /** @type {?} */
179
- SetFormDisabled.prototype.payload;
180
- }
181
- var SetFormEnabled = /** @class */ (function () {
182
- function SetFormEnabled(payload) {
183
- this.payload = payload;
184
- }
185
- Object.defineProperty(SetFormEnabled, "type", {
186
- get: /**
187
- * @return {?}
188
- */
189
- function () {
190
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
191
- return '[Forms] Set Form Enabled';
192
- },
193
- enumerable: true,
194
- configurable: true
195
- });
196
- return SetFormEnabled;
197
- }());
198
- export { SetFormEnabled };
199
- if (false) {
200
- /** @type {?} */
201
- SetFormEnabled.prototype.payload;
202
- }
203
- var ResetForm = /** @class */ (function () {
204
- function ResetForm(payload) {
205
- this.payload = payload;
206
- }
207
- Object.defineProperty(ResetForm, "type", {
208
- get: /**
209
- * @return {?}
210
- */
211
- function () {
212
- // NOTE: Not necessary to declare the type in this way in your code. See https://github.com/ngxs/store/pull/644#issuecomment-436003138
213
- return '[Forms] Reset Form';
214
- },
215
- enumerable: true,
216
- configurable: true
217
- });
218
- return ResetForm;
219
- }());
220
- export { ResetForm };
221
- if (false) {
222
- /** @type {?} */
223
- ResetForm.prototype.payload;
224
- }
225
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL2Zvcm0tcGx1Z2luLyIsInNvdXJjZXMiOlsic3JjL2FjdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBO0lBS0UsMEJBQ1MsT0FHTjtRQUhNLFlBQU8sR0FBUCxPQUFPLENBR2I7SUFDQSxDQUFDO0lBVEosc0JBQVcsd0JBQUk7Ozs7UUFBZjtZQUNFLHNJQUFzSTtZQUN0SSxPQUFPLDRCQUE0QixDQUFDO1FBQ3RDLENBQUM7OztPQUFBO0lBT0gsdUJBQUM7QUFBRCxDQUFDLEFBWEQsSUFXQzs7OztJQUxHLG1DQUdDOztBQUlMO0lBS0UseUJBQW1CLE9BQTREO1FBQTVELFlBQU8sR0FBUCxPQUFPLENBQXFEO0lBQUcsQ0FBQztJQUpuRixzQkFBVyx1QkFBSTs7OztRQUFmO1lBQ0Usc0lBQXNJO1lBQ3RJLE9BQU8sMkJBQTJCLENBQUM7UUFDckMsQ0FBQzs7O09BQUE7SUFFSCxzQkFBQztBQUFELENBQUMsQUFORCxJQU1DOzs7O0lBRGEsa0NBQW1FOztBQUdqRjtJQUtFLG9CQUNTLE9BTU47UUFOTSxZQUFPLEdBQVAsT0FBTyxDQU1iO0lBQ0EsQ0FBQztJQVpKLHNCQUFXLGtCQUFJOzs7O1FBQWY7WUFDRSxzSUFBc0k7WUFDdEksT0FBTyxxQkFBcUIsQ0FBQztRQUMvQixDQUFDOzs7T0FBQTtJQVVILGlCQUFDO0FBQUQsQ0FBQyxBQWRELElBY0M7Ozs7SUFSRyw2QkFNQzs7QUFJTDtJQUtFLHlCQUFtQixPQUFnRDtRQUFoRCxZQUFPLEdBQVAsT0FBTyxDQUF5QztJQUFHLENBQUM7SUFKdkUsc0JBQVcsdUJBQUk7Ozs7UUFBZjtZQUNFLHNJQUFzSTtZQUN0SSxPQUFPLDJCQUEyQixDQUFDO1FBQ3JDLENBQUM7OztPQUFBO0lBRUgsc0JBQUM7QUFBRCxDQUFDLEFBTkQsSUFNQzs7OztJQURhLGtDQUF1RDs7QUFHckU7SUFLRSxzQkFBbUIsT0FBZTtRQUFmLFlBQU8sR0FBUCxPQUFPLENBQVE7SUFBRyxDQUFDO0lBSnRDLHNCQUFXLG9CQUFJOzs7O1FBQWY7WUFDRSxzSUFBc0k7WUFDdEksT0FBTyx3QkFBd0IsQ0FBQztRQUNsQyxDQUFDOzs7T0FBQTtJQUVILG1CQUFDO0FBQUQsQ0FBQyxBQU5ELElBTUM7Ozs7SUFEYSwrQkFBc0I7O0FBR3BDO0lBS0UseUJBQW1CLE9BQWU7UUFBZixZQUFPLEdBQVAsT0FBTyxDQUFRO0lBQUcsQ0FBQztJQUp0QyxzQkFBVyx1QkFBSTs7OztRQUFmO1lBQ0Usc0lBQXNJO1lBQ3RJLE9BQU8sMkJBQTJCLENBQUM7UUFDckMsQ0FBQzs7O09BQUE7SUFFSCxzQkFBQztBQUFELENBQUMsQUFORCxJQU1DOzs7O0lBRGEsa0NBQXNCOztBQUdwQztJQUtFLDBCQUFtQixPQUFpRTtRQUFqRSxZQUFPLEdBQVAsT0FBTyxDQUEwRDtJQUFHLENBQUM7SUFKeEYsc0JBQVcsd0JBQUk7Ozs7UUFBZjtZQUNFLHNJQUFzSTtZQUN0SSxPQUFPLDRCQUE0QixDQUFDO1FBQ3RDLENBQUM7OztPQUFBO0lBRUgsdUJBQUM7QUFBRCxDQUFDLEFBTkQsSUFNQzs7OztJQURhLG1DQUF3RTs7QUFHdEY7SUFLRSx5QkFBbUIsT0FBZTtRQUFmLFlBQU8sR0FBUCxPQUFPLENBQVE7SUFBRyxDQUFDO0lBSnRDLHNCQUFXLHVCQUFJOzs7O1FBQWY7WUFDRSxzSUFBc0k7WUFDdEksT0FBTywyQkFBMkIsQ0FBQztRQUNyQyxDQUFDOzs7T0FBQTtJQUVILHNCQUFDO0FBQUQsQ0FBQyxBQU5ELElBTUM7Ozs7SUFEYSxrQ0FBc0I7O0FBR3BDO0lBS0Usd0JBQW1CLE9BQWU7UUFBZixZQUFPLEdBQVAsT0FBTyxDQUFRO0lBQUcsQ0FBQztJQUp0QyxzQkFBVyxzQkFBSTs7OztRQUFmO1lBQ0Usc0lBQXNJO1lBQ3RJLE9BQU8sMEJBQTBCLENBQUM7UUFDcEMsQ0FBQzs7O09BQUE7SUFFSCxxQkFBQztBQUFELENBQUMsQUFORCxJQU1DOzs7O0lBRGEsaUNBQXNCOztBQUdwQztJQUtFLG1CQUFtQixPQUFzQztRQUF0QyxZQUFPLEdBQVAsT0FBTyxDQUErQjtJQUFHLENBQUM7SUFKN0Qsc0JBQVcsaUJBQUk7Ozs7UUFBZjtZQUNFLHNJQUFzSTtZQUN0SSxPQUFPLG9CQUFvQixDQUFDO1FBQzlCLENBQUM7OztPQUFBO0lBRUgsZ0JBQUM7QUFBRCxDQUFDLEFBTkQsSUFNQzs7OztJQURhLDRCQUE2QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBVcGRhdGVGb3JtU3RhdHVzIHtcbiAgc3RhdGljIGdldCB0eXBlKCkge1xuICAgIC8vIE5PVEU6IE5vdCBuZWNlc3NhcnkgdG8gZGVjbGFyZSB0aGUgdHlwZSBpbiB0aGlzIHdheSBpbiB5b3VyIGNvZGUuIFNlZSBodHRwczovL2dpdGh1Yi5jb20vbmd4cy9zdG9yZS9wdWxsLzY0NCNpc3N1ZWNvbW1lbnQtNDM2MDAzMTM4XG4gICAgcmV0dXJuICdbRm9ybXNdIFVwZGF0ZSBGb3JtIFN0YXR1cyc7XG4gIH1cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIHBheWxvYWQ6IHtcbiAgICAgIHN0YXR1czogc3RyaW5nIHwgbnVsbDtcbiAgICAgIHBhdGg6IHN0cmluZztcbiAgICB9XG4gICkge31cbn1cblxuZXhwb3J0IGNsYXNzIFVwZGF0ZUZvcm1WYWx1ZSB7XG4gIHN0YXRpYyBnZXQgdHlwZSgpIHtcbiAgICAvLyBOT1RFOiBOb3QgbmVjZXNzYXJ5IHRvIGRlY2xhcmUgdGhlIHR5cGUgaW4gdGhpcyB3YXkgaW4geW91ciBjb2RlLiBTZWUgaHR0cHM6Ly9naXRodWIuY29tL25neHMvc3RvcmUvcHVsbC82NDQjaXNzdWVjb21tZW50LTQzNjAwMzEzOFxuICAgIHJldHVybiAnW0Zvcm1zXSBVcGRhdGUgRm9ybSBWYWx1ZSc7XG4gIH1cbiAgY29uc3RydWN0b3IocHVibGljIHBheWxvYWQ6IHsgdmFsdWU6IGFueTsgcGF0aDogc3RyaW5nOyBwcm9wZXJ0eVBhdGg/OiBzdHJpbmcgfSkge31cbn1cblxuZXhwb3J0IGNsYXNzIFVwZGF0ZUZvcm0ge1xuICBzdGF0aWMgZ2V0IHR5cGUoKSB7XG4gICAgLy8gTk9URTogTm90IG5lY2Vzc2FyeSB0byBkZWNsYXJlIHRoZSB0eXBlIGluIHRoaXMgd2F5IGluIHlvdXIgY29kZS4gU2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9uZ3hzL3N0b3JlL3B1bGwvNjQ0I2lzc3VlY29tbWVudC00MzYwMDMxMzhcbiAgICByZXR1cm4gJ1tGb3Jtc10gVXBkYXRlIEZvcm0nO1xuICB9XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBwYXlsb2FkOiB7XG4gICAgICB2YWx1ZTogYW55O1xuICAgICAgZXJyb3JzOiB7IFtrOiBzdHJpbmddOiBzdHJpbmcgfSB8IG51bGw7XG4gICAgICBkaXJ0eTogYm9vbGVhbiB8IG51bGw7XG4gICAgICBzdGF0dXM6IHN0cmluZyB8IG51bGw7XG4gICAgICBwYXRoOiBzdHJpbmc7XG4gICAgfVxuICApIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBVcGRhdGVGb3JtRGlydHkge1xuICBzdGF0aWMgZ2V0IHR5cGUoKSB7XG4gICAgLy8gTk9URTogTm90IG5lY2Vzc2FyeSB0byBkZWNsYXJlIHRoZSB0eXBlIGluIHRoaXMgd2F5IGluIHlvdXIgY29kZS4gU2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9uZ3hzL3N0b3JlL3B1bGwvNjQ0I2lzc3VlY29tbWVudC00MzYwMDMxMzhcbiAgICByZXR1cm4gJ1tGb3Jtc10gVXBkYXRlIEZvcm0gRGlydHknO1xuICB9XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBwYXlsb2FkOiB7IGRpcnR5OiBib29sZWFuIHwgbnVsbDsgcGF0aDogc3RyaW5nIH0pIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBTZXRGb3JtRGlydHkge1xuICBzdGF0aWMgZ2V0IHR5cGUoKSB7XG4gICAgLy8gTk9URTogTm90IG5lY2Vzc2FyeSB0byBkZWNsYXJlIHRoZSB0eXBlIGluIHRoaXMgd2F5IGluIHlvdXIgY29kZS4gU2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9uZ3hzL3N0b3JlL3B1bGwvNjQ0I2lzc3VlY29tbWVudC00MzYwMDMxMzhcbiAgICByZXR1cm4gJ1tGb3Jtc10gU2V0IEZvcm0gRGlydHknO1xuICB9XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBwYXlsb2FkOiBzdHJpbmcpIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBTZXRGb3JtUHJpc3RpbmUge1xuICBzdGF0aWMgZ2V0IHR5cGUoKSB7XG4gICAgLy8gTk9URTogTm90IG5lY2Vzc2FyeSB0byBkZWNsYXJlIHRoZSB0eXBlIGluIHRoaXMgd2F5IGluIHlvdXIgY29kZS4gU2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9uZ3hzL3N0b3JlL3B1bGwvNjQ0I2lzc3VlY29tbWVudC00MzYwMDMxMzhcbiAgICByZXR1cm4gJ1tGb3Jtc10gU2V0IEZvcm0gUHJpc3RpbmUnO1xuICB9XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBwYXlsb2FkOiBzdHJpbmcpIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBVcGRhdGVGb3JtRXJyb3JzIHtcbiAgc3RhdGljIGdldCB0eXBlKCkge1xuICAgIC8vIE5PVEU6IE5vdCBuZWNlc3NhcnkgdG8gZGVjbGFyZSB0aGUgdHlwZSBpbiB0aGlzIHdheSBpbiB5b3VyIGNvZGUuIFNlZSBodHRwczovL2dpdGh1Yi5jb20vbmd4cy9zdG9yZS9wdWxsLzY0NCNpc3N1ZWNvbW1lbnQtNDM2MDAzMTM4XG4gICAgcmV0dXJuICdbRm9ybXNdIFVwZGF0ZSBGb3JtIEVycm9ycyc7XG4gIH1cbiAgY29uc3RydWN0b3IocHVibGljIHBheWxvYWQ6IHsgZXJyb3JzOiB7IFtrOiBzdHJpbmddOiBzdHJpbmcgfSB8IG51bGw7IHBhdGg6IHN0cmluZyB9KSB7fVxufVxuXG5leHBvcnQgY2xhc3MgU2V0Rm9ybURpc2FibGVkIHtcbiAgc3RhdGljIGdldCB0eXBlKCkge1xuICAgIC8vIE5PVEU6IE5vdCBuZWNlc3NhcnkgdG8gZGVjbGFyZSB0aGUgdHlwZSBpbiB0aGlzIHdheSBpbiB5b3VyIGNvZGUuIFNlZSBodHRwczovL2dpdGh1Yi5jb20vbmd4cy9zdG9yZS9wdWxsLzY0NCNpc3N1ZWNvbW1lbnQtNDM2MDAzMTM4XG4gICAgcmV0dXJuICdbRm9ybXNdIFNldCBGb3JtIERpc2FibGVkJztcbiAgfVxuICBjb25zdHJ1Y3RvcihwdWJsaWMgcGF5bG9hZDogc3RyaW5nKSB7fVxufVxuXG5leHBvcnQgY2xhc3MgU2V0Rm9ybUVuYWJsZWQge1xuICBzdGF0aWMgZ2V0IHR5cGUoKSB7XG4gICAgLy8gTk9URTogTm90IG5lY2Vzc2FyeSB0byBkZWNsYXJlIHRoZSB0eXBlIGluIHRoaXMgd2F5IGluIHlvdXIgY29kZS4gU2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9uZ3hzL3N0b3JlL3B1bGwvNjQ0I2lzc3VlY29tbWVudC00MzYwMDMxMzhcbiAgICByZXR1cm4gJ1tGb3Jtc10gU2V0IEZvcm0gRW5hYmxlZCc7XG4gIH1cbiAgY29uc3RydWN0b3IocHVibGljIHBheWxvYWQ6IHN0cmluZykge31cbn1cblxuZXhwb3J0IGNsYXNzIFJlc2V0Rm9ybSB7XG4gIHN0YXRpYyBnZXQgdHlwZSgpIHtcbiAgICAvLyBOT1RFOiBOb3QgbmVjZXNzYXJ5IHRvIGRlY2xhcmUgdGhlIHR5cGUgaW4gdGhpcyB3YXkgaW4geW91ciBjb2RlLiBTZWUgaHR0cHM6Ly9naXRodWIuY29tL25neHMvc3RvcmUvcHVsbC82NDQjaXNzdWVjb21tZW50LTQzNjAwMzEzOFxuICAgIHJldHVybiAnW0Zvcm1zXSBSZXNldCBGb3JtJztcbiAgfVxuICBjb25zdHJ1Y3RvcihwdWJsaWMgcGF5bG9hZDogeyBwYXRoOiBzdHJpbmc7IHZhbHVlPzogYW55IH0pIHt9XG59XG4iXX0=
@@ -1,335 +0,0 @@
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
134
- .valueChanges)).pipe(distinctUntilChanged((/**
135
- * @param {?} a
136
- * @param {?} b
137
- * @return {?}
138
- */
139
- function (a, b) { return JSON.stringify(a) === JSON.stringify(b); })), this.debounceChange())
140
- .subscribe((/**
141
- * @return {?}
142
- */
143
- function () {
144
- _this.updateFormStateWithRawValue();
145
- }));
146
- (/** @type {?} */ (this._formGroupDirective
147
- .statusChanges)).pipe(distinctUntilChanged(), this.debounceChange())
148
- .subscribe((/**
149
- * @param {?} status
150
- * @return {?}
151
- */
152
- function (status) {
153
- _this._store.dispatch(new UpdateFormStatus({
154
- status: status,
155
- path: _this.path
156
- }));
157
- }));
158
- };
159
- /**
160
- * @param {?=} withFormStatus
161
- * @return {?}
162
- */
163
- FormDirective.prototype.updateFormStateWithRawValue = /**
164
- * @param {?=} withFormStatus
165
- * @return {?}
166
- */
167
- function (withFormStatus) {
168
- var _this = this;
169
- if (this._updating)
170
- return;
171
- /** @type {?} */
172
- var value = this._formGroupDirective.control.getRawValue();
173
- /** @type {?} */
174
- var actions = [
175
- new UpdateFormValue({
176
- path: this.path,
177
- value: value
178
- }),
179
- new UpdateFormDirty({
180
- path: this.path,
181
- dirty: this._formGroupDirective.dirty
182
- }),
183
- new UpdateFormErrors({
184
- path: this.path,
185
- errors: this._formGroupDirective.errors
186
- })
187
- ];
188
- if (withFormStatus) {
189
- actions.push(new UpdateFormStatus({
190
- path: this.path,
191
- status: this._formGroupDirective.status
192
- }));
193
- }
194
- this._updating = true;
195
- this._store.dispatch(actions).subscribe({
196
- error: (/**
197
- * @return {?}
198
- */
199
- function () { return (_this._updating = false); }),
200
- complete: (/**
201
- * @return {?}
202
- */
203
- function () { return (_this._updating = false); })
204
- });
205
- };
206
- /**
207
- * @return {?}
208
- */
209
- FormDirective.prototype.ngOnDestroy = /**
210
- * @return {?}
211
- */
212
- function () {
213
- this._destroy$.next();
214
- this._destroy$.complete();
215
- if (this.clearDestroy) {
216
- this._store.dispatch(new UpdateForm({
217
- path: this.path,
218
- value: null,
219
- dirty: null,
220
- status: null,
221
- errors: null
222
- }));
223
- }
224
- };
225
- /**
226
- * @private
227
- * @return {?}
228
- */
229
- FormDirective.prototype.debounceChange = /**
230
- * @private
231
- * @return {?}
232
- */
233
- function () {
234
- var _this = this;
235
- /** @type {?} */
236
- var skipDebounceTime = this._formGroupDirective.control.updateOn !== 'change' || this.debounce < 0;
237
- return skipDebounceTime
238
- ? (/**
239
- * @param {?} change
240
- * @return {?}
241
- */
242
- function (change) { return change.pipe(takeUntil(_this._destroy$)); })
243
- : (/**
244
- * @param {?} change
245
- * @return {?}
246
- */
247
- function (change) {
248
- return change.pipe(debounceTime(_this.debounce), takeUntil(_this._destroy$));
249
- });
250
- };
251
- Object.defineProperty(FormDirective.prototype, "form", {
252
- get: /**
253
- * @private
254
- * @return {?}
255
- */
256
- function () {
257
- return this._formGroupDirective.form;
258
- },
259
- enumerable: true,
260
- configurable: true
261
- });
262
- /**
263
- * @private
264
- * @param {?} path
265
- * @return {?}
266
- */
267
- FormDirective.prototype.getStateStream = /**
268
- * @private
269
- * @param {?} path
270
- * @return {?}
271
- */
272
- function (path) {
273
- return this._store.select((/**
274
- * @param {?} state
275
- * @return {?}
276
- */
277
- function (state) { return getValue(state, path); })).pipe(takeUntil(this._destroy$));
278
- };
279
- FormDirective.decorators = [
280
- { type: Directive, args: [{ selector: '[ngxsForm]' },] }
281
- ];
282
- /** @nocollapse */
283
- FormDirective.ctorParameters = function () { return [
284
- { type: Actions },
285
- { type: Store },
286
- { type: FormGroupDirective },
287
- { type: ChangeDetectorRef }
288
- ]; };
289
- FormDirective.propDecorators = {
290
- path: [{ type: Input, args: ['ngxsForm',] }],
291
- debounce: [{ type: Input, args: ['ngxsFormDebounce',] }],
292
- clearDestroy: [{ type: Input, args: ['ngxsFormClearOnDestroy',] }]
293
- };
294
- return FormDirective;
295
- }());
296
- export { FormDirective };
297
- if (false) {
298
- /** @type {?} */
299
- FormDirective.prototype.path;
300
- /** @type {?} */
301
- FormDirective.prototype.debounce;
302
- /** @type {?} */
303
- FormDirective.prototype._clearDestroy;
304
- /**
305
- * @type {?}
306
- * @private
307
- */
308
- FormDirective.prototype._destroy$;
309
- /**
310
- * @type {?}
311
- * @private
312
- */
313
- FormDirective.prototype._updating;
314
- /**
315
- * @type {?}
316
- * @private
317
- */
318
- FormDirective.prototype._actions$;
319
- /**
320
- * @type {?}
321
- * @private
322
- */
323
- FormDirective.prototype._store;
324
- /**
325
- * @type {?}
326
- * @private
327
- */
328
- FormDirective.prototype._formGroupDirective;
329
- /**
330
- * @type {?}
331
- * @private
332
- */
333
- FormDirective.prototype._cd;
334
- }
335
- //# 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"]}
@@ -1,41 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
5
- import { NgModule } from '@angular/core';
6
- import { NGXS_PLUGINS } from '@ngxs/store';
7
- import { NgxsFormPlugin } from './form.plugin';
8
- import { ReactiveFormsModule } from '@angular/forms';
9
- import { FormDirective } from './directive';
10
- var NgxsFormPluginModule = /** @class */ (function () {
11
- function NgxsFormPluginModule() {
12
- }
13
- /**
14
- * @return {?}
15
- */
16
- NgxsFormPluginModule.forRoot = /**
17
- * @return {?}
18
- */
19
- function () {
20
- return {
21
- ngModule: NgxsFormPluginModule,
22
- providers: [
23
- {
24
- provide: NGXS_PLUGINS,
25
- useClass: NgxsFormPlugin,
26
- multi: true
27
- }
28
- ]
29
- };
30
- };
31
- NgxsFormPluginModule.decorators = [
32
- { type: NgModule, args: [{
33
- imports: [ReactiveFormsModule],
34
- declarations: [FormDirective],
35
- exports: [FormDirective]
36
- },] }
37
- ];
38
- return NgxsFormPluginModule;
39
- }());
40
- export { NgxsFormPluginModule };
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Abmd4cy9mb3JtLXBsdWdpbi8iLCJzb3VyY2VzIjpbInNyYy9mb3JtLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUMzQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFNUM7SUFBQTtJQWtCQSxDQUFDOzs7O0lBWlEsNEJBQU87OztJQUFkO1FBQ0UsT0FBTztZQUNMLFFBQVEsRUFBRSxvQkFBb0I7WUFDOUIsU0FBUyxFQUFFO2dCQUNUO29CQUNFLE9BQU8sRUFBRSxZQUFZO29CQUNyQixRQUFRLEVBQUUsY0FBYztvQkFDeEIsS0FBSyxFQUFFLElBQUk7aUJBQ1o7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDOztnQkFqQkYsUUFBUSxTQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUM5QixZQUFZLEVBQUUsQ0FBQyxhQUFhLENBQUM7b0JBQzdCLE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQztpQkFDekI7O0lBY0QsMkJBQUM7Q0FBQSxBQWxCRCxJQWtCQztTQWJZLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBNb2R1bGVXaXRoUHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOR1hTX1BMVUdJTlMgfSBmcm9tICdAbmd4cy9zdG9yZSc7XG5pbXBvcnQgeyBOZ3hzRm9ybVBsdWdpbiB9IGZyb20gJy4vZm9ybS5wbHVnaW4nO1xuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEZvcm1EaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtSZWFjdGl2ZUZvcm1zTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbRm9ybURpcmVjdGl2ZV0sXG4gIGV4cG9ydHM6IFtGb3JtRGlyZWN0aXZlXVxufSlcbmV4cG9ydCBjbGFzcyBOZ3hzRm9ybVBsdWdpbk1vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KCk6IE1vZHVsZVdpdGhQcm92aWRlcnM8Tmd4c0Zvcm1QbHVnaW5Nb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IE5neHNGb3JtUGx1Z2luTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBwcm92aWRlOiBOR1hTX1BMVUdJTlMsXG4gICAgICAgICAgdXNlQ2xhc3M6IE5neHNGb3JtUGx1Z2luLFxuICAgICAgICAgIG11bHRpOiB0cnVlXG4gICAgICAgIH1cbiAgICAgIF1cbiAgICB9O1xuICB9XG59XG4iXX0=