@valtimo/dossier 5.11.0 → 5.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/dossier-detail/dossier-detail.component.mjs +66 -22
- package/esm2020/lib/dossier-detail/tab/summary/summary.component.mjs +36 -29
- package/esm2020/lib/dossier-detail/tab/zaakobjecten/zaakobjecten.component.mjs +1 -1
- package/esm2020/lib/dossier-list/dossier-list.component.mjs +17 -12
- package/esm2020/lib/dossier.module.mjs +6 -3
- package/esm2020/lib/models/index.mjs +2 -1
- package/esm2020/lib/models/search.model.mjs +2 -0
- package/fesm2015/valtimo-dossier.mjs +126 -73
- package/fesm2015/valtimo-dossier.mjs.map +1 -1
- package/fesm2020/valtimo-dossier.mjs +125 -71
- package/fesm2020/valtimo-dossier.mjs.map +1 -1
- package/lib/dossier-detail/dossier-detail.component.d.ts +22 -11
- package/lib/dossier-detail/dossier-detail.component.d.ts.map +1 -1
- package/lib/dossier-detail/tab/summary/summary.component.d.ts +4 -2
- package/lib/dossier-detail/tab/summary/summary.component.d.ts.map +1 -1
- package/lib/dossier-list/dossier-list.component.d.ts +9 -2
- package/lib/dossier-list/dossier-list.component.d.ts.map +1 -1
- package/lib/dossier.module.d.ts +1 -1
- package/lib/dossier.module.d.ts.map +1 -1
- package/lib/models/index.d.ts +1 -0
- package/lib/models/index.d.ts.map +1 -1
- package/lib/models/search.model.d.ts +11 -0
- package/lib/models/search.model.d.ts.map +1 -0
- package/package.json +1 -1
|
@@ -15,7 +15,8 @@
|
|
|
15
15
|
*/
|
|
16
16
|
import { Component, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
17
17
|
import { TabLoaderImpl } from '../models';
|
|
18
|
-
import
|
|
18
|
+
import moment from 'moment';
|
|
19
|
+
import { BehaviorSubject, combineLatest, from, map, of, startWith, switchMap, take, tap, } from 'rxjs';
|
|
19
20
|
import * as i0 from "@angular/core";
|
|
20
21
|
import * as i1 from "@ngx-translate/core";
|
|
21
22
|
import * as i2 from "@valtimo/document";
|
|
@@ -24,11 +25,13 @@ import * as i4 from "@angular/router";
|
|
|
24
25
|
import * as i5 from "@angular/common";
|
|
25
26
|
import * as i6 from "../tab.service";
|
|
26
27
|
import * as i7 from "@valtimo/config";
|
|
27
|
-
import * as i8 from "
|
|
28
|
-
import * as i9 from "
|
|
29
|
-
import * as i10 from "@
|
|
28
|
+
import * as i8 from "keycloak-angular";
|
|
29
|
+
import * as i9 from "ngx-logger";
|
|
30
|
+
import * as i10 from "@valtimo/components";
|
|
31
|
+
import * as i11 from "../dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component";
|
|
32
|
+
import * as i12 from "@ng-bootstrap/ng-bootstrap";
|
|
30
33
|
export class DossierDetailComponent {
|
|
31
|
-
constructor(componentFactoryResolver, translateService, documentService, processService, route, router, location, tabService, configService) {
|
|
34
|
+
constructor(componentFactoryResolver, translateService, documentService, processService, route, router, location, tabService, configService, keyCloakService, logger) {
|
|
32
35
|
this.componentFactoryResolver = componentFactoryResolver;
|
|
33
36
|
this.translateService = translateService;
|
|
34
37
|
this.documentService = documentService;
|
|
@@ -38,11 +41,31 @@ export class DossierDetailComponent {
|
|
|
38
41
|
this.location = location;
|
|
39
42
|
this.tabService = tabService;
|
|
40
43
|
this.configService = configService;
|
|
44
|
+
this.keyCloakService = keyCloakService;
|
|
45
|
+
this.logger = logger;
|
|
41
46
|
this.document = null;
|
|
42
47
|
this.tabLoader = null;
|
|
43
48
|
this.processDefinitionListFields = [];
|
|
44
49
|
this.processDocumentDefinitions = [];
|
|
45
50
|
this.customDossierHeaderItems = [];
|
|
51
|
+
this.refreshDocument$ = new BehaviorSubject(null);
|
|
52
|
+
this.assigneeId$ = new BehaviorSubject('');
|
|
53
|
+
this.document$ = this.refreshDocument$.pipe(switchMap(() => this.route.params), map(params => params?.documentId), switchMap(documentId => documentId ? this.documentService.getDocument(this.documentId) : of(null)), tap(document => {
|
|
54
|
+
if (document) {
|
|
55
|
+
this.assigneeId$.next(document.assigneeId);
|
|
56
|
+
this.document = document;
|
|
57
|
+
if (this.configService.config.customDossierHeader?.hasOwnProperty(this.documentDefinitionName.toLowerCase()) &&
|
|
58
|
+
this.customDossierHeaderItems.length === 0) {
|
|
59
|
+
this.configService.config.customDossierHeader[this.documentDefinitionName.toLowerCase()]?.forEach(item => this.getCustomDossierHeaderItem(item));
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}));
|
|
63
|
+
this.userId$ = from(this.keyCloakService.isLoggedIn()).pipe(switchMap(() => this.keyCloakService.loadUserProfile()), map(profile => profile?.id));
|
|
64
|
+
this.isAssigning$ = new BehaviorSubject(false);
|
|
65
|
+
this.isAssignedToCurrentUser$ = combineLatest([
|
|
66
|
+
this.assigneeId$,
|
|
67
|
+
this.userId$,
|
|
68
|
+
]).pipe(map(([assigneeId, userId]) => assigneeId && userId && assigneeId === userId), startWith(true));
|
|
46
69
|
this.snapshot = this.route.snapshot.paramMap;
|
|
47
70
|
this.documentDefinitionName = this.snapshot.get('documentDefinitionName') || '';
|
|
48
71
|
this.documentId = this.snapshot.get('documentId') || '';
|
|
@@ -55,7 +78,6 @@ export class DossierDetailComponent {
|
|
|
55
78
|
.subscribe(definition => {
|
|
56
79
|
this.documentDefinitionNameTitle = definition.schema.title;
|
|
57
80
|
});
|
|
58
|
-
this.getCustomDossierHeader();
|
|
59
81
|
this.initialTabName = this.snapshot.get('tab');
|
|
60
82
|
this.tabLoader.initial(this.initialTabName);
|
|
61
83
|
this.getAllAssociatedProcessDefinitions();
|
|
@@ -76,13 +98,17 @@ export class DossierDetailComponent {
|
|
|
76
98
|
startProcess(processDocumentDefinition) {
|
|
77
99
|
this.supportingProcessStart.openModal(processDocumentDefinition, this.documentId);
|
|
78
100
|
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
101
|
+
claimAssignee() {
|
|
102
|
+
this.isAssigning$.next(true);
|
|
103
|
+
this.userId$
|
|
104
|
+
.pipe(take(1), switchMap(userId => this.documentService.assignHandlerToDocument(this.documentId, userId)))
|
|
105
|
+
.subscribe(() => {
|
|
106
|
+
this.isAssigning$.next(false);
|
|
107
|
+
this.refreshDocument$.next(null);
|
|
108
|
+
}, () => {
|
|
109
|
+
this.isAssigning$.next(false);
|
|
110
|
+
this.logger.debug('Something went wrong while assigning user to case');
|
|
111
|
+
});
|
|
86
112
|
}
|
|
87
113
|
getCustomDossierHeaderItem(item) {
|
|
88
114
|
this.customDossierHeaderItems.push({
|
|
@@ -90,27 +116,45 @@ export class DossierDetailComponent {
|
|
|
90
116
|
columnSize: item['columnSize'] || 3,
|
|
91
117
|
textSize: item['textSize'] || 'md',
|
|
92
118
|
customClass: item['customClass'] || '',
|
|
119
|
+
modifier: item['modifier'] || '',
|
|
93
120
|
value: item['propertyPaths']?.reduce((prev, curr) => prev + this.getStringFromDocumentPath(item, curr), ''),
|
|
94
121
|
});
|
|
95
122
|
}
|
|
96
123
|
getStringFromDocumentPath(item, path) {
|
|
97
124
|
const prefix = item['propertyPaths'].indexOf(path) > 0 ? ' ' : '';
|
|
98
|
-
|
|
99
|
-
const
|
|
100
|
-
|
|
101
|
-
|
|
125
|
+
let string = path.split('.').reduce((o, i) => o[i], this.document.content) || item['noValueText'] || '';
|
|
126
|
+
const dateFormats = [
|
|
127
|
+
moment.ISO_8601,
|
|
128
|
+
"MM-DD-YYYY",
|
|
129
|
+
"DD-MM-YYYY",
|
|
130
|
+
"YYYY-MM-DD"
|
|
131
|
+
];
|
|
132
|
+
switch (item['modifier']) {
|
|
133
|
+
case 'age': {
|
|
134
|
+
if (moment(string, dateFormats, true).isValid()) {
|
|
135
|
+
string = moment().diff(string, 'years');
|
|
136
|
+
}
|
|
137
|
+
break;
|
|
138
|
+
}
|
|
139
|
+
default: {
|
|
140
|
+
if (moment(string, dateFormats, true).isValid()) {
|
|
141
|
+
string = moment(string).format('DD-MM-YYYY');
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
return prefix + string;
|
|
102
146
|
}
|
|
103
147
|
}
|
|
104
|
-
DossierDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.TranslateService }, { token: i2.DocumentService }, { token: i3.ProcessService }, { token: i4.ActivatedRoute }, { token: i4.Router }, { token: i5.Location }, { token: i6.TabService }, { token: i7.ConfigService }], target: i0.ɵɵFactoryTarget.Component });
|
|
105
|
-
DossierDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailComponent, selector: "valtimo-dossier-detail", viewQueries: [{ propertyName: "viewContainerRef", first: true, predicate: ["tabContainer"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "supportingProcessStart", first: true, predicate: ["supportingProcessStartModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"main-content\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <valtimo-widget>\n <div class=\"card-header bg-light card-header-divider pb-2\">\n <div class=\"row\">\n <div class=\"col\">\n <
|
|
148
|
+
DossierDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.TranslateService }, { token: i2.DocumentService }, { token: i3.ProcessService }, { token: i4.ActivatedRoute }, { token: i4.Router }, { token: i5.Location }, { token: i6.TabService }, { token: i7.ConfigService }, { token: i8.KeycloakService }, { token: i9.NGXLogger }], target: i0.ɵɵFactoryTarget.Component });
|
|
149
|
+
DossierDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailComponent, selector: "valtimo-dossier-detail", viewQueries: [{ propertyName: "viewContainerRef", first: true, predicate: ["tabContainer"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "supportingProcessStart", first: true, predicate: ["supportingProcessStartModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"main-content\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <valtimo-widget>\n <div class=\"card-header bg-light card-header-divider pb-2\">\n <div class=\"row\">\n <div class=\"col\">\n <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n </div>\n <div class=\"btn-group mt-m3px mb-3 col-auto\">\n <valtimo-extension\n module=\"dossier\"\n page=\"dossier-detail\"\n section=\"card-header\"\n ></valtimo-extension>\n <ng-container *ngTemplateOutlet=\"claimButton\"></ng-container>\n <div class=\"dropdown\">\n <button\n class=\"btn btn-primary dropdown-toggle\"\n type=\"button\"\n id=\"startProcessDropdown\"\n placement=\"bottom\"\n [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n [disabled]=\"processDocumentDefinitions.length === 0\"\n data-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n >\n <span>{{ 'dossier.startSubProcess' | translate }}</span>\n <i class=\"ml-1 mdi mdi-chevron-down\"></i>\n </button>\n <div\n class=\"dropdown-menu dropdown-menu-right\"\n aria-labelledby=\"startProcessDropdown\"\n >\n <button\n *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n class=\"dropdown-item p\"\n href=\"#\"\n (click)=\"startProcess(processDocumentDefinition)\"\n >\n {{ processDocumentDefinition.processName }}\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n <ul class=\"nav nav-tabs\">\n <li class=\"nav-item\" *ngFor=\"let tab of tabLoader.tabs\">\n <a\n id=\"{{ tab.name }}-tab\"\n class=\"nav-link clickable\"\n [ngClass]=\"{active: tab.isActive()}\"\n data-toggle=\"tab\"\n (click)=\"tabLoader.load(tab)\"\n >\n {{ tabLoader.translateTabName(tab) }}\n </a>\n </li>\n </ul>\n <div class=\"card-body bg-white p-5 position-relative tab-container\">\n <ng-template #tabContainer>Loading...</ng-template>\n <div class=\"clearfix\"></div>\n </div>\n </valtimo-widget>\n </div>\n <valtimo-dossier-supporting-process-start-modal\n (formSubmit)=\"tabLoader.refreshView()\"\n #supportingProcessStartModal\n ></valtimo-dossier-supporting-process-start-modal>\n </div>\n</div>\n\n<ng-template #caseDetailHeader>\n <div class=\"row\" *ngIf=\"customDossierHeaderItems.length > 0; else defaultTitle\">\n <span\n class=\"mb-0 mt-0 pb-2 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n item.columnSize * 2\n }} {{ item.customClass }}\"\n [ngClass]=\"{\n h1: item.textSize === 'xl',\n h2: item.textSize === 'lg',\n h3: item.textSize === 'md',\n h4: item.textSize === 'sm',\n h5: item.textSize === 'xs'\n }\"\n *ngFor=\"let item of customDossierHeaderItems\"\n >\n <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n <span *ngIf=\"item.label && item.value\">: </span>\n <strong>{{ item.value }}</strong>\n </span>\n </div>\n <ng-container *ngTemplateOutlet=\"caseDetailAssignee\"></ng-container>\n</ng-template>\n\n<ng-template #defaultTitle>\n <div class=\"row ml-0 mr-0\">{{ documentDefinitionNameTitle?.trim() }}</div>\n</ng-template>\n\n<ng-template #caseDetailAssignee>\n <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"(document$ | async)?.assigneeFullName as assignee\">\n <h5>{{ ('assignTask.assignedTo' | translate) + assignee }}</h5>\n </div>\n</ng-template>\n\n<ng-template #claimButton>\n <div class=\"user-full-name\">\n <button\n class=\"btn btn-space btn-primary mr-1\"\n type=\"button\"\n id=\"\"\n placement=\"bottom\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n (click)=\"claimAssignee()\"\n [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n >\n <span>{{ 'dossier.claimAssigneeCase' | translate }}</span>\n </button>\n </div>\n</ng-template>\n", styles: [".tab-container{min-height:300px}\n"], components: [{ type: i10.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { type: i7.ExtensionComponent, selector: "valtimo-extension", inputs: ["module", "page", "section"] }, { type: i11.DossierSupportingProcessStartModalComponent, selector: "valtimo-dossier-supporting-process-start-modal", outputs: ["formSubmit"] }], directives: [{ type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i12.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i1.TranslatePipe, "async": i5.AsyncPipe } });
|
|
106
150
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailComponent, decorators: [{
|
|
107
151
|
type: Component,
|
|
108
|
-
args: [{ selector: 'valtimo-dossier-detail', template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"main-content\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <valtimo-widget>\n <div class=\"card-header bg-light card-header-divider pb-2\">\n <div class=\"row\">\n <div class=\"col\">\n <
|
|
109
|
-
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.TranslateService }, { type: i2.DocumentService }, { type: i3.ProcessService }, { type: i4.ActivatedRoute }, { type: i4.Router }, { type: i5.Location }, { type: i6.TabService }, { type: i7.ConfigService }]; }, propDecorators: { viewContainerRef: [{
|
|
152
|
+
args: [{ selector: 'valtimo-dossier-detail', template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"main-content\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <valtimo-widget>\n <div class=\"card-header bg-light card-header-divider pb-2\">\n <div class=\"row\">\n <div class=\"col\">\n <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n </div>\n <div class=\"btn-group mt-m3px mb-3 col-auto\">\n <valtimo-extension\n module=\"dossier\"\n page=\"dossier-detail\"\n section=\"card-header\"\n ></valtimo-extension>\n <ng-container *ngTemplateOutlet=\"claimButton\"></ng-container>\n <div class=\"dropdown\">\n <button\n class=\"btn btn-primary dropdown-toggle\"\n type=\"button\"\n id=\"startProcessDropdown\"\n placement=\"bottom\"\n [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n [disabled]=\"processDocumentDefinitions.length === 0\"\n data-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n >\n <span>{{ 'dossier.startSubProcess' | translate }}</span>\n <i class=\"ml-1 mdi mdi-chevron-down\"></i>\n </button>\n <div\n class=\"dropdown-menu dropdown-menu-right\"\n aria-labelledby=\"startProcessDropdown\"\n >\n <button\n *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n class=\"dropdown-item p\"\n href=\"#\"\n (click)=\"startProcess(processDocumentDefinition)\"\n >\n {{ processDocumentDefinition.processName }}\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n <ul class=\"nav nav-tabs\">\n <li class=\"nav-item\" *ngFor=\"let tab of tabLoader.tabs\">\n <a\n id=\"{{ tab.name }}-tab\"\n class=\"nav-link clickable\"\n [ngClass]=\"{active: tab.isActive()}\"\n data-toggle=\"tab\"\n (click)=\"tabLoader.load(tab)\"\n >\n {{ tabLoader.translateTabName(tab) }}\n </a>\n </li>\n </ul>\n <div class=\"card-body bg-white p-5 position-relative tab-container\">\n <ng-template #tabContainer>Loading...</ng-template>\n <div class=\"clearfix\"></div>\n </div>\n </valtimo-widget>\n </div>\n <valtimo-dossier-supporting-process-start-modal\n (formSubmit)=\"tabLoader.refreshView()\"\n #supportingProcessStartModal\n ></valtimo-dossier-supporting-process-start-modal>\n </div>\n</div>\n\n<ng-template #caseDetailHeader>\n <div class=\"row\" *ngIf=\"customDossierHeaderItems.length > 0; else defaultTitle\">\n <span\n class=\"mb-0 mt-0 pb-2 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n item.columnSize * 2\n }} {{ item.customClass }}\"\n [ngClass]=\"{\n h1: item.textSize === 'xl',\n h2: item.textSize === 'lg',\n h3: item.textSize === 'md',\n h4: item.textSize === 'sm',\n h5: item.textSize === 'xs'\n }\"\n *ngFor=\"let item of customDossierHeaderItems\"\n >\n <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n <span *ngIf=\"item.label && item.value\">: </span>\n <strong>{{ item.value }}</strong>\n </span>\n </div>\n <ng-container *ngTemplateOutlet=\"caseDetailAssignee\"></ng-container>\n</ng-template>\n\n<ng-template #defaultTitle>\n <div class=\"row ml-0 mr-0\">{{ documentDefinitionNameTitle?.trim() }}</div>\n</ng-template>\n\n<ng-template #caseDetailAssignee>\n <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"(document$ | async)?.assigneeFullName as assignee\">\n <h5>{{ ('assignTask.assignedTo' | translate) + assignee }}</h5>\n </div>\n</ng-template>\n\n<ng-template #claimButton>\n <div class=\"user-full-name\">\n <button\n class=\"btn btn-space btn-primary mr-1\"\n type=\"button\"\n id=\"\"\n placement=\"bottom\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n (click)=\"claimAssignee()\"\n [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n >\n <span>{{ 'dossier.claimAssigneeCase' | translate }}</span>\n </button>\n </div>\n</ng-template>\n", styles: [".tab-container{min-height:300px}\n"] }]
|
|
153
|
+
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.TranslateService }, { type: i2.DocumentService }, { type: i3.ProcessService }, { type: i4.ActivatedRoute }, { type: i4.Router }, { type: i5.Location }, { type: i6.TabService }, { type: i7.ConfigService }, { type: i8.KeycloakService }, { type: i9.NGXLogger }]; }, propDecorators: { viewContainerRef: [{
|
|
110
154
|
type: ViewChild,
|
|
111
155
|
args: ['tabContainer', { read: ViewContainerRef, static: true }]
|
|
112
156
|
}], supportingProcessStart: [{
|
|
113
157
|
type: ViewChild,
|
|
114
158
|
args: ['supportingProcessStartModal']
|
|
115
159
|
}] } });
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-detail.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/dossier-detail.component.ts","../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/dossier-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  Component,\n  ComponentFactoryResolver,\n  OnInit,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ActivatedRoute, ParamMap, Router} from '@angular/router';\nimport {Document, DocumentService, ProcessDocumentDefinition} from '@valtimo/document';\nimport {TabLoaderImpl} from '../models';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Location} from '@angular/common';\nimport {TabService} from '../tab.service';\nimport {ProcessService} from '@valtimo/process';\nimport {DossierSupportingProcessStartModalComponent} from '../dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component';\nimport {ConfigService} from '@valtimo/config';\nimport * as moment from 'moment';\n\n@Component({\n  selector: 'valtimo-dossier-detail',\n  templateUrl: './dossier-detail.component.html',\n  styleUrls: ['./dossier-detail.component.css'],\n})\nexport class DossierDetailComponent implements OnInit {\n  @ViewChild('tabContainer', {read: ViewContainerRef, static: true})\n  viewContainerRef: ViewContainerRef;\n\n  public documentDefinitionName: string;\n  public documentDefinitionNameTitle: string;\n  public documentId: string;\n  public document: Document = null;\n  public tabLoader: TabLoaderImpl = null;\n  private snapshot: ParamMap;\n  public processDefinitionListFields: Array<any> = [];\n  public processDocumentDefinitions: ProcessDocumentDefinition[] = [];\n  private initialTabName: string;\n  public customDossierHeaderItems: Array<any> = [];\n  @ViewChild('supportingProcessStartModal')\n  supportingProcessStart: DossierSupportingProcessStartModalComponent;\n\n  constructor(\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private translateService: TranslateService,\n    private documentService: DocumentService,\n    private processService: ProcessService,\n    private route: ActivatedRoute,\n    private router: Router,\n    private location: Location,\n    private tabService: TabService,\n    private configService: ConfigService\n  ) {\n    this.snapshot = this.route.snapshot.paramMap;\n    this.documentDefinitionName = this.snapshot.get('documentDefinitionName') || '';\n    this.documentId = this.snapshot.get('documentId') || '';\n    this.tabService.getConfigurableTabs(this.documentDefinitionName);\n  }\n\n  ngOnInit() {\n    this.tabLoader = new TabLoaderImpl(\n      this.tabService.getTabs(),\n      this.componentFactoryResolver,\n      this.viewContainerRef,\n      this.translateService,\n      this.router,\n      this.location\n    );\n    this.documentService\n      .getDocumentDefinition(this.documentDefinitionName)\n      .subscribe(definition => {\n        this.documentDefinitionNameTitle = definition.schema.title;\n      });\n    this.getCustomDossierHeader();\n    this.initialTabName = this.snapshot.get('tab');\n    this.tabLoader.initial(this.initialTabName);\n    this.getAllAssociatedProcessDefinitions();\n  }\n\n  public getAllAssociatedProcessDefinitions() {\n    this.documentService\n      .findProcessDocumentDefinitions(this.documentDefinitionName)\n      .subscribe(processDocumentDefinitions => {\n        this.processDocumentDefinitions = processDocumentDefinitions.filter(\n          processDocumentDefinition => processDocumentDefinition.startableByUser\n        );\n        this.processDefinitionListFields = [\n          {\n            key: 'processName',\n            label: 'Proces',\n          },\n        ];\n      });\n  }\n\n  startProcess(processDocumentDefinition: ProcessDocumentDefinition) {\n    this.supportingProcessStart.openModal(processDocumentDefinition, this.documentId);\n  }\n\n  private getCustomDossierHeader() {\n    if (\n      this.configService.config.customDossierHeader?.hasOwnProperty(\n        this.documentDefinitionName.toLowerCase()\n      )\n    ) {\n      this.documentService.getDocument(this.documentId).subscribe(document => {\n        this.document = document;\n        this.configService.config.customDossierHeader[\n          this.documentDefinitionName.toLowerCase()\n        ]?.forEach(item => this.getCustomDossierHeaderItem(item));\n      });\n    }\n  }\n\n  private getCustomDossierHeaderItem(item) {\n    this.customDossierHeaderItems.push({\n      label: item['labelTranslationKey'] || '',\n      columnSize: item['columnSize'] || 3,\n      textSize: item['textSize'] || 'md',\n      customClass: item['customClass'] || '',\n      value: item['propertyPaths']?.reduce(\n        (prev, curr) => prev + this.getStringFromDocumentPath(item, curr),\n        ''\n      ),\n    });\n  }\n\n  private getStringFromDocumentPath(item, path) {\n    const prefix = item['propertyPaths'].indexOf(path) > 0 ? ' ' : '';\n    const string =\n      path.split('.').reduce((o, i) => o[i], this.document.content) || item['noValueText'] || '';\n    const regex = new RegExp('(T\\\\d\\\\d:\\\\d\\\\d:\\\\d\\\\d[+-])');\n    const formattedString = regex.test(string) ? moment(string).format('DD-MM-YYYY') : string;\n    return prefix + formattedString;\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div class=\"main-content\">\n  <div class=\"container-fluid\">\n    <div class=\"col-12 px-0 mb-5\">\n      <valtimo-widget>\n        <div class=\"card-header bg-light card-header-divider pb-2\">\n          <div class=\"row\">\n            <div class=\"col\">\n              <div class=\"row\" *ngIf=\"customDossierHeaderItems.length > 0; else defaultTitle\">\n                <span\n                  class=\"mb-0 mt-0 pb-2 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n                    item.columnSize * 2\n                  }} {{ item.customClass }}\"\n                  [ngClass]=\"{\n                    h1: item.textSize === 'xl',\n                    h2: item.textSize === 'lg',\n                    h3: item.textSize === 'md',\n                    h4: item.textSize === 'sm',\n                    h5: item.textSize === 'xs'\n                  }\"\n                  *ngFor=\"let item of customDossierHeaderItems\"\n                >\n                  <span *ngIf=\"item.label !== ''\">{{ item.label | translate }}</span>\n                  <span *ngIf=\"item.label !== '' && item.value !== '' && item.value !== null\"\n                    >:\n                  </span>\n                  <strong>{{ item.value }}</strong>\n                </span>\n              </div>\n              <ng-template #defaultTitle>\n                {{ documentDefinitionNameTitle }}\n              </ng-template>\n            </div>\n            <div class=\"btn-group mt-m3px mb-3 col-auto\">\n              <valtimo-extension\n                module=\"dossier\"\n                page=\"dossier-detail\"\n                section=\"card-header\"\n              ></valtimo-extension>\n              <div class=\"dropdown\">\n                <button\n                  class=\"btn btn-primary dropdown-toggle\"\n                  type=\"button\"\n                  id=\"startProcessDropdown\"\n                  placement=\"bottom\"\n                  [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n                  [disabled]=\"processDocumentDefinitions.length === 0\"\n                  data-toggle=\"dropdown\"\n                  aria-haspopup=\"true\"\n                  aria-expanded=\"false\"\n                >\n                  <span>{{ 'dossier.startSubProcess' | translate }}</span>\n                  <i class=\"ml-1 mdi mdi-chevron-down\"></i>\n                </button>\n                <div\n                  class=\"dropdown-menu dropdown-menu-right\"\n                  aria-labelledby=\"startProcessDropdown\"\n                >\n                  <button\n                    *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n                    class=\"dropdown-item p\"\n                    href=\"#\"\n                    (click)=\"startProcess(processDocumentDefinition)\"\n                  >\n                    {{ processDocumentDefinition.processName }}\n                  </button>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n        <ul class=\"nav nav-tabs\">\n          <li class=\"nav-item\" *ngFor=\"let tab of tabLoader.tabs\">\n            <a\n              id=\"{{ tab.name }}-tab\"\n              class=\"nav-link clickable\"\n              [ngClass]=\"{active: tab.isActive()}\"\n              data-toggle=\"tab\"\n              (click)=\"tabLoader.load(tab)\"\n            >\n              {{ tabLoader.translateTabName(tab) }}\n            </a>\n          </li>\n        </ul>\n        <div class=\"card-body bg-white p-5 position-relative tab-container\">\n          <ng-template #tabContainer>Loading...</ng-template>\n          <div class=\"clearfix\"></div>\n        </div>\n      </valtimo-widget>\n    </div>\n    <valtimo-dossier-supporting-process-start-modal\n      (formSubmit)=\"tabLoader.refreshView()\"\n      #supportingProcessStartModal\n    ></valtimo-dossier-supporting-process-start-modal>\n  </div>\n</div>\n"]}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-detail.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/dossier-detail.component.ts","../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/dossier-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  Component,\n  ComponentFactoryResolver,\n  OnInit,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ActivatedRoute, ParamMap, Router} from '@angular/router';\nimport {Document, DocumentService, ProcessDocumentDefinition} from '@valtimo/document';\nimport {TabLoaderImpl} from '../models';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Location} from '@angular/common';\nimport {TabService} from '../tab.service';\nimport {ProcessService} from '@valtimo/process';\nimport {DossierSupportingProcessStartModalComponent} from '../dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component';\nimport {ConfigService} from '@valtimo/config';\nimport moment from 'moment';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  from,\n  map,\n  Observable,\n  of,\n  startWith,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {KeycloakService} from 'keycloak-angular';\nimport {NGXLogger} from 'ngx-logger';\n\n@Component({\n  selector: 'valtimo-dossier-detail',\n  templateUrl: './dossier-detail.component.html',\n  styleUrls: ['./dossier-detail.component.css'],\n})\nexport class DossierDetailComponent implements OnInit {\n  @ViewChild('tabContainer', {read: ViewContainerRef, static: true})\n  viewContainerRef: ViewContainerRef;\n\n  public documentDefinitionName: string;\n  public documentDefinitionNameTitle: string;\n  public documentId: string;\n  public document: Document = null;\n  public tabLoader: TabLoaderImpl = null;\n  private snapshot: ParamMap;\n  public processDefinitionListFields: Array<any> = [];\n  public processDocumentDefinitions: ProcessDocumentDefinition[] = [];\n  private initialTabName: string;\n  public customDossierHeaderItems: Array<any> = [];\n  @ViewChild('supportingProcessStartModal')\n  supportingProcessStart: DossierSupportingProcessStartModalComponent;\n\n  readonly refreshDocument$ = new BehaviorSubject<null>(null);\n\n  readonly assigneeId$ = new BehaviorSubject<string>('');\n\n  readonly document$: Observable<Document | null> = this.refreshDocument$.pipe(\n    switchMap(() => this.route.params),\n    map(params => params?.documentId),\n    switchMap(documentId =>\n      documentId ? this.documentService.getDocument(this.documentId) : of(null)\n    ),\n    tap(document => {\n      if (document) {\n        this.assigneeId$.next(document.assigneeId);\n        this.document = document;\n\n        if (\n          this.configService.config.customDossierHeader?.hasOwnProperty(\n            this.documentDefinitionName.toLowerCase()\n          ) &&\n          this.customDossierHeaderItems.length === 0\n        ) {\n          this.configService.config.customDossierHeader[\n            this.documentDefinitionName.toLowerCase()\n          ]?.forEach(item => this.getCustomDossierHeaderItem(item));\n        }\n      }\n    })\n  );\n\n  readonly userId$: Observable<string> = from(this.keyCloakService.isLoggedIn()).pipe(\n    switchMap(() => this.keyCloakService.loadUserProfile()),\n    map(profile => profile?.id)\n  );\n\n  readonly isAssigning$ = new BehaviorSubject<boolean>(false);\n\n  readonly isAssignedToCurrentUser$: Observable<boolean> = combineLatest([\n    this.assigneeId$,\n    this.userId$,\n  ]).pipe(\n    map(([assigneeId, userId]) => assigneeId && userId && assigneeId === userId),\n    startWith(true)\n  );\n\n  constructor(\n    private readonly componentFactoryResolver: ComponentFactoryResolver,\n    private readonly translateService: TranslateService,\n    private readonly documentService: DocumentService,\n    private readonly processService: ProcessService,\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly location: Location,\n    private readonly tabService: TabService,\n    private readonly configService: ConfigService,\n    private readonly keyCloakService: KeycloakService,\n    private readonly logger: NGXLogger\n  ) {\n    this.snapshot = this.route.snapshot.paramMap;\n    this.documentDefinitionName = this.snapshot.get('documentDefinitionName') || '';\n    this.documentId = this.snapshot.get('documentId') || '';\n    this.tabService.getConfigurableTabs(this.documentDefinitionName);\n  }\n\n  ngOnInit(): void {\n    this.tabLoader = new TabLoaderImpl(\n      this.tabService.getTabs(),\n      this.componentFactoryResolver,\n      this.viewContainerRef,\n      this.translateService,\n      this.router,\n      this.location\n    );\n    this.documentService\n      .getDocumentDefinition(this.documentDefinitionName)\n      .subscribe(definition => {\n        this.documentDefinitionNameTitle = definition.schema.title;\n      });\n    this.initialTabName = this.snapshot.get('tab');\n    this.tabLoader.initial(this.initialTabName);\n    this.getAllAssociatedProcessDefinitions();\n  }\n\n  public getAllAssociatedProcessDefinitions(): void {\n    this.documentService\n      .findProcessDocumentDefinitions(this.documentDefinitionName)\n      .subscribe(processDocumentDefinitions => {\n        this.processDocumentDefinitions = processDocumentDefinitions.filter(\n          processDocumentDefinition => processDocumentDefinition.startableByUser\n        );\n        this.processDefinitionListFields = [\n          {\n            key: 'processName',\n            label: 'Proces',\n          },\n        ];\n      });\n  }\n\n  startProcess(processDocumentDefinition: ProcessDocumentDefinition): void {\n    this.supportingProcessStart.openModal(processDocumentDefinition, this.documentId);\n  }\n\n  claimAssignee(): void {\n    this.isAssigning$.next(true);\n\n    this.userId$\n      .pipe(\n        take(1),\n        switchMap(userId => this.documentService.assignHandlerToDocument(this.documentId, userId))\n      )\n      .subscribe(\n        (): void => {\n          this.isAssigning$.next(false);\n          this.refreshDocument$.next(null);\n        },\n        (): void => {\n          this.isAssigning$.next(false);\n          this.logger.debug('Something went wrong while assigning user to case');\n        }\n      );\n  }\n\n  private getCustomDossierHeaderItem(item): void {\n    this.customDossierHeaderItems.push({\n      label: item['labelTranslationKey'] || '',\n      columnSize: item['columnSize'] || 3,\n      textSize: item['textSize'] || 'md',\n      customClass: item['customClass'] || '',\n      modifier: item['modifier'] || '',\n      value: item['propertyPaths']?.reduce(\n        (prev, curr) => prev + this.getStringFromDocumentPath(item, curr),\n        ''\n      ),\n    });\n  }\n\n  private getStringFromDocumentPath(item, path): string {\n    const prefix = item['propertyPaths'].indexOf(path) > 0 ? ' ' : '';\n    let string =\n      path.split('.').reduce((o, i) => o[i], this.document.content) || item['noValueText'] || '';\n    const dateFormats = [\n      moment.ISO_8601,\n      \"MM-DD-YYYY\",\n      \"DD-MM-YYYY\",\n      \"YYYY-MM-DD\"\n    ];\n    switch (item['modifier']) {\n      case 'age': {\n        if (moment(string, dateFormats, true).isValid()) {\n          string = moment().diff(string, 'years');\n        }\n        break;\n      }\n      default: {\n        if (moment(string, dateFormats, true).isValid()) {\n          string = moment(string).format('DD-MM-YYYY');\n        }\n      }\n    }\n    return prefix + string;\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div class=\"main-content\">\n  <div class=\"container-fluid\">\n    <div class=\"col-12 px-0 mb-5\">\n      <valtimo-widget>\n        <div class=\"card-header bg-light card-header-divider pb-2\">\n          <div class=\"row\">\n            <div class=\"col\">\n              <ng-container *ngTemplateOutlet=\"caseDetailHeader\"></ng-container>\n            </div>\n            <div class=\"btn-group mt-m3px mb-3 col-auto\">\n              <valtimo-extension\n                module=\"dossier\"\n                page=\"dossier-detail\"\n                section=\"card-header\"\n              ></valtimo-extension>\n              <ng-container *ngTemplateOutlet=\"claimButton\"></ng-container>\n              <div class=\"dropdown\">\n                <button\n                  class=\"btn btn-primary dropdown-toggle\"\n                  type=\"button\"\n                  id=\"startProcessDropdown\"\n                  placement=\"bottom\"\n                  [ngbTooltip]=\"processDocumentDefinitions.length === 0 ? 'No action' : null\"\n                  [disabled]=\"processDocumentDefinitions.length === 0\"\n                  data-toggle=\"dropdown\"\n                  aria-haspopup=\"true\"\n                  aria-expanded=\"false\"\n                >\n                  <span>{{ 'dossier.startSubProcess' | translate }}</span>\n                  <i class=\"ml-1 mdi mdi-chevron-down\"></i>\n                </button>\n                <div\n                  class=\"dropdown-menu dropdown-menu-right\"\n                  aria-labelledby=\"startProcessDropdown\"\n                >\n                  <button\n                    *ngFor=\"let processDocumentDefinition of processDocumentDefinitions\"\n                    class=\"dropdown-item p\"\n                    href=\"#\"\n                    (click)=\"startProcess(processDocumentDefinition)\"\n                  >\n                    {{ processDocumentDefinition.processName }}\n                  </button>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n        <ul class=\"nav nav-tabs\">\n          <li class=\"nav-item\" *ngFor=\"let tab of tabLoader.tabs\">\n            <a\n              id=\"{{ tab.name }}-tab\"\n              class=\"nav-link clickable\"\n              [ngClass]=\"{active: tab.isActive()}\"\n              data-toggle=\"tab\"\n              (click)=\"tabLoader.load(tab)\"\n            >\n              {{ tabLoader.translateTabName(tab) }}\n            </a>\n          </li>\n        </ul>\n        <div class=\"card-body bg-white p-5 position-relative tab-container\">\n          <ng-template #tabContainer>Loading...</ng-template>\n          <div class=\"clearfix\"></div>\n        </div>\n      </valtimo-widget>\n    </div>\n    <valtimo-dossier-supporting-process-start-modal\n      (formSubmit)=\"tabLoader.refreshView()\"\n      #supportingProcessStartModal\n    ></valtimo-dossier-supporting-process-start-modal>\n  </div>\n</div>\n\n<ng-template #caseDetailHeader>\n  <div class=\"row\" *ngIf=\"customDossierHeaderItems.length > 0; else defaultTitle\">\n    <span\n      class=\"mb-0 mt-0 pb-2 align-self-end col-xl-{{ item.columnSize }} col-lg-{{\n        item.columnSize * 2\n      }} {{ item.customClass }}\"\n      [ngClass]=\"{\n        h1: item.textSize === 'xl',\n        h2: item.textSize === 'lg',\n        h3: item.textSize === 'md',\n        h4: item.textSize === 'sm',\n        h5: item.textSize === 'xs'\n      }\"\n      *ngFor=\"let item of customDossierHeaderItems\"\n    >\n      <span *ngIf=\"item.label\">{{ item.label | translate }}</span>\n      <span *ngIf=\"item.label && item.value\">: </span>\n      <strong>{{ item.value }}</strong>\n    </span>\n  </div>\n  <ng-container *ngTemplateOutlet=\"caseDetailAssignee\"></ng-container>\n</ng-template>\n\n<ng-template #defaultTitle>\n  <div class=\"row ml-0 mr-0\">{{ documentDefinitionNameTitle?.trim() }}</div>\n</ng-template>\n\n<ng-template #caseDetailAssignee>\n  <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"(document$ | async)?.assigneeFullName as assignee\">\n    <h5>{{ ('assignTask.assignedTo' | translate) + assignee }}</h5>\n  </div>\n</ng-template>\n\n<ng-template #claimButton>\n    <div class=\"user-full-name\">\n      <button\n        class=\"btn btn-space btn-primary mr-1\"\n        type=\"button\"\n        id=\"\"\n        placement=\"bottom\"\n        aria-haspopup=\"true\"\n        aria-expanded=\"false\"\n        (click)=\"claimAssignee()\"\n        [disabled]=\"(isAssigning$ | async) || (isAssignedToCurrentUser$ | async)\"\n      >\n        <span>{{ 'dossier.claimAssigneeCase' | translate }}</span>\n      </button>\n    </div>\n</ng-template>\n"]}
|
|
@@ -16,6 +16,7 @@
|
|
|
16
16
|
import { Component, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
17
17
|
import { FormioOptionsImpl } from '@valtimo/components';
|
|
18
18
|
import moment from 'moment';
|
|
19
|
+
import { Subscription } from 'rxjs';
|
|
19
20
|
import * as i0 from "@angular/core";
|
|
20
21
|
import * as i1 from "@angular/router";
|
|
21
22
|
import * as i2 from "@valtimo/document";
|
|
@@ -44,6 +45,7 @@ export class DossierDetailTabSummaryComponent {
|
|
|
44
45
|
this.tasks = [];
|
|
45
46
|
this.formDefinition = null;
|
|
46
47
|
this.roles = [];
|
|
48
|
+
this._subscriptions = new Subscription();
|
|
47
49
|
this.snapshot = this.route.snapshot.paramMap;
|
|
48
50
|
this.documentDefinitionName = this.snapshot.get('documentDefinitionName') || '';
|
|
49
51
|
this.documentId = this.snapshot.get('documentId') || '';
|
|
@@ -54,64 +56,69 @@ export class DossierDetailTabSummaryComponent {
|
|
|
54
56
|
this.moment = moment;
|
|
55
57
|
this.init();
|
|
56
58
|
}
|
|
59
|
+
ngOnDestroy() {
|
|
60
|
+
this._subscriptions.unsubscribe();
|
|
61
|
+
}
|
|
57
62
|
init() {
|
|
58
|
-
this.documentService.getDocument(this.documentId).subscribe(document => {
|
|
63
|
+
this._subscriptions.add(this.documentService.getDocument(this.documentId).subscribe(document => {
|
|
59
64
|
this.document = document;
|
|
60
|
-
});
|
|
61
|
-
this.formService
|
|
65
|
+
}));
|
|
66
|
+
this._subscriptions.add(this.formService
|
|
62
67
|
.getFormDefinitionByNamePreFilled(`${this.documentDefinitionName}.summary`, this.documentId)
|
|
63
68
|
.subscribe(formDefinition => {
|
|
64
69
|
this.formDefinition = formDefinition;
|
|
65
|
-
});
|
|
66
|
-
this.userProviderService.getUserSubject().subscribe(user => {
|
|
70
|
+
}));
|
|
71
|
+
this._subscriptions.add(this.userProviderService.getUserSubject().subscribe(user => {
|
|
67
72
|
this.roles = user.roles;
|
|
68
73
|
this.tasks = [];
|
|
69
74
|
this.loadProcessDocumentInstances(this.documentId);
|
|
70
|
-
});
|
|
75
|
+
}));
|
|
71
76
|
}
|
|
72
77
|
loadProcessDocumentInstances(documentId) {
|
|
73
|
-
this.documentService
|
|
78
|
+
this._subscriptions.add(this.documentService
|
|
74
79
|
.findProcessDocumentInstances(documentId)
|
|
75
80
|
.subscribe(processDocumentInstances => {
|
|
76
81
|
this.processDocumentInstances = processDocumentInstances;
|
|
77
82
|
this.processDocumentInstances.forEach(instance => {
|
|
78
83
|
this.loadProcessInstanceTasks(instance.id.processInstanceId);
|
|
79
84
|
});
|
|
80
|
-
});
|
|
85
|
+
}));
|
|
81
86
|
}
|
|
82
87
|
loadProcessInstanceTasks(processInstanceId) {
|
|
83
|
-
this.processService.getProcessInstanceTasks(processInstanceId).subscribe(tasks => {
|
|
84
|
-
tasks
|
|
85
|
-
task
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
if (
|
|
92
|
-
|
|
93
|
-
|
|
88
|
+
this._subscriptions.add(this.processService.getProcessInstanceTasks(processInstanceId).subscribe(tasks => {
|
|
89
|
+
if (tasks != null) {
|
|
90
|
+
tasks.forEach(task => {
|
|
91
|
+
task.createdUnix = this.moment(task.created).unix();
|
|
92
|
+
task.created = this.moment(task.created).format('DD MMM YYYY HH:mm');
|
|
93
|
+
task.isLocked = () => {
|
|
94
|
+
let locked = true;
|
|
95
|
+
for (const link of task.identityLinks) {
|
|
96
|
+
if (link.type === 'candidate' && link.groupId) {
|
|
97
|
+
if (this.roles.includes(link.groupId)) {
|
|
98
|
+
locked = false;
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
94
101
|
}
|
|
95
102
|
}
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
};
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
});
|
|
103
|
+
return locked;
|
|
104
|
+
};
|
|
105
|
+
});
|
|
106
|
+
this.tasks = this.tasks.concat(tasks);
|
|
107
|
+
this.tasks.sort((t1, t2) => t2.createdUnix - t1.createdUnix);
|
|
108
|
+
}
|
|
109
|
+
}));
|
|
103
110
|
}
|
|
104
111
|
rowTaskClick(task) {
|
|
105
112
|
this.taskDetail.openTaskDetails(task);
|
|
106
113
|
}
|
|
107
114
|
}
|
|
108
115
|
DossierDetailTabSummaryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabSummaryComponent, deps: [{ token: i1.Router }, { token: i2.DocumentService }, { token: i3.TaskService }, { token: i4.ProcessService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.ActivatedRoute }, { token: i5.FormService }, { token: i6.UserProviderService }], target: i0.ɵɵFactoryTarget.Component });
|
|
109
|
-
DossierDetailTabSummaryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailTabSummaryComponent, selector: "valtimo-dossier-detail-tab-summary", viewQueries: [{ propertyName: "taskDetail", first: true, predicate: ["taskDetail"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\">\n <div class=\"row py-4\">\n <div class=\"col-sm-12 col-md-8 col-xl-9\">\n <div *ngIf=\"document\">\n <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n <div class=\"mb-4\">\n <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n </div>\n </div>\n </div>\n </div>\n\n <!--Current user tasks right side-->\n <div class=\"col-sm-12 col-md-4 col-xl-3\">\n <h4 class=\"user-tasks-title\">
|
|
116
|
+
DossierDetailTabSummaryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailTabSummaryComponent, selector: "valtimo-dossier-detail-tab-summary", viewQueries: [{ propertyName: "taskDetail", first: true, predicate: ["taskDetail"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\">\n <div class=\"row py-4\">\n <div class=\"col-sm-12 col-md-8 col-xl-9\">\n <div *ngIf=\"document\">\n <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n <div class=\"mb-4\">\n <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n </div>\n </div>\n </div>\n </div>\n\n <!--Current user tasks right side-->\n <div class=\"col-sm-12 col-md-4 col-xl-3\">\n <h4 class=\"user-tasks-title\">{{ 'summary.userTasks' | translate }}</h4>\n <ng-container *ngIf=\"!tasks.length\">\n <valtimo-widget>\n <div class=\"p-3\">\n <img class=\"float-left\" src=\"assets/audit-2.png\" height=\"25\" />\n <span class=\"float-right\">{{ 'summary.userTasksDoneState' | translate }}</span>\n <div class=\"clearfix\"></div>\n </div>\n </valtimo-widget>\n </ng-container>\n <ng-container *ngFor=\"let task of tasks\">\n <valtimo-widget>\n <div\n class=\"p-3 clickable hoverable\"\n (click)=\"rowTaskClick(task)\"\n *ngIf=\"!task.isLocked()\"\n >\n <span class=\"float-right badge badge-pill badge-primary\">{{ 'summary.taskOpen' | translate }}</span>\n <strong>{{ task.name }}</strong>\n <div>{{ 'summary.taskCreated' | translate }} {{ task.created }}</div>\n </div>\n <div class=\"p-3 hoverable\" *ngIf=\"task.isLocked()\">\n <span\n class=\"float-right badge badge-pill badge-secondary bg-grey\"\n ngbTooltip=\"{{ 'summary.taskLocked' | translate }}\"\n >\n <i class=\"icon mdi mdi-lock\"></i>\n </span>\n <strong>{{ task.name }}</strong>\n <div>{{ 'summary.taskCreated' | translate }} {{ task.created }}</div>\n </div>\n </valtimo-widget>\n </ng-container>\n <valtimo-task-detail-modal\n #taskDetail\n (formSubmit)=\"init()\"\n (assignmentOfTaskChanged)=\"init()\"\n ></valtimo-task-detail-modal>\n </div>\n </div>\n</div>\n", styles: ["/*!\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */.hoverable:hover{background-color:#eee}.summaryForm .formio-component{margin-bottom:0!important}.summaryForm .formio-component div[ref=element] .form-control{height:24px!important;background-color:#fff;border:0px;margin:0;padding:0!important;font-size:13px}.summaryForm .formio-field div[ref=element] .form-control{font-weight:400}.summaryForm .formio-value div[ref=element] .form-control{font-weight:700}.user-tasks-title{margin-top:0;margin-bottom:12px;font-weight:400;color:#000;height:20px}\n"], components: [{ type: i7.FormioComponent, selector: "valtimo-form-io", inputs: ["form", "options", "submission", "formRefresh$"], outputs: ["submit", "change"] }, { type: i7.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { type: i3.TaskDetailModalComponent, selector: "valtimo-task-detail-modal", outputs: ["formSubmit", "assignmentOfTaskChanged"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i9.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }], pipes: { "translate": i10.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
110
117
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabSummaryComponent, decorators: [{
|
|
111
118
|
type: Component,
|
|
112
|
-
args: [{ selector: 'valtimo-dossier-detail-tab-summary', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\">\n <div class=\"row py-4\">\n <div class=\"col-sm-12 col-md-8 col-xl-9\">\n <div *ngIf=\"document\">\n <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n <div class=\"mb-4\">\n <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n </div>\n </div>\n </div>\n </div>\n\n <!--Current user tasks right side-->\n <div class=\"col-sm-12 col-md-4 col-xl-3\">\n <h4 class=\"user-tasks-title\">
|
|
119
|
+
args: [{ selector: 'valtimo-dossier-detail-tab-summary', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\">\n <div class=\"row py-4\">\n <div class=\"col-sm-12 col-md-8 col-xl-9\">\n <div *ngIf=\"document\">\n <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n <div class=\"mb-4\">\n <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n </div>\n </div>\n </div>\n </div>\n\n <!--Current user tasks right side-->\n <div class=\"col-sm-12 col-md-4 col-xl-3\">\n <h4 class=\"user-tasks-title\">{{ 'summary.userTasks' | translate }}</h4>\n <ng-container *ngIf=\"!tasks.length\">\n <valtimo-widget>\n <div class=\"p-3\">\n <img class=\"float-left\" src=\"assets/audit-2.png\" height=\"25\" />\n <span class=\"float-right\">{{ 'summary.userTasksDoneState' | translate }}</span>\n <div class=\"clearfix\"></div>\n </div>\n </valtimo-widget>\n </ng-container>\n <ng-container *ngFor=\"let task of tasks\">\n <valtimo-widget>\n <div\n class=\"p-3 clickable hoverable\"\n (click)=\"rowTaskClick(task)\"\n *ngIf=\"!task.isLocked()\"\n >\n <span class=\"float-right badge badge-pill badge-primary\">{{ 'summary.taskOpen' | translate }}</span>\n <strong>{{ task.name }}</strong>\n <div>{{ 'summary.taskCreated' | translate }} {{ task.created }}</div>\n </div>\n <div class=\"p-3 hoverable\" *ngIf=\"task.isLocked()\">\n <span\n class=\"float-right badge badge-pill badge-secondary bg-grey\"\n ngbTooltip=\"{{ 'summary.taskLocked' | translate }}\"\n >\n <i class=\"icon mdi mdi-lock\"></i>\n </span>\n <strong>{{ task.name }}</strong>\n <div>{{ 'summary.taskCreated' | translate }} {{ task.created }}</div>\n </div>\n </valtimo-widget>\n </ng-container>\n <valtimo-task-detail-modal\n #taskDetail\n (formSubmit)=\"init()\"\n (assignmentOfTaskChanged)=\"init()\"\n ></valtimo-task-detail-modal>\n </div>\n </div>\n</div>\n", styles: ["/*!\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */.hoverable:hover{background-color:#eee}.summaryForm .formio-component{margin-bottom:0!important}.summaryForm .formio-component div[ref=element] .form-control{height:24px!important;background-color:#fff;border:0px;margin:0;padding:0!important;font-size:13px}.summaryForm .formio-field div[ref=element] .form-control{font-weight:400}.summaryForm .formio-value div[ref=element] .form-control{font-weight:700}.user-tasks-title{margin-top:0;margin-bottom:12px;font-weight:400;color:#000;height:20px}\n"] }]
|
|
113
120
|
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.DocumentService }, { type: i3.TaskService }, { type: i4.ProcessService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.ActivatedRoute }, { type: i5.FormService }, { type: i6.UserProviderService }]; }, propDecorators: { taskDetail: [{
|
|
114
121
|
type: ViewChild,
|
|
115
122
|
args: ['taskDetail']
|
|
116
123
|
}] } });
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/summary/summary.component.ts","../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/summary/summary.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  Component,\n  ElementRef,\n  OnInit,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {ProcessInstanceTask, ProcessService} from '@valtimo/process';\nimport {ActivatedRoute, ParamMap, Router} from '@angular/router';\nimport {Document, DocumentService, ProcessDocumentInstance} from '@valtimo/document';\nimport {TaskDetailModalComponent, TaskService} from '@valtimo/task';\nimport {FormService} from '@valtimo/form';\nimport {FormioOptionsImpl, ValtimoFormioOptions} from '@valtimo/components';\nimport moment from 'moment';\nimport {FormioForm} from '@formio/angular';\nimport {UserProviderService} from '@valtimo/security';\n\nmoment.locale(localStorage.getItem('langKey') || '');\nmoment.defaultFormat = 'DD MMM YYYY HH:mm';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-summary',\n  templateUrl: './summary.component.html',\n  styleUrls: ['./summary.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DossierDetailTabSummaryComponent implements OnInit {\n  public readonly documentDefinitionName: string;\n  public document: Document;\n  public documentId: string;\n  public processDocumentInstances: ProcessDocumentInstance[] = [];\n  private snapshot: ParamMap;\n  public tasks: ProcessInstanceTask[] = [];\n  public moment;\n  public formDefinition: FormioForm = null;\n  public options: ValtimoFormioOptions;\n  public roles: string[] = [];\n  @ViewChild('taskDetail') taskDetail: TaskDetailModalComponent;\n\n  constructor(\n    private router: Router,\n    private documentService: DocumentService,\n    private taskService: TaskService,\n    private processService: ProcessService,\n    private el: ElementRef,\n    private renderer: Renderer2,\n    private route: ActivatedRoute,\n    private formService: FormService,\n    private userProviderService: UserProviderService\n  ) {\n    this.snapshot = this.route.snapshot.paramMap;\n    this.documentDefinitionName = this.snapshot.get('documentDefinitionName') || '';\n    this.documentId = this.snapshot.get('documentId') || '';\n    this.options = new FormioOptionsImpl();\n    this.options.disableAlerts = true;\n  }\n\n  ngOnInit() {\n    this.moment = moment;\n    this.init();\n  }\n\n  init() {\n    this.documentService.getDocument(this.documentId).subscribe(document => {\n      this.document = document;\n    });\n    this.formService\n      .getFormDefinitionByNamePreFilled(`${this.documentDefinitionName}.summary`, this.documentId)\n      .subscribe(formDefinition => {\n        this.formDefinition = formDefinition;\n      });\n    this.userProviderService.getUserSubject().subscribe(user => {\n      this.roles = user.roles;\n      this.tasks = [];\n      this.loadProcessDocumentInstances(this.documentId);\n    });\n  }\n\n  public loadProcessDocumentInstances(documentId: string) {\n    this.documentService\n      .findProcessDocumentInstances(documentId)\n      .subscribe(processDocumentInstances => {\n        this.processDocumentInstances = processDocumentInstances;\n        this.processDocumentInstances.forEach(instance => {\n          this.loadProcessInstanceTasks(instance.id.processInstanceId);\n        });\n      });\n  }\n\n  private loadProcessInstanceTasks(processInstanceId: string) {\n    this.processService.getProcessInstanceTasks(processInstanceId).subscribe(tasks => {\n      tasks.forEach(task => {\n        task.createdUnix = this.moment(task.created).unix();\n        task.created = this.moment(task.created).format('DD MMM YYYY HH:mm');\n        task.isLocked = () => {\n          let locked = true;\n          for (const link of task.identityLinks) {\n            if (link.type === 'candidate' && link.groupId) {\n              if (this.roles.includes(link.groupId)) {\n                locked = false;\n                break;\n              }\n            }\n          }\n          return locked;\n        };\n      });\n      this.tasks = this.tasks.concat(tasks);\n      this.tasks.sort((t1, t2) => t2.createdUnix - t1.createdUnix);\n    });\n  }\n\n  public rowTaskClick(task: any) {\n    this.taskDetail.openTaskDetails(task);\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div class=\"container-fluid\">\n  <div class=\"row py-4\">\n    <div class=\"col-sm-12 col-md-8 col-xl-9\">\n      <div *ngIf=\"document\">\n        <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n          <div class=\"mb-4\">\n            <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!--Current user tasks right side-->\n    <div class=\"col-sm-12 col-md-4 col-xl-3\">\n      <h4 class=\"user-tasks-title\">User tasks</h4>\n      <ng-container *ngIf=\"!tasks.length\">\n        <valtimo-widget>\n          <div class=\"p-3\">\n            <img class=\"float-left\" src=\"assets/audit-2.png\" height=\"25\" />\n            <span class=\"float-right\">{{ 'summary.userTasksDoneState' | translate }}</span>\n            <div class=\"clearfix\"></div>\n          </div>\n        </valtimo-widget>\n      </ng-container>\n      <ng-container *ngFor=\"let task of tasks\">\n        <valtimo-widget>\n          <div\n            class=\"p-3 clickable hoverable\"\n            (click)=\"rowTaskClick(task)\"\n            *ngIf=\"!task.isLocked()\"\n          >\n            <span class=\"float-right badge badge-pill badge-primary\">Open</span>\n            <strong>{{ task.name }}</strong>\n            <div>Created {{ task.created }}</div>\n          </div>\n          <div class=\"p-3 hoverable\" *ngIf=\"task.isLocked()\">\n            <span\n              class=\"float-right badge badge-pill badge-secondary bg-grey\"\n              ngbTooltip=\"{{ 'summary.taskLocked' | translate }}\"\n            >\n              <i class=\"icon mdi mdi-lock\"></i>\n            </span>\n            <strong>{{ task.name }}</strong>\n            <div>Created {{ task.created }}</div>\n          </div>\n        </valtimo-widget>\n      </ng-container>\n      <valtimo-task-detail-modal\n        #taskDetail\n        (formSubmit)=\"init()\"\n        (assignmentOfTaskChanged)=\"init()\"\n      ></valtimo-task-detail-modal>\n    </div>\n  </div>\n</div>\n"]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/summary/summary.component.ts","../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/summary/summary.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  Component,\n  ElementRef, OnDestroy,\n  OnInit,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {ProcessInstanceTask, ProcessService} from '@valtimo/process';\nimport {ActivatedRoute, ParamMap, Router} from '@angular/router';\nimport {Document, DocumentService, ProcessDocumentInstance} from '@valtimo/document';\nimport {TaskDetailModalComponent, TaskService} from '@valtimo/task';\nimport {FormService} from '@valtimo/form';\nimport {FormioOptionsImpl, ValtimoFormioOptions} from '@valtimo/components';\nimport moment from 'moment';\nimport {FormioForm} from '@formio/angular';\nimport {UserProviderService} from '@valtimo/security';\nimport {Subscription} from 'rxjs';\n\nmoment.locale(localStorage.getItem('langKey') || '');\nmoment.defaultFormat = 'DD MMM YYYY HH:mm';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-summary',\n  templateUrl: './summary.component.html',\n  styleUrls: ['./summary.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DossierDetailTabSummaryComponent implements OnInit, OnDestroy {\n  public readonly documentDefinitionName: string;\n  public document: Document;\n  public documentId: string;\n  public processDocumentInstances: ProcessDocumentInstance[] = [];\n  private snapshot: ParamMap;\n  public tasks: ProcessInstanceTask[] = [];\n  public moment;\n  public formDefinition: FormioForm = null;\n  public options: ValtimoFormioOptions;\n  public roles: string[] = [];\n  private _subscriptions = new Subscription();\n  @ViewChild('taskDetail') taskDetail: TaskDetailModalComponent;\n\n  constructor(\n    private router: Router,\n    private documentService: DocumentService,\n    private taskService: TaskService,\n    private processService: ProcessService,\n    private el: ElementRef,\n    private renderer: Renderer2,\n    private route: ActivatedRoute,\n    private formService: FormService,\n    private userProviderService: UserProviderService\n  ) {\n    this.snapshot = this.route.snapshot.paramMap;\n    this.documentDefinitionName = this.snapshot.get('documentDefinitionName') || '';\n    this.documentId = this.snapshot.get('documentId') || '';\n    this.options = new FormioOptionsImpl();\n    this.options.disableAlerts = true;\n  }\n\n  ngOnInit() {\n    this.moment = moment;\n    this.init();\n  }\n\n  ngOnDestroy() {\n    this._subscriptions.unsubscribe();\n  }\n\n  init() {\n    this._subscriptions.add(\n      this.documentService.getDocument(this.documentId).subscribe(document => {\n        this.document = document;\n      })\n    );\n\n    this._subscriptions.add(\n      this.formService\n        .getFormDefinitionByNamePreFilled(`${this.documentDefinitionName}.summary`, this.documentId)\n        .subscribe(formDefinition => {\n          this.formDefinition = formDefinition;\n        })\n    );\n\n    this._subscriptions.add(\n      this.userProviderService.getUserSubject().subscribe(user => {\n        this.roles = user.roles;\n        this.tasks = [];\n        this.loadProcessDocumentInstances(this.documentId);\n      })\n    );\n  }\n\n  public loadProcessDocumentInstances(documentId: string) {\n    this._subscriptions.add(\n      this.documentService\n        .findProcessDocumentInstances(documentId)\n        .subscribe(processDocumentInstances => {\n          this.processDocumentInstances = processDocumentInstances;\n          this.processDocumentInstances.forEach(instance => {\n            this.loadProcessInstanceTasks(instance.id.processInstanceId);\n          });\n        })\n    );\n  }\n\n  private loadProcessInstanceTasks(processInstanceId: string) {\n    this._subscriptions.add(\n      this.processService.getProcessInstanceTasks(processInstanceId).subscribe(tasks => {\n        if (tasks != null) {\n          tasks.forEach(task => {\n            task.createdUnix = this.moment(task.created).unix();\n            task.created = this.moment(task.created).format('DD MMM YYYY HH:mm');\n            task.isLocked = () => {\n              let locked = true;\n              for (const link of task.identityLinks) {\n                if (link.type === 'candidate' && link.groupId) {\n                  if (this.roles.includes(link.groupId)) {\n                    locked = false;\n                    break;\n                  }\n                }\n              }\n              return locked;\n            };\n          });\n          this.tasks = this.tasks.concat(tasks);\n          this.tasks.sort((t1, t2) => t2.createdUnix - t1.createdUnix);\n        }\n      })\n    );\n  }\n\n  public rowTaskClick(task: any) {\n    this.taskDetail.openTaskDetails(task);\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div class=\"container-fluid\">\n  <div class=\"row py-4\">\n    <div class=\"col-sm-12 col-md-8 col-xl-9\">\n      <div *ngIf=\"document\">\n        <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n          <div class=\"mb-4\">\n            <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!--Current user tasks right side-->\n    <div class=\"col-sm-12 col-md-4 col-xl-3\">\n      <h4 class=\"user-tasks-title\">{{ 'summary.userTasks' | translate }}</h4>\n      <ng-container *ngIf=\"!tasks.length\">\n        <valtimo-widget>\n          <div class=\"p-3\">\n            <img class=\"float-left\" src=\"assets/audit-2.png\" height=\"25\" />\n            <span class=\"float-right\">{{ 'summary.userTasksDoneState' | translate }}</span>\n            <div class=\"clearfix\"></div>\n          </div>\n        </valtimo-widget>\n      </ng-container>\n      <ng-container *ngFor=\"let task of tasks\">\n        <valtimo-widget>\n          <div\n            class=\"p-3 clickable hoverable\"\n            (click)=\"rowTaskClick(task)\"\n            *ngIf=\"!task.isLocked()\"\n          >\n            <span class=\"float-right badge badge-pill badge-primary\">{{ 'summary.taskOpen' | translate }}</span>\n            <strong>{{ task.name }}</strong>\n            <div>{{ 'summary.taskCreated' | translate }} {{ task.created }}</div>\n          </div>\n          <div class=\"p-3 hoverable\" *ngIf=\"task.isLocked()\">\n            <span\n              class=\"float-right badge badge-pill badge-secondary bg-grey\"\n              ngbTooltip=\"{{ 'summary.taskLocked' | translate }}\"\n            >\n              <i class=\"icon mdi mdi-lock\"></i>\n            </span>\n            <strong>{{ task.name }}</strong>\n            <div>{{ 'summary.taskCreated' | translate }} {{ task.created }}</div>\n          </div>\n        </valtimo-widget>\n      </ng-container>\n      <valtimo-task-detail-modal\n        #taskDetail\n        (formSubmit)=\"init()\"\n        (assignmentOfTaskChanged)=\"init()\"\n      ></valtimo-task-detail-modal>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -102,7 +102,7 @@ export class DossierDetailTabZaakobjectenComponent {
|
|
|
102
102
|
}
|
|
103
103
|
}
|
|
104
104
|
DossierDetailTabZaakobjectenComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabZaakobjectenComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.ZaakobjectenService }, { token: i3.ModalService }], target: i0.ɵɵFactoryTarget.Component });
|
|
105
|
-
DossierDetailTabZaakobjectenComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailTabZaakobjectenComponent, selector: "valtimo-dossier-detail-tab-zaakobjecten", viewQueries: [{ propertyName: "viewZaakobjectModal", first: true, predicate: ["viewZaakobjectModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n objecttypeSelectItems: objecttypeSelectItems$ | async,\n objects: objects$ | async,\n columns: columns$ | async,\n selectedObjectTypeUrl: selectedObjecttypeUrl$ | async\n } as obs\"\n>\n <v-select\n [items]=\"obs.objecttypeSelectItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"objecttypes\"\n [title]=\"'dossier.zaakobjecten.objecttype' | translate\"\n [placeholder]=\"'dossier.zaakobjecten.objecttypePlaceholder' | translate\"\n [loading]=\"!obs.objecttypeSelectItems\"\n (selectedChange)=\"selectObjectType($event)\"\n ></v-select>\n <v-input-label\n titleTranslationKey=\"dossier.zaakobjecten.objecten\"\n [largeMargin]=\"!!obs.selectedObjectTypeUrl\"\n ></v-input-label>\n <v-paragraph *ngIf=\"!obs.selectedObjectTypeUrl\">{{\n 'dossier.zaakobjecten.objectenPlaceholder' | translate\n }}</v-paragraph>\n <v-table\n *ngIf=\"obs.selectedObjectTypeUrl\"\n [loading]=\"!obs.objects\"\n [items]=\"obs.objects\"\n [columns]=\"obs.columns\"\n [showEditButtons]=\"true\"\n [amountOfLoadingRows]=\"2\"\n [itemsTranslationKey]=\"'pluginManagement.tableItemsText'\"\n [showPagination]=\"false\"\n editButtonTranslationKey=\"dossier.zaakobjecten.objectType.viewObject\"\n (editButtonClicked)=\"rowClicked($event, obs.objecttypeSelectItems)\"\n ></v-table>\n</ng-container>\n\n<v-modal #viewZaakobjectModal (closeEvent)=\"hide()\" [hideFooter]=\"true\" [maxWidthPx]=\"750\">\n <div role=\"header\">\n <v-title [margin]=\"false\" type=\"h2\" [fullWidth]=\"true\" [center]=\"true\">{{\n objectName$ | async\n }}</v-title>\n </div>\n\n <div role=\"content\">\n <valtimo-form-io\n *ngIf=\"(noFormDefinitionComponent$ | async) === false\"\n [form]=\"objectForm$ | async\"\n ></valtimo-form-io>\n <v-paragraph *ngIf=\"noFormDefinitionComponent$ | async\" [center]=\"true\">{{\n 'dossier.zaakobjecten.noFormDefinitionComponent' | translate\n }}</v-paragraph>\n </div>\n</v-modal>\n", styles: ["/*!\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], components: [{ type: i3.SelectComponent, selector: "v-select", inputs: ["items", "defaultSelection", "defaultSelectionId", "clearable", "disabled", "multiple", "margin", "widthInPx", "notFoundText", "clearAllText", "name", "title", "titleTranslationKey", "clearSelectionSubject$", "tooltip", "required", "loading", "loadingText", "placeholder"], outputs: ["selectedChange", "clear"] }, { type: i3.InputLabelComponent, selector: "v-input-label", inputs: ["name", "title", "titleTranslationKey", "tooltip", "required", "largeMargin"] }, { type: i3.ParagraphComponent, selector: "v-paragraph", inputs: ["center", "fullWidth", "margin", "italic", "loading"] }, { type: i3.TableComponent, selector: "v-table", inputs: ["items", "columns", "loading", "showEditButtons", "showPagination", "editButtonTranslationKey", "itemsTranslationKey", "noResultsTranslationKey", "mobileBreakpointPx", "amountOfLoadingRows", "collectionSize", "maxPaginationItemSize", "page", "size"], outputs: ["editButtonClicked", "paginationSizeSet", "paginationPageSet"] }, { type: i3.ModalComponent, selector: "v-modal", inputs: ["appearingDelayMs", "maxWidthPx", "hideFooter"], outputs: ["closeEvent"] }, { type: i3.TitleComponent, selector: "v-title", inputs: ["type", "margin", "fullWidth", "center"] }, { type: i4.FormioComponent, selector: "valtimo-form-io", inputs: ["form", "options", "submission", "formRefresh$"], outputs: ["submit", "change"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i5.AsyncPipe, "translate": i6.TranslatePipe } });
|
|
105
|
+
DossierDetailTabZaakobjectenComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailTabZaakobjectenComponent, selector: "valtimo-dossier-detail-tab-zaakobjecten", viewQueries: [{ propertyName: "viewZaakobjectModal", first: true, predicate: ["viewZaakobjectModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n objecttypeSelectItems: objecttypeSelectItems$ | async,\n objects: objects$ | async,\n columns: columns$ | async,\n selectedObjectTypeUrl: selectedObjecttypeUrl$ | async\n } as obs\"\n>\n <v-select\n [items]=\"obs.objecttypeSelectItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"objecttypes\"\n [title]=\"'dossier.zaakobjecten.objecttype' | translate\"\n [placeholder]=\"'dossier.zaakobjecten.objecttypePlaceholder' | translate\"\n [loading]=\"!obs.objecttypeSelectItems\"\n (selectedChange)=\"selectObjectType($event)\"\n ></v-select>\n <v-input-label\n titleTranslationKey=\"dossier.zaakobjecten.objecten\"\n [largeMargin]=\"!!obs.selectedObjectTypeUrl\"\n ></v-input-label>\n <v-paragraph *ngIf=\"!obs.selectedObjectTypeUrl\">{{\n 'dossier.zaakobjecten.objectenPlaceholder' | translate\n }}</v-paragraph>\n <v-table\n *ngIf=\"obs.selectedObjectTypeUrl\"\n [loading]=\"!obs.objects\"\n [items]=\"obs.objects\"\n [columns]=\"obs.columns\"\n [showEditButtons]=\"true\"\n [amountOfLoadingRows]=\"2\"\n [itemsTranslationKey]=\"'pluginManagement.tableItemsText'\"\n [showPagination]=\"false\"\n editButtonTranslationKey=\"dossier.zaakobjecten.objectType.viewObject\"\n (editButtonClicked)=\"rowClicked($event, obs.objecttypeSelectItems)\"\n ></v-table>\n</ng-container>\n\n<v-modal #viewZaakobjectModal (closeEvent)=\"hide()\" [hideFooter]=\"true\" [maxWidthPx]=\"750\">\n <div role=\"header\">\n <v-title [margin]=\"false\" type=\"h2\" [fullWidth]=\"true\" [center]=\"true\">{{\n objectName$ | async\n }}</v-title>\n </div>\n\n <div role=\"content\">\n <valtimo-form-io\n *ngIf=\"(noFormDefinitionComponent$ | async) === false\"\n [form]=\"objectForm$ | async\"\n ></valtimo-form-io>\n <v-paragraph *ngIf=\"noFormDefinitionComponent$ | async\" [center]=\"true\">{{\n 'dossier.zaakobjecten.noFormDefinitionComponent' | translate\n }}</v-paragraph>\n </div>\n</v-modal>\n", styles: ["/*!\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], components: [{ type: i3.SelectComponent, selector: "v-select", inputs: ["items", "defaultSelection", "defaultSelectionId", "clearable", "disabled", "multiple", "margin", "widthInPx", "notFoundText", "clearAllText", "name", "title", "titleTranslationKey", "clearSelectionSubject$", "tooltip", "required", "loading", "loadingText", "placeholder"], outputs: ["selectedChange", "clear"] }, { type: i3.InputLabelComponent, selector: "v-input-label", inputs: ["name", "title", "titleTranslationKey", "tooltip", "required", "largeMargin", "small"] }, { type: i3.ParagraphComponent, selector: "v-paragraph", inputs: ["center", "fullWidth", "margin", "italic", "loading"] }, { type: i3.TableComponent, selector: "v-table", inputs: ["items", "columns", "loading", "showEditButtons", "showPagination", "editButtonTranslationKey", "itemsTranslationKey", "noResultsTranslationKey", "mobileBreakpointPx", "amountOfLoadingRows", "collectionSize", "maxPaginationItemSize", "page", "size"], outputs: ["editButtonClicked", "paginationSizeSet", "paginationPageSet"] }, { type: i3.ModalComponent, selector: "v-modal", inputs: ["appearingDelayMs", "maxWidthPx", "hideFooter"], outputs: ["closeEvent"] }, { type: i3.TitleComponent, selector: "v-title", inputs: ["type", "margin", "fullWidth", "center"] }, { type: i4.FormioComponent, selector: "valtimo-form-io", inputs: ["form", "options", "submission", "formRefresh$"], outputs: ["submit", "change"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i5.AsyncPipe, "translate": i6.TranslatePipe } });
|
|
106
106
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabZaakobjectenComponent, decorators: [{
|
|
107
107
|
type: Component,
|
|
108
108
|
args: [{ selector: 'valtimo-dossier-detail-tab-zaakobjecten', template: "<!--\n ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n objecttypeSelectItems: objecttypeSelectItems$ | async,\n objects: objects$ | async,\n columns: columns$ | async,\n selectedObjectTypeUrl: selectedObjecttypeUrl$ | async\n } as obs\"\n>\n <v-select\n [items]=\"obs.objecttypeSelectItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"objecttypes\"\n [title]=\"'dossier.zaakobjecten.objecttype' | translate\"\n [placeholder]=\"'dossier.zaakobjecten.objecttypePlaceholder' | translate\"\n [loading]=\"!obs.objecttypeSelectItems\"\n (selectedChange)=\"selectObjectType($event)\"\n ></v-select>\n <v-input-label\n titleTranslationKey=\"dossier.zaakobjecten.objecten\"\n [largeMargin]=\"!!obs.selectedObjectTypeUrl\"\n ></v-input-label>\n <v-paragraph *ngIf=\"!obs.selectedObjectTypeUrl\">{{\n 'dossier.zaakobjecten.objectenPlaceholder' | translate\n }}</v-paragraph>\n <v-table\n *ngIf=\"obs.selectedObjectTypeUrl\"\n [loading]=\"!obs.objects\"\n [items]=\"obs.objects\"\n [columns]=\"obs.columns\"\n [showEditButtons]=\"true\"\n [amountOfLoadingRows]=\"2\"\n [itemsTranslationKey]=\"'pluginManagement.tableItemsText'\"\n [showPagination]=\"false\"\n editButtonTranslationKey=\"dossier.zaakobjecten.objectType.viewObject\"\n (editButtonClicked)=\"rowClicked($event, obs.objecttypeSelectItems)\"\n ></v-table>\n</ng-container>\n\n<v-modal #viewZaakobjectModal (closeEvent)=\"hide()\" [hideFooter]=\"true\" [maxWidthPx]=\"750\">\n <div role=\"header\">\n <v-title [margin]=\"false\" type=\"h2\" [fullWidth]=\"true\" [center]=\"true\">{{\n objectName$ | async\n }}</v-title>\n </div>\n\n <div role=\"content\">\n <valtimo-form-io\n *ngIf=\"(noFormDefinitionComponent$ | async) === false\"\n [form]=\"objectForm$ | async\"\n ></valtimo-form-io>\n <v-paragraph *ngIf=\"noFormDefinitionComponent$ | async\" [center]=\"true\">{{\n 'dossier.zaakobjecten.noFormDefinitionComponent' | translate\n }}</v-paragraph>\n </div>\n</v-modal>\n", styles: ["/*!\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
|