@valtimo/task 12.14.0 → 13.0.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.
Files changed (60) hide show
  1. package/fesm2022/valtimo-task.mjs +218 -173
  2. package/fesm2022/valtimo-task.mjs.map +1 -1
  3. package/lib/components/assign-user-to-task/assign-user-to-task.component.d.ts +1 -1
  4. package/lib/components/task-detail-content/task-detail-content.component.d.ts +3 -4
  5. package/lib/components/task-detail-content/task-detail-content.component.d.ts.map +1 -1
  6. package/lib/components/task-detail-intermediate-save/task-detail-intermediate-save.component.d.ts +5 -6
  7. package/lib/components/task-detail-intermediate-save/task-detail-intermediate-save.component.d.ts.map +1 -1
  8. package/lib/components/task-detail-modal/task-detail-modal.component.d.ts +10 -4
  9. package/lib/components/task-detail-modal/task-detail-modal.component.d.ts.map +1 -1
  10. package/lib/components/task-list/task-list.component.d.ts +8 -4
  11. package/lib/components/task-list/task-list.component.d.ts.map +1 -1
  12. package/lib/models/index.d.ts +1 -0
  13. package/lib/models/index.d.ts.map +1 -1
  14. package/lib/models/task-list.model.d.ts +2 -2
  15. package/lib/models/task-list.model.d.ts.map +1 -1
  16. package/lib/models/task-sse-event.model.d.ts +8 -0
  17. package/lib/models/task-sse-event.model.d.ts.map +1 -0
  18. package/lib/models/task.model.d.ts +1 -1
  19. package/lib/services/task-intermediate-save.service.d.ts +1 -1
  20. package/lib/services/task-intermediate-save.service.d.ts.map +1 -1
  21. package/lib/services/task-list-pagination.service.d.ts +1 -1
  22. package/lib/services/task-list-search.service.d.ts +1 -1
  23. package/lib/services/task-list-sort.service.d.ts +1 -1
  24. package/lib/services/task-list.service.d.ts +4 -7
  25. package/lib/services/task-list.service.d.ts.map +1 -1
  26. package/lib/services/task.service.d.ts +4 -4
  27. package/lib/services/task.service.d.ts.map +1 -1
  28. package/lib/task-permissions.d.ts +1 -1
  29. package/lib/task-permissions.d.ts.map +1 -1
  30. package/lib/task.module.d.ts +9 -10
  31. package/lib/task.module.d.ts.map +1 -1
  32. package/package.json +4 -7
  33. package/esm2022/lib/components/assign-user-to-task/assign-user-to-task.component.mjs +0 -210
  34. package/esm2022/lib/components/set-task-due-date/set-task-due-date.component.mjs +0 -128
  35. package/esm2022/lib/components/task-detail-content/task-detail-content.component.mjs +0 -398
  36. package/esm2022/lib/components/task-detail-intermediate-save/task-detail-intermediate-save.component.mjs +0 -168
  37. package/esm2022/lib/components/task-detail-modal/task-detail-modal.component.mjs +0 -151
  38. package/esm2022/lib/components/task-list/task-list.component.mjs +0 -361
  39. package/esm2022/lib/constants/index.mjs +0 -17
  40. package/esm2022/lib/constants/task-list.constants.mjs +0 -22
  41. package/esm2022/lib/models/index.mjs +0 -21
  42. package/esm2022/lib/models/task-definition.model.mjs +0 -17
  43. package/esm2022/lib/models/task-intermediate-save.model.mjs +0 -17
  44. package/esm2022/lib/models/task-list-search-field.model.mjs +0 -43
  45. package/esm2022/lib/models/task-list.model.mjs +0 -22
  46. package/esm2022/lib/models/task.model.mjs +0 -17
  47. package/esm2022/lib/services/index.mjs +0 -23
  48. package/esm2022/lib/services/task-intermediate-save.service.mjs +0 -73
  49. package/esm2022/lib/services/task-list-column.service.mjs +0 -193
  50. package/esm2022/lib/services/task-list-pagination.service.mjs +0 -74
  51. package/esm2022/lib/services/task-list-query-param.service.mjs +0 -53
  52. package/esm2022/lib/services/task-list-search.service.mjs +0 -99
  53. package/esm2022/lib/services/task-list-sort.service.mjs +0 -116
  54. package/esm2022/lib/services/task-list.service.mjs +0 -60
  55. package/esm2022/lib/services/task.service.mjs +0 -104
  56. package/esm2022/lib/task-permissions.mjs +0 -44
  57. package/esm2022/lib/task-routing.module.mjs +0 -45
  58. package/esm2022/lib/task.module.mjs +0 -158
  59. package/esm2022/public_api.mjs +0 -31
  60. package/esm2022/valtimo-task.mjs +0 -5
@@ -1,398 +0,0 @@
1
- /*
2
- * Copyright 2015-2024 Ritense BV, the Netherlands.
3
- *
4
- * Licensed under EUPL, Version 1.2 (the "License");
5
- * you may not use this file except in compliance with the License.
6
- * You may obtain a copy of the License at
7
- *
8
- * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
9
- *
10
- * Unless required by applicable law or agreed to in writing, software
11
- * distributed under the License is distributed on an "AS IS" basis,
12
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- * See the License for the specific language governing permissions and
14
- * limitations under the License.
15
- */
16
- import { CommonModule } from '@angular/common';
17
- import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output, ViewChild, ViewContainerRef, } from '@angular/core';
18
- import { RecentlyViewed16 } from '@carbon/icons';
19
- import { TranslateModule } from '@ngx-translate/core';
20
- import { FormIoModule, FormioOptionsImpl, } from '@valtimo/components';
21
- import { FORM_VIEW_MODEL_TOKEN } from '@valtimo/config';
22
- import { FORM_CUSTOM_COMPONENT_TOKEN, ProcessLinkModule, } from '@valtimo/process-link';
23
- import { BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, Subscription, switchMap, take, } from 'rxjs';
24
- import { CAN_ASSIGN_TASK_PERMISSION, TASK_DETAIL_PERMISSION_RESOURCE } from '../../task-permissions';
25
- import * as i0 from "@angular/core";
26
- import * as i1 from "@valtimo/config";
27
- import * as i2 from "@valtimo/document";
28
- import * as i3 from "carbon-components-angular";
29
- import * as i4 from "ngx-logger";
30
- import * as i5 from "@valtimo/components";
31
- import * as i6 from "@valtimo/access-control";
32
- import * as i7 from "@valtimo/process-link";
33
- import * as i8 from "@angular/router";
34
- import * as i9 from "../../services";
35
- import * as i10 from "ngx-toastr";
36
- import * as i11 from "@ngx-translate/core";
37
- import * as i12 from "@angular/common";
38
- export class TaskDetailContentComponent {
39
- set task(value) {
40
- if (!value)
41
- return;
42
- this.loadTaskDetails(value);
43
- }
44
- set taskAndProcessLink(value) {
45
- if (!value)
46
- return;
47
- this.loadTaskDetails(value.task, value.processLinkActivityResult);
48
- }
49
- set modalClosed(closed) {
50
- // save form flow data on modal closed
51
- if (this.formFlow)
52
- this.formFlow.saveData();
53
- if (closed) {
54
- this.closeModalEvent.emit();
55
- }
56
- }
57
- get viewInitialized$() {
58
- return this._viewInitialized$.pipe(filter(initialized => initialized));
59
- }
60
- constructor(configService, documentService, iconService, logger, modalService, permissionService, processLinkService, router, stateService, taskIntermediateSaveService, taskService, toastr, translateService, formViewModel, formCustomComponentConfig, urlResolverService) {
61
- this.configService = configService;
62
- this.documentService = documentService;
63
- this.iconService = iconService;
64
- this.logger = logger;
65
- this.modalService = modalService;
66
- this.permissionService = permissionService;
67
- this.processLinkService = processLinkService;
68
- this.router = router;
69
- this.stateService = stateService;
70
- this.taskIntermediateSaveService = taskIntermediateSaveService;
71
- this.taskService = taskService;
72
- this.toastr = toastr;
73
- this.translateService = translateService;
74
- this.formViewModel = formViewModel;
75
- this.formCustomComponentConfig = formCustomComponentConfig;
76
- this.urlResolverService = urlResolverService;
77
- this.closeModalEvent = new EventEmitter();
78
- this.formSubmit = new EventEmitter();
79
- this.activeChange = new EventEmitter();
80
- this.canAssignUserToTask$ = new BehaviorSubject(false);
81
- this.errorMessage$ = new BehaviorSubject(null);
82
- this.formDefinition$ = new BehaviorSubject(null);
83
- this.formDefinitionId$ = new BehaviorSubject(null);
84
- this.formFlowInstanceId$ = new BehaviorSubject(null);
85
- this.formioOptions$ = new BehaviorSubject(null);
86
- this.formIoFormData$ = new BehaviorSubject(null);
87
- this.formName$ = new BehaviorSubject(null);
88
- this.loading$ = new BehaviorSubject(true);
89
- this.page$ = new BehaviorSubject(null);
90
- this.submission$ = this.taskIntermediateSaveService.submission$;
91
- this.task$ = new BehaviorSubject(null);
92
- this.taskInstanceId$ = new BehaviorSubject(null);
93
- this.intermediateSaveEnabled = false;
94
- this._taskProcessLinkType$ = new BehaviorSubject(null);
95
- this.processLinkIsForm$ = this._taskProcessLinkType$.pipe(map((type) => type === 'form'));
96
- this.processLinkIsFormViewModel$ = this._taskProcessLinkType$.pipe(map((type) => type === 'form-view-model'));
97
- this.processLinkIsFormFlow$ = this._taskProcessLinkType$.pipe(map((type) => type === 'form-flow'));
98
- this.processLinkIsUiComponent$ = this._taskProcessLinkType$.pipe(map((type) => type === 'ui-component'));
99
- this._processLinkId$ = new BehaviorSubject(null);
100
- this._subscriptions = new Subscription();
101
- this._formCustomComponentConfig$ = new BehaviorSubject({});
102
- this._viewInitialized$ = new BehaviorSubject(false);
103
- this.intermediateSaveEnabled = !!this.configService.featureToggles?.enableIntermediateSave;
104
- this.iconService.registerAll([RecentlyViewed16]);
105
- const options = new FormioOptionsImpl();
106
- options.disableAlerts = true;
107
- this.formioOptions$.next(options);
108
- this._formCustomComponentConfig$.next(formCustomComponentConfig);
109
- }
110
- ngOnInit() {
111
- this.openPermissionSubscription();
112
- }
113
- ngOnDestroy() {
114
- this._subscriptions.unsubscribe();
115
- this.taskIntermediateSaveService.setSubmission({});
116
- this._viewInitialized$.next(false);
117
- }
118
- ngAfterViewInit() {
119
- this._viewInitialized$.next(true);
120
- }
121
- onSubmit(submission) {
122
- if (submission.data) {
123
- this.taskIntermediateSaveService.setFormIoFormData(submission.data);
124
- this.formIoFormData$.next(submission.data);
125
- }
126
- combineLatest([this._processLinkId$, this._taskProcessLinkType$, this.task$])
127
- .pipe(take(1))
128
- .subscribe(([processLinkId, taskProcessLinkType, task]) => {
129
- if (taskProcessLinkType === 'form') {
130
- if (processLinkId) {
131
- this.processLinkService
132
- .submitForm(processLinkId, submission.data, task?.businessKey, task?.id)
133
- .subscribe({
134
- next: (_) => {
135
- this.completeTask(task);
136
- },
137
- error: errors => {
138
- this.form.showErrors(errors);
139
- },
140
- });
141
- }
142
- }
143
- else if (taskProcessLinkType === 'form-view-model') {
144
- this.completeTask(task);
145
- }
146
- });
147
- }
148
- completeTask(task) {
149
- if (!task)
150
- return;
151
- this.toastr.success(`${task.name} ${this.translateService.instant('taskDetail.taskCompleted')}`);
152
- this.task$.next(null);
153
- this.formSubmit.emit();
154
- this.closeModalEvent.emit();
155
- this.activeChange.emit(false);
156
- if (this.formFlow)
157
- this.formFlow.saveData();
158
- }
159
- onChange(event) {
160
- if (event.data) {
161
- this.taskIntermediateSaveService.setFormIoFormData(event.data);
162
- this.formIoFormData$.next(event.data);
163
- this.activeChange.emit(true);
164
- }
165
- }
166
- onFormFlowChangeEvent() {
167
- this.activeChange.emit(true);
168
- }
169
- loadTaskDetails(task, processLink) {
170
- this.resetTaskProcessLinkType();
171
- this.resetFormDefinition();
172
- this.taskInstanceId$.next(task.id);
173
- if (!processLink) {
174
- this.getTaskProcessLink(task.id);
175
- }
176
- else {
177
- this.setTaskProcessLink(processLink);
178
- }
179
- this.setDocumentDefinitionNameInService(task);
180
- const documentId = task.businessKey;
181
- this.stateService.setDocumentId(documentId);
182
- this.task$.next(task);
183
- this.page$.next({
184
- title: task.name,
185
- subtitle: `${this.translateService.instant('taskDetail.taskCreated')} ${task.created}`,
186
- });
187
- }
188
- getCurrentProgress(formViewModelComponentRef) {
189
- this.taskInstanceId$
190
- .pipe(filter(value => !!value), take(1), switchMap((taskInstanceId) => this.taskIntermediateSaveService.getIntermediateSubmission(taskInstanceId ?? '')))
191
- .subscribe({
192
- next: (intermediateSubmission) => {
193
- this.taskIntermediateSaveService.setSubmission({
194
- data: intermediateSubmission?.submission || {},
195
- });
196
- if (formViewModelComponentRef) {
197
- formViewModelComponentRef.instance.submission = {
198
- data: intermediateSubmission.submission,
199
- };
200
- }
201
- },
202
- });
203
- }
204
- getTaskProcessLink(taskId) {
205
- this.taskService.getTaskProcessLink(taskId).subscribe({
206
- next: res => {
207
- this.setTaskProcessLink(res);
208
- },
209
- error: _ => {
210
- this.loading$.next(false);
211
- },
212
- });
213
- }
214
- setTaskProcessLink(processLinkResult) {
215
- if (processLinkResult !== null) {
216
- switch (processLinkResult?.type) {
217
- case 'form':
218
- this._taskProcessLinkType$.next('form');
219
- this._processLinkId$.next(processLinkResult.processLinkId);
220
- if (this.intermediateSaveEnabled)
221
- this.getCurrentProgress();
222
- this.setFormDefinition(processLinkResult.properties.prefilledForm);
223
- break;
224
- case 'form-flow':
225
- this._taskProcessLinkType$.next('form-flow');
226
- this.formFlowInstanceId$.next(processLinkResult.properties.formFlowInstanceId ?? '');
227
- break;
228
- case 'form-view-model':
229
- this._taskProcessLinkType$.next('form-view-model');
230
- this._processLinkId$.next(processLinkResult.processLinkId);
231
- this.formDefinition$.next(processLinkResult.properties.formDefinition);
232
- this.formName$.next(processLinkResult.properties.formName ?? '');
233
- this.setFormViewModelComponent();
234
- break;
235
- case 'url':
236
- this._taskProcessLinkType$.next('url');
237
- this._processLinkId$.next(processLinkResult.processLinkId);
238
- combineLatest([this.processLinkService.getVariables(), this.task$])
239
- .pipe(take(1))
240
- .subscribe(([variables, task]) => {
241
- let url = this.urlResolverService.resolveUrlVariables(processLinkResult.properties.url, variables.variables);
242
- window.open(url, '_blank').focus();
243
- this.processLinkService
244
- .submitURLProcessLink(processLinkResult.processLinkId, task.businessKey, task.id)
245
- .subscribe(() => {
246
- this.completeTask(task);
247
- });
248
- });
249
- break;
250
- case 'ui-component':
251
- this._taskProcessLinkType$.next('ui-component');
252
- this._processLinkId$.next(processLinkResult.processLinkId);
253
- this.formDefinition$.next(null);
254
- this.formName$.next('');
255
- this.setFormCustomComponent(processLinkResult.properties.componentKey);
256
- break;
257
- }
258
- this.loading$.next(false);
259
- }
260
- }
261
- openPermissionSubscription() {
262
- this._subscriptions.add(this.task$.subscribe(task => {
263
- if (task) {
264
- this.logger.debug('Checking if user allowed to assign a user to Task with id:', task.id);
265
- this.permissionService
266
- .requestPermission(CAN_ASSIGN_TASK_PERMISSION, {
267
- resource: TASK_DETAIL_PERMISSION_RESOURCE.task,
268
- identifier: task.id,
269
- })
270
- .subscribe((allowed) => {
271
- this.canAssignUserToTask$.next(allowed);
272
- });
273
- }
274
- else {
275
- this.logger.debug('Reset is user allowed to assign a user to Task as task is null');
276
- this.canAssignUserToTask$.next(false);
277
- }
278
- }));
279
- }
280
- setFormDefinition(formDefinition) {
281
- this._taskProcessLinkType$.next('form');
282
- this.formDefinition$.next(formDefinition);
283
- }
284
- setFormViewModelComponent() {
285
- combineLatest([this._viewInitialized$, this.processLinkIsFormViewModel$]).subscribe(([viewInitialized, isFvm]) => {
286
- if (viewInitialized && isFvm) {
287
- this.formViewModelDynamicContainer.clear();
288
- if (!this.formViewModel) {
289
- return;
290
- }
291
- const formViewModelComponent = this.formViewModelDynamicContainer.createComponent(this.formViewModel.component);
292
- formViewModelComponent.instance.form = this.formDefinition$.getValue();
293
- formViewModelComponent.instance.formName = this.formName$.getValue();
294
- formViewModelComponent.instance.taskInstanceId = this.taskInstanceId$.getValue();
295
- formViewModelComponent.instance.isStartForm = false;
296
- formViewModelComponent.instance.formSubmit
297
- .pipe(switchMap(() => this.task$), take(1))
298
- .subscribe((task) => {
299
- this.completeTask(task);
300
- });
301
- if (this.intermediateSaveEnabled) {
302
- this._subscriptions.add(formViewModelComponent.instance.submission$.subscribe(submission => {
303
- this.taskIntermediateSaveService.setSubmission(submission);
304
- }));
305
- this._subscriptions.add(this.submission$.pipe(distinctUntilChanged()).subscribe((submission) => {
306
- if (submission?.data && Object.keys(submission.data).length === 0) {
307
- formViewModelComponent.instance.submission = { data: {} };
308
- }
309
- }));
310
- this.getCurrentProgress(formViewModelComponent);
311
- }
312
- this._subscriptions.add(this.closeModalEvent.subscribe(() => {
313
- formViewModelComponent.destroy();
314
- }));
315
- }
316
- });
317
- }
318
- setFormCustomComponent(formCustomComponentKey) {
319
- combineLatest([this._viewInitialized$, this.processLinkIsUiComponent$]).subscribe(([viewInitialized, isUiComponent]) => {
320
- if (viewInitialized && isUiComponent) {
321
- this.formCustomComponentDynamicContainer.clear();
322
- if (!this.formCustomComponentConfig) {
323
- return;
324
- }
325
- let renderedComponent;
326
- this._subscriptions.add(this._formCustomComponentConfig$.subscribe(formCustomComponentConfig => {
327
- const customComponent = formCustomComponentConfig[formCustomComponentKey];
328
- renderedComponent = this.formCustomComponentDynamicContainer.createComponent(customComponent);
329
- renderedComponent.instance.taskInstanceId = this.taskInstanceId$.value;
330
- renderedComponent.instance.submittedEvent.subscribe(() => {
331
- this.closeModalEvent.emit();
332
- });
333
- }));
334
- this._subscriptions.add(this.closeModalEvent.subscribe(() => {
335
- renderedComponent.destroy();
336
- }));
337
- }
338
- });
339
- }
340
- resetFormDefinition() {
341
- this.formDefinition$.next(null);
342
- this.loading$.next(true);
343
- }
344
- resetTaskProcessLinkType() {
345
- this._taskProcessLinkType$.next(null);
346
- this._processLinkId$.next(null);
347
- }
348
- setDocumentDefinitionNameInService(task) {
349
- this.documentService
350
- .getProcessDocumentDefinitionFromProcessInstanceId(task.processInstanceId)
351
- .subscribe(processDocumentDefinition => {
352
- const documentDefinitionName = processDocumentDefinition.id.documentDefinitionId.name;
353
- this.modalService.setDocumentDefinitionName(documentDefinitionName);
354
- this.stateService.setDocumentDefinitionName(documentDefinitionName);
355
- });
356
- }
357
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TaskDetailContentComponent, deps: [{ token: i1.ConfigService }, { token: i2.DocumentService }, { token: i3.IconService }, { token: i4.NGXLogger }, { token: i5.ValtimoModalService }, { token: i6.PermissionService }, { token: i7.ProcessLinkService }, { token: i8.Router }, { token: i5.FormIoStateService }, { token: i9.TaskIntermediateSaveService }, { token: i9.TaskService }, { token: i10.ToastrService }, { token: i11.TranslateService }, { token: FORM_VIEW_MODEL_TOKEN, optional: true }, { token: FORM_CUSTOM_COMPONENT_TOKEN, optional: true }, { token: i7.UrlResolverService }], target: i0.ɵɵFactoryTarget.Component }); }
358
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TaskDetailContentComponent, isStandalone: true, selector: "valtimo-task-detail-content", inputs: { task: "task", taskAndProcessLink: "taskAndProcessLink", modalClosed: "modalClosed" }, outputs: { closeModalEvent: "closeModalEvent", formSubmit: "formSubmit", activeChange: "activeChange" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "formViewModelDynamicContainer", first: true, predicate: ["formViewModelComponent"], descendants: true, read: ViewContainerRef }, { propertyName: "formFlow", first: true, predicate: ["formFlow"], descendants: true }, { propertyName: "formCustomComponentDynamicContainer", first: true, predicate: ["formCustomComponent"], descendants: true, read: ViewContainerRef }], 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<ng-container\n *ngIf=\"{\n loading: loading$ | async,\n page: page$ | async,\n task: task$ | async,\n taskId: taskInstanceId$ | async,\n formDefinition: formDefinition$ | async,\n formDefinitionId: formDefinitionId$ | async,\n formName: formName$ | async,\n formIoFormData: formIoFormData$ | async,\n submission: submission$ | async,\n processLinkIsForm: processLinkIsForm$ | async,\n processLinkIsFormViewModel: processLinkIsFormViewModel$ | async,\n processLinkIsUiComponent: processLinkIsUiComponent$ | async,\n formioOptions: formioOptions$ | async,\n processLinkIsFormFlow: processLinkIsFormFlow$ | async,\n formFlowInstanceId: formFlowInstanceId$ | async,\n errorMessage: errorMessage$ | async,\n canAssignUserToTask: canAssignUserToTask$ | async,\n } as obs\"\n>\n <valtimo-form-io\n #form\n *ngIf=\"obs.formDefinition && obs.processLinkIsForm && !obs.processLinkIsUiComponent && !obs.processLinkIsFormViewModel\"\n [form]=\"obs.formDefinition\"\n [submission]=\"obs.submission\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n [options]=\"obs.formioOptions\"\n ></valtimo-form-io>\n\n <valtimo-form-flow\n #formFlow\n *ngIf=\"obs.processLinkIsFormFlow\"\n [formIoFormData]=\"formIoFormData$\"\n [formFlowInstanceId]=\"obs.formFlowInstanceId\"\n (formFlowComplete)=\"completeTask(obs.task)\"\n (formFlowChange)=\"onFormFlowChangeEvent()\"\n ></valtimo-form-flow>\n\n <div *ngIf=\"obs.loading\" class=\"text-black mb-0 p-3 text-center\">\n {{ 'formManagement.loading' | translate }}\n </div>\n\n <div\n *ngIf=\"\n obs.loading === false &&\n !obs.formDefinition &&\n !obs.formFlowInstanceId &&\n !obs.errorMessage &&\n !obs.processLinkIsUiComponent\n \"\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n >\n {{\n (isAdmin$ | async)\n ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n : ('formManagement.noFormDefinitionFoundUser' | translate)\n }}\n </div>\n\n <div *ngIf=\"obs.errorMessage\" class=\"bg-danger text-black mb-0 p-3 text-center\">\n {{ obs.errorMessage }}\n </div>\n\n <div class=\"m-2\">\n <ng-template #formViewModelComponent></ng-template>\n <ng-template #formCustomComponent></ng-template>\n </div>\n</ng-container>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i12.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormIoModule }, { kind: "component", type: i5.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i11.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: ProcessLinkModule }, { kind: "component", type: i7.FormFlowComponent, selector: "valtimo-form-flow", inputs: ["formIoFormData", "formFlowInstanceId"], outputs: ["formFlowComplete", "formFlowChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
359
- }
360
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TaskDetailContentComponent, decorators: [{
361
- type: Component,
362
- args: [{ selector: 'valtimo-task-detail-content', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [CommonModule, FormIoModule, TranslateModule, ProcessLinkModule], 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<ng-container\n *ngIf=\"{\n loading: loading$ | async,\n page: page$ | async,\n task: task$ | async,\n taskId: taskInstanceId$ | async,\n formDefinition: formDefinition$ | async,\n formDefinitionId: formDefinitionId$ | async,\n formName: formName$ | async,\n formIoFormData: formIoFormData$ | async,\n submission: submission$ | async,\n processLinkIsForm: processLinkIsForm$ | async,\n processLinkIsFormViewModel: processLinkIsFormViewModel$ | async,\n processLinkIsUiComponent: processLinkIsUiComponent$ | async,\n formioOptions: formioOptions$ | async,\n processLinkIsFormFlow: processLinkIsFormFlow$ | async,\n formFlowInstanceId: formFlowInstanceId$ | async,\n errorMessage: errorMessage$ | async,\n canAssignUserToTask: canAssignUserToTask$ | async,\n } as obs\"\n>\n <valtimo-form-io\n #form\n *ngIf=\"obs.formDefinition && obs.processLinkIsForm && !obs.processLinkIsUiComponent && !obs.processLinkIsFormViewModel\"\n [form]=\"obs.formDefinition\"\n [submission]=\"obs.submission\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n [options]=\"obs.formioOptions\"\n ></valtimo-form-io>\n\n <valtimo-form-flow\n #formFlow\n *ngIf=\"obs.processLinkIsFormFlow\"\n [formIoFormData]=\"formIoFormData$\"\n [formFlowInstanceId]=\"obs.formFlowInstanceId\"\n (formFlowComplete)=\"completeTask(obs.task)\"\n (formFlowChange)=\"onFormFlowChangeEvent()\"\n ></valtimo-form-flow>\n\n <div *ngIf=\"obs.loading\" class=\"text-black mb-0 p-3 text-center\">\n {{ 'formManagement.loading' | translate }}\n </div>\n\n <div\n *ngIf=\"\n obs.loading === false &&\n !obs.formDefinition &&\n !obs.formFlowInstanceId &&\n !obs.errorMessage &&\n !obs.processLinkIsUiComponent\n \"\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n >\n {{\n (isAdmin$ | async)\n ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n : ('formManagement.noFormDefinitionFoundUser' | translate)\n }}\n </div>\n\n <div *ngIf=\"obs.errorMessage\" class=\"bg-danger text-black mb-0 p-3 text-center\">\n {{ obs.errorMessage }}\n </div>\n\n <div class=\"m-2\">\n <ng-template #formViewModelComponent></ng-template>\n <ng-template #formCustomComponent></ng-template>\n </div>\n</ng-container>\n" }]
363
- }], ctorParameters: () => [{ type: i1.ConfigService }, { type: i2.DocumentService }, { type: i3.IconService }, { type: i4.NGXLogger }, { type: i5.ValtimoModalService }, { type: i6.PermissionService }, { type: i7.ProcessLinkService }, { type: i8.Router }, { type: i5.FormIoStateService }, { type: i9.TaskIntermediateSaveService }, { type: i9.TaskService }, { type: i10.ToastrService }, { type: i11.TranslateService }, { type: undefined, decorators: [{
364
- type: Optional
365
- }, {
366
- type: Inject,
367
- args: [FORM_VIEW_MODEL_TOKEN]
368
- }] }, { type: undefined, decorators: [{
369
- type: Optional
370
- }, {
371
- type: Inject,
372
- args: [FORM_CUSTOM_COMPONENT_TOKEN]
373
- }] }, { type: i7.UrlResolverService }], propDecorators: { form: [{
374
- type: ViewChild,
375
- args: ['form']
376
- }], formViewModelDynamicContainer: [{
377
- type: ViewChild,
378
- args: ['formViewModelComponent', { static: false, read: ViewContainerRef }]
379
- }], formFlow: [{
380
- type: ViewChild,
381
- args: ['formFlow']
382
- }], formCustomComponentDynamicContainer: [{
383
- type: ViewChild,
384
- args: ['formCustomComponent', { static: false, read: ViewContainerRef }]
385
- }], task: [{
386
- type: Input
387
- }], taskAndProcessLink: [{
388
- type: Input
389
- }], modalClosed: [{
390
- type: Input
391
- }], closeModalEvent: [{
392
- type: Output
393
- }], formSubmit: [{
394
- type: Output
395
- }], activeChange: [{
396
- type: Output
397
- }] } });
398
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-detail-content.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/task/src/lib/components/task-detail-content/task-detail-content.component.ts","../../../../../../../projects/valtimo/task/src/lib/components/task-detail-content/task-detail-content.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 {CommonModule} from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ComponentRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {RecentlyViewed16} from '@carbon/icons';\nimport {FormioForm} from '@formio/angular';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {PermissionService} from '@valtimo/access-control';\nimport {\n  FormioComponent,\n  FormIoModule,\n  FormioOptionsImpl,\n  FormIoStateService,\n  FormioSubmission,\n  ValtimoFormioOptions,\n  ValtimoModalService,\n} from '@valtimo/components';\nimport {ConfigService, FORM_VIEW_MODEL_TOKEN, FormViewModel} from '@valtimo/config';\nimport {DocumentService} from '@valtimo/document';\nimport {\n  FORM_CUSTOM_COMPONENT_TOKEN,\n  FormCustomComponent,\n  FormCustomComponentConfig,\n  FormFlowComponent,\n  FormSubmissionResult,\n  ProcessLinkModule,\n  ProcessLinkService,\n  TaskProcessLinkResult,\n  TaskProcessLinkType,\n  TaskWithProcessLink,\n  UrlResolverService,\n} from '@valtimo/process-link';\nimport {IconService} from 'carbon-components-angular';\nimport {NGXLogger} from 'ngx-logger';\nimport {ToastrService} from 'ngx-toastr';\nimport {BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, Observable, Subscription, switchMap, take,} from 'rxjs';\nimport {IntermediateSubmission, Task} from '../../models';\nimport {TaskIntermediateSaveService, TaskService} from '../../services';\nimport {CAN_ASSIGN_TASK_PERMISSION, TASK_DETAIL_PERMISSION_RESOURCE} from '../../task-permissions';\n\n@Component({\n  selector: 'valtimo-task-detail-content',\n  templateUrl: './task-detail-content.component.html',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CommonModule, FormIoModule, TranslateModule, ProcessLinkModule],\n})\nexport class TaskDetailContentComponent implements OnInit, OnDestroy, AfterViewInit {\n  @ViewChild('form') form: FormioComponent;\n  @ViewChild('formViewModelComponent', {static: false, read: ViewContainerRef})\n  public formViewModelDynamicContainer: ViewContainerRef;\n  @ViewChild('formFlow') public formFlow: FormFlowComponent;\n  @ViewChild('formCustomComponent', {static: false, read: ViewContainerRef})\n  public formCustomComponentDynamicContainer: ViewContainerRef;\n  @Input() public set task(value: Task | null) {\n    if (!value) return;\n\n    this.loadTaskDetails(value);\n  }\n  @Input() public set taskAndProcessLink(value: TaskWithProcessLink | null) {\n    if (!value) return;\n\n    this.loadTaskDetails(value.task as any, value.processLinkActivityResult);\n  }\n  @Input() public set modalClosed(closed: boolean) {\n    // save form flow data on modal closed\n    if (this.formFlow) this.formFlow.saveData();\n\n    if (closed) {\n      this.closeModalEvent.emit();\n    }\n  }\n  @Output() public readonly closeModalEvent = new EventEmitter();\n  @Output() public readonly formSubmit = new EventEmitter();\n  @Output() public readonly activeChange = new EventEmitter<boolean>();\n\n  public readonly canAssignUserToTask$ = new BehaviorSubject<boolean>(false);\n  public readonly errorMessage$ = new BehaviorSubject<string | null>(null);\n  public readonly formDefinition$ = new BehaviorSubject<FormioForm | null>(null);\n  public readonly formDefinitionId$ = new BehaviorSubject<string | null>(null);\n  public readonly formFlowInstanceId$ = new BehaviorSubject<string | null>(null);\n  public readonly formioOptions$ = new BehaviorSubject<ValtimoFormioOptions | null>(null);\n  public readonly formIoFormData$ = new BehaviorSubject<any>(null);\n  public readonly formName$ = new BehaviorSubject<string | null>(null);\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n  public readonly page$ = new BehaviorSubject<any>(null);\n  public readonly submission$ = this.taskIntermediateSaveService.submission$;\n  public readonly task$ = new BehaviorSubject<Task | null>(null);\n  public readonly taskInstanceId$ = new BehaviorSubject<string | null>(null);\n  public intermediateSaveEnabled = false;\n\n  private readonly _taskProcessLinkType$ = new BehaviorSubject<TaskProcessLinkType | null>(null);\n  public readonly processLinkIsForm$ = this._taskProcessLinkType$.pipe(\n    map((type: string | null) => type === 'form')\n  );\n  public readonly processLinkIsFormViewModel$ = this._taskProcessLinkType$.pipe(\n    map((type: string | null) => type === 'form-view-model')\n  );\n  public readonly processLinkIsFormFlow$ = this._taskProcessLinkType$.pipe(\n    map((type: string | null) => type === 'form-flow')\n  );\n  public readonly processLinkIsUiComponent$ = this._taskProcessLinkType$.pipe(\n    map((type: string | null) => type === 'ui-component')\n  );\n\n  private readonly _processLinkId$ = new BehaviorSubject<string | null>(null);\n  private readonly _subscriptions = new Subscription();\n  private readonly _formCustomComponentConfig$ = new BehaviorSubject<\n    FormCustomComponentConfig | {}\n  >({});\n\n  private readonly _viewInitialized$ = new BehaviorSubject<boolean>(false);\n\n  public get viewInitialized$(): Observable<boolean> {\n    return this._viewInitialized$.pipe(filter(initialized => initialized));\n  }\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly documentService: DocumentService,\n    private readonly iconService: IconService,\n    private readonly logger: NGXLogger,\n    private readonly modalService: ValtimoModalService,\n    private readonly permissionService: PermissionService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly router: Router,\n    private readonly stateService: FormIoStateService,\n    private readonly taskIntermediateSaveService: TaskIntermediateSaveService,\n    private readonly taskService: TaskService,\n    private readonly toastr: ToastrService,\n    private readonly translateService: TranslateService,\n    @Optional() @Inject(FORM_VIEW_MODEL_TOKEN) private readonly formViewModel: FormViewModel,\n    @Optional() @Inject(FORM_CUSTOM_COMPONENT_TOKEN) private readonly formCustomComponentConfig: FormCustomComponentConfig,\n    private readonly urlResolverService: UrlResolverService\n  ) {\n    this.intermediateSaveEnabled = !!this.configService.featureToggles?.enableIntermediateSave;\n\n    this.iconService.registerAll([RecentlyViewed16]);\n\n    const options = new FormioOptionsImpl();\n    options.disableAlerts = true;\n    this.formioOptions$.next(options);\n    this._formCustomComponentConfig$.next(formCustomComponentConfig);\n  }\n  public ngOnInit(): void {\n    this.openPermissionSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n    this.taskIntermediateSaveService.setSubmission({});\n    this._viewInitialized$.next(false);\n  }\n\n  public ngAfterViewInit(): void {\n    this._viewInitialized$.next(true);\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    if (submission.data) {\n      this.taskIntermediateSaveService.setFormIoFormData(submission.data);\n      this.formIoFormData$.next(submission.data);\n    }\n\n    combineLatest([this._processLinkId$, this._taskProcessLinkType$, this.task$])\n      .pipe(take(1))\n      .subscribe(([processLinkId, taskProcessLinkType, task]) => {\n        if (taskProcessLinkType === 'form') {\n          if (processLinkId) {\n            this.processLinkService\n              .submitForm(processLinkId, submission.data, task?.businessKey, task?.id)\n              .subscribe({\n                next: (_: FormSubmissionResult) => {\n                  this.completeTask(task);\n                },\n                error: errors => {\n                  this.form.showErrors(errors);\n                },\n              });\n          }\n        } else if (taskProcessLinkType === 'form-view-model') {\n          this.completeTask(task);\n        }\n      });\n  }\n\n  public completeTask(task: Task | null): void {\n    if (!task) return;\n\n    this.toastr.success(\n      `${task.name} ${this.translateService.instant('taskDetail.taskCompleted')}`\n    );\n    this.task$.next(null);\n    this.formSubmit.emit();\n    this.closeModalEvent.emit();\n    this.activeChange.emit(false);\n\n    if (this.formFlow) this.formFlow.saveData();\n  }\n\n  public onChange(event: any): void {\n    if (event.data) {\n      this.taskIntermediateSaveService.setFormIoFormData(event.data);\n      this.formIoFormData$.next(event.data);\n      this.activeChange.emit(true);\n    }\n  }\n\n  public onFormFlowChangeEvent(): void {\n    this.activeChange.emit(true);\n  }\n\n  private loadTaskDetails(task: Task, processLink?: TaskProcessLinkResult): void {\n    this.resetTaskProcessLinkType();\n    this.resetFormDefinition();\n\n    this.taskInstanceId$.next(task.id);\n\n    if (!processLink) {\n      this.getTaskProcessLink(task.id);\n    } else {\n      this.setTaskProcessLink(processLink);\n    }\n\n    this.setDocumentDefinitionNameInService(task);\n    const documentId = task.businessKey;\n    this.stateService.setDocumentId(documentId);\n\n    this.task$.next(task);\n    this.page$.next({\n      title: task.name,\n      subtitle: `${this.translateService.instant('taskDetail.taskCreated')} ${task.created}`,\n    });\n  }\n\n  private getCurrentProgress(formViewModelComponentRef?: ComponentRef<any>): void {\n    this.taskInstanceId$\n      .pipe(\n        filter(value => !!value),\n        take(1),\n        switchMap((taskInstanceId: string | null) =>\n          this.taskIntermediateSaveService.getIntermediateSubmission(taskInstanceId ?? '')\n        )\n      )\n      .subscribe({\n        next: (intermediateSubmission: IntermediateSubmission) => {\n          this.taskIntermediateSaveService.setSubmission({\n            data: intermediateSubmission?.submission || {},\n          });\n\n          if (formViewModelComponentRef) {\n            formViewModelComponentRef.instance.submission = {\n              data: intermediateSubmission.submission,\n            };\n          }\n        },\n      });\n  }\n\n  private getTaskProcessLink(taskId: string): void {\n    this.taskService.getTaskProcessLink(taskId).subscribe({\n      next: res => {\n        this.setTaskProcessLink(res);\n      },\n      error: _ => {\n        this.loading$.next(false);\n      },\n    });\n  }\n\n  private setTaskProcessLink(processLinkResult: TaskProcessLinkResult | null): void {\n    if (processLinkResult !== null) {\n      switch (processLinkResult?.type) {\n        case 'form':\n          this._taskProcessLinkType$.next('form');\n          this._processLinkId$.next(processLinkResult.processLinkId);\n          if (this.intermediateSaveEnabled) this.getCurrentProgress();\n          this.setFormDefinition(processLinkResult.properties.prefilledForm);\n          break;\n        case 'form-flow':\n          this._taskProcessLinkType$.next('form-flow');\n          this.formFlowInstanceId$.next(processLinkResult.properties.formFlowInstanceId ?? '');\n          break;\n        case 'form-view-model':\n          this._taskProcessLinkType$.next('form-view-model');\n          this._processLinkId$.next(processLinkResult.processLinkId);\n          this.formDefinition$.next(processLinkResult.properties.formDefinition);\n          this.formName$.next(processLinkResult.properties.formName ?? '');\n          this.setFormViewModelComponent();\n          break;\n        case 'url':\n          this._taskProcessLinkType$.next('url');\n          this._processLinkId$.next(processLinkResult.processLinkId);\n          combineLatest([this.processLinkService.getVariables(), this.task$])\n            .pipe(take(1))\n            .subscribe(([variables, task]) => {\n              let url = this.urlResolverService.resolveUrlVariables(\n                processLinkResult.properties.url,\n                variables.variables\n              );\n              window.open(url, '_blank').focus();\n              this.processLinkService\n                .submitURLProcessLink(processLinkResult.processLinkId, task.businessKey, task.id)\n                .subscribe(() => {\n                  this.completeTask(task);\n                });\n            });\n          break;\n        case 'ui-component':\n          this._taskProcessLinkType$.next('ui-component');\n          this._processLinkId$.next(processLinkResult.processLinkId);\n          this.formDefinition$.next(null);\n          this.formName$.next('');\n          this.setFormCustomComponent(processLinkResult.properties.componentKey);\n          break;\n      }\n\n      this.loading$.next(false);\n    }\n  }\n\n  private openPermissionSubscription(): void {\n    this._subscriptions.add(\n      this.task$.subscribe(task => {\n        if (task) {\n          this.logger.debug('Checking if user allowed to assign a user to Task with id:', task.id);\n          this.permissionService\n            .requestPermission(CAN_ASSIGN_TASK_PERMISSION, {\n              resource: TASK_DETAIL_PERMISSION_RESOURCE.task,\n              identifier: task.id,\n            })\n            .subscribe((allowed: boolean) => {\n              this.canAssignUserToTask$.next(allowed);\n            });\n        } else {\n          this.logger.debug('Reset is user allowed to assign a user to Task as task is null');\n          this.canAssignUserToTask$.next(false);\n        }\n      })\n    );\n  }\n\n  private setFormDefinition(formDefinition: any): void {\n    this._taskProcessLinkType$.next('form');\n    this.formDefinition$.next(formDefinition);\n  }\n\n  private setFormViewModelComponent() {\n    combineLatest([this._viewInitialized$, this.processLinkIsFormViewModel$]).subscribe(\n      ([viewInitialized, isFvm]) => {\n        if (viewInitialized && isFvm) {\n          this.formViewModelDynamicContainer.clear();\n          if (!this.formViewModel) {\n            return;\n          }\n          const formViewModelComponent = this.formViewModelDynamicContainer.createComponent(\n            this.formViewModel.component\n          );\n          formViewModelComponent.instance.form = this.formDefinition$.getValue();\n          formViewModelComponent.instance.formName = this.formName$.getValue();\n          formViewModelComponent.instance.taskInstanceId = this.taskInstanceId$.getValue();\n          formViewModelComponent.instance.isStartForm = false;\n\n          formViewModelComponent.instance.formSubmit\n            .pipe(\n              switchMap(() => this.task$),\n              take(1)\n            )\n            .subscribe((task: Task | null) => {\n              this.completeTask(task);\n            });\n\n          if (this.intermediateSaveEnabled) {\n            this._subscriptions.add(\n              formViewModelComponent.instance.submission$.subscribe(submission => {\n                this.taskIntermediateSaveService.setSubmission(submission);\n              })\n            );\n            this._subscriptions.add(\n              this.submission$.pipe(distinctUntilChanged()).subscribe((submission?) => {\n                if (submission?.data && Object.keys(submission.data).length === 0) {\n                  formViewModelComponent.instance.submission = {data: {}};\n                }\n              })\n            );\n            this.getCurrentProgress(formViewModelComponent);\n          }\n\n          this._subscriptions.add(\n            this.closeModalEvent.subscribe(() => {\n              formViewModelComponent.destroy();\n            })\n          );\n        }\n      }\n    );\n  }\n\n  private setFormCustomComponent(formCustomComponentKey: string): void {\n    combineLatest([this._viewInitialized$, this.processLinkIsUiComponent$]).subscribe(\n      ([viewInitialized, isUiComponent]) => {\n        if (viewInitialized && isUiComponent) {\n          this.formCustomComponentDynamicContainer.clear();\n          if (!this.formCustomComponentConfig) {\n            return;\n          }\n          let renderedComponent:ComponentRef<FormCustomComponent>;\n          this._subscriptions.add(\n            this._formCustomComponentConfig$.subscribe(formCustomComponentConfig => {\n              const customComponent = formCustomComponentConfig[formCustomComponentKey];\n              renderedComponent = this.formCustomComponentDynamicContainer.createComponent(\n                customComponent\n              ) as ComponentRef<FormCustomComponent>;\n\n              renderedComponent.instance.taskInstanceId = this.taskInstanceId$.value;\n              renderedComponent.instance.submittedEvent.subscribe(() => {\n                this.closeModalEvent.emit();\n              });\n            })\n          );\n          this._subscriptions.add(\n            this.closeModalEvent.subscribe(() => {\n              renderedComponent.destroy();\n            })\n          );\n        }\n      }\n    );\n  }\n\n  private resetFormDefinition(): void {\n    this.formDefinition$.next(null);\n    this.loading$.next(true);\n  }\n\n  private resetTaskProcessLinkType(): void {\n    this._taskProcessLinkType$.next(null);\n    this._processLinkId$.next(null);\n  }\n\n  private setDocumentDefinitionNameInService(task: Task): void {\n    this.documentService\n      .getProcessDocumentDefinitionFromProcessInstanceId(task.processInstanceId)\n      .subscribe(processDocumentDefinition => {\n        const documentDefinitionName = processDocumentDefinition.id.documentDefinitionId.name;\n        this.modalService.setDocumentDefinitionName(documentDefinitionName);\n        this.stateService.setDocumentDefinitionName(documentDefinitionName);\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<ng-container\n  *ngIf=\"{\n    loading: loading$ | async,\n    page: page$ | async,\n    task: task$ | async,\n    taskId: taskInstanceId$ | async,\n    formDefinition: formDefinition$ | async,\n    formDefinitionId: formDefinitionId$ | async,\n    formName: formName$ | async,\n    formIoFormData: formIoFormData$ | async,\n    submission: submission$ | async,\n    processLinkIsForm: processLinkIsForm$ | async,\n    processLinkIsFormViewModel: processLinkIsFormViewModel$ | async,\n    processLinkIsUiComponent: processLinkIsUiComponent$ | async,\n    formioOptions: formioOptions$ | async,\n    processLinkIsFormFlow: processLinkIsFormFlow$ | async,\n    formFlowInstanceId: formFlowInstanceId$ | async,\n    errorMessage: errorMessage$ | async,\n    canAssignUserToTask: canAssignUserToTask$ | async,\n  } as obs\"\n>\n  <valtimo-form-io\n    #form\n    *ngIf=\"obs.formDefinition && obs.processLinkIsForm && !obs.processLinkIsUiComponent && !obs.processLinkIsFormViewModel\"\n    [form]=\"obs.formDefinition\"\n    [submission]=\"obs.submission\"\n    (submit)=\"onSubmit($event)\"\n    (change)=\"onChange($event)\"\n    [options]=\"obs.formioOptions\"\n  ></valtimo-form-io>\n\n  <valtimo-form-flow\n    #formFlow\n    *ngIf=\"obs.processLinkIsFormFlow\"\n    [formIoFormData]=\"formIoFormData$\"\n    [formFlowInstanceId]=\"obs.formFlowInstanceId\"\n    (formFlowComplete)=\"completeTask(obs.task)\"\n    (formFlowChange)=\"onFormFlowChangeEvent()\"\n  ></valtimo-form-flow>\n\n  <div *ngIf=\"obs.loading\" class=\"text-black mb-0 p-3 text-center\">\n    {{ 'formManagement.loading' | translate }}\n  </div>\n\n  <div\n    *ngIf=\"\n      obs.loading === false &&\n      !obs.formDefinition &&\n      !obs.formFlowInstanceId &&\n      !obs.errorMessage &&\n      !obs.processLinkIsUiComponent\n    \"\n    class=\"bg-warning text-black mb-0 p-3 text-center\"\n  >\n    {{\n      (isAdmin$ | async)\n        ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n        : ('formManagement.noFormDefinitionFoundUser' | translate)\n    }}\n  </div>\n\n  <div *ngIf=\"obs.errorMessage\" class=\"bg-danger text-black mb-0 p-3 text-center\">\n    {{ obs.errorMessage }}\n  </div>\n\n  <div class=\"m-2\">\n    <ng-template #formViewModelComponent></ng-template>\n    <ng-template #formCustomComponent></ng-template>\n  </div>\n</ng-container>\n"]}