@valtimo/dossier 5.3.0 → 5.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/dossier-detail/dossier-detail.component.mjs +4 -4
- 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/documents/documents.component.mjs +4 -4
- package/esm2020/lib/dossier-detail/tab/progress/progress.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 +65 -0
- package/esm2020/lib/dossier-detail-tab-enum.mjs +2 -1
- package/esm2020/lib/dossier-list/dossier-list.component.mjs +144 -142
- package/esm2020/lib/dossier-process-start-modal/dossier-process-start-modal.component.mjs +4 -4
- package/esm2020/lib/dossier-routing.module.mjs +5 -5
- package/esm2020/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +16 -11
- package/esm2020/lib/dossier-update/dossier-update.component.mjs +4 -4
- package/esm2020/lib/dossier.module.mjs +22 -6
- package/esm2020/lib/dossier.service.mjs +10 -6
- package/esm2020/lib/models/index.mjs +13 -14
- package/esm2020/lib/models/zaakobjecten.model.mjs +17 -0
- package/esm2020/lib/services/zaakobjecten.service.mjs +41 -0
- package/esm2020/lib/tab.service.mjs +4 -4
- package/esm2020/public_api.mjs +2 -1
- package/fesm2015/valtimo-dossier.mjs +331 -219
- package/fesm2015/valtimo-dossier.mjs.map +1 -1
- package/fesm2020/valtimo-dossier.mjs +360 -224
- package/fesm2020/valtimo-dossier.mjs.map +1 -1
- package/lib/dossier-detail/tab/summary/summary.component.d.ts +3 -3
- package/lib/dossier-detail/tab/summary/summary.component.d.ts.map +1 -1
- package/lib/dossier-detail/tab/zaakobjecten/zaakobjecten.component.d.ts +21 -0
- package/lib/dossier-detail/tab/zaakobjecten/zaakobjecten.component.d.ts.map +1 -0
- package/lib/dossier-detail-tab-enum.d.ts +2 -1
- package/lib/dossier-detail-tab-enum.d.ts.map +1 -1
- package/lib/dossier-list/dossier-list.component.d.ts +50 -51
- package/lib/dossier-list/dossier-list.component.d.ts.map +1 -1
- package/lib/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +3 -3
- package/lib/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
- package/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts +6 -2
- package/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -1
- package/lib/dossier.module.d.ts +16 -14
- package/lib/dossier.module.d.ts.map +1 -1
- package/lib/dossier.service.d.ts.map +1 -1
- package/lib/models/index.d.ts +1 -0
- package/lib/models/index.d.ts.map +1 -1
- package/lib/models/zaakobjecten.model.d.ts +12 -0
- package/lib/models/zaakobjecten.model.d.ts.map +1 -0
- package/lib/services/zaakobjecten.service.d.ts +16 -0
- package/lib/services/zaakobjecten.service.d.ts.map +1 -0
- package/package.json +2 -2
- package/public_api.d.ts +1 -0
- package/public_api.d.ts.map +1 -1
|
@@ -14,161 +14,140 @@
|
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
16
|
import { Component, ViewChild } from '@angular/core';
|
|
17
|
-
import { NavigationEnd } from '@angular/router';
|
|
18
17
|
import { DocumentSearchRequestImpl, } from '@valtimo/document';
|
|
19
18
|
import moment from 'moment';
|
|
20
|
-
import { combineLatest } from 'rxjs';
|
|
19
|
+
import { BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, of, switchMap, take, tap, } from 'rxjs';
|
|
21
20
|
import { DefaultTabs } from '../dossier-detail-tab-enum';
|
|
22
21
|
import * as i0 from "@angular/core";
|
|
23
22
|
import * as i1 from "@angular/router";
|
|
24
23
|
import * as i2 from "@valtimo/document";
|
|
25
24
|
import * as i3 from "@ngx-translate/core";
|
|
26
25
|
import * as i4 from "../dossier.service";
|
|
27
|
-
import * as i5 from "
|
|
28
|
-
import * as i6 from "
|
|
29
|
-
import * as i7 from "
|
|
30
|
-
import * as i8 from "@
|
|
31
|
-
import * as i9 from "@
|
|
26
|
+
import * as i5 from "ngx-logger";
|
|
27
|
+
import * as i6 from "@valtimo/components";
|
|
28
|
+
import * as i7 from "../dossier-process-start-modal/dossier-process-start-modal.component";
|
|
29
|
+
import * as i8 from "@angular/common";
|
|
30
|
+
import * as i9 from "@ng-bootstrap/ng-bootstrap";
|
|
31
|
+
import * as i10 from "@angular/forms";
|
|
32
32
|
moment.locale(localStorage.getItem('langKey') || '');
|
|
33
33
|
export class DossierListComponent {
|
|
34
|
-
constructor(route, router, documentService, translateService, dossierService) {
|
|
34
|
+
constructor(route, router, documentService, translateService, dossierService, logger) {
|
|
35
35
|
this.route = route;
|
|
36
36
|
this.router = router;
|
|
37
37
|
this.documentService = documentService;
|
|
38
38
|
this.translateService = translateService;
|
|
39
39
|
this.dossierService = dossierService;
|
|
40
|
-
this.
|
|
41
|
-
this.
|
|
42
|
-
this.
|
|
43
|
-
this.
|
|
44
|
-
this.
|
|
45
|
-
|
|
46
|
-
|
|
40
|
+
this.logger = logger;
|
|
41
|
+
this.selectedProcessDocumentDefinition = null;
|
|
42
|
+
this.modalListenerAdded = false;
|
|
43
|
+
this.settingPaginationForDocName$ = new BehaviorSubject(undefined);
|
|
44
|
+
this.documentDefinitionName$ = this.route.params.pipe(map(params => params.documentDefinitionName || ''), tap(documentDefinitionName => {
|
|
45
|
+
this.resetPagination(documentDefinitionName);
|
|
46
|
+
}));
|
|
47
|
+
this.associatedProcessDocumentDefinitions$ = this.documentDefinitionName$.pipe(switchMap(documentDefinitionName => documentDefinitionName
|
|
48
|
+
? this.documentService.findProcessDocumentDefinitions(documentDefinitionName)
|
|
49
|
+
: of([])), map(processDocumentDefinitions => processDocumentDefinitions.filter(definition => definition.canInitializeDocument)));
|
|
50
|
+
this.schema$ = this.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.documentService.getDocumentDefinition(documentDefinitionName)), map(documentDefinition => documentDefinition?.schema));
|
|
51
|
+
this.storedSearchRequestKey$ = this.documentDefinitionName$.pipe(map(documentDefinitionName => `list-search-${documentDefinitionName}`));
|
|
52
|
+
this.hasStoredSearchRequest$ = this.storedSearchRequestKey$.pipe(map(storedSearchRequestKey => localStorage.getItem(storedSearchRequestKey) !== null));
|
|
53
|
+
this.columns$ = this.documentDefinitionName$.pipe(map(documentDefinitionName => this.dossierService.getDefinitionColumns(documentDefinitionName)));
|
|
54
|
+
this.fields$ = combineLatest([
|
|
55
|
+
this.columns$,
|
|
56
|
+
this.translateService.stream('key'),
|
|
57
|
+
]).pipe(map(([columns]) => columns.map((column, index) => ({
|
|
58
|
+
key: column.propertyName,
|
|
59
|
+
label: this.translateService.instant(`fieldLabels.${column.translationKey}`),
|
|
60
|
+
sortable: column.sortable,
|
|
61
|
+
...(column.viewType && { viewType: column.viewType }),
|
|
62
|
+
}))));
|
|
63
|
+
this.DEFAULT_PAGINATION = {
|
|
47
64
|
collectionSize: 0,
|
|
48
65
|
page: 1,
|
|
49
66
|
size: 10,
|
|
50
67
|
maxPaginationItemSize: 5,
|
|
51
68
|
sort: undefined,
|
|
52
69
|
};
|
|
53
|
-
this.
|
|
54
|
-
this.
|
|
70
|
+
this.pagination$ = new BehaviorSubject(undefined);
|
|
71
|
+
this.paginationCopy$ = this.pagination$.pipe(map(pagination => pagination && JSON.parse(JSON.stringify(pagination))));
|
|
72
|
+
this.sequence$ = new BehaviorSubject(undefined);
|
|
73
|
+
this.globalSearchFilter$ = new BehaviorSubject(undefined);
|
|
74
|
+
this.createdBy$ = new BehaviorSubject(undefined);
|
|
75
|
+
this.documentSearchRequest$ = combineLatest([
|
|
76
|
+
this.pagination$,
|
|
77
|
+
this.documentDefinitionName$,
|
|
78
|
+
this.sequence$,
|
|
79
|
+
this.createdBy$,
|
|
80
|
+
this.globalSearchFilter$,
|
|
81
|
+
]).pipe(filter(([pagination]) => !!pagination), map(([pagination, documentDefinitionName, sequence, createdBy, globalSearchFilter]) => new DocumentSearchRequestImpl(documentDefinitionName, pagination.page - 1, pagination.size, sequence, createdBy, globalSearchFilter, pagination.sort)));
|
|
82
|
+
this.documentsRequest$ = this.documentSearchRequest$.pipe(distinctUntilChanged((prev, curr) => JSON.stringify(prev) === JSON.stringify(curr)), tap(request => {
|
|
83
|
+
this.storedSearchRequestKey$.pipe(take(1)).subscribe(storedSearchRequestKey => {
|
|
84
|
+
this.logger.log(`store request in local storage: ${JSON.stringify(request)}`);
|
|
85
|
+
localStorage.setItem(storedSearchRequestKey, JSON.stringify(request));
|
|
86
|
+
});
|
|
87
|
+
}), switchMap(documentSearchRequest => this.documentService.getDocuments(documentSearchRequest)), tap(documents => {
|
|
88
|
+
this.setCollectionSize(documents);
|
|
89
|
+
}));
|
|
90
|
+
this.documentItems$ = this.documentsRequest$.pipe(map(documents => documents.content.map(document => {
|
|
91
|
+
const { content, ...others } = document;
|
|
92
|
+
return { ...content, ...others };
|
|
93
|
+
})));
|
|
55
94
|
}
|
|
56
95
|
ngOnInit() {
|
|
57
|
-
this.doInit();
|
|
58
|
-
this.routeEvent(this.router);
|
|
59
96
|
this.modalListenerAdded = false;
|
|
60
97
|
}
|
|
61
|
-
|
|
62
|
-
this.
|
|
63
|
-
this.
|
|
98
|
+
globalSearchFilterChange(searchFilter) {
|
|
99
|
+
this.globalSearchFilter$.next(searchFilter);
|
|
100
|
+
this.pageChange(1);
|
|
64
101
|
}
|
|
65
|
-
|
|
66
|
-
this.
|
|
102
|
+
sequenceChange(sequence) {
|
|
103
|
+
this.sequence$.next(Number(sequence));
|
|
104
|
+
this.pageChange(1);
|
|
67
105
|
}
|
|
68
|
-
|
|
69
|
-
this.
|
|
70
|
-
if (
|
|
71
|
-
this.
|
|
72
|
-
this.
|
|
106
|
+
pageChange(newPage) {
|
|
107
|
+
this.pagination$.pipe(take(1)).subscribe(pagination => {
|
|
108
|
+
if (pagination && pagination.page !== newPage) {
|
|
109
|
+
this.logger.log(`Page change: ${newPage}`);
|
|
110
|
+
this.pagination$.next({ ...pagination, page: newPage });
|
|
73
111
|
}
|
|
74
112
|
});
|
|
75
113
|
}
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
this.translationSubscription = combineLatest(columns.map(column => this.translateService.stream(`fieldLabels.${column.translationKey}`))).subscribe(labels => {
|
|
85
|
-
this.fields = columns.map((column, index) => ({
|
|
86
|
-
key: column.propertyName,
|
|
87
|
-
label: labels[index],
|
|
88
|
-
sortable: column.sortable,
|
|
89
|
-
...(column.viewType && { viewType: column.viewType }),
|
|
90
|
-
}));
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
getData() {
|
|
94
|
-
this.findDocumentDefinition(this.documentDefinitionName);
|
|
95
|
-
if (this.hasCachedSearchRequest()) {
|
|
96
|
-
const documentSearchRequest = this.getCachedSearch();
|
|
97
|
-
this.globalSearchFilter = documentSearchRequest.globalSearchFilter;
|
|
98
|
-
this.sequence = documentSearchRequest.sequence;
|
|
99
|
-
this.createdBy = documentSearchRequest.createdBy;
|
|
100
|
-
this.findDocuments(documentSearchRequest);
|
|
101
|
-
}
|
|
102
|
-
else {
|
|
103
|
-
this.doSearch();
|
|
104
|
-
}
|
|
105
|
-
this.getAllAssociatedProcessDefinitions();
|
|
106
|
-
}
|
|
107
|
-
doSearch() {
|
|
108
|
-
const documentSearchRequest = this.buildDocumentSearchRequest();
|
|
109
|
-
this.findDocuments(documentSearchRequest);
|
|
110
|
-
}
|
|
111
|
-
findDocuments(documentSearchRequest) {
|
|
112
|
-
return this.documentService.getDocuments(documentSearchRequest).subscribe(documents => {
|
|
113
|
-
this.documents = documents;
|
|
114
|
-
this.transformDocuments(this.documents.content);
|
|
115
|
-
this.pagination.collectionSize = this.documents.totalElements;
|
|
116
|
-
this.storeSearch(documentSearchRequest);
|
|
114
|
+
pageSizeChange(newPageSize) {
|
|
115
|
+
this.pagination$.pipe(take(1)).subscribe(pagination => {
|
|
116
|
+
if (pagination && pagination.size !== newPageSize) {
|
|
117
|
+
const amountOfAvailablePages = Math.ceil(pagination.collectionSize / newPageSize);
|
|
118
|
+
const newPage = amountOfAvailablePages < pagination.page ? amountOfAvailablePages : pagination.page;
|
|
119
|
+
this.logger.log(`Page size change. New Page: ${newPage} New page size: ${newPageSize}`);
|
|
120
|
+
this.pagination$.next({ ...pagination, size: newPageSize, page: newPage });
|
|
121
|
+
}
|
|
117
122
|
});
|
|
118
123
|
}
|
|
119
|
-
|
|
120
|
-
this.
|
|
121
|
-
.
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
{
|
|
126
|
-
key: 'processName',
|
|
127
|
-
label: 'Proces',
|
|
128
|
-
},
|
|
129
|
-
];
|
|
124
|
+
sortChanged(newSortState) {
|
|
125
|
+
this.pagination$.pipe(take(1)).subscribe(pagination => {
|
|
126
|
+
if (pagination && JSON.stringify(pagination.sort) !== JSON.stringify(newSortState)) {
|
|
127
|
+
this.logger.log(`Sort state change: ${JSON.stringify(newSortState)}`);
|
|
128
|
+
this.pagination$.next({ ...pagination, sort: newSortState });
|
|
129
|
+
}
|
|
130
130
|
});
|
|
131
131
|
}
|
|
132
|
-
getCachedSearch() {
|
|
133
|
-
const json = JSON.parse(this.getCachedDocumentSearchRequest());
|
|
134
|
-
return new DocumentSearchRequestImpl(json.definitionName, this.pagination.page - 1, this.pagination.size, json.sequence, json.createdBy, json.globalSearchFilter, json.sort);
|
|
135
|
-
}
|
|
136
|
-
buildDocumentSearchRequest() {
|
|
137
|
-
return new DocumentSearchRequestImpl(this.documentDefinitionName, this.pagination.page - 1, this.pagination.size, this.sequence, this.createdBy, this.globalSearchFilter, this.pagination.sort && this.pagination.sort.isSorting
|
|
138
|
-
? this.pagination.sort
|
|
139
|
-
: this.initialSortState);
|
|
140
|
-
}
|
|
141
|
-
storeSearch(documentSearchRequest) {
|
|
142
|
-
localStorage.setItem(this.getCachedKey(), JSON.stringify(documentSearchRequest));
|
|
143
|
-
}
|
|
144
|
-
getCachedDocumentSearchRequest() {
|
|
145
|
-
return localStorage.getItem(this.getCachedKey()) || '';
|
|
146
|
-
}
|
|
147
|
-
hasCachedSearchRequest() {
|
|
148
|
-
return localStorage.getItem(this.getCachedKey()) !== null;
|
|
149
|
-
}
|
|
150
|
-
getCachedKey() {
|
|
151
|
-
return 'list-search-' + this.documentDefinitionName;
|
|
152
|
-
}
|
|
153
132
|
rowClick(document) {
|
|
154
|
-
this.
|
|
155
|
-
|
|
156
|
-
|
|
133
|
+
this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
|
|
134
|
+
this.router.navigate([
|
|
135
|
+
`/dossiers/${documentDefinitionName}/document/${document.id}/${DefaultTabs.summary}`,
|
|
136
|
+
]);
|
|
137
|
+
});
|
|
157
138
|
}
|
|
158
139
|
startDossier() {
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
this.selectedProcessDocumentDefinition = null;
|
|
171
|
-
}
|
|
140
|
+
this.associatedProcessDocumentDefinitions$
|
|
141
|
+
.pipe(take(1))
|
|
142
|
+
.subscribe(associatedProcessDocumentDefinitions => {
|
|
143
|
+
if (associatedProcessDocumentDefinitions.length > 1) {
|
|
144
|
+
$('#startProcess').modal('show');
|
|
145
|
+
}
|
|
146
|
+
else {
|
|
147
|
+
this.selectedProcessDocumentDefinition = associatedProcessDocumentDefinitions[0];
|
|
148
|
+
this.showStartProcessModal();
|
|
149
|
+
}
|
|
150
|
+
});
|
|
172
151
|
}
|
|
173
152
|
selectProcess(processDocumentDefinition) {
|
|
174
153
|
const modal = $('#startProcess');
|
|
@@ -179,40 +158,63 @@ export class DossierListComponent {
|
|
|
179
158
|
this.selectedProcessDocumentDefinition = processDocumentDefinition;
|
|
180
159
|
modal.modal('hide');
|
|
181
160
|
}
|
|
182
|
-
|
|
183
|
-
this.
|
|
184
|
-
|
|
161
|
+
resetPagination(documentDefinitionName) {
|
|
162
|
+
this.settingPaginationForDocName$.pipe(take(1)).subscribe(settingPaginationForDocName => {
|
|
163
|
+
if (documentDefinitionName !== settingPaginationForDocName) {
|
|
164
|
+
this.pagination$.next(undefined);
|
|
165
|
+
this.logger.log('clear pagination');
|
|
166
|
+
this.settingPaginationForDocName$.next(documentDefinitionName);
|
|
167
|
+
this.setPagination(documentDefinitionName);
|
|
168
|
+
}
|
|
185
169
|
});
|
|
186
170
|
}
|
|
187
|
-
|
|
188
|
-
this.
|
|
189
|
-
|
|
190
|
-
|
|
171
|
+
setPagination(documentDefinitionName) {
|
|
172
|
+
combineLatest([this.hasStoredSearchRequest$, this.storedSearchRequestKey$, this.columns$])
|
|
173
|
+
.pipe(take(1))
|
|
174
|
+
.subscribe(([hasStoredSearchRequest, storedSearchRequestKey, columns]) => {
|
|
175
|
+
const defaultPagination = this.getDefaultPagination(columns);
|
|
176
|
+
const storedPagination = this.getStoredPagination(hasStoredSearchRequest, storedSearchRequestKey);
|
|
177
|
+
this.logger.log(`Set pagination: ${JSON.stringify(storedPagination || defaultPagination)}`);
|
|
178
|
+
this.pagination$.next(storedPagination || defaultPagination);
|
|
191
179
|
});
|
|
192
180
|
}
|
|
193
|
-
|
|
194
|
-
this.
|
|
195
|
-
|
|
181
|
+
getDefaultPagination(columns) {
|
|
182
|
+
const defaultSortState = this.dossierService.getInitialSortState(columns);
|
|
183
|
+
return {
|
|
184
|
+
...this.DEFAULT_PAGINATION,
|
|
185
|
+
sort: defaultSortState,
|
|
186
|
+
};
|
|
196
187
|
}
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
188
|
+
getStoredPagination(hasStoredSearchRequest, storedSearchRequestKey) {
|
|
189
|
+
const storedSearchRequest = hasStoredSearchRequest && JSON.parse(localStorage.getItem(storedSearchRequestKey));
|
|
190
|
+
return (storedSearchRequest && {
|
|
191
|
+
...this.DEFAULT_PAGINATION,
|
|
192
|
+
sort: storedSearchRequest.sort,
|
|
193
|
+
page: storedSearchRequest.page + 1,
|
|
194
|
+
size: storedSearchRequest.size,
|
|
195
|
+
});
|
|
196
|
+
}
|
|
197
|
+
setCollectionSize(documents) {
|
|
198
|
+
this.pagination$.pipe(take(1)).subscribe(pagination => {
|
|
199
|
+
if (pagination.collectionSize !== documents.totalElements) {
|
|
200
|
+
this.pagination$.next({ ...pagination, collectionSize: documents.totalElements });
|
|
201
|
+
}
|
|
202
|
+
});
|
|
200
203
|
}
|
|
201
|
-
|
|
202
|
-
if (this.
|
|
203
|
-
|
|
204
|
-
|
|
204
|
+
showStartProcessModal() {
|
|
205
|
+
if (this.selectedProcessDocumentDefinition !== null) {
|
|
206
|
+
this.processStart.openModal(this.selectedProcessDocumentDefinition);
|
|
207
|
+
this.selectedProcessDocumentDefinition = null;
|
|
205
208
|
}
|
|
206
|
-
return this.initialSortState;
|
|
207
209
|
}
|
|
208
210
|
}
|
|
209
|
-
DossierListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
210
|
-
DossierListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
211
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
211
|
+
DossierListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierListComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.DocumentService }, { token: i3.TranslateService }, { token: i4.DossierService }, { token: i5.NGXLogger }], target: i0.ɵɵFactoryTarget.Component });
|
|
212
|
+
DossierListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierListComponent, selector: "valtimo-dossier-list", viewQueries: [{ propertyName: "processStart", first: true, predicate: ["processStartModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 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 *ngTemplateOutlet=\"sidebar\"></ng-container>\n\n<div class=\"main-content pt-0\">\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\"\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\">×</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-widget>\n <ng-container *ngTemplateOutlet=\"list\"></ng-container>\n </valtimo-widget>\n </div>\n </div>\n <valtimo-dossier-process-start-modal #processStartModal></valtimo-dossier-process-start-modal>\n</div>\n\n<ng-template #list>\n <ng-container *ngIf=\"paginationCopy$ | async as pagination\">\n <ng-container *ngIf=\"fields$ | async as fields\">\n <valtimo-list\n *ngIf=\"documentItems$ | async as documentItems\"\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\">{{ documentItems?.length || 0 }}</sup>\n </h3>\n </div>\n </valtimo-list>\n </ng-container>\n </ng-container>\n</ng-template>\n\n<ng-template #sidebar>\n <valtimo-filter-sidebar>\n <h4 class=\"title\">Search</h4>\n <div class=\"mb-4\">\n <input\n type=\"text\"\n class=\"form-control\"\n placeholder=\"{{ 'dossier.forms.globalSearchPlaceHolder' | translate }}\"\n [ngModel]=\"globalSearchFilter$ | async\"\n (ngModelChange)=\"globalSearchFilterChange($event)\"\n />\n </div>\n\n <div class=\"mb-4\">\n <input\n type=\"number\"\n class=\"form-control\"\n placeholder=\"{{ 'dossier.forms.referenceNumberPlaceHolder' | translate }}\"\n [ngModel]=\"sequence$ | async\"\n (ngModelChange)=\"sequenceChange($event)\"\n />\n </div>\n </valtimo-filter-sidebar>\n</ng-template>\n", styles: [""], components: [{ type: i6.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { type: i7.DossierProcessStartModalComponent, selector: "valtimo-dossier-process-start-modal" }, { type: i6.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }, { type: i6.FilterSidebarComponent, selector: "valtimo-filter-sidebar" }], directives: [{ type: i8.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i10.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i10.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }], pipes: { "async": i8.AsyncPipe, "translate": i3.TranslatePipe } });
|
|
213
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierListComponent, decorators: [{
|
|
212
214
|
type: Component,
|
|
213
|
-
args: [{ selector: 'valtimo-dossier-list', template: "<!--\n ~ Copyright 2015-2020 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 *ngTemplateOutlet=\"sidebar\"></ng-container>\n\n<div class=\"main-content pt-0\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <div>\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]=\"
|
|
214
|
-
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.DocumentService }, { type: i3.TranslateService }, { type: i4.DossierService }]; }, propDecorators: { processStart: [{
|
|
215
|
+
args: [{ selector: 'valtimo-dossier-list', template: "<!--\n ~ Copyright 2015-2020 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 *ngTemplateOutlet=\"sidebar\"></ng-container>\n\n<div class=\"main-content pt-0\">\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\"\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\">×</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-widget>\n <ng-container *ngTemplateOutlet=\"list\"></ng-container>\n </valtimo-widget>\n </div>\n </div>\n <valtimo-dossier-process-start-modal #processStartModal></valtimo-dossier-process-start-modal>\n</div>\n\n<ng-template #list>\n <ng-container *ngIf=\"paginationCopy$ | async as pagination\">\n <ng-container *ngIf=\"fields$ | async as fields\">\n <valtimo-list\n *ngIf=\"documentItems$ | async as documentItems\"\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\">{{ documentItems?.length || 0 }}</sup>\n </h3>\n </div>\n </valtimo-list>\n </ng-container>\n </ng-container>\n</ng-template>\n\n<ng-template #sidebar>\n <valtimo-filter-sidebar>\n <h4 class=\"title\">Search</h4>\n <div class=\"mb-4\">\n <input\n type=\"text\"\n class=\"form-control\"\n placeholder=\"{{ 'dossier.forms.globalSearchPlaceHolder' | translate }}\"\n [ngModel]=\"globalSearchFilter$ | async\"\n (ngModelChange)=\"globalSearchFilterChange($event)\"\n />\n </div>\n\n <div class=\"mb-4\">\n <input\n type=\"number\"\n class=\"form-control\"\n placeholder=\"{{ 'dossier.forms.referenceNumberPlaceHolder' | translate }}\"\n [ngModel]=\"sequence$ | async\"\n (ngModelChange)=\"sequenceChange($event)\"\n />\n </div>\n </valtimo-filter-sidebar>\n</ng-template>\n", styles: [""] }]
|
|
216
|
+
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.DocumentService }, { type: i3.TranslateService }, { type: i4.DossierService }, { type: i5.NGXLogger }]; }, propDecorators: { processStart: [{
|
|
215
217
|
type: ViewChild,
|
|
216
218
|
args: ['processStartModal']
|
|
217
219
|
}] } });
|
|
218
|
-
//# 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-2020 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, ViewChild} from '@angular/core';\nimport {ActivatedRoute, NavigationEnd, Router} from '@angular/router';\nimport {TranslateService} from '@ngx-translate/core';\nimport {DefinitionColumn} from '@valtimo/config';\nimport {\n  DocumentSearchRequest,\n  DocumentSearchRequestImpl,\n  DocumentService,\n  SortState,\n  ProcessDocumentDefinition,\n} from '@valtimo/document';\nimport moment from 'moment';\nimport {combineLatest, Subscription} 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';\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})\nexport class DossierListComponent implements OnInit, OnDestroy {\n  public documentDefinitionName = '';\n  public implementationDefinitions: any;\n  public showCreateDocument = false;\n  public schema: any;\n  public documents: any;\n  public items: Array<any> = [];\n  public fields: Array<any> = [];\n  public processDefinitionListFields: Array<any> = [];\n  public processDocumentDefinitions: ProcessDocumentDefinition[] = [];\n  public pagination = {\n    collectionSize: 0,\n    page: 1,\n    size: 10,\n    maxPaginationItemSize: 5,\n    sort: undefined,\n  };\n  public globalSearchFilter: string | undefined;\n  public sequence: number | undefined;\n  public createdBy: string | undefined;\n  private selectedProcessDocumentDefinition: ProcessDocumentDefinition | null = null;\n  private modalListenerAdded = false;\n  @ViewChild('processStartModal') processStart: DossierProcessStartModalComponent;\n\n  private routerSubscription: Subscription;\n\n  private translationSubscription: Subscription;\n\n  initialSortState: SortState;\n\n  constructor(\n    private route: ActivatedRoute,\n    private router: Router,\n    private documentService: DocumentService,\n    private readonly translateService: TranslateService,\n    private readonly dossierService: DossierService\n  ) {}\n\n  ngOnInit(): void {\n    this.doInit();\n    this.routeEvent(this.router);\n    this.modalListenerAdded = false;\n  }\n\n  ngOnDestroy(): void {\n    this.routerSubscription.unsubscribe();\n    this.translationSubscription.unsubscribe();\n  }\n\n  paginationSet() {\n    this.getData();\n  }\n\n  private routeEvent(router: Router) {\n    this.routerSubscription = router.events.subscribe(e => {\n      if (e instanceof NavigationEnd) {\n        this.doInit();\n        this.getData();\n      }\n    });\n  }\n\n  public doInit() {\n    const documentDefinitionName = this.route.snapshot.paramMap.get('documentDefinitionName') || '';\n    const columns: Array<DefinitionColumn> =\n      this.dossierService.getDefinitionColumns(documentDefinitionName);\n\n    this.documentDefinitionName = documentDefinitionName;\n    this.initialSortState = this.dossierService.getInitialSortState(columns);\n\n    this.openTranslationSubscription(columns);\n  }\n\n  private openTranslationSubscription(columns: Array<DefinitionColumn>): void {\n    this.translationSubscription = combineLatest(\n      columns.map(column => this.translateService.stream(`fieldLabels.${column.translationKey}`))\n    ).subscribe(labels => {\n      this.fields = columns.map((column, index) => ({\n        key: column.propertyName,\n        label: labels[index],\n        sortable: column.sortable,\n        ...(column.viewType && {viewType: column.viewType}),\n      }));\n    });\n  }\n\n  public getData() {\n    this.findDocumentDefinition(this.documentDefinitionName);\n\n    if (this.hasCachedSearchRequest()) {\n      const documentSearchRequest = this.getCachedSearch();\n      this.globalSearchFilter = documentSearchRequest.globalSearchFilter;\n      this.sequence = documentSearchRequest.sequence;\n      this.createdBy = documentSearchRequest.createdBy;\n      this.findDocuments(documentSearchRequest);\n    } else {\n      this.doSearch();\n    }\n\n    this.getAllAssociatedProcessDefinitions();\n  }\n\n  public doSearch() {\n    const documentSearchRequest = this.buildDocumentSearchRequest();\n    this.findDocuments(documentSearchRequest);\n  }\n\n  private findDocuments(documentSearchRequest: DocumentSearchRequest) {\n    return this.documentService.getDocuments(documentSearchRequest).subscribe(documents => {\n      this.documents = documents;\n      this.transformDocuments(this.documents.content);\n      this.pagination.collectionSize = this.documents.totalElements;\n      this.storeSearch(documentSearchRequest);\n    });\n  }\n\n  public getAllAssociatedProcessDefinitions() {\n    this.documentService\n      .findProcessDocumentDefinitions(this.documentDefinitionName)\n      .subscribe(processDocumentDefinitions => {\n        this.processDocumentDefinitions = processDocumentDefinitions.filter(\n          processDocumentDefinition => processDocumentDefinition.canInitializeDocument\n        );\n        this.processDefinitionListFields = [\n          {\n            key: 'processName',\n            label: 'Proces',\n          },\n        ];\n      });\n  }\n\n  public getCachedSearch(): DocumentSearchRequest {\n    const json = JSON.parse(this.getCachedDocumentSearchRequest());\n    return new DocumentSearchRequestImpl(\n      json.definitionName,\n      this.pagination.page - 1,\n      this.pagination.size,\n      json.sequence,\n      json.createdBy,\n      json.globalSearchFilter,\n      json.sort\n    );\n  }\n\n  private buildDocumentSearchRequest(): DocumentSearchRequest {\n    return new DocumentSearchRequestImpl(\n      this.documentDefinitionName,\n      this.pagination.page - 1,\n      this.pagination.size,\n      this.sequence,\n      this.createdBy,\n      this.globalSearchFilter,\n      this.pagination.sort && this.pagination.sort.isSorting\n        ? this.pagination.sort\n        : this.initialSortState\n    );\n  }\n\n  private storeSearch(documentSearchRequest: DocumentSearchRequest) {\n    localStorage.setItem(this.getCachedKey(), JSON.stringify(documentSearchRequest));\n  }\n\n  private getCachedDocumentSearchRequest(): string {\n    return localStorage.getItem(this.getCachedKey()) || '';\n  }\n\n  private hasCachedSearchRequest(): boolean {\n    return localStorage.getItem(this.getCachedKey()) !== null;\n  }\n\n  private getCachedKey(): string {\n    return 'list-search-' + this.documentDefinitionName;\n  }\n\n  public rowClick(document: any) {\n    this.router.navigate([\n      `/dossiers/${this.documentDefinitionName}/document/${document.id}/${DefaultTabs.summary}`,\n    ]);\n  }\n\n  public startDossier() {\n    if (this.processDocumentDefinitions.length > 1) {\n      $('#startProcess').modal('show');\n    } else {\n      this.selectedProcessDocumentDefinition = this.processDocumentDefinitions[0];\n      this.showStartProcessModal();\n    }\n  }\n\n  private showStartProcessModal() {\n    if (this.selectedProcessDocumentDefinition !== null) {\n      this.processStart.openModal(this.selectedProcessDocumentDefinition);\n      this.selectedProcessDocumentDefinition = null;\n    }\n  }\n\n  public selectProcess(processDocumentDefinition: ProcessDocumentDefinition) {\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  private findDocumentDefinition(documentDefinitionName: string) {\n    this.documentService.getDocumentDefinition(documentDefinitionName).subscribe(definition => {\n      this.schema = definition.schema;\n    });\n  }\n\n  private transformDocuments(documentsContent: Array<any>) {\n    this.items = documentsContent.map(document => {\n      const {content, ...others} = document;\n      return {...content, ...others};\n    });\n  }\n\n  public paginationClicked(page: number) {\n    this.pagination.page = page;\n    this.doSearch();\n  }\n\n  public sortChanged(sortState: SortState) {\n    this.pagination.sort = sortState;\n    this.doSearch();\n  }\n\n  public getInitialSortState(): SortState {\n    if (this.hasCachedSearchRequest()) {\n      const cachedRequest = JSON.parse(this.getCachedDocumentSearchRequest());\n      return cachedRequest.sort ? cachedRequest.sort : this.initialSortState;\n    }\n    return this.initialSortState;\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 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 *ngTemplateOutlet=\"sidebar\"></ng-container>\n\n<div class=\"main-content pt-0\">\n  <div class=\"container-fluid\">\n    <div class=\"col-12 px-0 mb-5\">\n      <div>\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]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n            placement=\"bottom\"\n            [disabled]=\"processDocumentDefinitions.length === 0\"\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 processDocumentDefinitions\"\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-widget>\n        <valtimo-list\n          [items]=\"items\"\n          [fields]=\"fields\"\n          (rowClicked)=\"rowClick($event)\"\n          [pagination]=\"pagination\"\n          [viewMode]=\"true\"\n          [header]=\"true\"\n          paginationIdentifier=\"dossierList\"\n          (paginationClicked)=\"paginationClicked($event)\"\n          (paginationSet)=\"paginationSet()\"\n          [initialSortState]=\"getInitialSortState()\"\n          (sortChanged)=\"sortChanged($event)\"\n        >\n          <div header>\n            <h3 class=\"list-header-title\">\n              {{ schema?.title }}\n              <sup class=\"ml-1 badge badge-pill badge-primary\">{{\n                documents?.content.length || 0\n              }}</sup>\n            </h3>\n          </div>\n        </valtimo-list>\n      </valtimo-widget>\n    </div>\n  </div>\n  <valtimo-dossier-process-start-modal #processStartModal></valtimo-dossier-process-start-modal>\n</div>\n\n<ng-template #sidebar>\n  <valtimo-filter-sidebar>\n    <h4 class=\"title\">Search</h4>\n    <div class=\"mb-4\">\n      <input\n        type=\"text\"\n        class=\"form-control\"\n        placeholder=\"{{ 'dossier.forms.globalSearchPlaceHolder' | translate }}\"\n        [(ngModel)]=\"globalSearchFilter\"\n        (blur)=\"doSearch()\"\n        (keyup.enter)=\"doSearch()\"\n      />\n    </div>\n\n    <div class=\"mb-4\">\n      <input\n        type=\"number\"\n        class=\"form-control\"\n        placeholder=\"{{ 'dossier.forms.referenceNumberPlaceHolder' | translate }}\"\n        [(ngModel)]=\"sequence\"\n        (blur)=\"doSearch()\"\n        (keyup.enter)=\"doSearch()\"\n      />\n    </div>\n  </valtimo-filter-sidebar>\n</ng-template>\n"]}
|
|
220
|
+
//# 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-2020 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, ViewChild} from '@angular/core';\nimport {ActivatedRoute, NavigationEnd, Router} from '@angular/router';\nimport {TranslateService} from '@ngx-translate/core';\nimport {DefinitionColumn} from '@valtimo/config';\nimport {\n  DocumentSearchRequest,\n  DocumentSearchRequestImpl,\n  DocumentService,\n  SortState,\n  ProcessDocumentDefinition,\n  Documents,\n  DocumentDefinition,\n} from '@valtimo/document';\nimport moment from 'moment';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  fromEvent,\n  map,\n  Observable,\n  of,\n  startWith,\n  Subscription,\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 {Pagination, ListField} from '@valtimo/components';\nimport {NGXLogger} from 'ngx-logger';\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})\nexport class DossierListComponent implements OnInit {\n  @ViewChild('processStartModal') processStart: DossierProcessStartModalComponent;\n\n  private selectedProcessDocumentDefinition: ProcessDocumentDefinition | null = null;\n  private modalListenerAdded = false;\n\n  private readonly settingPaginationForDocName$ = new BehaviorSubject<string | undefined>(\n    undefined\n  );\n\n  private 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 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  );\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 columns$: Observable<Array<DefinitionColumn>> =\n    this.documentDefinitionName$.pipe(\n      map(documentDefinitionName =>\n        this.dossierService.getDefinitionColumns(documentDefinitionName)\n      )\n    );\n\n  readonly fields$: Observable<Array<ListField>> = combineLatest([\n    this.columns$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([columns]) =>\n      columns.map((column, index) => ({\n        key: column.propertyName,\n        label: this.translateService.instant(`fieldLabels.${column.translationKey}`),\n        sortable: column.sortable,\n        ...(column.viewType && {viewType: column.viewType}),\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  );\n\n  readonly sequence$ = new BehaviorSubject<number | undefined>(undefined);\n\n  readonly globalSearchFilter$ = new BehaviorSubject<string | undefined>(undefined);\n\n  private readonly createdBy$ = new BehaviorSubject<string | undefined>(undefined);\n\n  private readonly documentSearchRequest$: Observable<DocumentSearchRequest> = combineLatest([\n    this.pagination$,\n    this.documentDefinitionName$,\n    this.sequence$,\n    this.createdBy$,\n    this.globalSearchFilter$,\n  ]).pipe(\n    filter(([pagination]) => !!pagination),\n    map(\n      ([pagination, documentDefinitionName, sequence, createdBy, globalSearchFilter]) =>\n        new DocumentSearchRequestImpl(\n          documentDefinitionName,\n          pagination.page - 1,\n          pagination.size,\n          sequence,\n          createdBy,\n          globalSearchFilter,\n          pagination.sort\n        )\n    )\n  );\n\n  private readonly documentsRequest$: Observable<Documents> = this.documentSearchRequest$.pipe(\n    distinctUntilChanged((prev, curr) => JSON.stringify(prev) === JSON.stringify(curr)),\n    tap(request => {\n      this.storedSearchRequestKey$.pipe(take(1)).subscribe(storedSearchRequestKey => {\n        this.logger.log(`store request in local storage: ${JSON.stringify(request)}`);\n        localStorage.setItem(storedSearchRequestKey, JSON.stringify(request));\n      });\n    }),\n    switchMap(documentSearchRequest => this.documentService.getDocuments(documentSearchRequest)),\n    tap(documents => {\n      this.setCollectionSize(documents);\n    })\n  );\n\n  readonly documentItems$ = this.documentsRequest$.pipe(\n    map(documents =>\n      documents.content.map(document => {\n        const {content, ...others} = document;\n        return {...content, ...others};\n      })\n    )\n  );\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  ) {}\n\n  ngOnInit(): void {\n    this.modalListenerAdded = false;\n  }\n\n  globalSearchFilterChange(searchFilter: string): void {\n    this.globalSearchFilter$.next(searchFilter);\n    this.pageChange(1);\n  }\n\n  sequenceChange(sequence: string): void {\n    this.sequence$.next(Number(sequence));\n    this.pageChange(1);\n  }\n\n  pageChange(newPage: number): void {\n    this.pagination$.pipe(take(1)).subscribe(pagination => {\n      if (pagination && pagination.page !== newPage) {\n        this.logger.log(`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.log(`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.log(`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  private resetPagination(documentDefinitionName): void {\n    this.settingPaginationForDocName$.pipe(take(1)).subscribe(settingPaginationForDocName => {\n      if (documentDefinitionName !== settingPaginationForDocName) {\n        this.pagination$.next(undefined);\n        this.logger.log('clear pagination');\n        this.settingPaginationForDocName$.next(documentDefinitionName);\n        this.setPagination(documentDefinitionName);\n      }\n    });\n  }\n\n  private setPagination(documentDefinitionName: string): void {\n    combineLatest([this.hasStoredSearchRequest$, this.storedSearchRequestKey$, this.columns$])\n      .pipe(take(1))\n      .subscribe(([hasStoredSearchRequest, storedSearchRequestKey, columns]) => {\n        const defaultPagination: Pagination = this.getDefaultPagination(columns);\n        const storedPagination: Pagination = this.getStoredPagination(\n          hasStoredSearchRequest,\n          storedSearchRequestKey\n        );\n\n        this.logger.log(`Set pagination: ${JSON.stringify(storedPagination || defaultPagination)}`);\n        this.pagination$.next(storedPagination || defaultPagination);\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): 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","<!--\n  ~ Copyright 2015-2020 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 *ngTemplateOutlet=\"sidebar\"></ng-container>\n\n<div class=\"main-content pt-0\">\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\"\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-widget>\n        <ng-container *ngTemplateOutlet=\"list\"></ng-container>\n      </valtimo-widget>\n    </div>\n  </div>\n  <valtimo-dossier-process-start-modal #processStartModal></valtimo-dossier-process-start-modal>\n</div>\n\n<ng-template #list>\n  <ng-container *ngIf=\"paginationCopy$ | async as pagination\">\n    <ng-container *ngIf=\"fields$ | async as fields\">\n      <valtimo-list\n        *ngIf=\"documentItems$ | async as documentItems\"\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\">{{ documentItems?.length || 0 }}</sup>\n          </h3>\n        </div>\n      </valtimo-list>\n    </ng-container>\n  </ng-container>\n</ng-template>\n\n<ng-template #sidebar>\n  <valtimo-filter-sidebar>\n    <h4 class=\"title\">Search</h4>\n    <div class=\"mb-4\">\n      <input\n        type=\"text\"\n        class=\"form-control\"\n        placeholder=\"{{ 'dossier.forms.globalSearchPlaceHolder' | translate }}\"\n        [ngModel]=\"globalSearchFilter$ | async\"\n        (ngModelChange)=\"globalSearchFilterChange($event)\"\n      />\n    </div>\n\n    <div class=\"mb-4\">\n      <input\n        type=\"number\"\n        class=\"form-control\"\n        placeholder=\"{{ 'dossier.forms.referenceNumberPlaceHolder' | translate }}\"\n        [ngModel]=\"sequence$ | async\"\n        (ngModelChange)=\"sequenceChange($event)\"\n      />\n    </div>\n  </valtimo-filter-sidebar>\n</ng-template>\n"]}
|