@valtimo/form-view-model 12.6.1 → 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,17 +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, of, switchMap, take, tap, } 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';
24
+ import { LayerModule } from 'carbon-components-angular';
23
25
  import * as i0 from "@angular/core";
24
26
  import * as i1 from "../../services";
25
27
  import * as i2 from "@ngx-translate/core";
26
28
  import * as i3 from "@valtimo/components";
27
29
  import * as i4 from "@angular/common";
28
30
  import * as i5 from "@formio/angular";
31
+ import * as i6 from "carbon-components-angular";
29
32
  moment.defaultFormat = 'DD MMM YYYY HH:mm';
30
33
  export class FormViewModelComponent {
31
34
  set options(optionsValue) {
@@ -39,6 +42,8 @@ export class FormViewModelComponent {
39
42
  const form = {
40
43
  loadInitialViewModel: () => instance.loadInitialViewModel(),
41
44
  updateViewModel: () => instance.updateViewModel(),
45
+ loadInitialStartFormViewModel: () => instance.loadInitialViewModelForStartForm(),
46
+ updateViewStartFormModel: () => instance.updateViewModelForStartForm(),
42
47
  ...formValue,
43
48
  };
44
49
  this.form$.next(form);
@@ -52,6 +57,9 @@ export class FormViewModelComponent {
52
57
  set isStartForm(isStartFormValue) {
53
58
  this.isStartForm$.next(isStartFormValue);
54
59
  }
60
+ set documentId(documentId) {
61
+ this.documentId$.next(documentId);
62
+ }
55
63
  set processDefinitionKey(processDefinitionKeyValue) {
56
64
  this.processDefinitionKey$.next(processDefinitionKeyValue);
57
65
  }
@@ -63,23 +71,27 @@ export class FormViewModelComponent {
63
71
  this.translateService = translateService;
64
72
  this.stateService = stateService;
65
73
  this.formSubmit = new EventEmitter();
66
- this.errors = [];
67
74
  this.refreshForm = new EventEmitter();
68
75
  this._preventNextPage = false;
69
76
  this._preventPreviousPage = false;
70
77
  this._isWizard = false;
78
+ this.pendingUpdateSubscription = null;
71
79
  this.submission$ = new BehaviorSubject({});
72
80
  this.form$ = new BehaviorSubject(undefined);
73
81
  this.formName$ = new BehaviorSubject(undefined);
82
+ this.formErrors$ = new BehaviorSubject([]);
74
83
  this.options$ = new BehaviorSubject(undefined);
75
84
  this.taskInstanceId$ = new BehaviorSubject(undefined);
76
85
  this.tokenSetInLocalStorage$ = new BehaviorSubject(false);
77
86
  this.change$ = new BehaviorSubject(null);
78
- this.blur$ = new BehaviorSubject(null);
87
+ this.blur$ = new Subject();
88
+ this.focus$ = new BehaviorSubject(null);
79
89
  this.loading$ = new BehaviorSubject(true);
80
90
  this.isStartForm$ = new BehaviorSubject(false);
91
+ this.documentId$ = new BehaviorSubject(null);
81
92
  this.processDefinitionKey$ = new BehaviorSubject(undefined);
82
93
  this.documentDefinitionName$ = new BehaviorSubject(undefined);
94
+ this.updateForm = new Subject();
83
95
  this.currentLanguage$ = this.translateService.stream('key').pipe(map(() => this.translateService.currentLang), distinctUntilChanged());
84
96
  this._overrideOptions$ = new BehaviorSubject({
85
97
  hooks: {
@@ -87,21 +99,24 @@ export class FormViewModelComponent {
87
99
  },
88
100
  });
89
101
  this.formioOptions$ = combineLatest([
90
- this.currentLanguage$,
91
102
  this.options$,
92
103
  this._overrideOptions$,
93
- ]).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]) => {
94
108
  const formioTranslations = this.translateService.instant('formioTranslations');
95
- const defaultOptions = {
96
- ...options,
109
+ return {
97
110
  language,
98
- ...(formioTranslations === 'object' && {
99
- i18n: {
100
- [language]: this.stateService.flattenTranslationsObject(formioTranslations),
101
- },
102
- }),
111
+ ...(typeof formioTranslations === 'object'
112
+ ? {
113
+ language,
114
+ i18n: {
115
+ [language]: this.stateService.flattenTranslationsObject(formioTranslations),
116
+ },
117
+ }
118
+ : {}),
103
119
  };
104
- return deepmerge(defaultOptions, overrideOptions);
105
120
  }));
106
121
  }
107
122
  ngOnInit() {
@@ -111,71 +126,112 @@ export class FormViewModelComponent {
111
126
  else {
112
127
  this.loadInitialViewModel();
113
128
  }
129
+ this.focusSubscription = this.focus$
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);
147
+ });
148
+ });
149
+ this.updateSubscription = this.updateForm.subscribe(() => {
150
+ if (this.isStartForm$.value) {
151
+ this.updateViewModelForStartForm();
152
+ }
153
+ else {
154
+ this.updateViewModel();
155
+ }
156
+ });
157
+ }
158
+ ngOnDestroy() {
159
+ this.blurSubscription?.unsubscribe();
160
+ this.focusSubscription?.unsubscribe();
161
+ this.updateSubscription?.unsubscribe();
162
+ this.pendingUpdateSubscription?.unsubscribe();
163
+ this.setWaitCursor(false);
114
164
  }
115
165
  beforeSubmitHook(instance) {
116
166
  return (submission, callback) => instance.beforeSubmit(submission, callback);
117
167
  }
118
168
  beforeSubmit(submission, callback) {
169
+ this.pendingUpdateSubscription?.unsubscribe();
170
+ this.setWaitCursor(false);
119
171
  combineLatest([
120
172
  this.formName$,
121
173
  this.taskInstanceId$,
122
174
  this.processDefinitionKey$,
123
175
  this.documentDefinitionName$,
124
176
  this.isStartForm$,
177
+ this.documentId$,
125
178
  ])
126
- .pipe(take(1), switchMap(([formName, taskInstanceId, processDefinitionKey, documentDefinitionName, isStartForm,]) => isStartForm
179
+ .pipe(take(1), switchMap(([formName, taskInstanceId, processDefinitionKey, documentDefinitionName, isStartForm, documentId,]) => isStartForm
127
180
  ? this.viewModelService
128
- .submitViewModelForStartForm(formName, processDefinitionKey, documentDefinitionName, submission.data)
129
- .pipe(take(1), switchMap(response => {
130
- callback(null, submission);
131
- return of(response);
132
- }), catchError(error => {
133
- this.handleFormError(error);
134
- callback({ message: ' ', component: null }, null);
135
- return EMPTY; // return an empty observable to complete the stream
136
- }))
181
+ .submitViewModelForStartForm(formName, processDefinitionKey, documentId, documentDefinitionName, submission.data)
137
182
  : this.viewModelService
138
- .submitViewModel(formName, taskInstanceId, submission.data)
139
- .pipe(take(1), switchMap(response => {
183
+ .submitViewModel(formName, taskInstanceId, submission.data)))
184
+ .subscribe({
185
+ next: _ => {
140
186
  callback(null, submission);
141
- return of(response);
142
- }), catchError(error => {
143
- this.handleFormError(error);
144
- callback({ message: ' ', component: null }, null);
145
- return EMPTY; // return an empty observable to complete the stream
146
- }))))
147
- .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
+ }
148
198
  }
149
199
  handleFormError(error) {
150
200
  const formInstance = this.formio.formio;
151
- this.errors = [];
152
- if (error.error.componentErrors) {
201
+ this.formErrors$.next([]);
202
+ if (error.error?.componentErrors) {
203
+ const errors = [];
153
204
  error.error.componentErrors.forEach(componentError => {
154
205
  const component = formInstance.getComponent(componentError.component);
155
206
  if (component == null) {
156
- this.errors.push(componentError.message);
207
+ errors.push(componentError.message);
157
208
  }
158
209
  else {
159
- component?.setCustomValidity(componentError.message);
210
+ // `true` makes the error dirty, setting the css class properly
211
+ component.setCustomValidity(componentError.message, true);
160
212
  }
161
213
  });
214
+ this.formErrors$.next(errors);
162
215
  }
163
- else {
216
+ else if (error.error?.error) {
164
217
  const component = formInstance.getComponent(error.error?.component);
165
218
  if (component == null) {
166
- this.errors.push(error.error.error);
219
+ this.formErrors$.next([error.error.error]);
167
220
  }
168
221
  else {
169
- component?.setCustomValidity(error.error.error);
222
+ // `true` makes the error dirty, setting the css class properly
223
+ component.setCustomValidity(error.error.error, true);
170
224
  }
171
225
  }
172
226
  }
173
227
  onSubmit(submission) {
174
228
  this.formSubmit.next(submission);
175
229
  }
230
+ onFocus($event) {
231
+ this.focus$.next($event);
232
+ }
176
233
  onBlur(blurEvent) {
177
234
  this.blur$.next(blurEvent);
178
- this.handleChanges();
179
235
  }
180
236
  onChange(object) {
181
237
  if (object.data) {
@@ -185,12 +241,12 @@ export class FormViewModelComponent {
185
241
  onNextPage() {
186
242
  this._preventNextPage = true;
187
243
  this.formio.formio.setPage(this.formio.formio.page - 1);
188
- this.handleChanges();
244
+ this.updateForm.next(true);
189
245
  }
190
246
  onPreviousPage() {
191
247
  this._preventPreviousPage = true;
192
248
  this.formio.formio.setPage(this.formio.formio.page + 1);
193
- this.handleChanges();
249
+ this.updateForm.next(true);
194
250
  }
195
251
  handlePageChange() {
196
252
  if (this._preventNextPage) {
@@ -213,36 +269,11 @@ export class FormViewModelComponent {
213
269
  }))))
214
270
  .subscribe();
215
271
  }
216
- updateViewModel() {
217
- this.loading$
218
- .pipe(take(1), switchMap(updating => {
219
- if (!updating) {
220
- this.loading$.next(true);
221
- return combineLatest([this.formName$, this.taskInstanceId$, this.change$]).pipe(take(1), switchMap(([formName, taskInstanceId, change]) => this.viewModelService
222
- .updateViewModel(formName, taskInstanceId, change.data, this.formio.formio.page, this._isWizard)
223
- .pipe(tap({
224
- next: viewModel => {
225
- const submission = this.submission$.value;
226
- submission.data = viewModel;
227
- this.submission$.next(submission);
228
- this.handlePageChange();
229
- this.refreshForm.emit({ submission: submission });
230
- this.loading$.next(false);
231
- this.errors = [];
232
- },
233
- error: error => {
234
- this.loading$.next(false);
235
- this.handleFormError(error);
236
- },
237
- }))));
238
- }
239
- return of(null); // Fallback to return an observable if updating is true
240
- }))
241
- .subscribe();
242
- }
243
272
  loadInitialViewModelForStartForm() {
244
- combineLatest([this.formName$, this.processDefinitionKey$])
245
- .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 => {
246
277
  this.submission$.next({ data: viewModel });
247
278
  this.change$.pipe(take(1)).subscribe(() => {
248
279
  this.loading$.next(false);
@@ -251,49 +282,63 @@ export class FormViewModelComponent {
251
282
  }))))
252
283
  .subscribe();
253
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
+ }
254
300
  updateViewModelForStartForm() {
255
- this.loading$
256
- .pipe(take(1), switchMap(updating => {
257
- if (!updating) {
258
- this.loading$.next(true);
259
- return combineLatest([this.formName$, this.processDefinitionKey$, this.change$]).pipe(take(1), switchMap(([formName, processDefinitionKey, change]) => this.viewModelService
260
- .updateViewModelForStartForm(formName, processDefinitionKey, change.data, this.formio.formio.page, this._isWizard)
261
- .pipe(tap({
262
- next: viewModel => {
263
- const submission = this.submission$.value;
264
- submission.data = viewModel;
265
- this.submission$.next(submission);
266
- this.handlePageChange();
267
- this.refreshForm.emit({ submission: submission });
268
- this.loading$.next(false);
269
- this.errors = [];
270
- },
271
- error: error => {
272
- this.loading$.next(false);
273
- this.handleFormError(error);
274
- },
275
- }))));
276
- }
277
- return of(null); // Fallback to return an observable if updating is true
278
- }))
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
+ }))))
279
314
  .subscribe();
280
315
  }
281
- handleChanges() {
282
- this.blur$.pipe(debounceTime(500)).subscribe(() => {
283
- if (this.isStartForm$.value) {
284
- this.updateViewModelForStartForm();
285
- }
286
- else {
287
- this.updateViewModel();
288
- }
289
- });
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';
290
335
  }
291
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 }); }
292
- 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 (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"] }] }); }
293
338
  }
294
339
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormViewModelComponent, decorators: [{
295
340
  type: Component,
296
- 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 (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"] }]
297
342
  }], ctorParameters: () => [{ type: i1.ViewModelService }, { type: i2.TranslateService }, { type: i3.FormIoStateService }], propDecorators: { formio: [{
298
343
  type: ViewChild,
299
344
  args: ['formio']
@@ -309,6 +354,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
309
354
  type: Input
310
355
  }], isStartForm: [{
311
356
  type: Input
357
+ }], documentId: [{
358
+ type: Input
312
359
  }], processDefinitionKey: [{
313
360
  type: Input
314
361
  }], documentDefinitionName: [{
@@ -316,4 +363,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
316
363
  }], formSubmit: [{
317
364
  type: Output
318
365
  }] } });
319
- //# 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, OnInit, Output, ViewChild} from '@angular/core';\nimport moment from 'moment';\nimport {\n  BehaviorSubject,\n  catchError,\n  combineLatest,\n  debounceTime,\n  EMPTY,\n  Observable,\n  of,\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';\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 {\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 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\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        ...(formioTranslations === 'object' && {\n          i18n: {\n            [language]: this.stateService.flattenTranslationsObject(formioTranslations),\n          },\n        }),\n      };\n\n      return deepmerge(defaultOptions, overrideOptions);\n    })\n  );\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\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 onBlur(blurEvent: FocusEvent): void {\n    this.blur$.next(blurEvent);\n    this.handleChanges();\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.handleChanges();\n  }\n\n  public onPreviousPage(): void {\n    this._preventPreviousPage = true;\n    this.formio.formio.setPage(this.formio.formio.page + 1);\n    this.handleChanges();\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  private handleChanges(): void {\n    this.blur$.pipe(debounceTime(500)).subscribe(() => {\n      if (this.isStartForm$.value) {\n        this.updateViewModelForStartForm();\n      } else {\n        this.updateViewModel();\n      }\n    });\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    (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"]}