@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.
- package/fesm2022/valtimo-task.mjs +218 -173
- package/fesm2022/valtimo-task.mjs.map +1 -1
- package/lib/components/assign-user-to-task/assign-user-to-task.component.d.ts +1 -1
- package/lib/components/task-detail-content/task-detail-content.component.d.ts +3 -4
- package/lib/components/task-detail-content/task-detail-content.component.d.ts.map +1 -1
- package/lib/components/task-detail-intermediate-save/task-detail-intermediate-save.component.d.ts +5 -6
- package/lib/components/task-detail-intermediate-save/task-detail-intermediate-save.component.d.ts.map +1 -1
- package/lib/components/task-detail-modal/task-detail-modal.component.d.ts +10 -4
- package/lib/components/task-detail-modal/task-detail-modal.component.d.ts.map +1 -1
- package/lib/components/task-list/task-list.component.d.ts +8 -4
- package/lib/components/task-list/task-list.component.d.ts.map +1 -1
- package/lib/models/index.d.ts +1 -0
- package/lib/models/index.d.ts.map +1 -1
- package/lib/models/task-list.model.d.ts +2 -2
- package/lib/models/task-list.model.d.ts.map +1 -1
- package/lib/models/task-sse-event.model.d.ts +8 -0
- package/lib/models/task-sse-event.model.d.ts.map +1 -0
- package/lib/models/task.model.d.ts +1 -1
- package/lib/services/task-intermediate-save.service.d.ts +1 -1
- package/lib/services/task-intermediate-save.service.d.ts.map +1 -1
- package/lib/services/task-list-pagination.service.d.ts +1 -1
- package/lib/services/task-list-search.service.d.ts +1 -1
- package/lib/services/task-list-sort.service.d.ts +1 -1
- package/lib/services/task-list.service.d.ts +4 -7
- package/lib/services/task-list.service.d.ts.map +1 -1
- package/lib/services/task.service.d.ts +4 -4
- package/lib/services/task.service.d.ts.map +1 -1
- package/lib/task-permissions.d.ts +1 -1
- package/lib/task-permissions.d.ts.map +1 -1
- package/lib/task.module.d.ts +9 -10
- package/lib/task.module.d.ts.map +1 -1
- package/package.json +4 -7
- package/esm2022/lib/components/assign-user-to-task/assign-user-to-task.component.mjs +0 -210
- package/esm2022/lib/components/set-task-due-date/set-task-due-date.component.mjs +0 -128
- package/esm2022/lib/components/task-detail-content/task-detail-content.component.mjs +0 -398
- package/esm2022/lib/components/task-detail-intermediate-save/task-detail-intermediate-save.component.mjs +0 -168
- package/esm2022/lib/components/task-detail-modal/task-detail-modal.component.mjs +0 -151
- package/esm2022/lib/components/task-list/task-list.component.mjs +0 -361
- package/esm2022/lib/constants/index.mjs +0 -17
- package/esm2022/lib/constants/task-list.constants.mjs +0 -22
- package/esm2022/lib/models/index.mjs +0 -21
- package/esm2022/lib/models/task-definition.model.mjs +0 -17
- package/esm2022/lib/models/task-intermediate-save.model.mjs +0 -17
- package/esm2022/lib/models/task-list-search-field.model.mjs +0 -43
- package/esm2022/lib/models/task-list.model.mjs +0 -22
- package/esm2022/lib/models/task.model.mjs +0 -17
- package/esm2022/lib/services/index.mjs +0 -23
- package/esm2022/lib/services/task-intermediate-save.service.mjs +0 -73
- package/esm2022/lib/services/task-list-column.service.mjs +0 -193
- package/esm2022/lib/services/task-list-pagination.service.mjs +0 -74
- package/esm2022/lib/services/task-list-query-param.service.mjs +0 -53
- package/esm2022/lib/services/task-list-search.service.mjs +0 -99
- package/esm2022/lib/services/task-list-sort.service.mjs +0 -116
- package/esm2022/lib/services/task-list.service.mjs +0 -60
- package/esm2022/lib/services/task.service.mjs +0 -104
- package/esm2022/lib/task-permissions.mjs +0 -44
- package/esm2022/lib/task-routing.module.mjs +0 -45
- package/esm2022/lib/task.module.mjs +0 -158
- package/esm2022/public_api.mjs +0 -31
- 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"]}
|