@valtimo/form-view-model 12.7.0 → 12.8.0

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.
@@ -15,18 +15,20 @@
15
15
  */
16
16
  import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
17
17
  import moment from 'moment';
18
- import { BehaviorSubject, catchError, combineLatest, debounceTime, EMPTY, filter, of, Subject, switchMap, take, tap, withLatestFrom, } from 'rxjs';
18
+ import { BehaviorSubject, combineLatest, filter, Subject, switchMap, take, tap, } from 'rxjs';
19
19
  import { FormioModule, } from '@formio/angular';
20
20
  import { distinctUntilChanged, map } from 'rxjs/operators';
21
21
  import { deepmerge } from 'deepmerge-ts';
22
+ import { HttpErrorResponse } from '@angular/common/http';
22
23
  import { CommonModule } from '@angular/common';
23
- import { isEqual } from 'lodash';
24
+ import { LayerModule } from 'carbon-components-angular';
24
25
  import * as i0 from "@angular/core";
25
26
  import * as i1 from "../../services";
26
27
  import * as i2 from "@ngx-translate/core";
27
28
  import * as i3 from "@valtimo/components";
28
29
  import * as i4 from "@angular/common";
29
30
  import * as i5 from "@formio/angular";
31
+ import * as i6 from "carbon-components-angular";
30
32
  moment.defaultFormat = 'DD MMM YYYY HH:mm';
31
33
  export class FormViewModelComponent {
32
34
  set options(optionsValue) {
@@ -40,6 +42,8 @@ export class FormViewModelComponent {
40
42
  const form = {
41
43
  loadInitialViewModel: () => instance.loadInitialViewModel(),
42
44
  updateViewModel: () => instance.updateViewModel(),
45
+ loadInitialStartFormViewModel: () => instance.loadInitialViewModelForStartForm(),
46
+ updateViewStartFormModel: () => instance.updateViewModelForStartForm(),
43
47
  ...formValue,
44
48
  };
45
49
  this.form$.next(form);
@@ -53,6 +57,9 @@ export class FormViewModelComponent {
53
57
  set isStartForm(isStartFormValue) {
54
58
  this.isStartForm$.next(isStartFormValue);
55
59
  }
60
+ set documentId(documentId) {
61
+ this.documentId$.next(documentId);
62
+ }
56
63
  set processDefinitionKey(processDefinitionKeyValue) {
57
64
  this.processDefinitionKey$.next(processDefinitionKeyValue);
58
65
  }
@@ -64,14 +71,15 @@ export class FormViewModelComponent {
64
71
  this.translateService = translateService;
65
72
  this.stateService = stateService;
66
73
  this.formSubmit = new EventEmitter();
67
- this.errors = [];
68
74
  this.refreshForm = new EventEmitter();
69
75
  this._preventNextPage = false;
70
76
  this._preventPreviousPage = false;
71
77
  this._isWizard = false;
78
+ this.pendingUpdateSubscription = null;
72
79
  this.submission$ = new BehaviorSubject({});
73
80
  this.form$ = new BehaviorSubject(undefined);
74
81
  this.formName$ = new BehaviorSubject(undefined);
82
+ this.formErrors$ = new BehaviorSubject([]);
75
83
  this.options$ = new BehaviorSubject(undefined);
76
84
  this.taskInstanceId$ = new BehaviorSubject(undefined);
77
85
  this.tokenSetInLocalStorage$ = new BehaviorSubject(false);
@@ -80,6 +88,7 @@ export class FormViewModelComponent {
80
88
  this.focus$ = new BehaviorSubject(null);
81
89
  this.loading$ = new BehaviorSubject(true);
82
90
  this.isStartForm$ = new BehaviorSubject(false);
91
+ this.documentId$ = new BehaviorSubject(null);
83
92
  this.processDefinitionKey$ = new BehaviorSubject(undefined);
84
93
  this.documentDefinitionName$ = new BehaviorSubject(undefined);
85
94
  this.updateForm = new Subject();
@@ -90,13 +99,14 @@ export class FormViewModelComponent {
90
99
  },
91
100
  });
92
101
  this.formioOptions$ = combineLatest([
93
- this.currentLanguage$,
94
102
  this.options$,
95
103
  this._overrideOptions$,
96
- ]).pipe(map(([language, options, overrideOptions]) => {
104
+ ]).pipe(map(([options, overrideOptions]) => {
105
+ return deepmerge(options, overrideOptions);
106
+ }));
107
+ this.renderOptions$ = combineLatest([this.currentLanguage$]).pipe(map(([language]) => {
97
108
  const formioTranslations = this.translateService.instant('formioTranslations');
98
- const defaultOptions = {
99
- ...options,
109
+ return {
100
110
  language,
101
111
  ...(typeof formioTranslations === 'object'
102
112
  ? {
@@ -107,7 +117,6 @@ export class FormViewModelComponent {
107
117
  }
108
118
  : {}),
109
119
  };
110
- return deepmerge(defaultOptions, overrideOptions);
111
120
  }));
112
121
  }
113
122
  ngOnInit() {
@@ -118,20 +127,26 @@ export class FormViewModelComponent {
118
127
  this.loadInitialViewModel();
119
128
  }
120
129
  this.focusSubscription = this.focus$
121
- .pipe(withLatestFrom(this.change$))
122
- .subscribe(data => {
123
- const dataAtFocus = !!data[1] && !!data[1].data ? JSON.parse(JSON.stringify(data[1].data)) : null;
124
- this.blur$
125
- .pipe(take(1))
126
- .pipe(withLatestFrom(this.change$))
127
- .subscribe(dataBlur => {
128
- const dataEqual = isEqual(dataAtFocus, dataBlur[1]?.data);
129
- if (!dataEqual) {
130
- this.updateForm.next(true);
131
- }
130
+ .pipe(filter(e => {
131
+ // We only want to handle blur events after entering an input
132
+ return !!e && e.target instanceof HTMLInputElement;
133
+ }))
134
+ .subscribe(() => {
135
+ this.pendingUpdateSubscription?.unsubscribe();
136
+ this.blurSubscription?.unsubscribe();
137
+ this.blurSubscription = this.blur$
138
+ .pipe(filter(e => {
139
+ // Filter out events where relatedTarget is not null.
140
+ // The relatedTarget will be null when no new input is focused.
141
+ return !e.relatedTarget;
142
+ }))
143
+ .subscribe(() => {
144
+ this.blurSubscription?.unsubscribe();
145
+ this.setWaitCursor(true);
146
+ this.updateForm.next(true);
132
147
  });
133
148
  });
134
- this.updateSubscription = this.updateForm.pipe(filter(it => it), debounceTime(500)).subscribe(() => {
149
+ this.updateSubscription = this.updateForm.subscribe(() => {
135
150
  if (this.isStartForm$.value) {
136
151
  this.updateViewModelForStartForm();
137
152
  }
@@ -141,64 +156,71 @@ export class FormViewModelComponent {
141
156
  });
142
157
  }
143
158
  ngOnDestroy() {
144
- this.focusSubscription.unsubscribe();
145
- this.updateSubscription.unsubscribe();
159
+ this.blurSubscription?.unsubscribe();
160
+ this.focusSubscription?.unsubscribe();
161
+ this.updateSubscription?.unsubscribe();
162
+ this.pendingUpdateSubscription?.unsubscribe();
163
+ this.setWaitCursor(false);
146
164
  }
147
165
  beforeSubmitHook(instance) {
148
166
  return (submission, callback) => instance.beforeSubmit(submission, callback);
149
167
  }
150
168
  beforeSubmit(submission, callback) {
169
+ this.pendingUpdateSubscription?.unsubscribe();
170
+ this.setWaitCursor(false);
151
171
  combineLatest([
152
172
  this.formName$,
153
173
  this.taskInstanceId$,
154
174
  this.processDefinitionKey$,
155
175
  this.documentDefinitionName$,
156
176
  this.isStartForm$,
177
+ this.documentId$,
157
178
  ])
158
- .pipe(take(1), switchMap(([formName, taskInstanceId, processDefinitionKey, documentDefinitionName, isStartForm,]) => isStartForm
179
+ .pipe(take(1), switchMap(([formName, taskInstanceId, processDefinitionKey, documentDefinitionName, isStartForm, documentId,]) => isStartForm
159
180
  ? this.viewModelService
160
- .submitViewModelForStartForm(formName, processDefinitionKey, documentDefinitionName, submission.data)
161
- .pipe(take(1), switchMap(response => {
162
- callback(null, submission);
163
- return of(response);
164
- }), catchError(error => {
165
- this.handleFormError(error);
166
- callback({ message: ' ', component: null }, null);
167
- return EMPTY; // return an empty observable to complete the stream
168
- }))
181
+ .submitViewModelForStartForm(formName, processDefinitionKey, documentId, documentDefinitionName, submission.data)
169
182
  : this.viewModelService
170
- .submitViewModel(formName, taskInstanceId, submission.data)
171
- .pipe(take(1), switchMap(response => {
183
+ .submitViewModel(formName, taskInstanceId, submission.data)))
184
+ .subscribe({
185
+ next: _ => {
172
186
  callback(null, submission);
173
- return of(response);
174
- }), catchError(error => {
175
- this.handleFormError(error);
176
- callback({ message: ' ', component: null }, null);
177
- return EMPTY; // return an empty observable to complete the stream
178
- }))))
179
- .subscribe();
187
+ },
188
+ error: err => {
189
+ this.handleSubmissionError(err, callback);
190
+ }
191
+ });
192
+ }
193
+ handleSubmissionError(error, callback) {
194
+ callback({ message: '', component: null, silent: true }, null);
195
+ if (error instanceof HttpErrorResponse) {
196
+ this.handleFormError(error);
197
+ }
180
198
  }
181
199
  handleFormError(error) {
182
200
  const formInstance = this.formio.formio;
183
- this.errors = [];
184
- if (error.error.componentErrors) {
201
+ this.formErrors$.next([]);
202
+ if (error.error?.componentErrors) {
203
+ const errors = [];
185
204
  error.error.componentErrors.forEach(componentError => {
186
205
  const component = formInstance.getComponent(componentError.component);
187
206
  if (component == null) {
188
- this.errors.push(componentError.message);
207
+ errors.push(componentError.message);
189
208
  }
190
209
  else {
191
- component?.setCustomValidity(componentError.message);
210
+ // `true` makes the error dirty, setting the css class properly
211
+ component.setCustomValidity(componentError.message, true);
192
212
  }
193
213
  });
214
+ this.formErrors$.next(errors);
194
215
  }
195
- else {
216
+ else if (error.error?.error) {
196
217
  const component = formInstance.getComponent(error.error?.component);
197
218
  if (component == null) {
198
- this.errors.push(error.error.error);
219
+ this.formErrors$.next([error.error.error]);
199
220
  }
200
221
  else {
201
- component?.setCustomValidity(error.error.error);
222
+ // `true` makes the error dirty, setting the css class properly
223
+ component.setCustomValidity(error.error.error, true);
202
224
  }
203
225
  }
204
226
  }
@@ -247,36 +269,11 @@ export class FormViewModelComponent {
247
269
  }))))
248
270
  .subscribe();
249
271
  }
250
- updateViewModel() {
251
- this.loading$
252
- .pipe(take(1), switchMap(updating => {
253
- if (!updating) {
254
- this.loading$.next(true);
255
- return combineLatest([this.formName$, this.taskInstanceId$, this.change$]).pipe(take(1), switchMap(([formName, taskInstanceId, change]) => this.viewModelService
256
- .updateViewModel(formName, taskInstanceId, change.data, this.formio.formio.page, this._isWizard)
257
- .pipe(tap({
258
- next: viewModel => {
259
- const submission = this.submission$.value;
260
- submission.data = viewModel;
261
- this.submission$.next(submission);
262
- this.handlePageChange();
263
- this.refreshForm.emit({ submission: submission });
264
- this.loading$.next(false);
265
- this.errors = [];
266
- },
267
- error: error => {
268
- this.loading$.next(false);
269
- this.handleFormError(error);
270
- },
271
- }))));
272
- }
273
- return of(null); // Fallback to return an observable if updating is true
274
- }))
275
- .subscribe();
276
- }
277
272
  loadInitialViewModelForStartForm() {
278
- combineLatest([this.formName$, this.processDefinitionKey$])
279
- .pipe(take(1), switchMap(([formName, processDefinitionKey]) => this.viewModelService.getViewModelForStartForm(formName, processDefinitionKey).pipe(tap(viewModel => {
273
+ combineLatest([this.formName$, this.processDefinitionKey$, this.documentId$])
274
+ .pipe(take(1), switchMap(([formName, processDefinitionKey, documentId]) => this.viewModelService
275
+ .getViewModelForStartForm(formName, processDefinitionKey, documentId)
276
+ .pipe(tap(viewModel => {
280
277
  this.submission$.next({ data: viewModel });
281
278
  this.change$.pipe(take(1)).subscribe(() => {
282
279
  this.loading$.next(false);
@@ -285,39 +282,63 @@ export class FormViewModelComponent {
285
282
  }))))
286
283
  .subscribe();
287
284
  }
285
+ updateViewModel() {
286
+ this.pendingUpdateSubscription?.unsubscribe();
287
+ this.pendingUpdateSubscription = combineLatest([
288
+ this.formName$,
289
+ this.taskInstanceId$,
290
+ this.change$,
291
+ ])
292
+ .pipe(take(1), switchMap(([formName, taskInstanceId, change]) => this.viewModelService
293
+ .updateViewModel(formName, taskInstanceId, change.data, this.formio.formio.page, this._isWizard)
294
+ .pipe(tap({
295
+ next: viewModel => this.handleViewModelUpdate(viewModel),
296
+ error: error => this.handleViewModelUpdateError(error),
297
+ }))))
298
+ .subscribe();
299
+ }
288
300
  updateViewModelForStartForm() {
289
- this.loading$
290
- .pipe(take(1), switchMap(updating => {
291
- if (!updating) {
292
- this.loading$.next(true);
293
- return combineLatest([this.formName$, this.processDefinitionKey$, this.change$]).pipe(take(1), switchMap(([formName, processDefinitionKey, change]) => this.viewModelService
294
- .updateViewModelForStartForm(formName, processDefinitionKey, change.data, this.formio.formio.page, this._isWizard)
295
- .pipe(tap({
296
- next: viewModel => {
297
- const submission = this.submission$.value;
298
- submission.data = viewModel;
299
- this.submission$.next(submission);
300
- this.handlePageChange();
301
- this.refreshForm.emit({ submission: submission });
302
- this.loading$.next(false);
303
- this.errors = [];
304
- },
305
- error: error => {
306
- this.loading$.next(false);
307
- this.handleFormError(error);
308
- },
309
- }))));
310
- }
311
- return of(null); // Fallback to return an observable if updating is true
312
- }))
301
+ this.pendingUpdateSubscription?.unsubscribe();
302
+ this.pendingUpdateSubscription = combineLatest([
303
+ this.formName$,
304
+ this.processDefinitionKey$,
305
+ this.change$,
306
+ this.documentId$,
307
+ ])
308
+ .pipe(take(1), switchMap(([formName, processDefinitionKey, change, documentId]) => this.viewModelService
309
+ .updateViewModelForStartForm(formName, processDefinitionKey, documentId, change.data, this.formio.formio.page, this._isWizard)
310
+ .pipe(tap({
311
+ next: viewModel => this.handleViewModelUpdate(viewModel),
312
+ error: error => this.handleViewModelUpdateError(error),
313
+ }))))
313
314
  .subscribe();
314
315
  }
316
+ handleViewModelUpdate(viewModel) {
317
+ const submission = this.submission$.value;
318
+ submission.data = viewModel;
319
+ this.submission$.next(submission);
320
+ this.handlePageChange();
321
+ this.refreshForm.emit({ submission });
322
+ this.pendingUpdateSubscription?.unsubscribe();
323
+ this.pendingUpdateSubscription = null;
324
+ this.formErrors$.next([]);
325
+ this.setWaitCursor(false);
326
+ }
327
+ handleViewModelUpdateError(error) {
328
+ this.pendingUpdateSubscription?.unsubscribe();
329
+ this.pendingUpdateSubscription = null;
330
+ this.handleFormError(error);
331
+ this.setWaitCursor(false);
332
+ }
333
+ setWaitCursor(enabled) {
334
+ document.body.style.cursor = enabled ? 'wait' : 'auto';
335
+ }
315
336
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormViewModelComponent, deps: [{ token: i1.ViewModelService }, { token: i2.TranslateService }, { token: i3.FormIoStateService }], target: i0.ɵɵFactoryTarget.Component }); }
316
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormViewModelComponent, isStandalone: true, selector: "valtimo-form-view-model", inputs: { options: "options", submission: "submission", form: "form", formName: "formName", taskInstanceId: "taskInstanceId", isStartForm: "isStartForm", processDefinitionKey: "processDefinitionKey", documentDefinitionName: "documentDefinitionName" }, outputs: { formSubmit: "formSubmit" }, viewQueries: [{ propertyName: "formio", first: true, predicate: ["formio"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n class=\"form-container formio-carbon\"\n *ngIf=\"{\n submission: submission$ | async,\n form: form$ | async,\n tokenSetInLocalStorage: tokenSetInLocalStorage$ | async,\n formioOptions: formioOptions$ | async,\n loading: loading$ | async,\n } as obs\"\n>\n <div *ngIf=\"obs.loading\" class=\"overlay\">\n <div class=\"spinner\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n </div>\n\n <div *ngIf=\"errors.length > 0\" class=\"alert alert-danger pt-5 pb-5 mb-2\">\n <ol>\n <li *ngFor=\"let error of errors\" class=\"pl-2\">\n {{ error }}\n </li>\n </ol>\n </div>\n\n <formio\n #formio\n [submission]=\"obs.submission\"\n [form]=\"obs.form\"\n [options]=\"obs.formioOptions\"\n [refresh]=\"refreshForm\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n (focusin)=\"onFocus($event)\"\n (focusout)=\"onBlur($event)\"\n (nextPage)=\"onNextPage()\"\n (prevPage)=\"onPreviousPage()\"\n ></formio>\n</div>\n", styles: [".form-container{position:relative}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#fffc;z-index:1000;display:flex;justify-content:center;align-items:center;pointer-events:all}.spinner{font-size:3rem;color:#007bff}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormioModule }, { kind: "component", type: i5.FormioComponent, selector: "formio" }] }); }
337
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormViewModelComponent, isStandalone: true, selector: "valtimo-form-view-model", inputs: { options: "options", submission: "submission", form: "form", formName: "formName", taskInstanceId: "taskInstanceId", isStartForm: "isStartForm", documentId: "documentId", processDefinitionKey: "processDefinitionKey", documentDefinitionName: "documentDefinitionName" }, outputs: { formSubmit: "formSubmit" }, viewQueries: [{ propertyName: "formio", first: true, predicate: ["formio"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n class=\"form-container formio-carbon\"\n cdsLayer=\"1.0\"\n *ngIf=\"{\n submission: submission$ | async,\n form: form$ | async,\n tokenSetInLocalStorage: tokenSetInLocalStorage$ | async,\n formioOptions: formioOptions$ | async,\n loading: loading$ | async,\n errors: formErrors$ | async,\n renderOptions: renderOptions$ | async,\n } as obs\"\n>\n <div *ngIf=\"obs.loading\" class=\"overlay\">\n <div class=\"spinner\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n </div>\n\n <div *ngIf=\"obs.errors.length > 0\" class=\"alert alert-danger pt-5 pb-5 mb-2\">\n <ol>\n <li *ngFor=\"let error of obs.errors\" class=\"pl-2\">\n {{ error }}\n </li>\n </ol>\n </div>\n\n <formio\n #formio\n [submission]=\"obs.submission\"\n [form]=\"obs.form\"\n [options]=\"obs.formioOptions\"\n [renderOptions]=\"obs.renderOptions\"\n [refresh]=\"refreshForm\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n (focusin)=\"onFocus($event)\"\n (focusout)=\"onBlur($event)\"\n (nextPage)=\"onNextPage()\"\n (prevPage)=\"onPreviousPage()\"\n ></formio>\n</div>\n", styles: [".form-container{position:relative}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#fffc;z-index:1000;display:flex;justify-content:center;align-items:center;pointer-events:all}.spinner{font-size:3rem;color:#007bff}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormioModule }, { kind: "component", type: i5.FormioComponent, selector: "formio" }, { kind: "ngmodule", type: LayerModule }, { kind: "directive", type: i6.LayerDirective, selector: "[cdsLayer], [ibmLayer]", inputs: ["ibmLayer", "cdsLayer"], exportAs: ["layer"] }] }); }
317
338
  }
318
339
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormViewModelComponent, decorators: [{
319
340
  type: Component,
320
- args: [{ selector: 'valtimo-form-view-model', standalone: true, imports: [CommonModule, FormioModule], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n class=\"form-container formio-carbon\"\n *ngIf=\"{\n submission: submission$ | async,\n form: form$ | async,\n tokenSetInLocalStorage: tokenSetInLocalStorage$ | async,\n formioOptions: formioOptions$ | async,\n loading: loading$ | async,\n } as obs\"\n>\n <div *ngIf=\"obs.loading\" class=\"overlay\">\n <div class=\"spinner\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n </div>\n\n <div *ngIf=\"errors.length > 0\" class=\"alert alert-danger pt-5 pb-5 mb-2\">\n <ol>\n <li *ngFor=\"let error of errors\" class=\"pl-2\">\n {{ error }}\n </li>\n </ol>\n </div>\n\n <formio\n #formio\n [submission]=\"obs.submission\"\n [form]=\"obs.form\"\n [options]=\"obs.formioOptions\"\n [refresh]=\"refreshForm\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n (focusin)=\"onFocus($event)\"\n (focusout)=\"onBlur($event)\"\n (nextPage)=\"onNextPage()\"\n (prevPage)=\"onPreviousPage()\"\n ></formio>\n</div>\n", styles: [".form-container{position:relative}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#fffc;z-index:1000;display:flex;justify-content:center;align-items:center;pointer-events:all}.spinner{font-size:3rem;color:#007bff}\n"] }]
341
+ args: [{ selector: 'valtimo-form-view-model', standalone: true, imports: [CommonModule, FormioModule, LayerModule], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n class=\"form-container formio-carbon\"\n cdsLayer=\"1.0\"\n *ngIf=\"{\n submission: submission$ | async,\n form: form$ | async,\n tokenSetInLocalStorage: tokenSetInLocalStorage$ | async,\n formioOptions: formioOptions$ | async,\n loading: loading$ | async,\n errors: formErrors$ | async,\n renderOptions: renderOptions$ | async,\n } as obs\"\n>\n <div *ngIf=\"obs.loading\" class=\"overlay\">\n <div class=\"spinner\">\n <i class=\"fa fa-spinner fa-spin\"></i>\n </div>\n </div>\n\n <div *ngIf=\"obs.errors.length > 0\" class=\"alert alert-danger pt-5 pb-5 mb-2\">\n <ol>\n <li *ngFor=\"let error of obs.errors\" class=\"pl-2\">\n {{ error }}\n </li>\n </ol>\n </div>\n\n <formio\n #formio\n [submission]=\"obs.submission\"\n [form]=\"obs.form\"\n [options]=\"obs.formioOptions\"\n [renderOptions]=\"obs.renderOptions\"\n [refresh]=\"refreshForm\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n (focusin)=\"onFocus($event)\"\n (focusout)=\"onBlur($event)\"\n (nextPage)=\"onNextPage()\"\n (prevPage)=\"onPreviousPage()\"\n ></formio>\n</div>\n", styles: [".form-container{position:relative}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#fffc;z-index:1000;display:flex;justify-content:center;align-items:center;pointer-events:all}.spinner{font-size:3rem;color:#007bff}\n"] }]
321
342
  }], ctorParameters: () => [{ type: i1.ViewModelService }, { type: i2.TranslateService }, { type: i3.FormIoStateService }], propDecorators: { formio: [{
322
343
  type: ViewChild,
323
344
  args: ['formio']
@@ -333,6 +354,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
333
354
  type: Input
334
355
  }], isStartForm: [{
335
356
  type: Input
357
+ }], documentId: [{
358
+ type: Input
336
359
  }], processDefinitionKey: [{
337
360
  type: Input
338
361
  }], documentDefinitionName: [{
@@ -340,4 +363,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
340
363
  }], formSubmit: [{
341
364
  type: Output
342
365
  }] } });
343
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-view-model.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/form-view-model/src/lib/components/form-view-model/form-view-model.component.ts","../../../../../../../projects/valtimo/form-view-model/src/lib/components/form-view-model/form-view-model.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\nimport moment from 'moment';\nimport {\n  BehaviorSubject,\n  catchError,\n  combineLatest,\n  debounceTime,\n  EMPTY, filter,\n  Observable,\n  of, Subject, Subscription,\n  switchMap,\n  take,\n  tap, withLatestFrom,\n} from 'rxjs';\nimport {\n  FormioComponent,\n  FormioModule,\n  FormioOptions,\n  FormioSubmission,\n  FormioSubmissionCallback,\n} from '@formio/angular';\nimport {ViewModelService} from '../../services';\nimport {distinctUntilChanged, map} from 'rxjs/operators';\nimport {deepmerge} from 'deepmerge-ts';\nimport {FormIoStateService, ValtimoFormioOptions} from '@valtimo/components';\nimport {TranslateService} from '@ngx-translate/core';\nimport {HttpErrorResponse} from '@angular/common/http';\nimport {CommonModule} from '@angular/common';\nimport {isEqual} from 'lodash';\n\nmoment.defaultFormat = 'DD MMM YYYY HH:mm';\n\n@Component({\n  selector: 'valtimo-form-view-model',\n  templateUrl: './form-view-model.component.html',\n  styleUrls: ['./form-view-model.component.css'],\n  standalone: true,\n  imports: [CommonModule, FormioModule],\n})\nexport class FormViewModelComponent implements OnInit, OnDestroy {\n  @ViewChild('formio') formio: FormioComponent;\n\n  @Input() set options(optionsValue: any) {\n    this.options$.next(optionsValue);\n  }\n\n  @Input() set submission(submissionValue: FormioSubmission) {\n    this.submission$.next(submissionValue);\n  }\n\n  @Input() set form(formValue: object) {\n    const instance = this;\n    const form = {\n      loadInitialViewModel: () => instance.loadInitialViewModel(),\n      updateViewModel: () => instance.updateViewModel(),\n      ...formValue,\n    };\n    this.form$.next(form);\n  }\n\n  @Input() set formName(formName: string) {\n    this.formName$.next(formName);\n  }\n\n  @Input() set taskInstanceId(taskInstanceId: string) {\n    this.taskInstanceId$.next(taskInstanceId);\n  }\n\n  @Input() set isStartForm(isStartFormValue: boolean) {\n    this.isStartForm$.next(isStartFormValue);\n  }\n\n  @Input() set processDefinitionKey(processDefinitionKeyValue: string) {\n    this.processDefinitionKey$.next(processDefinitionKeyValue);\n  }\n\n  @Input() set documentDefinitionName(documentDefinitionNameValue: string) {\n    this.documentDefinitionName$.next(documentDefinitionNameValue);\n  }\n\n  @Output() formSubmit = new EventEmitter<any>();\n\n  public errors: string[] = [];\n  public refreshForm = new EventEmitter();\n\n  private _preventNextPage = false;\n  private _preventPreviousPage = false;\n  private _isWizard: boolean = false;\n\n  public readonly submission$ = new BehaviorSubject<any>({});\n  public readonly form$ = new BehaviorSubject<object>(undefined);\n  public readonly formName$ = new BehaviorSubject<string>(undefined);\n  public readonly options$ = new BehaviorSubject<ValtimoFormioOptions>(undefined);\n  public readonly taskInstanceId$ = new BehaviorSubject<string>(undefined);\n  public readonly tokenSetInLocalStorage$ = new BehaviorSubject<boolean>(false);\n  public readonly change$ = new BehaviorSubject<any>(null);\n  public readonly blur$ = new Subject<FocusEvent>();\n  public readonly focus$ = new BehaviorSubject<FocusEvent>(null);\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n  public readonly isStartForm$ = new BehaviorSubject<boolean>(false);\n  public readonly processDefinitionKey$ = new BehaviorSubject<string>(undefined);\n  public readonly documentDefinitionName$ = new BehaviorSubject<string>(undefined);\n  public readonly updateForm = new Subject<boolean>();\n\n  public readonly currentLanguage$ = this.translateService.stream('key').pipe(\n    map(() => this.translateService.currentLang),\n    distinctUntilChanged()\n  );\n\n  private readonly _overrideOptions$ = new BehaviorSubject<FormioOptions>({\n    hooks: {\n      beforeSubmit: this.beforeSubmitHook(this),\n    },\n  });\n\n  public readonly formioOptions$: Observable<ValtimoFormioOptions | FormioOptions> = combineLatest([\n    this.currentLanguage$,\n    this.options$,\n    this._overrideOptions$,\n  ]).pipe(\n    map(([language, options, overrideOptions]) => {\n      const formioTranslations = this.translateService.instant('formioTranslations');\n\n      const defaultOptions = {\n        ...options,\n        language,\n        ...(typeof formioTranslations === 'object'\n          ? {\n            language,\n            i18n: {\n              [language]: this.stateService.flattenTranslationsObject(formioTranslations),\n            },\n          }\n          : {}),\n      };\n\n      return deepmerge(defaultOptions, overrideOptions);\n    })\n  );\n\n  private focusSubscription: Subscription\n  private updateSubscription: Subscription\n\n  constructor(\n    private readonly viewModelService: ViewModelService,\n    private readonly translateService: TranslateService,\n    private readonly stateService: FormIoStateService\n  ) {}\n\n  public ngOnInit(): void {\n    if (this.isStartForm$.value) {\n      this.loadInitialViewModelForStartForm();\n    } else {\n      this.loadInitialViewModel();\n    }\n\n    this.focusSubscription = this.focus$\n      .pipe(withLatestFrom(this.change$))\n      .subscribe(data => {\n        const dataAtFocus = !!data[1] && !!data[1].data ? JSON.parse(JSON.stringify(data[1].data)) : null\n        this.blur$\n          .pipe(take(1))\n          .pipe(withLatestFrom(this.change$))\n          .subscribe(dataBlur => {\n            const dataEqual = isEqual(dataAtFocus, dataBlur[1]?.data)\n            if(!dataEqual) {\n              this.updateForm.next(true)\n            }\n          })\n      })\n\n    this.updateSubscription = this.updateForm.pipe(filter(it => it), debounceTime(500)).subscribe(() => {\n      if (this.isStartForm$.value) {\n        this.updateViewModelForStartForm();\n      } else {\n        this.updateViewModel();\n      }\n    })\n  }\n\n  public ngOnDestroy(): void {\n    this.focusSubscription.unsubscribe()\n    this.updateSubscription.unsubscribe()\n  }\n\n  public beforeSubmitHook(instance: FormViewModelComponent): (submission, callback) => void {\n    return (submission, callback) => instance.beforeSubmit(submission, callback);\n  }\n\n  public beforeSubmit(submission: any, callback: FormioSubmissionCallback): void {\n    combineLatest([\n      this.formName$,\n      this.taskInstanceId$,\n      this.processDefinitionKey$,\n      this.documentDefinitionName$,\n      this.isStartForm$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(\n          ([\n            formName,\n            taskInstanceId,\n            processDefinitionKey,\n            documentDefinitionName,\n            isStartForm,\n          ]) =>\n            isStartForm\n              ? this.viewModelService\n                  .submitViewModelForStartForm(\n                    formName,\n                    processDefinitionKey,\n                    documentDefinitionName,\n                    submission.data\n                  )\n                  .pipe(\n                    take(1),\n                    switchMap(response => {\n                      callback(null, submission);\n                      return of(response);\n                    }),\n                    catchError(error => {\n                      this.handleFormError(error);\n                      callback({message: ' ', component: null}, null);\n                      return EMPTY; // return an empty observable to complete the stream\n                    })\n                  )\n              : this.viewModelService\n                  .submitViewModel(formName, taskInstanceId, submission.data)\n                  .pipe(\n                    take(1),\n                    switchMap(response => {\n                      callback(null, submission);\n                      return of(response);\n                    }),\n                    catchError(error => {\n                      this.handleFormError(error);\n                      callback({message: ' ', component: null}, null);\n                      return EMPTY; // return an empty observable to complete the stream\n                    })\n                  )\n        )\n      )\n      .subscribe();\n  }\n\n  private handleFormError(error: HttpErrorResponse): void {\n    const formInstance = this.formio.formio;\n    this.errors = [];\n    if (error.error.componentErrors) {\n      error.error.componentErrors.forEach(componentError => {\n        const component = formInstance.getComponent(componentError.component);\n        if (component == null) {\n          this.errors.push(componentError.message);\n        } else {\n          component?.setCustomValidity(componentError.message);\n        }\n      });\n    } else {\n      const component = formInstance.getComponent(error.error?.component);\n      if (component == null) {\n        this.errors.push(error.error.error);\n      } else {\n        component?.setCustomValidity(error.error.error);\n      }\n    }\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    this.formSubmit.next(submission);\n  }\n\n  public onFocus($event: FocusEvent): void {\n    this.focus$.next($event);\n  }\n\n  public onBlur(blurEvent: FocusEvent): void {\n    this.blur$.next(blurEvent);\n  }\n\n  public onChange(object: any): void {\n    if (object.data) {\n      this.change$.next(object);\n    }\n  }\n\n  public onNextPage(): void {\n    this._preventNextPage = true;\n    this.formio.formio.setPage(this.formio.formio.page - 1);\n    this.updateForm.next(true);\n  }\n\n  public onPreviousPage(): void {\n    this._preventPreviousPage = true;\n    this.formio.formio.setPage(this.formio.formio.page + 1);\n    this.updateForm.next(true);\n  }\n\n  private handlePageChange(): void {\n    if (this._preventNextPage) {\n      this._preventNextPage = false;\n      this.formio.formio.setPage(this.formio.formio.page + 1);\n    } else if (this._preventPreviousPage) {\n      this._preventPreviousPage = false;\n      this.formio.formio.setPage(this.formio.formio.page - 1);\n    }\n  }\n\n  public loadInitialViewModel(): void {\n    combineLatest([this.formName$, this.taskInstanceId$])\n      .pipe(\n        take(1),\n        switchMap(([formName, taskInstanceId]) =>\n          this.viewModelService.getViewModel(formName, taskInstanceId).pipe(\n            tap(viewModel => {\n              this.submission$.next({data: viewModel});\n              this.change$.pipe(take(1)).subscribe(() => {\n                this.loading$.next(false);\n              });\n              this._isWizard = this.formio.form.display === 'wizard';\n            })\n          )\n        )\n      )\n      .subscribe();\n  }\n\n  public updateViewModel(): void {\n    this.loading$\n      .pipe(\n        take(1),\n        switchMap(updating => {\n          if (!updating) {\n            this.loading$.next(true);\n            return combineLatest([this.formName$, this.taskInstanceId$, this.change$]).pipe(\n              take(1),\n              switchMap(([formName, taskInstanceId, change]) =>\n                this.viewModelService\n                  .updateViewModel(\n                    formName,\n                    taskInstanceId,\n                    change.data,\n                    this.formio.formio.page,\n                    this._isWizard\n                  )\n                  .pipe(\n                    tap({\n                      next: viewModel => {\n                        const submission = this.submission$.value;\n                        submission.data = viewModel;\n                        this.submission$.next(submission);\n                        this.handlePageChange();\n                        this.refreshForm.emit({submission: submission});\n                        this.loading$.next(false);\n                        this.errors = [];\n                      },\n                      error: error => {\n                        this.loading$.next(false);\n                        this.handleFormError(error);\n                      },\n                    })\n                  )\n              )\n            );\n          }\n          return of(null); // Fallback to return an observable if updating is true\n        })\n      )\n      .subscribe();\n  }\n\n  public loadInitialViewModelForStartForm(): void {\n    combineLatest([this.formName$, this.processDefinitionKey$])\n      .pipe(\n        take(1),\n        switchMap(([formName, processDefinitionKey]) =>\n          this.viewModelService.getViewModelForStartForm(formName, processDefinitionKey).pipe(\n            tap(viewModel => {\n              this.submission$.next({data: viewModel});\n              this.change$.pipe(take(1)).subscribe(() => {\n                this.loading$.next(false);\n              });\n              this._isWizard = this.formio.form.display === 'wizard';\n            })\n          )\n        )\n      )\n      .subscribe();\n  }\n\n  public updateViewModelForStartForm(): void {\n    this.loading$\n      .pipe(\n        take(1),\n        switchMap(updating => {\n          if (!updating) {\n            this.loading$.next(true);\n            return combineLatest([this.formName$, this.processDefinitionKey$, this.change$]).pipe(\n              take(1),\n              switchMap(([formName, processDefinitionKey, change]) =>\n                this.viewModelService\n                  .updateViewModelForStartForm(\n                    formName,\n                    processDefinitionKey,\n                    change.data,\n                    this.formio.formio.page,\n                    this._isWizard\n                  )\n                  .pipe(\n                    tap({\n                      next: viewModel => {\n                        const submission = this.submission$.value;\n                        submission.data = viewModel;\n                        this.submission$.next(submission);\n                        this.handlePageChange();\n                        this.refreshForm.emit({submission: submission});\n                        this.loading$.next(false);\n                        this.errors = [];\n                      },\n                      error: error => {\n                        this.loading$.next(false);\n                        this.handleFormError(error);\n                      },\n                    })\n                  )\n              )\n            );\n          }\n          return of(null); // Fallback to return an observable if updating is true\n        })\n      )\n      .subscribe();\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  class=\"form-container formio-carbon\"\n  *ngIf=\"{\n    submission: submission$ | async,\n    form: form$ | async,\n    tokenSetInLocalStorage: tokenSetInLocalStorage$ | async,\n    formioOptions: formioOptions$ | async,\n    loading: loading$ | async,\n  } as obs\"\n>\n  <div *ngIf=\"obs.loading\" class=\"overlay\">\n    <div class=\"spinner\">\n      <i class=\"fa fa-spinner fa-spin\"></i>\n    </div>\n  </div>\n\n  <div *ngIf=\"errors.length > 0\" class=\"alert alert-danger pt-5 pb-5 mb-2\">\n    <ol>\n      <li *ngFor=\"let error of errors\" class=\"pl-2\">\n        {{ error }}\n      </li>\n    </ol>\n  </div>\n\n  <formio\n    #formio\n    [submission]=\"obs.submission\"\n    [form]=\"obs.form\"\n    [options]=\"obs.formioOptions\"\n    [refresh]=\"refreshForm\"\n    (submit)=\"onSubmit($event)\"\n    (change)=\"onChange($event)\"\n    (focusin)=\"onFocus($event)\"\n    (focusout)=\"onBlur($event)\"\n    (nextPage)=\"onNextPage()\"\n    (prevPage)=\"onPreviousPage()\"\n  ></formio>\n</div>\n"]}
366
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-view-model.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/form-view-model/src/lib/components/form-view-model/form-view-model.component.ts","../../../../../../../projects/valtimo/form-view-model/src/lib/components/form-view-model/form-view-model.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\nimport moment from 'moment';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  filter,\n  Observable,\n  Subject,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {\n  FormioComponent,\n  FormioModule,\n  FormioOptions,\n  FormioSubmission,\n  FormioSubmissionCallback,\n} from '@formio/angular';\nimport {ViewModelService} from '../../services';\nimport {distinctUntilChanged, map} from 'rxjs/operators';\nimport {deepmerge} from 'deepmerge-ts';\nimport {FormIoStateService, ValtimoFormioOptions} from '@valtimo/components';\nimport {TranslateService} from '@ngx-translate/core';\nimport {HttpErrorResponse} from '@angular/common/http';\nimport {CommonModule} from '@angular/common';\nimport {LayerModule} from 'carbon-components-angular';\n\nmoment.defaultFormat = 'DD MMM YYYY HH:mm';\n\n@Component({\n  selector: 'valtimo-form-view-model',\n  templateUrl: './form-view-model.component.html',\n  styleUrls: ['./form-view-model.component.css'],\n  standalone: true,\n  imports: [CommonModule, FormioModule, LayerModule],\n})\nexport class FormViewModelComponent implements OnInit, OnDestroy {\n  @ViewChild('formio') formio: FormioComponent;\n\n  @Input() set options(optionsValue: any) {\n    this.options$.next(optionsValue);\n  }\n\n  @Input() set submission(submissionValue: FormioSubmission) {\n    this.submission$.next(submissionValue);\n  }\n\n  @Input() set form(formValue: object) {\n    const instance = this;\n    const form = {\n      loadInitialViewModel: () => instance.loadInitialViewModel(),\n      updateViewModel: () => instance.updateViewModel(),\n      loadInitialStartFormViewModel: () => instance.loadInitialViewModelForStartForm(),\n      updateViewStartFormModel: () => instance.updateViewModelForStartForm(),\n      ...formValue,\n    };\n    this.form$.next(form);\n  }\n\n  @Input() set formName(formName: string) {\n    this.formName$.next(formName);\n  }\n\n  @Input() set taskInstanceId(taskInstanceId: string) {\n    this.taskInstanceId$.next(taskInstanceId);\n  }\n\n  @Input() set isStartForm(isStartFormValue: boolean) {\n    this.isStartForm$.next(isStartFormValue);\n  }\n\n  @Input() set documentId(documentId: string) {\n    this.documentId$.next(documentId);\n  }\n\n  @Input() set processDefinitionKey(processDefinitionKeyValue: string) {\n    this.processDefinitionKey$.next(processDefinitionKeyValue);\n  }\n\n  @Input() set documentDefinitionName(documentDefinitionNameValue: string) {\n    this.documentDefinitionName$.next(documentDefinitionNameValue);\n  }\n\n  @Output() formSubmit = new EventEmitter<any>();\n\n  public refreshForm = new EventEmitter();\n\n  private _preventNextPage = false;\n  private _preventPreviousPage = false;\n  private _isWizard: boolean = false;\n\n  public pendingUpdateSubscription: Subscription | null = null;\n\n  public readonly submission$ = new BehaviorSubject<any>({});\n  public readonly form$ = new BehaviorSubject<object>(undefined);\n  public readonly formName$ = new BehaviorSubject<string>(undefined);\n  public readonly formErrors$ = new BehaviorSubject<string[]>([]);\n  public readonly options$ = new BehaviorSubject<ValtimoFormioOptions>(undefined);\n  public readonly taskInstanceId$ = new BehaviorSubject<string>(undefined);\n  public readonly tokenSetInLocalStorage$ = new BehaviorSubject<boolean>(false);\n  public readonly change$ = new BehaviorSubject<any>(null);\n  public readonly blur$ = new Subject<FocusEvent>();\n  public readonly focus$ = new BehaviorSubject<FocusEvent>(null);\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n  public readonly isStartForm$ = new BehaviorSubject<boolean>(false);\n  public readonly documentId$ = new BehaviorSubject<string>(null);\n  public readonly processDefinitionKey$ = new BehaviorSubject<string>(undefined);\n  public readonly documentDefinitionName$ = new BehaviorSubject<string>(undefined);\n  public readonly updateForm = new Subject<boolean>();\n\n  public readonly currentLanguage$ = this.translateService.stream('key').pipe(\n    map(() => this.translateService.currentLang),\n    distinctUntilChanged()\n  );\n\n  private readonly _overrideOptions$ = new BehaviorSubject<FormioOptions>({\n    hooks: {\n      beforeSubmit: this.beforeSubmitHook(this),\n    },\n  });\n\n  public readonly formioOptions$: Observable<ValtimoFormioOptions | FormioOptions> = combineLatest([\n    this.options$,\n    this._overrideOptions$,\n  ]).pipe(\n    map(([options, overrideOptions]) => {\n      return deepmerge(options, overrideOptions);\n    })\n  );\n\n  public readonly renderOptions$: Observable<any> = combineLatest([this.currentLanguage$]).pipe(\n    map(([language]) => {\n      const formioTranslations = this.translateService.instant('formioTranslations');\n\n      return {\n        language,\n        ...(typeof formioTranslations === 'object'\n          ? {\n              language,\n              i18n: {\n                [language]: this.stateService.flattenTranslationsObject(formioTranslations),\n              },\n            }\n          : {}),\n      };\n    })\n  );\n\n  private focusSubscription: Subscription;\n  private blurSubscription: Subscription;\n  private updateSubscription: Subscription;\n\n  constructor(\n    private readonly viewModelService: ViewModelService,\n    private readonly translateService: TranslateService,\n    private readonly stateService: FormIoStateService\n  ) {}\n\n  public ngOnInit(): void {\n    if (this.isStartForm$.value) {\n      this.loadInitialViewModelForStartForm();\n    } else {\n      this.loadInitialViewModel();\n    }\n\n    this.focusSubscription = this.focus$\n      .pipe(\n        filter(e => {\n          // We only want to handle blur events after entering an input\n          return !!e && e.target instanceof HTMLInputElement;\n        })\n      )\n      .subscribe(() => {\n        this.pendingUpdateSubscription?.unsubscribe();\n        this.blurSubscription?.unsubscribe();\n        this.blurSubscription = this.blur$\n          .pipe(\n            filter(e => {\n              // Filter out events where relatedTarget is not null.\n              // The relatedTarget will be null when no new input is focused.\n              return !e.relatedTarget;\n            })\n          )\n          .subscribe(() => {\n            this.blurSubscription?.unsubscribe();\n            this.setWaitCursor(true);\n            this.updateForm.next(true);\n          });\n      });\n\n    this.updateSubscription = this.updateForm.subscribe(() => {\n      if (this.isStartForm$.value) {\n        this.updateViewModelForStartForm();\n      } else {\n        this.updateViewModel();\n      }\n    });\n  }\n\n  public ngOnDestroy(): void {\n    this.blurSubscription?.unsubscribe();\n    this.focusSubscription?.unsubscribe();\n    this.updateSubscription?.unsubscribe();\n    this.pendingUpdateSubscription?.unsubscribe();\n    this.setWaitCursor(false);\n  }\n\n  public beforeSubmitHook(instance: FormViewModelComponent): (submission, callback) => void {\n    return (submission, callback) => instance.beforeSubmit(submission, callback);\n  }\n\n  public beforeSubmit(submission: any, callback: FormioSubmissionCallback): void {\n    this.pendingUpdateSubscription?.unsubscribe();\n    this.setWaitCursor(false);\n\n    combineLatest([\n      this.formName$,\n      this.taskInstanceId$,\n      this.processDefinitionKey$,\n      this.documentDefinitionName$,\n      this.isStartForm$,\n      this.documentId$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(\n          ([\n            formName,\n            taskInstanceId,\n            processDefinitionKey,\n            documentDefinitionName,\n            isStartForm,\n            documentId,\n          ]) =>\n            isStartForm\n              ? this.viewModelService\n                  .submitViewModelForStartForm(\n                    formName,\n                    processDefinitionKey,\n                    documentId,\n                    documentDefinitionName,\n                    submission.data\n                  )\n              : this.viewModelService\n                  .submitViewModel(formName, taskInstanceId, submission.data)\n        )\n      )\n      .subscribe({\n        next: _ => {\n          callback(null, submission);\n        },\n        error: err => {\n          this.handleSubmissionError(err, callback);\n        }\n      });\n  }\n\n  private handleSubmissionError(error: any, callback: FormioSubmissionCallback): void {\n    callback({ message: '', component: null, silent: true }, null);\n\n    if (error instanceof HttpErrorResponse) {\n      this.handleFormError(error);\n    }\n  }\n\n  private handleFormError(error: HttpErrorResponse): void {\n    const formInstance = this.formio.formio;\n    this.formErrors$.next([]);\n    if (error.error?.componentErrors) {\n      const errors = [];\n      error.error.componentErrors.forEach(componentError => {\n        const component = formInstance.getComponent(componentError.component);\n        if (component == null) {\n          errors.push(componentError.message);\n        } else {\n          // `true` makes the error dirty, setting the css class properly\n          component.setCustomValidity(componentError.message, true);\n        }\n      });\n      this.formErrors$.next(errors);\n    } else if (error.error?.error) {\n      const component = formInstance.getComponent(error.error?.component);\n      if (component == null) {\n        this.formErrors$.next([error.error.error]);\n      } else {\n        // `true` makes the error dirty, setting the css class properly\n        component.setCustomValidity(error.error.error, true);\n      }\n    }\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    this.formSubmit.next(submission);\n  }\n\n  public onFocus($event: FocusEvent): void {\n    this.focus$.next($event);\n  }\n\n  public onBlur(blurEvent: FocusEvent): void {\n    this.blur$.next(blurEvent);\n  }\n\n  public onChange(object: any): void {\n    if (object.data) {\n      this.change$.next(object);\n    }\n  }\n\n  public onNextPage(): void {\n    this._preventNextPage = true;\n    this.formio.formio.setPage(this.formio.formio.page - 1);\n    this.updateForm.next(true);\n  }\n\n  public onPreviousPage(): void {\n    this._preventPreviousPage = true;\n    this.formio.formio.setPage(this.formio.formio.page + 1);\n    this.updateForm.next(true);\n  }\n\n  private handlePageChange(): void {\n    if (this._preventNextPage) {\n      this._preventNextPage = false;\n      this.formio.formio.setPage(this.formio.formio.page + 1);\n    } else if (this._preventPreviousPage) {\n      this._preventPreviousPage = false;\n      this.formio.formio.setPage(this.formio.formio.page - 1);\n    }\n  }\n\n  public loadInitialViewModel(): void {\n    combineLatest([this.formName$, this.taskInstanceId$])\n      .pipe(\n        take(1),\n        switchMap(([formName, taskInstanceId]) =>\n          this.viewModelService.getViewModel(formName, taskInstanceId).pipe(\n            tap(viewModel => {\n              this.submission$.next({data: viewModel});\n              this.change$.pipe(take(1)).subscribe(() => {\n                this.loading$.next(false);\n              });\n              this._isWizard = this.formio.form.display === 'wizard';\n            })\n          )\n        )\n      )\n      .subscribe();\n  }\n\n  public loadInitialViewModelForStartForm(): void {\n    combineLatest([this.formName$, this.processDefinitionKey$, this.documentId$])\n      .pipe(\n        take(1),\n        switchMap(([formName, processDefinitionKey, documentId]) =>\n          this.viewModelService\n            .getViewModelForStartForm(formName, processDefinitionKey, documentId)\n            .pipe(\n              tap(viewModel => {\n                this.submission$.next({data: viewModel});\n                this.change$.pipe(take(1)).subscribe(() => {\n                  this.loading$.next(false);\n                });\n                this._isWizard = this.formio.form.display === 'wizard';\n              })\n            )\n        )\n      )\n      .subscribe();\n  }\n\n  public updateViewModel(): void {\n    this.pendingUpdateSubscription?.unsubscribe();\n\n    this.pendingUpdateSubscription = combineLatest([\n      this.formName$,\n      this.taskInstanceId$,\n      this.change$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(([formName, taskInstanceId, change]) =>\n          this.viewModelService\n            .updateViewModel(\n              formName,\n              taskInstanceId,\n              change.data,\n              this.formio.formio.page,\n              this._isWizard\n            )\n            .pipe(\n              tap({\n                next: viewModel => this.handleViewModelUpdate(viewModel),\n                error: error => this.handleViewModelUpdateError(error),\n              })\n            )\n        )\n      )\n      .subscribe();\n  }\n\n  public updateViewModelForStartForm(): void {\n    this.pendingUpdateSubscription?.unsubscribe();\n\n    this.pendingUpdateSubscription = combineLatest([\n      this.formName$,\n      this.processDefinitionKey$,\n      this.change$,\n      this.documentId$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(([formName, processDefinitionKey, change, documentId]) =>\n          this.viewModelService\n            .updateViewModelForStartForm(\n              formName,\n              processDefinitionKey,\n              documentId,\n              change.data,\n              this.formio.formio.page,\n              this._isWizard\n            )\n            .pipe(\n              tap({\n                next: viewModel => this.handleViewModelUpdate(viewModel),\n                error: error => this.handleViewModelUpdateError(error),\n              })\n            )\n        )\n      )\n      .subscribe();\n  }\n\n  public handleViewModelUpdate(viewModel: object): void {\n    const submission = this.submission$.value;\n    submission.data = viewModel;\n    this.submission$.next(submission);\n    this.handlePageChange();\n    this.refreshForm.emit({submission});\n    this.pendingUpdateSubscription?.unsubscribe();\n    this.pendingUpdateSubscription = null;\n    this.formErrors$.next([]);\n    this.setWaitCursor(false);\n  }\n\n  public handleViewModelUpdateError(error: HttpErrorResponse): void {\n    this.pendingUpdateSubscription?.unsubscribe();\n    this.pendingUpdateSubscription = null;\n    this.handleFormError(error);\n    this.setWaitCursor(false);\n  }\n\n  private setWaitCursor(enabled: boolean): void {\n    document.body.style.cursor = enabled ? 'wait' : 'auto';\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  class=\"form-container formio-carbon\"\n  cdsLayer=\"1.0\"\n  *ngIf=\"{\n    submission: submission$ | async,\n    form: form$ | async,\n    tokenSetInLocalStorage: tokenSetInLocalStorage$ | async,\n    formioOptions: formioOptions$ | async,\n    loading: loading$ | async,\n    errors: formErrors$ | async,\n    renderOptions: renderOptions$ | async,\n  } as obs\"\n>\n  <div *ngIf=\"obs.loading\" class=\"overlay\">\n    <div class=\"spinner\">\n      <i class=\"fa fa-spinner fa-spin\"></i>\n    </div>\n  </div>\n\n  <div *ngIf=\"obs.errors.length > 0\" class=\"alert alert-danger pt-5 pb-5 mb-2\">\n    <ol>\n      <li *ngFor=\"let error of obs.errors\" class=\"pl-2\">\n        {{ error }}\n      </li>\n    </ol>\n  </div>\n\n  <formio\n    #formio\n    [submission]=\"obs.submission\"\n    [form]=\"obs.form\"\n    [options]=\"obs.formioOptions\"\n    [renderOptions]=\"obs.renderOptions\"\n    [refresh]=\"refreshForm\"\n    (submit)=\"onSubmit($event)\"\n    (change)=\"onChange($event)\"\n    (focusin)=\"onFocus($event)\"\n    (focusout)=\"onBlur($event)\"\n    (nextPage)=\"onNextPage()\"\n    (prevPage)=\"onPreviousPage()\"\n  ></formio>\n</div>\n"]}