@valtimo/dossier 10.8.0 → 11.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dossier-assign-user/dossier-assign-user.component.mjs +98 -0
- package/esm2022/lib/components/dossier-bulk-assign-modal/dossier-bulk-assign-modal.component.mjs +75 -0
- package/esm2022/lib/components/dossier-detail/dossier-detail.component.mjs +191 -0
- package/esm2022/lib/components/dossier-detail/tab/audit/audit.component.mjs +76 -0
- package/esm2022/lib/components/dossier-detail/tab/contact-moments/contact-moments.component.mjs +86 -0
- package/esm2022/lib/components/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.mjs +146 -0
- package/esm2022/lib/components/dossier-detail/tab/documents/documents.component.mjs +41 -0
- package/esm2022/lib/components/dossier-detail/tab/formio/formio.component.mjs +61 -0
- package/esm2022/lib/components/dossier-detail/tab/notes/notes.component.mjs +166 -0
- package/esm2022/lib/components/dossier-detail/tab/object-type/object-type.component.mjs +121 -0
- package/esm2022/lib/components/dossier-detail/tab/progress/progress.component.mjs +52 -0
- package/esm2022/lib/components/dossier-detail/tab/s3-documents/s3-documents.component.mjs +136 -0
- package/esm2022/lib/components/dossier-detail/tab/summary/summary.component.mjs +134 -0
- package/esm2022/lib/components/dossier-detail/tab/zaakobjecten/zaakobjecten.component.mjs +112 -0
- package/esm2022/lib/components/dossier-list/dossier-list.component.mjs +370 -0
- package/esm2022/lib/components/dossier-list-actions/dossier-list-actions.component.mjs +84 -0
- package/esm2022/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.mjs +132 -0
- package/esm2022/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +116 -0
- package/esm2022/lib/components/dossier-update/dossier-update.component.mjs +113 -0
- package/{esm2020 → esm2022}/lib/components/note-modal/note-modal.component.mjs +5 -5
- package/esm2022/lib/constants/case-tab-token.mjs +19 -0
- package/esm2022/lib/constants/index.mjs +3 -0
- package/esm2022/lib/constants/tab.mjs +42 -0
- package/esm2022/lib/dossier-routing.module.mjs +76 -0
- package/esm2022/lib/dossier.module.mjs +288 -0
- package/esm2022/lib/models/candidate-user.model.mjs +17 -0
- package/esm2022/lib/models/dossier-detail-tab.model.mjs +27 -0
- package/{esm2020 → esm2022}/lib/models/dossier-parameters.model.mjs +1 -1
- package/esm2022/lib/models/index.mjs +23 -0
- package/esm2022/lib/models/tab-api.model.mjs +23 -0
- package/esm2022/lib/models/tabs.model.mjs +116 -0
- package/esm2022/lib/permissions/dossier-detail.permissions.mjs +55 -0
- package/esm2022/lib/permissions/index.mjs +17 -0
- package/esm2022/lib/pipes/index.mjs +17 -0
- package/esm2022/lib/pipes/tab-translate/index.mjs +18 -0
- package/esm2022/lib/pipes/tab-translate/tab-translate-pipe.module.mjs +33 -0
- package/esm2022/lib/pipes/tab-translate/tab-translate.pipe.mjs +41 -0
- package/esm2022/lib/services/dossier-bulk-assign.service.mjs +35 -0
- package/esm2022/lib/services/dossier-column.service.mjs +98 -0
- package/esm2022/lib/services/dossier-list-assignee.service.mjs +89 -0
- package/esm2022/lib/services/dossier-list-pagination.service.mjs +119 -0
- package/esm2022/lib/services/dossier-list-search.service.mjs +59 -0
- package/esm2022/lib/services/dossier-list.service.mjs +74 -0
- package/esm2022/lib/services/dossier-parameter.service.mjs +165 -0
- package/esm2022/lib/services/dossier-tab-api.service.mjs +23 -0
- package/esm2022/lib/services/dossier-tab.service.mjs +130 -0
- package/esm2022/lib/services/dossier.service.mjs +58 -0
- package/{esm2020 → esm2022}/lib/services/file-sort.service.mjs +4 -4
- package/esm2022/lib/services/index.mjs +27 -0
- package/esm2022/lib/services/notes.service.mjs +76 -0
- package/{esm2020 → esm2022}/lib/services/zaakobjecten.service.mjs +4 -4
- package/esm2022/public_api.mjs +34 -0
- package/fesm2022/valtimo-dossier.mjs +3979 -0
- package/fesm2022/valtimo-dossier.mjs.map +1 -0
- package/lib/components/dossier-assign-user/dossier-assign-user.component.d.ts +28 -0
- package/lib/components/dossier-assign-user/dossier-assign-user.component.d.ts.map +1 -0
- package/lib/components/dossier-bulk-assign-modal/dossier-bulk-assign-modal.component.d.ts +22 -0
- package/lib/components/dossier-bulk-assign-modal/dossier-bulk-assign-modal.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/dossier-detail.component.d.ts +36 -33
- package/lib/components/dossier-detail/dossier-detail.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/audit/audit.component.d.ts +1 -1
- package/lib/components/dossier-detail/tab/audit/audit.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/contact-moments/contact-moments.component.d.ts +1 -1
- package/lib/components/dossier-detail/tab/contact-moments/contact-moments.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/documenten-api-documents/documenten-api-documents.component.d.ts +3 -4
- package/lib/components/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/documents/documents.component.d.ts +1 -1
- package/lib/components/dossier-detail/tab/documents/documents.component.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/formio/formio.component.d.ts +20 -0
- package/lib/components/dossier-detail/tab/formio/formio.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/notes/notes.component.d.ts +19 -12
- package/lib/components/dossier-detail/tab/notes/notes.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/object-type/object-type.component.d.ts +5 -5
- package/lib/components/dossier-detail/tab/object-type/object-type.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/progress/progress.component.d.ts +1 -1
- package/lib/components/dossier-detail/tab/progress/progress.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/s3-documents/s3-documents.component.d.ts +3 -3
- package/lib/components/dossier-detail/tab/s3-documents/s3-documents.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/summary/summary.component.d.ts +8 -4
- package/lib/components/dossier-detail/tab/summary/summary.component.d.ts.map +1 -0
- package/lib/{dossier-detail → components/dossier-detail}/tab/zaakobjecten/zaakobjecten.component.d.ts +5 -5
- package/lib/components/dossier-detail/tab/zaakobjecten/zaakobjecten.component.d.ts.map +1 -0
- package/lib/components/dossier-list/dossier-list.component.d.ts +94 -0
- package/lib/components/dossier-list/dossier-list.component.d.ts.map +1 -0
- package/lib/{dossier-list-actions → components/dossier-list-actions}/dossier-list-actions.component.d.ts +6 -7
- package/lib/components/dossier-list-actions/dossier-list-actions.component.d.ts.map +1 -0
- package/lib/{dossier-process-start-modal → components/dossier-process-start-modal}/dossier-process-start-modal.component.d.ts +4 -7
- package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -0
- package/lib/{dossier-supporting-process-start-modal → components/dossier-supporting-process-start-modal}/dossier-supporting-process-start-modal.component.d.ts +4 -7
- package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -0
- package/lib/{dossier-update → components/dossier-update}/dossier-update.component.d.ts +2 -2
- package/lib/components/dossier-update/dossier-update.component.d.ts.map +1 -0
- package/lib/components/note-modal/note-modal.component.d.ts +3 -3
- package/lib/components/note-modal/note-modal.component.d.ts.map +1 -1
- package/lib/constants/case-tab-token.d.ts +5 -0
- package/lib/constants/case-tab-token.d.ts.map +1 -0
- package/lib/constants/index.d.ts +3 -0
- package/lib/constants/index.d.ts.map +1 -0
- package/lib/constants/tab.d.ts +7 -0
- package/lib/constants/tab.d.ts.map +1 -0
- package/lib/dossier-routing.module.d.ts.map +1 -1
- package/lib/dossier.module.d.ts +35 -33
- package/lib/dossier.module.d.ts.map +1 -1
- package/lib/models/candidate-user.model.d.ts +7 -0
- package/lib/models/candidate-user.model.d.ts.map +1 -0
- package/lib/models/dossier-detail-tab.model.d.ts +18 -0
- package/lib/models/dossier-detail-tab.model.d.ts.map +1 -0
- package/lib/models/dossier-parameters.model.d.ts +0 -1
- package/lib/models/dossier-parameters.model.d.ts.map +1 -1
- package/lib/models/index.d.ts +5 -2
- package/lib/models/index.d.ts.map +1 -1
- package/lib/models/search.model.d.ts +3 -3
- package/lib/models/search.model.d.ts.map +1 -1
- package/lib/models/tab-api.model.d.ts +13 -0
- package/lib/models/tab-api.model.d.ts.map +1 -0
- package/lib/models/tabs.model.d.ts +11 -10
- package/lib/models/tabs.model.d.ts.map +1 -1
- package/lib/permissions/dossier-detail.permissions.d.ts +14 -0
- package/lib/permissions/dossier-detail.permissions.d.ts.map +1 -0
- package/lib/permissions/index.d.ts +2 -0
- package/lib/permissions/index.d.ts.map +1 -0
- package/lib/pipes/index.d.ts +2 -0
- package/lib/pipes/index.d.ts.map +1 -0
- package/lib/pipes/tab-translate/index.d.ts +3 -0
- package/lib/pipes/tab-translate/index.d.ts.map +1 -0
- package/lib/pipes/tab-translate/tab-translate-pipe.module.d.ts +9 -0
- package/lib/pipes/tab-translate/tab-translate-pipe.module.d.ts.map +1 -0
- package/lib/pipes/tab-translate/tab-translate.pipe.d.ts +13 -0
- package/lib/pipes/tab-translate/tab-translate.pipe.d.ts.map +1 -0
- package/lib/services/dossier-bulk-assign.service.d.ts +17 -0
- package/lib/services/dossier-bulk-assign.service.d.ts.map +1 -0
- package/lib/services/dossier-column.service.d.ts +1 -1
- package/lib/services/dossier-column.service.d.ts.map +1 -1
- package/lib/services/dossier-list-assignee.service.d.ts +5 -4
- package/lib/services/dossier-list-assignee.service.d.ts.map +1 -1
- package/lib/services/dossier-list-pagination.service.d.ts +2 -2
- package/lib/services/dossier-list-pagination.service.d.ts.map +1 -1
- package/lib/services/dossier-list-search.service.d.ts +0 -3
- package/lib/services/dossier-list-search.service.d.ts.map +1 -1
- package/lib/services/dossier-list.service.d.ts +6 -0
- package/lib/services/dossier-list.service.d.ts.map +1 -1
- package/lib/services/dossier-parameter.service.d.ts.map +1 -1
- package/lib/services/dossier-tab-api.service.d.ts +15 -0
- package/lib/services/dossier-tab-api.service.d.ts.map +1 -0
- package/lib/services/dossier-tab.service.d.ts +31 -0
- package/lib/services/dossier-tab.service.d.ts.map +1 -0
- package/lib/{dossier.service.d.ts → services/dossier.service.d.ts} +5 -1
- package/lib/services/dossier.service.d.ts.map +1 -0
- package/lib/services/index.d.ts +4 -1
- package/lib/services/index.d.ts.map +1 -1
- package/lib/services/notes.service.d.ts.map +1 -1
- package/lib/services/zaakobjecten.service.d.ts.map +1 -1
- package/package.json +13 -19
- package/public_api.d.ts +13 -14
- package/public_api.d.ts.map +1 -1
- package/esm2020/lib/dossier-assign-user/dossier-assign-user.component.mjs +0 -126
- package/esm2020/lib/dossier-detail/dossier-detail.component.mjs +0 -175
- package/esm2020/lib/dossier-detail/tab/audit/audit.component.mjs +0 -76
- package/esm2020/lib/dossier-detail/tab/contact-moments/contact-moments.component.mjs +0 -86
- package/esm2020/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.mjs +0 -147
- package/esm2020/lib/dossier-detail/tab/documents/documents.component.mjs +0 -41
- package/esm2020/lib/dossier-detail/tab/notes/notes.component.mjs +0 -153
- package/esm2020/lib/dossier-detail/tab/object-type/object-type.component.mjs +0 -122
- package/esm2020/lib/dossier-detail/tab/progress/progress.component.mjs +0 -51
- package/esm2020/lib/dossier-detail/tab/s3-documents/s3-documents.component.mjs +0 -134
- package/esm2020/lib/dossier-detail/tab/summary/summary.component.mjs +0 -124
- package/esm2020/lib/dossier-detail/tab/zaakobjecten/zaakobjecten.component.mjs +0 -113
- package/esm2020/lib/dossier-detail-tab-enum.mjs +0 -26
- package/esm2020/lib/dossier-list/dossier-list.component.mjs +0 -224
- package/esm2020/lib/dossier-list-actions/dossier-list-actions.component.mjs +0 -86
- package/esm2020/lib/dossier-process-start-modal/dossier-process-start-modal.component.mjs +0 -192
- package/esm2020/lib/dossier-routing.module.mjs +0 -66
- package/esm2020/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +0 -181
- package/esm2020/lib/dossier-update/dossier-update.component.mjs +0 -113
- package/esm2020/lib/dossier.config.mjs +0 -29
- package/esm2020/lib/dossier.module.mjs +0 -259
- package/esm2020/lib/dossier.service.mjs +0 -50
- package/esm2020/lib/models/index.mjs +0 -20
- package/esm2020/lib/models/tabs.model.mjs +0 -112
- package/esm2020/lib/services/dossier-column.service.mjs +0 -100
- package/esm2020/lib/services/dossier-list-assignee.service.mjs +0 -82
- package/esm2020/lib/services/dossier-list-pagination.service.mjs +0 -116
- package/esm2020/lib/services/dossier-list-search.service.mjs +0 -66
- package/esm2020/lib/services/dossier-list.service.mjs +0 -56
- package/esm2020/lib/services/dossier-parameter.service.mjs +0 -167
- package/esm2020/lib/services/index.mjs +0 -24
- package/esm2020/lib/services/notes.service.mjs +0 -76
- package/esm2020/lib/tab.service.mjs +0 -80
- package/esm2020/public_api.mjs +0 -35
- package/fesm2015/valtimo-dossier.mjs +0 -3348
- package/fesm2015/valtimo-dossier.mjs.map +0 -1
- package/fesm2020/valtimo-dossier.mjs +0 -3447
- package/fesm2020/valtimo-dossier.mjs.map +0 -1
- package/lib/dossier-assign-user/dossier-assign-user.component.d.ts +0 -34
- package/lib/dossier-assign-user/dossier-assign-user.component.d.ts.map +0 -1
- package/lib/dossier-detail/dossier-detail.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/audit/audit.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/contact-moments/contact-moments.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/documents/documents.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/notes/notes.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/object-type/object-type.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/progress/progress.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/s3-documents/s3-documents.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/summary/summary.component.d.ts.map +0 -1
- package/lib/dossier-detail/tab/zaakobjecten/zaakobjecten.component.d.ts.map +0 -1
- package/lib/dossier-detail-tab-enum.d.ts +0 -10
- package/lib/dossier-detail-tab-enum.d.ts.map +0 -1
- package/lib/dossier-list/dossier-list.component.d.ts +0 -66
- package/lib/dossier-list/dossier-list.component.d.ts.map +0 -1
- package/lib/dossier-list-actions/dossier-list-actions.component.d.ts.map +0 -1
- package/lib/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +0 -1
- package/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +0 -1
- package/lib/dossier-update/dossier-update.component.d.ts.map +0 -1
- package/lib/dossier.config.d.ts +0 -4
- package/lib/dossier.config.d.ts.map +0 -1
- package/lib/dossier.service.d.ts.map +0 -1
- package/lib/tab.service.d.ts +0 -21
- package/lib/tab.service.d.ts.map +0 -1
- /package/{esm2020 → esm2022}/lib/models/notes.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/search.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/zaakobjecten.model.mjs +0 -0
- /package/{esm2020 → esm2022}/valtimo-dossier.mjs +0 -0
|
@@ -0,0 +1,370 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2023 Ritense BV, the Netherlands.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under EUPL, Version 1.2 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" basis,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
import { Component, ViewChild } from '@angular/core';
|
|
17
|
+
import { CarbonListComponent, } from '@valtimo/components';
|
|
18
|
+
import { DossierListTab, } from '@valtimo/config';
|
|
19
|
+
import { AdvancedDocumentSearchRequestImpl, } from '@valtimo/document';
|
|
20
|
+
import { Tabs } from 'carbon-components-angular';
|
|
21
|
+
import { isEqual } from 'lodash';
|
|
22
|
+
import { BehaviorSubject, combineLatest, distinctUntilChanged, filter, forkJoin, map, of, switchMap, take, tap, } from 'rxjs';
|
|
23
|
+
import { DossierListActionsComponent } from '../dossier-list-actions/dossier-list-actions.component';
|
|
24
|
+
import { CAN_CREATE_CASE_PERMISSION, DOSSIER_DETAIL_PERMISSION_RESOURCE } from '../../permissions';
|
|
25
|
+
import { DossierColumnService, DossierListAssigneeService, DossierListPaginationService, DossierListSearchService, DossierListService, DossierParameterService, } from '../../services';
|
|
26
|
+
import * as i0 from "@angular/core";
|
|
27
|
+
import * as i1 from "../../services";
|
|
28
|
+
import * as i2 from "@valtimo/components";
|
|
29
|
+
import * as i3 from "@valtimo/config";
|
|
30
|
+
import * as i4 from "@valtimo/document";
|
|
31
|
+
import * as i5 from "@angular/router";
|
|
32
|
+
import * as i6 from "@ngx-translate/core";
|
|
33
|
+
import * as i7 from "@valtimo/access-control";
|
|
34
|
+
import * as i8 from "@angular/common";
|
|
35
|
+
import * as i9 from "carbon-components-angular";
|
|
36
|
+
import * as i10 from "../dossier-bulk-assign-modal/dossier-bulk-assign-modal.component";
|
|
37
|
+
import * as i11 from "../dossier-list-actions/dossier-list-actions.component";
|
|
38
|
+
export class DossierListComponent {
|
|
39
|
+
constructor(assigneeService, breadcrumbService, bulkAssignService, columnService, configService, documentService, listService, pageTitleService, paginationService, parameterService, route, router, searchService, translateService, permissionService) {
|
|
40
|
+
this.assigneeService = assigneeService;
|
|
41
|
+
this.breadcrumbService = breadcrumbService;
|
|
42
|
+
this.bulkAssignService = bulkAssignService;
|
|
43
|
+
this.columnService = columnService;
|
|
44
|
+
this.configService = configService;
|
|
45
|
+
this.documentService = documentService;
|
|
46
|
+
this.listService = listService;
|
|
47
|
+
this.pageTitleService = pageTitleService;
|
|
48
|
+
this.paginationService = paginationService;
|
|
49
|
+
this.parameterService = parameterService;
|
|
50
|
+
this.route = route;
|
|
51
|
+
this.router = router;
|
|
52
|
+
this.searchService = searchService;
|
|
53
|
+
this.translateService = translateService;
|
|
54
|
+
this.permissionService = permissionService;
|
|
55
|
+
this.activeTab = null;
|
|
56
|
+
this.loadingFields = true;
|
|
57
|
+
this.loadingPagination = true;
|
|
58
|
+
this.loadingSearchFields = true;
|
|
59
|
+
this.loadingAssigneeFilter = true;
|
|
60
|
+
this.loadingDocumentItems = true;
|
|
61
|
+
this.visibleDossierTabs = null;
|
|
62
|
+
this.defaultTabs = [
|
|
63
|
+
DossierListTab.ALL,
|
|
64
|
+
DossierListTab.MINE,
|
|
65
|
+
DossierListTab.OPEN,
|
|
66
|
+
];
|
|
67
|
+
this.tableTranslations = {
|
|
68
|
+
select: {
|
|
69
|
+
single: 'dossier.select.single',
|
|
70
|
+
multiple: 'dossier.select.multiple',
|
|
71
|
+
},
|
|
72
|
+
pagination: {
|
|
73
|
+
itemsPerPage: 'dossier.pagination.itemsPerPage',
|
|
74
|
+
totalItem: 'dossier.pagination.totalItem',
|
|
75
|
+
totalItems: 'dossier.pagination.totalItems',
|
|
76
|
+
},
|
|
77
|
+
};
|
|
78
|
+
this.noResultsMessage$ = new BehaviorSubject({
|
|
79
|
+
description: 'dossier.noResults.ALL.description',
|
|
80
|
+
isSearchResult: false,
|
|
81
|
+
title: 'dossier.noResults.ALL.title',
|
|
82
|
+
});
|
|
83
|
+
this.showAssignModal$ = new BehaviorSubject(false);
|
|
84
|
+
this.showChangePageModal$ = new BehaviorSubject(false);
|
|
85
|
+
this.showChangeTabModal$ = new BehaviorSubject(false);
|
|
86
|
+
this.searchFields$ = this.searchService.documentSearchFields$.pipe(tap(() => {
|
|
87
|
+
this.loadingSearchFields = false;
|
|
88
|
+
}));
|
|
89
|
+
this.documentDefinitionName$ = this.listService.documentDefinitionName$;
|
|
90
|
+
this.canCreateDocument$ = this.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.permissionService.requestPermission(CAN_CREATE_CASE_PERMISSION, {
|
|
91
|
+
resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocumentDefinition,
|
|
92
|
+
identifier: documentDefinitionName,
|
|
93
|
+
})));
|
|
94
|
+
this.selectedDocumentIds$ = new BehaviorSubject([]);
|
|
95
|
+
this.schema$ = this.listService.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.documentService.getDocumentDefinition(documentDefinitionName)), map(documentDefinition => documentDefinition?.schema), tap(schema => {
|
|
96
|
+
if (schema?.title) {
|
|
97
|
+
this.pageTitleService.setCustomPageTitle(schema?.title, true);
|
|
98
|
+
}
|
|
99
|
+
}));
|
|
100
|
+
this.searchFieldValues$ = this.parameterService.searchFieldValues$;
|
|
101
|
+
this.assigneeFilter$ = this.assigneeService.assigneeFilter$.pipe(tap(assigneeFilter => (this.activeTab = assigneeFilter)));
|
|
102
|
+
this.paginationChange$ = new BehaviorSubject(null);
|
|
103
|
+
this.tabChange$ = new BehaviorSubject(null);
|
|
104
|
+
this._pagination$ = this.paginationService.pagination$.pipe(tap(pagination => {
|
|
105
|
+
this.pagination = pagination;
|
|
106
|
+
this.loadingPagination = false;
|
|
107
|
+
}));
|
|
108
|
+
this._hasEnvColumnConfig$ = this.listService.hasEnvColumnConfig$;
|
|
109
|
+
this._hasApiColumnConfig$ = new BehaviorSubject(false);
|
|
110
|
+
this._canHaveAssignee$ = this.assigneeService.canHaveAssignee$;
|
|
111
|
+
this._columns$ = this.listService.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.columnService.getDefinitionColumns(documentDefinitionName)), map(res => {
|
|
112
|
+
this._hasApiColumnConfig$.next(res.hasApiConfig);
|
|
113
|
+
return res.columns;
|
|
114
|
+
}), tap(columns => {
|
|
115
|
+
this.listService.documentDefinitionName$.pipe(take(1)).subscribe(_ => {
|
|
116
|
+
this.paginationService.setPagination(columns);
|
|
117
|
+
});
|
|
118
|
+
}));
|
|
119
|
+
this.fields$ = combineLatest([
|
|
120
|
+
this._canHaveAssignee$,
|
|
121
|
+
this._columns$,
|
|
122
|
+
this._hasEnvColumnConfig$,
|
|
123
|
+
this._hasApiColumnConfig$,
|
|
124
|
+
this.translateService.stream('key'),
|
|
125
|
+
]).pipe(tap(([canHaveAssignee]) => {
|
|
126
|
+
this.canHaveAssignee = canHaveAssignee;
|
|
127
|
+
}), map(([canHaveAssignee, columns, hasEnvConfig, hasApiConfig]) => {
|
|
128
|
+
const filteredAssigneeColumns = this.assigneeService.filterAssigneeColumns(columns, canHaveAssignee);
|
|
129
|
+
const listFields = this.columnService.mapDefinitionColumnsToListFields(filteredAssigneeColumns, hasEnvConfig, hasApiConfig);
|
|
130
|
+
const fieldsToReturn = this.assigneeService.addAssigneeListField(columns, listFields, canHaveAssignee);
|
|
131
|
+
return fieldsToReturn;
|
|
132
|
+
}), tap(listFields => {
|
|
133
|
+
const defaultListField = listFields.find(field => field.default);
|
|
134
|
+
// set default sort state if no pagination query parameters for sorting are available
|
|
135
|
+
this.parameterService.queryPaginationParams$
|
|
136
|
+
.pipe(take(1))
|
|
137
|
+
.subscribe(queryPaginationParams => {
|
|
138
|
+
if (defaultListField && !queryPaginationParams?.sort?.isSorting) {
|
|
139
|
+
const sortDirection = typeof defaultListField.default === 'string' ? defaultListField.default : 'DESC';
|
|
140
|
+
this.paginationService.sortChanged({
|
|
141
|
+
isSorting: true,
|
|
142
|
+
state: { name: defaultListField.key, direction: sortDirection },
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
});
|
|
146
|
+
}), tap(() => {
|
|
147
|
+
this.loadingFields = false;
|
|
148
|
+
}));
|
|
149
|
+
this._documentSearchRequest$ = combineLatest([this._pagination$, this.listService.documentDefinitionName$]).pipe(filter(([pagination]) => !!pagination), map(([pagination, documentDefinitionName]) => {
|
|
150
|
+
const page = pagination.page - 1;
|
|
151
|
+
return new AdvancedDocumentSearchRequestImpl(documentDefinitionName, page >= 0 ? page : 0, pagination.size, pagination.sort);
|
|
152
|
+
}));
|
|
153
|
+
this.documentItems$ = this.listService.checkRefresh$.pipe(switchMap(() => combineLatest([
|
|
154
|
+
this._documentSearchRequest$,
|
|
155
|
+
this.assigneeFilter$,
|
|
156
|
+
this.searchFieldValues$,
|
|
157
|
+
this.listService.forceRefresh$,
|
|
158
|
+
this._hasEnvColumnConfig$,
|
|
159
|
+
this._hasApiColumnConfig$,
|
|
160
|
+
])), distinctUntilChanged(([prevSearchRequest, prevAssigneeFilter, prevSearchFieldValues, prevForceRefresh], [currSearchRequest, currAssigneeFilter, currSearchFieldValues, currForceRefresh]) => isEqual({
|
|
161
|
+
...prevSearchRequest,
|
|
162
|
+
assignee: prevAssigneeFilter,
|
|
163
|
+
...prevSearchFieldValues,
|
|
164
|
+
forceRefresh: prevForceRefresh,
|
|
165
|
+
}, {
|
|
166
|
+
...currSearchRequest,
|
|
167
|
+
assignee: currAssigneeFilter,
|
|
168
|
+
...currSearchFieldValues,
|
|
169
|
+
forceRefresh: currForceRefresh,
|
|
170
|
+
})), switchMap(([documentSearchRequest, assigneeFilter, searchValues, _, hasEnvColumnConfig, hasApiColumnConfig,]) => {
|
|
171
|
+
const obsEnv = of(hasEnvColumnConfig);
|
|
172
|
+
const obsApi = of(hasApiColumnConfig);
|
|
173
|
+
if ((Object.keys(searchValues) || []).length > 0) {
|
|
174
|
+
return forkJoin({
|
|
175
|
+
documents: hasEnvColumnConfig || !hasApiColumnConfig
|
|
176
|
+
? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.searchService.mapSearchValuesToFilters(searchValues))
|
|
177
|
+
: this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.searchService.mapSearchValuesToFilters(searchValues)),
|
|
178
|
+
hasEnvColumnConfig: obsEnv,
|
|
179
|
+
hasApiColumnConfig: obsApi,
|
|
180
|
+
isSearchResult: of(true),
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
return forkJoin({
|
|
184
|
+
documents: hasEnvColumnConfig || !hasApiColumnConfig
|
|
185
|
+
? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter)
|
|
186
|
+
: this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter),
|
|
187
|
+
hasEnvColumnConfig: obsEnv,
|
|
188
|
+
hasApiColumnConfig: obsApi,
|
|
189
|
+
isSearchResult: of(false),
|
|
190
|
+
});
|
|
191
|
+
}), map((res) => {
|
|
192
|
+
this.paginationService.setCollectionSize(res.documents);
|
|
193
|
+
this.paginationService.checkPage(res.documents);
|
|
194
|
+
this.updateNoResultsMessage(res.isSearchResult);
|
|
195
|
+
return this.listService.mapDocuments(res.documents, res.hasEnvColumnConfig, res.hasApiColumnConfig);
|
|
196
|
+
}), tap(() => {
|
|
197
|
+
this.loadingAssigneeFilter = false;
|
|
198
|
+
this.loadingDocumentItems = false;
|
|
199
|
+
}));
|
|
200
|
+
}
|
|
201
|
+
ngOnInit() {
|
|
202
|
+
this.setVisibleTabs();
|
|
203
|
+
this.openDocumentDefinitionNameSubscription();
|
|
204
|
+
}
|
|
205
|
+
ngOnDestroy() {
|
|
206
|
+
this._documentDefinitionNameSubscription?.unsubscribe();
|
|
207
|
+
this.pageTitleService.enableReset();
|
|
208
|
+
}
|
|
209
|
+
trackByIndex(index) {
|
|
210
|
+
return index;
|
|
211
|
+
}
|
|
212
|
+
search(searchFieldValues) {
|
|
213
|
+
this.searchService.search(searchFieldValues);
|
|
214
|
+
}
|
|
215
|
+
rowClick(document) {
|
|
216
|
+
this.listService.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
|
|
217
|
+
this.breadcrumbService.cacheQueryParams(`/dossiers/${documentDefinitionName}`, this.route.snapshot.queryParams);
|
|
218
|
+
this.router.navigate([
|
|
219
|
+
`/dossiers/${documentDefinitionName}/document/${document.id}`,
|
|
220
|
+
]);
|
|
221
|
+
});
|
|
222
|
+
}
|
|
223
|
+
tabChange(tab) {
|
|
224
|
+
if (!this.activeTab) {
|
|
225
|
+
this.activeTab = tab;
|
|
226
|
+
this.updateNoResultsMessage(false);
|
|
227
|
+
return;
|
|
228
|
+
}
|
|
229
|
+
if (this.activeTab.toLowerCase() === tab.toLowerCase()) {
|
|
230
|
+
return;
|
|
231
|
+
}
|
|
232
|
+
if (this.carbonList.model.selectedRowsCount()) {
|
|
233
|
+
this.showChangeTabModal$.next(true);
|
|
234
|
+
this.tabChange$.next(tab);
|
|
235
|
+
return;
|
|
236
|
+
}
|
|
237
|
+
this.onChangeTabConfirm(tab);
|
|
238
|
+
}
|
|
239
|
+
onChangeTabCancel() {
|
|
240
|
+
if (!this.tabsComponent) {
|
|
241
|
+
return;
|
|
242
|
+
}
|
|
243
|
+
const prevTab = this.tabsComponent.tabs.find((tab) => tab.id === this.activeTab);
|
|
244
|
+
if (!prevTab) {
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
this.tabsComponent.tabs.find((tab) => tab.active).active = false;
|
|
248
|
+
prevTab.active = true;
|
|
249
|
+
}
|
|
250
|
+
pageChange(page) {
|
|
251
|
+
if (this.carbonList?.model.selectedRowsCount()) {
|
|
252
|
+
this.showChangePageModal$.next(true);
|
|
253
|
+
this.paginationChange$.next({ page, size: this.pagination.size });
|
|
254
|
+
return;
|
|
255
|
+
}
|
|
256
|
+
this.paginationService.pageChange(page);
|
|
257
|
+
}
|
|
258
|
+
pageSizeChange(size) {
|
|
259
|
+
if (this.carbonList?.model.selectedRowsCount()) {
|
|
260
|
+
this.showChangePageModal$.next(true);
|
|
261
|
+
this.paginationChange$.next({ page: this.pagination.page, size });
|
|
262
|
+
return;
|
|
263
|
+
}
|
|
264
|
+
this.paginationService.pageSizeChange(size);
|
|
265
|
+
}
|
|
266
|
+
sortChanged(newSortState) {
|
|
267
|
+
this.paginationService.sortChanged(newSortState);
|
|
268
|
+
}
|
|
269
|
+
onChangeTabConfirm(tab) {
|
|
270
|
+
this.loadingAssigneeFilter = true;
|
|
271
|
+
this.activeTab = tab;
|
|
272
|
+
this.updateNoResultsMessage(false);
|
|
273
|
+
this.paginationService.setPage(1);
|
|
274
|
+
this.assigneeService.setAssigneeFilter(tab);
|
|
275
|
+
}
|
|
276
|
+
showAssignModal() {
|
|
277
|
+
this.selectedDocumentIds$.next(this.carbonList.selectedItems.map((document) => document.id));
|
|
278
|
+
this.showAssignModal$.next(true);
|
|
279
|
+
}
|
|
280
|
+
onCloseEvent(assigneeId, documentIds) {
|
|
281
|
+
this.showAssignModal$.next(false);
|
|
282
|
+
if (!assigneeId) {
|
|
283
|
+
return;
|
|
284
|
+
}
|
|
285
|
+
this.bulkAssignService.bulkAssign(assigneeId, documentIds).subscribe(() => {
|
|
286
|
+
this.forceRefresh();
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
onChangePageConfirm(pagination) {
|
|
290
|
+
if (pagination.size !== this.pagination.size) {
|
|
291
|
+
this.paginationService.pageSizeChange(pagination.size);
|
|
292
|
+
return;
|
|
293
|
+
}
|
|
294
|
+
this.paginationService.pageChange(pagination.page);
|
|
295
|
+
}
|
|
296
|
+
startDossier() {
|
|
297
|
+
this.listActionsComponent.startDossier();
|
|
298
|
+
}
|
|
299
|
+
forceRefresh() {
|
|
300
|
+
this.listService.forceRefresh();
|
|
301
|
+
}
|
|
302
|
+
openDocumentDefinitionNameSubscription() {
|
|
303
|
+
this._documentDefinitionNameSubscription = this.route.params
|
|
304
|
+
.pipe(map((params) => params?.documentDefinitionName), filter(docDefName => !!docDefName), distinctUntilChanged())
|
|
305
|
+
.subscribe(documentDefinitonName => {
|
|
306
|
+
if (this._previousDocumentDefinitionName) {
|
|
307
|
+
this.parameterService.clearParameters();
|
|
308
|
+
this.parameterService.clearSearchFieldValues();
|
|
309
|
+
}
|
|
310
|
+
this._previousDocumentDefinitionName = documentDefinitonName;
|
|
311
|
+
this.setLoading();
|
|
312
|
+
this.paginationService.clearPagination();
|
|
313
|
+
this.assigneeService.resetAssigneeFilter();
|
|
314
|
+
this.listService.setDocumentDefinitionName(documentDefinitonName);
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
setLoading() {
|
|
318
|
+
this.loadingFields = true;
|
|
319
|
+
this.loadingPagination = true;
|
|
320
|
+
this.loadingSearchFields = true;
|
|
321
|
+
this.loadingAssigneeFilter = true;
|
|
322
|
+
this.loadingDocumentItems = true;
|
|
323
|
+
}
|
|
324
|
+
setVisibleTabs() {
|
|
325
|
+
this.visibleDossierTabs = this.configService.config?.visibleDossierListTabs || null;
|
|
326
|
+
}
|
|
327
|
+
updateNoResultsMessage(isSearchResult) {
|
|
328
|
+
this.noResultsMessage$.next(isSearchResult
|
|
329
|
+
? {
|
|
330
|
+
description: 'dossier.noResults.search.description',
|
|
331
|
+
isSearchResult,
|
|
332
|
+
title: 'dossier.noResults.search.title',
|
|
333
|
+
}
|
|
334
|
+
: {
|
|
335
|
+
description: `dossier.noResults.${this.activeTab ?? 'ALL'}.description`,
|
|
336
|
+
isSearchResult,
|
|
337
|
+
title: `dossier.noResults.${this.activeTab ?? 'ALL'}.title`,
|
|
338
|
+
});
|
|
339
|
+
}
|
|
340
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierListComponent, deps: [{ token: i1.DossierListAssigneeService }, { token: i2.BreadcrumbService }, { token: i1.DossierBulkAssignService }, { token: i1.DossierColumnService }, { token: i3.ConfigService }, { token: i4.DocumentService }, { token: i1.DossierListService }, { token: i2.PageTitleService }, { token: i1.DossierListPaginationService }, { token: i1.DossierParameterService }, { token: i5.ActivatedRoute }, { token: i5.Router }, { token: i1.DossierListSearchService }, { token: i6.TranslateService }, { token: i7.PermissionService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
341
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DossierListComponent, selector: "valtimo-dossier-list", providers: [
|
|
342
|
+
DossierListService,
|
|
343
|
+
DossierColumnService,
|
|
344
|
+
DossierListAssigneeService,
|
|
345
|
+
DossierParameterService,
|
|
346
|
+
DossierListPaginationService,
|
|
347
|
+
DossierListSearchService,
|
|
348
|
+
], viewQueries: [{ propertyName: "carbonList", first: true, predicate: CarbonListComponent, descendants: true }, { propertyName: "listActionsComponent", first: true, predicate: DossierListActionsComponent, descendants: true }, { propertyName: "tabsComponent", first: true, predicate: Tabs, descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n fields: fields$ | async,\n documentItems: documentItems$ | async,\n noResultsMessage: noResultsMessage$ | async,\n searchFields: searchFields$ | async,\n schema: schema$ | async,\n showAssignModal: showAssignModal$ | async,\n selectedDocumentIds: selectedDocumentIds$ | async,\n loaded:\n !loadingFields &&\n !loadingPagination &&\n !loadingSearchFields &&\n !loadingAssigneeFilter &&\n !loadingDocumentItems\n } as obs\"\n>\n <div class=\"main-content pt-0\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <valtimo-dossier-list-actions\n [loading]=\"!obs.loaded\"\n (formFlowComplete)=\"forceRefresh()\"\n ></valtimo-dossier-list-actions>\n <ng-container *ngTemplateOutlet=\"searchFields; context: {obs: obs}\"></ng-container>\n\n <ng-container *ngIf=\"obs.loaded; else loading\">\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n </ng-container>\n </div>\n </div>\n </div>\n\n <ng-container *ngTemplateOutlet=\"bulkAssignModal; context: {obs: obs}\"></ng-container>\n\n <ng-container *ngTemplateOutlet=\"changePageModal\"></ng-container>\n\n <ng-container *ngTemplateOutlet=\"changeTabModal\"></ng-container>\n</ng-container>\n\n<ng-template #searchFields let-obs=\"obs\">\n <div class=\"mb-3\">\n <valtimo-search-fields\n [searchFields]=\"obs.searchFields\"\n (doSearch)=\"search($event)\"\n [documentDefinitionName]=\"documentDefinitionName$ | async\"\n [defaultValues]=\"searchFieldValues$ | async\"\n [inputDisabled]=\"!obs.loaded\"\n ></valtimo-search-fields>\n </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n <valtimo-carbon-list\n [fields]=\"obs.fields\"\n [header]=\"false\"\n [initialSortState]=\"pagination.sort\"\n [items]=\"obs.documentItems\"\n [pagination]=\"pagination\"\n paginationIdentifier=\"dossierList\"\n [showSelectionColumn]=\"canHaveAssignee\"\n [tableTranslations]=\"tableTranslations\"\n (paginationClicked)=\"pageChange($event)\"\n (paginationSet)=\"pageSizeChange($event)\"\n (rowClicked)=\"rowClick($event)\"\n (sortChanged)=\"sortChanged($event)\"\n >\n <ng-container carbonToolbarActions>\n <button cdsButton=\"primary\" (click)=\"showAssignModal()\">\n {{ 'dossier.bulkAssign.assign' | translate }}\n </button>\n </ng-container>\n\n <div carbonToolbarContent>\n <ng-container *ngTemplateOutlet=\"dossierListActions\"></ng-container>\n </div>\n\n <valtimo-no-results\n [action]=\"obs.noResultsMessage.isSearchResult ? null : dossierListActions\"\n [description]=\"obs.noResultsMessage.description | translate\"\n [title]=\"obs.noResultsMessage.title | translate\"\n ></valtimo-no-results>\n\n <div tabs *ngIf=\"canHaveAssignee\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n </div>\n </valtimo-carbon-list>\n</ng-template>\n\n<ng-template #tabs>\n <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n <cds-tabs\n *ngIf=\"!visibleDossierTabs; else configuredTabs\"\n type=\"contained\"\n data-carbon-theme=\"g10\"\n class=\"dossier-list-tabs\"\n >\n <cds-tab\n *ngFor=\"let tab of defaultTabs; trackBy: trackByIndex\"\n [active]=\"assigneeFilter === tab\"\n heading=\"{{ 'dossier.tabs.' + tab | translate }}\"\n [id]=\"tab\"\n (selected)=\"tabChange(tab)\"\n ></cds-tab>\n </cds-tabs>\n </ng-container>\n</ng-template>\n\n<ng-template #configuredTabs>\n <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n <cds-tabs type=\"contained\" class=\"dossier-list-tabs\">\n <cds-tab\n *ngFor=\"let tab of visibleDossierTabs; trackBy: trackByIndex\"\n [active]=\"assigneeFilter === tab\"\n heading=\"{{ 'dossier.tabs.' + tab | translate }}\"\n [id]=\"tab\"\n (selected)=\"tabChange(tab)\"\n ></cds-tab>\n </cds-tabs>\n </ng-container>\n</ng-template>\n\n<ng-template #loading\n ><valtimo-carbon-list [loading]=\"true\">\n <div tabs *ngIf=\"canHaveAssignee\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n </div> </valtimo-carbon-list\n></ng-template>\n\n<ng-template #bulkAssignModal let-obs=\"obs\">\n <valtimo-dossier-bulk-assign-modal\n [documentIds]=\"obs.selectedDocumentIds\"\n [open]=\"obs.showAssignModal\"\n (closeEvent)=\"onCloseEvent($event, obs.selectedDocumentIds)\"\n ></valtimo-dossier-bulk-assign-modal>\n</ng-template>\n\n<ng-template #changePageModal>\n <valtimo-confirmation-modal\n confirmButtonTextTranslationKey=\"dossier.changePageModal.confirm\"\n contentTranslationKey=\"dossier.changePageModal.content\"\n [outputOnConfirm]=\"paginationChange$ | async\"\n [showModalSubject$]=\"showChangePageModal$\"\n titleTranslationKey=\"dossier.changePageModal.title\"\n (confirmEvent)=\"onChangePageConfirm($event)\"\n ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #changeTabModal>\n <valtimo-confirmation-modal\n confirmButtonTextTranslationKey=\"dossier.changeTabModal.confirm\"\n contentTranslationKey=\"dossier.changeTabModal.content\"\n [outputOnConfirm]=\"tabChange$ | async\"\n [showModalSubject$]=\"showChangeTabModal$\"\n titleTranslationKey=\"dossier.changeTabModal.title\"\n (cancelEvent)=\"onChangeTabCancel()\"\n (confirmEvent)=\"onChangeTabConfirm($event)\"\n ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #dossierListActions>\n <button\n cdsButton=\"primary\"\n [disabled]=\"listActionsComponent?.disableStartDossierButton$ | async\"\n (click)=\"startDossier()\"\n >\n {{ 'Start Dossier' | translate }}\n\n <svg cdsIcon=\"add\" size=\"16\" class=\"cds--btn__icon\"></svg>\n </button>\n</ng-template>\n", styles: [".dossier-list-tabs cds-tab{display:none}\n"], dependencies: [{ kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.SearchFieldsComponent, selector: "valtimo-search-fields", inputs: ["loading", "searchFields", "documentDefinitionName", "setValuesSubject$", "defaultValues", "inputDisabled"], outputs: ["doSearch"] }, { kind: "directive", type: i9.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "directive", type: i9.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "component", type: i2.ConfirmationModalComponent, selector: "valtimo-confirmation-modal", inputs: ["titleTranslationKey", "title", "content", "contentTranslationKey", "confirmButtonText", "confirmButtonTextTranslationKey", "confirmButtonType", "cancelButtonText", "cancelButtonTextTranslationKey", "cancelButtonType", "showModalSubject$", "outputOnConfirm"], outputs: ["confirmEvent", "cancelEvent"] }, { kind: "component", type: i9.Tabs, selector: "cds-tabs, ibm-tabs", inputs: ["position", "cacheActive", "followFocus", "isNavigation", "ariaLabel", "ariaLabelledby", "type", "theme", "skeleton"] }, { kind: "component", type: i9.Tab, selector: "cds-tab, ibm-tab", inputs: ["heading", "title", "context", "active", "disabled", "tabIndex", "id", "cacheActive"], outputs: ["selected"] }, { kind: "component", type: i2.CarbonListComponent, selector: "valtimo-carbon-list", inputs: ["items", "fields", "tableTranslations", "paginatorConfig", "pagination", "loading", "actions", "header", "initialSortState", "isSearchable", "enableSingleSelection", "lastColumnTemplate", "paginationIdentifier", "showSelectionColumn", "striped"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }, { kind: "component", type: i2.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title"] }, { kind: "component", type: i10.DossierBulkAssignModalComponent, selector: "valtimo-dossier-bulk-assign-modal", inputs: ["documentIds", "open"], outputs: ["closeEvent"] }, { kind: "component", type: i11.DossierListActionsComponent, selector: "valtimo-dossier-list-actions", inputs: ["loading"], outputs: ["formFlowComplete"] }, { kind: "pipe", type: i8.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] }); }
|
|
349
|
+
}
|
|
350
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierListComponent, decorators: [{
|
|
351
|
+
type: Component,
|
|
352
|
+
args: [{ selector: 'valtimo-dossier-list', providers: [
|
|
353
|
+
DossierListService,
|
|
354
|
+
DossierColumnService,
|
|
355
|
+
DossierListAssigneeService,
|
|
356
|
+
DossierParameterService,
|
|
357
|
+
DossierListPaginationService,
|
|
358
|
+
DossierListSearchService,
|
|
359
|
+
], template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n fields: fields$ | async,\n documentItems: documentItems$ | async,\n noResultsMessage: noResultsMessage$ | async,\n searchFields: searchFields$ | async,\n schema: schema$ | async,\n showAssignModal: showAssignModal$ | async,\n selectedDocumentIds: selectedDocumentIds$ | async,\n loaded:\n !loadingFields &&\n !loadingPagination &&\n !loadingSearchFields &&\n !loadingAssigneeFilter &&\n !loadingDocumentItems\n } as obs\"\n>\n <div class=\"main-content pt-0\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <valtimo-dossier-list-actions\n [loading]=\"!obs.loaded\"\n (formFlowComplete)=\"forceRefresh()\"\n ></valtimo-dossier-list-actions>\n <ng-container *ngTemplateOutlet=\"searchFields; context: {obs: obs}\"></ng-container>\n\n <ng-container *ngIf=\"obs.loaded; else loading\">\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n </ng-container>\n </div>\n </div>\n </div>\n\n <ng-container *ngTemplateOutlet=\"bulkAssignModal; context: {obs: obs}\"></ng-container>\n\n <ng-container *ngTemplateOutlet=\"changePageModal\"></ng-container>\n\n <ng-container *ngTemplateOutlet=\"changeTabModal\"></ng-container>\n</ng-container>\n\n<ng-template #searchFields let-obs=\"obs\">\n <div class=\"mb-3\">\n <valtimo-search-fields\n [searchFields]=\"obs.searchFields\"\n (doSearch)=\"search($event)\"\n [documentDefinitionName]=\"documentDefinitionName$ | async\"\n [defaultValues]=\"searchFieldValues$ | async\"\n [inputDisabled]=\"!obs.loaded\"\n ></valtimo-search-fields>\n </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n <valtimo-carbon-list\n [fields]=\"obs.fields\"\n [header]=\"false\"\n [initialSortState]=\"pagination.sort\"\n [items]=\"obs.documentItems\"\n [pagination]=\"pagination\"\n paginationIdentifier=\"dossierList\"\n [showSelectionColumn]=\"canHaveAssignee\"\n [tableTranslations]=\"tableTranslations\"\n (paginationClicked)=\"pageChange($event)\"\n (paginationSet)=\"pageSizeChange($event)\"\n (rowClicked)=\"rowClick($event)\"\n (sortChanged)=\"sortChanged($event)\"\n >\n <ng-container carbonToolbarActions>\n <button cdsButton=\"primary\" (click)=\"showAssignModal()\">\n {{ 'dossier.bulkAssign.assign' | translate }}\n </button>\n </ng-container>\n\n <div carbonToolbarContent>\n <ng-container *ngTemplateOutlet=\"dossierListActions\"></ng-container>\n </div>\n\n <valtimo-no-results\n [action]=\"obs.noResultsMessage.isSearchResult ? null : dossierListActions\"\n [description]=\"obs.noResultsMessage.description | translate\"\n [title]=\"obs.noResultsMessage.title | translate\"\n ></valtimo-no-results>\n\n <div tabs *ngIf=\"canHaveAssignee\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n </div>\n </valtimo-carbon-list>\n</ng-template>\n\n<ng-template #tabs>\n <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n <cds-tabs\n *ngIf=\"!visibleDossierTabs; else configuredTabs\"\n type=\"contained\"\n data-carbon-theme=\"g10\"\n class=\"dossier-list-tabs\"\n >\n <cds-tab\n *ngFor=\"let tab of defaultTabs; trackBy: trackByIndex\"\n [active]=\"assigneeFilter === tab\"\n heading=\"{{ 'dossier.tabs.' + tab | translate }}\"\n [id]=\"tab\"\n (selected)=\"tabChange(tab)\"\n ></cds-tab>\n </cds-tabs>\n </ng-container>\n</ng-template>\n\n<ng-template #configuredTabs>\n <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n <cds-tabs type=\"contained\" class=\"dossier-list-tabs\">\n <cds-tab\n *ngFor=\"let tab of visibleDossierTabs; trackBy: trackByIndex\"\n [active]=\"assigneeFilter === tab\"\n heading=\"{{ 'dossier.tabs.' + tab | translate }}\"\n [id]=\"tab\"\n (selected)=\"tabChange(tab)\"\n ></cds-tab>\n </cds-tabs>\n </ng-container>\n</ng-template>\n\n<ng-template #loading\n ><valtimo-carbon-list [loading]=\"true\">\n <div tabs *ngIf=\"canHaveAssignee\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n </div> </valtimo-carbon-list\n></ng-template>\n\n<ng-template #bulkAssignModal let-obs=\"obs\">\n <valtimo-dossier-bulk-assign-modal\n [documentIds]=\"obs.selectedDocumentIds\"\n [open]=\"obs.showAssignModal\"\n (closeEvent)=\"onCloseEvent($event, obs.selectedDocumentIds)\"\n ></valtimo-dossier-bulk-assign-modal>\n</ng-template>\n\n<ng-template #changePageModal>\n <valtimo-confirmation-modal\n confirmButtonTextTranslationKey=\"dossier.changePageModal.confirm\"\n contentTranslationKey=\"dossier.changePageModal.content\"\n [outputOnConfirm]=\"paginationChange$ | async\"\n [showModalSubject$]=\"showChangePageModal$\"\n titleTranslationKey=\"dossier.changePageModal.title\"\n (confirmEvent)=\"onChangePageConfirm($event)\"\n ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #changeTabModal>\n <valtimo-confirmation-modal\n confirmButtonTextTranslationKey=\"dossier.changeTabModal.confirm\"\n contentTranslationKey=\"dossier.changeTabModal.content\"\n [outputOnConfirm]=\"tabChange$ | async\"\n [showModalSubject$]=\"showChangeTabModal$\"\n titleTranslationKey=\"dossier.changeTabModal.title\"\n (cancelEvent)=\"onChangeTabCancel()\"\n (confirmEvent)=\"onChangeTabConfirm($event)\"\n ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #dossierListActions>\n <button\n cdsButton=\"primary\"\n [disabled]=\"listActionsComponent?.disableStartDossierButton$ | async\"\n (click)=\"startDossier()\"\n >\n {{ 'Start Dossier' | translate }}\n\n <svg cdsIcon=\"add\" size=\"16\" class=\"cds--btn__icon\"></svg>\n </button>\n</ng-template>\n", styles: [".dossier-list-tabs cds-tab{display:none}\n"] }]
|
|
360
|
+
}], ctorParameters: function () { return [{ type: i1.DossierListAssigneeService }, { type: i2.BreadcrumbService }, { type: i1.DossierBulkAssignService }, { type: i1.DossierColumnService }, { type: i3.ConfigService }, { type: i4.DocumentService }, { type: i1.DossierListService }, { type: i2.PageTitleService }, { type: i1.DossierListPaginationService }, { type: i1.DossierParameterService }, { type: i5.ActivatedRoute }, { type: i5.Router }, { type: i1.DossierListSearchService }, { type: i6.TranslateService }, { type: i7.PermissionService }]; }, propDecorators: { carbonList: [{
|
|
361
|
+
type: ViewChild,
|
|
362
|
+
args: [CarbonListComponent]
|
|
363
|
+
}], listActionsComponent: [{
|
|
364
|
+
type: ViewChild,
|
|
365
|
+
args: [DossierListActionsComponent]
|
|
366
|
+
}], tabsComponent: [{
|
|
367
|
+
type: ViewChild,
|
|
368
|
+
args: [Tabs]
|
|
369
|
+
}] } });
|
|
370
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-list/dossier-list.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-list/dossier-list.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {Component, OnDestroy, OnInit, ViewChild} from '@angular/core';\nimport {ActivatedRoute, Params, Router} from '@angular/router';\nimport {TranslateService} from '@ngx-translate/core';\nimport {PermissionService} from '@valtimo/access-control';\nimport {\n  BreadcrumbService,\n  CarbonListComponent,\n  CarbonListTranslations,\n  CarbonPaginationSelection,\n  ListField,\n  PageTitleService,\n  Pagination,\n} from '@valtimo/components';\nimport {\n  AssigneeFilter,\n  ConfigService,\n  DefinitionColumn,\n  Direction,\n  DossierListTab,\n  SearchField,\n  SearchFieldValues,\n  SortState,\n} from '@valtimo/config';\nimport {\n  AdvancedDocumentSearchRequest,\n  AdvancedDocumentSearchRequestImpl,\n  Document,\n  Documents,\n  DocumentService,\n  SpecifiedDocuments,\n} from '@valtimo/document';\nimport {Tab, Tabs} from 'carbon-components-angular';\nimport {isEqual} from 'lodash';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  forkJoin,\n  map,\n  Observable,\n  of,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {DossierListActionsComponent} from '../dossier-list-actions/dossier-list-actions.component';\nimport {CAN_CREATE_CASE_PERMISSION, DOSSIER_DETAIL_PERMISSION_RESOURCE} from '../../permissions';\nimport {\n  DossierBulkAssignService,\n  DossierColumnService,\n  DossierListAssigneeService,\n  DossierListPaginationService,\n  DossierListSearchService,\n  DossierListService,\n  DossierParameterService,\n} from '../../services';\nimport { DefaultTabs } from '../../models';\n\n@Component({\n  selector: 'valtimo-dossier-list',\n  templateUrl: './dossier-list.component.html',\n  styleUrls: ['./dossier-list.component.scss'],\n  providers: [\n    DossierListService,\n    DossierColumnService,\n    DossierListAssigneeService,\n    DossierParameterService,\n    DossierListPaginationService,\n    DossierListSearchService,\n  ],\n})\nexport class DossierListComponent implements OnInit, OnDestroy {\n  @ViewChild(CarbonListComponent) carbonList: CarbonListComponent<Document>;\n  @ViewChild(DossierListActionsComponent) listActionsComponent: DossierListActionsComponent;\n  @ViewChild(Tabs) tabsComponent: Tabs;\n\n  public activeTab: DossierListTab = null;\n  public loadingFields = true;\n  public loadingPagination = true;\n  public loadingSearchFields = true;\n  public loadingAssigneeFilter = true;\n  public loadingDocumentItems = true;\n  public pagination!: Pagination;\n  public canHaveAssignee!: boolean;\n  public visibleDossierTabs: Array<DossierListTab> | null = null;\n\n  public readonly defaultTabs: DossierListTab[] = [\n    DossierListTab.ALL,\n    DossierListTab.MINE,\n    DossierListTab.OPEN,\n  ];\n\n  public readonly tableTranslations: CarbonListTranslations = {\n    select: {\n      single: 'dossier.select.single',\n      multiple: 'dossier.select.multiple',\n    },\n    pagination: {\n      itemsPerPage: 'dossier.pagination.itemsPerPage',\n      totalItem: 'dossier.pagination.totalItem',\n      totalItems: 'dossier.pagination.totalItems',\n    },\n  };\n\n  public readonly noResultsMessage$ = new BehaviorSubject<{\n    description: string;\n    isSearchResult: boolean;\n    title: string;\n  }>({\n    description: 'dossier.noResults.ALL.description',\n    isSearchResult: false,\n    title: 'dossier.noResults.ALL.title',\n  });\n  public readonly showAssignModal$ = new BehaviorSubject<boolean>(false);\n  public readonly showChangePageModal$ = new BehaviorSubject<boolean>(false);\n  public readonly showChangeTabModal$ = new BehaviorSubject<boolean>(false);\n\n  public readonly searchFields$: Observable<Array<SearchField> | null> =\n    this.searchService.documentSearchFields$.pipe(\n      tap(() => {\n        this.loadingSearchFields = false;\n      })\n    );\n\n  public readonly documentDefinitionName$ = this.listService.documentDefinitionName$;\n\n  public readonly canCreateDocument$: Observable<boolean> = this.documentDefinitionName$.pipe(\n    switchMap(documentDefinitionName =>\n      this.permissionService.requestPermission(CAN_CREATE_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocumentDefinition,\n        identifier: documentDefinitionName,\n      })\n    )\n  );\n  public readonly selectedDocumentIds$ = new BehaviorSubject<string[]>([]);\n\n  public readonly schema$ = this.listService.documentDefinitionName$.pipe(\n    switchMap(documentDefinitionName =>\n      this.documentService.getDocumentDefinition(documentDefinitionName)\n    ),\n    map(documentDefinition => documentDefinition?.schema),\n    tap(schema => {\n      if (schema?.title) {\n        this.pageTitleService.setCustomPageTitle(schema?.title, true);\n      }\n    })\n  );\n\n  public readonly searchFieldValues$ = this.parameterService.searchFieldValues$;\n  public readonly assigneeFilter$: Observable<AssigneeFilter> =\n    this.assigneeService.assigneeFilter$.pipe(\n      tap(assigneeFilter => (this.activeTab = assigneeFilter as DossierListTab))\n    );\n  public readonly paginationChange$ = new BehaviorSubject<CarbonPaginationSelection | null>(null);\n  public readonly tabChange$ = new BehaviorSubject<DossierListTab | null>(null);\n  private readonly _pagination$ = this.paginationService.pagination$.pipe(\n    tap(pagination => {\n      this.pagination = pagination;\n      this.loadingPagination = false;\n    })\n  );\n  private readonly _hasEnvColumnConfig$: Observable<boolean> = this.listService.hasEnvColumnConfig$;\n  private readonly _hasApiColumnConfig$ = new BehaviorSubject<boolean>(false);\n  private readonly _canHaveAssignee$: Observable<boolean> = this.assigneeService.canHaveAssignee$;\n  private readonly _columns$: Observable<Array<DefinitionColumn>> =\n    this.listService.documentDefinitionName$.pipe(\n      switchMap(documentDefinitionName =>\n        this.columnService.getDefinitionColumns(documentDefinitionName)\n      ),\n      map(res => {\n        this._hasApiColumnConfig$.next(res.hasApiConfig);\n        return res.columns;\n      }),\n      tap(columns => {\n        this.listService.documentDefinitionName$.pipe(take(1)).subscribe(_ => {\n          this.paginationService.setPagination(columns);\n        });\n      })\n    );\n\n  public readonly fields$: Observable<Array<ListField>> = combineLatest([\n    this._canHaveAssignee$,\n    this._columns$,\n    this._hasEnvColumnConfig$,\n    this._hasApiColumnConfig$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    tap(([canHaveAssignee]) => {\n      this.canHaveAssignee = canHaveAssignee;\n    }),\n    map(([canHaveAssignee, columns, hasEnvConfig, hasApiConfig]) => {\n      const filteredAssigneeColumns = this.assigneeService.filterAssigneeColumns(\n        columns,\n        canHaveAssignee\n      );\n      const listFields = this.columnService.mapDefinitionColumnsToListFields(\n        filteredAssigneeColumns,\n        hasEnvConfig,\n        hasApiConfig\n      );\n      const fieldsToReturn = this.assigneeService.addAssigneeListField(\n        columns,\n        listFields,\n        canHaveAssignee\n      );\n\n      return fieldsToReturn;\n    }),\n    tap(listFields => {\n      const defaultListField = listFields.find(field => field.default);\n      // set default sort state if no pagination query parameters for sorting are available\n      this.parameterService.queryPaginationParams$\n        .pipe(take(1))\n        .subscribe(queryPaginationParams => {\n          if (defaultListField && !queryPaginationParams?.sort?.isSorting) {\n            const sortDirection =\n              typeof defaultListField.default === 'string' ? defaultListField.default : 'DESC';\n            this.paginationService.sortChanged({\n              isSorting: true,\n              state: {name: defaultListField.key, direction: sortDirection as Direction},\n            });\n          }\n        });\n    }),\n    tap(() => {\n      this.loadingFields = false;\n    })\n  );\n\n  private readonly _documentSearchRequest$: Observable<AdvancedDocumentSearchRequest> =\n    combineLatest([this._pagination$, this.listService.documentDefinitionName$]).pipe(\n      filter(([pagination]) => !!pagination),\n      map(([pagination, documentDefinitionName]) => {\n        const page = pagination.page - 1;\n\n        return new AdvancedDocumentSearchRequestImpl(\n          documentDefinitionName,\n          page >= 0 ? page : 0,\n          pagination.size,\n          pagination.sort\n        );\n      })\n    );\n\n  public readonly documentItems$: Observable<any[]> = this.listService.checkRefresh$.pipe(\n    switchMap(() =>\n      combineLatest([\n        this._documentSearchRequest$,\n        this.assigneeFilter$,\n        this.searchFieldValues$,\n        this.listService.forceRefresh$,\n        this._hasEnvColumnConfig$,\n        this._hasApiColumnConfig$,\n      ])\n    ),\n    distinctUntilChanged(\n      (\n        [prevSearchRequest, prevAssigneeFilter, prevSearchFieldValues, prevForceRefresh],\n        [currSearchRequest, currAssigneeFilter, currSearchFieldValues, currForceRefresh]\n      ) =>\n        isEqual(\n          {\n            ...prevSearchRequest,\n            assignee: prevAssigneeFilter,\n            ...prevSearchFieldValues,\n            forceRefresh: prevForceRefresh,\n          },\n          {\n            ...currSearchRequest,\n            assignee: currAssigneeFilter,\n            ...currSearchFieldValues,\n            forceRefresh: currForceRefresh,\n          }\n        )\n    ),\n    switchMap(\n      ([\n        documentSearchRequest,\n        assigneeFilter,\n        searchValues,\n        _,\n        hasEnvColumnConfig,\n        hasApiColumnConfig,\n      ]) => {\n        const obsEnv: Observable<boolean> = of(hasEnvColumnConfig);\n        const obsApi: Observable<boolean> = of(hasApiColumnConfig);\n\n        if ((Object.keys(searchValues) || []).length > 0) {\n          return forkJoin({\n            documents:\n              hasEnvColumnConfig || !hasApiColumnConfig\n                ? this.documentService.getDocumentsSearch(\n                    documentSearchRequest,\n                    'AND',\n                    assigneeFilter,\n                    this.searchService.mapSearchValuesToFilters(searchValues)\n                  )\n                : this.documentService.getSpecifiedDocumentsSearch(\n                    documentSearchRequest,\n                    'AND',\n                    assigneeFilter,\n                    this.searchService.mapSearchValuesToFilters(searchValues)\n                  ),\n            hasEnvColumnConfig: obsEnv,\n            hasApiColumnConfig: obsApi,\n            isSearchResult: of(true),\n          });\n        }\n\n        return forkJoin({\n          documents:\n            hasEnvColumnConfig || !hasApiColumnConfig\n              ? this.documentService.getDocumentsSearch(\n                  documentSearchRequest,\n                  'AND',\n                  assigneeFilter\n                )\n              : this.documentService.getSpecifiedDocumentsSearch(\n                  documentSearchRequest,\n                  'AND',\n                  assigneeFilter\n                ),\n          hasEnvColumnConfig: obsEnv,\n          hasApiColumnConfig: obsApi,\n          isSearchResult: of(false),\n        });\n      }\n    ),\n    map(\n      (res: {\n        documents: Documents | SpecifiedDocuments;\n        hasEnvColumnConfig: boolean;\n        hasApiColumnConfig: boolean;\n        isSearchResult: boolean;\n      }) => {\n        this.paginationService.setCollectionSize(res.documents);\n        this.paginationService.checkPage(res.documents);\n        this.updateNoResultsMessage(res.isSearchResult);\n\n        return this.listService.mapDocuments(\n          res.documents,\n          res.hasEnvColumnConfig,\n          res.hasApiColumnConfig\n        );\n      }\n    ),\n    tap(() => {\n      this.loadingAssigneeFilter = false;\n      this.loadingDocumentItems = false;\n    })\n  );\n\n  private _previousDocumentDefinitionName!: string;\n  private _documentDefinitionNameSubscription!: Subscription;\n\n  constructor(\n    private readonly assigneeService: DossierListAssigneeService,\n    private readonly breadcrumbService: BreadcrumbService,\n    private readonly bulkAssignService: DossierBulkAssignService,\n    private readonly columnService: DossierColumnService,\n    private readonly configService: ConfigService,\n    private readonly documentService: DocumentService,\n    private readonly listService: DossierListService,\n    private readonly pageTitleService: PageTitleService,\n    private readonly paginationService: DossierListPaginationService,\n    private readonly parameterService: DossierParameterService,\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly searchService: DossierListSearchService,\n    private readonly translateService: TranslateService,\n    private readonly permissionService: PermissionService\n  ) {}\n\n  public ngOnInit(): void {\n    this.setVisibleTabs();\n    this.openDocumentDefinitionNameSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._documentDefinitionNameSubscription?.unsubscribe();\n    this.pageTitleService.enableReset();\n  }\n\n  public trackByIndex(index: number): number {\n    return index;\n  }\n\n  public search(searchFieldValues: SearchFieldValues): void {\n    this.searchService.search(searchFieldValues);\n  }\n\n  public rowClick(document: any): void {\n    this.listService.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {\n      this.breadcrumbService.cacheQueryParams(\n        `/dossiers/${documentDefinitionName}`,\n        this.route.snapshot.queryParams\n      );\n      this.router.navigate([\n        `/dossiers/${documentDefinitionName}/document/${document.id}`,\n      ]);\n    });\n  }\n\n  public tabChange(tab: DossierListTab): void {\n    if (!this.activeTab) {\n      this.activeTab = tab;\n      this.updateNoResultsMessage(false);\n      return;\n    }\n\n    if (this.activeTab.toLowerCase() === tab.toLowerCase()) {\n      return;\n    }\n\n    if (this.carbonList.model.selectedRowsCount()) {\n      this.showChangeTabModal$.next(true);\n      this.tabChange$.next(tab);\n      return;\n    }\n\n    this.onChangeTabConfirm(tab);\n  }\n\n  public onChangeTabCancel(): void {\n    if (!this.tabsComponent) {\n      return;\n    }\n\n    const prevTab: Tab | undefined = this.tabsComponent.tabs.find(\n      (tab: Tab) => tab.id === this.activeTab\n    );\n\n    if (!prevTab) {\n      return;\n    }\n\n    this.tabsComponent.tabs.find((tab: Tab) => tab.active).active = false;\n    prevTab.active = true;\n  }\n\n  public pageChange(page: number): void {\n    if (this.carbonList?.model.selectedRowsCount()) {\n      this.showChangePageModal$.next(true);\n      this.paginationChange$.next({page, size: this.pagination.size});\n      return;\n    }\n    this.paginationService.pageChange(page);\n  }\n\n  public pageSizeChange(size: number): void {\n    if (this.carbonList?.model.selectedRowsCount()) {\n      this.showChangePageModal$.next(true);\n      this.paginationChange$.next({page: this.pagination.page, size});\n      return;\n    }\n    this.paginationService.pageSizeChange(size);\n  }\n\n  public sortChanged(newSortState: SortState): void {\n    this.paginationService.sortChanged(newSortState);\n  }\n\n  private onChangeTabConfirm(tab: DossierListTab): void {\n    this.loadingAssigneeFilter = true;\n    this.activeTab = tab;\n    this.updateNoResultsMessage(false);\n    this.paginationService.setPage(1);\n    this.assigneeService.setAssigneeFilter(tab);\n  }\n\n  public showAssignModal(): void {\n    this.selectedDocumentIds$.next(\n      this.carbonList.selectedItems.map((document: Document) => document.id)\n    );\n    this.showAssignModal$.next(true);\n  }\n\n  public onCloseEvent(assigneeId: null | string, documentIds: string[]): void {\n    this.showAssignModal$.next(false);\n    if (!assigneeId) {\n      return;\n    }\n\n    this.bulkAssignService.bulkAssign(assigneeId, documentIds).subscribe(() => {\n      this.forceRefresh();\n    });\n  }\n\n  public onChangePageConfirm(pagination: CarbonPaginationSelection): void {\n    if (pagination.size !== this.pagination.size) {\n      this.paginationService.pageSizeChange(pagination.size);\n      return;\n    }\n\n    this.paginationService.pageChange(pagination.page);\n  }\n\n  public startDossier(): void {\n    this.listActionsComponent.startDossier();\n  }\n\n  public forceRefresh(): void {\n    this.listService.forceRefresh();\n  }\n\n  private openDocumentDefinitionNameSubscription(): void {\n    this._documentDefinitionNameSubscription = this.route.params\n      .pipe(\n        map((params: Params) => params?.documentDefinitionName),\n        filter(docDefName => !!docDefName),\n        distinctUntilChanged()\n      )\n      .subscribe(documentDefinitonName => {\n        if (this._previousDocumentDefinitionName) {\n          this.parameterService.clearParameters();\n          this.parameterService.clearSearchFieldValues();\n        }\n        this._previousDocumentDefinitionName = documentDefinitonName;\n        this.setLoading();\n        this.paginationService.clearPagination();\n        this.assigneeService.resetAssigneeFilter();\n        this.listService.setDocumentDefinitionName(documentDefinitonName);\n      });\n  }\n\n  private setLoading(): void {\n    this.loadingFields = true;\n    this.loadingPagination = true;\n    this.loadingSearchFields = true;\n    this.loadingAssigneeFilter = true;\n    this.loadingDocumentItems = true;\n  }\n\n  private setVisibleTabs(): void {\n    this.visibleDossierTabs = this.configService.config?.visibleDossierListTabs || null;\n  }\n\n  private updateNoResultsMessage(isSearchResult: boolean): void {\n    this.noResultsMessage$.next(\n      isSearchResult\n        ? {\n            description: 'dossier.noResults.search.description',\n            isSearchResult,\n            title: 'dossier.noResults.search.title',\n          }\n        : {\n            description: `dossier.noResults.${this.activeTab ?? 'ALL'}.description`,\n            isSearchResult,\n            title: `dossier.noResults.${this.activeTab ?? 'ALL'}.title`,\n          }\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    fields: fields$ | async,\n    documentItems: documentItems$ | async,\n    noResultsMessage: noResultsMessage$ | async,\n    searchFields: searchFields$ | async,\n    schema: schema$ | async,\n    showAssignModal: showAssignModal$ | async,\n    selectedDocumentIds: selectedDocumentIds$ | async,\n    loaded:\n      !loadingFields &&\n      !loadingPagination &&\n      !loadingSearchFields &&\n      !loadingAssigneeFilter &&\n      !loadingDocumentItems\n  } as obs\"\n>\n  <div class=\"main-content pt-0\">\n    <div class=\"container-fluid\">\n      <div class=\"col-12 px-0 mb-5\">\n        <valtimo-dossier-list-actions\n          [loading]=\"!obs.loaded\"\n          (formFlowComplete)=\"forceRefresh()\"\n        ></valtimo-dossier-list-actions>\n        <ng-container *ngTemplateOutlet=\"searchFields; context: {obs: obs}\"></ng-container>\n\n        <ng-container *ngIf=\"obs.loaded; else loading\">\n          <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n\n  <ng-container *ngTemplateOutlet=\"bulkAssignModal; context: {obs: obs}\"></ng-container>\n\n  <ng-container *ngTemplateOutlet=\"changePageModal\"></ng-container>\n\n  <ng-container *ngTemplateOutlet=\"changeTabModal\"></ng-container>\n</ng-container>\n\n<ng-template #searchFields let-obs=\"obs\">\n  <div class=\"mb-3\">\n    <valtimo-search-fields\n      [searchFields]=\"obs.searchFields\"\n      (doSearch)=\"search($event)\"\n      [documentDefinitionName]=\"documentDefinitionName$ | async\"\n      [defaultValues]=\"searchFieldValues$ | async\"\n      [inputDisabled]=\"!obs.loaded\"\n    ></valtimo-search-fields>\n  </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n  <valtimo-carbon-list\n    [fields]=\"obs.fields\"\n    [header]=\"false\"\n    [initialSortState]=\"pagination.sort\"\n    [items]=\"obs.documentItems\"\n    [pagination]=\"pagination\"\n    paginationIdentifier=\"dossierList\"\n    [showSelectionColumn]=\"canHaveAssignee\"\n    [tableTranslations]=\"tableTranslations\"\n    (paginationClicked)=\"pageChange($event)\"\n    (paginationSet)=\"pageSizeChange($event)\"\n    (rowClicked)=\"rowClick($event)\"\n    (sortChanged)=\"sortChanged($event)\"\n  >\n    <ng-container carbonToolbarActions>\n      <button cdsButton=\"primary\" (click)=\"showAssignModal()\">\n        {{ 'dossier.bulkAssign.assign' | translate }}\n      </button>\n    </ng-container>\n\n    <div carbonToolbarContent>\n      <ng-container *ngTemplateOutlet=\"dossierListActions\"></ng-container>\n    </div>\n\n    <valtimo-no-results\n      [action]=\"obs.noResultsMessage.isSearchResult ? null : dossierListActions\"\n      [description]=\"obs.noResultsMessage.description | translate\"\n      [title]=\"obs.noResultsMessage.title | translate\"\n    ></valtimo-no-results>\n\n    <div tabs *ngIf=\"canHaveAssignee\">\n      <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n    </div>\n  </valtimo-carbon-list>\n</ng-template>\n\n<ng-template #tabs>\n  <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n    <cds-tabs\n      *ngIf=\"!visibleDossierTabs; else configuredTabs\"\n      type=\"contained\"\n      data-carbon-theme=\"g10\"\n      class=\"dossier-list-tabs\"\n    >\n      <cds-tab\n        *ngFor=\"let tab of defaultTabs; trackBy: trackByIndex\"\n        [active]=\"assigneeFilter === tab\"\n        heading=\"{{ 'dossier.tabs.' + tab | translate }}\"\n        [id]=\"tab\"\n        (selected)=\"tabChange(tab)\"\n      ></cds-tab>\n    </cds-tabs>\n  </ng-container>\n</ng-template>\n\n<ng-template #configuredTabs>\n  <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n    <cds-tabs type=\"contained\" class=\"dossier-list-tabs\">\n      <cds-tab\n        *ngFor=\"let tab of visibleDossierTabs; trackBy: trackByIndex\"\n        [active]=\"assigneeFilter === tab\"\n        heading=\"{{ 'dossier.tabs.' + tab | translate }}\"\n        [id]=\"tab\"\n        (selected)=\"tabChange(tab)\"\n      ></cds-tab>\n    </cds-tabs>\n  </ng-container>\n</ng-template>\n\n<ng-template #loading\n  ><valtimo-carbon-list [loading]=\"true\">\n    <div tabs *ngIf=\"canHaveAssignee\">\n      <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n    </div> </valtimo-carbon-list\n></ng-template>\n\n<ng-template #bulkAssignModal let-obs=\"obs\">\n  <valtimo-dossier-bulk-assign-modal\n    [documentIds]=\"obs.selectedDocumentIds\"\n    [open]=\"obs.showAssignModal\"\n    (closeEvent)=\"onCloseEvent($event, obs.selectedDocumentIds)\"\n  ></valtimo-dossier-bulk-assign-modal>\n</ng-template>\n\n<ng-template #changePageModal>\n  <valtimo-confirmation-modal\n    confirmButtonTextTranslationKey=\"dossier.changePageModal.confirm\"\n    contentTranslationKey=\"dossier.changePageModal.content\"\n    [outputOnConfirm]=\"paginationChange$ | async\"\n    [showModalSubject$]=\"showChangePageModal$\"\n    titleTranslationKey=\"dossier.changePageModal.title\"\n    (confirmEvent)=\"onChangePageConfirm($event)\"\n  ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #changeTabModal>\n  <valtimo-confirmation-modal\n    confirmButtonTextTranslationKey=\"dossier.changeTabModal.confirm\"\n    contentTranslationKey=\"dossier.changeTabModal.content\"\n    [outputOnConfirm]=\"tabChange$ | async\"\n    [showModalSubject$]=\"showChangeTabModal$\"\n    titleTranslationKey=\"dossier.changeTabModal.title\"\n    (cancelEvent)=\"onChangeTabCancel()\"\n    (confirmEvent)=\"onChangeTabConfirm($event)\"\n  ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #dossierListActions>\n  <button\n    cdsButton=\"primary\"\n    [disabled]=\"listActionsComponent?.disableStartDossierButton$ | async\"\n    (click)=\"startDossier()\"\n  >\n    {{ 'Start Dossier' | translate }}\n\n    <svg cdsIcon=\"add\" size=\"16\" class=\"cds--btn__icon\"></svg>\n  </button>\n</ng-template>\n"]}
|