@valtimo/task 11.0.0 → 11.1.2

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.
@@ -16,49 +16,52 @@
16
16
  import { Component, EventEmitter, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
17
17
  import { FormioOptionsImpl, } from '@valtimo/components';
18
18
  import moment from 'moment';
19
- import { BehaviorSubject, distinctUntilChanged, map, Subscription, tap } from 'rxjs';
20
- import { CAN_ASSIGN_TASK_PERMISSION, TASK_DETAIL_PERMISSION_RESOURCE } from '../task-permissions';
19
+ import { map, take } from 'rxjs/operators';
20
+ import { BehaviorSubject, combineLatest, distinctUntilChanged, Subscription, tap, } from 'rxjs';
21
21
  import * as i0 from "@angular/core";
22
- import * as i1 from "@valtimo/document";
23
- import * as i2 from "@valtimo/components";
24
- import * as i3 from "@valtimo/access-control";
25
- import * as i4 from "@valtimo/form-link";
26
- import * as i5 from "@angular/router";
27
- import * as i6 from "../task.service";
28
- import * as i7 from "ngx-toastr";
22
+ import * as i1 from "ngx-toastr";
23
+ import * as i2 from "@valtimo/form-link";
24
+ import * as i3 from "@angular/router";
25
+ import * as i4 from "../task.service";
26
+ import * as i5 from "@valtimo/security";
27
+ import * as i6 from "@valtimo/components";
28
+ import * as i7 from "@valtimo/document";
29
29
  import * as i8 from "@ngx-translate/core";
30
- import * as i9 from "@valtimo/security";
31
- import * as i10 from "@angular/common";
32
- import * as i11 from "../assign-user-to-task/assign-user-to-task.component";
30
+ import * as i9 from "@angular/common";
31
+ import * as i10 from "../assign-user-to-task/assign-user-to-task.component";
33
32
  moment.locale(localStorage.getItem('langKey') || '');
34
33
  export class TaskDetailModalComponent {
35
- constructor(documentService, modalService, permissionService, processLinkService, router, stateService, taskService, toastr, translateService, userProviderService) {
36
- this.documentService = documentService;
37
- this.modalService = modalService;
38
- this.permissionService = permissionService;
34
+ constructor(toastr, processLinkService, router, taskService, userProviderService, modalService, stateService, documentService, translateService) {
35
+ this.toastr = toastr;
39
36
  this.processLinkService = processLinkService;
40
37
  this.router = router;
41
- this.stateService = stateService;
42
38
  this.taskService = taskService;
43
- this.toastr = toastr;
44
- this.translateService = translateService;
45
39
  this.userProviderService = userProviderService;
40
+ this.modalService = modalService;
41
+ this.stateService = stateService;
42
+ this.documentService = documentService;
43
+ this.translateService = translateService;
46
44
  this.formSubmit = new EventEmitter();
47
45
  this.assignmentOfTaskChanged = new EventEmitter();
48
- this.errorMessage = null;
49
- this.formIoFormData$ = new BehaviorSubject(null);
50
- this.page = null;
51
- this.task = null;
52
- this._taskProcessLinkType$ = new BehaviorSubject(null);
53
- this.processLinkIsForm$ = this._taskProcessLinkType$.pipe(map(type => type === 'form'));
54
- this.processLinkIsFormFlow$ = this._taskProcessLinkType$.pipe(map(type => type === 'form-flow'));
46
+ this.task$ = new BehaviorSubject(null);
47
+ this.formDefinition$ = new BehaviorSubject(undefined);
48
+ this.formFlowInstanceId$ = new BehaviorSubject(undefined);
49
+ this.page$ = new BehaviorSubject(null);
50
+ this.formioOptions$ = new BehaviorSubject(null);
51
+ this.errorMessage$ = new BehaviorSubject(undefined);
55
52
  this.isAdmin$ = this.userProviderService
56
53
  .getUserSubject()
57
54
  .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));
55
+ this.formIoFormData$ = new BehaviorSubject(null);
58
56
  this.loading$ = new BehaviorSubject(true);
57
+ this.taskProcessLinkType$ = new BehaviorSubject(null);
58
+ this.processLinkIsForm$ = this.taskProcessLinkType$.pipe(map(type => type === 'form'));
59
+ this.processLinkIsFormFlow$ = this.taskProcessLinkType$.pipe(map(type => type === 'form-flow'));
60
+ this.processLinkId$ = new BehaviorSubject(undefined);
59
61
  this._subscriptions = new Subscription();
60
- this.formioOptions = new FormioOptionsImpl();
61
- this.formioOptions.disableAlerts = true;
62
+ const options = new FormioOptionsImpl();
63
+ options.disableAlerts = true;
64
+ this.formioOptions$.next(options);
62
65
  }
63
66
  ngAfterViewInit() {
64
67
  this._subscriptions.add(this.modal.modalShowing$
@@ -75,21 +78,19 @@ export class TaskDetailModalComponent {
75
78
  this._subscriptions.unsubscribe();
76
79
  }
77
80
  openTaskDetails(task) {
78
- this.canAssign$ = this.permissionService.requestPermission(CAN_ASSIGN_TASK_PERMISSION, {
79
- resource: TASK_DETAIL_PERMISSION_RESOURCE.task,
80
- identifier: task.id,
81
- });
82
81
  this.resetTaskProcessLinkType();
83
82
  this.resetFormDefinition();
84
83
  this.getTaskProcessLink(task.id);
85
84
  this.setDocumentDefinitionNameInService(task);
86
- this.stateService.setDocumentId(task.businessKey);
87
- this.task = task;
88
- this.page = {
85
+ const documentId = task.businessKey;
86
+ this.stateService.setDocumentId(documentId);
87
+ this.task$.next(task);
88
+ this.page$.next({
89
89
  title: task.name,
90
90
  subtitle: `${this.translateService.instant('taskDetail.taskCreated')} ${task.created}`,
91
- };
92
- if (!this._taskProcessLinkType$.getValue()) {
91
+ });
92
+ //only load from formlink when process link failed for backwards compatibility
93
+ if (!this.taskProcessLinkType$.getValue()) {
93
94
  this.modal.show();
94
95
  }
95
96
  }
@@ -102,31 +103,39 @@ export class TaskDetailModalComponent {
102
103
  this.formIoFormData$.next(event.data);
103
104
  }
104
105
  }
105
- completeTask() {
106
- this.toastr.success(`${this.task?.name} ${this.translateService.instant('taskDetail.taskCompleted')}`);
107
- this.modal.hide();
108
- this.task = null;
109
- this.formSubmit.emit();
110
- }
111
106
  onSubmit(submission) {
112
107
  if (submission.data) {
113
108
  this.formIoFormData$.next(submission.data);
114
109
  }
115
- if (this._taskProcessLinkType$.getValue() === 'form') {
116
- this.processLinkService
117
- .submitForm(this._processLinkId ?? '', submission.data, this.task?.businessKey, this.task?.id)
118
- .subscribe({
119
- next: (_) => {
120
- this.completeTask();
121
- },
122
- error: errors => {
123
- this.form.showErrors(errors);
124
- },
125
- });
126
- }
110
+ combineLatest([this.processLinkId$, this.taskProcessLinkType$, this.task$])
111
+ .pipe(take(1))
112
+ .subscribe(([processLinkId, taskProcessLinkType, task]) => {
113
+ if (taskProcessLinkType === 'form') {
114
+ if (processLinkId) {
115
+ this.processLinkService
116
+ .submitForm(processLinkId, submission.data, task.businessKey, task.id)
117
+ .subscribe({
118
+ next: (_) => {
119
+ this.completeTask();
120
+ },
121
+ error: errors => {
122
+ this.form.showErrors(errors);
123
+ },
124
+ });
125
+ }
126
+ }
127
+ });
128
+ }
129
+ completeTask() {
130
+ this.task$.pipe(take(1)).subscribe(task => {
131
+ this.toastr.success(`${task.name} ${this.translateService.instant('taskDetail.taskCompleted')}`);
132
+ this.modal.hide();
133
+ this.task$.next(null);
134
+ this.formSubmit.emit();
135
+ });
127
136
  }
128
137
  resetFormDefinition() {
129
- this.formDefinition = null;
138
+ this.formDefinition$.next(null);
130
139
  this.loading$.next(true);
131
140
  }
132
141
  getTaskProcessLink(taskId) {
@@ -135,13 +144,13 @@ export class TaskDetailModalComponent {
135
144
  if (res != null) {
136
145
  switch (res?.type) {
137
146
  case 'form':
138
- this._taskProcessLinkType$.next('form');
139
- this._processLinkId = res.processLinkId;
147
+ this.taskProcessLinkType$.next('form');
148
+ this.processLinkId$.next(res.processLinkId);
140
149
  this.setFormDefinitionAndOpenModal(res.properties.prefilledForm);
141
150
  break;
142
151
  case 'form-flow':
143
- this._taskProcessLinkType$.next('form-flow');
144
- this.formFlowInstanceId = res.properties.formFlowInstanceId ?? '';
152
+ this.taskProcessLinkType$.next('form-flow');
153
+ this.formFlowInstanceId$.next(res.properties.formFlowInstanceId);
145
154
  break;
146
155
  }
147
156
  this.loading$.next(false);
@@ -159,23 +168,23 @@ export class TaskDetailModalComponent {
159
168
  this.taskService.getTaskProcessLinkV1(taskId).subscribe(resV1 => {
160
169
  switch (resV1?.type) {
161
170
  case 'form':
162
- this._taskProcessLinkType$.next('form');
171
+ this.taskProcessLinkType$.next('form');
163
172
  break;
164
173
  case 'form-flow':
165
- this._taskProcessLinkType$.next('form-flow');
166
- this.formFlowInstanceId = resV1.properties.formFlowInstanceId ?? '';
174
+ this.taskProcessLinkType$.next('form-flow');
175
+ this.formFlowInstanceId$.next(resV1.properties.formFlowInstanceId);
167
176
  break;
168
177
  }
169
178
  this.loading$.next(false);
170
179
  });
171
180
  }
172
181
  resetTaskProcessLinkType() {
173
- this._taskProcessLinkType$.next(null);
174
- this._processLinkId = null;
182
+ this.taskProcessLinkType$.next(null);
183
+ this.processLinkId$.next(null);
175
184
  }
176
185
  setFormDefinitionAndOpenModal(formDefinition) {
177
- this._taskProcessLinkType$.next('form');
178
- this.formDefinition = formDefinition;
186
+ this.taskProcessLinkType$.next('form');
187
+ this.formDefinition$.next(formDefinition);
179
188
  this.modal.show();
180
189
  }
181
190
  setDocumentDefinitionNameInService(task) {
@@ -187,13 +196,13 @@ export class TaskDetailModalComponent {
187
196
  this.stateService.setDocumentDefinitionName(documentDefinitionName);
188
197
  });
189
198
  }
190
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TaskDetailModalComponent, deps: [{ token: i1.DocumentService }, { token: i2.ValtimoModalService }, { token: i3.PermissionService }, { token: i4.ProcessLinkService }, { token: i5.Router }, { token: i2.FormIoStateService }, { token: i6.TaskService }, { token: i7.ToastrService }, { token: i8.TranslateService }, { token: i9.UserProviderService }], target: i0.ɵɵFactoryTarget.Component }); }
191
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TaskDetailModalComponent, selector: "valtimo-task-detail-modal", outputs: { formSubmit: "formSubmit", assignmentOfTaskChanged: "assignmentOfTaskChanged" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "formFlow", first: true, predicate: ["formFlow"], descendants: true }, { propertyName: "modal", first: true, predicate: ["taskDetailModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 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<valtimo-modal\n #taskDetailModal\n *ngIf=\"{\n loading: loading$ | async\n } as obs\"\n elementId=\"taskDetailModal\"\n [title]=\"page?.title\"\n [subtitle]=\"page?.subtitle\"\n [templateBelowSubtitle]=\"assignUserToTask\"\n>\n <div body *ngIf=\"formDefinition && (processLinkIsForm$ | async)\">\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n [options]=\"formioOptions\"\n ></valtimo-form-io>\n </div>\n <div body *ngIf=\"processLinkIsFormFlow$ | async\">\n <valtimo-form-flow\n #formFlow\n [formIoFormData]=\"formIoFormData$\"\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"completeTask()\"\n ></valtimo-form-flow>\n </div>\n <div body *ngIf=\"obs.loading\">\n <div class=\"text-black mb-0 p-3 text-center\">\n {{ 'formManagement.loading' | translate }}\n </div>\n </div>\n <div body *ngIf=\"obs.loading === false && !formDefinition && !formFlowInstanceId && !errorMessage\">\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n (isAdmin$ | async)\n ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n : ('formManagement.noFormDefinitionFoundUser' | translate)\n }}\n </div>\n </div>\n <div body *ngIf=\"errorMessage\">\n <div class=\"bg-danger text-black mb-0 p-3 text-center\">\n {{ errorMessage }}\n </div>\n </div>\n <div footer>\n <div class=\"mb-0 p-3 text-center\" *ngIf=\"!formDefinition\">\n <button\n (click)=\"gotoProcessLinkScreen()\"\n class=\"btn btn-secondary btn-space\"\n id=\"process-link-button\"\n type=\"button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n </div>\n</valtimo-modal>\n\n<ng-template #assignUserToTask>\n <valtimo-assign-user-to-task\n *ngIf=\"task && assignmentOfTaskChanged && (canAssign$ | async)\"\n [taskId]=\"task.id\"\n [assigneeEmail]=\"task.assignee\"\n (assignmentOfTaskChanged)=\"assignmentOfTaskChanged.emit()\"\n ></valtimo-assign-user-to-task>\n</ng-template>\n", styles: ["/*!\n * Copyright 2015-2023 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 */#taskDetailModal .formio-component-submit{text-align:right}\n"], dependencies: [{ kind: "directive", type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormioComponent, selector: "valtimo-form-io", inputs: ["form", "options", "submission", "readOnly", "formRefresh$"], outputs: ["submit", "change"] }, { kind: "component", type: i2.ModalComponent, selector: "valtimo-modal", inputs: ["elementId", "title", "subtitle", "templateBelowSubtitle", "showFooter"] }, { kind: "component", type: i4.FormFlowComponent, selector: "valtimo-form-flow", inputs: ["formIoFormData", "formFlowInstanceId"], outputs: ["formFlowComplete"] }, { kind: "component", type: i11.AssignUserToTaskComponent, selector: "valtimo-assign-user-to-task", inputs: ["taskId", "assigneeEmail"], outputs: ["assignmentOfTaskChanged"] }, { kind: "pipe", type: i10.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
199
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TaskDetailModalComponent, deps: [{ token: i1.ToastrService }, { token: i2.ProcessLinkService }, { token: i3.Router }, { token: i4.TaskService }, { token: i5.UserProviderService }, { token: i6.ValtimoModalService }, { token: i6.FormIoStateService }, { token: i7.DocumentService }, { token: i8.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
200
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TaskDetailModalComponent, selector: "valtimo-task-detail-modal", outputs: { formSubmit: "formSubmit", assignmentOfTaskChanged: "assignmentOfTaskChanged" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "formFlow", first: true, predicate: ["formFlow"], descendants: true }, { propertyName: "modal", first: true, predicate: ["taskDetailModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 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<valtimo-modal\n #taskDetailModal\n *ngIf=\"{\n loading: loading$ | async,\n page: page$ | async,\n task: task$ | async,\n formDefinition: formDefinition$ | async,\n processLinkIsForm: processLinkIsForm$ | async,\n formioOptions: formioOptions$ | async,\n processLinkIsFormFlow: processLinkIsFormFlow$ | async,\n formFlowInstanceId: formFlowInstanceId$ | async,\n errorMessage: errorMessage$ | async\n } as obs\"\n elementId=\"taskDetailModal\"\n [title]=\"obs.page?.title\"\n [subtitle]=\"obs.page?.subtitle\"\n [templateBelowSubtitle]=\"assignUserToTask\"\n>\n <div body *ngIf=\"obs.formDefinition && obs.processLinkIsForm\">\n <valtimo-form-io\n #form\n [form]=\"obs.formDefinition\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n [options]=\"obs.formioOptions\"\n ></valtimo-form-io>\n </div>\n <div body *ngIf=\"obs.processLinkIsFormFlow\">\n <valtimo-form-flow\n #formFlow\n [formIoFormData]=\"formIoFormData$\"\n [formFlowInstanceId]=\"obs.formFlowInstanceId\"\n (formFlowComplete)=\"completeTask()\"\n ></valtimo-form-flow>\n </div>\n <div body *ngIf=\"obs.loading\">\n <div class=\"text-black mb-0 p-3 text-center\">\n {{ 'formManagement.loading' | translate }}\n </div>\n </div>\n <div\n body\n *ngIf=\"\n obs.loading === false && !obs.formDefinition && !obs.formFlowInstanceId && !obs.errorMessage\n \"\n >\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n (isAdmin$ | async)\n ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n : ('formManagement.noFormDefinitionFoundUser' | translate)\n }}\n </div>\n </div>\n <div body *ngIf=\"obs.errorMessage\">\n <div class=\"bg-danger text-black mb-0 p-3 text-center\">\n {{ obs.errorMessage }}\n </div>\n </div>\n <div footer>\n <div class=\"mb-0 p-3 text-center\" *ngIf=\"!!obs.formDefinition\">\n <button\n class=\"btn btn-secondary btn-space\"\n type=\"button\"\n (click)=\"gotoProcessLinkScreen()\"\n id=\"process-link-button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n </div>\n</valtimo-modal>\n\n<ng-template #assignUserToTask>\n <ng-container *ngIf=\"task$ | async as task\">\n <valtimo-assign-user-to-task\n *ngIf=\"task && assignmentOfTaskChanged\"\n [taskId]=\"task.id\"\n [assigneeEmail]=\"task.assignee\"\n (assignmentOfTaskChanged)=\"assignmentOfTaskChanged.emit()\"\n ></valtimo-assign-user-to-task>\n </ng-container>\n</ng-template>\n", styles: ["/*!\n * Copyright 2015-2023 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 */#taskDetailModal .formio-component-submit{text-align:right}\n"], dependencies: [{ kind: "directive", type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change"] }, { kind: "component", type: i6.ModalComponent, selector: "valtimo-modal", inputs: ["elementId", "title", "subtitle", "templateBelowSubtitle", "showFooter"] }, { kind: "component", type: i2.FormFlowComponent, selector: "valtimo-form-flow", inputs: ["formIoFormData", "formFlowInstanceId"], outputs: ["formFlowComplete"] }, { kind: "component", type: i10.AssignUserToTaskComponent, selector: "valtimo-assign-user-to-task", inputs: ["taskId", "assigneeEmail"], outputs: ["assignmentOfTaskChanged"] }, { kind: "pipe", type: i9.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
192
201
  }
193
202
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TaskDetailModalComponent, decorators: [{
194
203
  type: Component,
195
- args: [{ selector: 'valtimo-task-detail-modal', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2015-2023 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<valtimo-modal\n #taskDetailModal\n *ngIf=\"{\n loading: loading$ | async\n } as obs\"\n elementId=\"taskDetailModal\"\n [title]=\"page?.title\"\n [subtitle]=\"page?.subtitle\"\n [templateBelowSubtitle]=\"assignUserToTask\"\n>\n <div body *ngIf=\"formDefinition && (processLinkIsForm$ | async)\">\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n [options]=\"formioOptions\"\n ></valtimo-form-io>\n </div>\n <div body *ngIf=\"processLinkIsFormFlow$ | async\">\n <valtimo-form-flow\n #formFlow\n [formIoFormData]=\"formIoFormData$\"\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"completeTask()\"\n ></valtimo-form-flow>\n </div>\n <div body *ngIf=\"obs.loading\">\n <div class=\"text-black mb-0 p-3 text-center\">\n {{ 'formManagement.loading' | translate }}\n </div>\n </div>\n <div body *ngIf=\"obs.loading === false && !formDefinition && !formFlowInstanceId && !errorMessage\">\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n (isAdmin$ | async)\n ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n : ('formManagement.noFormDefinitionFoundUser' | translate)\n }}\n </div>\n </div>\n <div body *ngIf=\"errorMessage\">\n <div class=\"bg-danger text-black mb-0 p-3 text-center\">\n {{ errorMessage }}\n </div>\n </div>\n <div footer>\n <div class=\"mb-0 p-3 text-center\" *ngIf=\"!formDefinition\">\n <button\n (click)=\"gotoProcessLinkScreen()\"\n class=\"btn btn-secondary btn-space\"\n id=\"process-link-button\"\n type=\"button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n </div>\n</valtimo-modal>\n\n<ng-template #assignUserToTask>\n <valtimo-assign-user-to-task\n *ngIf=\"task && assignmentOfTaskChanged && (canAssign$ | async)\"\n [taskId]=\"task.id\"\n [assigneeEmail]=\"task.assignee\"\n (assignmentOfTaskChanged)=\"assignmentOfTaskChanged.emit()\"\n ></valtimo-assign-user-to-task>\n</ng-template>\n", styles: ["/*!\n * Copyright 2015-2023 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 */#taskDetailModal .formio-component-submit{text-align:right}\n"] }]
196
- }], ctorParameters: function () { return [{ type: i1.DocumentService }, { type: i2.ValtimoModalService }, { type: i3.PermissionService }, { type: i4.ProcessLinkService }, { type: i5.Router }, { type: i2.FormIoStateService }, { type: i6.TaskService }, { type: i7.ToastrService }, { type: i8.TranslateService }, { type: i9.UserProviderService }]; }, propDecorators: { form: [{
204
+ args: [{ selector: 'valtimo-task-detail-modal', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2015-2023 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<valtimo-modal\n #taskDetailModal\n *ngIf=\"{\n loading: loading$ | async,\n page: page$ | async,\n task: task$ | async,\n formDefinition: formDefinition$ | async,\n processLinkIsForm: processLinkIsForm$ | async,\n formioOptions: formioOptions$ | async,\n processLinkIsFormFlow: processLinkIsFormFlow$ | async,\n formFlowInstanceId: formFlowInstanceId$ | async,\n errorMessage: errorMessage$ | async\n } as obs\"\n elementId=\"taskDetailModal\"\n [title]=\"obs.page?.title\"\n [subtitle]=\"obs.page?.subtitle\"\n [templateBelowSubtitle]=\"assignUserToTask\"\n>\n <div body *ngIf=\"obs.formDefinition && obs.processLinkIsForm\">\n <valtimo-form-io\n #form\n [form]=\"obs.formDefinition\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n [options]=\"obs.formioOptions\"\n ></valtimo-form-io>\n </div>\n <div body *ngIf=\"obs.processLinkIsFormFlow\">\n <valtimo-form-flow\n #formFlow\n [formIoFormData]=\"formIoFormData$\"\n [formFlowInstanceId]=\"obs.formFlowInstanceId\"\n (formFlowComplete)=\"completeTask()\"\n ></valtimo-form-flow>\n </div>\n <div body *ngIf=\"obs.loading\">\n <div class=\"text-black mb-0 p-3 text-center\">\n {{ 'formManagement.loading' | translate }}\n </div>\n </div>\n <div\n body\n *ngIf=\"\n obs.loading === false && !obs.formDefinition && !obs.formFlowInstanceId && !obs.errorMessage\n \"\n >\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n (isAdmin$ | async)\n ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n : ('formManagement.noFormDefinitionFoundUser' | translate)\n }}\n </div>\n </div>\n <div body *ngIf=\"obs.errorMessage\">\n <div class=\"bg-danger text-black mb-0 p-3 text-center\">\n {{ obs.errorMessage }}\n </div>\n </div>\n <div footer>\n <div class=\"mb-0 p-3 text-center\" *ngIf=\"!!obs.formDefinition\">\n <button\n class=\"btn btn-secondary btn-space\"\n type=\"button\"\n (click)=\"gotoProcessLinkScreen()\"\n id=\"process-link-button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n </div>\n</valtimo-modal>\n\n<ng-template #assignUserToTask>\n <ng-container *ngIf=\"task$ | async as task\">\n <valtimo-assign-user-to-task\n *ngIf=\"task && assignmentOfTaskChanged\"\n [taskId]=\"task.id\"\n [assigneeEmail]=\"task.assignee\"\n (assignmentOfTaskChanged)=\"assignmentOfTaskChanged.emit()\"\n ></valtimo-assign-user-to-task>\n </ng-container>\n</ng-template>\n", styles: ["/*!\n * Copyright 2015-2023 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 */#taskDetailModal .formio-component-submit{text-align:right}\n"] }]
205
+ }], ctorParameters: function () { return [{ type: i1.ToastrService }, { type: i2.ProcessLinkService }, { type: i3.Router }, { type: i4.TaskService }, { type: i5.UserProviderService }, { type: i6.ValtimoModalService }, { type: i6.FormIoStateService }, { type: i7.DocumentService }, { type: i8.TranslateService }]; }, propDecorators: { form: [{
197
206
  type: ViewChild,
198
207
  args: ['form']
199
208
  }], formFlow: [{
@@ -207,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
207
216
  }], assignmentOfTaskChanged: [{
208
217
  type: Output
209
218
  }] } });
210
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-detail-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/task/src/lib/task-detail-modal/task-detail-modal.component.ts","../../../../../../projects/valtimo/task/src/lib/task-detail-modal/task-detail-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 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 {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  OnDestroy,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {FormioForm} from '@formio/angular';\nimport {TranslateService} from '@ngx-translate/core';\nimport {\n  FormioComponent,\n  FormioOptionsImpl,\n  FormIoStateService,\n  FormioSubmission,\n  ModalComponent,\n  ValtimoFormioOptions,\n  ValtimoModalService,\n} from '@valtimo/components';\nimport {DocumentService} from '@valtimo/document';\nimport {FormFlowComponent, FormSubmissionResult, ProcessLinkService} from '@valtimo/form-link';\nimport {UserProviderService} from '@valtimo/security';\nimport moment from 'moment';\nimport {ToastrService} from 'ngx-toastr';\nimport {BehaviorSubject, distinctUntilChanged, map, Observable, Subscription, tap} from 'rxjs';\nimport {Task, TaskProcessLinkType} from '../models';\nimport {TaskService} from '../task.service';\nimport {PermissionService} from '@valtimo/access-control';\nimport {CAN_ASSIGN_TASK_PERMISSION, TASK_DETAIL_PERMISSION_RESOURCE} from '../task-permissions';\n\nmoment.locale(localStorage.getItem('langKey') || '');\n\n@Component({\n  selector: 'valtimo-task-detail-modal',\n  templateUrl: './task-detail-modal.component.html',\n  styleUrls: ['./task-detail-modal.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class TaskDetailModalComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('form') form: FormioComponent;\n  @ViewChild('formFlow') formFlow: FormFlowComponent;\n  @ViewChild('taskDetailModal') modal: ModalComponent;\n  @Output() formSubmit = new EventEmitter();\n  @Output() assignmentOfTaskChanged = new EventEmitter();\n\n  public canAssign$: Observable<boolean>;\n  public errorMessage: string | null = null;\n  public formDefinition: FormioForm | null;\n  public formFlowInstanceId: string;\n  public formIoFormData$ = new BehaviorSubject<any>(null);\n  public formioOptions: ValtimoFormioOptions;\n  public page: any = null;\n  public task: Task | null = null;\n\n  private _taskProcessLinkType$ = new BehaviorSubject<TaskProcessLinkType | null>(null);\n  public processLinkIsForm$: Observable<boolean> = this._taskProcessLinkType$.pipe(\n    map(type => type === 'form')\n  );\n  public processLinkIsFormFlow$: Observable<boolean> = this._taskProcessLinkType$.pipe(\n    map(type => type === 'form-flow')\n  );\n\n  public readonly isAdmin$: Observable<boolean> = this.userProviderService\n    .getUserSubject()\n    .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  private _processLinkId: string | null;\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly documentService: DocumentService,\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 taskService: TaskService,\n    private readonly toastr: ToastrService,\n    private readonly translateService: TranslateService,\n    private readonly userProviderService: UserProviderService\n  ) {\n    this.formioOptions = new FormioOptionsImpl();\n    this.formioOptions.disableAlerts = true;\n  }\n\n  public ngAfterViewInit(): void {\n    this._subscriptions.add(\n      this.modal.modalShowing$\n        .pipe(\n          distinctUntilChanged(),\n          tap(modalShowing => {\n            if (!modalShowing) {\n              if (this.formFlow) {\n                this.formFlow.saveData();\n              }\n            }\n          })\n        )\n        .subscribe()\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public openTaskDetails(task: Task): void {\n    this.canAssign$ = this.permissionService.requestPermission(CAN_ASSIGN_TASK_PERMISSION, {\n      resource: TASK_DETAIL_PERMISSION_RESOURCE.task,\n      identifier: task.id,\n    });\n    this.resetTaskProcessLinkType();\n    this.resetFormDefinition();\n    this.getTaskProcessLink(task.id);\n    this.setDocumentDefinitionNameInService(task);\n    this.stateService.setDocumentId(task.businessKey);\n\n    this.task = task;\n    this.page = {\n      title: task.name,\n      subtitle: `${this.translateService.instant('taskDetail.taskCreated')} ${task.created}`,\n    };\n\n    if (!this._taskProcessLinkType$.getValue()) {\n      this.modal.show();\n    }\n  }\n\n  public gotoProcessLinkScreen(): void {\n    this.modal.hide();\n    this.router.navigate(['process-links']);\n  }\n\n  public onChange(event: any): void {\n    if (event.data) {\n      this.formIoFormData$.next(event.data);\n    }\n  }\n\n  public completeTask(): void {\n    this.toastr.success(\n      `${this.task?.name} ${this.translateService.instant('taskDetail.taskCompleted')}`\n    );\n    this.modal.hide();\n    this.task = null;\n    this.formSubmit.emit();\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    if (submission.data) {\n      this.formIoFormData$.next(submission.data);\n    }\n\n    if (this._taskProcessLinkType$.getValue() === 'form') {\n      this.processLinkService\n        .submitForm(\n          this._processLinkId ?? '',\n          submission.data,\n          this.task?.businessKey,\n          this.task?.id\n        )\n        .subscribe({\n          next: (_: FormSubmissionResult) => {\n            this.completeTask();\n          },\n          error: errors => {\n            this.form.showErrors(errors);\n          },\n        });\n    }\n  }\n\n  private resetFormDefinition(): void {\n    this.formDefinition = null;\n    this.loading$.next(true);\n  }\n\n  private getTaskProcessLink(taskId: string): void {\n    this.taskService.getTaskProcessLink(taskId).subscribe({\n      next: res => {\n        if (res != null) {\n          switch (res?.type) {\n            case 'form':\n              this._taskProcessLinkType$.next('form');\n              this._processLinkId = res.processLinkId;\n              this.setFormDefinitionAndOpenModal(res.properties.prefilledForm);\n              break;\n            case 'form-flow':\n              this._taskProcessLinkType$.next('form-flow');\n              this.formFlowInstanceId = res.properties.formFlowInstanceId ?? '';\n              break;\n          }\n          this.loading$.next(false);\n        } else {\n          this.getLegacyTaskProcessLink(taskId);\n        }\n      },\n      error: _ => {\n        this.getLegacyTaskProcessLink(taskId);\n      },\n    });\n  }\n\n  private getLegacyTaskProcessLink(taskId: string): void {\n    this.taskService.getTaskProcessLinkV1(taskId).subscribe(resV1 => {\n      switch (resV1?.type) {\n        case 'form':\n          this._taskProcessLinkType$.next('form');\n          break;\n        case 'form-flow':\n          this._taskProcessLinkType$.next('form-flow');\n          this.formFlowInstanceId = resV1.properties.formFlowInstanceId ?? '';\n          break;\n      }\n      this.loading$.next(false);\n    });\n  }\n\n  private resetTaskProcessLinkType(): void {\n    this._taskProcessLinkType$.next(null);\n    this._processLinkId = null;\n  }\n\n  private setFormDefinitionAndOpenModal(formDefinition: any): void {\n    this._taskProcessLinkType$.next('form');\n    this.formDefinition = formDefinition;\n    this.modal.show();\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-2023 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<valtimo-modal\n  #taskDetailModal\n  *ngIf=\"{\n    loading: loading$ | async\n  } as obs\"\n  elementId=\"taskDetailModal\"\n  [title]=\"page?.title\"\n  [subtitle]=\"page?.subtitle\"\n  [templateBelowSubtitle]=\"assignUserToTask\"\n>\n  <div body *ngIf=\"formDefinition && (processLinkIsForm$ | async)\">\n    <valtimo-form-io\n      #form\n      [form]=\"formDefinition\"\n      (submit)=\"onSubmit($event)\"\n      (change)=\"onChange($event)\"\n      [options]=\"formioOptions\"\n    ></valtimo-form-io>\n  </div>\n  <div body *ngIf=\"processLinkIsFormFlow$ | async\">\n    <valtimo-form-flow\n      #formFlow\n      [formIoFormData]=\"formIoFormData$\"\n      [formFlowInstanceId]=\"formFlowInstanceId\"\n      (formFlowComplete)=\"completeTask()\"\n    ></valtimo-form-flow>\n  </div>\n  <div body *ngIf=\"obs.loading\">\n    <div class=\"text-black mb-0 p-3 text-center\">\n      {{ 'formManagement.loading' | translate }}\n    </div>\n  </div>\n  <div body *ngIf=\"obs.loading === false && !formDefinition && !formFlowInstanceId && !errorMessage\">\n    <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n      {{\n        (isAdmin$ | async)\n          ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n          : ('formManagement.noFormDefinitionFoundUser' | translate)\n      }}\n    </div>\n  </div>\n  <div body *ngIf=\"errorMessage\">\n    <div class=\"bg-danger text-black mb-0 p-3 text-center\">\n      {{ errorMessage }}\n    </div>\n  </div>\n  <div footer>\n    <div class=\"mb-0 p-3 text-center\" *ngIf=\"!formDefinition\">\n      <button\n        (click)=\"gotoProcessLinkScreen()\"\n        class=\"btn btn-secondary btn-space\"\n        id=\"process-link-button\"\n        type=\"button\"\n      >\n        {{ 'formManagement.gotoProcessLinksButton' | translate }}\n      </button>\n    </div>\n  </div>\n</valtimo-modal>\n\n<ng-template #assignUserToTask>\n  <valtimo-assign-user-to-task\n    *ngIf=\"task && assignmentOfTaskChanged && (canAssign$ | async)\"\n    [taskId]=\"task.id\"\n    [assigneeEmail]=\"task.assignee\"\n    (assignmentOfTaskChanged)=\"assignmentOfTaskChanged.emit()\"\n  ></valtimo-assign-user-to-task>\n</ng-template>\n"]}
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-detail-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/task/src/lib/task-detail-modal/task-detail-modal.component.ts","../../../../../../projects/valtimo/task/src/lib/task-detail-modal/task-detail-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 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\nimport {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  OnDestroy,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {\n  FormioComponent,\n  FormioOptionsImpl,\n  FormIoStateService,\n  FormioSubmission,\n  ModalComponent,\n  ValtimoFormioOptions,\n  ValtimoModalService,\n} from '@valtimo/components';\nimport {Task, TaskProcessLinkType} from '../models';\nimport {FormFlowComponent, FormSubmissionResult, ProcessLinkService} from '@valtimo/form-link';\nimport {FormioForm} from '@formio/angular';\nimport moment from 'moment';\nimport {ToastrService} from 'ngx-toastr';\nimport {map, take} from 'rxjs/operators';\nimport {TaskService} from '../task.service';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  distinctUntilChanged,\n  Observable,\n  Subscription,\n  tap,\n} from 'rxjs';\nimport {UserProviderService} from '@valtimo/security';\nimport {DocumentService} from '@valtimo/document';\nimport {TranslateService} from '@ngx-translate/core';\n\nmoment.locale(localStorage.getItem('langKey') || '');\n\n@Component({\n  selector: 'valtimo-task-detail-modal',\n  templateUrl: './task-detail-modal.component.html',\n  styleUrls: ['./task-detail-modal.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class TaskDetailModalComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('form') form: FormioComponent;\n  @ViewChild('formFlow') formFlow: FormFlowComponent;\n  @ViewChild('taskDetailModal') modal: ModalComponent;\n  @Output() formSubmit = new EventEmitter();\n  @Output() assignmentOfTaskChanged = new EventEmitter();\n\n  public readonly task$ = new BehaviorSubject<Task | null>(null);\n  public readonly formDefinition$ = new BehaviorSubject<FormioForm>(undefined);\n  public readonly formFlowInstanceId$ = new BehaviorSubject<string>(undefined);\n  public readonly page$ = new BehaviorSubject<any>(null);\n  public readonly formioOptions$ = new BehaviorSubject<ValtimoFormioOptions>(null);\n  public readonly errorMessage$ = new BehaviorSubject<string>(undefined);\n  public readonly isAdmin$: Observable<boolean> = this.userProviderService\n    .getUserSubject()\n    .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));\n  public readonly formIoFormData$ = new BehaviorSubject<any>(null);\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  private readonly taskProcessLinkType$ = new BehaviorSubject<TaskProcessLinkType | null>(null);\n  public readonly processLinkIsForm$ = this.taskProcessLinkType$.pipe(map(type => type === 'form'));\n  public readonly processLinkIsFormFlow$ = this.taskProcessLinkType$.pipe(\n    map(type => type === 'form-flow')\n  );\n\n  private readonly processLinkId$ = new BehaviorSubject<string>(undefined);\n\n  private _subscriptions = new Subscription();\n\n  constructor(\n    private readonly toastr: ToastrService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly router: Router,\n    private readonly taskService: TaskService,\n    private readonly userProviderService: UserProviderService,\n    private readonly modalService: ValtimoModalService,\n    private readonly stateService: FormIoStateService,\n    private readonly documentService: DocumentService,\n    private readonly translateService: TranslateService\n  ) {\n    const options = new FormioOptionsImpl();\n    options.disableAlerts = true;\n    this.formioOptions$.next(options);\n  }\n\n  public ngAfterViewInit(): void {\n    this._subscriptions.add(\n      this.modal.modalShowing$\n        .pipe(\n          distinctUntilChanged(),\n          tap(modalShowing => {\n            if (!modalShowing) {\n              if (this.formFlow) {\n                this.formFlow.saveData();\n              }\n            }\n          })\n        )\n        .subscribe()\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public openTaskDetails(task: Task): void {\n    this.resetTaskProcessLinkType();\n    this.resetFormDefinition();\n    this.getTaskProcessLink(task.id);\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    //only load from formlink when process link failed for backwards compatibility\n    if (!this.taskProcessLinkType$.getValue()) {\n      this.modal.show();\n    }\n  }\n\n  public gotoProcessLinkScreen(): void {\n    this.modal.hide();\n    this.router.navigate(['process-links']);\n  }\n\n  public onChange(event: any): void {\n    if (event.data) {\n      this.formIoFormData$.next(event.data);\n    }\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    if (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();\n                },\n                error: errors => {\n                  this.form.showErrors(errors);\n                },\n              });\n          }\n        }\n      });\n  }\n\n  public completeTask(): void {\n    this.task$.pipe(take(1)).subscribe(task => {\n      this.toastr.success(\n        `${task.name} ${this.translateService.instant('taskDetail.taskCompleted')}`\n      );\n      this.modal.hide();\n      this.task$.next(null);\n      this.formSubmit.emit();\n    });\n  }\n\n  private resetFormDefinition(): void {\n    this.formDefinition$.next(null);\n    this.loading$.next(true);\n  }\n\n  private getTaskProcessLink(taskId: string): void {\n    this.taskService.getTaskProcessLink(taskId).subscribe({\n      next: res => {\n        if (res != null) {\n          switch (res?.type) {\n            case 'form':\n              this.taskProcessLinkType$.next('form');\n              this.processLinkId$.next(res.processLinkId);\n              this.setFormDefinitionAndOpenModal(res.properties.prefilledForm);\n              break;\n            case 'form-flow':\n              this.taskProcessLinkType$.next('form-flow');\n              this.formFlowInstanceId$.next(res.properties.formFlowInstanceId);\n              break;\n          }\n          this.loading$.next(false);\n        } else {\n          this.getLegacyTaskProcessLink(taskId);\n        }\n      },\n      error: _ => {\n        this.getLegacyTaskProcessLink(taskId);\n      },\n    });\n  }\n\n  private getLegacyTaskProcessLink(taskId: string): void {\n    this.taskService.getTaskProcessLinkV1(taskId).subscribe(resV1 => {\n      switch (resV1?.type) {\n        case 'form':\n          this.taskProcessLinkType$.next('form');\n          break;\n        case 'form-flow':\n          this.taskProcessLinkType$.next('form-flow');\n          this.formFlowInstanceId$.next(resV1.properties.formFlowInstanceId);\n          break;\n      }\n      this.loading$.next(false);\n    });\n  }\n\n  private resetTaskProcessLinkType(): void {\n    this.taskProcessLinkType$.next(null);\n    this.processLinkId$.next(null);\n  }\n\n  private setFormDefinitionAndOpenModal(formDefinition: any): void {\n    this.taskProcessLinkType$.next('form');\n    this.formDefinition$.next(formDefinition);\n    this.modal.show();\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-2023 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<valtimo-modal\n  #taskDetailModal\n  *ngIf=\"{\n    loading: loading$ | async,\n    page: page$ | async,\n    task: task$ | async,\n    formDefinition: formDefinition$ | async,\n    processLinkIsForm: processLinkIsForm$ | async,\n    formioOptions: formioOptions$ | async,\n    processLinkIsFormFlow: processLinkIsFormFlow$ | async,\n    formFlowInstanceId: formFlowInstanceId$ | async,\n    errorMessage: errorMessage$ | async\n  } as obs\"\n  elementId=\"taskDetailModal\"\n  [title]=\"obs.page?.title\"\n  [subtitle]=\"obs.page?.subtitle\"\n  [templateBelowSubtitle]=\"assignUserToTask\"\n>\n  <div body *ngIf=\"obs.formDefinition && obs.processLinkIsForm\">\n    <valtimo-form-io\n      #form\n      [form]=\"obs.formDefinition\"\n      (submit)=\"onSubmit($event)\"\n      (change)=\"onChange($event)\"\n      [options]=\"obs.formioOptions\"\n    ></valtimo-form-io>\n  </div>\n  <div body *ngIf=\"obs.processLinkIsFormFlow\">\n    <valtimo-form-flow\n      #formFlow\n      [formIoFormData]=\"formIoFormData$\"\n      [formFlowInstanceId]=\"obs.formFlowInstanceId\"\n      (formFlowComplete)=\"completeTask()\"\n    ></valtimo-form-flow>\n  </div>\n  <div body *ngIf=\"obs.loading\">\n    <div class=\"text-black mb-0 p-3 text-center\">\n      {{ 'formManagement.loading' | translate }}\n    </div>\n  </div>\n  <div\n    body\n    *ngIf=\"\n      obs.loading === false && !obs.formDefinition && !obs.formFlowInstanceId && !obs.errorMessage\n    \"\n  >\n    <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n      {{\n        (isAdmin$ | async)\n          ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n          : ('formManagement.noFormDefinitionFoundUser' | translate)\n      }}\n    </div>\n  </div>\n  <div body *ngIf=\"obs.errorMessage\">\n    <div class=\"bg-danger text-black mb-0 p-3 text-center\">\n      {{ obs.errorMessage }}\n    </div>\n  </div>\n  <div footer>\n    <div class=\"mb-0 p-3 text-center\" *ngIf=\"!!obs.formDefinition\">\n      <button\n        class=\"btn btn-secondary btn-space\"\n        type=\"button\"\n        (click)=\"gotoProcessLinkScreen()\"\n        id=\"process-link-button\"\n      >\n        {{ 'formManagement.gotoProcessLinksButton' | translate }}\n      </button>\n    </div>\n  </div>\n</valtimo-modal>\n\n<ng-template #assignUserToTask>\n  <ng-container *ngIf=\"task$ | async as task\">\n    <valtimo-assign-user-to-task\n      *ngIf=\"task && assignmentOfTaskChanged\"\n      [taskId]=\"task.id\"\n      [assigneeEmail]=\"task.assignee\"\n      (assignmentOfTaskChanged)=\"assignmentOfTaskChanged.emit()\"\n    ></valtimo-assign-user-to-task>\n  </ng-container>\n</ng-template>\n"]}
@@ -164,7 +164,7 @@ export class TaskListComponent {
164
164
  .pipe(take(1))
165
165
  .subscribe(document => {
166
166
  this.router.navigate([
167
- `/dossiers/${document.definitionId?.name}/document/${currentTask.businessKey}/summary`,
167
+ `/dossiers/${document.definitionId?.name}/document/${currentTask.businessKey}`,
168
168
  ]);
169
169
  });
170
170
  }
@@ -249,4 +249,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
249
249
  type: ViewChild,
250
250
  args: ['taskDetail']
251
251
  }] } });
252
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-list.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/task/src/lib/task-list/task-list.component.ts","../../../../../../projects/valtimo/task/src/lib/task-list/task-list.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 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\nimport {Component, OnDestroy, ViewChild, ViewEncapsulation} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {TaskService} from '../task.service';\nimport moment from 'moment';\nimport {Task, TaskList} from '../models';\nimport {NGXLogger} from 'ngx-logger';\nimport {TaskDetailModalComponent} from '../task-detail-modal/task-detail-modal.component';\nimport {TranslateService} from '@ngx-translate/core';\nimport {BehaviorSubject, combineLatest, of, Subscription, switchMap} from 'rxjs';\nimport {ConfigService, SortState, TaskListTab} from '@valtimo/config';\nimport {DocumentService} from '@valtimo/document';\nimport {take} from 'rxjs/operators';\nimport {PermissionService} from '@valtimo/access-control';\nimport {CAN_VIEW_TASK_PERMISSION, TASK_DETAIL_PERMISSION_RESOURCE} from '../task-permissions';\n\nmoment.locale(localStorage.getItem('langKey') || '');\n\n@Component({\n  selector: 'valtimo-task-list',\n  templateUrl: './task-list.component.html',\n  styleUrls: ['./task-list.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class TaskListComponent implements OnDestroy {\n  @ViewChild('taskDetail') taskDetail: TaskDetailModalComponent;\n  public tasks = {\n    mine: new TaskList(),\n    open: new TaskList(),\n    all: new TaskList(),\n  };\n  public visibleTabs: Array<TaskListTab> | null = null;\n  public currentTaskType = 'mine';\n  public listTitle: string | null = null;\n  public listDescription: string | null = null;\n  public sortState: SortState | null = null;\n  public readonly loadingTasks$ = new BehaviorSubject<boolean>(true);\n  public readonly activeTab$ = new BehaviorSubject<string>('');\n  private _translationSubscription!: Subscription;\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly documentService: DocumentService,\n    private readonly logger: NGXLogger,\n    private readonly permissionService: PermissionService,\n    private readonly router: Router,\n    private readonly taskService: TaskService,\n    private readonly translateService: TranslateService\n  ) {\n    this.visibleTabs = this.configService.config?.visibleTaskListTabs || null;\n    if (this.visibleTabs) {\n      this.currentTaskType = this.visibleTabs[0];\n    }\n    this.setDefaultSorting();\n  }\n\n  public ngOnDestroy(): void {\n    this.closeTranslationSubscription();\n  }\n\n  public paginationClicked(page: number, type: string): void {\n    this.tasks[type].page = page - 1;\n    this.tasks[type].pagination.page = page;\n    this.getTasks(type);\n  }\n\n  public paginationSet(size: number): void {\n    this.tasks.mine.pagination.size =\n      this.tasks.all.pagination.size =\n      this.tasks.open.pagination.size =\n        size;\n    this.getTasks(this.currentTaskType);\n  }\n\n  public tabChange(tab: string): void {\n    this.clearPagination(this.currentTaskType);\n    this.getTasks(tab);\n  }\n\n  public showTask(task: Task): void {\n    this.router.navigate(['tasks', task.id]);\n  }\n\n  public getTasks(type: string): void {\n    this.loadingTasks$.next(true);\n    this.activeTab$.next(type);\n\n    let params: any;\n\n    this.closeTranslationSubscription();\n\n    this._translationSubscription = combineLatest([\n      this.translateService.stream(`task-list.${type}.title`),\n      this.translateService.stream(`task-list.${type}.description`),\n    ]).subscribe(([title, description]) => {\n      this.listTitle = title;\n      this.listDescription = description;\n    });\n\n    switch (type) {\n      case 'mine':\n        params = {\n          page: this.tasks.mine.page,\n          size: this.tasks.mine.pagination.size,\n          filter: 'mine',\n        };\n        this.currentTaskType = 'mine';\n        break;\n      case 'open':\n        params = {\n          page: this.tasks.open.page,\n          size: this.tasks.open.pagination.size,\n          filter: 'open',\n        };\n        this.currentTaskType = 'open';\n        break;\n      case 'all':\n        params = {page: this.tasks.all.page, size: this.tasks.open.pagination.size, filter: 'all'};\n        this.currentTaskType = 'all';\n        break;\n      default:\n        this.logger.fatal('Unreachable case');\n    }\n\n    if (this.sortState) {\n      params.sort = this.getSortString(this.sortState);\n    }\n\n    this.taskService\n      .queryTasks(params)\n      .pipe(\n        switchMap(tasksResult =>\n          combineLatest([\n            of(tasksResult),\n            ...tasksResult.body.map(task =>\n              this.permissionService.requestPermission(CAN_VIEW_TASK_PERMISSION, {\n                resource: TASK_DETAIL_PERMISSION_RESOURCE.task,\n                identifier: task.id,\n              })\n            ),\n          ])\n        )\n      )\n      .subscribe(results => {\n        const tasksResult = results[0];\n        const permissions = results.filter((_, index) => index !== 0);\n\n        this.tasks[type].pagination = {\n          ...this.tasks[type].pagination,\n          collectionSize: tasksResult.headers.get('x-total-count'),\n        };\n        this.tasks[type].tasks = tasksResult.body;\n        this.tasks[type].tasks.map((task, taskIndex) => {\n          task.created = moment(task.created).format('DD MMM YYYY HH:mm');\n          if (task.due) {\n            task.due = moment(task.due).format('DD MMM YYYY HH:mm');\n          }\n          task.isLocked = !permissions[taskIndex];\n        });\n\n        if (this.taskService.getConfigCustomTaskList()) {\n          this.customTaskListFields(type);\n        } else {\n          this.defaultTaskListFields(type);\n        }\n\n        this.loadingTasks$.next(false);\n      });\n  }\n\n  public openRelatedCase(event: MouseEvent, index: number): void {\n    event.stopPropagation();\n\n    const tasks = this.tasks[this.currentTaskType].tasks;\n    const currentTask = tasks && tasks[index];\n\n    if (currentTask) {\n      this.documentService\n        .getDocument(currentTask.businessKey)\n        .pipe(take(1))\n        .subscribe(document => {\n          this.router.navigate([\n            `/dossiers/${document.definitionId?.name}/document/${currentTask.businessKey}/summary`,\n          ]);\n        });\n    }\n  }\n\n  public defaultTaskListFields(type): void {\n    this.closeTranslationSubscription();\n    this._translationSubscription = combineLatest([\n      this.translateService.stream(`task-list.fieldLabels.created`),\n      this.translateService.stream(`task-list.fieldLabels.name`),\n      this.translateService.stream(`task-list.fieldLabels.valtimoAssignee.fullName`),\n      this.translateService.stream(`task-list.fieldLabels.due`),\n      this.translateService.stream(`task-list.fieldLabels.context`),\n    ]).subscribe(([created, name, assignee, due, context]) => {\n      this.tasks[type].fields = [\n        {\n          key: 'created',\n          label: created,\n        },\n        {\n          key: 'name',\n          label: name,\n        },\n        {\n          key: 'valtimoAssignee.fullName',\n          label: assignee,\n        },\n        {\n          key: 'due',\n          label: due,\n        },\n        {\n          key: 'context',\n          label: context,\n        },\n      ];\n    });\n  }\n\n  public customTaskListFields(type): void {\n    const customTaskListFields = this.taskService.getConfigCustomTaskList().fields;\n\n    this.closeTranslationSubscription();\n    this._translationSubscription = combineLatest(\n      customTaskListFields.map(column =>\n        this.translateService.stream(`task-list.fieldLabels.${column.translationKey}`)\n      )\n    ).subscribe(labels => {\n      this.tasks[type].fields = customTaskListFields.map((column, index) => ({\n        key: column.propertyName,\n        label: labels[index],\n        sortable: column.sortable,\n        ...(column.viewType && {viewType: column.viewType}),\n        ...(column.enum && {enum: column.enum}),\n      }));\n    });\n  }\n\n  public rowOpenTaskClick(task): void | boolean {\n    if (!task.endTime && !task.isLocked) {\n      this.taskDetail.openTaskDetails(task);\n    } else {\n      return false;\n    }\n  }\n\n  public setDefaultSorting(): void {\n    this.sortState = this.taskService.getConfigCustomTaskList()?.defaultSortedColumn || null;\n  }\n\n  public sortChanged(sortState: SortState): void {\n    this.sortState = sortState;\n    this.getTasks(this.currentTaskType);\n  }\n\n  public getSortString(sort: SortState): string {\n    return `${sort.state.name},${sort.state.direction}`;\n  }\n\n  private clearPagination(type: string): void {\n    this.tasks[type].page = 0;\n  }\n\n  private closeTranslationSubscription(): void {\n    this._translationSubscription?.unsubscribe();\n  }\n}\n","<!--\n  ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  class=\"main-content\"\n  *ngIf=\"{loadingTasks: loadingTasks$ | async, activeTab: activeTab$ | async} as obs\"\n>\n  <div class=\"container-fluid\">\n    <ng-container\n      *ngTemplateOutlet=\"tasksList; context: {show: !obs.loadingTasks, activeTab: obs.activeTab}\"\n    ></ng-container>\n\n    <ng-container\n      *ngTemplateOutlet=\"\n        tasksListLoading;\n        context: {show: obs.loadingTasks, activeTab: obs.activeTab}\n      \"\n    ></ng-container>\n\n    <valtimo-task-detail-modal\n      #taskDetail\n      (formSubmit)=\"getTasks(currentTaskType)\"\n      (assignmentOfTaskChanged)=\"getTasks(currentTaskType)\"\n    ></valtimo-task-detail-modal>\n  </div>\n</div>\n\n<ng-template #configuredTabs let-activeTab=\"activeTab\">\n  <cds-tabs type=\"contained\" class=\"valtimo-carbon-list__tabs\">\n    <cds-tab\n      *ngFor=\"let tab of visibleTabs\"\n      [heading]=\"'task-list.' + tab + '.title' | translate\"\n      [active]=\"activeTab === tab\"\n      (selected)=\"tabChange(tab)\"\n    ></cds-tab>\n  </cds-tabs>\n</ng-template>\n\n<ng-template #caseLinkWithTaskLock let-data=\"data\">\n  <a\n    class=\"float-left\"\n    cdsLink\n    href=\"javascript:void(0)\"\n    (click)=\"openRelatedCase($event, data.index)\"\n  >\n    {{ 'task-list.goToCase' | translate }}\n  </a>\n  <div *ngIf=\"tasks[currentTaskType].tasks[data.index].isLocked\">\n    <span\n      class=\"float-right badge badge-pill badge-secondary bg-grey\"\n      ngbTooltip=\"{{ 'task-list.taskLocked' | translate }}\"\n    >\n      <i class=\"icon mdi mdi-lock\"></i>\n    </span>\n  </div>\n</ng-template>\n\n<ng-template #tasksList let-show=\"show\" let-activeTab=\"activeTab\">\n  <valtimo-carbon-list\n    [ngClass]=\"{'hide-tasks-list': !show}\"\n    [fields]=\"tasks[currentTaskType].fields\"\n    [header]=\"false\"\n    [items]=\"tasks[currentTaskType].tasks\"\n    [lastColumnTemplate]=\"caseLinkWithTaskLock\"\n    [pagination]=\"tasks[currentTaskType].pagination\"\n    paginationIdentifier=\"taskList\"\n    (paginationClicked)=\"paginationClicked($event, currentTaskType)\"\n    (paginationSet)=\"paginationSet($event)\"\n    (rowClicked)=\"rowOpenTaskClick($event)\"\n    (sortChanged)=\"sortChanged($event)\"\n  >\n    <div tabs>\n      <cds-tabs\n        *ngIf=\"visibleTabs === null; else configuredTabs; context: {activeTab: activeTab}\"\n        type=\"contained\"\n        class=\"valtimo-carbon-list__tabs\"\n      >\n        <cds-tab\n          [heading]=\"'task-list.mine.title' | translate\"\n          (selected)=\"tabChange('mine')\"\n          [active]=\"activeTab === 'mine'\"\n        >\n        </cds-tab>\n\n        <cds-tab\n          [heading]=\"'task-list.open.title' | translate\"\n          (selected)=\"tabChange('open')\"\n          [active]=\"activeTab === 'open'\"\n        >\n        </cds-tab>\n\n        <cds-tab\n          [heading]=\"'task-list.all.title' | translate\"\n          (selected)=\"tabChange('all')\"\n          [active]=\"activeTab === 'all'\"\n        >\n        </cds-tab>\n      </cds-tabs>\n    </div>\n\n    <valtimo-no-results\n      [description]=\"'task-list.' + currentTaskType + '.noResultsDescription' | translate\"\n      [title]=\"'task-list.' + currentTaskType + '.noResultsTitle' | translate\"\n    >\n    </valtimo-no-results>\n  </valtimo-carbon-list>\n</ng-template>\n\n<ng-template #tasksListLoading let-show=\"show\" let-activeTab=\"activeTab\">\n  <valtimo-carbon-list [ngClass]=\"{'hide-tasks-list': !show}\" [loading]=\"true\">\n    <div tabs>\n      <cds-tabs *ngIf=\"visibleTabs === null\" type=\"contained\" class=\"valtimo-carbon-list__tabs\">\n        <cds-tab [heading]=\"'task-list.mine.title' | translate\" [active]=\"activeTab === 'mine'\">\n        </cds-tab>\n\n        <cds-tab [heading]=\"'task-list.open.title' | translate\" [active]=\"activeTab === 'open'\">\n        </cds-tab>\n\n        <cds-tab [heading]=\"'task-list.all.title' | translate\" [active]=\"activeTab === 'all'\">\n        </cds-tab>\n      </cds-tabs>\n\n      <cds-tabs type=\"contained\" class=\"valtimo-carbon-list__tabs\" *ngIf=\"visibleTabs\">\n        <cds-tab\n          *ngFor=\"let tab of visibleTabs\"\n          [heading]=\"'task-list.' + tab + '.title' | translate\"\n          [active]=\"activeTab === tab\"\n        ></cds-tab>\n      </cds-tabs>\n    </div>\n  </valtimo-carbon-list>\n</ng-template>\n"]}
252
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task-list.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/task/src/lib/task-list/task-list.component.ts","../../../../../../projects/valtimo/task/src/lib/task-list/task-list.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 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\nimport {Component, OnDestroy, ViewChild, ViewEncapsulation} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {TaskService} from '../task.service';\nimport moment from 'moment';\nimport {Task, TaskList} from '../models';\nimport {NGXLogger} from 'ngx-logger';\nimport {TaskDetailModalComponent} from '../task-detail-modal/task-detail-modal.component';\nimport {TranslateService} from '@ngx-translate/core';\nimport {BehaviorSubject, combineLatest, of, Subscription, switchMap} from 'rxjs';\nimport {ConfigService, SortState, TaskListTab} from '@valtimo/config';\nimport {DocumentService} from '@valtimo/document';\nimport {take} from 'rxjs/operators';\nimport {PermissionService} from '@valtimo/access-control';\nimport {CAN_VIEW_TASK_PERMISSION, TASK_DETAIL_PERMISSION_RESOURCE} from '../task-permissions';\n\nmoment.locale(localStorage.getItem('langKey') || '');\n\n@Component({\n  selector: 'valtimo-task-list',\n  templateUrl: './task-list.component.html',\n  styleUrls: ['./task-list.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class TaskListComponent implements OnDestroy {\n  @ViewChild('taskDetail') taskDetail: TaskDetailModalComponent;\n  public tasks = {\n    mine: new TaskList(),\n    open: new TaskList(),\n    all: new TaskList(),\n  };\n  public visibleTabs: Array<TaskListTab> | null = null;\n  public currentTaskType = 'mine';\n  public listTitle: string | null = null;\n  public listDescription: string | null = null;\n  public sortState: SortState | null = null;\n  public readonly loadingTasks$ = new BehaviorSubject<boolean>(true);\n  public readonly activeTab$ = new BehaviorSubject<string>('');\n  private _translationSubscription!: Subscription;\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly documentService: DocumentService,\n    private readonly logger: NGXLogger,\n    private readonly permissionService: PermissionService,\n    private readonly router: Router,\n    private readonly taskService: TaskService,\n    private readonly translateService: TranslateService\n  ) {\n    this.visibleTabs = this.configService.config?.visibleTaskListTabs || null;\n    if (this.visibleTabs) {\n      this.currentTaskType = this.visibleTabs[0];\n    }\n    this.setDefaultSorting();\n  }\n\n  public ngOnDestroy(): void {\n    this.closeTranslationSubscription();\n  }\n\n  public paginationClicked(page: number, type: string): void {\n    this.tasks[type].page = page - 1;\n    this.tasks[type].pagination.page = page;\n    this.getTasks(type);\n  }\n\n  public paginationSet(size: number): void {\n    this.tasks.mine.pagination.size =\n      this.tasks.all.pagination.size =\n      this.tasks.open.pagination.size =\n        size;\n    this.getTasks(this.currentTaskType);\n  }\n\n  public tabChange(tab: string): void {\n    this.clearPagination(this.currentTaskType);\n    this.getTasks(tab);\n  }\n\n  public showTask(task: Task): void {\n    this.router.navigate(['tasks', task.id]);\n  }\n\n  public getTasks(type: string): void {\n    this.loadingTasks$.next(true);\n    this.activeTab$.next(type);\n\n    let params: any;\n\n    this.closeTranslationSubscription();\n\n    this._translationSubscription = combineLatest([\n      this.translateService.stream(`task-list.${type}.title`),\n      this.translateService.stream(`task-list.${type}.description`),\n    ]).subscribe(([title, description]) => {\n      this.listTitle = title;\n      this.listDescription = description;\n    });\n\n    switch (type) {\n      case 'mine':\n        params = {\n          page: this.tasks.mine.page,\n          size: this.tasks.mine.pagination.size,\n          filter: 'mine',\n        };\n        this.currentTaskType = 'mine';\n        break;\n      case 'open':\n        params = {\n          page: this.tasks.open.page,\n          size: this.tasks.open.pagination.size,\n          filter: 'open',\n        };\n        this.currentTaskType = 'open';\n        break;\n      case 'all':\n        params = {page: this.tasks.all.page, size: this.tasks.open.pagination.size, filter: 'all'};\n        this.currentTaskType = 'all';\n        break;\n      default:\n        this.logger.fatal('Unreachable case');\n    }\n\n    if (this.sortState) {\n      params.sort = this.getSortString(this.sortState);\n    }\n\n    this.taskService\n      .queryTasks(params)\n      .pipe(\n        switchMap(tasksResult =>\n          combineLatest([\n            of(tasksResult),\n            ...tasksResult.body.map(task =>\n              this.permissionService.requestPermission(CAN_VIEW_TASK_PERMISSION, {\n                resource: TASK_DETAIL_PERMISSION_RESOURCE.task,\n                identifier: task.id,\n              })\n            ),\n          ])\n        )\n      )\n      .subscribe(results => {\n        const tasksResult = results[0];\n        const permissions = results.filter((_, index) => index !== 0);\n\n        this.tasks[type].pagination = {\n          ...this.tasks[type].pagination,\n          collectionSize: tasksResult.headers.get('x-total-count'),\n        };\n        this.tasks[type].tasks = tasksResult.body;\n        this.tasks[type].tasks.map((task, taskIndex) => {\n          task.created = moment(task.created).format('DD MMM YYYY HH:mm');\n          if (task.due) {\n            task.due = moment(task.due).format('DD MMM YYYY HH:mm');\n          }\n          task.isLocked = !permissions[taskIndex];\n        });\n\n        if (this.taskService.getConfigCustomTaskList()) {\n          this.customTaskListFields(type);\n        } else {\n          this.defaultTaskListFields(type);\n        }\n\n        this.loadingTasks$.next(false);\n      });\n  }\n\n  public openRelatedCase(event: MouseEvent, index: number): void {\n    event.stopPropagation();\n\n    const tasks = this.tasks[this.currentTaskType].tasks;\n    const currentTask = tasks && tasks[index];\n\n    if (currentTask) {\n      this.documentService\n        .getDocument(currentTask.businessKey)\n        .pipe(take(1))\n        .subscribe(document => {\n          this.router.navigate([\n            `/dossiers/${document.definitionId?.name}/document/${currentTask.businessKey}`,\n          ]);\n        });\n    }\n  }\n\n  public defaultTaskListFields(type): void {\n    this.closeTranslationSubscription();\n    this._translationSubscription = combineLatest([\n      this.translateService.stream(`task-list.fieldLabels.created`),\n      this.translateService.stream(`task-list.fieldLabels.name`),\n      this.translateService.stream(`task-list.fieldLabels.valtimoAssignee.fullName`),\n      this.translateService.stream(`task-list.fieldLabels.due`),\n      this.translateService.stream(`task-list.fieldLabels.context`),\n    ]).subscribe(([created, name, assignee, due, context]) => {\n      this.tasks[type].fields = [\n        {\n          key: 'created',\n          label: created,\n        },\n        {\n          key: 'name',\n          label: name,\n        },\n        {\n          key: 'valtimoAssignee.fullName',\n          label: assignee,\n        },\n        {\n          key: 'due',\n          label: due,\n        },\n        {\n          key: 'context',\n          label: context,\n        },\n      ];\n    });\n  }\n\n  public customTaskListFields(type): void {\n    const customTaskListFields = this.taskService.getConfigCustomTaskList().fields;\n\n    this.closeTranslationSubscription();\n    this._translationSubscription = combineLatest(\n      customTaskListFields.map(column =>\n        this.translateService.stream(`task-list.fieldLabels.${column.translationKey}`)\n      )\n    ).subscribe(labels => {\n      this.tasks[type].fields = customTaskListFields.map((column, index) => ({\n        key: column.propertyName,\n        label: labels[index],\n        sortable: column.sortable,\n        ...(column.viewType && {viewType: column.viewType}),\n        ...(column.enum && {enum: column.enum}),\n      }));\n    });\n  }\n\n  public rowOpenTaskClick(task): void | boolean {\n    if (!task.endTime && !task.isLocked) {\n      this.taskDetail.openTaskDetails(task);\n    } else {\n      return false;\n    }\n  }\n\n  public setDefaultSorting(): void {\n    this.sortState = this.taskService.getConfigCustomTaskList()?.defaultSortedColumn || null;\n  }\n\n  public sortChanged(sortState: SortState): void {\n    this.sortState = sortState;\n    this.getTasks(this.currentTaskType);\n  }\n\n  public getSortString(sort: SortState): string {\n    return `${sort.state.name},${sort.state.direction}`;\n  }\n\n  private clearPagination(type: string): void {\n    this.tasks[type].page = 0;\n  }\n\n  private closeTranslationSubscription(): void {\n    this._translationSubscription?.unsubscribe();\n  }\n}\n","<!--\n  ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  class=\"main-content\"\n  *ngIf=\"{loadingTasks: loadingTasks$ | async, activeTab: activeTab$ | async} as obs\"\n>\n  <div class=\"container-fluid\">\n    <ng-container\n      *ngTemplateOutlet=\"tasksList; context: {show: !obs.loadingTasks, activeTab: obs.activeTab}\"\n    ></ng-container>\n\n    <ng-container\n      *ngTemplateOutlet=\"\n        tasksListLoading;\n        context: {show: obs.loadingTasks, activeTab: obs.activeTab}\n      \"\n    ></ng-container>\n\n    <valtimo-task-detail-modal\n      #taskDetail\n      (formSubmit)=\"getTasks(currentTaskType)\"\n      (assignmentOfTaskChanged)=\"getTasks(currentTaskType)\"\n    ></valtimo-task-detail-modal>\n  </div>\n</div>\n\n<ng-template #configuredTabs let-activeTab=\"activeTab\">\n  <cds-tabs type=\"contained\" class=\"valtimo-carbon-list__tabs\">\n    <cds-tab\n      *ngFor=\"let tab of visibleTabs\"\n      [heading]=\"'task-list.' + tab + '.title' | translate\"\n      [active]=\"activeTab === tab\"\n      (selected)=\"tabChange(tab)\"\n    ></cds-tab>\n  </cds-tabs>\n</ng-template>\n\n<ng-template #caseLinkWithTaskLock let-data=\"data\">\n  <a\n    class=\"float-left\"\n    cdsLink\n    href=\"javascript:void(0)\"\n    (click)=\"openRelatedCase($event, data.index)\"\n  >\n    {{ 'task-list.goToCase' | translate }}\n  </a>\n  <div *ngIf=\"tasks[currentTaskType].tasks[data.index].isLocked\">\n    <span\n      class=\"float-right badge badge-pill badge-secondary bg-grey\"\n      ngbTooltip=\"{{ 'task-list.taskLocked' | translate }}\"\n    >\n      <i class=\"icon mdi mdi-lock\"></i>\n    </span>\n  </div>\n</ng-template>\n\n<ng-template #tasksList let-show=\"show\" let-activeTab=\"activeTab\">\n  <valtimo-carbon-list\n    [ngClass]=\"{'hide-tasks-list': !show}\"\n    [fields]=\"tasks[currentTaskType].fields\"\n    [header]=\"false\"\n    [items]=\"tasks[currentTaskType].tasks\"\n    [lastColumnTemplate]=\"caseLinkWithTaskLock\"\n    [pagination]=\"tasks[currentTaskType].pagination\"\n    paginationIdentifier=\"taskList\"\n    (paginationClicked)=\"paginationClicked($event, currentTaskType)\"\n    (paginationSet)=\"paginationSet($event)\"\n    (rowClicked)=\"rowOpenTaskClick($event)\"\n    (sortChanged)=\"sortChanged($event)\"\n  >\n    <div tabs>\n      <cds-tabs\n        *ngIf=\"visibleTabs === null; else configuredTabs; context: {activeTab: activeTab}\"\n        type=\"contained\"\n        class=\"valtimo-carbon-list__tabs\"\n      >\n        <cds-tab\n          [heading]=\"'task-list.mine.title' | translate\"\n          (selected)=\"tabChange('mine')\"\n          [active]=\"activeTab === 'mine'\"\n        >\n        </cds-tab>\n\n        <cds-tab\n          [heading]=\"'task-list.open.title' | translate\"\n          (selected)=\"tabChange('open')\"\n          [active]=\"activeTab === 'open'\"\n        >\n        </cds-tab>\n\n        <cds-tab\n          [heading]=\"'task-list.all.title' | translate\"\n          (selected)=\"tabChange('all')\"\n          [active]=\"activeTab === 'all'\"\n        >\n        </cds-tab>\n      </cds-tabs>\n    </div>\n\n    <valtimo-no-results\n      [description]=\"'task-list.' + currentTaskType + '.noResultsDescription' | translate\"\n      [title]=\"'task-list.' + currentTaskType + '.noResultsTitle' | translate\"\n    >\n    </valtimo-no-results>\n  </valtimo-carbon-list>\n</ng-template>\n\n<ng-template #tasksListLoading let-show=\"show\" let-activeTab=\"activeTab\">\n  <valtimo-carbon-list [ngClass]=\"{'hide-tasks-list': !show}\" [loading]=\"true\">\n    <div tabs>\n      <cds-tabs *ngIf=\"visibleTabs === null\" type=\"contained\" class=\"valtimo-carbon-list__tabs\">\n        <cds-tab [heading]=\"'task-list.mine.title' | translate\" [active]=\"activeTab === 'mine'\">\n        </cds-tab>\n\n        <cds-tab [heading]=\"'task-list.open.title' | translate\" [active]=\"activeTab === 'open'\">\n        </cds-tab>\n\n        <cds-tab [heading]=\"'task-list.all.title' | translate\" [active]=\"activeTab === 'all'\">\n        </cds-tab>\n      </cds-tabs>\n\n      <cds-tabs type=\"contained\" class=\"valtimo-carbon-list__tabs\" *ngIf=\"visibleTabs\">\n        <cds-tab\n          *ngFor=\"let tab of visibleTabs\"\n          [heading]=\"'task-list.' + tab + '.title' | translate\"\n          [active]=\"activeTab === tab\"\n        ></cds-tab>\n      </cds-tabs>\n    </div>\n  </valtimo-carbon-list>\n</ng-template>\n"]}