@valtimo/dossier 12.5.1 → 12.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/esm2022/lib/components/dossier-detail/dossier-detail.component.mjs +101 -55
  2. package/esm2022/lib/components/dossier-detail/tab/notes/notes.component.mjs +3 -3
  3. package/esm2022/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.mjs +26 -13
  4. package/esm2022/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.mjs +27 -12
  5. package/esm2022/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.mjs +42 -21
  6. package/esm2022/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.mjs +25 -11
  7. package/esm2022/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.mjs +32 -13
  8. package/esm2022/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.mjs +2 -5
  9. package/esm2022/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.mjs +17 -0
  10. package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.component.mjs +4 -4
  11. package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.permissions.mjs +30 -0
  12. package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.service.mjs +45 -0
  13. package/esm2022/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.mjs +11 -10
  14. package/esm2022/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.mjs +52 -47
  15. package/esm2022/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.mjs +38 -6
  16. package/esm2022/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +84 -7
  17. package/esm2022/lib/components/note-modal/note-modal.component.mjs +3 -3
  18. package/esm2022/lib/models/case-widget-content.model.mjs +1 -1
  19. package/esm2022/lib/models/case-widget-display.model.mjs +1 -1
  20. package/esm2022/lib/models/case-widget.model.mjs +1 -1
  21. package/esm2022/lib/permissions/dossier-detail.permissions.mjs +6 -2
  22. package/esm2022/lib/services/dossier-detail-layout.service.mjs +10 -10
  23. package/fesm2022/valtimo-dossier.mjs +512 -211
  24. package/fesm2022/valtimo-dossier.mjs.map +1 -1
  25. package/lib/components/dossier-detail/dossier-detail.component.d.ts +20 -10
  26. package/lib/components/dossier-detail/dossier-detail.component.d.ts.map +1 -1
  27. package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts +11 -3
  28. package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts.map +1 -1
  29. package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts +12 -4
  30. package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts.map +1 -1
  31. package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts +15 -4
  32. package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts.map +1 -1
  33. package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts +11 -3
  34. package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts.map +1 -1
  35. package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts +11 -3
  36. package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts.map +1 -1
  37. package/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.d.ts +0 -1
  38. package/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.d.ts.map +1 -1
  39. package/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.d.ts +13 -0
  40. package/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.d.ts.map +1 -0
  41. package/lib/components/dossier-detail/tab/widgets/widgets.component.d.ts.map +1 -1
  42. package/lib/components/dossier-detail/tab/widgets/widgets.permissions.d.ts +8 -0
  43. package/lib/components/dossier-detail/tab/widgets/widgets.permissions.d.ts.map +1 -0
  44. package/lib/components/dossier-detail/tab/widgets/widgets.service.d.ts +16 -0
  45. package/lib/components/dossier-detail/tab/widgets/widgets.service.d.ts.map +1 -0
  46. package/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.d.ts +5 -3
  47. package/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.d.ts.map +1 -1
  48. package/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.d.ts +14 -13
  49. package/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.d.ts.map +1 -1
  50. package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +8 -3
  51. package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
  52. package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts +14 -4
  53. package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -1
  54. package/lib/models/case-widget-content.model.d.ts.map +1 -1
  55. package/lib/models/case-widget-display.model.d.ts +6 -2
  56. package/lib/models/case-widget-display.model.d.ts.map +1 -1
  57. package/lib/models/case-widget.model.d.ts +7 -1
  58. package/lib/models/case-widget.model.d.ts.map +1 -1
  59. package/lib/permissions/dossier-detail.permissions.d.ts +2 -1
  60. package/lib/permissions/dossier-detail.permissions.d.ts.map +1 -1
  61. package/lib/services/dossier-detail-layout.service.d.ts +4 -5
  62. package/lib/services/dossier-detail-layout.service.d.ts.map +1 -1
  63. package/package.json +1 -1
@@ -21,12 +21,11 @@ import { CARBON_CONSTANTS, CurrentCarbonTheme, PendingChangesComponent, } from '
21
21
  import { InternalCaseStatusUtils, } from '@valtimo/document';
22
22
  import { NotificationService } from 'carbon-components-angular';
23
23
  import moment from 'moment';
24
- import { BehaviorSubject, catchError, combineLatest, filter, map, of, startWith, Subject, Subscription, switchMap, take, tap, } from 'rxjs';
24
+ import { BehaviorSubject, combineLatest, filter, map, of, startWith, Subject, Subscription, switchMap, take, tap, } from 'rxjs';
25
25
  import { DOSSIER_DETAIL_DEFAULT_DISPLAY_SIZE, DOSSIER_DETAIL_DEFAULT_DISPLAY_TYPE, DOSSIER_DETAIL_GUTTER_SIZE, } from '../../constants';
26
26
  import { TabLoaderImpl } from '../../models';
27
- import { CAN_ASSIGN_CASE_PERMISSION, CAN_CLAIM_CASE_PERMISSION, DOSSIER_DETAIL_PERMISSION_RESOURCE, } from '../../permissions';
27
+ import { CAN_ASSIGN_CASE_PERMISSION, CAN_CLAIM_CASE_PERMISSION, CAN_DELETE_CASE_PERMISSION, CAN_VIEW_CASE_PERMISSION, DOSSIER_DETAIL_PERMISSION_RESOURCE, } from '../../permissions';
28
28
  import { DossierDetailLayoutService, DossierTabService } from '../../services';
29
- import { isBoolean } from 'lodash';
30
29
  import * as i0 from "@angular/core";
31
30
  import * as i1 from "@valtimo/components";
32
31
  import * as i2 from "@valtimo/document";
@@ -38,7 +37,7 @@ import * as i7 from "ngx-logger";
38
37
  import * as i8 from "@valtimo/access-control";
39
38
  import * as i9 from "@ngx-translate/core";
40
39
  import * as i10 from "@angular/router";
41
- import * as i11 from "@valtimo/task";
40
+ import * as i11 from "./tab/widgets/widgets.service";
42
41
  import * as i12 from "@valtimo/security";
43
42
  import * as i13 from "@angular/common";
44
43
  import * as i14 from "@ng-bootstrap/ng-bootstrap";
@@ -52,7 +51,7 @@ export class DossierDetailComponent extends PendingChangesComponent {
52
51
  get activeTabName$() {
53
52
  return combineLatest([this.route.paramMap, this._activeTabName$]).pipe(map(([paramMap, activeTabName]) => !activeTabName ? (paramMap.get('tab') ?? null) : activeTabName));
54
53
  }
55
- constructor(breadcrumbService, caseStatusService, cdsThemeService, componentFactoryResolver, configService, documentService, dossierDetailLayoutService, dossierService, dossierTabService, iconService, keyCloakService, logger, notificationService, pageHeaderService, pageTitleService, permissionService, translateService, renderer, route, router, taskService, userProviderService, htmlDocument) {
54
+ constructor(breadcrumbService, caseStatusService, cdsThemeService, componentFactoryResolver, configService, documentService, dossierDetailLayoutService, dossierService, dossierTabService, iconService, keyCloakService, logger, notificationService, pageHeaderService, pageTitleService, permissionService, translateService, renderer, route, router, widgetsService, userProviderService, htmlDocument) {
56
55
  super();
57
56
  this.breadcrumbService = breadcrumbService;
58
57
  this.caseStatusService = caseStatusService;
@@ -74,7 +73,7 @@ export class DossierDetailComponent extends PendingChangesComponent {
74
73
  this.renderer = renderer;
75
74
  this.route = route;
76
75
  this.router = router;
77
- this.taskService = taskService;
76
+ this.widgetsService = widgetsService;
78
77
  this.userProviderService = userProviderService;
79
78
  this.htmlDocument = htmlDocument;
80
79
  this.customDossierHeaderItems = [];
@@ -87,10 +86,19 @@ export class DossierDetailComponent extends PendingChangesComponent {
87
86
  this.isAdmin$ = this.userProviderService
88
87
  .getUserSubject()
89
88
  .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));
90
- this.taskOpenedInPanel$ = this.dossierDetailLayoutService.taskOpenedInPanel$;
89
+ this.taskAndProcessLinkOpenedInPanel$ = this.dossierDetailLayoutService.taskAndProcessLinkOpenedInPanel$;
91
90
  this._caseStatusKey$ = new BehaviorSubject(null);
91
+ this._taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;
92
92
  this.caseStatusKey$ = this._caseStatusKey$.pipe(filter(key => !!key));
93
- this.document$ = this.dossierService.refreshDocument$.pipe(switchMap(() => this.route.params), map((params) => params?.documentId), switchMap((documentId) => documentId ? this.documentService.getDocument(this.documentId) : of(null)), tap((document) => {
93
+ this.showDeleteModal$ = new BehaviorSubject(false);
94
+ this.canView$ = this.route.paramMap.pipe(switchMap((params) => this.permissionService.requestPermission(CAN_VIEW_CASE_PERMISSION, {
95
+ resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,
96
+ identifier: params.get('documentId') ?? '',
97
+ })));
98
+ this.document$ = combineLatest([
99
+ this.dossierService.refreshDocument$,
100
+ this.canView$,
101
+ ]).pipe(filter(([_, canView]) => canView), switchMap(() => this.route.params), map((params) => params?.documentId), switchMap((documentId) => documentId ? this.documentService.getDocument(this.documentId) : of(null)), tap((document) => {
94
102
  if (document) {
95
103
  this.assigneeId$.next(document.assigneeId);
96
104
  this.document = document;
@@ -127,15 +135,21 @@ export class DossierDetailComponent extends PendingChangesComponent {
127
135
  resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,
128
136
  identifier: params.get('documentId') ?? '',
129
137
  })));
138
+ this.isDeleting$ = new BehaviorSubject(false);
139
+ this.canDelete$ = this.route.paramMap.pipe(switchMap((params) => this.permissionService.requestPermission(CAN_DELETE_CASE_PERMISSION, {
140
+ resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,
141
+ identifier: params.get('documentId') ?? '',
142
+ })));
130
143
  this.loadingTabs$ = new BehaviorSubject(true);
131
144
  this.noTabsConfigured$ = new BehaviorSubject(false);
145
+ this.showNoAccess$ = new BehaviorSubject(false);
132
146
  this.compactMode$ = this.pageHeaderService.compactMode$;
133
147
  this.tabHorizontalOverflowDisabled = this.dossierTabService.tabHorizontalOverflowDisabled;
134
148
  this.showTaskList$ = this.dossierTabService.showTaskList$;
135
149
  this._activeTabName$ = new BehaviorSubject(null);
136
150
  this.DOSSIER_DETAIL_GUTTER_SIZE = DOSSIER_DETAIL_GUTTER_SIZE;
137
151
  this.dossierDetailLayout$ = this.dossierDetailLayoutService.dossierDetailLayout$;
138
- this.openTaskInModal$ = new Subject();
152
+ this.openTaskAndProcessLinkInModal$ = new Subject();
139
153
  this.isDarkMode$ = this.cdsThemeService.currentTheme$.pipe(map(currentTheme => currentTheme === CurrentCarbonTheme.G90));
140
154
  this._activeChange = false;
141
155
  this._tabsInit = false;
@@ -147,12 +161,12 @@ export class DossierDetailComponent extends PendingChangesComponent {
147
161
  ngAfterViewInit() {
148
162
  this.initTabLoader();
149
163
  this.initBreadcrumb();
150
- this.getAllAssociatedProcessDefinitions();
151
164
  this.openWidthObserver();
152
165
  this.pageTitleService.disableReset();
153
166
  this.iconService.registerAll([ChevronDown16]);
154
167
  this.setDocumentStyle();
155
168
  this.enableResetOnBackNavigation();
169
+ this.openWidgetProcessSubscription();
156
170
  }
157
171
  ngOnDestroy() {
158
172
  this.breadcrumbService.clearSecondBreadcrumb();
@@ -162,7 +176,7 @@ export class DossierDetailComponent extends PendingChangesComponent {
162
176
  }
163
177
  getAllAssociatedProcessDefinitions() {
164
178
  this.documentService
165
- .findProcessDocumentDefinitionsByStartableByUser(this.documentDefinitionName, true)
179
+ .findProcessDocumentDefinitionsForDocument(this.documentId, { startableByUser: true })
166
180
  .subscribe((processDocumentDefinitions) => {
167
181
  this.processDocumentDefinitions = processDocumentDefinitions;
168
182
  this.processDefinitionListFields = [
@@ -176,6 +190,13 @@ export class DossierDetailComponent extends PendingChangesComponent {
176
190
  startProcess(processDocumentDefinition) {
177
191
  this.supportingProcessStart.openModal(processDocumentDefinition, this.documentId);
178
192
  }
193
+ openWidgetProcessSubscription() {
194
+ this._subscriptions.add(this.widgetsService.startProcessEvent
195
+ .pipe(switchMap(() => this.widgetsService.activeProcess$))
196
+ .subscribe((processDocumentDefinitions) => {
197
+ this.startProcess(processDocumentDefinitions[0]);
198
+ }));
199
+ }
179
200
  claimAssignee() {
180
201
  this.isAssigning$.next(true);
181
202
  this.userId$
@@ -206,29 +227,45 @@ export class DossierDetailComponent extends PendingChangesComponent {
206
227
  },
207
228
  });
208
229
  }
209
- onTaskClickEvent(task) {
210
- this.taskService
211
- .getTaskProcessLink(task.id)
212
- .pipe(catchError(() => this.isAdmin$))
213
- .subscribe((result) => {
214
- if (isBoolean(result)) {
215
- this.handleNoTaskProcessLink(result);
216
- return;
217
- }
218
- const displayType = result.properties.formDisplayType || DOSSIER_DETAIL_DEFAULT_DISPLAY_TYPE;
219
- const size = result.properties.formSize || DOSSIER_DETAIL_DEFAULT_DISPLAY_SIZE;
220
- this.dossierDetailLayoutService.setFormDisplaySize(size);
221
- this.dossierDetailLayoutService.setFormDisplayType(displayType);
222
- if (displayType === 'panel') {
223
- this.dossierDetailLayoutService.setTaskOpenedInPanel(task);
224
- }
225
- else {
226
- this.openTaskInModal$.next({ ...task });
227
- }
230
+ deleteDocument() {
231
+ this.showDeleteModal$.next(true);
232
+ }
233
+ onConfirmDelete() {
234
+ this.isDeleting$.next(true);
235
+ this.documentService.deleteDocument(this.documentId).subscribe({
236
+ next: () => {
237
+ this.isDeleting$.next(false);
238
+ this.showDeleteModal$.next(false);
239
+ this.router.navigate([`/dossiers/${this.documentDefinitionName}`]);
240
+ },
241
+ error: () => {
242
+ this.isDeleting$.next(false);
243
+ this.logger.debug('Something went wrong while deleting the case');
244
+ },
228
245
  });
229
246
  }
247
+ onTaskClickEvent(taskProcessLinkResult) {
248
+ if (!taskProcessLinkResult.processLinkActivityResult) {
249
+ this.isAdmin$.pipe(take(1)).subscribe(isAdmin => {
250
+ this.handleNoTaskProcessLink(isAdmin);
251
+ });
252
+ return;
253
+ }
254
+ const displayType = taskProcessLinkResult.processLinkActivityResult.properties.formDisplayType ||
255
+ DOSSIER_DETAIL_DEFAULT_DISPLAY_TYPE;
256
+ const size = taskProcessLinkResult.processLinkActivityResult.properties.formSize ||
257
+ DOSSIER_DETAIL_DEFAULT_DISPLAY_SIZE;
258
+ this.dossierDetailLayoutService.setFormDisplaySize(size);
259
+ this.dossierDetailLayoutService.setFormDisplayType(displayType);
260
+ if (displayType === 'panel' && !!this._taskPanelToggle) {
261
+ this.dossierDetailLayoutService.setTaskAndProcessLinkOpenedInPanel(taskProcessLinkResult);
262
+ }
263
+ else {
264
+ this.openTaskAndProcessLinkInModal$.next({ ...taskProcessLinkResult });
265
+ }
266
+ }
230
267
  onTaskDetailsClose() {
231
- this.dossierDetailLayoutService.setTaskOpenedInPanel(null);
268
+ this.dossierDetailLayoutService.setTaskAndProcessLinkOpenedInPanel(null);
232
269
  }
233
270
  onActiveChangeEvent(event) {
234
271
  this._activeChange = event;
@@ -250,12 +287,12 @@ export class DossierDetailComponent extends PendingChangesComponent {
250
287
  return;
251
288
  }
252
289
  if (!tab.showTasks)
253
- this.openTaskInModal$.next(null);
290
+ this.openTaskAndProcessLinkInModal$.next(null);
254
291
  this.tabLoader.load(tab);
255
292
  this.setDocumentStyle();
256
293
  }
257
294
  onFormSubmitEvent() {
258
- this.dossierDetailLayoutService.setTaskOpenedInPanel(null);
295
+ this.dossierDetailLayoutService.setTaskAndProcessLinkOpenedInPanel(null);
259
296
  if (!this.tabLoader)
260
297
  return;
261
298
  this.tabLoader.refreshView();
@@ -266,7 +303,7 @@ export class DossierDetailComponent extends PendingChangesComponent {
266
303
  this._activeChange = false;
267
304
  this._activeTabName$.next(this._pendingTab.name);
268
305
  this.tabLoader.load(this._pendingTab);
269
- this.dossierDetailLayoutService.setTaskOpenedInPanel(null);
306
+ this.dossierDetailLayoutService.setTaskAndProcessLinkOpenedInPanel(null);
270
307
  }
271
308
  onCancelRedirect() {
272
309
  if (!this.tabLoader)
@@ -282,17 +319,26 @@ export class DossierDetailComponent extends PendingChangesComponent {
282
319
  });
283
320
  }
284
321
  initTabLoader() {
285
- this.dossierTabService.tabs$.pipe(take(1)).subscribe(tabs => {
286
- if (tabs?.length > 0) {
287
- this._initialTabName = this._snapshot.get('tab') ?? '';
288
- this.tabLoader = new TabLoaderImpl(tabs, this.componentFactoryResolver, this.viewContainerRef, this.router, this.route);
289
- this.tabLoader.initial(this._initialTabName);
290
- this.dossierTabService.setTabLoader(this.tabLoader);
291
- this.loadingTabs$.next(false);
292
- this.activeTab$ = this.tabLoader.activeTab$;
322
+ combineLatest([this.dossierTabService.tabs$, this.canView$])
323
+ .pipe(take(1))
324
+ .subscribe(([tabs, canView]) => {
325
+ if (canView) {
326
+ if (tabs?.length > 0) {
327
+ this._initialTabName = this._snapshot.get('tab') ?? '';
328
+ this.tabLoader = new TabLoaderImpl(tabs, this.componentFactoryResolver, this.viewContainerRef, this.router, this.route);
329
+ this.tabLoader.initial(this._initialTabName);
330
+ this.dossierTabService.setTabLoader(this.tabLoader);
331
+ this.loadingTabs$.next(false);
332
+ this.activeTab$ = this.tabLoader.activeTab$;
333
+ }
334
+ else {
335
+ this.noTabsConfigured$.next(true);
336
+ this.loadingTabs$.next(false);
337
+ }
338
+ this.getAllAssociatedProcessDefinitions();
293
339
  }
294
340
  else {
295
- this.noTabsConfigured$.next(true);
341
+ this.showNoAccess$.next(true);
296
342
  this.loadingTabs$.next(false);
297
343
  }
298
344
  });
@@ -332,13 +378,6 @@ export class DossierDetailComponent extends PendingChangesComponent {
332
378
  getNestedProperty(obj, path, defaultValue) {
333
379
  return (path.split('.').reduce((currentObject, key) => currentObject?.[key], obj) || defaultValue);
334
380
  }
335
- enableResetOnBackNavigation() {
336
- this._subscriptions.add(this.router.events
337
- .pipe(filter(event => event instanceof NavigationStart && event.navigationTrigger === 'popstate'))
338
- .subscribe(() => {
339
- this.pageTitleService.enableReset();
340
- }));
341
- }
342
381
  setBreadcrumb() {
343
382
  this.breadcrumbService.setSecondBreadcrumb({
344
383
  route: [`/dossiers/${this.documentDefinitionName}`],
@@ -366,6 +405,13 @@ export class DossierDetailComponent extends PendingChangesComponent {
366
405
  removeDocumentStyle() {
367
406
  this.renderer.removeClass(this.htmlDocument.getElementsByTagName('html')[0], 'html--fixed');
368
407
  }
408
+ enableResetOnBackNavigation() {
409
+ this._subscriptions.add(this.router.events
410
+ .pipe(filter(event => event instanceof NavigationStart && event.navigationTrigger === 'popstate'))
411
+ .subscribe(() => {
412
+ this.pageTitleService.enableReset();
413
+ }));
414
+ }
369
415
  handleNoTaskProcessLink(isAdmin) {
370
416
  this.notificationService.showActionable({
371
417
  type: 'warning',
@@ -382,13 +428,13 @@ export class DossierDetailComponent extends PendingChangesComponent {
382
428
  duration: CARBON_CONSTANTS.notificationDuration,
383
429
  });
384
430
  }
385
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailComponent, deps: [{ token: i1.BreadcrumbService }, { token: i2.CaseStatusService }, { token: i1.CdsThemeService }, { token: i0.ComponentFactoryResolver }, { token: i3.ConfigService }, { token: i2.DocumentService }, { token: i4.DossierDetailLayoutService }, { token: i4.DossierService }, { token: i4.DossierTabService }, { token: i5.IconService }, { token: i6.KeycloakService }, { token: i7.NGXLogger }, { token: i5.NotificationService }, { token: i1.PageHeaderService }, { token: i1.PageTitleService }, { token: i8.PermissionService }, { token: i9.TranslateService }, { token: i0.Renderer2 }, { token: i10.ActivatedRoute }, { token: i10.Router }, { token: i11.TaskService }, { token: i12.UserProviderService }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
386
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierDetailComponent, selector: "valtimo-dossier-detail", providers: [DossierTabService, DossierDetailLayoutService, NotificationService], viewQueries: [{ propertyName: "supportingProcessStart", first: true, predicate: ["supportingProcessStartModal"], descendants: true }, { propertyName: "viewContainerRef", first: true, predicate: ["tabContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_tabContentContainer", first: true, predicate: ["tabContentContainer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n<div\n class=\"main-content\"\n [ngClass]=\"{'main-content--no-horizontal-overflow': tabHorizontalOverflowDisabled()}\"\n>\n <div class=\"container-fluid\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n\n <ng-template #tabs>\n <ng-container *ngIf=\"{activeTab: activeTab$ | async} as obs\">\n <cds-tabs *ngIf=\"tabLoader\" type=\"inline\" class=\"case-detail-tabs\">\n <cds-tab\n *ngFor=\"let tab of tabLoader.tabs\"\n [active]=\"tab.name === (activeTabName$ | async)\"\n heading=\"{{ tab | tabTranslate | async }}\"\n (selected)=\"onTabSelected(tab, obs.activeTab)\"\n ></cds-tab>\n </cds-tabs>\n </ng-container>\n </ng-template>\n\n <div\n #tabContentContainer\n class=\"tab-content-container\"\n [ngClass]=\"{\n 'tab-content-container--dark': isDarkMode$ | async,\n 'tab-content-container--compact': compactMode$ | async,\n }\"\n *ngIf=\"{\n noTabsConfigured: noTabsConfigured$ | async,\n showTaskList: showTaskList$ | async,\n taskOpenedInPanel: taskOpenedInPanel$ | async,\n dossierDetailLayout: dossierDetailLayout$ | async,\n } as tabContentObs\"\n >\n <as-split\n direction=\"horizontal\"\n [disabled]=\"!tabContentObs.dossierDetailLayout.widthAdjustable\"\n [gutterSize]=\"DOSSIER_DETAIL_GUTTER_SIZE\"\n [unit]=\"tabContentObs.dossierDetailLayout.unit\"\n >\n <as-split-area\n [size]=\"tabContentObs.dossierDetailLayout.leftPanelWidth\"\n [minSize]=\"tabContentObs.dossierDetailLayout.leftPanelMinWidth\"\n [maxSize]=\"tabContentObs.dossierDetailLayout.leftPanelMaxWidth\"\n >\n <div\n class=\"card-body bg-white p-5 position-relative tab-container\"\n [class.tab-container--compact]=\"compactMode$ | async\"\n >\n <div *ngIf=\"loadingTabs$ | async\" class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n\n <valtimo-no-results\n *ngIf=\"tabContentObs.noTabsConfigured\"\n [description]=\"'dossier.tabs.noResultsDescription' | translate\"\n [title]=\"'dossier.tabs.noResults' | translate\"\n ></valtimo-no-results>\n\n <ng-template #tabContainer></ng-template>\n\n <div class=\"clearfix\"></div>\n </div>\n </as-split-area>\n\n <as-split-area\n *ngIf=\"tabContentObs.dossierDetailLayout.showRightPanel\"\n [size]=\"tabContentObs.dossierDetailLayout.rightPanelWidth\"\n [minSize]=\"tabContentObs.dossierDetailLayout.rightPanelMinWidth\"\n [maxSize]=\"tabContentObs.dossierDetailLayout.rightPanelMaxWidth\"\n >\n @if (tabContentObs.showTaskList) {\n <div class=\"task-panel\">\n @if (!tabContentObs.taskOpenedInPanel) {\n <valtimo-dossier-detail-task-list\n [openInTaskModal]=\"openTaskInModal$ | async\"\n (taskClickEvent)=\"onTaskClickEvent($event)\"\n (formSubmitEvent)=\"onFormSubmitEvent()\"\n ></valtimo-dossier-detail-task-list>\n }\n\n @if (tabContentObs.taskOpenedInPanel) {\n <valtimo-dossier-detail-task-detail\n [task]=\"tabContentObs.taskOpenedInPanel\"\n (activeChange)=\"onActiveChangeEvent($event)\"\n (closeEvent)=\"onTaskDetailsClose()\"\n (formSubmit)=\"onFormSubmitEvent()\"\n >\n </valtimo-dossier-detail-task-detail>\n }\n </div>\n }\n </as-split-area>\n </as-split>\n </div>\n </div>\n\n <valtimo-dossier-supporting-process-start-modal\n [isAdmin]=\"isAdmin$ | async\"\n (formSubmit)=\"tabLoader.refreshView()\"\n #supportingProcessStartModal\n ></valtimo-dossier-supporting-process-start-modal>\n</div>\n\n<ng-template\n #caseDetailHeader\n let-canHaveAssignee=\"canHaveAssignee\"\n let-document=\"document\"\n let-canAssign=\"canAssign\"\n>\n <div class=\"row\" *ngIf=\"(customDossierHeaderItems || []).length > 0\">\n <span\n *ngFor=\"let item of customDossierHeaderItems\"\n [ngClass]=\"{\n h1: item.textSize === 'xl',\n h2: item.textSize === 'lg',\n h3: item.textSize === 'md',\n h4: item.textSize === 'sm',\n h5: item.textSize === 'xs',\n }\"\n class=\"mb-0 mt-0 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n item.columnSize * 2\n }} {{ item.customClass }}\"\n >\n <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n\n <span *ngIf=\"item.label && item.value\">: </span>\n\n <strong>{{ item.value }}</strong>\n </span>\n </div>\n\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailAssignee;\n context: {canHaveAssignee: canHaveAssignee, document: document, canAssign: canAssign}\n \"\n ></ng-container>\n</ng-template>\n\n<ng-template\n #caseDetailAssignee\n let-canHaveAssignee=\"canHaveAssignee\"\n let-document=\"document\"\n let-canAssign=\"canAssign\"\n>\n <div *ngIf=\"canHaveAssignee && document\">\n <valtimo-dossier-assign-user\n *ngIf=\"canAssignLoaded$ | async\"\n [assigneeFullName]=\"document?.assigneeFullName\"\n [assigneeId]=\"document.assigneeId\"\n [documentId]=\"document.id\"\n [hasPermission]=\"canAssign\"\n (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n ></valtimo-dossier-assign-user>\n </div>\n</ng-template>\n\n<ng-template #claimButton let-canClaim=\"canClaim\" let-canHaveAssignee=\"canHaveAssignee\">\n <cds-overflow-menu-option\n *ngIf=\"canClaim && canHaveAssignee\"\n [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n (click)=\"claimAssignee()\"\n >\n <span>{{ 'dossier.claimAssigneeCase' | translate }}</span>\n </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #customStartTrigger>\n <button\n [size]=\"(compactMode$ | async) ? 'sm' : 'lg'\"\n cdsButton=\"primary\"\n [disabled]=\"processDocumentDefinitions.length === 0\"\n [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n >\n {{ 'dossier.startSubProcess' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"chevron--down\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-container renderInPageHeader [fullWidth]=\"true\">\n <ng-template>\n <div\n class=\"dossier-actions\"\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n *ngIf=\"{\n assigneeId: assigneeId$ | async,\n canAssign: canAssign$ | async,\n canClaim: canClaim$ | async,\n canHaveAssignee: canHaveAssignee$ | async,\n document: document$ | async,\n caseStatus: caseStatus$ | async,\n } as obs\"\n >\n <div\n class=\"dossier-status-assign-custom-title\"\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n >\n @if (obs.caseStatus) {\n <cds-tag size=\"sm\" [type]=\"obs.caseStatus.tagType\">{{ obs.caseStatus.title }}</cds-tag>\n }\n\n <div class=\"dossier-assign-user\" [ngClass]=\"{'--compact': compactMode$ | async}\">\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailAssignee;\n context: {\n canHaveAssignee: obs.canHaveAssignee,\n document: obs.document,\n canAssign: obs.canAssign,\n }\n \"\n ></ng-container>\n </div>\n\n <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n </div>\n\n <div class=\"buttons-container\">\n <cds-overflow-menu\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n *ngIf=\"obs.canHaveAssignee\"\n flip=\"true\"\n [offset]=\"(compactMode$ | async) ? {y: 48, x: -4} : {y: 48, x: 4}\"\n class=\"overflow-button assign-overflow\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n claimButton;\n context: {canClaim: obs.canClaim, canHaveAssignee: obs.canHaveAssignee}\n \"\n >\n </ng-container>\n <cds-overflow-menu-option (selected)=\"unassignAssignee()\" [disabled]=\"!obs.assigneeId\">\n {{ 'assignDocument.remove' | translate }}\n </cds-overflow-menu-option>\n </cds-overflow-menu>\n\n <cds-overflow-menu\n valtimoCdsOverflowButton\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n [width]=\"250\"\n [customTrigger]=\"customStartTrigger\"\n [offset]=\"{y: 48, x: 35}\"\n class=\"overflow-button case-detail-overflow\"\n >\n <cds-overflow-menu-option\n *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n (click)=\"startProcess(processDocumentDefinition)\"\n >\n {{\n (processDocumentDefinition?.id?.processDefinitionKey | translate) !==\n processDocumentDefinition?.id?.processDefinitionKey\n ? (processDocumentDefinition.id.processDefinitionKey | translate)\n : processDocumentDefinition.processName\n }}\n </cds-overflow-menu-option>\n </cds-overflow-menu>\n </div>\n </div>\n </ng-template>\n</ng-container>\n", styles: [".main-content{overflow:hidden;padding-bottom:0}.main-content--no-horizontal-overflow{overflow-x:hidden}.tab-container{height:min-content;min-height:300px;overflow-y:auto;max-height:calc(100vh - 226px);overflow-x:hidden}.tab-container--compact{max-height:calc(100vh - 176px)}.tab-container:has(>.tab--no-margin){padding:0!important}.tab-container:has(>.tab--no-min-height){min-height:unset}.tab-container:has(>.tab--no-background){background:transparent!important}.tab-content-container{overflow:hidden;display:flex;gap:32px;overflow:auto;margin-bottom:16px;max-height:calc(100vh - 226px)}.tab-content-container--compact{max-height:calc(100vh - 176px)}.loading-container{display:flex;justify-content:center;flex-direction:row}.dossier-detail-page-header{display:flex;width:100%;justify-content:flex-start;padding-bottom:5px}.dossier-detail-page-header ::ng-deep .cds--tag{margin:0}.case-detail-tabs{display:flex;margin-bottom:24px}.case-detail-tabs cds-tab{display:none!important}.cds--overflow-menu-options{margin-top:32px}.assign-overflow{margin-right:8px}.buttons-container{display:flex;flex-direction:row}.dossier-actions{display:flex;width:100%;justify-content:space-between;align-items:flex-end;padding-bottom:4px}.dossier-actions.--compact{padding-bottom:0;align-items:flex-start}.dossier-actions ::ng-deep .version-selection{width:160px}.dossier-actions ::ng-deep .version-selection .cds--list-box__selection{display:none}.dossier-status-assign-custom-title{display:flex;gap:16px;align-items:flex-end}.dossier-status-assign-custom-title .cds--tag{margin:0;height:var(--cds-layout-size-height-md)}.dossier-status-assign-custom-title.--compact{align-items:center}.task-panel{width:100%;transition:height .15s ease-in-out}:host ::ng-deep .container-fluid{height:100%!important;width:100%!important;margin:0!important;padding:0!important}::ng-deep .tab-content-container .as-split-gutter{background-color:transparent!important;--_as-gutter-icon-disabled: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mP8/wcAAgEBAYcDngAAAAAASUVORK5CYII=);--_as-gutter-icon-horizontal: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAABQJJREFUeF7dWll22zAMpNwzlM5xmpMlOVl6mzrKHexWm8UFy4xIp+/FP3mxQWAwWAiRGsJ3/gwhhJvt4CRCfgCtosYhDOHm4SlW7rZyq9t/R7GsZoYQDhCA89UIrzakKuQtpRTiHv03ycJB3t8KuU9AByNfw5dWJpj1h5YABmGRsvgufzsSG21NEwGWUrv5yiuZb31yMZoAAjBFPqBdor9G0vpwu2+PBgE6TK/q0pUxxiwZxnE0SefkE0sHWQUygGG3ll0c2tGNn+M0DiSfHDlHQBu2rffoWgBWPRHWIUreM654li5bMwDQBIhI9naHFgVQCSS2PHliWlLm0/YsMrcwK6ISp1QGANhzG7XFDj2gUFr8yzrkydOJ6CyACBB1lIWkbPyeQ2UQ2ZKxksCLft4EaWqB/AshHCdg0b/1gB7wJB1QBrQ0ml4E2MMyFgxJ6iABuEGdgCUeZVQm+fQ7fhfAsflzAKFLS1G2ptmMwUpDl1oyAGxo2fw2hHBzjpsm+XiO2TGQF1GWACJGfecAjHmgCTZum/lQfezQTZ3L7z+g3goc2xGtFT86A0qLh5pgjPF13aLmv9aHdYiVn8uMwFNixQlYqVuNvayK3sZxNElgHarlP6duo2bpOcbXWxheVhkTj7Tv4ATsTG/OL6CG8DZ+KCQMIcSf6HnAAo8hrAjGRpIblLxveDm8/q4YC6fT6flyufzWBhXGoTWd4QOUp6enX9fr9X2od6SFhJlTu4FBGZA5n+jbnddZjPG8nz8lo222ItHJEraRICAAMmG6rPGb2FTjedqHsET+4/Lbu+phHWLlJ/g+Cd4gpJDgp71HHzAHFCqOEFCSULjrNkaxw2rO/zidnv/MNY99WIcY+TKufibUmOcSEB5IxLTHXLal2FG4h83VPzET1h6wUxDP8fXfJW5V8xuQhqFwVtGNgDuQ6Yo367Pb9ixdjVckVE1QS/0ekZhybRw/zMZblkBpd1sMPIdJkAsClF2ghQQPYJYBQjp5BKCBEHD4JZDi6bED3AebRDFbAp58Ski3JrgphQcgozEwXZ2dBH3nZ2Bq5KcyahuEgO1wIWBnyIuoS5hA9pHIp01dnANSdlvKwXWocRC6Pw/U70MBozCQAWI5JKDF5wFrtk8uR6XKYQibnL9dr+/CjgA5v81AamMFByTTmOhQp56hPw5/vrrvx61euz2gZKfHgcj98bUkgjo/WJCxeMrJFyQgR8ocQcGnwqsJpgSK8pymTPeIThus4DKwBKWJFNsFklEcOT9ApyFADswAQJMiwkaUldeQ7ZTKDWf79tsSgIasDwGduro1CbY+hVqZgpJ1SA5L6bQHMJNjOy19MsCgBiNgV8DK+1GxSXoYAcMwhNttOedPIZTPAhm8bQ6Anx57ZMBGgfHuXs6yuEANBBtR/2bIjzkj8bAMSIYU+KLDaoKSU8KFCOP7LAsTcDTZ2jPAfrUWf3VGnwdo1pgF5xiz9yhazwOExwfv9suEm2XArJwNtSP/+AxgwlHL1iVwiAUdhEaAxhtLWGbZDEbPEiCyhHWIla93KO7AvMoAwre7bW5jxCAfwaHnoa4N3gVU5X2RthX0gdVNBPhDZnYgzMH7ImKbCOA8wnfsVO+jeUgIEHfYFUs7jHYNLN2YvJkBXwYaNuQIwnp2cgoCag3LN1Z2+EwfwCVPLPAOJ1n05oDt9x5oRR37Pb72s/e+kU81L/EXSRwjcUdkvjUAAAAASUVORK5CYII=)}::ng-deep .tab-content-container .as-split-gutter-icon{background-repeat:no-repeat;background-size:16px 16px}::ng-deep .tab-content-container--dark .as-split-gutter{--_as-gutter-icon-horizontal: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAABPlJREFUeF7tm1tW3DAMhu2+krCmdmWlKytrIuGV9HjixDddfjkOtOd0XmAGWZfPsiw7g3fVyzvntvpD9H01+JIuwCamX5YKf9VfmCVaDze2S2fXIDG+CGC8YsrqMCvDFDmHZYCeI5gE6LietD2LlNb6uQAQTLWfCDTLmLpOIfoRvxEZydZn+pH7+vdlAEJyoIwIwDIrFtk7C2TyA/Po9gxY1zVWrN2haZq85FqS3zEF+YET3qi6rFzjfAR0yGkBwQA0wyFU75zf5MaOBYDoR2YGDigqY+U7HOKHlAsFiQOXqax+JYCYBGJr32ZAB+lEpxwc3i1nDcDWtBUYPjN8p35VBxf/4/MQUI7lqAGPzwjYBQDv3PQ0+Ue/CjV/sODp8+UiyNE7XLHO6EM+Dg4/ntBdAI69zdIqBlgTlDldADLN9a7R551cDot0kDPNbn40AIh6LSS4DS0Be9jJg7sAXPHJfBZojbXriMscGgDvvhUYmRGEes6iocJiyVejWdelYDPNk5cquhnAxVSAlgDZQG/7bUqKjvZEDqgdYwaAzQsrVQHowFkPqd5bA4LlO1ytp+zoFM0Ml2V5CYPmeX78lF7v67rla8B6GpynKZxnxBfmD03MvASCMe/9z+DRtm2/SAiZLXRGqcapbYTaICB/BHwggN1wbuzQSUHI3UQBHPqo+wPO/7dlefkWJ0PyR0ofEIAjg49Z8GOe51fOCAYgIcPkd2vLsnz33v+ubadJ0TZw8Fqcmnkk+CBjCahHXodQ49mhHGjUDJCDf37Vjmn54Sa4MuxGaL/weWzDdggJigjgDL7KpG3bxLTPmY/PALqa90JgAahpf/ohb8jjAfAlrQdCCSDG0gRPxCiHzf81XwKUVA1M7gDwbojbspsM4GZea3jov5cFp6cGoHYRFCWE5FthQwKAGCnLS9vD6UXwXbnIRpGUcsH3D6JxI2sADwFHwEnqAI4HKW0AB07ci6QDXgLHELUIghPxbxRBBukICDuAZMCaAbu8XnLf1K4wzBjdGYpzSUGI66ntBQg/8QzYB+PyyW18++sAEHvu8wSY02IbosyONaBTPj7XO6/F+SxVzgPKRooWlN7l0A0g+i0tGXrmvdu2D/qYTrBgO0GKG3ocRlrhB/jm6a13zR2i8GAk+BOOw/lmy95RMIlgAlAvh4ex5/ll5CUndYMkJfGNFyL84sCuoHa3tSVQW9HkGxjeueUNv6Krx7dbTO5R/J1FARSQ9X3d8gyh13RSZAYA9iOcmHkJWO1ZA+LkRdbaRAlO3wogKL/+/YDZl5cuFQogC/P4k/j+mx0AYVDyYVQGWDMPlbcDQDVHOREA1DmGDAgv7emA0bEofgmAmn3euXUpT3d9Z4G+4PRR+6PR9oigRqarPiT6ng4nBzRguCe0ZJEBatyqQGvkfw249VtiHTNSzdGZAddVESmW1YBDv5bSpoxBnOZkst7h6jISx5sCEltnJFp7KKkG3KNfPQvULluB2UMuR1zaBiXjB08+IJr4FQA9c3gDgNINKSDK4SCff67VjEsZEI+Cl3Scg3vwA4cU6uu0bRL3d4k3ZEDm3mAoY2YqdX7BvVsA2OJW9qlhUe+KQvObX1DYANS+2iIdHArR0bArgXfUBoAMoewopH9ROd3oBmcZiMkOANA3sXUq9mm5Pqrvq7IYXLo3Vs713ao7WRAZ8NULfTACRd0fdjtUcYyr1cIAAAAASUVORK5CYII=)}\n"], dependencies: [{ kind: "directive", type: i13.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i13.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i13.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i13.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i14.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "component", type: i5.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "directive", type: i5.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "directive", type: i5.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "component", type: i5.Tabs, selector: "cds-tabs, ibm-tabs", inputs: ["position", "cacheActive", "followFocus", "isNavigation", "ariaLabel", "ariaLabelledby", "type", "theme", "skeleton"] }, { kind: "component", type: i5.Tab, selector: "cds-tab, ibm-tab", inputs: ["heading", "title", "context", "active", "disabled", "tabIndex", "id", "cacheActive", "tabContent", "templateContext"], outputs: ["selected"] }, { kind: "component", type: i1.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "directive", type: i1.RenderInPageHeaderDirective, selector: "[renderInPageHeader]", inputs: ["fullWidth"] }, { kind: "component", type: i5.Tag, selector: "cds-tag, ibm-tag", inputs: ["type", "size", "class"] }, { kind: "component", type: i5.OverflowMenu, selector: "cds-overflow-menu, ibm-overflow-menu", inputs: ["buttonLabel", "flip", "placement", "open", "customTrigger", "offset", "wrapperClass", "triggerClass"], outputs: ["openChange"] }, { kind: "component", type: i5.OverflowMenuOption, selector: "cds-overflow-menu-option, ibm-overflow-menu-option", inputs: ["divider", "type", "disabled", "href", "target", "innerClass"], outputs: ["selected"] }, { kind: "directive", type: i1.ValtimoCdsOverflowButtonDirective, selector: "[valtimoCdsOverflowButton]", inputs: ["width"] }, { kind: "component", type: i15.DossierDetailTaskListComponent, selector: "valtimo-dossier-detail-task-list", inputs: ["openInTaskModal"], outputs: ["taskClickEvent", "formSubmitEvent"] }, { kind: "component", type: i16.DossierDetailsTaskDetailComponent, selector: "valtimo-dossier-detail-task-detail", inputs: ["task"], outputs: ["closeEvent", "assignmentOfTaskChanged", "activeChange", "formSubmit"] }, { kind: "component", type: i17.SplitComponent, selector: "as-split", inputs: ["gutterSize", "gutterStep", "disabled", "gutterClickDeltaPx", "direction", "dir", "unit", "gutterAriaLabel", "restrictMove", "useTransition", "gutterDblClickDuration"], outputs: ["gutterClick", "gutterDblClick", "dragStart", "dragEnd", "transitionEnd"], exportAs: ["asSplit"] }, { kind: "component", type: i17.SplitAreaComponent, selector: "as-split-area", inputs: ["size", "minSize", "maxSize", "lockSize", "visible"], exportAs: ["asSplitArea"] }, { kind: "component", type: i18.DossierSupportingProcessStartModalComponent, selector: "valtimo-dossier-supporting-process-start-modal", inputs: ["isAdmin"], outputs: ["formSubmit"] }, { kind: "component", type: i19.DossierAssignUserComponent, selector: "valtimo-dossier-assign-user", inputs: ["documentId", "assigneeId", "assigneeFullName", "hasPermission"], outputs: ["assignmentOfDocumentChanged"] }, { kind: "pipe", type: i13.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }, { kind: "pipe", type: i20.TabTranslatePipe, name: "tabTranslate" }] }); }
431
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailComponent, deps: [{ token: i1.BreadcrumbService }, { token: i2.CaseStatusService }, { token: i1.CdsThemeService }, { token: i0.ComponentFactoryResolver }, { token: i3.ConfigService }, { token: i2.DocumentService }, { token: i4.DossierDetailLayoutService }, { token: i4.DossierService }, { token: i4.DossierTabService }, { token: i5.IconService }, { token: i6.KeycloakService }, { token: i7.NGXLogger }, { token: i5.NotificationService }, { token: i1.PageHeaderService }, { token: i1.PageTitleService }, { token: i8.PermissionService }, { token: i9.TranslateService }, { token: i0.Renderer2 }, { token: i10.ActivatedRoute }, { token: i10.Router }, { token: i11.WidgetsService }, { token: i12.UserProviderService }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
432
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierDetailComponent, selector: "valtimo-dossier-detail", providers: [DossierTabService, DossierDetailLayoutService, NotificationService], viewQueries: [{ propertyName: "supportingProcessStart", first: true, predicate: ["supportingProcessStartModal"], descendants: true }, { propertyName: "viewContainerRef", first: true, predicate: ["tabContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_tabContentContainer", first: true, predicate: ["tabContentContainer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n<div\n class=\"main-content\"\n [ngClass]=\"{'main-content--no-horizontal-overflow': tabHorizontalOverflowDisabled()}\"\n>\n <div class=\"container-fluid\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n\n <ng-template #tabs>\n <ng-container *ngIf=\"{activeTab: activeTab$ | async} as obs\">\n <cds-tabs *ngIf=\"tabLoader\" type=\"inline\" class=\"case-detail-tabs\">\n <cds-tab\n *ngFor=\"let tab of tabLoader.tabs\"\n [active]=\"tab.name === (activeTabName$ | async)\"\n heading=\"{{ tab | tabTranslate | async }}\"\n (selected)=\"onTabSelected(tab, obs.activeTab)\"\n ></cds-tab>\n </cds-tabs>\n </ng-container>\n </ng-template>\n\n <div\n #tabContentContainer\n class=\"tab-content-container\"\n [ngClass]=\"{\n 'tab-content-container--dark': isDarkMode$ | async,\n 'tab-content-container--compact': compactMode$ | async,\n }\"\n *ngIf=\"{\n noTabsConfigured: noTabsConfigured$ | async,\n showTaskList: showTaskList$ | async,\n showNoAccess: showNoAccess$ | async,\n dossierDetailLayout: dossierDetailLayout$ | async,\n openTaskAndProcessLinkInModal: openTaskAndProcessLinkInModal$ | async,\n taskAndProcessLinkOpenedInPanel: taskAndProcessLinkOpenedInPanel$ | async,\n } as tabContentObs\"\n >\n <as-split\n direction=\"horizontal\"\n [disabled]=\"!tabContentObs.dossierDetailLayout.widthAdjustable\"\n [gutterSize]=\"DOSSIER_DETAIL_GUTTER_SIZE\"\n [unit]=\"tabContentObs.dossierDetailLayout.unit\"\n >\n <as-split-area\n [size]=\"tabContentObs.dossierDetailLayout.leftPanelWidth\"\n [minSize]=\"tabContentObs.dossierDetailLayout.leftPanelMinWidth\"\n [maxSize]=\"tabContentObs.dossierDetailLayout.leftPanelMaxWidth\"\n >\n <div\n class=\"card-body bg-white p-5 position-relative tab-container\"\n [class.tab-container--compact]=\"compactMode$ | async\"\n >\n <div *ngIf=\"loadingTabs$ | async\" class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n\n <valtimo-no-results\n *ngIf=\"tabContentObs.showNoAccess\"\n description=\"{{ 'dossier.noAccess.description' | translate }}\"\n title=\"{{ 'dossier.noAccess.title' | translate }}\"\n illustration=\"valtimo-layout/img/emptystate-not-authorised.svg\"\n >\n </valtimo-no-results>\n\n <valtimo-no-results\n *ngIf=\"tabContentObs.noTabsConfigured\"\n [description]=\"'dossier.tabs.noResultsDescription' | translate\"\n [title]=\"'dossier.tabs.noResults' | translate\"\n ></valtimo-no-results>\n\n <ng-template #tabContainer></ng-template>\n\n <div class=\"clearfix\"></div>\n </div>\n </as-split-area>\n\n <as-split-area\n *ngIf=\"tabContentObs.dossierDetailLayout.showRightPanel\"\n [size]=\"tabContentObs.dossierDetailLayout.rightPanelWidth\"\n [minSize]=\"tabContentObs.dossierDetailLayout.rightPanelMinWidth\"\n [maxSize]=\"tabContentObs.dossierDetailLayout.rightPanelMaxWidth\"\n >\n @if (tabContentObs.showTaskList) {\n <div class=\"task-panel\">\n @if (!tabContentObs.taskAndProcessLinkOpenedInPanel) {\n <valtimo-dossier-detail-task-list\n [openTaskAndProcessLinkInModal]=\"tabContentObs.openTaskAndProcessLinkInModal\"\n (taskClickEvent)=\"onTaskClickEvent($event)\"\n (formSubmitEvent)=\"onFormSubmitEvent()\"\n ></valtimo-dossier-detail-task-list>\n }\n\n @if (tabContentObs.taskAndProcessLinkOpenedInPanel) {\n <valtimo-dossier-detail-task-detail\n [taskAndProcessLink]=\"tabContentObs.taskAndProcessLinkOpenedInPanel\"\n (activeChange)=\"onActiveChangeEvent($event)\"\n (closeEvent)=\"onTaskDetailsClose()\"\n (formSubmit)=\"onFormSubmitEvent()\"\n >\n </valtimo-dossier-detail-task-detail>\n }\n </div>\n }\n </as-split-area>\n </as-split>\n </div>\n </div>\n\n <valtimo-dossier-supporting-process-start-modal\n [isAdmin]=\"isAdmin$ | async\"\n (formSubmit)=\"tabLoader.refreshView()\"\n #supportingProcessStartModal\n ></valtimo-dossier-supporting-process-start-modal>\n</div>\n\n<ng-template\n #caseDetailHeader\n let-canHaveAssignee=\"canHaveAssignee\"\n let-document=\"document\"\n let-canAssign=\"canAssign\"\n>\n <div class=\"row\" *ngIf=\"(customDossierHeaderItems || []).length > 0\">\n <span\n *ngFor=\"let item of customDossierHeaderItems\"\n [ngClass]=\"{\n h1: item.textSize === 'xl',\n h2: item.textSize === 'lg',\n h3: item.textSize === 'md',\n h4: item.textSize === 'sm',\n h5: item.textSize === 'xs',\n }\"\n class=\"mb-0 mt-0 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n item.columnSize * 2\n }} {{ item.customClass }}\"\n >\n <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n\n <span *ngIf=\"item.label && item.value\">: </span>\n\n <strong>{{ item.value }}</strong>\n </span>\n </div>\n\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailAssignee;\n context: {canHaveAssignee: canHaveAssignee, document: document, canAssign: canAssign}\n \"\n ></ng-container>\n</ng-template>\n\n<ng-template\n #caseDetailAssignee\n let-canHaveAssignee=\"canHaveAssignee\"\n let-document=\"document\"\n let-canAssign=\"canAssign\"\n>\n <div *ngIf=\"canHaveAssignee && document\">\n <valtimo-dossier-assign-user\n *ngIf=\"canAssignLoaded$ | async\"\n [assigneeFullName]=\"document?.assigneeFullName\"\n [assigneeId]=\"document.assigneeId\"\n [documentId]=\"document.id\"\n [hasPermission]=\"canAssign\"\n (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n ></valtimo-dossier-assign-user>\n </div>\n</ng-template>\n\n<ng-template #claimButton let-canClaim=\"canClaim\" let-canHaveAssignee=\"canHaveAssignee\">\n <cds-overflow-menu-option\n *ngIf=\"canClaim && canHaveAssignee\"\n [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n (click)=\"claimAssignee()\"\n >\n {{ 'dossier.claimAssigneeCase' | translate }}\n </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #unassignButton let-canHaveAssignee=\"canHaveAssignee\" let-assigneeId=\"assigneeId\">\n <cds-overflow-menu-option\n *ngIf=\"canHaveAssignee\"\n [disabled]=\"!assigneeId\"\n (selected)=\"unassignAssignee()\"\n >\n {{ 'assignDocument.remove' | translate }}\n </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #deleteButton let-canDelete=\"canDelete\">\n <cds-overflow-menu-option\n *ngIf=\"canDelete\"\n [disabled]=\"isDeleting$ | async\"\n (click)=\"deleteDocument()\"\n type=\"danger\"\n >\n {{ 'dossier.delete.delete' | translate }}\n </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #customStartTrigger>\n <button\n [size]=\"(compactMode$ | async) ? 'sm' : 'lg'\"\n cdsButton=\"primary\"\n [disabled]=\"processDocumentDefinitions.length === 0\"\n [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n >\n {{ 'dossier.startSubProcess' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"chevron--down\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<valtimo-confirmation-modal\n confirmButtonTextTranslationKey=\"dossier.delete.confirm\"\n confirmButtonType=\"danger\"\n contentTranslationKey=\"dossier.delete.description\"\n [showModalSubject$]=\"showDeleteModal$\"\n titleTranslationKey=\"dossier.delete.delete\"\n (confirmEvent)=\"onConfirmDelete()\"\n></valtimo-confirmation-modal>\n\n<ng-container renderInPageHeader [fullWidth]=\"true\">\n <ng-template>\n <div\n class=\"dossier-actions\"\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n *ngIf=\"{\n assigneeId: assigneeId$ | async,\n canAssign: canAssign$ | async,\n canClaim: canClaim$ | async,\n canHaveAssignee: canHaveAssignee$ | async,\n canDelete: canDelete$ | async,\n document: document$ | async,\n caseStatus: caseStatus$ | async,\n } as obs\"\n >\n <div\n class=\"dossier-status-assign-custom-title\"\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n >\n @if (obs.caseStatus) {\n <cds-tag size=\"sm\" [type]=\"obs.caseStatus.tagType\">{{ obs.caseStatus.title }}</cds-tag>\n }\n\n <div class=\"dossier-assign-user\" [ngClass]=\"{'--compact': compactMode$ | async}\">\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailAssignee;\n context: {\n canHaveAssignee: obs.canHaveAssignee,\n document: obs.document,\n canAssign: obs.canAssign,\n }\n \"\n ></ng-container>\n </div>\n\n <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n </div>\n\n <div class=\"buttons-container\">\n <cds-overflow-menu\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n *ngIf=\"obs.canHaveAssignee || obs.canDelete\"\n flip=\"true\"\n [offset]=\"(compactMode$ | async) ? {y: 48, x: -4} : {y: 48, x: 4}\"\n class=\"overflow-button assign-overflow\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n claimButton;\n context: {canClaim: obs.canClaim, canHaveAssignee: obs.canHaveAssignee}\n \"\n >\n </ng-container>\n <ng-container\n *ngTemplateOutlet=\"\n unassignButton;\n context: {canHaveAssignee: obs.canHaveAssignee, assigneeId: obs.assigneeId}\n \"\n >\n </ng-container>\n <ng-container *ngTemplateOutlet=\"deleteButton; context: {canDelete: obs.canDelete}\">\n </ng-container>\n </cds-overflow-menu>\n\n <cds-overflow-menu\n valtimoCdsOverflowButton\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n [width]=\"250\"\n [customTrigger]=\"customStartTrigger\"\n [offset]=\"{y: 48, x: 35}\"\n class=\"overflow-button case-detail-overflow\"\n >\n <cds-overflow-menu-option\n *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n (click)=\"startProcess(processDocumentDefinition)\"\n >\n {{\n (processDocumentDefinition?.id?.processDefinitionKey | translate) !==\n processDocumentDefinition?.id?.processDefinitionKey\n ? (processDocumentDefinition.id.processDefinitionKey | translate)\n : processDocumentDefinition.processName\n }}\n </cds-overflow-menu-option>\n </cds-overflow-menu>\n </div>\n </div>\n </ng-template>\n</ng-container>\n", styles: [".main-content{overflow:hidden;padding-bottom:0}.main-content--no-horizontal-overflow{overflow-x:hidden}.tab-container{height:min-content;min-height:300px;overflow-y:auto;max-height:calc(100vh - 226px);overflow-x:hidden}.tab-container--compact{max-height:calc(100vh - 176px)}.tab-container:has(>.tab--no-margin){padding:0!important}.tab-container:has(>.tab--no-min-height){min-height:unset}.tab-container:has(>.tab--no-background){background:transparent!important}.tab-content-container{overflow:hidden;display:flex;gap:32px;overflow:auto;margin-bottom:16px;max-height:calc(100vh - 226px)}.tab-content-container--compact{max-height:calc(100vh - 176px)}.loading-container{display:flex;justify-content:center;flex-direction:row}.dossier-detail-page-header{display:flex;width:100%;justify-content:flex-start;padding-bottom:5px}.dossier-detail-page-header ::ng-deep .cds--tag{margin:0}.case-detail-tabs{display:flex;margin-bottom:24px}.case-detail-tabs cds-tab{display:none!important}.cds--overflow-menu-options{margin-top:32px}.assign-overflow{margin-right:8px}.buttons-container{display:flex;flex-direction:row}.dossier-actions{display:flex;width:100%;justify-content:space-between;align-items:flex-end;padding-bottom:4px}.dossier-actions.--compact{padding-bottom:0;align-items:flex-start}.dossier-actions ::ng-deep .version-selection{width:160px}.dossier-actions ::ng-deep .version-selection .cds--list-box__selection{display:none}.dossier-status-assign-custom-title{display:flex;gap:16px;align-items:flex-end}.dossier-status-assign-custom-title .cds--tag{margin:0;height:var(--cds-layout-size-height-md)}.dossier-status-assign-custom-title.--compact{align-items:center}.task-panel{width:100%;transition:height .15s ease-in-out}:host ::ng-deep .container-fluid{height:100%!important;width:100%!important;margin:0!important;padding:0!important}::ng-deep .tab-content-container .as-split-gutter{background-color:transparent!important;--_as-gutter-icon-disabled: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mP8/wcAAgEBAYcDngAAAAAASUVORK5CYII=);--_as-gutter-icon-horizontal: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAABQJJREFUeF7dWll22zAMpNwzlM5xmpMlOVl6mzrKHexWm8UFy4xIp+/FP3mxQWAwWAiRGsJ3/gwhhJvt4CRCfgCtosYhDOHm4SlW7rZyq9t/R7GsZoYQDhCA89UIrzakKuQtpRTiHv03ycJB3t8KuU9AByNfw5dWJpj1h5YABmGRsvgufzsSG21NEwGWUrv5yiuZb31yMZoAAjBFPqBdor9G0vpwu2+PBgE6TK/q0pUxxiwZxnE0SefkE0sHWQUygGG3ll0c2tGNn+M0DiSfHDlHQBu2rffoWgBWPRHWIUreM654li5bMwDQBIhI9naHFgVQCSS2PHliWlLm0/YsMrcwK6ISp1QGANhzG7XFDj2gUFr8yzrkydOJ6CyACBB1lIWkbPyeQ2UQ2ZKxksCLft4EaWqB/AshHCdg0b/1gB7wJB1QBrQ0ml4E2MMyFgxJ6iABuEGdgCUeZVQm+fQ7fhfAsflzAKFLS1G2ptmMwUpDl1oyAGxo2fw2hHBzjpsm+XiO2TGQF1GWACJGfecAjHmgCTZum/lQfezQTZ3L7z+g3goc2xGtFT86A0qLh5pgjPF13aLmv9aHdYiVn8uMwFNixQlYqVuNvayK3sZxNElgHarlP6duo2bpOcbXWxheVhkTj7Tv4ATsTG/OL6CG8DZ+KCQMIcSf6HnAAo8hrAjGRpIblLxveDm8/q4YC6fT6flyufzWBhXGoTWd4QOUp6enX9fr9X2od6SFhJlTu4FBGZA5n+jbnddZjPG8nz8lo222ItHJEraRICAAMmG6rPGb2FTjedqHsET+4/Lbu+phHWLlJ/g+Cd4gpJDgp71HHzAHFCqOEFCSULjrNkaxw2rO/zidnv/MNY99WIcY+TKufibUmOcSEB5IxLTHXLal2FG4h83VPzET1h6wUxDP8fXfJW5V8xuQhqFwVtGNgDuQ6Yo367Pb9ixdjVckVE1QS/0ekZhybRw/zMZblkBpd1sMPIdJkAsClF2ghQQPYJYBQjp5BKCBEHD4JZDi6bED3AebRDFbAp58Ski3JrgphQcgozEwXZ2dBH3nZ2Bq5KcyahuEgO1wIWBnyIuoS5hA9pHIp01dnANSdlvKwXWocRC6Pw/U70MBozCQAWI5JKDF5wFrtk8uR6XKYQibnL9dr+/CjgA5v81AamMFByTTmOhQp56hPw5/vrrvx61euz2gZKfHgcj98bUkgjo/WJCxeMrJFyQgR8ocQcGnwqsJpgSK8pymTPeIThus4DKwBKWJFNsFklEcOT9ApyFADswAQJMiwkaUldeQ7ZTKDWf79tsSgIasDwGduro1CbY+hVqZgpJ1SA5L6bQHMJNjOy19MsCgBiNgV8DK+1GxSXoYAcMwhNttOedPIZTPAhm8bQ6Anx57ZMBGgfHuXs6yuEANBBtR/2bIjzkj8bAMSIYU+KLDaoKSU8KFCOP7LAsTcDTZ2jPAfrUWf3VGnwdo1pgF5xiz9yhazwOExwfv9suEm2XArJwNtSP/+AxgwlHL1iVwiAUdhEaAxhtLWGbZDEbPEiCyhHWIla93KO7AvMoAwre7bW5jxCAfwaHnoa4N3gVU5X2RthX0gdVNBPhDZnYgzMH7ImKbCOA8wnfsVO+jeUgIEHfYFUs7jHYNLN2YvJkBXwYaNuQIwnp2cgoCag3LN1Z2+EwfwCVPLPAOJ1n05oDt9x5oRR37Pb72s/e+kU81L/EXSRwjcUdkvjUAAAAASUVORK5CYII=)}::ng-deep .tab-content-container .as-split-gutter-icon{background-repeat:no-repeat;background-size:16px 16px}::ng-deep .tab-content-container--dark .as-split-gutter{--_as-gutter-icon-horizontal: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAABPlJREFUeF7tm1tW3DAMhu2+krCmdmWlKytrIuGV9HjixDddfjkOtOd0XmAGWZfPsiw7g3fVyzvntvpD9H01+JIuwCamX5YKf9VfmCVaDze2S2fXIDG+CGC8YsrqMCvDFDmHZYCeI5gE6LietD2LlNb6uQAQTLWfCDTLmLpOIfoRvxEZydZn+pH7+vdlAEJyoIwIwDIrFtk7C2TyA/Po9gxY1zVWrN2haZq85FqS3zEF+YET3qi6rFzjfAR0yGkBwQA0wyFU75zf5MaOBYDoR2YGDigqY+U7HOKHlAsFiQOXqax+JYCYBGJr32ZAB+lEpxwc3i1nDcDWtBUYPjN8p35VBxf/4/MQUI7lqAGPzwjYBQDv3PQ0+Ue/CjV/sODp8+UiyNE7XLHO6EM+Dg4/ntBdAI69zdIqBlgTlDldADLN9a7R551cDot0kDPNbn40AIh6LSS4DS0Be9jJg7sAXPHJfBZojbXriMscGgDvvhUYmRGEes6iocJiyVejWdelYDPNk5cquhnAxVSAlgDZQG/7bUqKjvZEDqgdYwaAzQsrVQHowFkPqd5bA4LlO1ytp+zoFM0Ml2V5CYPmeX78lF7v67rla8B6GpynKZxnxBfmD03MvASCMe/9z+DRtm2/SAiZLXRGqcapbYTaICB/BHwggN1wbuzQSUHI3UQBHPqo+wPO/7dlefkWJ0PyR0ofEIAjg49Z8GOe51fOCAYgIcPkd2vLsnz33v+ubadJ0TZw8Fqcmnkk+CBjCahHXodQ49mhHGjUDJCDf37Vjmn54Sa4MuxGaL/weWzDdggJigjgDL7KpG3bxLTPmY/PALqa90JgAahpf/ohb8jjAfAlrQdCCSDG0gRPxCiHzf81XwKUVA1M7gDwbojbspsM4GZea3jov5cFp6cGoHYRFCWE5FthQwKAGCnLS9vD6UXwXbnIRpGUcsH3D6JxI2sADwFHwEnqAI4HKW0AB07ci6QDXgLHELUIghPxbxRBBukICDuAZMCaAbu8XnLf1K4wzBjdGYpzSUGI66ntBQg/8QzYB+PyyW18++sAEHvu8wSY02IbosyONaBTPj7XO6/F+SxVzgPKRooWlN7l0A0g+i0tGXrmvdu2D/qYTrBgO0GKG3ocRlrhB/jm6a13zR2i8GAk+BOOw/lmy95RMIlgAlAvh4ex5/ll5CUndYMkJfGNFyL84sCuoHa3tSVQW9HkGxjeueUNv6Krx7dbTO5R/J1FARSQ9X3d8gyh13RSZAYA9iOcmHkJWO1ZA+LkRdbaRAlO3wogKL/+/YDZl5cuFQogC/P4k/j+mx0AYVDyYVQGWDMPlbcDQDVHOREA1DmGDAgv7emA0bEofgmAmn3euXUpT3d9Z4G+4PRR+6PR9oigRqarPiT6ng4nBzRguCe0ZJEBatyqQGvkfw249VtiHTNSzdGZAddVESmW1YBDv5bSpoxBnOZkst7h6jISx5sCEltnJFp7KKkG3KNfPQvULluB2UMuR1zaBiXjB08+IJr4FQA9c3gDgNINKSDK4SCff67VjEsZEI+Cl3Scg3vwA4cU6uu0bRL3d4k3ZEDm3mAoY2YqdX7BvVsA2OJW9qlhUe+KQvObX1DYANS+2iIdHArR0bArgXfUBoAMoewopH9ROd3oBmcZiMkOANA3sXUq9mm5Pqrvq7IYXLo3Vs713ao7WRAZ8NULfTACRd0fdjtUcYyr1cIAAAAASUVORK5CYII=)}\n"], dependencies: [{ kind: "directive", type: i13.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i13.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i13.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i13.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i14.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "component", type: i5.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "directive", type: i5.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "directive", type: i5.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "component", type: i1.ConfirmationModalComponent, selector: "valtimo-confirmation-modal", inputs: ["titleTranslationKey", "title", "content", "contentTranslationKey", "confirmButtonText", "confirmButtonTextTranslationKey", "confirmButtonType", "showOptionalButton", "optionalButtonText", "optionalButtonTextTranslationKey", "optionalButtonType", "cancelButtonText", "cancelButtonTextTranslationKey", "cancelButtonType", "showModalSubject$", "outputOnConfirm", "outputOnOptional", "spacerAfterCancelButton"], outputs: ["confirmEvent", "optionalEvent", "cancelEvent"] }, { kind: "component", type: i5.Tabs, selector: "cds-tabs, ibm-tabs", inputs: ["position", "cacheActive", "followFocus", "isNavigation", "ariaLabel", "ariaLabelledby", "type", "theme", "skeleton"] }, { kind: "component", type: i5.Tab, selector: "cds-tab, ibm-tab", inputs: ["heading", "title", "context", "active", "disabled", "tabIndex", "id", "cacheActive", "tabContent", "templateContext"], outputs: ["selected"] }, { kind: "component", type: i1.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "directive", type: i1.RenderInPageHeaderDirective, selector: "[renderInPageHeader]", inputs: ["fullWidth"] }, { kind: "component", type: i5.Tag, selector: "cds-tag, ibm-tag", inputs: ["type", "size", "class"] }, { kind: "component", type: i5.OverflowMenu, selector: "cds-overflow-menu, ibm-overflow-menu", inputs: ["buttonLabel", "flip", "placement", "open", "customTrigger", "offset", "wrapperClass", "triggerClass"], outputs: ["openChange"] }, { kind: "component", type: i5.OverflowMenuOption, selector: "cds-overflow-menu-option, ibm-overflow-menu-option", inputs: ["divider", "type", "disabled", "href", "target", "innerClass"], outputs: ["selected"] }, { kind: "directive", type: i1.ValtimoCdsOverflowButtonDirective, selector: "[valtimoCdsOverflowButton]", inputs: ["width"] }, { kind: "component", type: i15.DossierDetailTaskListComponent, selector: "valtimo-dossier-detail-task-list", inputs: ["openTaskAndProcessLinkInModal"], outputs: ["taskClickEvent", "formSubmitEvent"] }, { kind: "component", type: i16.DossierDetailsTaskDetailComponent, selector: "valtimo-dossier-detail-task-detail", inputs: ["taskAndProcessLink"], outputs: ["closeEvent", "assignmentOfTaskChanged", "activeChange", "formSubmit"] }, { kind: "component", type: i17.SplitComponent, selector: "as-split", inputs: ["gutterSize", "gutterStep", "disabled", "gutterClickDeltaPx", "direction", "dir", "unit", "gutterAriaLabel", "restrictMove", "useTransition", "gutterDblClickDuration"], outputs: ["gutterClick", "gutterDblClick", "dragStart", "dragEnd", "transitionEnd"], exportAs: ["asSplit"] }, { kind: "component", type: i17.SplitAreaComponent, selector: "as-split-area", inputs: ["size", "minSize", "maxSize", "lockSize", "visible"], exportAs: ["asSplitArea"] }, { kind: "component", type: i18.DossierSupportingProcessStartModalComponent, selector: "valtimo-dossier-supporting-process-start-modal", inputs: ["isAdmin"], outputs: ["formSubmit"] }, { kind: "component", type: i19.DossierAssignUserComponent, selector: "valtimo-dossier-assign-user", inputs: ["documentId", "assigneeId", "assigneeFullName", "hasPermission"], outputs: ["assignmentOfDocumentChanged"] }, { kind: "pipe", type: i13.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }, { kind: "pipe", type: i20.TabTranslatePipe, name: "tabTranslate" }] }); }
387
433
  }
388
434
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailComponent, decorators: [{
389
435
  type: Component,
390
- args: [{ selector: 'valtimo-dossier-detail', providers: [DossierTabService, DossierDetailLayoutService, NotificationService], 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<div\n class=\"main-content\"\n [ngClass]=\"{'main-content--no-horizontal-overflow': tabHorizontalOverflowDisabled()}\"\n>\n <div class=\"container-fluid\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n\n <ng-template #tabs>\n <ng-container *ngIf=\"{activeTab: activeTab$ | async} as obs\">\n <cds-tabs *ngIf=\"tabLoader\" type=\"inline\" class=\"case-detail-tabs\">\n <cds-tab\n *ngFor=\"let tab of tabLoader.tabs\"\n [active]=\"tab.name === (activeTabName$ | async)\"\n heading=\"{{ tab | tabTranslate | async }}\"\n (selected)=\"onTabSelected(tab, obs.activeTab)\"\n ></cds-tab>\n </cds-tabs>\n </ng-container>\n </ng-template>\n\n <div\n #tabContentContainer\n class=\"tab-content-container\"\n [ngClass]=\"{\n 'tab-content-container--dark': isDarkMode$ | async,\n 'tab-content-container--compact': compactMode$ | async,\n }\"\n *ngIf=\"{\n noTabsConfigured: noTabsConfigured$ | async,\n showTaskList: showTaskList$ | async,\n taskOpenedInPanel: taskOpenedInPanel$ | async,\n dossierDetailLayout: dossierDetailLayout$ | async,\n } as tabContentObs\"\n >\n <as-split\n direction=\"horizontal\"\n [disabled]=\"!tabContentObs.dossierDetailLayout.widthAdjustable\"\n [gutterSize]=\"DOSSIER_DETAIL_GUTTER_SIZE\"\n [unit]=\"tabContentObs.dossierDetailLayout.unit\"\n >\n <as-split-area\n [size]=\"tabContentObs.dossierDetailLayout.leftPanelWidth\"\n [minSize]=\"tabContentObs.dossierDetailLayout.leftPanelMinWidth\"\n [maxSize]=\"tabContentObs.dossierDetailLayout.leftPanelMaxWidth\"\n >\n <div\n class=\"card-body bg-white p-5 position-relative tab-container\"\n [class.tab-container--compact]=\"compactMode$ | async\"\n >\n <div *ngIf=\"loadingTabs$ | async\" class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n\n <valtimo-no-results\n *ngIf=\"tabContentObs.noTabsConfigured\"\n [description]=\"'dossier.tabs.noResultsDescription' | translate\"\n [title]=\"'dossier.tabs.noResults' | translate\"\n ></valtimo-no-results>\n\n <ng-template #tabContainer></ng-template>\n\n <div class=\"clearfix\"></div>\n </div>\n </as-split-area>\n\n <as-split-area\n *ngIf=\"tabContentObs.dossierDetailLayout.showRightPanel\"\n [size]=\"tabContentObs.dossierDetailLayout.rightPanelWidth\"\n [minSize]=\"tabContentObs.dossierDetailLayout.rightPanelMinWidth\"\n [maxSize]=\"tabContentObs.dossierDetailLayout.rightPanelMaxWidth\"\n >\n @if (tabContentObs.showTaskList) {\n <div class=\"task-panel\">\n @if (!tabContentObs.taskOpenedInPanel) {\n <valtimo-dossier-detail-task-list\n [openInTaskModal]=\"openTaskInModal$ | async\"\n (taskClickEvent)=\"onTaskClickEvent($event)\"\n (formSubmitEvent)=\"onFormSubmitEvent()\"\n ></valtimo-dossier-detail-task-list>\n }\n\n @if (tabContentObs.taskOpenedInPanel) {\n <valtimo-dossier-detail-task-detail\n [task]=\"tabContentObs.taskOpenedInPanel\"\n (activeChange)=\"onActiveChangeEvent($event)\"\n (closeEvent)=\"onTaskDetailsClose()\"\n (formSubmit)=\"onFormSubmitEvent()\"\n >\n </valtimo-dossier-detail-task-detail>\n }\n </div>\n }\n </as-split-area>\n </as-split>\n </div>\n </div>\n\n <valtimo-dossier-supporting-process-start-modal\n [isAdmin]=\"isAdmin$ | async\"\n (formSubmit)=\"tabLoader.refreshView()\"\n #supportingProcessStartModal\n ></valtimo-dossier-supporting-process-start-modal>\n</div>\n\n<ng-template\n #caseDetailHeader\n let-canHaveAssignee=\"canHaveAssignee\"\n let-document=\"document\"\n let-canAssign=\"canAssign\"\n>\n <div class=\"row\" *ngIf=\"(customDossierHeaderItems || []).length > 0\">\n <span\n *ngFor=\"let item of customDossierHeaderItems\"\n [ngClass]=\"{\n h1: item.textSize === 'xl',\n h2: item.textSize === 'lg',\n h3: item.textSize === 'md',\n h4: item.textSize === 'sm',\n h5: item.textSize === 'xs',\n }\"\n class=\"mb-0 mt-0 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n item.columnSize * 2\n }} {{ item.customClass }}\"\n >\n <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n\n <span *ngIf=\"item.label && item.value\">: </span>\n\n <strong>{{ item.value }}</strong>\n </span>\n </div>\n\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailAssignee;\n context: {canHaveAssignee: canHaveAssignee, document: document, canAssign: canAssign}\n \"\n ></ng-container>\n</ng-template>\n\n<ng-template\n #caseDetailAssignee\n let-canHaveAssignee=\"canHaveAssignee\"\n let-document=\"document\"\n let-canAssign=\"canAssign\"\n>\n <div *ngIf=\"canHaveAssignee && document\">\n <valtimo-dossier-assign-user\n *ngIf=\"canAssignLoaded$ | async\"\n [assigneeFullName]=\"document?.assigneeFullName\"\n [assigneeId]=\"document.assigneeId\"\n [documentId]=\"document.id\"\n [hasPermission]=\"canAssign\"\n (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n ></valtimo-dossier-assign-user>\n </div>\n</ng-template>\n\n<ng-template #claimButton let-canClaim=\"canClaim\" let-canHaveAssignee=\"canHaveAssignee\">\n <cds-overflow-menu-option\n *ngIf=\"canClaim && canHaveAssignee\"\n [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n (click)=\"claimAssignee()\"\n >\n <span>{{ 'dossier.claimAssigneeCase' | translate }}</span>\n </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #customStartTrigger>\n <button\n [size]=\"(compactMode$ | async) ? 'sm' : 'lg'\"\n cdsButton=\"primary\"\n [disabled]=\"processDocumentDefinitions.length === 0\"\n [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n >\n {{ 'dossier.startSubProcess' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"chevron--down\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-container renderInPageHeader [fullWidth]=\"true\">\n <ng-template>\n <div\n class=\"dossier-actions\"\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n *ngIf=\"{\n assigneeId: assigneeId$ | async,\n canAssign: canAssign$ | async,\n canClaim: canClaim$ | async,\n canHaveAssignee: canHaveAssignee$ | async,\n document: document$ | async,\n caseStatus: caseStatus$ | async,\n } as obs\"\n >\n <div\n class=\"dossier-status-assign-custom-title\"\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n >\n @if (obs.caseStatus) {\n <cds-tag size=\"sm\" [type]=\"obs.caseStatus.tagType\">{{ obs.caseStatus.title }}</cds-tag>\n }\n\n <div class=\"dossier-assign-user\" [ngClass]=\"{'--compact': compactMode$ | async}\">\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailAssignee;\n context: {\n canHaveAssignee: obs.canHaveAssignee,\n document: obs.document,\n canAssign: obs.canAssign,\n }\n \"\n ></ng-container>\n </div>\n\n <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n </div>\n\n <div class=\"buttons-container\">\n <cds-overflow-menu\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n *ngIf=\"obs.canHaveAssignee\"\n flip=\"true\"\n [offset]=\"(compactMode$ | async) ? {y: 48, x: -4} : {y: 48, x: 4}\"\n class=\"overflow-button assign-overflow\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n claimButton;\n context: {canClaim: obs.canClaim, canHaveAssignee: obs.canHaveAssignee}\n \"\n >\n </ng-container>\n <cds-overflow-menu-option (selected)=\"unassignAssignee()\" [disabled]=\"!obs.assigneeId\">\n {{ 'assignDocument.remove' | translate }}\n </cds-overflow-menu-option>\n </cds-overflow-menu>\n\n <cds-overflow-menu\n valtimoCdsOverflowButton\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n [width]=\"250\"\n [customTrigger]=\"customStartTrigger\"\n [offset]=\"{y: 48, x: 35}\"\n class=\"overflow-button case-detail-overflow\"\n >\n <cds-overflow-menu-option\n *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n (click)=\"startProcess(processDocumentDefinition)\"\n >\n {{\n (processDocumentDefinition?.id?.processDefinitionKey | translate) !==\n processDocumentDefinition?.id?.processDefinitionKey\n ? (processDocumentDefinition.id.processDefinitionKey | translate)\n : processDocumentDefinition.processName\n }}\n </cds-overflow-menu-option>\n </cds-overflow-menu>\n </div>\n </div>\n </ng-template>\n</ng-container>\n", styles: [".main-content{overflow:hidden;padding-bottom:0}.main-content--no-horizontal-overflow{overflow-x:hidden}.tab-container{height:min-content;min-height:300px;overflow-y:auto;max-height:calc(100vh - 226px);overflow-x:hidden}.tab-container--compact{max-height:calc(100vh - 176px)}.tab-container:has(>.tab--no-margin){padding:0!important}.tab-container:has(>.tab--no-min-height){min-height:unset}.tab-container:has(>.tab--no-background){background:transparent!important}.tab-content-container{overflow:hidden;display:flex;gap:32px;overflow:auto;margin-bottom:16px;max-height:calc(100vh - 226px)}.tab-content-container--compact{max-height:calc(100vh - 176px)}.loading-container{display:flex;justify-content:center;flex-direction:row}.dossier-detail-page-header{display:flex;width:100%;justify-content:flex-start;padding-bottom:5px}.dossier-detail-page-header ::ng-deep .cds--tag{margin:0}.case-detail-tabs{display:flex;margin-bottom:24px}.case-detail-tabs cds-tab{display:none!important}.cds--overflow-menu-options{margin-top:32px}.assign-overflow{margin-right:8px}.buttons-container{display:flex;flex-direction:row}.dossier-actions{display:flex;width:100%;justify-content:space-between;align-items:flex-end;padding-bottom:4px}.dossier-actions.--compact{padding-bottom:0;align-items:flex-start}.dossier-actions ::ng-deep .version-selection{width:160px}.dossier-actions ::ng-deep .version-selection .cds--list-box__selection{display:none}.dossier-status-assign-custom-title{display:flex;gap:16px;align-items:flex-end}.dossier-status-assign-custom-title .cds--tag{margin:0;height:var(--cds-layout-size-height-md)}.dossier-status-assign-custom-title.--compact{align-items:center}.task-panel{width:100%;transition:height .15s ease-in-out}:host ::ng-deep .container-fluid{height:100%!important;width:100%!important;margin:0!important;padding:0!important}::ng-deep .tab-content-container .as-split-gutter{background-color:transparent!important;--_as-gutter-icon-disabled: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mP8/wcAAgEBAYcDngAAAAAASUVORK5CYII=);--_as-gutter-icon-horizontal: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAABQJJREFUeF7dWll22zAMpNwzlM5xmpMlOVl6mzrKHexWm8UFy4xIp+/FP3mxQWAwWAiRGsJ3/gwhhJvt4CRCfgCtosYhDOHm4SlW7rZyq9t/R7GsZoYQDhCA89UIrzakKuQtpRTiHv03ycJB3t8KuU9AByNfw5dWJpj1h5YABmGRsvgufzsSG21NEwGWUrv5yiuZb31yMZoAAjBFPqBdor9G0vpwu2+PBgE6TK/q0pUxxiwZxnE0SefkE0sHWQUygGG3ll0c2tGNn+M0DiSfHDlHQBu2rffoWgBWPRHWIUreM654li5bMwDQBIhI9naHFgVQCSS2PHliWlLm0/YsMrcwK6ISp1QGANhzG7XFDj2gUFr8yzrkydOJ6CyACBB1lIWkbPyeQ2UQ2ZKxksCLft4EaWqB/AshHCdg0b/1gB7wJB1QBrQ0ml4E2MMyFgxJ6iABuEGdgCUeZVQm+fQ7fhfAsflzAKFLS1G2ptmMwUpDl1oyAGxo2fw2hHBzjpsm+XiO2TGQF1GWACJGfecAjHmgCTZum/lQfezQTZ3L7z+g3goc2xGtFT86A0qLh5pgjPF13aLmv9aHdYiVn8uMwFNixQlYqVuNvayK3sZxNElgHarlP6duo2bpOcbXWxheVhkTj7Tv4ATsTG/OL6CG8DZ+KCQMIcSf6HnAAo8hrAjGRpIblLxveDm8/q4YC6fT6flyufzWBhXGoTWd4QOUp6enX9fr9X2od6SFhJlTu4FBGZA5n+jbnddZjPG8nz8lo222ItHJEraRICAAMmG6rPGb2FTjedqHsET+4/Lbu+phHWLlJ/g+Cd4gpJDgp71HHzAHFCqOEFCSULjrNkaxw2rO/zidnv/MNY99WIcY+TKufibUmOcSEB5IxLTHXLal2FG4h83VPzET1h6wUxDP8fXfJW5V8xuQhqFwVtGNgDuQ6Yo367Pb9ixdjVckVE1QS/0ekZhybRw/zMZblkBpd1sMPIdJkAsClF2ghQQPYJYBQjp5BKCBEHD4JZDi6bED3AebRDFbAp58Ski3JrgphQcgozEwXZ2dBH3nZ2Bq5KcyahuEgO1wIWBnyIuoS5hA9pHIp01dnANSdlvKwXWocRC6Pw/U70MBozCQAWI5JKDF5wFrtk8uR6XKYQibnL9dr+/CjgA5v81AamMFByTTmOhQp56hPw5/vrrvx61euz2gZKfHgcj98bUkgjo/WJCxeMrJFyQgR8ocQcGnwqsJpgSK8pymTPeIThus4DKwBKWJFNsFklEcOT9ApyFADswAQJMiwkaUldeQ7ZTKDWf79tsSgIasDwGduro1CbY+hVqZgpJ1SA5L6bQHMJNjOy19MsCgBiNgV8DK+1GxSXoYAcMwhNttOedPIZTPAhm8bQ6Anx57ZMBGgfHuXs6yuEANBBtR/2bIjzkj8bAMSIYU+KLDaoKSU8KFCOP7LAsTcDTZ2jPAfrUWf3VGnwdo1pgF5xiz9yhazwOExwfv9suEm2XArJwNtSP/+AxgwlHL1iVwiAUdhEaAxhtLWGbZDEbPEiCyhHWIla93KO7AvMoAwre7bW5jxCAfwaHnoa4N3gVU5X2RthX0gdVNBPhDZnYgzMH7ImKbCOA8wnfsVO+jeUgIEHfYFUs7jHYNLN2YvJkBXwYaNuQIwnp2cgoCag3LN1Z2+EwfwCVPLPAOJ1n05oDt9x5oRR37Pb72s/e+kU81L/EXSRwjcUdkvjUAAAAASUVORK5CYII=)}::ng-deep .tab-content-container .as-split-gutter-icon{background-repeat:no-repeat;background-size:16px 16px}::ng-deep .tab-content-container--dark .as-split-gutter{--_as-gutter-icon-horizontal: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAABPlJREFUeF7tm1tW3DAMhu2+krCmdmWlKytrIuGV9HjixDddfjkOtOd0XmAGWZfPsiw7g3fVyzvntvpD9H01+JIuwCamX5YKf9VfmCVaDze2S2fXIDG+CGC8YsrqMCvDFDmHZYCeI5gE6LietD2LlNb6uQAQTLWfCDTLmLpOIfoRvxEZydZn+pH7+vdlAEJyoIwIwDIrFtk7C2TyA/Po9gxY1zVWrN2haZq85FqS3zEF+YET3qi6rFzjfAR0yGkBwQA0wyFU75zf5MaOBYDoR2YGDigqY+U7HOKHlAsFiQOXqax+JYCYBGJr32ZAB+lEpxwc3i1nDcDWtBUYPjN8p35VBxf/4/MQUI7lqAGPzwjYBQDv3PQ0+Ue/CjV/sODp8+UiyNE7XLHO6EM+Dg4/ntBdAI69zdIqBlgTlDldADLN9a7R551cDot0kDPNbn40AIh6LSS4DS0Be9jJg7sAXPHJfBZojbXriMscGgDvvhUYmRGEes6iocJiyVejWdelYDPNk5cquhnAxVSAlgDZQG/7bUqKjvZEDqgdYwaAzQsrVQHowFkPqd5bA4LlO1ytp+zoFM0Ml2V5CYPmeX78lF7v67rla8B6GpynKZxnxBfmD03MvASCMe/9z+DRtm2/SAiZLXRGqcapbYTaICB/BHwggN1wbuzQSUHI3UQBHPqo+wPO/7dlefkWJ0PyR0ofEIAjg49Z8GOe51fOCAYgIcPkd2vLsnz33v+ubadJ0TZw8Fqcmnkk+CBjCahHXodQ49mhHGjUDJCDf37Vjmn54Sa4MuxGaL/weWzDdggJigjgDL7KpG3bxLTPmY/PALqa90JgAahpf/ohb8jjAfAlrQdCCSDG0gRPxCiHzf81XwKUVA1M7gDwbojbspsM4GZea3jov5cFp6cGoHYRFCWE5FthQwKAGCnLS9vD6UXwXbnIRpGUcsH3D6JxI2sADwFHwEnqAI4HKW0AB07ci6QDXgLHELUIghPxbxRBBukICDuAZMCaAbu8XnLf1K4wzBjdGYpzSUGI66ntBQg/8QzYB+PyyW18++sAEHvu8wSY02IbosyONaBTPj7XO6/F+SxVzgPKRooWlN7l0A0g+i0tGXrmvdu2D/qYTrBgO0GKG3ocRlrhB/jm6a13zR2i8GAk+BOOw/lmy95RMIlgAlAvh4ex5/ll5CUndYMkJfGNFyL84sCuoHa3tSVQW9HkGxjeueUNv6Krx7dbTO5R/J1FARSQ9X3d8gyh13RSZAYA9iOcmHkJWO1ZA+LkRdbaRAlO3wogKL/+/YDZl5cuFQogC/P4k/j+mx0AYVDyYVQGWDMPlbcDQDVHOREA1DmGDAgv7emA0bEofgmAmn3euXUpT3d9Z4G+4PRR+6PR9oigRqarPiT6ng4nBzRguCe0ZJEBatyqQGvkfw249VtiHTNSzdGZAddVESmW1YBDv5bSpoxBnOZkst7h6jISx5sCEltnJFp7KKkG3KNfPQvULluB2UMuR1zaBiXjB08+IJr4FQA9c3gDgNINKSDK4SCff67VjEsZEI+Cl3Scg3vwA4cU6uu0bRL3d4k3ZEDm3mAoY2YqdX7BvVsA2OJW9qlhUe+KQvObX1DYANS+2iIdHArR0bArgXfUBoAMoewopH9ROd3oBmcZiMkOANA3sXUq9mm5Pqrvq7IYXLo3Vs713ao7WRAZ8NULfTACRd0fdjtUcYyr1cIAAAAASUVORK5CYII=)}\n"] }]
391
- }], ctorParameters: () => [{ type: i1.BreadcrumbService }, { type: i2.CaseStatusService }, { type: i1.CdsThemeService }, { type: i0.ComponentFactoryResolver }, { type: i3.ConfigService }, { type: i2.DocumentService }, { type: i4.DossierDetailLayoutService }, { type: i4.DossierService }, { type: i4.DossierTabService }, { type: i5.IconService }, { type: i6.KeycloakService }, { type: i7.NGXLogger }, { type: i5.NotificationService }, { type: i1.PageHeaderService }, { type: i1.PageTitleService }, { type: i8.PermissionService }, { type: i9.TranslateService }, { type: i0.Renderer2 }, { type: i10.ActivatedRoute }, { type: i10.Router }, { type: i11.TaskService }, { type: i12.UserProviderService }, { type: Document, decorators: [{
436
+ args: [{ selector: 'valtimo-dossier-detail', providers: [DossierTabService, DossierDetailLayoutService, NotificationService], 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<div\n class=\"main-content\"\n [ngClass]=\"{'main-content--no-horizontal-overflow': tabHorizontalOverflowDisabled()}\"\n>\n <div class=\"container-fluid\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n\n <ng-template #tabs>\n <ng-container *ngIf=\"{activeTab: activeTab$ | async} as obs\">\n <cds-tabs *ngIf=\"tabLoader\" type=\"inline\" class=\"case-detail-tabs\">\n <cds-tab\n *ngFor=\"let tab of tabLoader.tabs\"\n [active]=\"tab.name === (activeTabName$ | async)\"\n heading=\"{{ tab | tabTranslate | async }}\"\n (selected)=\"onTabSelected(tab, obs.activeTab)\"\n ></cds-tab>\n </cds-tabs>\n </ng-container>\n </ng-template>\n\n <div\n #tabContentContainer\n class=\"tab-content-container\"\n [ngClass]=\"{\n 'tab-content-container--dark': isDarkMode$ | async,\n 'tab-content-container--compact': compactMode$ | async,\n }\"\n *ngIf=\"{\n noTabsConfigured: noTabsConfigured$ | async,\n showTaskList: showTaskList$ | async,\n showNoAccess: showNoAccess$ | async,\n dossierDetailLayout: dossierDetailLayout$ | async,\n openTaskAndProcessLinkInModal: openTaskAndProcessLinkInModal$ | async,\n taskAndProcessLinkOpenedInPanel: taskAndProcessLinkOpenedInPanel$ | async,\n } as tabContentObs\"\n >\n <as-split\n direction=\"horizontal\"\n [disabled]=\"!tabContentObs.dossierDetailLayout.widthAdjustable\"\n [gutterSize]=\"DOSSIER_DETAIL_GUTTER_SIZE\"\n [unit]=\"tabContentObs.dossierDetailLayout.unit\"\n >\n <as-split-area\n [size]=\"tabContentObs.dossierDetailLayout.leftPanelWidth\"\n [minSize]=\"tabContentObs.dossierDetailLayout.leftPanelMinWidth\"\n [maxSize]=\"tabContentObs.dossierDetailLayout.leftPanelMaxWidth\"\n >\n <div\n class=\"card-body bg-white p-5 position-relative tab-container\"\n [class.tab-container--compact]=\"compactMode$ | async\"\n >\n <div *ngIf=\"loadingTabs$ | async\" class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n\n <valtimo-no-results\n *ngIf=\"tabContentObs.showNoAccess\"\n description=\"{{ 'dossier.noAccess.description' | translate }}\"\n title=\"{{ 'dossier.noAccess.title' | translate }}\"\n illustration=\"valtimo-layout/img/emptystate-not-authorised.svg\"\n >\n </valtimo-no-results>\n\n <valtimo-no-results\n *ngIf=\"tabContentObs.noTabsConfigured\"\n [description]=\"'dossier.tabs.noResultsDescription' | translate\"\n [title]=\"'dossier.tabs.noResults' | translate\"\n ></valtimo-no-results>\n\n <ng-template #tabContainer></ng-template>\n\n <div class=\"clearfix\"></div>\n </div>\n </as-split-area>\n\n <as-split-area\n *ngIf=\"tabContentObs.dossierDetailLayout.showRightPanel\"\n [size]=\"tabContentObs.dossierDetailLayout.rightPanelWidth\"\n [minSize]=\"tabContentObs.dossierDetailLayout.rightPanelMinWidth\"\n [maxSize]=\"tabContentObs.dossierDetailLayout.rightPanelMaxWidth\"\n >\n @if (tabContentObs.showTaskList) {\n <div class=\"task-panel\">\n @if (!tabContentObs.taskAndProcessLinkOpenedInPanel) {\n <valtimo-dossier-detail-task-list\n [openTaskAndProcessLinkInModal]=\"tabContentObs.openTaskAndProcessLinkInModal\"\n (taskClickEvent)=\"onTaskClickEvent($event)\"\n (formSubmitEvent)=\"onFormSubmitEvent()\"\n ></valtimo-dossier-detail-task-list>\n }\n\n @if (tabContentObs.taskAndProcessLinkOpenedInPanel) {\n <valtimo-dossier-detail-task-detail\n [taskAndProcessLink]=\"tabContentObs.taskAndProcessLinkOpenedInPanel\"\n (activeChange)=\"onActiveChangeEvent($event)\"\n (closeEvent)=\"onTaskDetailsClose()\"\n (formSubmit)=\"onFormSubmitEvent()\"\n >\n </valtimo-dossier-detail-task-detail>\n }\n </div>\n }\n </as-split-area>\n </as-split>\n </div>\n </div>\n\n <valtimo-dossier-supporting-process-start-modal\n [isAdmin]=\"isAdmin$ | async\"\n (formSubmit)=\"tabLoader.refreshView()\"\n #supportingProcessStartModal\n ></valtimo-dossier-supporting-process-start-modal>\n</div>\n\n<ng-template\n #caseDetailHeader\n let-canHaveAssignee=\"canHaveAssignee\"\n let-document=\"document\"\n let-canAssign=\"canAssign\"\n>\n <div class=\"row\" *ngIf=\"(customDossierHeaderItems || []).length > 0\">\n <span\n *ngFor=\"let item of customDossierHeaderItems\"\n [ngClass]=\"{\n h1: item.textSize === 'xl',\n h2: item.textSize === 'lg',\n h3: item.textSize === 'md',\n h4: item.textSize === 'sm',\n h5: item.textSize === 'xs',\n }\"\n class=\"mb-0 mt-0 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n item.columnSize * 2\n }} {{ item.customClass }}\"\n >\n <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n\n <span *ngIf=\"item.label && item.value\">: </span>\n\n <strong>{{ item.value }}</strong>\n </span>\n </div>\n\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailAssignee;\n context: {canHaveAssignee: canHaveAssignee, document: document, canAssign: canAssign}\n \"\n ></ng-container>\n</ng-template>\n\n<ng-template\n #caseDetailAssignee\n let-canHaveAssignee=\"canHaveAssignee\"\n let-document=\"document\"\n let-canAssign=\"canAssign\"\n>\n <div *ngIf=\"canHaveAssignee && document\">\n <valtimo-dossier-assign-user\n *ngIf=\"canAssignLoaded$ | async\"\n [assigneeFullName]=\"document?.assigneeFullName\"\n [assigneeId]=\"document.assigneeId\"\n [documentId]=\"document.id\"\n [hasPermission]=\"canAssign\"\n (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n ></valtimo-dossier-assign-user>\n </div>\n</ng-template>\n\n<ng-template #claimButton let-canClaim=\"canClaim\" let-canHaveAssignee=\"canHaveAssignee\">\n <cds-overflow-menu-option\n *ngIf=\"canClaim && canHaveAssignee\"\n [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n (click)=\"claimAssignee()\"\n >\n {{ 'dossier.claimAssigneeCase' | translate }}\n </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #unassignButton let-canHaveAssignee=\"canHaveAssignee\" let-assigneeId=\"assigneeId\">\n <cds-overflow-menu-option\n *ngIf=\"canHaveAssignee\"\n [disabled]=\"!assigneeId\"\n (selected)=\"unassignAssignee()\"\n >\n {{ 'assignDocument.remove' | translate }}\n </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #deleteButton let-canDelete=\"canDelete\">\n <cds-overflow-menu-option\n *ngIf=\"canDelete\"\n [disabled]=\"isDeleting$ | async\"\n (click)=\"deleteDocument()\"\n type=\"danger\"\n >\n {{ 'dossier.delete.delete' | translate }}\n </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #customStartTrigger>\n <button\n [size]=\"(compactMode$ | async) ? 'sm' : 'lg'\"\n cdsButton=\"primary\"\n [disabled]=\"processDocumentDefinitions.length === 0\"\n [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n >\n {{ 'dossier.startSubProcess' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"chevron--down\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<valtimo-confirmation-modal\n confirmButtonTextTranslationKey=\"dossier.delete.confirm\"\n confirmButtonType=\"danger\"\n contentTranslationKey=\"dossier.delete.description\"\n [showModalSubject$]=\"showDeleteModal$\"\n titleTranslationKey=\"dossier.delete.delete\"\n (confirmEvent)=\"onConfirmDelete()\"\n></valtimo-confirmation-modal>\n\n<ng-container renderInPageHeader [fullWidth]=\"true\">\n <ng-template>\n <div\n class=\"dossier-actions\"\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n *ngIf=\"{\n assigneeId: assigneeId$ | async,\n canAssign: canAssign$ | async,\n canClaim: canClaim$ | async,\n canHaveAssignee: canHaveAssignee$ | async,\n canDelete: canDelete$ | async,\n document: document$ | async,\n caseStatus: caseStatus$ | async,\n } as obs\"\n >\n <div\n class=\"dossier-status-assign-custom-title\"\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n >\n @if (obs.caseStatus) {\n <cds-tag size=\"sm\" [type]=\"obs.caseStatus.tagType\">{{ obs.caseStatus.title }}</cds-tag>\n }\n\n <div class=\"dossier-assign-user\" [ngClass]=\"{'--compact': compactMode$ | async}\">\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailAssignee;\n context: {\n canHaveAssignee: obs.canHaveAssignee,\n document: obs.document,\n canAssign: obs.canAssign,\n }\n \"\n ></ng-container>\n </div>\n\n <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n </div>\n\n <div class=\"buttons-container\">\n <cds-overflow-menu\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n *ngIf=\"obs.canHaveAssignee || obs.canDelete\"\n flip=\"true\"\n [offset]=\"(compactMode$ | async) ? {y: 48, x: -4} : {y: 48, x: 4}\"\n class=\"overflow-button assign-overflow\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n claimButton;\n context: {canClaim: obs.canClaim, canHaveAssignee: obs.canHaveAssignee}\n \"\n >\n </ng-container>\n <ng-container\n *ngTemplateOutlet=\"\n unassignButton;\n context: {canHaveAssignee: obs.canHaveAssignee, assigneeId: obs.assigneeId}\n \"\n >\n </ng-container>\n <ng-container *ngTemplateOutlet=\"deleteButton; context: {canDelete: obs.canDelete}\">\n </ng-container>\n </cds-overflow-menu>\n\n <cds-overflow-menu\n valtimoCdsOverflowButton\n [ngClass]=\"{'--compact': compactMode$ | async}\"\n [width]=\"250\"\n [customTrigger]=\"customStartTrigger\"\n [offset]=\"{y: 48, x: 35}\"\n class=\"overflow-button case-detail-overflow\"\n >\n <cds-overflow-menu-option\n *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n (click)=\"startProcess(processDocumentDefinition)\"\n >\n {{\n (processDocumentDefinition?.id?.processDefinitionKey | translate) !==\n processDocumentDefinition?.id?.processDefinitionKey\n ? (processDocumentDefinition.id.processDefinitionKey | translate)\n : processDocumentDefinition.processName\n }}\n </cds-overflow-menu-option>\n </cds-overflow-menu>\n </div>\n </div>\n </ng-template>\n</ng-container>\n", styles: [".main-content{overflow:hidden;padding-bottom:0}.main-content--no-horizontal-overflow{overflow-x:hidden}.tab-container{height:min-content;min-height:300px;overflow-y:auto;max-height:calc(100vh - 226px);overflow-x:hidden}.tab-container--compact{max-height:calc(100vh - 176px)}.tab-container:has(>.tab--no-margin){padding:0!important}.tab-container:has(>.tab--no-min-height){min-height:unset}.tab-container:has(>.tab--no-background){background:transparent!important}.tab-content-container{overflow:hidden;display:flex;gap:32px;overflow:auto;margin-bottom:16px;max-height:calc(100vh - 226px)}.tab-content-container--compact{max-height:calc(100vh - 176px)}.loading-container{display:flex;justify-content:center;flex-direction:row}.dossier-detail-page-header{display:flex;width:100%;justify-content:flex-start;padding-bottom:5px}.dossier-detail-page-header ::ng-deep .cds--tag{margin:0}.case-detail-tabs{display:flex;margin-bottom:24px}.case-detail-tabs cds-tab{display:none!important}.cds--overflow-menu-options{margin-top:32px}.assign-overflow{margin-right:8px}.buttons-container{display:flex;flex-direction:row}.dossier-actions{display:flex;width:100%;justify-content:space-between;align-items:flex-end;padding-bottom:4px}.dossier-actions.--compact{padding-bottom:0;align-items:flex-start}.dossier-actions ::ng-deep .version-selection{width:160px}.dossier-actions ::ng-deep .version-selection .cds--list-box__selection{display:none}.dossier-status-assign-custom-title{display:flex;gap:16px;align-items:flex-end}.dossier-status-assign-custom-title .cds--tag{margin:0;height:var(--cds-layout-size-height-md)}.dossier-status-assign-custom-title.--compact{align-items:center}.task-panel{width:100%;transition:height .15s ease-in-out}:host ::ng-deep .container-fluid{height:100%!important;width:100%!important;margin:0!important;padding:0!important}::ng-deep .tab-content-container .as-split-gutter{background-color:transparent!important;--_as-gutter-icon-disabled: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mP8/wcAAgEBAYcDngAAAAAASUVORK5CYII=);--_as-gutter-icon-horizontal: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAABQJJREFUeF7dWll22zAMpNwzlM5xmpMlOVl6mzrKHexWm8UFy4xIp+/FP3mxQWAwWAiRGsJ3/gwhhJvt4CRCfgCtosYhDOHm4SlW7rZyq9t/R7GsZoYQDhCA89UIrzakKuQtpRTiHv03ycJB3t8KuU9AByNfw5dWJpj1h5YABmGRsvgufzsSG21NEwGWUrv5yiuZb31yMZoAAjBFPqBdor9G0vpwu2+PBgE6TK/q0pUxxiwZxnE0SefkE0sHWQUygGG3ll0c2tGNn+M0DiSfHDlHQBu2rffoWgBWPRHWIUreM654li5bMwDQBIhI9naHFgVQCSS2PHliWlLm0/YsMrcwK6ISp1QGANhzG7XFDj2gUFr8yzrkydOJ6CyACBB1lIWkbPyeQ2UQ2ZKxksCLft4EaWqB/AshHCdg0b/1gB7wJB1QBrQ0ml4E2MMyFgxJ6iABuEGdgCUeZVQm+fQ7fhfAsflzAKFLS1G2ptmMwUpDl1oyAGxo2fw2hHBzjpsm+XiO2TGQF1GWACJGfecAjHmgCTZum/lQfezQTZ3L7z+g3goc2xGtFT86A0qLh5pgjPF13aLmv9aHdYiVn8uMwFNixQlYqVuNvayK3sZxNElgHarlP6duo2bpOcbXWxheVhkTj7Tv4ATsTG/OL6CG8DZ+KCQMIcSf6HnAAo8hrAjGRpIblLxveDm8/q4YC6fT6flyufzWBhXGoTWd4QOUp6enX9fr9X2od6SFhJlTu4FBGZA5n+jbnddZjPG8nz8lo222ItHJEraRICAAMmG6rPGb2FTjedqHsET+4/Lbu+phHWLlJ/g+Cd4gpJDgp71HHzAHFCqOEFCSULjrNkaxw2rO/zidnv/MNY99WIcY+TKufibUmOcSEB5IxLTHXLal2FG4h83VPzET1h6wUxDP8fXfJW5V8xuQhqFwVtGNgDuQ6Yo367Pb9ixdjVckVE1QS/0ekZhybRw/zMZblkBpd1sMPIdJkAsClF2ghQQPYJYBQjp5BKCBEHD4JZDi6bED3AebRDFbAp58Ski3JrgphQcgozEwXZ2dBH3nZ2Bq5KcyahuEgO1wIWBnyIuoS5hA9pHIp01dnANSdlvKwXWocRC6Pw/U70MBozCQAWI5JKDF5wFrtk8uR6XKYQibnL9dr+/CjgA5v81AamMFByTTmOhQp56hPw5/vrrvx61euz2gZKfHgcj98bUkgjo/WJCxeMrJFyQgR8ocQcGnwqsJpgSK8pymTPeIThus4DKwBKWJFNsFklEcOT9ApyFADswAQJMiwkaUldeQ7ZTKDWf79tsSgIasDwGduro1CbY+hVqZgpJ1SA5L6bQHMJNjOy19MsCgBiNgV8DK+1GxSXoYAcMwhNttOedPIZTPAhm8bQ6Anx57ZMBGgfHuXs6yuEANBBtR/2bIjzkj8bAMSIYU+KLDaoKSU8KFCOP7LAsTcDTZ2jPAfrUWf3VGnwdo1pgF5xiz9yhazwOExwfv9suEm2XArJwNtSP/+AxgwlHL1iVwiAUdhEaAxhtLWGbZDEbPEiCyhHWIla93KO7AvMoAwre7bW5jxCAfwaHnoa4N3gVU5X2RthX0gdVNBPhDZnYgzMH7ImKbCOA8wnfsVO+jeUgIEHfYFUs7jHYNLN2YvJkBXwYaNuQIwnp2cgoCag3LN1Z2+EwfwCVPLPAOJ1n05oDt9x5oRR37Pb72s/e+kU81L/EXSRwjcUdkvjUAAAAASUVORK5CYII=)}::ng-deep .tab-content-container .as-split-gutter-icon{background-repeat:no-repeat;background-size:16px 16px}::ng-deep .tab-content-container--dark .as-split-gutter{--_as-gutter-icon-horizontal: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAAXNSR0IArs4c6QAABPlJREFUeF7tm1tW3DAMhu2+krCmdmWlKytrIuGV9HjixDddfjkOtOd0XmAGWZfPsiw7g3fVyzvntvpD9H01+JIuwCamX5YKf9VfmCVaDze2S2fXIDG+CGC8YsrqMCvDFDmHZYCeI5gE6LietD2LlNb6uQAQTLWfCDTLmLpOIfoRvxEZydZn+pH7+vdlAEJyoIwIwDIrFtk7C2TyA/Po9gxY1zVWrN2haZq85FqS3zEF+YET3qi6rFzjfAR0yGkBwQA0wyFU75zf5MaOBYDoR2YGDigqY+U7HOKHlAsFiQOXqax+JYCYBGJr32ZAB+lEpxwc3i1nDcDWtBUYPjN8p35VBxf/4/MQUI7lqAGPzwjYBQDv3PQ0+Ue/CjV/sODp8+UiyNE7XLHO6EM+Dg4/ntBdAI69zdIqBlgTlDldADLN9a7R551cDot0kDPNbn40AIh6LSS4DS0Be9jJg7sAXPHJfBZojbXriMscGgDvvhUYmRGEes6iocJiyVejWdelYDPNk5cquhnAxVSAlgDZQG/7bUqKjvZEDqgdYwaAzQsrVQHowFkPqd5bA4LlO1ytp+zoFM0Ml2V5CYPmeX78lF7v67rla8B6GpynKZxnxBfmD03MvASCMe/9z+DRtm2/SAiZLXRGqcapbYTaICB/BHwggN1wbuzQSUHI3UQBHPqo+wPO/7dlefkWJ0PyR0ofEIAjg49Z8GOe51fOCAYgIcPkd2vLsnz33v+ubadJ0TZw8Fqcmnkk+CBjCahHXodQ49mhHGjUDJCDf37Vjmn54Sa4MuxGaL/weWzDdggJigjgDL7KpG3bxLTPmY/PALqa90JgAahpf/ohb8jjAfAlrQdCCSDG0gRPxCiHzf81XwKUVA1M7gDwbojbspsM4GZea3jov5cFp6cGoHYRFCWE5FthQwKAGCnLS9vD6UXwXbnIRpGUcsH3D6JxI2sADwFHwEnqAI4HKW0AB07ci6QDXgLHELUIghPxbxRBBukICDuAZMCaAbu8XnLf1K4wzBjdGYpzSUGI66ntBQg/8QzYB+PyyW18++sAEHvu8wSY02IbosyONaBTPj7XO6/F+SxVzgPKRooWlN7l0A0g+i0tGXrmvdu2D/qYTrBgO0GKG3ocRlrhB/jm6a13zR2i8GAk+BOOw/lmy95RMIlgAlAvh4ex5/ll5CUndYMkJfGNFyL84sCuoHa3tSVQW9HkGxjeueUNv6Krx7dbTO5R/J1FARSQ9X3d8gyh13RSZAYA9iOcmHkJWO1ZA+LkRdbaRAlO3wogKL/+/YDZl5cuFQogC/P4k/j+mx0AYVDyYVQGWDMPlbcDQDVHOREA1DmGDAgv7emA0bEofgmAmn3euXUpT3d9Z4G+4PRR+6PR9oigRqarPiT6ng4nBzRguCe0ZJEBatyqQGvkfw249VtiHTNSzdGZAddVESmW1YBDv5bSpoxBnOZkst7h6jISx5sCEltnJFp7KKkG3KNfPQvULluB2UMuR1zaBiXjB08+IJr4FQA9c3gDgNINKSDK4SCff67VjEsZEI+Cl3Scg3vwA4cU6uu0bRL3d4k3ZEDm3mAoY2YqdX7BvVsA2OJW9qlhUe+KQvObX1DYANS+2iIdHArR0bArgXfUBoAMoewopH9ROd3oBmcZiMkOANA3sXUq9mm5Pqrvq7IYXLo3Vs713ao7WRAZ8NULfTACRd0fdjtUcYyr1cIAAAAASUVORK5CYII=)}\n"] }]
437
+ }], ctorParameters: () => [{ type: i1.BreadcrumbService }, { type: i2.CaseStatusService }, { type: i1.CdsThemeService }, { type: i0.ComponentFactoryResolver }, { type: i3.ConfigService }, { type: i2.DocumentService }, { type: i4.DossierDetailLayoutService }, { type: i4.DossierService }, { type: i4.DossierTabService }, { type: i5.IconService }, { type: i6.KeycloakService }, { type: i7.NGXLogger }, { type: i5.NotificationService }, { type: i1.PageHeaderService }, { type: i1.PageTitleService }, { type: i8.PermissionService }, { type: i9.TranslateService }, { type: i0.Renderer2 }, { type: i10.ActivatedRoute }, { type: i10.Router }, { type: i11.WidgetsService }, { type: i12.UserProviderService }, { type: Document, decorators: [{
392
438
  type: Inject,
393
439
  args: [DOCUMENT]
394
440
  }] }], propDecorators: { supportingProcessStart: [{
@@ -401,4 +447,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
401
447
  type: ViewChild,
402
448
  args: ['tabContentContainer']
403
449
  }] } });
404
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-detail.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/dossier-detail.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/dossier-detail.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 {DOCUMENT} from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  ComponentFactoryResolver,\n  ElementRef,\n  Inject,\n  OnDestroy,\n  Renderer2,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ActivatedRoute, NavigationStart, ParamMap, Params, Router} from '@angular/router';\nimport {ChevronDown16} from '@carbon/icons';\nimport {PermissionService} from '@valtimo/access-control';\nimport {\n  BreadcrumbService,\n  CARBON_CONSTANTS,\n  CdsThemeService,\n  CurrentCarbonTheme,\n  PageHeaderService,\n  PageTitleService,\n  PendingChangesComponent,\n} from '@valtimo/components';\nimport {ConfigService} from '@valtimo/config';\nimport {\n  CaseStatusService,\n  Document as ValtimoDocument,\n  DocumentService,\n  InternalCaseStatus,\n  InternalCaseStatusUtils,\n  ProcessDocumentDefinition,\n} from '@valtimo/document';\nimport {ProcessInstanceTask} from '@valtimo/process';\nimport {IntermediateSubmission, Task, TaskProcessLinkResult, TaskService} from '@valtimo/task';\nimport {IconService, NotificationService} from 'carbon-components-angular';\nimport {KeycloakService} from 'keycloak-angular';\nimport moment from 'moment';\nimport {NGXLogger} from 'ngx-logger';\nimport {\n  BehaviorSubject,\n  catchError,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  of,\n  startWith,\n  Subject,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {\n  DOSSIER_DETAIL_DEFAULT_DISPLAY_SIZE,\n  DOSSIER_DETAIL_DEFAULT_DISPLAY_TYPE,\n  DOSSIER_DETAIL_GUTTER_SIZE,\n} from '../../constants';\nimport {TabImpl, TabLoaderImpl} from '../../models';\nimport {\n  CAN_ASSIGN_CASE_PERMISSION,\n  CAN_CLAIM_CASE_PERMISSION,\n  DOSSIER_DETAIL_PERMISSION_RESOURCE,\n} from '../../permissions';\nimport {DossierDetailLayoutService, DossierService, DossierTabService} from '../../services';\nimport {DossierSupportingProcessStartModalComponent} from '../dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component';\nimport {UserProviderService} from '@valtimo/security';\nimport {isBoolean} from 'lodash';\nimport {TranslateService} from '@ngx-translate/core';\n\n@Component({\n  selector: 'valtimo-dossier-detail',\n  templateUrl: './dossier-detail.component.html',\n  styleUrls: ['./dossier-detail.component.scss'],\n  providers: [DossierTabService, DossierDetailLayoutService, NotificationService],\n})\nexport class DossierDetailComponent\n  extends PendingChangesComponent\n  implements AfterViewInit, OnDestroy\n{\n  @ViewChild('supportingProcessStartModal')\n  supportingProcessStart: DossierSupportingProcessStartModalComponent;\n\n  @ViewChild('tabContainer', {read: ViewContainerRef})\n  viewContainerRef: ViewContainerRef;\n\n  @ViewChild('tabContentContainer')\n  private readonly _tabContentContainer!: ElementRef<HTMLDivElement>;\n\n  public customDossierHeaderItems: Array<any> = [];\n  public document: ValtimoDocument | null = null;\n  public documentDefinitionName: string;\n  public documentDefinitionNameTitle: string;\n  public documentId: string;\n  public processDefinitionListFields: Array<any> = [];\n  public processDocumentDefinitions: ProcessDocumentDefinition[] = [];\n  public tabLoader: TabLoaderImpl | null = null;\n\n  public readonly assigneeId$ = new BehaviorSubject<string>('');\n  public readonly currentIntermediateSave$ = new BehaviorSubject<IntermediateSubmission | null>(\n    null\n  );\n  public readonly isAdmin$: Observable<boolean> = this.userProviderService\n    .getUserSubject()\n    .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));\n\n  public readonly taskOpenedInPanel$ = this.dossierDetailLayoutService.taskOpenedInPanel$;\n\n  private readonly _caseStatusKey$ = new BehaviorSubject<string | null | 'NOT_AVAILABLE'>(null);\n\n  public readonly caseStatusKey$: Observable<string | 'NOT_AVAILABLE'> = this._caseStatusKey$.pipe(\n    filter(key => !!key)\n  );\n\n  public readonly document$: Observable<ValtimoDocument | null> =\n    this.dossierService.refreshDocument$.pipe(\n      switchMap(() => this.route.params),\n      map((params: Params) => params?.documentId),\n      switchMap((documentId: string) =>\n        documentId ? this.documentService.getDocument(this.documentId) : of(null)\n      ),\n      tap((document: ValtimoDocument | null) => {\n        if (document) {\n          this.assigneeId$.next(document.assigneeId);\n          this.document = document;\n          this._caseStatusKey$.next(document?.internalStatus || 'NOT_AVAILABLE');\n\n          if (\n            this.configService.config.customDossierHeader?.hasOwnProperty(\n              this.documentDefinitionName.toLowerCase()\n            ) &&\n            this.customDossierHeaderItems.length === 0\n          ) {\n            this.configService.config.customDossierHeader[\n              this.documentDefinitionName.toLowerCase()\n            ]?.forEach(item => this.getCustomDossierHeaderItem(item));\n          }\n        }\n      })\n    );\n\n  public readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params.documentDefinitionName || '')\n  );\n\n  public readonly caseStatus$: Observable<InternalCaseStatus | undefined> =\n    this.documentDefinitionName$.pipe(\n      filter(documentDefinitionName => !!documentDefinitionName),\n      switchMap(documentDefinitionName =>\n        combineLatest([\n          this.caseStatusService.getInternalCaseStatuses(documentDefinitionName),\n          this.caseStatusKey$,\n        ])\n      ),\n      map(\n        ([statuses, key]) => key !== 'NOT_AVAILABLE' && statuses.find(status => status?.key === key)\n      ),\n      map(\n        status =>\n          status && {\n            ...status,\n            tagType: InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(status.color),\n          }\n      )\n    );\n\n  public readonly userId$: Observable<string | undefined> = of(\n    this.keyCloakService.isLoggedIn()\n  ).pipe(\n    switchMap(() => this.keyCloakService.loadUserProfile()),\n    map(profile => profile?.id)\n  );\n\n  public readonly isAssigning$ = new BehaviorSubject<boolean>(false);\n  public readonly isAssignedToCurrentUser$: Observable<boolean> = combineLatest([\n    this.assigneeId$,\n    this.userId$,\n  ]).pipe(\n    map(([assigneeId, userId]) => !!assigneeId && !!userId && assigneeId === userId),\n    startWith(true)\n  );\n\n  public readonly canHaveAssignee$: Observable<boolean> = this.documentDefinitionName$.pipe(\n    switchMap(documentDefinitionName =>\n      this.documentService.getCaseSettings(documentDefinitionName)\n    ),\n    map(caseSettings => caseSettings?.canHaveAssignee)\n  );\n\n  public readonly canAssignLoaded$ = new BehaviorSubject<boolean>(false);\n  public readonly canAssign$: Observable<boolean> = this.route.paramMap.pipe(\n    switchMap((params: ParamMap) =>\n      this.permissionService.requestPermission(CAN_ASSIGN_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: params.get('documentId') ?? '',\n      })\n    ),\n    tap(() => {\n      this.canAssignLoaded$.next(true);\n    })\n  );\n\n  public readonly canClaim$: Observable<boolean> = this.route.paramMap.pipe(\n    switchMap((params: ParamMap) =>\n      this.permissionService.requestPermission(CAN_CLAIM_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: params.get('documentId') ?? '',\n      })\n    )\n  );\n\n  public readonly loadingTabs$ = new BehaviorSubject<boolean>(true);\n  public readonly noTabsConfigured$ = new BehaviorSubject<boolean>(false);\n  public activeTab$: Observable<TabImpl>;\n\n  public readonly compactMode$ = this.pageHeaderService.compactMode$;\n\n  public readonly tabHorizontalOverflowDisabled =\n    this.dossierTabService.tabHorizontalOverflowDisabled;\n\n  public readonly showTaskList$ = this.dossierTabService.showTaskList$;\n\n  private readonly _activeTabName$ = new BehaviorSubject<string | null>(null);\n  public get activeTabName$(): Observable<string | null> {\n    return combineLatest([this.route.paramMap, this._activeTabName$]).pipe(\n      map(([paramMap, activeTabName]) =>\n        !activeTabName ? (paramMap.get('tab') ?? null) : activeTabName\n      )\n    );\n  }\n\n  public readonly DOSSIER_DETAIL_GUTTER_SIZE = DOSSIER_DETAIL_GUTTER_SIZE;\n\n  public readonly dossierDetailLayout$ = this.dossierDetailLayoutService.dossierDetailLayout$;\n\n  public readonly openTaskInModal$ = new Subject<Task>();\n\n  public readonly isDarkMode$ = this.cdsThemeService.currentTheme$.pipe(\n    map(currentTheme => currentTheme === CurrentCarbonTheme.G90)\n  );\n\n  private _snapshot: ParamMap;\n  private _initialTabName: string;\n  private _activeChange = false;\n  private _oldTabName: string;\n  private _pendingTab: TabImpl;\n  private _observer!: ResizeObserver;\n  private _tabsInit = false;\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly breadcrumbService: BreadcrumbService,\n    private readonly caseStatusService: CaseStatusService,\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly componentFactoryResolver: ComponentFactoryResolver,\n    private readonly configService: ConfigService,\n    private readonly documentService: DocumentService,\n    private readonly dossierDetailLayoutService: DossierDetailLayoutService,\n    private readonly dossierService: DossierService,\n    private readonly dossierTabService: DossierTabService,\n    private readonly iconService: IconService,\n    private readonly keyCloakService: KeycloakService,\n    private readonly logger: NGXLogger,\n    private readonly notificationService: NotificationService,\n    private readonly pageHeaderService: PageHeaderService,\n    private readonly pageTitleService: PageTitleService,\n    private readonly permissionService: PermissionService,\n    private readonly translateService: TranslateService,\n    private readonly renderer: Renderer2,\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly taskService: TaskService,\n    private readonly userProviderService: UserProviderService,\n    @Inject(DOCUMENT) private readonly htmlDocument: Document\n  ) {\n    super();\n    this._snapshot = this.route.snapshot.paramMap;\n    this.documentDefinitionName = this._snapshot.get('documentDefinitionName') || '';\n    this.documentId = this._snapshot.get('documentId') || '';\n  }\n\n  public ngAfterViewInit(): void {\n    this.initTabLoader();\n    this.initBreadcrumb();\n    this.getAllAssociatedProcessDefinitions();\n    this.openWidthObserver();\n    this.pageTitleService.disableReset();\n    this.iconService.registerAll([ChevronDown16]);\n    this.setDocumentStyle();\n    this.enableResetOnBackNavigation();\n  }\n\n  public ngOnDestroy(): void {\n    this.breadcrumbService.clearSecondBreadcrumb();\n    this.pageTitleService.enableReset();\n    this.removeDocumentStyle();\n    this._subscriptions.unsubscribe();\n  }\n\n  public getAllAssociatedProcessDefinitions(): void {\n    this.documentService\n      .findProcessDocumentDefinitionsByStartableByUser(this.documentDefinitionName, true)\n      .subscribe((processDocumentDefinitions: ProcessDocumentDefinition[]) => {\n        this.processDocumentDefinitions = processDocumentDefinitions;\n\n        this.processDefinitionListFields = [\n          {\n            key: 'processName',\n            label: 'Proces',\n          },\n        ];\n      });\n  }\n\n  public startProcess(processDocumentDefinition: ProcessDocumentDefinition): void {\n    this.supportingProcessStart.openModal(processDocumentDefinition, this.documentId);\n  }\n\n  public claimAssignee(): void {\n    this.isAssigning$.next(true);\n\n    this.userId$\n      .pipe(\n        take(1),\n        switchMap((userId: string | undefined) =>\n          this.documentService.assignHandlerToDocument(this.documentId, userId ?? '')\n        )\n      )\n      .subscribe({\n        next: (): void => {\n          this.isAssigning$.next(false);\n          this.dossierService.refresh();\n        },\n        error: (): void => {\n          this.isAssigning$.next(false);\n          this.logger.debug('Something went wrong while assigning user to case');\n        },\n      });\n  }\n\n  public unassignAssignee(): void {\n    this.isAssigning$.next(true);\n\n    this.userId$\n      .pipe(\n        take(1),\n        switchMap((userId: string | undefined) =>\n          this.documentService.unassignHandlerFromDocument(this.documentId)\n        )\n      )\n      .subscribe({\n        next: (): void => {\n          this.isAssigning$.next(false);\n          this.dossierService.refresh();\n        },\n        error: (): void => {\n          this.isAssigning$.next(false);\n          this.logger.debug('Something went wrong while unassigning user from case');\n        },\n      });\n  }\n\n  public onTaskClickEvent(task: Task): void {\n    this.taskService\n      .getTaskProcessLink(task.id)\n      .pipe(catchError(() => this.isAdmin$))\n      .subscribe((result: TaskProcessLinkResult | boolean) => {\n        if (isBoolean(result)) {\n          this.handleNoTaskProcessLink(result as boolean);\n          return;\n        }\n\n        const displayType =\n          (result as TaskProcessLinkResult).properties.formDisplayType || DOSSIER_DETAIL_DEFAULT_DISPLAY_TYPE;\n        const size = (result as TaskProcessLinkResult).properties.formSize || DOSSIER_DETAIL_DEFAULT_DISPLAY_SIZE;\n\n        this.dossierDetailLayoutService.setFormDisplaySize(size);\n        this.dossierDetailLayoutService.setFormDisplayType(displayType);\n\n        if (displayType === 'panel') {\n          this.dossierDetailLayoutService.setTaskOpenedInPanel(task as any as ProcessInstanceTask);\n        } else {\n          this.openTaskInModal$.next({...task});\n        }\n      });\n  }\n\n  public onTaskDetailsClose(): void {\n    this.dossierDetailLayoutService.setTaskOpenedInPanel(null);\n  }\n\n  public onActiveChangeEvent(event: boolean): void {\n    this._activeChange = event;\n  }\n\n  public onTabSelected(tab: TabImpl, activeTab: TabImpl): void {\n    if (!this.tabLoader) return;\n\n    if (!this._tabsInit) {\n      this._tabsInit = true;\n      return;\n    }\n\n    this._oldTabName = activeTab.name;\n    this._pendingTab = tab;\n    this._activeTabName$.next(tab.name);\n    this.pendingChanges =\n      tab.contentKey === 'summary' ? false : !tab.showTasks && this._activeChange;\n\n    if (this.pendingChanges) {\n      this.tabLoader.replaceUrlState(tab);\n      return;\n    }\n\n    if (!tab.showTasks) this.openTaskInModal$.next(null);\n    this.tabLoader.load(tab);\n    this.setDocumentStyle();\n  }\n\n  public onFormSubmitEvent(): void {\n    this.dossierDetailLayoutService.setTaskOpenedInPanel(null);\n\n    if (!this.tabLoader) return;\n    this.tabLoader.refreshView();\n  }\n\n  protected onConfirmRedirect(): void {\n    if (!this.tabLoader || !this._pendingTab) return;\n    this._activeChange = false;\n    this._activeTabName$.next(this._pendingTab.name);\n    this.tabLoader.load(this._pendingTab);\n    this.dossierDetailLayoutService.setTaskOpenedInPanel(null);\n  }\n\n  protected onCancelRedirect(): void {\n    if (!this.tabLoader) return;\n    this._activeTabName$.next(this._oldTabName);\n  }\n\n  private initBreadcrumb(): void {\n    this.documentService\n      .getDocumentDefinition(this.documentDefinitionName)\n      .subscribe(definition => {\n        this.documentDefinitionNameTitle = definition.schema.title;\n        this.setBreadcrumb();\n      });\n  }\n\n  private initTabLoader(): void {\n    this.dossierTabService.tabs$.pipe(take(1)).subscribe(tabs => {\n      if (tabs?.length > 0) {\n        this._initialTabName = this._snapshot.get('tab') ?? '';\n        this.tabLoader = new TabLoaderImpl(\n          tabs,\n          this.componentFactoryResolver,\n          this.viewContainerRef,\n          this.router,\n          this.route\n        );\n        this.tabLoader.initial(this._initialTabName);\n        this.dossierTabService.setTabLoader(this.tabLoader);\n        this.loadingTabs$.next(false);\n        this.activeTab$ = this.tabLoader.activeTab$;\n      } else {\n        this.noTabsConfigured$.next(true);\n        this.loadingTabs$.next(false);\n      }\n    });\n  }\n\n  public assignmentOfDocumentChanged(): void {\n    this.dossierService.refresh();\n  }\n\n  private getCustomDossierHeaderItem(item): void {\n    this.customDossierHeaderItems.push({\n      label: item['labelTranslationKey'] || '',\n      columnSize: item['columnSize'] || 3,\n      textSize: item['textSize'] || 'md',\n      customClass: item['customClass'] || '',\n      modifier: item['modifier'] || '',\n      value: item['propertyPaths']?.reduce(\n        (prev, curr) => prev + this.getStringFromDocumentPath(item, curr),\n        ''\n      ),\n    });\n  }\n\n  private getStringFromDocumentPath(item, path): string {\n    const prefix = item['propertyPaths'].indexOf(path) > 0 ? ' ' : '';\n    let string = this.getNestedProperty(this.document.content, path, item['noValueText']) || '';\n    const dateFormats = [moment.ISO_8601, 'MM-DD-YYYY', 'DD-MM-YYYY', 'YYYY-MM-DD'];\n    switch (item['modifier']) {\n      case 'age': {\n        if (moment(string, dateFormats, true).isValid()) {\n          string = moment().diff(string, 'years');\n        }\n        break;\n      }\n      default: {\n        if (moment(string, dateFormats, true).isValid()) {\n          string = moment(string).format('DD-MM-YYYY');\n        }\n      }\n    }\n    return prefix + string;\n  }\n\n  private getNestedProperty(obj: any, path: string, defaultValue: any): any {\n    return (\n      path.split('.').reduce((currentObject, key) => currentObject?.[key], obj) || defaultValue\n    );\n  }\n\n  private enableResetOnBackNavigation(): void {\n    this._subscriptions.add(\n      this.router.events\n        .pipe(\n          filter(\n            event => event instanceof NavigationStart && event.navigationTrigger === 'popstate'\n          )\n        )\n        .subscribe(() => {\n          this.pageTitleService.enableReset();\n        })\n    );\n  }\n\n  private setBreadcrumb(): void {\n    this.breadcrumbService.setSecondBreadcrumb({\n      route: [`/dossiers/${this.documentDefinitionName}`],\n      content: this.documentDefinitionNameTitle,\n      href: `/dossiers/${this.documentDefinitionName}`,\n    });\n  }\n\n  private openWidthObserver(): void {\n    if (!this._tabContentContainer.nativeElement) return;\n\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._tabContentContainer.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const elementWidth = event[0]?.borderBoxSize[0]?.inlineSize;\n\n    if (typeof elementWidth === 'number' && elementWidth !== 0) {\n      this.dossierDetailLayoutService.setTabContentContainerWidth(elementWidth);\n    }\n  }\n\n  private setDocumentStyle(): void {\n    this.renderer.addClass(this.htmlDocument.getElementsByTagName('html')[0], 'html--fixed');\n  }\n\n  private removeDocumentStyle(): void {\n    this.renderer.removeClass(this.htmlDocument.getElementsByTagName('html')[0], 'html--fixed');\n  }\n\n  private handleNoTaskProcessLink(isAdmin: boolean): void {\n    this.notificationService.showActionable({\n      type: 'warning',\n      lowContrast: true,\n      title: this.translateService.instant('dossier.noLinkedProcessNotification'),\n      ...(isAdmin && {\n        actions: [\n          {\n            text: this.translateService.instant('dossier.configure'),\n            click: () => this.router.navigate(['/process-links']),\n          },\n        ],\n      }),\n      duration: CARBON_CONSTANTS.notificationDuration,\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<div\n  class=\"main-content\"\n  [ngClass]=\"{'main-content--no-horizontal-overflow': tabHorizontalOverflowDisabled()}\"\n>\n  <div class=\"container-fluid\">\n    <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n\n    <ng-template #tabs>\n      <ng-container *ngIf=\"{activeTab: activeTab$ | async} as obs\">\n        <cds-tabs *ngIf=\"tabLoader\" type=\"inline\" class=\"case-detail-tabs\">\n          <cds-tab\n            *ngFor=\"let tab of tabLoader.tabs\"\n            [active]=\"tab.name === (activeTabName$ | async)\"\n            heading=\"{{ tab | tabTranslate | async }}\"\n            (selected)=\"onTabSelected(tab, obs.activeTab)\"\n          ></cds-tab>\n        </cds-tabs>\n      </ng-container>\n    </ng-template>\n\n    <div\n      #tabContentContainer\n      class=\"tab-content-container\"\n      [ngClass]=\"{\n        'tab-content-container--dark': isDarkMode$ | async,\n        'tab-content-container--compact': compactMode$ | async,\n      }\"\n      *ngIf=\"{\n        noTabsConfigured: noTabsConfigured$ | async,\n        showTaskList: showTaskList$ | async,\n        taskOpenedInPanel: taskOpenedInPanel$ | async,\n        dossierDetailLayout: dossierDetailLayout$ | async,\n      } as tabContentObs\"\n    >\n      <as-split\n        direction=\"horizontal\"\n        [disabled]=\"!tabContentObs.dossierDetailLayout.widthAdjustable\"\n        [gutterSize]=\"DOSSIER_DETAIL_GUTTER_SIZE\"\n        [unit]=\"tabContentObs.dossierDetailLayout.unit\"\n      >\n        <as-split-area\n          [size]=\"tabContentObs.dossierDetailLayout.leftPanelWidth\"\n          [minSize]=\"tabContentObs.dossierDetailLayout.leftPanelMinWidth\"\n          [maxSize]=\"tabContentObs.dossierDetailLayout.leftPanelMaxWidth\"\n        >\n          <div\n            class=\"card-body bg-white p-5 position-relative tab-container\"\n            [class.tab-container--compact]=\"compactMode$ | async\"\n          >\n            <div *ngIf=\"loadingTabs$ | async\" class=\"loading-container\">\n              <cds-loading></cds-loading>\n            </div>\n\n            <valtimo-no-results\n              *ngIf=\"tabContentObs.noTabsConfigured\"\n              [description]=\"'dossier.tabs.noResultsDescription' | translate\"\n              [title]=\"'dossier.tabs.noResults' | translate\"\n            ></valtimo-no-results>\n\n            <ng-template #tabContainer></ng-template>\n\n            <div class=\"clearfix\"></div>\n          </div>\n        </as-split-area>\n\n        <as-split-area\n          *ngIf=\"tabContentObs.dossierDetailLayout.showRightPanel\"\n          [size]=\"tabContentObs.dossierDetailLayout.rightPanelWidth\"\n          [minSize]=\"tabContentObs.dossierDetailLayout.rightPanelMinWidth\"\n          [maxSize]=\"tabContentObs.dossierDetailLayout.rightPanelMaxWidth\"\n        >\n          @if (tabContentObs.showTaskList) {\n            <div class=\"task-panel\">\n              @if (!tabContentObs.taskOpenedInPanel) {\n                <valtimo-dossier-detail-task-list\n                  [openInTaskModal]=\"openTaskInModal$ | async\"\n                  (taskClickEvent)=\"onTaskClickEvent($event)\"\n                  (formSubmitEvent)=\"onFormSubmitEvent()\"\n                ></valtimo-dossier-detail-task-list>\n              }\n\n              @if (tabContentObs.taskOpenedInPanel) {\n                <valtimo-dossier-detail-task-detail\n                  [task]=\"tabContentObs.taskOpenedInPanel\"\n                  (activeChange)=\"onActiveChangeEvent($event)\"\n                  (closeEvent)=\"onTaskDetailsClose()\"\n                  (formSubmit)=\"onFormSubmitEvent()\"\n                >\n                </valtimo-dossier-detail-task-detail>\n              }\n            </div>\n          }\n        </as-split-area>\n      </as-split>\n    </div>\n  </div>\n\n  <valtimo-dossier-supporting-process-start-modal\n    [isAdmin]=\"isAdmin$ | async\"\n    (formSubmit)=\"tabLoader.refreshView()\"\n    #supportingProcessStartModal\n  ></valtimo-dossier-supporting-process-start-modal>\n</div>\n\n<ng-template\n  #caseDetailHeader\n  let-canHaveAssignee=\"canHaveAssignee\"\n  let-document=\"document\"\n  let-canAssign=\"canAssign\"\n>\n  <div class=\"row\" *ngIf=\"(customDossierHeaderItems || []).length > 0\">\n    <span\n      *ngFor=\"let item of customDossierHeaderItems\"\n      [ngClass]=\"{\n        h1: item.textSize === 'xl',\n        h2: item.textSize === 'lg',\n        h3: item.textSize === 'md',\n        h4: item.textSize === 'sm',\n        h5: item.textSize === 'xs',\n      }\"\n      class=\"mb-0 mt-0 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n        item.columnSize * 2\n      }} {{ item.customClass }}\"\n    >\n      <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n\n      <span *ngIf=\"item.label && item.value\">: </span>\n\n      <strong>{{ item.value }}</strong>\n    </span>\n  </div>\n\n  <ng-container\n    *ngTemplateOutlet=\"\n      caseDetailAssignee;\n      context: {canHaveAssignee: canHaveAssignee, document: document, canAssign: canAssign}\n    \"\n  ></ng-container>\n</ng-template>\n\n<ng-template\n  #caseDetailAssignee\n  let-canHaveAssignee=\"canHaveAssignee\"\n  let-document=\"document\"\n  let-canAssign=\"canAssign\"\n>\n  <div *ngIf=\"canHaveAssignee && document\">\n    <valtimo-dossier-assign-user\n      *ngIf=\"canAssignLoaded$ | async\"\n      [assigneeFullName]=\"document?.assigneeFullName\"\n      [assigneeId]=\"document.assigneeId\"\n      [documentId]=\"document.id\"\n      [hasPermission]=\"canAssign\"\n      (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n    ></valtimo-dossier-assign-user>\n  </div>\n</ng-template>\n\n<ng-template #claimButton let-canClaim=\"canClaim\" let-canHaveAssignee=\"canHaveAssignee\">\n  <cds-overflow-menu-option\n    *ngIf=\"canClaim && canHaveAssignee\"\n    [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n    (click)=\"claimAssignee()\"\n  >\n    <span>{{ 'dossier.claimAssigneeCase' | translate }}</span>\n  </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #customStartTrigger>\n  <button\n    [size]=\"(compactMode$ | async) ? 'sm' : 'lg'\"\n    cdsButton=\"primary\"\n    [disabled]=\"processDocumentDefinitions.length === 0\"\n    [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n  >\n    {{ 'dossier.startSubProcess' | translate }}\n\n    <svg class=\"cds--btn__icon\" cdsIcon=\"chevron--down\" size=\"16\"></svg>\n  </button>\n</ng-template>\n\n<ng-container renderInPageHeader [fullWidth]=\"true\">\n  <ng-template>\n    <div\n      class=\"dossier-actions\"\n      [ngClass]=\"{'--compact': compactMode$ | async}\"\n      *ngIf=\"{\n        assigneeId: assigneeId$ | async,\n        canAssign: canAssign$ | async,\n        canClaim: canClaim$ | async,\n        canHaveAssignee: canHaveAssignee$ | async,\n        document: document$ | async,\n        caseStatus: caseStatus$ | async,\n      } as obs\"\n    >\n      <div\n        class=\"dossier-status-assign-custom-title\"\n        [ngClass]=\"{'--compact': compactMode$ | async}\"\n      >\n        @if (obs.caseStatus) {\n          <cds-tag size=\"sm\" [type]=\"obs.caseStatus.tagType\">{{ obs.caseStatus.title }}</cds-tag>\n        }\n\n        <div class=\"dossier-assign-user\" [ngClass]=\"{'--compact': compactMode$ | async}\">\n          <ng-container\n            *ngTemplateOutlet=\"\n              caseDetailAssignee;\n              context: {\n                canHaveAssignee: obs.canHaveAssignee,\n                document: obs.document,\n                canAssign: obs.canAssign,\n              }\n            \"\n          ></ng-container>\n        </div>\n\n        <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n      </div>\n\n      <div class=\"buttons-container\">\n        <cds-overflow-menu\n          [ngClass]=\"{'--compact': compactMode$ | async}\"\n          *ngIf=\"obs.canHaveAssignee\"\n          flip=\"true\"\n          [offset]=\"(compactMode$ | async) ? {y: 48, x: -4} : {y: 48, x: 4}\"\n          class=\"overflow-button assign-overflow\"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"\n              claimButton;\n              context: {canClaim: obs.canClaim, canHaveAssignee: obs.canHaveAssignee}\n            \"\n          >\n          </ng-container>\n          <cds-overflow-menu-option (selected)=\"unassignAssignee()\" [disabled]=\"!obs.assigneeId\">\n            {{ 'assignDocument.remove' | translate }}\n          </cds-overflow-menu-option>\n        </cds-overflow-menu>\n\n        <cds-overflow-menu\n          valtimoCdsOverflowButton\n          [ngClass]=\"{'--compact': compactMode$ | async}\"\n          [width]=\"250\"\n          [customTrigger]=\"customStartTrigger\"\n          [offset]=\"{y: 48, x: 35}\"\n          class=\"overflow-button case-detail-overflow\"\n        >\n          <cds-overflow-menu-option\n            *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n            (click)=\"startProcess(processDocumentDefinition)\"\n          >\n            {{\n              (processDocumentDefinition?.id?.processDefinitionKey | translate) !==\n              processDocumentDefinition?.id?.processDefinitionKey\n                ? (processDocumentDefinition.id.processDefinitionKey | translate)\n                : processDocumentDefinition.processName\n            }}\n          </cds-overflow-menu-option>\n        </cds-overflow-menu>\n      </div>\n    </div>\n  </ng-template>\n</ng-container>\n"]}
450
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-detail.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/dossier-detail.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/dossier-detail.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 {DOCUMENT} from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  ComponentFactoryResolver,\n  ElementRef,\n  Inject,\n  OnDestroy,\n  Renderer2,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ActivatedRoute, NavigationStart, ParamMap, Params, Router} from '@angular/router';\nimport {ChevronDown16} from '@carbon/icons';\nimport {TranslateService} from '@ngx-translate/core';\nimport {PermissionService} from '@valtimo/access-control';\nimport {\n  BreadcrumbService,\n  CARBON_CONSTANTS,\n  CdsThemeService,\n  CurrentCarbonTheme,\n  PageHeaderService,\n  PageTitleService,\n  PendingChangesComponent,\n} from '@valtimo/components';\nimport {ConfigService} from '@valtimo/config';\nimport {\n  CaseStatusService,\n  Document as ValtimoDocument,\n  DocumentService,\n  InternalCaseStatus,\n  InternalCaseStatusUtils,\n  ProcessDocumentDefinition,\n} from '@valtimo/document';\nimport {TaskWithProcessLink} from '@valtimo/process-link';\nimport {UserProviderService} from '@valtimo/security';\nimport {IntermediateSubmission} from '@valtimo/task';\nimport {IconService, NotificationService} from 'carbon-components-angular';\nimport {KeycloakService} from 'keycloak-angular';\nimport moment from 'moment';\nimport {NGXLogger} from 'ngx-logger';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  of,\n  startWith,\n  Subject,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {\n  DOSSIER_DETAIL_DEFAULT_DISPLAY_SIZE,\n  DOSSIER_DETAIL_DEFAULT_DISPLAY_TYPE,\n  DOSSIER_DETAIL_GUTTER_SIZE,\n} from '../../constants';\nimport {TabImpl, TabLoaderImpl} from '../../models';\nimport {\n  CAN_ASSIGN_CASE_PERMISSION,\n  CAN_CLAIM_CASE_PERMISSION,\n  CAN_DELETE_CASE_PERMISSION,\n  CAN_VIEW_CASE_PERMISSION,\n  DOSSIER_DETAIL_PERMISSION_RESOURCE,\n} from '../../permissions';\nimport {DossierDetailLayoutService, DossierService, DossierTabService} from '../../services';\nimport {DossierSupportingProcessStartModalComponent} from '../dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component';\nimport {WidgetsService} from './tab/widgets/widgets.service';\n\n@Component({\n  selector: 'valtimo-dossier-detail',\n  templateUrl: './dossier-detail.component.html',\n  styleUrls: ['./dossier-detail.component.scss'],\n  providers: [DossierTabService, DossierDetailLayoutService, NotificationService],\n})\nexport class DossierDetailComponent\n  extends PendingChangesComponent\n  implements AfterViewInit, OnDestroy\n{\n  @ViewChild('supportingProcessStartModal')\n  supportingProcessStart: DossierSupportingProcessStartModalComponent;\n\n  @ViewChild('tabContainer', {read: ViewContainerRef})\n  viewContainerRef: ViewContainerRef;\n\n  @ViewChild('tabContentContainer')\n  private readonly _tabContentContainer!: ElementRef<HTMLDivElement>;\n\n  public customDossierHeaderItems: Array<any> = [];\n  public document: ValtimoDocument | null = null;\n  public documentDefinitionName: string;\n  public documentDefinitionNameTitle: string;\n  public documentId: string;\n  public processDefinitionListFields: Array<any> = [];\n  public processDocumentDefinitions: ProcessDocumentDefinition[] = [];\n  public tabLoader: TabLoaderImpl | null = null;\n\n  public readonly assigneeId$ = new BehaviorSubject<string>('');\n  public readonly currentIntermediateSave$ = new BehaviorSubject<IntermediateSubmission | null>(\n    null\n  );\n  public readonly isAdmin$: Observable<boolean> = this.userProviderService\n    .getUserSubject()\n    .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));\n\n  public readonly taskAndProcessLinkOpenedInPanel$ =\n    this.dossierDetailLayoutService.taskAndProcessLinkOpenedInPanel$;\n\n  private readonly _caseStatusKey$ = new BehaviorSubject<string | null | 'NOT_AVAILABLE'>(null);\n  private readonly _taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;\n\n  public readonly caseStatusKey$: Observable<string | 'NOT_AVAILABLE'> = this._caseStatusKey$.pipe(\n    filter(key => !!key)\n  );\n\n  public readonly showDeleteModal$: BehaviorSubject<boolean> = new BehaviorSubject(false);\n\n  public readonly canView$: Observable<boolean> = this.route.paramMap.pipe(\n    switchMap((params: ParamMap) =>\n      this.permissionService.requestPermission(CAN_VIEW_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: params.get('documentId') ?? '',\n      })\n    )\n  );\n\n  public readonly document$: Observable<ValtimoDocument | null> = combineLatest([\n    this.dossierService.refreshDocument$,\n    this.canView$,\n  ]).pipe(\n    filter(([_, canView]) => canView),\n    switchMap(() => this.route.params),\n    map((params: Params) => params?.documentId),\n    switchMap((documentId: string) =>\n      documentId ? this.documentService.getDocument(this.documentId) : of(null)\n    ),\n    tap((document: ValtimoDocument | null) => {\n      if (document) {\n        this.assigneeId$.next(document.assigneeId);\n        this.document = document;\n        this._caseStatusKey$.next(document?.internalStatus || 'NOT_AVAILABLE');\n\n        if (\n          this.configService.config.customDossierHeader?.hasOwnProperty(\n            this.documentDefinitionName.toLowerCase()\n          ) &&\n          this.customDossierHeaderItems.length === 0\n        ) {\n          this.configService.config.customDossierHeader[\n            this.documentDefinitionName.toLowerCase()\n          ]?.forEach(item => this.getCustomDossierHeaderItem(item));\n        }\n      }\n    })\n  );\n\n  public readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params.documentDefinitionName || '')\n  );\n\n  public readonly caseStatus$: Observable<InternalCaseStatus | undefined> =\n    this.documentDefinitionName$.pipe(\n      filter(documentDefinitionName => !!documentDefinitionName),\n      switchMap(documentDefinitionName =>\n        combineLatest([\n          this.caseStatusService.getInternalCaseStatuses(documentDefinitionName),\n          this.caseStatusKey$,\n        ])\n      ),\n      map(\n        ([statuses, key]) => key !== 'NOT_AVAILABLE' && statuses.find(status => status?.key === key)\n      ),\n      map(\n        status =>\n          status && {\n            ...status,\n            tagType: InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(status.color),\n          }\n      )\n    );\n\n  public readonly userId$: Observable<string | undefined> = of(\n    this.keyCloakService.isLoggedIn()\n  ).pipe(\n    switchMap(() => this.keyCloakService.loadUserProfile()),\n    map(profile => profile?.id)\n  );\n\n  public readonly isAssigning$ = new BehaviorSubject<boolean>(false);\n  public readonly isAssignedToCurrentUser$: Observable<boolean> = combineLatest([\n    this.assigneeId$,\n    this.userId$,\n  ]).pipe(\n    map(([assigneeId, userId]) => !!assigneeId && !!userId && assigneeId === userId),\n    startWith(true)\n  );\n\n  public readonly canHaveAssignee$: Observable<boolean> = this.documentDefinitionName$.pipe(\n    switchMap(documentDefinitionName =>\n      this.documentService.getCaseSettings(documentDefinitionName)\n    ),\n    map(caseSettings => caseSettings?.canHaveAssignee)\n  );\n\n  public readonly canAssignLoaded$ = new BehaviorSubject<boolean>(false);\n  public readonly canAssign$: Observable<boolean> = this.route.paramMap.pipe(\n    switchMap((params: ParamMap) =>\n      this.permissionService.requestPermission(CAN_ASSIGN_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: params.get('documentId') ?? '',\n      })\n    ),\n    tap(() => {\n      this.canAssignLoaded$.next(true);\n    })\n  );\n\n  public readonly canClaim$: Observable<boolean> = this.route.paramMap.pipe(\n    switchMap((params: ParamMap) =>\n      this.permissionService.requestPermission(CAN_CLAIM_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: params.get('documentId') ?? '',\n      })\n    )\n  );\n\n  public readonly isDeleting$ = new BehaviorSubject<boolean>(false);\n  public readonly canDelete$: Observable<boolean> = this.route.paramMap.pipe(\n    switchMap((params: ParamMap) =>\n      this.permissionService.requestPermission(CAN_DELETE_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: params.get('documentId') ?? '',\n      })\n    )\n  );\n\n  public readonly loadingTabs$ = new BehaviorSubject<boolean>(true);\n  public readonly noTabsConfigured$ = new BehaviorSubject<boolean>(false);\n  public readonly showNoAccess$ = new BehaviorSubject<boolean>(false);\n  public activeTab$: Observable<TabImpl>;\n\n  public readonly compactMode$ = this.pageHeaderService.compactMode$;\n\n  public readonly tabHorizontalOverflowDisabled =\n    this.dossierTabService.tabHorizontalOverflowDisabled;\n\n  public readonly showTaskList$ = this.dossierTabService.showTaskList$;\n\n  private readonly _activeTabName$ = new BehaviorSubject<string | null>(null);\n  public get activeTabName$(): Observable<string | null> {\n    return combineLatest([this.route.paramMap, this._activeTabName$]).pipe(\n      map(([paramMap, activeTabName]) =>\n        !activeTabName ? (paramMap.get('tab') ?? null) : activeTabName\n      )\n    );\n  }\n\n  public readonly DOSSIER_DETAIL_GUTTER_SIZE = DOSSIER_DETAIL_GUTTER_SIZE;\n\n  public readonly dossierDetailLayout$ = this.dossierDetailLayoutService.dossierDetailLayout$;\n\n  public readonly openTaskAndProcessLinkInModal$ = new Subject<TaskWithProcessLink>();\n\n  public readonly isDarkMode$ = this.cdsThemeService.currentTheme$.pipe(\n    map(currentTheme => currentTheme === CurrentCarbonTheme.G90)\n  );\n\n  private _snapshot: ParamMap;\n  private _initialTabName: string;\n  private _activeChange = false;\n  private _oldTabName: string;\n  private _pendingTab: TabImpl;\n  private _observer!: ResizeObserver;\n  private _tabsInit = false;\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly breadcrumbService: BreadcrumbService,\n    private readonly caseStatusService: CaseStatusService,\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly componentFactoryResolver: ComponentFactoryResolver,\n    private readonly configService: ConfigService,\n    private readonly documentService: DocumentService,\n    private readonly dossierDetailLayoutService: DossierDetailLayoutService,\n    private readonly dossierService: DossierService,\n    private readonly dossierTabService: DossierTabService,\n    private readonly iconService: IconService,\n    private readonly keyCloakService: KeycloakService,\n    private readonly logger: NGXLogger,\n    private readonly notificationService: NotificationService,\n    private readonly pageHeaderService: PageHeaderService,\n    private readonly pageTitleService: PageTitleService,\n    private readonly permissionService: PermissionService,\n    private readonly translateService: TranslateService,\n    private readonly renderer: Renderer2,\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly widgetsService: WidgetsService,\n    private readonly userProviderService: UserProviderService,\n    @Inject(DOCUMENT) private readonly htmlDocument: Document\n  ) {\n    super();\n    this._snapshot = this.route.snapshot.paramMap;\n    this.documentDefinitionName = this._snapshot.get('documentDefinitionName') || '';\n    this.documentId = this._snapshot.get('documentId') || '';\n  }\n\n  public ngAfterViewInit(): void {\n    this.initTabLoader();\n    this.initBreadcrumb();\n    this.openWidthObserver();\n    this.pageTitleService.disableReset();\n    this.iconService.registerAll([ChevronDown16]);\n    this.setDocumentStyle();\n    this.enableResetOnBackNavigation();\n    this.openWidgetProcessSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this.breadcrumbService.clearSecondBreadcrumb();\n    this.pageTitleService.enableReset();\n    this.removeDocumentStyle();\n    this._subscriptions.unsubscribe();\n  }\n\n  public getAllAssociatedProcessDefinitions(): void {\n    this.documentService\n      .findProcessDocumentDefinitionsForDocument(this.documentId, {startableByUser: true})\n      .subscribe((processDocumentDefinitions: ProcessDocumentDefinition[]) => {\n        this.processDocumentDefinitions = processDocumentDefinitions;\n\n        this.processDefinitionListFields = [\n          {\n            key: 'processName',\n            label: 'Proces',\n          },\n        ];\n      });\n  }\n\n  public startProcess(processDocumentDefinition: ProcessDocumentDefinition): void {\n    this.supportingProcessStart.openModal(processDocumentDefinition, this.documentId);\n  }\n\n  public openWidgetProcessSubscription(): void {\n    this._subscriptions.add(\n      this.widgetsService.startProcessEvent\n        .pipe(switchMap(() => this.widgetsService.activeProcess$))\n        .subscribe((processDocumentDefinitions: ProcessDocumentDefinition[]) => {\n          this.startProcess(processDocumentDefinitions[0]);\n        })\n    );\n  }\n\n  public claimAssignee(): void {\n    this.isAssigning$.next(true);\n\n    this.userId$\n      .pipe(\n        take(1),\n        switchMap((userId: string | undefined) =>\n          this.documentService.assignHandlerToDocument(this.documentId, userId ?? '')\n        )\n      )\n      .subscribe({\n        next: (): void => {\n          this.isAssigning$.next(false);\n          this.dossierService.refresh();\n        },\n        error: (): void => {\n          this.isAssigning$.next(false);\n          this.logger.debug('Something went wrong while assigning user to case');\n        },\n      });\n  }\n\n  public unassignAssignee(): void {\n    this.isAssigning$.next(true);\n\n    this.userId$\n      .pipe(\n        take(1),\n        switchMap((userId: string | undefined) =>\n          this.documentService.unassignHandlerFromDocument(this.documentId)\n        )\n      )\n      .subscribe({\n        next: (): void => {\n          this.isAssigning$.next(false);\n          this.dossierService.refresh();\n        },\n        error: (): void => {\n          this.isAssigning$.next(false);\n          this.logger.debug('Something went wrong while unassigning user from case');\n        },\n      });\n  }\n\n  public deleteDocument(): void {\n    this.showDeleteModal$.next(true);\n  }\n\n  public onConfirmDelete(): void {\n    this.isDeleting$.next(true);\n    this.documentService.deleteDocument(this.documentId).subscribe({\n      next: (): void => {\n        this.isDeleting$.next(false);\n        this.showDeleteModal$.next(false);\n        this.router.navigate([`/dossiers/${this.documentDefinitionName}`]);\n      },\n      error: (): void => {\n        this.isDeleting$.next(false);\n        this.logger.debug('Something went wrong while deleting the case');\n      },\n    });\n  }\n\n  public onTaskClickEvent(taskProcessLinkResult: TaskWithProcessLink): void {\n    if (!taskProcessLinkResult.processLinkActivityResult) {\n      this.isAdmin$.pipe(take(1)).subscribe(isAdmin => {\n        this.handleNoTaskProcessLink(isAdmin);\n      });\n      return;\n    }\n\n    const displayType =\n      taskProcessLinkResult.processLinkActivityResult.properties.formDisplayType ||\n      DOSSIER_DETAIL_DEFAULT_DISPLAY_TYPE;\n    const size =\n      taskProcessLinkResult.processLinkActivityResult.properties.formSize ||\n      DOSSIER_DETAIL_DEFAULT_DISPLAY_SIZE;\n\n    this.dossierDetailLayoutService.setFormDisplaySize(size);\n    this.dossierDetailLayoutService.setFormDisplayType(displayType);\n\n    if (displayType === 'panel' && !!this._taskPanelToggle) {\n      this.dossierDetailLayoutService.setTaskAndProcessLinkOpenedInPanel(taskProcessLinkResult);\n    } else {\n      this.openTaskAndProcessLinkInModal$.next({...taskProcessLinkResult});\n    }\n  }\n\n  public onTaskDetailsClose(): void {\n    this.dossierDetailLayoutService.setTaskAndProcessLinkOpenedInPanel(null);\n  }\n\n  public onActiveChangeEvent(event: boolean): void {\n    this._activeChange = event;\n  }\n\n  public onTabSelected(tab: TabImpl, activeTab: TabImpl): void {\n    if (!this.tabLoader) return;\n\n    if (!this._tabsInit) {\n      this._tabsInit = true;\n      return;\n    }\n\n    this._oldTabName = activeTab.name;\n    this._pendingTab = tab;\n    this._activeTabName$.next(tab.name);\n    this.pendingChanges =\n      tab.contentKey === 'summary' ? false : !tab.showTasks && this._activeChange;\n\n    if (this.pendingChanges) {\n      this.tabLoader.replaceUrlState(tab);\n      return;\n    }\n\n    if (!tab.showTasks) this.openTaskAndProcessLinkInModal$.next(null);\n    this.tabLoader.load(tab);\n    this.setDocumentStyle();\n  }\n\n  public onFormSubmitEvent(): void {\n    this.dossierDetailLayoutService.setTaskAndProcessLinkOpenedInPanel(null);\n\n    if (!this.tabLoader) return;\n    this.tabLoader.refreshView();\n  }\n\n  protected onConfirmRedirect(): void {\n    if (!this.tabLoader || !this._pendingTab) return;\n    this._activeChange = false;\n    this._activeTabName$.next(this._pendingTab.name);\n    this.tabLoader.load(this._pendingTab);\n    this.dossierDetailLayoutService.setTaskAndProcessLinkOpenedInPanel(null);\n  }\n\n  protected onCancelRedirect(): void {\n    if (!this.tabLoader) return;\n    this._activeTabName$.next(this._oldTabName);\n  }\n\n  private initBreadcrumb(): void {\n    this.documentService\n      .getDocumentDefinition(this.documentDefinitionName)\n      .subscribe(definition => {\n        this.documentDefinitionNameTitle = definition.schema.title;\n        this.setBreadcrumb();\n      });\n  }\n\n  private initTabLoader(): void {\n    combineLatest([this.dossierTabService.tabs$, this.canView$])\n      .pipe(take(1))\n      .subscribe(([tabs, canView]) => {\n        if (canView) {\n          if (tabs?.length > 0) {\n            this._initialTabName = this._snapshot.get('tab') ?? '';\n            this.tabLoader = new TabLoaderImpl(\n              tabs,\n              this.componentFactoryResolver,\n              this.viewContainerRef,\n              this.router,\n              this.route\n            );\n            this.tabLoader.initial(this._initialTabName);\n            this.dossierTabService.setTabLoader(this.tabLoader);\n            this.loadingTabs$.next(false);\n            this.activeTab$ = this.tabLoader.activeTab$;\n          } else {\n            this.noTabsConfigured$.next(true);\n            this.loadingTabs$.next(false);\n          }\n\n          this.getAllAssociatedProcessDefinitions();\n        } else {\n          this.showNoAccess$.next(true);\n          this.loadingTabs$.next(false);\n        }\n      });\n  }\n\n  public assignmentOfDocumentChanged(): void {\n    this.dossierService.refresh();\n  }\n\n  private getCustomDossierHeaderItem(item): void {\n    this.customDossierHeaderItems.push({\n      label: item['labelTranslationKey'] || '',\n      columnSize: item['columnSize'] || 3,\n      textSize: item['textSize'] || 'md',\n      customClass: item['customClass'] || '',\n      modifier: item['modifier'] || '',\n      value: item['propertyPaths']?.reduce(\n        (prev, curr) => prev + this.getStringFromDocumentPath(item, curr),\n        ''\n      ),\n    });\n  }\n\n  private getStringFromDocumentPath(item, path): string {\n    const prefix = item['propertyPaths'].indexOf(path) > 0 ? ' ' : '';\n    let string = this.getNestedProperty(this.document.content, path, item['noValueText']) || '';\n    const dateFormats = [moment.ISO_8601, 'MM-DD-YYYY', 'DD-MM-YYYY', 'YYYY-MM-DD'];\n    switch (item['modifier']) {\n      case 'age': {\n        if (moment(string, dateFormats, true).isValid()) {\n          string = moment().diff(string, 'years');\n        }\n        break;\n      }\n      default: {\n        if (moment(string, dateFormats, true).isValid()) {\n          string = moment(string).format('DD-MM-YYYY');\n        }\n      }\n    }\n    return prefix + string;\n  }\n\n  private getNestedProperty(obj: any, path: string, defaultValue: any): any {\n    return (\n      path.split('.').reduce((currentObject, key) => currentObject?.[key], obj) || defaultValue\n    );\n  }\n\n  private setBreadcrumb(): void {\n    this.breadcrumbService.setSecondBreadcrumb({\n      route: [`/dossiers/${this.documentDefinitionName}`],\n      content: this.documentDefinitionNameTitle,\n      href: `/dossiers/${this.documentDefinitionName}`,\n    });\n  }\n\n  private openWidthObserver(): void {\n    if (!this._tabContentContainer.nativeElement) return;\n\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._tabContentContainer.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const elementWidth = event[0]?.borderBoxSize[0]?.inlineSize;\n\n    if (typeof elementWidth === 'number' && elementWidth !== 0) {\n      this.dossierDetailLayoutService.setTabContentContainerWidth(elementWidth);\n    }\n  }\n\n  private setDocumentStyle(): void {\n    this.renderer.addClass(this.htmlDocument.getElementsByTagName('html')[0], 'html--fixed');\n  }\n\n  private removeDocumentStyle(): void {\n    this.renderer.removeClass(this.htmlDocument.getElementsByTagName('html')[0], 'html--fixed');\n  }\n\n  private enableResetOnBackNavigation(): void {\n    this._subscriptions.add(\n      this.router.events\n        .pipe(\n          filter(\n            event => event instanceof NavigationStart && event.navigationTrigger === 'popstate'\n          )\n        )\n        .subscribe(() => {\n          this.pageTitleService.enableReset();\n        })\n    );\n  }\n\n  private handleNoTaskProcessLink(isAdmin: boolean): void {\n    this.notificationService.showActionable({\n      type: 'warning',\n      lowContrast: true,\n      title: this.translateService.instant('dossier.noLinkedProcessNotification'),\n      ...(isAdmin && {\n        actions: [\n          {\n            text: this.translateService.instant('dossier.configure'),\n            click: () => this.router.navigate(['/process-links']),\n          },\n        ],\n      }),\n      duration: CARBON_CONSTANTS.notificationDuration,\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<div\n  class=\"main-content\"\n  [ngClass]=\"{'main-content--no-horizontal-overflow': tabHorizontalOverflowDisabled()}\"\n>\n  <div class=\"container-fluid\">\n    <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n\n    <ng-template #tabs>\n      <ng-container *ngIf=\"{activeTab: activeTab$ | async} as obs\">\n        <cds-tabs *ngIf=\"tabLoader\" type=\"inline\" class=\"case-detail-tabs\">\n          <cds-tab\n            *ngFor=\"let tab of tabLoader.tabs\"\n            [active]=\"tab.name === (activeTabName$ | async)\"\n            heading=\"{{ tab | tabTranslate | async }}\"\n            (selected)=\"onTabSelected(tab, obs.activeTab)\"\n          ></cds-tab>\n        </cds-tabs>\n      </ng-container>\n    </ng-template>\n\n    <div\n      #tabContentContainer\n      class=\"tab-content-container\"\n      [ngClass]=\"{\n        'tab-content-container--dark': isDarkMode$ | async,\n        'tab-content-container--compact': compactMode$ | async,\n      }\"\n      *ngIf=\"{\n        noTabsConfigured: noTabsConfigured$ | async,\n        showTaskList: showTaskList$ | async,\n        showNoAccess: showNoAccess$ | async,\n        dossierDetailLayout: dossierDetailLayout$ | async,\n        openTaskAndProcessLinkInModal: openTaskAndProcessLinkInModal$ | async,\n        taskAndProcessLinkOpenedInPanel: taskAndProcessLinkOpenedInPanel$ | async,\n      } as tabContentObs\"\n    >\n      <as-split\n        direction=\"horizontal\"\n        [disabled]=\"!tabContentObs.dossierDetailLayout.widthAdjustable\"\n        [gutterSize]=\"DOSSIER_DETAIL_GUTTER_SIZE\"\n        [unit]=\"tabContentObs.dossierDetailLayout.unit\"\n      >\n        <as-split-area\n          [size]=\"tabContentObs.dossierDetailLayout.leftPanelWidth\"\n          [minSize]=\"tabContentObs.dossierDetailLayout.leftPanelMinWidth\"\n          [maxSize]=\"tabContentObs.dossierDetailLayout.leftPanelMaxWidth\"\n        >\n          <div\n            class=\"card-body bg-white p-5 position-relative tab-container\"\n            [class.tab-container--compact]=\"compactMode$ | async\"\n          >\n            <div *ngIf=\"loadingTabs$ | async\" class=\"loading-container\">\n              <cds-loading></cds-loading>\n            </div>\n\n            <valtimo-no-results\n              *ngIf=\"tabContentObs.showNoAccess\"\n              description=\"{{ 'dossier.noAccess.description' | translate }}\"\n              title=\"{{ 'dossier.noAccess.title' | translate }}\"\n              illustration=\"valtimo-layout/img/emptystate-not-authorised.svg\"\n            >\n            </valtimo-no-results>\n\n            <valtimo-no-results\n              *ngIf=\"tabContentObs.noTabsConfigured\"\n              [description]=\"'dossier.tabs.noResultsDescription' | translate\"\n              [title]=\"'dossier.tabs.noResults' | translate\"\n            ></valtimo-no-results>\n\n            <ng-template #tabContainer></ng-template>\n\n            <div class=\"clearfix\"></div>\n          </div>\n        </as-split-area>\n\n        <as-split-area\n          *ngIf=\"tabContentObs.dossierDetailLayout.showRightPanel\"\n          [size]=\"tabContentObs.dossierDetailLayout.rightPanelWidth\"\n          [minSize]=\"tabContentObs.dossierDetailLayout.rightPanelMinWidth\"\n          [maxSize]=\"tabContentObs.dossierDetailLayout.rightPanelMaxWidth\"\n        >\n          @if (tabContentObs.showTaskList) {\n            <div class=\"task-panel\">\n              @if (!tabContentObs.taskAndProcessLinkOpenedInPanel) {\n                <valtimo-dossier-detail-task-list\n                  [openTaskAndProcessLinkInModal]=\"tabContentObs.openTaskAndProcessLinkInModal\"\n                  (taskClickEvent)=\"onTaskClickEvent($event)\"\n                  (formSubmitEvent)=\"onFormSubmitEvent()\"\n                ></valtimo-dossier-detail-task-list>\n              }\n\n              @if (tabContentObs.taskAndProcessLinkOpenedInPanel) {\n                <valtimo-dossier-detail-task-detail\n                  [taskAndProcessLink]=\"tabContentObs.taskAndProcessLinkOpenedInPanel\"\n                  (activeChange)=\"onActiveChangeEvent($event)\"\n                  (closeEvent)=\"onTaskDetailsClose()\"\n                  (formSubmit)=\"onFormSubmitEvent()\"\n                >\n                </valtimo-dossier-detail-task-detail>\n              }\n            </div>\n          }\n        </as-split-area>\n      </as-split>\n    </div>\n  </div>\n\n  <valtimo-dossier-supporting-process-start-modal\n    [isAdmin]=\"isAdmin$ | async\"\n    (formSubmit)=\"tabLoader.refreshView()\"\n    #supportingProcessStartModal\n  ></valtimo-dossier-supporting-process-start-modal>\n</div>\n\n<ng-template\n  #caseDetailHeader\n  let-canHaveAssignee=\"canHaveAssignee\"\n  let-document=\"document\"\n  let-canAssign=\"canAssign\"\n>\n  <div class=\"row\" *ngIf=\"(customDossierHeaderItems || []).length > 0\">\n    <span\n      *ngFor=\"let item of customDossierHeaderItems\"\n      [ngClass]=\"{\n        h1: item.textSize === 'xl',\n        h2: item.textSize === 'lg',\n        h3: item.textSize === 'md',\n        h4: item.textSize === 'sm',\n        h5: item.textSize === 'xs',\n      }\"\n      class=\"mb-0 mt-0 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n        item.columnSize * 2\n      }} {{ item.customClass }}\"\n    >\n      <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n\n      <span *ngIf=\"item.label && item.value\">: </span>\n\n      <strong>{{ item.value }}</strong>\n    </span>\n  </div>\n\n  <ng-container\n    *ngTemplateOutlet=\"\n      caseDetailAssignee;\n      context: {canHaveAssignee: canHaveAssignee, document: document, canAssign: canAssign}\n    \"\n  ></ng-container>\n</ng-template>\n\n<ng-template\n  #caseDetailAssignee\n  let-canHaveAssignee=\"canHaveAssignee\"\n  let-document=\"document\"\n  let-canAssign=\"canAssign\"\n>\n  <div *ngIf=\"canHaveAssignee && document\">\n    <valtimo-dossier-assign-user\n      *ngIf=\"canAssignLoaded$ | async\"\n      [assigneeFullName]=\"document?.assigneeFullName\"\n      [assigneeId]=\"document.assigneeId\"\n      [documentId]=\"document.id\"\n      [hasPermission]=\"canAssign\"\n      (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n    ></valtimo-dossier-assign-user>\n  </div>\n</ng-template>\n\n<ng-template #claimButton let-canClaim=\"canClaim\" let-canHaveAssignee=\"canHaveAssignee\">\n  <cds-overflow-menu-option\n    *ngIf=\"canClaim && canHaveAssignee\"\n    [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n    (click)=\"claimAssignee()\"\n  >\n    {{ 'dossier.claimAssigneeCase' | translate }}\n  </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #unassignButton let-canHaveAssignee=\"canHaveAssignee\" let-assigneeId=\"assigneeId\">\n  <cds-overflow-menu-option\n    *ngIf=\"canHaveAssignee\"\n    [disabled]=\"!assigneeId\"\n    (selected)=\"unassignAssignee()\"\n  >\n    {{ 'assignDocument.remove' | translate }}\n  </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #deleteButton let-canDelete=\"canDelete\">\n  <cds-overflow-menu-option\n    *ngIf=\"canDelete\"\n    [disabled]=\"isDeleting$ | async\"\n    (click)=\"deleteDocument()\"\n    type=\"danger\"\n  >\n    {{ 'dossier.delete.delete' | translate }}\n  </cds-overflow-menu-option>\n</ng-template>\n\n<ng-template #customStartTrigger>\n  <button\n    [size]=\"(compactMode$ | async) ? 'sm' : 'lg'\"\n    cdsButton=\"primary\"\n    [disabled]=\"processDocumentDefinitions.length === 0\"\n    [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n  >\n    {{ 'dossier.startSubProcess' | translate }}\n\n    <svg class=\"cds--btn__icon\" cdsIcon=\"chevron--down\" size=\"16\"></svg>\n  </button>\n</ng-template>\n\n<valtimo-confirmation-modal\n  confirmButtonTextTranslationKey=\"dossier.delete.confirm\"\n  confirmButtonType=\"danger\"\n  contentTranslationKey=\"dossier.delete.description\"\n  [showModalSubject$]=\"showDeleteModal$\"\n  titleTranslationKey=\"dossier.delete.delete\"\n  (confirmEvent)=\"onConfirmDelete()\"\n></valtimo-confirmation-modal>\n\n<ng-container renderInPageHeader [fullWidth]=\"true\">\n  <ng-template>\n    <div\n      class=\"dossier-actions\"\n      [ngClass]=\"{'--compact': compactMode$ | async}\"\n      *ngIf=\"{\n        assigneeId: assigneeId$ | async,\n        canAssign: canAssign$ | async,\n        canClaim: canClaim$ | async,\n        canHaveAssignee: canHaveAssignee$ | async,\n        canDelete: canDelete$ | async,\n        document: document$ | async,\n        caseStatus: caseStatus$ | async,\n      } as obs\"\n    >\n      <div\n        class=\"dossier-status-assign-custom-title\"\n        [ngClass]=\"{'--compact': compactMode$ | async}\"\n      >\n        @if (obs.caseStatus) {\n          <cds-tag size=\"sm\" [type]=\"obs.caseStatus.tagType\">{{ obs.caseStatus.title }}</cds-tag>\n        }\n\n        <div class=\"dossier-assign-user\" [ngClass]=\"{'--compact': compactMode$ | async}\">\n          <ng-container\n            *ngTemplateOutlet=\"\n              caseDetailAssignee;\n              context: {\n                canHaveAssignee: obs.canHaveAssignee,\n                document: obs.document,\n                canAssign: obs.canAssign,\n              }\n            \"\n          ></ng-container>\n        </div>\n\n        <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n      </div>\n\n      <div class=\"buttons-container\">\n        <cds-overflow-menu\n          [ngClass]=\"{'--compact': compactMode$ | async}\"\n          *ngIf=\"obs.canHaveAssignee || obs.canDelete\"\n          flip=\"true\"\n          [offset]=\"(compactMode$ | async) ? {y: 48, x: -4} : {y: 48, x: 4}\"\n          class=\"overflow-button assign-overflow\"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"\n              claimButton;\n              context: {canClaim: obs.canClaim, canHaveAssignee: obs.canHaveAssignee}\n            \"\n          >\n          </ng-container>\n          <ng-container\n            *ngTemplateOutlet=\"\n              unassignButton;\n              context: {canHaveAssignee: obs.canHaveAssignee, assigneeId: obs.assigneeId}\n            \"\n          >\n          </ng-container>\n          <ng-container *ngTemplateOutlet=\"deleteButton; context: {canDelete: obs.canDelete}\">\n          </ng-container>\n        </cds-overflow-menu>\n\n        <cds-overflow-menu\n          valtimoCdsOverflowButton\n          [ngClass]=\"{'--compact': compactMode$ | async}\"\n          [width]=\"250\"\n          [customTrigger]=\"customStartTrigger\"\n          [offset]=\"{y: 48, x: 35}\"\n          class=\"overflow-button case-detail-overflow\"\n        >\n          <cds-overflow-menu-option\n            *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n            (click)=\"startProcess(processDocumentDefinition)\"\n          >\n            {{\n              (processDocumentDefinition?.id?.processDefinitionKey | translate) !==\n              processDocumentDefinition?.id?.processDefinitionKey\n                ? (processDocumentDefinition.id.processDefinitionKey | translate)\n                : processDocumentDefinition.processName\n            }}\n          </cds-overflow-menu-option>\n        </cds-overflow-menu>\n      </div>\n    </div>\n  </ng-template>\n</ng-container>\n"]}