@valtimo/dossier 10.5.1 → 10.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.
- package/esm2020/lib/components/note-modal/note-modal.component.mjs +30 -12
- package/esm2020/lib/dossier-assign-user/dossier-assign-user.component.mjs +8 -5
- package/esm2020/lib/dossier-detail/dossier-detail.component.mjs +19 -6
- package/esm2020/lib/dossier-detail/tab/audit/audit.component.mjs +4 -4
- package/esm2020/lib/dossier-detail/tab/contact-moments/contact-moments.component.mjs +4 -4
- package/esm2020/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.mjs +18 -14
- package/esm2020/lib/dossier-detail/tab/documents/documents.component.mjs +4 -4
- package/esm2020/lib/dossier-detail/tab/notes/notes.component.mjs +63 -12
- package/esm2020/lib/dossier-detail/tab/object-type/object-type.component.mjs +4 -4
- package/esm2020/lib/dossier-detail/tab/progress/progress.component.mjs +4 -4
- package/esm2020/lib/dossier-detail/tab/s3-documents/s3-documents.component.mjs +4 -4
- package/esm2020/lib/dossier-detail/tab/summary/summary.component.mjs +4 -4
- package/esm2020/lib/dossier-detail/tab/zaakobjecten/zaakobjecten.component.mjs +4 -4
- package/esm2020/lib/dossier-list/dossier-list.component.mjs +165 -287
- package/esm2020/lib/dossier-list-actions/dossier-list-actions.component.mjs +86 -0
- package/esm2020/lib/dossier-process-start-modal/dossier-process-start-modal.component.mjs +114 -46
- package/esm2020/lib/dossier-routing.module.mjs +12 -8
- package/esm2020/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +108 -51
- package/esm2020/lib/dossier-update/dossier-update.component.mjs +4 -4
- package/esm2020/lib/dossier.module.mjs +21 -8
- package/esm2020/lib/dossier.service.mjs +4 -4
- package/esm2020/lib/models/dossier-parameters.model.mjs +1 -1
- package/esm2020/lib/models/notes.model.mjs +1 -1
- package/esm2020/lib/services/dossier-column.service.mjs +25 -10
- package/esm2020/lib/services/dossier-list-assignee.service.mjs +82 -0
- package/esm2020/lib/services/dossier-list-pagination.service.mjs +116 -0
- package/esm2020/lib/services/dossier-list-search.service.mjs +66 -0
- package/esm2020/lib/services/dossier-list.service.mjs +56 -0
- package/esm2020/lib/services/dossier-parameter.service.mjs +74 -34
- package/esm2020/lib/services/file-sort.service.mjs +4 -4
- package/esm2020/lib/services/index.mjs +5 -1
- package/esm2020/lib/services/notes.service.mjs +10 -4
- package/esm2020/lib/services/zaakobjecten.service.mjs +4 -4
- package/esm2020/lib/tab.service.mjs +4 -4
- package/fesm2015/valtimo-dossier.mjs +1074 -529
- package/fesm2015/valtimo-dossier.mjs.map +1 -1
- package/fesm2020/valtimo-dossier.mjs +1083 -542
- package/fesm2020/valtimo-dossier.mjs.map +1 -1
- package/lib/components/note-modal/note-modal.component.d.ts +6 -2
- package/lib/components/note-modal/note-modal.component.d.ts.map +1 -1
- package/lib/dossier-assign-user/dossier-assign-user.component.d.ts +2 -1
- package/lib/dossier-assign-user/dossier-assign-user.component.d.ts.map +1 -1
- package/lib/dossier-detail/dossier-detail.component.d.ts +8 -3
- package/lib/dossier-detail/dossier-detail.component.d.ts.map +1 -1
- package/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.d.ts +3 -6
- package/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -1
- package/lib/dossier-detail/tab/notes/notes.component.d.ts +10 -1
- package/lib/dossier-detail/tab/notes/notes.component.d.ts.map +1 -1
- package/lib/dossier-detail/tab/summary/summary.component.d.ts +9 -9
- package/lib/dossier-detail/tab/summary/summary.component.d.ts.map +1 -1
- package/lib/dossier-list/dossier-list.component.d.ts +47 -56
- package/lib/dossier-list/dossier-list.component.d.ts.map +1 -1
- package/lib/dossier-list-actions/dossier-list-actions.component.d.ts +28 -0
- package/lib/dossier-list-actions/dossier-list-actions.component.d.ts.map +1 -0
- package/lib/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +14 -5
- package/lib/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
- package/lib/dossier-routing.module.d.ts.map +1 -1
- package/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts +12 -5
- package/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -1
- package/lib/dossier.module.d.ts +31 -29
- package/lib/dossier.module.d.ts.map +1 -1
- package/lib/models/dossier-parameters.model.d.ts +1 -0
- package/lib/models/dossier-parameters.model.d.ts.map +1 -1
- package/lib/models/notes.model.d.ts +4 -1
- package/lib/models/notes.model.d.ts.map +1 -1
- package/lib/services/dossier-column.service.d.ts +5 -1
- package/lib/services/dossier-column.service.d.ts.map +1 -1
- package/lib/services/dossier-list-assignee.service.d.ts +27 -0
- package/lib/services/dossier-list-assignee.service.d.ts.map +1 -0
- package/lib/services/dossier-list-pagination.service.d.ts +30 -0
- package/lib/services/dossier-list-pagination.service.d.ts.map +1 -0
- package/lib/services/dossier-list-search.service.d.ts +22 -0
- package/lib/services/dossier-list-search.service.d.ts.map +1 -0
- package/lib/services/dossier-list.service.d.ts +17 -0
- package/lib/services/dossier-list.service.d.ts.map +1 -0
- package/lib/services/dossier-parameter.service.d.ts +9 -1
- package/lib/services/dossier-parameter.service.d.ts.map +1 -1
- package/lib/services/index.d.ts +4 -0
- package/lib/services/index.d.ts.map +1 -1
- package/lib/services/notes.service.d.ts +3 -1
- package/lib/services/notes.service.d.ts.map +1 -1
- package/package.json +6 -6
|
@@ -13,334 +13,212 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import { Component
|
|
16
|
+
import { Component } from '@angular/core';
|
|
17
|
+
import { BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, switchMap, take, tap, } from 'rxjs';
|
|
18
|
+
import { DossierColumnService, DossierListAssigneeService, DossierListPaginationService, DossierListSearchService, DossierListService, DossierParameterService, } from '../services';
|
|
17
19
|
import { AdvancedDocumentSearchRequestImpl, } from '@valtimo/document';
|
|
18
|
-
import moment from 'moment';
|
|
19
|
-
import { BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, of, Subject, switchMap, take, tap, } from 'rxjs';
|
|
20
20
|
import { DefaultTabs } from '../dossier-detail-tab-enum';
|
|
21
|
-
import { DossierParameterService } from '../services';
|
|
22
21
|
import * as i0 from "@angular/core";
|
|
23
22
|
import * as i1 from "@angular/router";
|
|
24
|
-
import * as i2 from "@
|
|
25
|
-
import * as i3 from "
|
|
26
|
-
import * as i4 from "
|
|
27
|
-
import * as i5 from "
|
|
28
|
-
import * as i6 from "@valtimo/
|
|
29
|
-
import * as i7 from "
|
|
30
|
-
import * as i8 from "@
|
|
31
|
-
import * as i9 from "
|
|
32
|
-
import * as i10 from "@ng-bootstrap/ng-bootstrap";
|
|
33
|
-
import * as i11 from "../dossier-process-start-modal/dossier-process-start-modal.component";
|
|
34
|
-
moment.locale(localStorage.getItem('langKey') || '');
|
|
23
|
+
import * as i2 from "@ngx-translate/core";
|
|
24
|
+
import * as i3 from "../services";
|
|
25
|
+
import * as i4 from "@valtimo/document";
|
|
26
|
+
import * as i5 from "@valtimo/config";
|
|
27
|
+
import * as i6 from "@valtimo/components";
|
|
28
|
+
import * as i7 from "@angular/common";
|
|
29
|
+
import * as i8 from "@ng-bootstrap/ng-bootstrap";
|
|
30
|
+
import * as i9 from "../dossier-list-actions/dossier-list-actions.component";
|
|
35
31
|
export class DossierListComponent {
|
|
36
|
-
constructor(route,
|
|
32
|
+
constructor(route, translateService, listService, columnService, assigneeService, paginationService, searchService, parameterService, documentService, router, configService, pageTitleService, breadcrumbService) {
|
|
37
33
|
this.route = route;
|
|
38
|
-
this.router = router;
|
|
39
|
-
this.documentService = documentService;
|
|
40
34
|
this.translateService = translateService;
|
|
41
|
-
this.
|
|
42
|
-
this.
|
|
35
|
+
this.listService = listService;
|
|
36
|
+
this.columnService = columnService;
|
|
37
|
+
this.assigneeService = assigneeService;
|
|
38
|
+
this.paginationService = paginationService;
|
|
39
|
+
this.searchService = searchService;
|
|
40
|
+
this.parameterService = parameterService;
|
|
41
|
+
this.documentService = documentService;
|
|
42
|
+
this.router = router;
|
|
43
43
|
this.configService = configService;
|
|
44
|
-
this.
|
|
45
|
-
this.
|
|
46
|
-
this.
|
|
47
|
-
this.
|
|
48
|
-
this.
|
|
49
|
-
this.
|
|
50
|
-
this.
|
|
51
|
-
this.
|
|
52
|
-
this.
|
|
53
|
-
|
|
54
|
-
this.resetPagination(documentDefinitionName);
|
|
44
|
+
this.pageTitleService = pageTitleService;
|
|
45
|
+
this.breadcrumbService = breadcrumbService;
|
|
46
|
+
this.loadingFields = true;
|
|
47
|
+
this.loadingPagination = true;
|
|
48
|
+
this.loadingSearchFields = true;
|
|
49
|
+
this.loadingAssigneeFilter = true;
|
|
50
|
+
this.loadingDocumentItems = true;
|
|
51
|
+
this.visibleDossierTabs = null;
|
|
52
|
+
this.searchFields$ = this.searchService.documentSearchFields$.pipe(tap(searchFields => {
|
|
53
|
+
this.loadingSearchFields = false;
|
|
55
54
|
}));
|
|
56
|
-
this.
|
|
57
|
-
this.
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
this.
|
|
63
|
-
|
|
55
|
+
this.documentDefinitionName$ = this.listService.documentDefinitionName$;
|
|
56
|
+
this.schema$ = this.listService.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.documentService.getDocumentDefinition(documentDefinitionName)), map(documentDefinition => documentDefinition?.schema), tap(schema => {
|
|
57
|
+
if (schema?.title) {
|
|
58
|
+
this.pageTitleService.setCustomPageTitle(schema?.title, true);
|
|
59
|
+
}
|
|
60
|
+
}));
|
|
61
|
+
this.searchFieldValues$ = this.parameterService.searchFieldValues$;
|
|
62
|
+
this.assigneeFilter$ = this.assigneeService.assigneeFilter$;
|
|
63
|
+
this._pagination$ = this.paginationService.pagination$.pipe(tap(pagination => {
|
|
64
|
+
this.pagination = pagination;
|
|
65
|
+
this.loadingPagination = false;
|
|
64
66
|
}));
|
|
65
|
-
this.
|
|
66
|
-
this.
|
|
67
|
-
this.
|
|
68
|
-
this.
|
|
69
|
-
|
|
67
|
+
this._hasEnvColumnConfig$ = this.listService.hasEnvColumnConfig$;
|
|
68
|
+
this._hasApiColumnConfig$ = new BehaviorSubject(false);
|
|
69
|
+
this._canHaveAssignee$ = this.assigneeService.canHaveAssignee$;
|
|
70
|
+
this._searchSwitch$ = this.searchService.searchSwitch$;
|
|
71
|
+
this._columns$ = this.listService.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.columnService.getDefinitionColumns(documentDefinitionName)), map(res => {
|
|
72
|
+
this._hasApiColumnConfig$.next(res.hasApiConfig);
|
|
70
73
|
return res.columns;
|
|
74
|
+
}), tap(columns => {
|
|
75
|
+
this.listService.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
|
|
76
|
+
this.paginationService.setPagination(documentDefinitionName, columns);
|
|
77
|
+
});
|
|
71
78
|
}));
|
|
72
|
-
this.ASSIGNEE_KEY = 'assigneeFullName';
|
|
73
79
|
this.fields$ = combineLatest([
|
|
74
|
-
this.
|
|
75
|
-
this.
|
|
76
|
-
this.
|
|
80
|
+
this._canHaveAssignee$,
|
|
81
|
+
this._columns$,
|
|
82
|
+
this._hasEnvColumnConfig$,
|
|
77
83
|
this.translateService.stream('key'),
|
|
78
|
-
]).pipe(
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
84
|
+
]).pipe(tap(([canHaveAssignee]) => {
|
|
85
|
+
this.canHaveAssignee = canHaveAssignee;
|
|
86
|
+
}), map(([canHaveAssignee, columns, hasEnvConfig]) => {
|
|
87
|
+
const filteredAssigneeColumns = this.assigneeService.filterAssigneeColumns(columns, canHaveAssignee);
|
|
88
|
+
const listFields = this.columnService.mapDefinitionColumnsToListFields(filteredAssigneeColumns, hasEnvConfig);
|
|
89
|
+
const fieldsToReturn = this.assigneeService.addAssigneeListField(columns, listFields, canHaveAssignee);
|
|
90
|
+
return fieldsToReturn;
|
|
91
|
+
}), tap(listFields => {
|
|
92
|
+
const defaultListField = listFields.find(field => field.default);
|
|
93
|
+
// set default sort state if no pagination query parameters for sorting are available
|
|
94
|
+
this.parameterService.queryPaginationParams$
|
|
95
|
+
.pipe(take(1))
|
|
96
|
+
.subscribe(queryPaginationParams => {
|
|
97
|
+
if (defaultListField && !queryPaginationParams?.sort?.isSorting) {
|
|
98
|
+
const sortDirection = typeof defaultListField.default === 'string' ? defaultListField.default : 'DESC';
|
|
99
|
+
this.paginationService.sortChanged({
|
|
100
|
+
isSorting: true,
|
|
101
|
+
state: { name: defaultListField.key, direction: sortDirection },
|
|
102
|
+
});
|
|
97
103
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
label: this.translateService.instant(`fieldLabels.${this.ASSIGNEE_KEY}`),
|
|
106
|
-
sortable: true,
|
|
107
|
-
viewType: 'string',
|
|
108
|
-
},
|
|
109
|
-
]
|
|
110
|
-
: []),
|
|
111
|
-
]));
|
|
112
|
-
this.DEFAULT_PAGINATION = {
|
|
113
|
-
collectionSize: 0,
|
|
114
|
-
page: 1,
|
|
115
|
-
size: 10,
|
|
116
|
-
maxPaginationItemSize: 5,
|
|
117
|
-
sort: undefined,
|
|
118
|
-
};
|
|
119
|
-
this.pagination$ = new BehaviorSubject(undefined);
|
|
120
|
-
this.paginationCopy$ = this.pagination$.pipe(map(pagination => pagination && JSON.parse(JSON.stringify(pagination))), tap(pagination => this.dossierParameterService.setPaginationParameters(pagination)));
|
|
121
|
-
this.documentSearchRequest$ = combineLatest([this.pagination$, this.documentDefinitionName$]).pipe(filter(([pagination]) => !!pagination), map(([pagination, documentDefinitionName]) => new AdvancedDocumentSearchRequestImpl(documentDefinitionName, pagination.page - 1, pagination.size, pagination.sort)));
|
|
122
|
-
this.searchFieldValues$ = new BehaviorSubject({});
|
|
123
|
-
this.assigneeFilter$ = new BehaviorSubject(this.defaultAssigneeFilter);
|
|
124
|
-
this.documentsRequest$ = combineLatest([
|
|
125
|
-
this.documentSearchRequest$,
|
|
104
|
+
});
|
|
105
|
+
}), tap(() => {
|
|
106
|
+
this.loadingFields = false;
|
|
107
|
+
}));
|
|
108
|
+
this._documentSearchRequest$ = combineLatest([this._pagination$, this.listService.documentDefinitionName$]).pipe(filter(([pagination]) => !!pagination), map(([pagination, documentDefinitionName]) => new AdvancedDocumentSearchRequestImpl(documentDefinitionName, pagination.page - 1, pagination.size, pagination.sort)));
|
|
109
|
+
this._documentsRequest$ = combineLatest([
|
|
110
|
+
this._documentSearchRequest$,
|
|
126
111
|
this.searchFieldValues$,
|
|
127
112
|
this.assigneeFilter$,
|
|
128
|
-
this.
|
|
129
|
-
this.
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
113
|
+
this._hasEnvColumnConfig$,
|
|
114
|
+
this._hasApiColumnConfig$,
|
|
115
|
+
this._searchSwitch$,
|
|
116
|
+
]).pipe(distinctUntilChanged(([prevSearchRequest, prevSearchValues, prevAssigneeFilter, prevHasEnvColumnConfig, prevHasApiColumnConfig, prevSearchSwitch,], [currSearchRequest, currSearchValues, currAssigneeFilter, currHasEnvColumnConfig, currHasApiColumnConfig, currSearchSwitch,]) => JSON.stringify({ ...prevSearchRequest, ...prevSearchValues }) +
|
|
117
|
+
prevAssigneeFilter +
|
|
118
|
+
prevSearchSwitch ===
|
|
119
|
+
JSON.stringify({ ...currSearchRequest, ...currSearchValues }) +
|
|
120
|
+
currAssigneeFilter +
|
|
121
|
+
currSearchSwitch), switchMap(([documentSearchRequest, searchValues, assigneeFilter, hasEnvColumnConfig, hasApiColumnConfig,]) => {
|
|
137
122
|
if ((Object.keys(searchValues) || []).length > 0) {
|
|
138
123
|
return hasEnvColumnConfig || !hasApiColumnConfig
|
|
139
|
-
? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.mapSearchValuesToFilters(searchValues))
|
|
140
|
-
: this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.mapSearchValuesToFilters(searchValues));
|
|
141
|
-
}
|
|
142
|
-
else {
|
|
143
|
-
return hasEnvColumnConfig || !hasApiColumnConfig
|
|
144
|
-
? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter)
|
|
145
|
-
: this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter);
|
|
124
|
+
? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.searchService.mapSearchValuesToFilters(searchValues))
|
|
125
|
+
: this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.searchService.mapSearchValuesToFilters(searchValues));
|
|
146
126
|
}
|
|
127
|
+
return hasEnvColumnConfig || !hasApiColumnConfig
|
|
128
|
+
? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter)
|
|
129
|
+
: this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter);
|
|
147
130
|
}), tap(documents => {
|
|
148
|
-
this.setCollectionSize(documents);
|
|
149
|
-
this.checkPage(documents);
|
|
131
|
+
this.paginationService.setCollectionSize(documents);
|
|
132
|
+
this.paginationService.checkPage(documents);
|
|
150
133
|
}));
|
|
151
134
|
this.documentItems$ = combineLatest([
|
|
152
|
-
this.
|
|
153
|
-
this.
|
|
154
|
-
this.
|
|
155
|
-
]).pipe(map(([documents, hasEnvColumnConfig, hasApiColumnConfig]) => {
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
const { content, ...others } = document;
|
|
160
|
-
return { ...content, ...others };
|
|
161
|
-
});
|
|
162
|
-
}
|
|
163
|
-
else {
|
|
164
|
-
const docsToMap = documents;
|
|
165
|
-
return docsToMap.content.reduce((acc, curr) => {
|
|
166
|
-
const propsObject = { id: curr.id };
|
|
167
|
-
curr.items.forEach(item => {
|
|
168
|
-
propsObject[item.key] = item.value;
|
|
169
|
-
});
|
|
170
|
-
return [...acc, propsObject];
|
|
171
|
-
}, []);
|
|
172
|
-
}
|
|
173
|
-
}), tap(() => this.loading$.next(false)));
|
|
174
|
-
this.setSearchFieldValuesSubject$ = new Subject();
|
|
175
|
-
this.dossierVisibleTabs = this.configService.config?.visibleDossierListTabs || null;
|
|
135
|
+
this._documentsRequest$,
|
|
136
|
+
this._hasEnvColumnConfig$,
|
|
137
|
+
this._hasApiColumnConfig$,
|
|
138
|
+
]).pipe(map(([documents, hasEnvColumnConfig, hasApiColumnConfig]) => this.listService.mapDocuments(documents, hasEnvColumnConfig, hasApiColumnConfig)), tap(() => {
|
|
139
|
+
this.loadingAssigneeFilter = false;
|
|
140
|
+
this.loadingDocumentItems = false;
|
|
141
|
+
}));
|
|
176
142
|
}
|
|
177
143
|
ngOnInit() {
|
|
178
|
-
this.
|
|
179
|
-
this.
|
|
180
|
-
}
|
|
181
|
-
pageChange(newPage) {
|
|
182
|
-
this.pagination$.pipe(take(1)).subscribe(pagination => {
|
|
183
|
-
if (pagination && pagination.page !== newPage) {
|
|
184
|
-
this.logger.debug(`Page change: ${newPage}`);
|
|
185
|
-
this.pagination$.next({ ...pagination, page: newPage });
|
|
186
|
-
}
|
|
187
|
-
});
|
|
144
|
+
this.setVisibleTabs();
|
|
145
|
+
this.openDocumentDefinitionNameSubscription();
|
|
188
146
|
}
|
|
189
|
-
|
|
190
|
-
this.
|
|
191
|
-
|
|
192
|
-
const amountOfAvailablePages = Math.ceil(pagination.collectionSize / newPageSize);
|
|
193
|
-
const newPage = amountOfAvailablePages < pagination.page ? amountOfAvailablePages : pagination.page;
|
|
194
|
-
this.logger.debug(`Page size change. New Page: ${newPage} New page size: ${newPageSize}`);
|
|
195
|
-
this.pagination$.next({ ...pagination, size: newPageSize, page: newPage });
|
|
196
|
-
}
|
|
197
|
-
});
|
|
147
|
+
ngOnDestroy() {
|
|
148
|
+
this._documentDefinitionNameSubscription?.unsubscribe();
|
|
149
|
+
this.pageTitleService.enableReset();
|
|
198
150
|
}
|
|
199
|
-
|
|
200
|
-
this.
|
|
201
|
-
if (pagination && JSON.stringify(pagination.sort) !== JSON.stringify(newSortState)) {
|
|
202
|
-
this.logger.debug(`Sort state change: ${JSON.stringify(newSortState)}`);
|
|
203
|
-
this.pagination$.next({ ...pagination, sort: newSortState });
|
|
204
|
-
}
|
|
205
|
-
});
|
|
151
|
+
search(searchFieldValues) {
|
|
152
|
+
this.searchService.search(searchFieldValues);
|
|
206
153
|
}
|
|
207
154
|
rowClick(document) {
|
|
208
|
-
this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
|
|
155
|
+
this.listService.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
|
|
156
|
+
this.breadcrumbService.cacheQueryParams(`/dossiers/${documentDefinitionName}`, this.route.snapshot.queryParams);
|
|
209
157
|
this.router.navigate([
|
|
210
158
|
`/dossiers/${documentDefinitionName}/document/${document.id}/${DefaultTabs.summary}`,
|
|
211
159
|
]);
|
|
212
160
|
});
|
|
213
161
|
}
|
|
214
|
-
|
|
215
|
-
this.
|
|
216
|
-
.pipe(take(1))
|
|
217
|
-
.subscribe(associatedProcessDocumentDefinitions => {
|
|
218
|
-
if (associatedProcessDocumentDefinitions.length > 1) {
|
|
219
|
-
$('#startProcess').modal('show');
|
|
220
|
-
}
|
|
221
|
-
else {
|
|
222
|
-
this.selectedProcessDocumentDefinition = associatedProcessDocumentDefinitions[0];
|
|
223
|
-
this.showStartProcessModal();
|
|
224
|
-
}
|
|
225
|
-
});
|
|
162
|
+
pageChange(newPage) {
|
|
163
|
+
this.paginationService.pageChange(newPage);
|
|
226
164
|
}
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
if (!this.modalListenerAdded) {
|
|
230
|
-
modal.on('hidden.bs.modal', this.showStartProcessModal.bind(this));
|
|
231
|
-
this.modalListenerAdded = true;
|
|
232
|
-
}
|
|
233
|
-
this.selectedProcessDocumentDefinition = processDocumentDefinition;
|
|
234
|
-
modal.modal('hide');
|
|
165
|
+
pageSizeChange(newPageSize) {
|
|
166
|
+
this.paginationService.pageSizeChange(newPageSize);
|
|
235
167
|
}
|
|
236
|
-
|
|
237
|
-
this.
|
|
238
|
-
this.dossierParameterService.setSearchParameters(searchFieldValues);
|
|
168
|
+
sortChanged(newSortState) {
|
|
169
|
+
this.paginationService.sortChanged(newSortState);
|
|
239
170
|
}
|
|
240
171
|
tabChange(tab) {
|
|
241
|
-
this.
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
return filters;
|
|
261
|
-
}
|
|
262
|
-
resetPagination(documentDefinitionName) {
|
|
263
|
-
this.settingPaginationForDocName$.pipe(take(1)).subscribe(settingPaginationForDocName => {
|
|
264
|
-
if (documentDefinitionName !== settingPaginationForDocName) {
|
|
265
|
-
this.pagination$.next(undefined);
|
|
266
|
-
this.logger.debug('clear pagination');
|
|
267
|
-
this.settingPaginationForDocName$.next(documentDefinitionName);
|
|
268
|
-
this.setPagination(documentDefinitionName);
|
|
269
|
-
}
|
|
270
|
-
});
|
|
271
|
-
}
|
|
272
|
-
setPagination(documentDefinitionName) {
|
|
273
|
-
combineLatest([
|
|
274
|
-
this.hasStoredSearchRequest$,
|
|
275
|
-
this.storedSearchRequestKey$,
|
|
276
|
-
this.columns$,
|
|
277
|
-
this.dossierParameterService.queryPaginationParams$,
|
|
278
|
-
])
|
|
279
|
-
.pipe(take(1))
|
|
280
|
-
.subscribe(([hasStoredSearchRequest, storedSearchRequestKey, columns, queryPaginationParams]) => {
|
|
281
|
-
const defaultPagination = this.getDefaultPagination(columns);
|
|
282
|
-
const storedPagination = this.getStoredPagination(hasStoredSearchRequest, storedSearchRequestKey);
|
|
283
|
-
const paginationToUse = queryPaginationParams || storedPagination || defaultPagination;
|
|
284
|
-
this.logger.debug(`Set pagination: ${JSON.stringify(paginationToUse)}`);
|
|
285
|
-
this.pagination$.next(paginationToUse);
|
|
286
|
-
});
|
|
287
|
-
}
|
|
288
|
-
getDefaultPagination(columns) {
|
|
289
|
-
const defaultSortState = this.dossierService.getInitialSortState(columns);
|
|
290
|
-
return {
|
|
291
|
-
...this.DEFAULT_PAGINATION,
|
|
292
|
-
sort: defaultSortState,
|
|
293
|
-
};
|
|
294
|
-
}
|
|
295
|
-
getStoredPagination(hasStoredSearchRequest, storedSearchRequestKey) {
|
|
296
|
-
const storedSearchRequest = hasStoredSearchRequest && JSON.parse(localStorage.getItem(storedSearchRequestKey));
|
|
297
|
-
return (storedSearchRequest && {
|
|
298
|
-
...this.DEFAULT_PAGINATION,
|
|
299
|
-
sort: storedSearchRequest.sort,
|
|
300
|
-
page: storedSearchRequest.page + 1,
|
|
301
|
-
size: storedSearchRequest.size,
|
|
302
|
-
});
|
|
303
|
-
}
|
|
304
|
-
setCollectionSize(documents) {
|
|
305
|
-
this.pagination$.pipe(take(1)).subscribe(pagination => {
|
|
306
|
-
if (pagination.collectionSize !== documents.totalElements) {
|
|
307
|
-
this.pagination$.next({ ...pagination, collectionSize: documents.totalElements });
|
|
308
|
-
}
|
|
172
|
+
this.paginationService.setPage(1);
|
|
173
|
+
this.assigneeService.setAssigneeFilter(tab.nextId.toUpperCase());
|
|
174
|
+
}
|
|
175
|
+
refresh() {
|
|
176
|
+
this.searchService.refresh();
|
|
177
|
+
}
|
|
178
|
+
openDocumentDefinitionNameSubscription() {
|
|
179
|
+
this._documentDefinitionNameSubscription = this.route.params
|
|
180
|
+
.pipe(map(params => params?.documentDefinitionName), filter(docDefName => !!docDefName), distinctUntilChanged())
|
|
181
|
+
.subscribe(documentDefinitonName => {
|
|
182
|
+
if (this._previousDocumentDefinitionName) {
|
|
183
|
+
this.parameterService.clearParameters();
|
|
184
|
+
this.parameterService.clearSearchFieldValues();
|
|
185
|
+
}
|
|
186
|
+
this._previousDocumentDefinitionName = documentDefinitonName;
|
|
187
|
+
this.setLoading();
|
|
188
|
+
this.paginationService.clearPagination();
|
|
189
|
+
this.assigneeService.resetAssigneeFilter();
|
|
190
|
+
this.listService.setDocumentDefinitionName(documentDefinitonName);
|
|
309
191
|
});
|
|
310
192
|
}
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
193
|
+
setLoading() {
|
|
194
|
+
this.loadingFields = true;
|
|
195
|
+
this.loadingPagination = true;
|
|
196
|
+
this.loadingSearchFields = true;
|
|
197
|
+
this.loadingAssigneeFilter = true;
|
|
198
|
+
this.loadingDocumentItems = true;
|
|
316
199
|
}
|
|
317
|
-
|
|
318
|
-
this.
|
|
319
|
-
const amountOfItems = documents.totalElements;
|
|
320
|
-
const amountOfPages = Math.ceil(amountOfItems / pagination.size);
|
|
321
|
-
const currentPage = pagination.page;
|
|
322
|
-
if (currentPage > amountOfPages) {
|
|
323
|
-
this.pagination$.next({ ...pagination, page: amountOfPages });
|
|
324
|
-
}
|
|
325
|
-
});
|
|
326
|
-
}
|
|
327
|
-
setSearchFieldParametersInComponent() {
|
|
328
|
-
this.dossierParameterService.querySearchParams$.pipe(take(1)).subscribe(values => {
|
|
329
|
-
if (Object.keys(values || {}).length > 0) {
|
|
330
|
-
setTimeout(() => {
|
|
331
|
-
this.setSearchFieldValuesSubject$.next(values);
|
|
332
|
-
});
|
|
333
|
-
}
|
|
334
|
-
});
|
|
200
|
+
setVisibleTabs() {
|
|
201
|
+
this.visibleDossierTabs = this.configService.config?.visibleDossierListTabs || null;
|
|
335
202
|
}
|
|
336
203
|
}
|
|
337
|
-
DossierListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.
|
|
338
|
-
DossierListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.
|
|
339
|
-
|
|
204
|
+
DossierListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DossierListComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.TranslateService }, { token: i3.DossierListService }, { token: i3.DossierColumnService }, { token: i3.DossierListAssigneeService }, { token: i3.DossierListPaginationService }, { token: i3.DossierListSearchService }, { token: i3.DossierParameterService }, { token: i4.DocumentService }, { token: i1.Router }, { token: i5.ConfigService }, { token: i6.PageTitleService }, { token: i6.BreadcrumbService }], target: i0.ɵɵFactoryTarget.Component });
|
|
205
|
+
DossierListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: DossierListComponent, selector: "valtimo-dossier-list", providers: [
|
|
206
|
+
DossierListService,
|
|
207
|
+
DossierColumnService,
|
|
208
|
+
DossierListAssigneeService,
|
|
209
|
+
DossierParameterService,
|
|
210
|
+
DossierListPaginationService,
|
|
211
|
+
DossierListSearchService,
|
|
212
|
+
], 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 searchFields: searchFields$ | async,\n schema: schema$ | 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)=\"refresh()\"\n ></valtimo-dossier-list-actions>\n <ng-container *ngIf=\"obs.loaded; else loading\">\n <ng-container *ngTemplateOutlet=\"searchFields; context: {obs: obs}\"></ng-container>\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n </ng-container>\n </div>\n </div>\n </div>\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 ></valtimo-search-fields>\n </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n <valtimo-widget>\n <valtimo-list\n [items]=\"obs.documentItems\"\n [fields]=\"obs.fields\"\n (rowClicked)=\"rowClick($event)\"\n [pagination]=\"pagination\"\n [viewMode]=\"true\"\n [header]=\"true\"\n paginationIdentifier=\"dossierList\"\n (paginationClicked)=\"pageChange($event)\"\n (paginationSet)=\"pageSizeChange($event)\"\n [initialSortState]=\"pagination.sort\"\n (sortChanged)=\"sortChanged($event)\"\n >\n <div header>\n <h3 class=\"list-header-title\">\n <sup class=\"ml-1 badge badge-pill badge-primary\">{{\n pagination?.collectionSize || 0\n }}</sup>\n </h3>\n </div>\n <div tabs *ngIf=\"canHaveAssignee\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n </div>\n </valtimo-list>\n </valtimo-widget>\n</ng-template>\n\n<ng-template #tabs>\n <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n <ul\n *ngIf=\"visibleDossierTabs === null; else configuredTabs\"\n ngbNav\n [destroyOnHide]=\"false\"\n (navChange)=\"tabChange($event)\"\n class=\"nav-tabs\"\n [activeId]=\"assigneeFilter\"\n >\n <li ngbNavItem=\"ALL\" [title]=\"'dossier.tabs.ALL' | translate\">\n <a ngbNavLink>{{ 'dossier.tabs.ALL' | translate }}</a>\n </li>\n <li ngbNavItem=\"MINE\" [title]=\"'dossier.tabs.MINE' | translate\">\n <a ngbNavLink>{{ 'dossier.tabs.MINE' | translate }}</a>\n </li>\n <li ngbNavItem=\"OPEN\" [title]=\"'dossier.tabs.OPEN' | translate\">\n <a ngbNavLink>{{ 'dossier.tabs.OPEN' | translate }}</a>\n </li>\n </ul>\n </ng-container>\n</ng-template>\n\n<ng-template #configuredTabs>\n <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n <ul\n ngbNav\n [destroyOnHide]=\"false\"\n (navChange)=\"tabChange($event)\"\n class=\"nav-tabs\"\n [activeId]=\"assigneeFilter\"\n >\n <li\n *ngFor=\"let tab of visibleDossierTabs\"\n [ngbNavItem]=\"tab\"\n [title]=\"'dossier.tabs.' + tab | translate\"\n >\n <a ngbNavLink>{{ 'dossier.tabs.' + tab | translate }}</a>\n </li>\n </ul>\n </ng-container>\n</ng-template>\n\n<ng-template #loading><valtimo-spinner></valtimo-spinner></ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState", "lastColumnTemplate"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }, { kind: "component", type: i6.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { kind: "component", type: i6.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "component", type: i6.SearchFieldsComponent, selector: "valtimo-search-fields", inputs: ["loading", "searchFields", "documentDefinitionName", "setValuesSubject$", "defaultValues"], outputs: ["doSearch"] }, { kind: "directive", type: i8.NgbNav, selector: "[ngbNav]", inputs: ["activeId", "animation", "destroyOnHide", "orientation", "roles", "keyboard"], outputs: ["activeIdChange", "shown", "hidden", "navChange"], exportAs: ["ngbNav"] }, { kind: "directive", type: i8.NgbNavItem, selector: "[ngbNavItem]", inputs: ["destroyOnHide", "disabled", "domId", "ngbNavItem"], outputs: ["shown", "hidden"], exportAs: ["ngbNavItem"] }, { kind: "directive", type: i8.NgbNavLink, selector: "a[ngbNavLink]" }, { kind: "component", type: i9.DossierListActionsComponent, selector: "valtimo-dossier-list-actions", inputs: ["loading"], outputs: ["formFlowComplete"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
|
|
213
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DossierListComponent, decorators: [{
|
|
340
214
|
type: Component,
|
|
341
|
-
args: [{ selector: 'valtimo-dossier-list', providers: [
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-list.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/dossier-list/dossier-list.component.ts","../../../../../../projects/valtimo/dossier/src/lib/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 */\n\nimport {Component, OnInit, ViewChild} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {TranslateService} from '@ngx-translate/core';\nimport {\n  AssigneeFilter,\n  ConfigService,\n  DefinitionColumn,\n  DossierListTab,\n  SearchField,\n  SearchFieldValues,\n  SearchFilter,\n  SearchFilterRange,\n} from '@valtimo/config';\nimport {\n  AdvancedDocumentSearchRequest,\n  AdvancedDocumentSearchRequestImpl,\n  Documents,\n  DocumentService,\n  ProcessDocumentDefinition,\n  SortState,\n  SpecifiedDocuments,\n} from '@valtimo/document';\nimport moment from 'moment';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  map,\n  Observable,\n  of,\n  Subject,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {DefaultTabs} from '../dossier-detail-tab-enum';\nimport {DossierProcessStartModalComponent} from '../dossier-process-start-modal/dossier-process-start-modal.component';\nimport {DossierService} from '../dossier.service';\nimport {ListField, Pagination} from '@valtimo/components';\nimport {NGXLogger} from 'ngx-logger';\nimport {NgbNavChangeEvent} from '@ng-bootstrap/ng-bootstrap';\nimport {DossierColumnService, DossierParameterService} from '../services';\n\n// eslint-disable-next-line no-var\ndeclare var $;\n\nmoment.locale(localStorage.getItem('langKey') || '');\n\n@Component({\n  selector: 'valtimo-dossier-list',\n  templateUrl: './dossier-list.component.html',\n  styleUrls: ['./dossier-list.component.css'],\n  providers: [DossierParameterService],\n})\nexport class DossierListComponent implements OnInit {\n  @ViewChild('processStartModal') processStart: DossierProcessStartModalComponent;\n\n  public dossierVisibleTabs: Array<DossierListTab> | null = null;\n\n  private readonly defaultAssigneeFilter = 'ALL';\n  private selectedProcessDocumentDefinition: ProcessDocumentDefinition | null = null;\n  private modalListenerAdded = false;\n  private readonly settingPaginationForDocName$ = new BehaviorSubject<string | undefined>(\n    undefined\n  );\n\n  readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  readonly loadingDocumentSearchFields$ = new BehaviorSubject<boolean>(true);\n\n  readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params.documentDefinitionName || ''),\n    tap(documentDefinitionName => {\n      this.resetPagination(documentDefinitionName);\n    })\n  );\n\n  readonly hasEnvColumnConfig$: Observable<boolean> = this.route.params.pipe(\n    map(params => params.documentDefinitionName || ''),\n    map(documentDefinitionName =>\n      this.dossierColumnService.hasEnvironmentConfig(documentDefinitionName)\n    )\n  );\n\n  readonly canHaveAssignee$: Observable<boolean> = this.documentDefinitionName$.pipe(\n    switchMap(documentDefinitionName =>\n      this.documentService.getCaseSettings(documentDefinitionName)\n    ),\n    map(caseSettings => caseSettings?.canHaveAssignee)\n  );\n\n  readonly documentSearchFields$: Observable<Array<SearchField> | null> =\n    this.documentDefinitionName$.pipe(\n      distinctUntilChanged(),\n      tap(() => this.loadingDocumentSearchFields$.next(true)),\n      switchMap(documentDefinitionName =>\n        this.documentService.getDocumentSearchFields(documentDefinitionName)\n      ),\n      tap(() => this.loadingDocumentSearchFields$.next(false))\n    );\n\n  readonly associatedProcessDocumentDefinitions$: Observable<Array<ProcessDocumentDefinition>> =\n    this.documentDefinitionName$.pipe(\n      switchMap(documentDefinitionName =>\n        documentDefinitionName\n          ? this.documentService.findProcessDocumentDefinitions(documentDefinitionName)\n          : of([])\n      ),\n      map(processDocumentDefinitions =>\n        processDocumentDefinitions.filter(definition => definition.canInitializeDocument)\n      )\n    );\n\n  readonly schema$ = this.documentDefinitionName$.pipe(\n    switchMap(documentDefinitionName =>\n      this.documentService.getDocumentDefinition(documentDefinitionName)\n    ),\n    map(documentDefinition => documentDefinition?.schema),\n    tap(() => {\n      this.assigneeFilter$.next(this.defaultAssigneeFilter);\n    })\n  );\n\n  private readonly storedSearchRequestKey$: Observable<string> = this.documentDefinitionName$.pipe(\n    map(documentDefinitionName => `list-search-${documentDefinitionName}`)\n  );\n\n  private readonly hasStoredSearchRequest$: Observable<boolean> = this.storedSearchRequestKey$.pipe(\n    map(storedSearchRequestKey => localStorage.getItem(storedSearchRequestKey) !== null)\n  );\n\n  private readonly hasApiColumnConfig$ = new BehaviorSubject<boolean>(false);\n\n  private readonly columns$: Observable<Array<DefinitionColumn>> =\n    this.documentDefinitionName$.pipe(\n      switchMap(documentDefinitionName =>\n        this.dossierColumnService.getDefinitionColumns(documentDefinitionName)\n      ),\n      map(res => {\n        this.hasApiColumnConfig$.next(res.hasApiConfig);\n        return res.columns;\n      })\n    );\n\n  private readonly ASSIGNEE_KEY = 'assigneeFullName';\n\n  readonly fields$: Observable<Array<ListField>> = combineLatest([\n    this.columns$,\n    this.canHaveAssignee$,\n    this.hasEnvColumnConfig$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([columns, canHaveAssignee, hasEnvConfig]) => [\n      ...columns\n        .map(column => {\n          const translationKey = `fieldLabels.${column.translationKey}`;\n          const translation = this.translateService.instant(translationKey);\n          const validTranslation = translation !== translationKey && translation;\n          return {\n            key: hasEnvConfig ? column.propertyName : column.translationKey,\n            label: column.title || validTranslation || column.translationKey,\n            sortable: column.sortable,\n            ...(column.viewType && {viewType: column.viewType}),\n            ...(column.enum && {enum: column.enum}),\n            ...(column.format && {format: column.format}),\n          };\n        })\n        // Filter out assignee column if the case type can not have an assignee\n        .filter(column => {\n          if (column?.key === this.ASSIGNEE_KEY && !canHaveAssignee) {\n            return false;\n          }\n          return true;\n        }),\n      // If the case type can have an assignee, and the assignee column is not present in the case column definition, add an assignee column at the end\n      ...(canHaveAssignee && !columns.find(column => column.propertyName === this.ASSIGNEE_KEY)\n        ? [\n            {\n              key: this.ASSIGNEE_KEY,\n              label: this.translateService.instant(`fieldLabels.${this.ASSIGNEE_KEY}`),\n              sortable: true,\n              viewType: 'string',\n            },\n          ]\n        : []),\n    ])\n  );\n\n  private readonly DEFAULT_PAGINATION: Pagination = {\n    collectionSize: 0,\n    page: 1,\n    size: 10,\n    maxPaginationItemSize: 5,\n    sort: undefined,\n  };\n\n  private readonly pagination$ = new BehaviorSubject<Pagination | undefined>(undefined);\n\n  readonly paginationCopy$ = this.pagination$.pipe(\n    map(pagination => pagination && JSON.parse(JSON.stringify(pagination))),\n    tap(pagination => this.dossierParameterService.setPaginationParameters(pagination))\n  );\n\n  private readonly documentSearchRequest$: Observable<AdvancedDocumentSearchRequest> =\n    combineLatest([this.pagination$, this.documentDefinitionName$]).pipe(\n      filter(([pagination]) => !!pagination),\n      map(\n        ([pagination, documentDefinitionName]) =>\n          new AdvancedDocumentSearchRequestImpl(\n            documentDefinitionName,\n            pagination.page - 1,\n            pagination.size,\n            pagination.sort\n          )\n      )\n    );\n\n  private readonly searchFieldValues$ = new BehaviorSubject<SearchFieldValues>({});\n  private readonly assigneeFilter$ = new BehaviorSubject<AssigneeFilter>(\n    this.defaultAssigneeFilter\n  );\n\n  private readonly documentsRequest$: Observable<Documents | SpecifiedDocuments> = combineLatest([\n    this.documentSearchRequest$,\n    this.searchFieldValues$,\n    this.assigneeFilter$,\n    this.hasEnvColumnConfig$,\n    this.hasApiColumnConfig$,\n  ]).pipe(\n    distinctUntilChanged(\n      (\n        [prevSearchRequest, prevSearchValues, prevAssigneeFilter],\n        [currSearchRequest, currSearchValues, currAssigneeFilter]\n      ) =>\n        JSON.stringify({...prevSearchRequest, ...prevSearchValues}) + prevAssigneeFilter ===\n        JSON.stringify({...currSearchRequest, ...currSearchValues}) + currAssigneeFilter\n    ),\n    tap(([documentSearchRequest]) => {\n      this.storedSearchRequestKey$.pipe(take(1)).subscribe(storedSearchRequestKey => {\n        this.logger.debug(\n          `store request in local storage: ${JSON.stringify(documentSearchRequest)}`\n        );\n        localStorage.setItem(storedSearchRequestKey, JSON.stringify(documentSearchRequest));\n      });\n    }),\n    switchMap(\n      ([\n        documentSearchRequest,\n        searchValues,\n        assigneeFilter,\n        hasEnvColumnConfig,\n        hasApiColumnConfig,\n      ]) => {\n        if ((Object.keys(searchValues) || []).length > 0) {\n          return hasEnvColumnConfig || !hasApiColumnConfig\n            ? this.documentService.getDocumentsSearch(\n                documentSearchRequest,\n                'AND',\n                assigneeFilter,\n                this.mapSearchValuesToFilters(searchValues)\n              )\n            : this.documentService.getSpecifiedDocumentsSearch(\n                documentSearchRequest,\n                'AND',\n                assigneeFilter,\n                this.mapSearchValuesToFilters(searchValues)\n              );\n        } else {\n          return hasEnvColumnConfig || !hasApiColumnConfig\n            ? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter)\n            : this.documentService.getSpecifiedDocumentsSearch(\n                documentSearchRequest,\n                'AND',\n                assigneeFilter\n              );\n        }\n      }\n    ),\n    tap(documents => {\n      this.setCollectionSize(documents);\n      this.checkPage(documents);\n    })\n  );\n\n  readonly documentItems$ = combineLatest([\n    this.documentsRequest$,\n    this.hasEnvColumnConfig$,\n    this.hasApiColumnConfig$,\n  ]).pipe(\n    map(([documents, hasEnvColumnConfig, hasApiColumnConfig]) => {\n      if (hasEnvColumnConfig || !hasApiColumnConfig) {\n        const docsToMap = documents as Documents;\n        return documents.content.map(document => {\n          const {content, ...others} = document;\n          return {...content, ...others};\n        });\n      } else {\n        const docsToMap = documents as SpecifiedDocuments;\n        return docsToMap.content.reduce((acc, curr) => {\n          const propsObject = {id: curr.id};\n          curr.items.forEach(item => {\n            propsObject[item.key] = item.value;\n          });\n          return [...acc, propsObject];\n        }, []);\n      }\n    }),\n    tap(() => this.loading$.next(false))\n  );\n\n  readonly setSearchFieldValuesSubject$ = new Subject<SearchFieldValues>();\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly documentService: DocumentService,\n    private readonly translateService: TranslateService,\n    private readonly dossierService: DossierService,\n    private readonly logger: NGXLogger,\n    private readonly configService: ConfigService,\n    private readonly dossierColumnService: DossierColumnService,\n    private readonly dossierParameterService: DossierParameterService\n  ) {\n    this.dossierVisibleTabs = this.configService.config?.visibleDossierListTabs || null;\n  }\n\n  ngOnInit(): void {\n    this.modalListenerAdded = false;\n    this.setSearchFieldParametersInComponent();\n  }\n\n  pageChange(newPage: number): void {\n    this.pagination$.pipe(take(1)).subscribe(pagination => {\n      if (pagination && pagination.page !== newPage) {\n        this.logger.debug(`Page change: ${newPage}`);\n        this.pagination$.next({...pagination, page: newPage});\n      }\n    });\n  }\n\n  pageSizeChange(newPageSize: number): void {\n    this.pagination$.pipe(take(1)).subscribe(pagination => {\n      if (pagination && pagination.size !== newPageSize) {\n        const amountOfAvailablePages = Math.ceil(pagination.collectionSize / newPageSize);\n        const newPage =\n          amountOfAvailablePages < pagination.page ? amountOfAvailablePages : pagination.page;\n\n        this.logger.debug(`Page size change. New Page: ${newPage} New page size: ${newPageSize}`);\n        this.pagination$.next({...pagination, size: newPageSize, page: newPage});\n      }\n    });\n  }\n\n  sortChanged(newSortState: SortState): void {\n    this.pagination$.pipe(take(1)).subscribe(pagination => {\n      if (pagination && JSON.stringify(pagination.sort) !== JSON.stringify(newSortState)) {\n        this.logger.debug(`Sort state change: ${JSON.stringify(newSortState)}`);\n        this.pagination$.next({...pagination, sort: newSortState});\n      }\n    });\n  }\n\n  rowClick(document: any): void {\n    this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {\n      this.router.navigate([\n        `/dossiers/${documentDefinitionName}/document/${document.id}/${DefaultTabs.summary}`,\n      ]);\n    });\n  }\n\n  startDossier(): void {\n    this.associatedProcessDocumentDefinitions$\n      .pipe(take(1))\n      .subscribe(associatedProcessDocumentDefinitions => {\n        if (associatedProcessDocumentDefinitions.length > 1) {\n          $('#startProcess').modal('show');\n        } else {\n          this.selectedProcessDocumentDefinition = associatedProcessDocumentDefinitions[0];\n          this.showStartProcessModal();\n        }\n      });\n  }\n\n  selectProcess(processDocumentDefinition: ProcessDocumentDefinition): void {\n    const modal = $('#startProcess');\n    if (!this.modalListenerAdded) {\n      modal.on('hidden.bs.modal', this.showStartProcessModal.bind(this));\n      this.modalListenerAdded = true;\n    }\n    this.selectedProcessDocumentDefinition = processDocumentDefinition;\n    modal.modal('hide');\n  }\n\n  search(searchFieldValues: SearchFieldValues): void {\n    this.searchFieldValues$.next(searchFieldValues || {});\n    this.dossierParameterService.setSearchParameters(searchFieldValues);\n  }\n\n  tabChange(tab: NgbNavChangeEvent<any>): void {\n    this.pagination$.pipe(take(1)).subscribe(pagination => {\n      this.pagination$.next({...pagination, page: 1});\n    });\n    this.assigneeFilter$.next(tab.nextId.toUpperCase());\n  }\n\n  private mapSearchValuesToFilters(\n    values: SearchFieldValues\n  ): Array<SearchFilter | SearchFilterRange> {\n    const filters: Array<SearchFilter | SearchFilterRange> = [];\n\n    Object.keys(values).forEach(valueKey => {\n      const searchValue = values[valueKey] as any;\n      if (searchValue.start) {\n        filters.push({key: valueKey, rangeFrom: searchValue.start, rangeTo: searchValue.end});\n      } else if (Array.isArray(searchValue)) {\n        filters.push({key: valueKey, values: searchValue});\n      } else {\n        filters.push({key: valueKey, values: [searchValue]});\n      }\n    });\n\n    return filters;\n  }\n\n  private resetPagination(documentDefinitionName): void {\n    this.settingPaginationForDocName$.pipe(take(1)).subscribe(settingPaginationForDocName => {\n      if (documentDefinitionName !== settingPaginationForDocName) {\n        this.pagination$.next(undefined);\n        this.logger.debug('clear pagination');\n        this.settingPaginationForDocName$.next(documentDefinitionName);\n        this.setPagination(documentDefinitionName);\n      }\n    });\n  }\n\n  private setPagination(documentDefinitionName: string): void {\n    combineLatest([\n      this.hasStoredSearchRequest$,\n      this.storedSearchRequestKey$,\n      this.columns$,\n      this.dossierParameterService.queryPaginationParams$,\n    ])\n      .pipe(take(1))\n      .subscribe(\n        ([hasStoredSearchRequest, storedSearchRequestKey, columns, queryPaginationParams]) => {\n          const defaultPagination: Pagination = this.getDefaultPagination(columns);\n          const storedPagination: Pagination = this.getStoredPagination(\n            hasStoredSearchRequest,\n            storedSearchRequestKey\n          );\n          const paginationToUse = queryPaginationParams || storedPagination || defaultPagination;\n\n          this.logger.debug(`Set pagination: ${JSON.stringify(paginationToUse)}`);\n          this.pagination$.next(paginationToUse);\n        }\n      );\n  }\n\n  private getDefaultPagination(columns: Array<DefinitionColumn>): Pagination {\n    const defaultSortState = this.dossierService.getInitialSortState(columns);\n\n    return {\n      ...this.DEFAULT_PAGINATION,\n      sort: defaultSortState,\n    };\n  }\n\n  private getStoredPagination(\n    hasStoredSearchRequest: boolean,\n    storedSearchRequestKey: string\n  ): Pagination | undefined {\n    const storedSearchRequest =\n      hasStoredSearchRequest && JSON.parse(localStorage.getItem(storedSearchRequestKey));\n\n    return (\n      storedSearchRequest && {\n        ...this.DEFAULT_PAGINATION,\n        sort: storedSearchRequest.sort,\n        page: storedSearchRequest.page + 1,\n        size: storedSearchRequest.size,\n      }\n    );\n  }\n\n  private setCollectionSize(documents: Documents | SpecifiedDocuments): void {\n    this.pagination$.pipe(take(1)).subscribe(pagination => {\n      if (pagination.collectionSize !== documents.totalElements) {\n        this.pagination$.next({...pagination, collectionSize: documents.totalElements});\n      }\n    });\n  }\n\n  private showStartProcessModal(): void {\n    if (this.selectedProcessDocumentDefinition !== null) {\n      this.processStart.openModal(this.selectedProcessDocumentDefinition);\n      this.selectedProcessDocumentDefinition = null;\n    }\n  }\n\n  private checkPage(documents: Documents | SpecifiedDocuments): void {\n    this.pagination$.pipe(take(1)).subscribe(pagination => {\n      const amountOfItems = documents.totalElements;\n      const amountOfPages = Math.ceil(amountOfItems / pagination.size);\n      const currentPage = pagination.page;\n\n      if (currentPage > amountOfPages) {\n        this.pagination$.next({...pagination, page: amountOfPages});\n      }\n    });\n  }\n\n  private setSearchFieldParametersInComponent(): void {\n    this.dossierParameterService.querySearchParams$.pipe(take(1)).subscribe(values => {\n      if (Object.keys(values || {}).length > 0) {\n        setTimeout(() => {\n          this.setSearchFieldValuesSubject$.next(values);\n        });\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<div class=\"main-content pt-0\" *ngIf=\"{loading: loading$ | async} as obs\">\n  <div class=\"container-fluid\">\n    <div class=\"col-12 px-0 mb-5\">\n      <div\n        *ngIf=\"\n          associatedProcessDocumentDefinitions$ | async as associatedProcessDocumentDefinitions\n        \"\n      >\n        <div class=\"text-right mt-m3px mb-3\">\n          <button\n            type=\"button\"\n            class=\"btn btn-space btn-primary mr-0\"\n            (click)=\"startDossier()\"\n            [ngbTooltip]=\"associatedProcessDocumentDefinitions.length === 0 ? 'No action' : null\"\n            placement=\"bottom\"\n            [disabled]=\"associatedProcessDocumentDefinitions.length === 0 || obs.loading\"\n          >\n            <i class=\"icon mdi mdi-plus mr-1\"></i>\n            {{ 'Start Dossier' | translate }}\n          </button>\n        </div>\n\n        <div\n          class=\"modal fade\"\n          id=\"startProcess\"\n          tabindex=\"-1\"\n          role=\"dialog\"\n          aria-labelledby=\"startProcessLabel\"\n          aria-hidden=\"true\"\n        >\n          <div class=\"modal-dialog modal-dialog-centered\" role=\"document\">\n            <div class=\"modal-content\">\n              <div class=\"modal-header\">\n                <h3 class=\"modal-title\" id=\"startProcessLabel\">\n                  {{ 'dashboard.startProcess.title' | translate }}\n                </h3>\n                <button type=\"button\" class=\"close\" data-dismiss=\"modal\" aria-label=\"Close\">\n                  <span aria-hidden=\"true\">&times;</span>\n                </button>\n              </div>\n              <div class=\"modal-body\">\n                <div class=\"table-responsive\">\n                  <table class=\"table m-0\">\n                    <tr\n                      *ngFor=\"let processDocumentDefinition of associatedProcessDocumentDefinitions\"\n                      (click)=\"selectProcess(processDocumentDefinition)\"\n                      style=\"cursor: pointer\"\n                    >\n                      <td>{{ processDocumentDefinition.processName }}</td>\n                    </tr>\n                  </table>\n                </div>\n              </div>\n              <div class=\"modal-footer\">\n                <button type=\"button\" class=\"btn btn-secondary\" data-dismiss=\"modal\">\n                  {{ 'cta.close' | translate }}\n                </button>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n      <valtimo-spinner *ngIf=\"obs.loading\"></valtimo-spinner>\n      <ng-container *ngTemplateOutlet=\"searchFields\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n    </div>\n  </div>\n  <valtimo-dossier-process-start-modal #processStartModal></valtimo-dossier-process-start-modal>\n</div>\n\n<ng-template #searchFields>\n  <div class=\"mb-3\">\n    <valtimo-search-fields\n      [loading]=\"loadingDocumentSearchFields$ | async\"\n      [searchFields]=\"documentSearchFields$ | async\"\n      (doSearch)=\"search($event)\"\n      [documentDefinitionName]=\"documentDefinitionName$ | async\"\n      [setValuesSubject$]=\"setSearchFieldValuesSubject$\"\n    ></valtimo-search-fields>\n  </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n  <ng-container *ngIf=\"paginationCopy$ | async as pagination\">\n    <ng-container *ngIf=\"fields$ | async as fields\">\n      <ng-container *ngIf=\"documentItems$ | async as documentItems\">\n        <valtimo-widget *ngIf=\"obs.loading === false\">\n          <valtimo-list\n            [items]=\"documentItems\"\n            [fields]=\"fields\"\n            (rowClicked)=\"rowClick($event)\"\n            [pagination]=\"pagination\"\n            [viewMode]=\"true\"\n            [header]=\"true\"\n            paginationIdentifier=\"dossierList\"\n            (paginationClicked)=\"pageChange($event)\"\n            (paginationSet)=\"pageSizeChange($event)\"\n            [initialSortState]=\"pagination.sort\"\n            (sortChanged)=\"sortChanged($event)\"\n          >\n            <div header>\n              <h3 class=\"list-header-title\">\n                {{ (schema$ | async)?.title }}\n                <sup class=\"ml-1 badge badge-pill badge-primary\">{{\n                  pagination?.collectionSize || 0\n                }}</sup>\n              </h3>\n            </div>\n            <div tabs *ngIf=\"canHaveAssignee$ | async\">\n              <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n            </div>\n          </valtimo-list>\n        </valtimo-widget>\n      </ng-container>\n    </ng-container>\n  </ng-container>\n</ng-template>\n\n<ng-template #configuredTabs>\n  <ul ngbNav [destroyOnHide]=\"false\" (navChange)=\"tabChange($event)\" class=\"nav-tabs\">\n    <li\n      *ngFor=\"let tab of dossierVisibleTabs\"\n      [ngbNavItem]=\"tab\"\n      [title]=\"'dossier.tabs.' + tab | translate\"\n    >\n      <a ngbNavLink>{{ 'dossier.tabs.' + tab | translate }}</a>\n    </li>\n  </ul>\n</ng-template>\n\n<ng-template #tabs>\n  <ul\n    *ngIf=\"dossierVisibleTabs === null; else configuredTabs\"\n    ngbNav\n    [destroyOnHide]=\"false\"\n    (navChange)=\"tabChange($event)\"\n    class=\"nav-tabs\"\n  >\n    <li ngbNavItem=\"all\" [title]=\"'dossier.tabs.ALL' | translate\">\n      <a ngbNavLink>{{ 'dossier.tabs.ALL' | translate }}</a>\n    </li>\n    <li ngbNavItem=\"mine\" [title]=\"'dossier.tabs.MINE' | translate\">\n      <a ngbNavLink>{{ 'dossier.tabs.MINE' | translate }}</a>\n    </li>\n    <li ngbNavItem=\"open\" [title]=\"'dossier.tabs.OPEN' | translate\">\n      <a ngbNavLink>{{ 'dossier.tabs.OPEN' | translate }}</a>\n    </li>\n  </ul>\n</ng-template>\n"]}
|
|
215
|
+
args: [{ selector: 'valtimo-dossier-list', providers: [
|
|
216
|
+
DossierListService,
|
|
217
|
+
DossierColumnService,
|
|
218
|
+
DossierListAssigneeService,
|
|
219
|
+
DossierParameterService,
|
|
220
|
+
DossierListPaginationService,
|
|
221
|
+
DossierListSearchService,
|
|
222
|
+
], 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 searchFields: searchFields$ | async,\n schema: schema$ | 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)=\"refresh()\"\n ></valtimo-dossier-list-actions>\n <ng-container *ngIf=\"obs.loaded; else loading\">\n <ng-container *ngTemplateOutlet=\"searchFields; context: {obs: obs}\"></ng-container>\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n </ng-container>\n </div>\n </div>\n </div>\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 ></valtimo-search-fields>\n </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n <valtimo-widget>\n <valtimo-list\n [items]=\"obs.documentItems\"\n [fields]=\"obs.fields\"\n (rowClicked)=\"rowClick($event)\"\n [pagination]=\"pagination\"\n [viewMode]=\"true\"\n [header]=\"true\"\n paginationIdentifier=\"dossierList\"\n (paginationClicked)=\"pageChange($event)\"\n (paginationSet)=\"pageSizeChange($event)\"\n [initialSortState]=\"pagination.sort\"\n (sortChanged)=\"sortChanged($event)\"\n >\n <div header>\n <h3 class=\"list-header-title\">\n <sup class=\"ml-1 badge badge-pill badge-primary\">{{\n pagination?.collectionSize || 0\n }}</sup>\n </h3>\n </div>\n <div tabs *ngIf=\"canHaveAssignee\">\n <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n </div>\n </valtimo-list>\n </valtimo-widget>\n</ng-template>\n\n<ng-template #tabs>\n <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n <ul\n *ngIf=\"visibleDossierTabs === null; else configuredTabs\"\n ngbNav\n [destroyOnHide]=\"false\"\n (navChange)=\"tabChange($event)\"\n class=\"nav-tabs\"\n [activeId]=\"assigneeFilter\"\n >\n <li ngbNavItem=\"ALL\" [title]=\"'dossier.tabs.ALL' | translate\">\n <a ngbNavLink>{{ 'dossier.tabs.ALL' | translate }}</a>\n </li>\n <li ngbNavItem=\"MINE\" [title]=\"'dossier.tabs.MINE' | translate\">\n <a ngbNavLink>{{ 'dossier.tabs.MINE' | translate }}</a>\n </li>\n <li ngbNavItem=\"OPEN\" [title]=\"'dossier.tabs.OPEN' | translate\">\n <a ngbNavLink>{{ 'dossier.tabs.OPEN' | translate }}</a>\n </li>\n </ul>\n </ng-container>\n</ng-template>\n\n<ng-template #configuredTabs>\n <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n <ul\n ngbNav\n [destroyOnHide]=\"false\"\n (navChange)=\"tabChange($event)\"\n class=\"nav-tabs\"\n [activeId]=\"assigneeFilter\"\n >\n <li\n *ngFor=\"let tab of visibleDossierTabs\"\n [ngbNavItem]=\"tab\"\n [title]=\"'dossier.tabs.' + tab | translate\"\n >\n <a ngbNavLink>{{ 'dossier.tabs.' + tab | translate }}</a>\n </li>\n </ul>\n </ng-container>\n</ng-template>\n\n<ng-template #loading><valtimo-spinner></valtimo-spinner></ng-template>\n" }]
|
|
223
|
+
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.TranslateService }, { type: i3.DossierListService }, { type: i3.DossierColumnService }, { type: i3.DossierListAssigneeService }, { type: i3.DossierListPaginationService }, { type: i3.DossierListSearchService }, { type: i3.DossierParameterService }, { type: i4.DocumentService }, { type: i1.Router }, { type: i5.ConfigService }, { type: i6.PageTitleService }, { type: i6.BreadcrumbService }]; } });
|
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-list.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/dossier-list/dossier-list.component.ts","../../../../../../projects/valtimo/dossier/src/lib/dossier-list/dossier-list.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,SAAS,EAAoB,MAAM,eAAe,CAAC;AAC3D,OAAO,EACL,eAAe,EACf,aAAa,EACb,oBAAoB,EACpB,MAAM,EACN,GAAG,EAGH,SAAS,EACT,IAAI,EACJ,GAAG,GACJ,MAAM,MAAM,CAAC;AAEd,OAAO,EACL,oBAAoB,EACpB,0BAA0B,EAC1B,4BAA4B,EAC5B,wBAAwB,EACxB,kBAAkB,EAClB,uBAAuB,GACxB,MAAM,aAAa,CAAC;AAarB,OAAO,EAEL,iCAAiC,GAIlC,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAC,WAAW,EAAC,MAAM,4BAA4B,CAAC;;;;;;;;;;;AAgBvD,MAAM,OAAO,oBAAoB;IAoN/B,YACmB,KAAqB,EACrB,gBAAkC,EAClC,WAA+B,EAC/B,aAAmC,EACnC,eAA2C,EAC3C,iBAA+C,EAC/C,aAAuC,EACvC,gBAAyC,EACzC,eAAgC,EAChC,MAAc,EACd,aAA4B,EAC5B,gBAAkC,EAClC,iBAAoC;QAZpC,UAAK,GAAL,KAAK,CAAgB;QACrB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,gBAAW,GAAX,WAAW,CAAoB;QAC/B,kBAAa,GAAb,aAAa,CAAsB;QACnC,oBAAe,GAAf,eAAe,CAA4B;QAC3C,sBAAiB,GAAjB,iBAAiB,CAA8B;QAC/C,kBAAa,GAAb,aAAa,CAA0B;QACvC,qBAAgB,GAAhB,gBAAgB,CAAyB;QACzC,oBAAe,GAAf,eAAe,CAAiB;QAChC,WAAM,GAAN,MAAM,CAAQ;QACd,kBAAa,GAAb,aAAa,CAAe;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAhOhD,kBAAa,GAAG,IAAI,CAAC;QACrB,sBAAiB,GAAG,IAAI,CAAC;QACzB,wBAAmB,GAAG,IAAI,CAAC;QAC3B,0BAAqB,GAAG,IAAI,CAAC;QAC7B,yBAAoB,GAAG,IAAI,CAAC;QAG5B,uBAAkB,GAAiC,IAAI,CAAC;QAE/C,kBAAa,GAC3B,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,IAAI,CAC3C,GAAG,CAAC,YAAY,CAAC,EAAE;YACjB,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACnC,CAAC,CAAC,CACH,CAAC;QAEY,4BAAuB,GAAG,IAAI,CAAC,WAAW,CAAC,uBAAuB,CAAC;QAEnE,YAAO,GAAG,IAAI,CAAC,WAAW,CAAC,uBAAuB,CAAC,IAAI,CACrE,SAAS,CAAC,sBAAsB,CAAC,EAAE,CACjC,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,sBAAsB,CAAC,CACnE,EACD,GAAG,CAAC,kBAAkB,CAAC,EAAE,CAAC,kBAAkB,EAAE,MAAM,CAAC,EACrD,GAAG,CAAC,MAAM,CAAC,EAAE;YACX,IAAI,MAAM,EAAE,KAAK,EAAE;gBACjB,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;aAC/D;QACH,CAAC,CAAC,CACH,CAAC;QAEc,uBAAkB,GAAG,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC;QAC9D,oBAAe,GAC7B,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC;QACtB,iBAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CACrE,GAAG,CAAC,UAAU,CAAC,EAAE;YACf,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;YAC7B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QACjC,CAAC,CAAC,CACH,CAAC;QACe,yBAAoB,GAAwB,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC;QACjF,yBAAoB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAC3D,sBAAiB,GAAwB,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC;QAC/E,mBAAc,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;QAClD,cAAS,GACxB,IAAI,CAAC,WAAW,CAAC,uBAAuB,CAAC,IAAI,CAC3C,SAAS,CAAC,sBAAsB,CAAC,EAAE,CACjC,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,sBAAsB,CAAC,CAChE,EACD,GAAG,CAAC,GAAG,CAAC,EAAE;YACR,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;YACjD,OAAO,GAAG,CAAC,OAAO,CAAC;QACrB,CAAC,CAAC,EACF,GAAG,CAAC,OAAO,CAAC,EAAE;YACZ,IAAI,CAAC,WAAW,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,EAAE;gBACxF,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,sBAAsB,EAAE,OAAO,CAAC,CAAC;YACxE,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CACH,CAAC;QAEK,YAAO,GAAiC,aAAa,CAAC;YAC7D,IAAI,CAAC,iBAAiB;YACtB,IAAI,CAAC,SAAS;YACd,IAAI,CAAC,oBAAoB;YACzB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;SACpC,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE,EAAE;YACxB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QACzC,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,eAAe,EAAE,OAAO,EAAE,YAAY,CAAC,EAAE,EAAE;YAC/C,MAAM,uBAAuB,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CACxE,OAAO,EACP,eAAe,CAChB,CAAC;YACF,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,gCAAgC,CACpE,uBAAuB,EACvB,YAAY,CACb,CAAC;YACF,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAC9D,OAAO,EACP,UAAU,EACV,eAAe,CAChB,CAAC;YAEF,OAAO,cAAc,CAAC;QACxB,CAAC,CAAC,EACF,GAAG,CAAC,UAAU,CAAC,EAAE;YACf,MAAM,gBAAgB,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAEjE,qFAAqF;YACrF,IAAI,CAAC,gBAAgB,CAAC,sBAAsB;iBACzC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACb,SAAS,CAAC,qBAAqB,CAAC,EAAE;gBACjC,IAAI,gBAAgB,IAAI,CAAC,qBAAqB,EAAE,IAAI,EAAE,SAAS,EAAE;oBAC/D,MAAM,aAAa,GACjB,OAAO,gBAAgB,CAAC,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;oBACnF,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC;wBACjC,SAAS,EAAE,IAAI;wBACf,KAAK,EAAE,EAAC,IAAI,EAAE,gBAAgB,CAAC,GAAG,EAAE,SAAS,EAAE,aAA0B,EAAC;qBAC3E,CAAC,CAAC;iBACJ;YACH,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC7B,CAAC,CAAC,CACH,CAAC;QAEe,4BAAuB,GACtC,aAAa,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,uBAAuB,CAAC,CAAC,CAAC,IAAI,CAC/E,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,EACtC,GAAG,CACD,CAAC,CAAC,UAAU,EAAE,sBAAsB,CAAC,EAAE,EAAE,CACvC,IAAI,iCAAiC,CACnC,sBAAsB,EACtB,UAAU,CAAC,IAAI,GAAG,CAAC,EACnB,UAAU,CAAC,IAAI,EACf,UAAU,CAAC,IAAI,CAChB,CACJ,CACF,CAAC;QAEa,uBAAkB,GAA+C,aAAa,CAAC;YAC9F,IAAI,CAAC,uBAAuB;YAC5B,IAAI,CAAC,kBAAkB;YACvB,IAAI,CAAC,eAAe;YACpB,IAAI,CAAC,oBAAoB;YACzB,IAAI,CAAC,oBAAoB;YACzB,IAAI,CAAC,cAAc;SACpB,CAAC,CAAC,IAAI,CACL,oBAAoB,CAClB,CACE,CACE,iBAAiB,EACjB,gBAAgB,EAChB,kBAAkB,EAClB,sBAAsB,EACtB,sBAAsB,EACtB,gBAAgB,EACjB,EACD,CACE,iBAAiB,EACjB,gBAAgB,EAChB,kBAAkB,EAClB,sBAAsB,EACtB,sBAAsB,EACtB,gBAAgB,EACjB,EACD,EAAE,CACF,IAAI,CAAC,SAAS,CAAC,EAAC,GAAG,iBAAiB,EAAE,GAAG,gBAAgB,EAAC,CAAC;YACzD,kBAAkB;YAClB,gBAAgB;YAClB,IAAI,CAAC,SAAS,CAAC,EAAC,GAAG,iBAAiB,EAAE,GAAG,gBAAgB,EAAC,CAAC;gBACzD,kBAAkB;gBAClB,gBAAgB,CACrB,EACD,SAAS,CACP,CAAC,CACC,qBAAqB,EACrB,YAAY,EACZ,cAAc,EACd,kBAAkB,EAClB,kBAAkB,EACnB,EAAE,EAAE;YACH,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;gBAChD,OAAO,kBAAkB,IAAI,CAAC,kBAAkB;oBAC9C,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,kBAAkB,CACrC,qBAAqB,EACrB,KAAK,EACL,cAAc,EACd,IAAI,CAAC,aAAa,CAAC,wBAAwB,CAAC,YAAY,CAAC,CAC1D;oBACH,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,2BAA2B,CAC9C,qBAAqB,EACrB,KAAK,EACL,cAAc,EACd,IAAI,CAAC,aAAa,CAAC,wBAAwB,CAAC,YAAY,CAAC,CAC1D,CAAC;aACP;YAED,OAAO,kBAAkB,IAAI,CAAC,kBAAkB;gBAC9C,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,qBAAqB,EAAE,KAAK,EAAE,cAAc,CAAC;gBACvF,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,2BAA2B,CAC9C,qBAAqB,EACrB,KAAK,EACL,cAAc,CACf,CAAC;QACR,CAAC,CACF,EACD,GAAG,CAAC,SAAS,CAAC,EAAE;YACd,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YACpD,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC9C,CAAC,CAAC,CACH,CAAC;QAEK,mBAAc,GAAG,aAAa,CAAC;YACpC,IAAI,CAAC,kBAAkB;YACvB,IAAI,CAAC,oBAAoB;YACzB,IAAI,CAAC,oBAAoB;SAC1B,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,EAAE,EAAE,CAC1D,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,SAAS,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,CACjF,EACD,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;YACnC,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QACpC,CAAC,CAAC,CACH,CAAC;IAmBC,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,sCAAsC,EAAE,CAAC;IAChD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,mCAAmC,EAAE,WAAW,EAAE,CAAC;QACxD,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC;IACtC,CAAC;IAED,MAAM,CAAC,iBAAoC;QACzC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAC/C,CAAC;IAED,QAAQ,CAAC,QAAa;QACpB,IAAI,CAAC,WAAW,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,EAAE;YACxF,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CACrC,aAAa,sBAAsB,EAAE,EACrC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAChC,CAAC;YACF,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;gBACnB,aAAa,sBAAsB,aAAa,QAAQ,CAAC,EAAE,IAAI,WAAW,CAAC,OAAO,EAAE;aACrF,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU,CAAC,OAAe;QACxB,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAC7C,CAAC;IAED,cAAc,CAAC,WAAmB;QAChC,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IACrD,CAAC;IAED,WAAW,CAAC,YAAuB;QACjC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;IAED,SAAS,CAAC,GAA2B;QACnC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,OAAO;QACL,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;IAC/B,CAAC;IAEO,sCAAsC;QAC5C,IAAI,CAAC,mCAAmC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM;aACzD,IAAI,CACH,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,sBAAsB,CAAC,EAC7C,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,EAClC,oBAAoB,EAAE,CACvB;aACA,SAAS,CAAC,qBAAqB,CAAC,EAAE;YACjC,IAAI,IAAI,CAAC,+BAA+B,EAAE;gBACxC,IAAI,CAAC,gBAAgB,CAAC,eAAe,EAAE,CAAC;gBACxC,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,CAAC;aAChD;YACD,IAAI,CAAC,+BAA+B,GAAG,qBAAqB,CAAC;YAC7D,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,iBAAiB,CAAC,eAAe,EAAE,CAAC;YACzC,IAAI,CAAC,eAAe,CAAC,mBAAmB,EAAE,CAAC;YAC3C,IAAI,CAAC,WAAW,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,CAAC;QACpE,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;QAClC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;IACnC,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,sBAAsB,IAAI,IAAI,CAAC;IACtF,CAAC;;iHAjTU,oBAAoB;qGAApB,oBAAoB,+CATpB;QACT,kBAAkB;QAClB,oBAAoB;QACpB,0BAA0B;QAC1B,uBAAuB;QACvB,4BAA4B;QAC5B,wBAAwB;KACzB,0BCvEH,svIAkIA;2FDzDa,oBAAoB;kBAbhC,SAAS;+BACE,sBAAsB,aAGrB;wBACT,kBAAkB;wBAClB,oBAAoB;wBACpB,0BAA0B;wBAC1B,uBAAuB;wBACvB,4BAA4B;wBAC5B,wBAAwB;qBACzB","sourcesContent":["/*\n * Copyright 2015-2023 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  map,\n  Observable,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {\n  DossierColumnService,\n  DossierListAssigneeService,\n  DossierListPaginationService,\n  DossierListSearchService,\n  DossierListService,\n  DossierParameterService,\n} from '../services';\nimport {\n  AssigneeFilter,\n  ConfigService,\n  DefinitionColumn,\n  Direction,\n  DossierListTab,\n  SearchField,\n  SearchFieldValues,\n  SortState,\n} from '@valtimo/config';\nimport {BreadcrumbService, ListField, PageTitleService, Pagination} from '@valtimo/components';\nimport {TranslateService} from '@ngx-translate/core';\nimport {\n  AdvancedDocumentSearchRequest,\n  AdvancedDocumentSearchRequestImpl,\n  Documents,\n  DocumentService,\n  SpecifiedDocuments,\n} from '@valtimo/document';\nimport {DefaultTabs} from '../dossier-detail-tab-enum';\nimport {NgbNavChangeEvent} from '@ng-bootstrap/ng-bootstrap';\n\n@Component({\n  selector: 'valtimo-dossier-list',\n  templateUrl: './dossier-list.component.html',\n  styleUrls: ['./dossier-list.component.css'],\n  providers: [\n    DossierListService,\n    DossierColumnService,\n    DossierListAssigneeService,\n    DossierParameterService,\n    DossierListPaginationService,\n    DossierListSearchService,\n  ],\n})\nexport class DossierListComponent implements OnInit, OnDestroy {\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 searchFields$: Observable<Array<SearchField> | null> =\n    this.searchService.documentSearchFields$.pipe(\n      tap(searchFields => {\n        this.loadingSearchFields = false;\n      })\n    );\n\n  public readonly documentDefinitionName$ = this.listService.documentDefinitionName$;\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$;\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 _searchSwitch$ = this.searchService.searchSwitch$;\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(documentDefinitionName => {\n          this.paginationService.setPagination(documentDefinitionName, columns);\n        });\n      })\n    );\n\n  readonly fields$: Observable<Array<ListField>> = combineLatest([\n    this._canHaveAssignee$,\n    this._columns$,\n    this._hasEnvColumnConfig$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    tap(([canHaveAssignee]) => {\n      this.canHaveAssignee = canHaveAssignee;\n    }),\n    map(([canHaveAssignee, columns, hasEnvConfig]) => {\n      const filteredAssigneeColumns = this.assigneeService.filterAssigneeColumns(\n        columns,\n        canHaveAssignee\n      );\n      const listFields = this.columnService.mapDefinitionColumnsToListFields(\n        filteredAssigneeColumns,\n        hasEnvConfig\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\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(\n        ([pagination, documentDefinitionName]) =>\n          new AdvancedDocumentSearchRequestImpl(\n            documentDefinitionName,\n            pagination.page - 1,\n            pagination.size,\n            pagination.sort\n          )\n      )\n    );\n\n  private readonly _documentsRequest$: Observable<Documents | SpecifiedDocuments> = combineLatest([\n    this._documentSearchRequest$,\n    this.searchFieldValues$,\n    this.assigneeFilter$,\n    this._hasEnvColumnConfig$,\n    this._hasApiColumnConfig$,\n    this._searchSwitch$,\n  ]).pipe(\n    distinctUntilChanged(\n      (\n        [\n          prevSearchRequest,\n          prevSearchValues,\n          prevAssigneeFilter,\n          prevHasEnvColumnConfig,\n          prevHasApiColumnConfig,\n          prevSearchSwitch,\n        ],\n        [\n          currSearchRequest,\n          currSearchValues,\n          currAssigneeFilter,\n          currHasEnvColumnConfig,\n          currHasApiColumnConfig,\n          currSearchSwitch,\n        ]\n      ) =>\n        JSON.stringify({...prevSearchRequest, ...prevSearchValues}) +\n          prevAssigneeFilter +\n          prevSearchSwitch ===\n        JSON.stringify({...currSearchRequest, ...currSearchValues}) +\n          currAssigneeFilter +\n          currSearchSwitch\n    ),\n    switchMap(\n      ([\n        documentSearchRequest,\n        searchValues,\n        assigneeFilter,\n        hasEnvColumnConfig,\n        hasApiColumnConfig,\n      ]) => {\n        if ((Object.keys(searchValues) || []).length > 0) {\n          return 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        }\n\n        return hasEnvColumnConfig || !hasApiColumnConfig\n          ? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter)\n          : this.documentService.getSpecifiedDocumentsSearch(\n              documentSearchRequest,\n              'AND',\n              assigneeFilter\n            );\n      }\n    ),\n    tap(documents => {\n      this.paginationService.setCollectionSize(documents);\n      this.paginationService.checkPage(documents);\n    })\n  );\n\n  public documentItems$ = combineLatest([\n    this._documentsRequest$,\n    this._hasEnvColumnConfig$,\n    this._hasApiColumnConfig$,\n  ]).pipe(\n    map(([documents, hasEnvColumnConfig, hasApiColumnConfig]) =>\n      this.listService.mapDocuments(documents, hasEnvColumnConfig, hasApiColumnConfig)\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 route: ActivatedRoute,\n    private readonly translateService: TranslateService,\n    private readonly listService: DossierListService,\n    private readonly columnService: DossierColumnService,\n    private readonly assigneeService: DossierListAssigneeService,\n    private readonly paginationService: DossierListPaginationService,\n    private readonly searchService: DossierListSearchService,\n    private readonly parameterService: DossierParameterService,\n    private readonly documentService: DocumentService,\n    private readonly router: Router,\n    private readonly configService: ConfigService,\n    private readonly pageTitleService: PageTitleService,\n    private readonly breadcrumbService: BreadcrumbService\n  ) {}\n\n  ngOnInit(): void {\n    this.setVisibleTabs();\n    this.openDocumentDefinitionNameSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this._documentDefinitionNameSubscription?.unsubscribe();\n    this.pageTitleService.enableReset();\n  }\n\n  search(searchFieldValues: SearchFieldValues): void {\n    this.searchService.search(searchFieldValues);\n  }\n\n  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}/${DefaultTabs.summary}`,\n      ]);\n    });\n  }\n\n  pageChange(newPage: number): void {\n    this.paginationService.pageChange(newPage);\n  }\n\n  pageSizeChange(newPageSize: number): void {\n    this.paginationService.pageSizeChange(newPageSize);\n  }\n\n  sortChanged(newSortState: SortState): void {\n    this.paginationService.sortChanged(newSortState);\n  }\n\n  tabChange(tab: NgbNavChangeEvent<any>): void {\n    this.paginationService.setPage(1);\n    this.assigneeService.setAssigneeFilter(tab.nextId.toUpperCase());\n  }\n\n  refresh(): void {\n    this.searchService.refresh();\n  }\n\n  private openDocumentDefinitionNameSubscription(): void {\n    this._documentDefinitionNameSubscription = this.route.params\n      .pipe(\n        map(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","<!--\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    searchFields: searchFields$ | async,\n    schema: schema$ | 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)=\"refresh()\"\n        ></valtimo-dossier-list-actions>\n        <ng-container *ngIf=\"obs.loaded; else loading\">\n          <ng-container *ngTemplateOutlet=\"searchFields; context: {obs: obs}\"></ng-container>\n          <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n        </ng-container>\n      </div>\n    </div>\n  </div>\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    ></valtimo-search-fields>\n  </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n  <valtimo-widget>\n    <valtimo-list\n      [items]=\"obs.documentItems\"\n      [fields]=\"obs.fields\"\n      (rowClicked)=\"rowClick($event)\"\n      [pagination]=\"pagination\"\n      [viewMode]=\"true\"\n      [header]=\"true\"\n      paginationIdentifier=\"dossierList\"\n      (paginationClicked)=\"pageChange($event)\"\n      (paginationSet)=\"pageSizeChange($event)\"\n      [initialSortState]=\"pagination.sort\"\n      (sortChanged)=\"sortChanged($event)\"\n    >\n      <div header>\n        <h3 class=\"list-header-title\">\n          <sup class=\"ml-1 badge badge-pill badge-primary\">{{\n            pagination?.collectionSize || 0\n          }}</sup>\n        </h3>\n      </div>\n      <div tabs *ngIf=\"canHaveAssignee\">\n        <ng-container *ngTemplateOutlet=\"tabs\"></ng-container>\n      </div>\n    </valtimo-list>\n  </valtimo-widget>\n</ng-template>\n\n<ng-template #tabs>\n  <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n    <ul\n      *ngIf=\"visibleDossierTabs === null; else configuredTabs\"\n      ngbNav\n      [destroyOnHide]=\"false\"\n      (navChange)=\"tabChange($event)\"\n      class=\"nav-tabs\"\n      [activeId]=\"assigneeFilter\"\n    >\n      <li ngbNavItem=\"ALL\" [title]=\"'dossier.tabs.ALL' | translate\">\n        <a ngbNavLink>{{ 'dossier.tabs.ALL' | translate }}</a>\n      </li>\n      <li ngbNavItem=\"MINE\" [title]=\"'dossier.tabs.MINE' | translate\">\n        <a ngbNavLink>{{ 'dossier.tabs.MINE' | translate }}</a>\n      </li>\n      <li ngbNavItem=\"OPEN\" [title]=\"'dossier.tabs.OPEN' | translate\">\n        <a ngbNavLink>{{ 'dossier.tabs.OPEN' | translate }}</a>\n      </li>\n    </ul>\n  </ng-container>\n</ng-template>\n\n<ng-template #configuredTabs>\n  <ng-container *ngIf=\"assigneeFilter$ | async as assigneeFilter\">\n    <ul\n      ngbNav\n      [destroyOnHide]=\"false\"\n      (navChange)=\"tabChange($event)\"\n      class=\"nav-tabs\"\n      [activeId]=\"assigneeFilter\"\n    >\n      <li\n        *ngFor=\"let tab of visibleDossierTabs\"\n        [ngbNavItem]=\"tab\"\n        [title]=\"'dossier.tabs.' + tab | translate\"\n      >\n        <a ngbNavLink>{{ 'dossier.tabs.' + tab | translate }}</a>\n      </li>\n    </ul>\n  </ng-container>\n</ng-template>\n\n<ng-template #loading><valtimo-spinner></valtimo-spinner></ng-template>\n"]}
|