@valtimo/dossier 10.5.0 → 10.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/esm2020/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.mjs +16 -12
  2. package/esm2020/lib/dossier-detail/tab/summary/summary.component.mjs +1 -1
  3. package/esm2020/lib/dossier-list/dossier-list.component.mjs +153 -281
  4. package/esm2020/lib/dossier-list-actions/dossier-list-actions.component.mjs +86 -0
  5. package/esm2020/lib/dossier-process-start-modal/dossier-process-start-modal.component.mjs +113 -45
  6. package/esm2020/lib/dossier-routing.module.mjs +2 -2
  7. package/esm2020/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +107 -50
  8. package/esm2020/lib/dossier.module.mjs +17 -4
  9. package/esm2020/lib/models/dossier-parameters.model.mjs +1 -1
  10. package/esm2020/lib/services/dossier-column.service.mjs +24 -9
  11. package/esm2020/lib/services/dossier-list-assignee.service.mjs +82 -0
  12. package/esm2020/lib/services/dossier-list-pagination.service.mjs +116 -0
  13. package/esm2020/lib/services/dossier-list-search.service.mjs +66 -0
  14. package/esm2020/lib/services/dossier-list.service.mjs +60 -0
  15. package/esm2020/lib/services/dossier-parameter.service.mjs +71 -31
  16. package/esm2020/lib/services/index.mjs +5 -1
  17. package/fesm2015/valtimo-dossier.mjs +906 -457
  18. package/fesm2015/valtimo-dossier.mjs.map +1 -1
  19. package/fesm2020/valtimo-dossier.mjs +906 -460
  20. package/fesm2020/valtimo-dossier.mjs.map +1 -1
  21. package/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.d.ts +3 -6
  22. package/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -1
  23. package/lib/dossier-detail/tab/summary/summary.component.d.ts +9 -9
  24. package/lib/dossier-detail/tab/summary/summary.component.d.ts.map +1 -1
  25. package/lib/dossier-list/dossier-list.component.d.ts +45 -56
  26. package/lib/dossier-list/dossier-list.component.d.ts.map +1 -1
  27. package/lib/dossier-list-actions/dossier-list-actions.component.d.ts +28 -0
  28. package/lib/dossier-list-actions/dossier-list-actions.component.d.ts.map +1 -0
  29. package/lib/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +14 -5
  30. package/lib/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
  31. package/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts +12 -5
  32. package/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -1
  33. package/lib/dossier.module.d.ts +31 -29
  34. package/lib/dossier.module.d.ts.map +1 -1
  35. package/lib/models/dossier-parameters.model.d.ts +1 -0
  36. package/lib/models/dossier-parameters.model.d.ts.map +1 -1
  37. package/lib/services/dossier-column.service.d.ts +5 -1
  38. package/lib/services/dossier-column.service.d.ts.map +1 -1
  39. package/lib/services/dossier-list-assignee.service.d.ts +27 -0
  40. package/lib/services/dossier-list-assignee.service.d.ts.map +1 -0
  41. package/lib/services/dossier-list-pagination.service.d.ts +30 -0
  42. package/lib/services/dossier-list-pagination.service.d.ts.map +1 -0
  43. package/lib/services/dossier-list-search.service.d.ts +22 -0
  44. package/lib/services/dossier-list-search.service.d.ts.map +1 -0
  45. package/lib/services/dossier-list.service.d.ts +17 -0
  46. package/lib/services/dossier-list.service.d.ts.map +1 -0
  47. package/lib/services/dossier-parameter.service.d.ts +9 -1
  48. package/lib/services/dossier-parameter.service.d.ts.map +1 -1
  49. package/lib/services/index.d.ts +4 -0
  50. package/lib/services/index.d.ts.map +1 -1
  51. package/package.json +1 -1
@@ -13,131 +13,110 @@
13
13
  * See the License for the specific language governing permissions and
14
14
  * limitations under the License.
15
15
  */
16
- import { Component, ViewChild } from '@angular/core';
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 "@valtimo/document";
25
- import * as i3 from "@ngx-translate/core";
26
- import * as i4 from "../dossier.service";
27
- import * as i5 from "ngx-logger";
28
- import * as i6 from "@valtimo/config";
29
- import * as i7 from "../services";
30
- import * as i8 from "@angular/common";
31
- import * as i9 from "@valtimo/components";
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 "@angular/common";
28
+ import * as i7 from "@valtimo/components";
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, router, documentService, translateService, dossierService, logger, configService, dossierColumnService, dossierParameterService) {
32
+ constructor(route, translateService, listService, columnService, assigneeService, paginationService, searchService, parameterService, documentService, router, configService) {
37
33
  this.route = route;
38
- this.router = router;
39
- this.documentService = documentService;
40
34
  this.translateService = translateService;
41
- this.dossierService = dossierService;
42
- this.logger = logger;
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.dossierColumnService = dossierColumnService;
45
- this.dossierParameterService = dossierParameterService;
46
- this.dossierVisibleTabs = null;
47
- this.defaultAssigneeFilter = 'ALL';
48
- this.selectedProcessDocumentDefinition = null;
49
- this.modalListenerAdded = false;
50
- this.settingPaginationForDocName$ = new BehaviorSubject(undefined);
51
- this.loading$ = new BehaviorSubject(true);
52
- this.loadingDocumentSearchFields$ = new BehaviorSubject(true);
53
- this.documentDefinitionName$ = this.route.params.pipe(map(params => params.documentDefinitionName || ''), tap(documentDefinitionName => {
54
- this.resetPagination(documentDefinitionName);
44
+ this.loadingFields = true;
45
+ this.loadingPagination = true;
46
+ this.loadingSearchFields = true;
47
+ this.loadingAssigneeFilter = true;
48
+ this.loadingDocumentItems = true;
49
+ this.visibleDossierTabs = null;
50
+ this.searchFields$ = this.searchService.documentSearchFields$.pipe(tap(searchFields => {
51
+ this.loadingSearchFields = false;
55
52
  }));
56
- this.hasEnvColumnConfig$ = this.route.params.pipe(map(params => params.documentDefinitionName || ''), map(documentDefinitionName => this.dossierColumnService.hasEnvironmentConfig(documentDefinitionName)));
57
- this.canHaveAssignee$ = this.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.documentService.getCaseSettings(documentDefinitionName)), map(caseSettings => caseSettings?.canHaveAssignee));
58
- this.documentSearchFields$ = this.documentDefinitionName$.pipe(distinctUntilChanged(), tap(() => this.loadingDocumentSearchFields$.next(true)), switchMap(documentDefinitionName => this.documentService.getDocumentSearchFields(documentDefinitionName)), tap(() => this.loadingDocumentSearchFields$.next(false)));
59
- this.associatedProcessDocumentDefinitions$ = this.documentDefinitionName$.pipe(switchMap(documentDefinitionName => documentDefinitionName
60
- ? this.documentService.findProcessDocumentDefinitions(documentDefinitionName)
61
- : of([])), map(processDocumentDefinitions => processDocumentDefinitions.filter(definition => definition.canInitializeDocument)));
62
- this.schema$ = this.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.documentService.getDocumentDefinition(documentDefinitionName)), map(documentDefinition => documentDefinition?.schema), tap(() => {
63
- this.assigneeFilter$.next(this.defaultAssigneeFilter);
53
+ this.documentDefinitionName$ = this.listService.documentDefinitionName$;
54
+ this.schema$ = this.listService.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.documentService.getDocumentDefinition(documentDefinitionName)), map(documentDefinition => documentDefinition?.schema));
55
+ this.searchFieldValues$ = this.parameterService.searchFieldValues$;
56
+ this.assigneeFilter$ = this.assigneeService.assigneeFilter$;
57
+ this._pagination$ = this.paginationService.pagination$.pipe(tap(pagination => {
58
+ this.pagination = pagination;
59
+ this.loadingPagination = false;
64
60
  }));
65
- this.storedSearchRequestKey$ = this.documentDefinitionName$.pipe(map(documentDefinitionName => `list-search-${documentDefinitionName}`));
66
- this.hasStoredSearchRequest$ = this.storedSearchRequestKey$.pipe(map(storedSearchRequestKey => localStorage.getItem(storedSearchRequestKey) !== null));
67
- this.hasApiColumnConfig$ = new BehaviorSubject(false);
68
- this.columns$ = this.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.dossierColumnService.getDefinitionColumns(documentDefinitionName)), map(res => {
69
- this.hasApiColumnConfig$.next(res.hasApiConfig);
61
+ this._hasEnvColumnConfig$ = this.listService.hasEnvColumnConfig$;
62
+ this._hasApiColumnConfig$ = new BehaviorSubject(false);
63
+ this._canHaveAssignee$ = this.assigneeService.canHaveAssignee$;
64
+ this._searchSwitch$ = this.searchService.searchSwitch$;
65
+ this._columns$ = this.listService.documentDefinitionName$.pipe(switchMap(documentDefinitionName => this.columnService.getDefinitionColumns(documentDefinitionName)), map(res => {
66
+ this._hasApiColumnConfig$.next(res.hasApiConfig);
70
67
  return res.columns;
68
+ }), tap(columns => {
69
+ this.listService.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
70
+ this.paginationService.setPagination(documentDefinitionName, columns);
71
+ });
71
72
  }));
72
- this.ASSIGNEE_KEY = 'assigneeFullName';
73
73
  this.fields$ = combineLatest([
74
- this.columns$,
75
- this.canHaveAssignee$,
76
- this.hasEnvColumnConfig$,
74
+ this._canHaveAssignee$,
75
+ this._columns$,
76
+ this._hasEnvColumnConfig$,
77
77
  this.translateService.stream('key'),
78
- ]).pipe(map(([columns, canHaveAssignee, hasEnvConfig]) => [
79
- ...columns
80
- .map(column => {
81
- const translationKey = `fieldLabels.${column.translationKey}`;
82
- const translation = this.translateService.instant(translationKey);
83
- const validTranslation = translation !== translationKey && translation;
84
- return {
85
- key: hasEnvConfig ? column.propertyName : column.translationKey,
86
- label: column.title || validTranslation || column.translationKey,
87
- sortable: column.sortable,
88
- ...(column.viewType && { viewType: column.viewType }),
89
- ...(column.enum && { enum: column.enum }),
90
- ...(column.format && { format: column.format }),
91
- };
92
- })
93
- // Filter out assignee column if the case type can not have an assignee
94
- .filter(column => {
95
- if (column?.key === this.ASSIGNEE_KEY && !canHaveAssignee) {
96
- return false;
78
+ ]).pipe(tap(([canHaveAssignee]) => {
79
+ this.canHaveAssignee = canHaveAssignee;
80
+ }), map(([canHaveAssignee, columns, hasEnvConfig]) => {
81
+ const filteredAssigneeColumns = this.assigneeService.filterAssigneeColumns(columns, canHaveAssignee);
82
+ const listFields = this.columnService.mapDefinitionColumnsToListFields(filteredAssigneeColumns, hasEnvConfig);
83
+ const fieldsToReturn = this.assigneeService.addAssigneeListField(columns, listFields, canHaveAssignee);
84
+ return fieldsToReturn;
85
+ }), tap(listFields => {
86
+ const defaultListField = listFields.find(field => field.default);
87
+ // set default sort state if no pagination query parameters for sorting are available
88
+ this.parameterService.queryPaginationParams$
89
+ .pipe(take(1))
90
+ .subscribe(queryPaginationParams => {
91
+ if (defaultListField && !queryPaginationParams?.sort.isSorting) {
92
+ const sortDirection = typeof defaultListField.default === 'string' ? defaultListField.default : 'DESC';
93
+ this.paginationService.sortChanged({
94
+ isSorting: true,
95
+ state: { name: defaultListField.key, direction: sortDirection },
96
+ });
97
97
  }
98
- return true;
99
- }),
100
- // 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
101
- ...(canHaveAssignee && !columns.find(column => column.propertyName === this.ASSIGNEE_KEY)
102
- ? [
103
- {
104
- key: this.ASSIGNEE_KEY,
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$,
98
+ });
99
+ }), tap(() => {
100
+ this.loadingFields = false;
101
+ }));
102
+ 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)));
103
+ this._documentsRequest$ = combineLatest([
104
+ this._documentSearchRequest$,
126
105
  this.searchFieldValues$,
127
106
  this.assigneeFilter$,
128
- this.hasEnvColumnConfig$,
129
- this.hasApiColumnConfig$,
130
- ]).pipe(distinctUntilChanged(([prevSearchRequest, prevSearchValues, prevAssigneeFilter], [currSearchRequest, currSearchValues, currAssigneeFilter]) => JSON.stringify({ ...prevSearchRequest, ...prevSearchValues }) + prevAssigneeFilter ===
131
- JSON.stringify({ ...currSearchRequest, ...currSearchValues }) + currAssigneeFilter), tap(([documentSearchRequest]) => {
132
- this.storedSearchRequestKey$.pipe(take(1)).subscribe(storedSearchRequestKey => {
133
- this.logger.debug(`store request in local storage: ${JSON.stringify(documentSearchRequest)}`);
134
- localStorage.setItem(storedSearchRequestKey, JSON.stringify(documentSearchRequest));
135
- });
136
- }), switchMap(([documentSearchRequest, searchValues, assigneeFilter, hasEnvColumnConfig, hasApiColumnConfig,]) => {
107
+ this._hasEnvColumnConfig$,
108
+ this._hasApiColumnConfig$,
109
+ this._searchSwitch$,
110
+ ]).pipe(distinctUntilChanged(([prevSearchRequest, prevSearchValues, prevAssigneeFilter, prevHasEnvColumnConfig, prevHasApiColumnConfig, prevSearchSwitch,], [currSearchRequest, currSearchValues, currAssigneeFilter, currHasEnvColumnConfig, currHasApiColumnConfig, currSearchSwitch,]) => JSON.stringify({ ...prevSearchRequest, ...prevSearchValues }) +
111
+ prevAssigneeFilter +
112
+ prevSearchSwitch ===
113
+ JSON.stringify({ ...currSearchRequest, ...currSearchValues }) +
114
+ currAssigneeFilter +
115
+ currSearchSwitch), switchMap(([documentSearchRequest, searchValues, assigneeFilter, hasEnvColumnConfig, hasApiColumnConfig,]) => {
137
116
  if ((Object.keys(searchValues) || []).length > 0) {
138
117
  return hasEnvColumnConfig || !hasApiColumnConfig
139
- ? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.mapSearchValuesToFilters(searchValues))
140
- : this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.mapSearchValuesToFilters(searchValues));
118
+ ? this.documentService.getDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.searchService.mapSearchValuesToFilters(searchValues))
119
+ : this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter, this.searchService.mapSearchValuesToFilters(searchValues));
141
120
  }
142
121
  else {
143
122
  return hasEnvColumnConfig || !hasApiColumnConfig
@@ -145,202 +124,95 @@ export class DossierListComponent {
145
124
  : this.documentService.getSpecifiedDocumentsSearch(documentSearchRequest, 'AND', assigneeFilter);
146
125
  }
147
126
  }), tap(documents => {
148
- this.setCollectionSize(documents);
149
- this.checkPage(documents);
127
+ this.paginationService.setCollectionSize(documents);
128
+ this.paginationService.checkPage(documents);
150
129
  }));
151
130
  this.documentItems$ = combineLatest([
152
- this.documentsRequest$,
153
- this.hasEnvColumnConfig$,
154
- this.hasApiColumnConfig$,
155
- ]).pipe(map(([documents, hasEnvColumnConfig, hasApiColumnConfig]) => {
156
- if (hasEnvColumnConfig || !hasApiColumnConfig) {
157
- const docsToMap = documents;
158
- return documents.content.map(document => {
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;
131
+ this._documentsRequest$,
132
+ this._hasEnvColumnConfig$,
133
+ this._hasApiColumnConfig$,
134
+ ]).pipe(map(([documents, hasEnvColumnConfig, hasApiColumnConfig]) => this.listService.mapDocuments(documents, hasEnvColumnConfig, hasApiColumnConfig)), tap(() => {
135
+ this.loadingAssigneeFilter = false;
136
+ this.loadingDocumentItems = false;
137
+ }));
176
138
  }
177
139
  ngOnInit() {
178
- this.modalListenerAdded = false;
179
- this.setSearchFieldParametersInComponent();
140
+ this.setVisibleTabs();
141
+ this.openDocumentDefinitionNameSubscription();
180
142
  }
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
- });
188
- }
189
- pageSizeChange(newPageSize) {
190
- this.pagination$.pipe(take(1)).subscribe(pagination => {
191
- if (pagination && pagination.size !== newPageSize) {
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
- });
143
+ ngOnDestroy() {
144
+ this._documentDefinitionNameSubscription?.unsubscribe();
198
145
  }
199
- sortChanged(newSortState) {
200
- this.pagination$.pipe(take(1)).subscribe(pagination => {
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
- });
146
+ search(searchFieldValues) {
147
+ this.searchService.search(searchFieldValues);
206
148
  }
207
149
  rowClick(document) {
208
- this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
150
+ this.listService.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
209
151
  this.router.navigate([
210
152
  `/dossiers/${documentDefinitionName}/document/${document.id}/${DefaultTabs.summary}`,
211
153
  ]);
212
154
  });
213
155
  }
214
- startDossier() {
215
- this.associatedProcessDocumentDefinitions$
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
- });
156
+ pageChange(newPage) {
157
+ this.paginationService.pageChange(newPage);
226
158
  }
227
- selectProcess(processDocumentDefinition) {
228
- const modal = $('#startProcess');
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');
159
+ pageSizeChange(newPageSize) {
160
+ this.paginationService.pageSizeChange(newPageSize);
235
161
  }
236
- search(searchFieldValues) {
237
- this.searchFieldValues$.next(searchFieldValues || {});
238
- this.dossierParameterService.setSearchParameters(searchFieldValues);
162
+ sortChanged(newSortState) {
163
+ this.paginationService.sortChanged(newSortState);
239
164
  }
240
165
  tabChange(tab) {
241
- this.pagination$.pipe(take(1)).subscribe(pagination => {
242
- this.pagination$.next({ ...pagination, page: 1 });
243
- });
244
- this.assigneeFilter$.next(tab.nextId.toUpperCase());
245
- }
246
- mapSearchValuesToFilters(values) {
247
- const filters = [];
248
- Object.keys(values).forEach(valueKey => {
249
- const searchValue = values[valueKey];
250
- if (searchValue.start) {
251
- filters.push({ key: valueKey, rangeFrom: searchValue.start, rangeTo: searchValue.end });
252
- }
253
- else if (Array.isArray(searchValue)) {
254
- filters.push({ key: valueKey, values: searchValue });
255
- }
256
- else {
257
- filters.push({ key: valueKey, values: [searchValue] });
258
- }
166
+ this.paginationService.setPage(1);
167
+ this.assigneeService.setAssigneeFilter(tab.nextId.toUpperCase());
168
+ }
169
+ refresh() {
170
+ this.searchService.refresh();
171
+ }
172
+ openDocumentDefinitionNameSubscription() {
173
+ this._documentDefinitionNameSubscription = this.route.params
174
+ .pipe(map(params => params?.documentDefinitionName), filter(docDefName => !!docDefName), distinctUntilChanged())
175
+ .subscribe(documentDefinitonName => {
176
+ if (this._previousDocumentDefinitionName) {
177
+ this.parameterService.clearParameters();
178
+ this.parameterService.clearSearchFieldValues();
179
+ }
180
+ this._previousDocumentDefinitionName = documentDefinitonName;
181
+ this.setLoading();
182
+ this.paginationService.clearPagination();
183
+ this.assigneeService.resetAssigneeFilter();
184
+ this.listService.setDocumentDefinitionName(documentDefinitonName);
259
185
  });
260
- return filters;
261
186
  }
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
- });
187
+ setLoading() {
188
+ this.loadingFields = true;
189
+ this.loadingPagination = true;
190
+ this.loadingSearchFields = true;
191
+ this.loadingAssigneeFilter = true;
192
+ this.loadingDocumentItems = true;
271
193
  }
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
- }
309
- });
310
- }
311
- showStartProcessModal() {
312
- if (this.selectedProcessDocumentDefinition !== null) {
313
- this.processStart.openModal(this.selectedProcessDocumentDefinition);
314
- this.selectedProcessDocumentDefinition = null;
315
- }
316
- }
317
- checkPage(documents) {
318
- this.pagination$.pipe(take(1)).subscribe(pagination => {
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
- });
194
+ setVisibleTabs() {
195
+ this.visibleDossierTabs = this.configService.config?.visibleDossierListTabs || null;
335
196
  }
336
197
  }
337
- DossierListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DossierListComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.DocumentService }, { token: i3.TranslateService }, { token: i4.DossierService }, { token: i5.NGXLogger }, { token: i6.ConfigService }, { token: i7.DossierColumnService }, { token: i7.DossierParameterService }], target: i0.ɵɵFactoryTarget.Component });
338
- DossierListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DossierListComponent, selector: "valtimo-dossier-list", providers: [DossierParameterService], viewQueries: [{ propertyName: "processStart", first: true, predicate: ["processStartModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<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", styles: [""], dependencies: [{ kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i9.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState", "lastColumnTemplate"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }, { kind: "component", type: i9.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { kind: "component", type: i9.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "directive", type: i10.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "component", type: i9.SearchFieldsComponent, selector: "valtimo-search-fields", inputs: ["loading", "searchFields", "documentDefinitionName", "setValuesSubject$"], outputs: ["doSearch"] }, { kind: "directive", type: i10.NgbNav, selector: "[ngbNav]", inputs: ["activeId", "animation", "destroyOnHide", "orientation", "roles", "keyboard"], outputs: ["activeIdChange", "shown", "hidden", "navChange"], exportAs: ["ngbNav"] }, { kind: "directive", type: i10.NgbNavItem, selector: "[ngbNavItem]", inputs: ["destroyOnHide", "disabled", "domId", "ngbNavItem"], outputs: ["shown", "hidden"], exportAs: ["ngbNavItem"] }, { kind: "directive", type: i10.NgbNavLink, selector: "a[ngbNavLink]" }, { kind: "component", type: i11.DossierProcessStartModalComponent, selector: "valtimo-dossier-process-start-modal" }, { kind: "pipe", type: i8.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] });
198
+ DossierListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", 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 }], target: i0.ɵɵFactoryTarget.Component });
199
+ DossierListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DossierListComponent, selector: "valtimo-dossier-list", providers: [
200
+ DossierListService,
201
+ DossierColumnService,
202
+ DossierListAssigneeService,
203
+ DossierParameterService,
204
+ DossierListPaginationService,
205
+ DossierListSearchService,
206
+ ], 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 {{ obs.schema?.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: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i7.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState", "lastColumnTemplate"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }, { kind: "component", type: i7.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { kind: "component", type: i7.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "component", type: i7.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: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
339
207
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DossierListComponent, decorators: [{
340
208
  type: Component,
341
- args: [{ selector: 'valtimo-dossier-list', providers: [DossierParameterService], 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<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" }]
342
- }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.DocumentService }, { type: i3.TranslateService }, { type: i4.DossierService }, { type: i5.NGXLogger }, { type: i6.ConfigService }, { type: i7.DossierColumnService }, { type: i7.DossierParameterService }]; }, propDecorators: { processStart: [{
343
- type: ViewChild,
344
- args: ['processStartModal']
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"]}
209
+ args: [{ selector: 'valtimo-dossier-list', providers: [
210
+ DossierListService,
211
+ DossierColumnService,
212
+ DossierListAssigneeService,
213
+ DossierParameterService,
214
+ DossierListPaginationService,
215
+ DossierListSearchService,
216
+ ], 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 {{ obs.schema?.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" }]
217
+ }], 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 }]; } });
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-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 {ListField, 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  );\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        } 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.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  ) {}\n\n  ngOnInit(): void {\n    this.setVisibleTabs();\n    this.openDocumentDefinitionNameSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this._documentDefinitionNameSubscription?.unsubscribe();\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.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          {{ obs.schema?.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"]}