@valtimo/dossier 10.1.0 → 10.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/note-modal/note-modal.component.mjs +95 -0
- package/esm2020/lib/dossier-assign-user/dossier-assign-user.component.mjs +6 -2
- package/esm2020/lib/dossier-detail/dossier-detail.component.mjs +3 -3
- package/esm2020/lib/dossier-detail/tab/notes/notes.component.mjs +100 -0
- package/esm2020/lib/dossier-detail-tab-enum.mjs +2 -1
- package/esm2020/lib/dossier-list/dossier-list.component.mjs +43 -11
- package/esm2020/lib/dossier.module.mjs +22 -4
- package/esm2020/lib/dossier.service.mjs +3 -3
- package/esm2020/lib/models/notes.model.mjs +17 -0
- package/esm2020/lib/services/dossier-column.service.mjs +8 -2
- package/esm2020/lib/services/notes.service.mjs +70 -0
- package/esm2020/public_api.mjs +2 -1
- package/fesm2015/valtimo-dossier.mjs +318 -20
- package/fesm2015/valtimo-dossier.mjs.map +1 -1
- package/fesm2020/valtimo-dossier.mjs +318 -20
- package/fesm2020/valtimo-dossier.mjs.map +1 -1
- package/lib/components/note-modal/note-modal.component.d.ts +32 -0
- package/lib/components/note-modal/note-modal.component.d.ts.map +1 -0
- package/lib/dossier-assign-user/dossier-assign-user.component.d.ts.map +1 -1
- package/lib/dossier-detail/tab/notes/notes.component.d.ts +32 -0
- package/lib/dossier-detail/tab/notes/notes.component.d.ts.map +1 -0
- package/lib/dossier-detail-tab-enum.d.ts +2 -1
- package/lib/dossier-detail-tab-enum.d.ts.map +1 -1
- package/lib/dossier-list/dossier-list.component.d.ts +3 -13
- package/lib/dossier-list/dossier-list.component.d.ts.map +1 -1
- package/lib/dossier.module.d.ts +21 -19
- package/lib/dossier.module.d.ts.map +1 -1
- package/lib/models/notes.model.d.ts +13 -0
- package/lib/models/notes.model.d.ts.map +1 -0
- package/lib/services/dossier-column.service.d.ts +5 -1
- package/lib/services/dossier-column.service.d.ts.map +1 -1
- package/lib/services/notes.service.d.ts +28 -0
- package/lib/services/notes.service.d.ts.map +1 -0
- package/package.json +1 -1
- package/public_api.d.ts +1 -0
- package/public_api.d.ts.map +1 -1
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2020 Ritense BV, the Netherlands.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under EUPL, Version 1.2 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" basis,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
import { Component, EventEmitter, Output, ViewChild } from '@angular/core';
|
|
17
|
+
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
|
|
18
|
+
import { take } from 'rxjs/operators';
|
|
19
|
+
import * as i0 from "@angular/core";
|
|
20
|
+
import * as i1 from "../../services/notes.service";
|
|
21
|
+
import * as i2 from "@valtimo/user-interface";
|
|
22
|
+
import * as i3 from "@angular/common";
|
|
23
|
+
import * as i4 from "@ngx-translate/core";
|
|
24
|
+
export class NoteModalComponent {
|
|
25
|
+
constructor(notesService, modalService) {
|
|
26
|
+
this.notesService = notesService;
|
|
27
|
+
this.modalService = modalService;
|
|
28
|
+
this.createNoteEvent = new EventEmitter();
|
|
29
|
+
this.valid$ = new BehaviorSubject(false);
|
|
30
|
+
this.showForm$ = this.modalService.modalVisible$;
|
|
31
|
+
this.formData$ = new BehaviorSubject(null);
|
|
32
|
+
this.returnToFirstStepSubject$ = new Subject();
|
|
33
|
+
}
|
|
34
|
+
ngAfterViewInit() {
|
|
35
|
+
this.openShowSubscription();
|
|
36
|
+
this.openHideSubscription();
|
|
37
|
+
}
|
|
38
|
+
ngOnDestroy() {
|
|
39
|
+
this.showSubscription?.unsubscribe();
|
|
40
|
+
this.hideSubscription?.unsubscribe();
|
|
41
|
+
}
|
|
42
|
+
hide() {
|
|
43
|
+
this.formData$.next(null);
|
|
44
|
+
this.valid$.next(false);
|
|
45
|
+
this.modalService.closeModal();
|
|
46
|
+
}
|
|
47
|
+
cancel() {
|
|
48
|
+
this.hide();
|
|
49
|
+
}
|
|
50
|
+
save() {
|
|
51
|
+
combineLatest([this.valid$, this.formData$])
|
|
52
|
+
.pipe(take(1))
|
|
53
|
+
.subscribe(([valid, formData]) => {
|
|
54
|
+
if (valid) {
|
|
55
|
+
this.createNoteEvent.emit(formData);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
openShowSubscription() {
|
|
60
|
+
this.showSubscription = this.notesService.showModal$.subscribe(() => {
|
|
61
|
+
this.show();
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
openHideSubscription() {
|
|
65
|
+
this.hideSubscription = this.notesService.hideModal$.subscribe(() => {
|
|
66
|
+
this.hide();
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
show() {
|
|
70
|
+
this.notesService.modalType$.pipe(take(1)).subscribe(modalType => {
|
|
71
|
+
if (modalType === 'add') {
|
|
72
|
+
this.modalService.openModal(this.addNoteModal);
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
formValueChange(data) {
|
|
77
|
+
this.formData$.next(data);
|
|
78
|
+
this.setValid(data);
|
|
79
|
+
}
|
|
80
|
+
setValid(data) {
|
|
81
|
+
this.valid$.next(!!data.content);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
NoteModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NoteModalComponent, deps: [{ token: i1.NotesService }, { token: i2.ModalService }], target: i0.ɵɵFactoryTarget.Component });
|
|
85
|
+
NoteModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: NoteModalComponent, selector: "valtimo-note-modal", outputs: { createNoteEvent: "createNoteEvent" }, viewQueries: [{ propertyName: "addNoteModal", first: true, predicate: ["addNoteModal"], 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<v-modal #addNoteModal *ngIf=\"{ disabled: disabled$ | async, valid: valid$ | async} as obs\">\n <div role=\"header\">\n <div class=\"add-note-title\">\n <v-title [margin]=\"false\">{{ 'dossier.notes.addNote' | translate }}</v-title>\n </div>\n </div>\n <div role=\"content\">\n <ng-container *ngTemplateOutlet=\"addForm\"></ng-container>\n </div>\n <div role=\"footer\">\n <div class=\"buttons\">\n <v-button (clickEvent)=\"cancel()\" [disabled]=\"obs.disabled\" type=\"secondary\">\n {{ 'document.cancel' | translate }}\n </v-button>\n <v-button (clickEvent)=\"save()\" [disabled]=\"obs.disabled || !obs.valid\" mdiIcon=\"plus\" type=\"success\">\n {{ 'dossier.notes.addNote' | translate }}\n </v-button>\n </div>\n </div>\n</v-modal>\n\n<ng-template #addForm>\n <ng-container *ngIf=\"showForm$ | async\">\n <v-form (valueChange)=\"formValueChange($event)\">\n <v-input\n type=\"textarea\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'dossier.notes.input.content' | translate\"\n name=\"content\"\n [fullWidth]=\"true\"\n [rows]=\"10\"\n >\n </v-input>\n </v-form>\n </ng-container>\n</ng-template>\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 */.buttons,.add-note-title{width:100%;display:flex;flex-direction:row;justify-content:space-between}.add-note-title{justify-content:center}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ModalComponent, selector: "v-modal", inputs: ["appearingDelayMs", "maxWidthPx", "hideFooter"], outputs: ["closeEvent"] }, { kind: "component", type: i2.TitleComponent, selector: "v-title", inputs: ["type", "margin", "fullWidth", "center"] }, { kind: "component", type: i2.ButtonComponent, selector: "v-button", inputs: ["type", "mdiIcon", "disabled", "title", "titleTranslationKey"], outputs: ["clickEvent"] }, { kind: "component", type: i2.InputComponent, selector: "v-input", inputs: ["name", "type", "title", "titleTranslationKey", "defaultValue", "widthPx", "fullWidth", "margin", "disabled", "step", "min", "maxLength", "tooltip", "required", "hideNumberSpinBox", "smallLabel", "rows", "clear$"], outputs: ["valueChange"] }, { kind: "component", type: i2.FormComponent, selector: "v-form", inputs: ["className"], outputs: ["valueChange"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] });
|
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NoteModalComponent, decorators: [{
|
|
87
|
+
type: Component,
|
|
88
|
+
args: [{ selector: 'valtimo-note-modal', 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<v-modal #addNoteModal *ngIf=\"{ disabled: disabled$ | async, valid: valid$ | async} as obs\">\n <div role=\"header\">\n <div class=\"add-note-title\">\n <v-title [margin]=\"false\">{{ 'dossier.notes.addNote' | translate }}</v-title>\n </div>\n </div>\n <div role=\"content\">\n <ng-container *ngTemplateOutlet=\"addForm\"></ng-container>\n </div>\n <div role=\"footer\">\n <div class=\"buttons\">\n <v-button (clickEvent)=\"cancel()\" [disabled]=\"obs.disabled\" type=\"secondary\">\n {{ 'document.cancel' | translate }}\n </v-button>\n <v-button (clickEvent)=\"save()\" [disabled]=\"obs.disabled || !obs.valid\" mdiIcon=\"plus\" type=\"success\">\n {{ 'dossier.notes.addNote' | translate }}\n </v-button>\n </div>\n </div>\n</v-modal>\n\n<ng-template #addForm>\n <ng-container *ngIf=\"showForm$ | async\">\n <v-form (valueChange)=\"formValueChange($event)\">\n <v-input\n type=\"textarea\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'dossier.notes.input.content' | translate\"\n name=\"content\"\n [fullWidth]=\"true\"\n [rows]=\"10\"\n >\n </v-input>\n </v-form>\n </ng-container>\n</ng-template>\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 */.buttons,.add-note-title{width:100%;display:flex;flex-direction:row;justify-content:space-between}.add-note-title{justify-content:center}\n"] }]
|
|
89
|
+
}], ctorParameters: function () { return [{ type: i1.NotesService }, { type: i2.ModalService }]; }, propDecorators: { addNoteModal: [{
|
|
90
|
+
type: ViewChild,
|
|
91
|
+
args: ['addNoteModal']
|
|
92
|
+
}], createNoteEvent: [{
|
|
93
|
+
type: Output
|
|
94
|
+
}] } });
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"note-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/note-modal/note-modal.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/note-modal/note-modal.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 {AfterViewInit, Component, EventEmitter, OnDestroy, Output, ViewChild} from '@angular/core';\nimport {ModalComponent as vModalComponent, ModalService} from '@valtimo/user-interface';\nimport {BehaviorSubject, combineLatest, Observable, Subject, Subscription} from 'rxjs';\nimport {take} from 'rxjs/operators';\nimport {NotesService} from '../../services/notes.service';\n\n@Component({\n  selector: 'valtimo-note-modal',\n  templateUrl: './note-modal.component.html',\n  styleUrls: ['./note-modal.component.scss'],\n})\nexport class NoteModalComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('addNoteModal') addNoteModal: vModalComponent;\n  @Output() createNoteEvent: EventEmitter<any> = new EventEmitter();\n\n  readonly disabled$!: Observable<boolean>;\n  readonly valid$ = new BehaviorSubject<boolean>(false);\n  readonly showForm$: Observable<boolean> = this.modalService.modalVisible$;\n  readonly formData$ = new BehaviorSubject<any>(null);\n\n  showSubscription!: Subscription;\n  hideSubscription!: Subscription;\n\n  readonly returnToFirstStepSubject$ = new Subject<boolean>();\n\n  constructor(\n    private readonly notesService: NotesService,\n    private readonly modalService: ModalService\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.openShowSubscription();\n    this.openHideSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this.showSubscription?.unsubscribe();\n    this.hideSubscription?.unsubscribe();\n  }\n\n  hide(): void {\n    this.formData$.next(null);\n    this.valid$.next(false);\n    this.modalService.closeModal();\n  }\n\n  cancel(): void {\n    this.hide();\n  }\n\n  save(): void {\n    combineLatest([this.valid$, this.formData$])\n      .pipe(take(1))\n      .subscribe(([valid, formData]) => {\n        if (valid) {\n          this.createNoteEvent.emit(formData);\n        }\n      });\n  }\n\n  private openShowSubscription(): void {\n    this.showSubscription = this.notesService.showModal$.subscribe(() => {\n      this.show();\n    });\n  }\n\n  private openHideSubscription(): void {\n    this.hideSubscription = this.notesService.hideModal$.subscribe(() => {\n      this.hide();\n    });\n  }\n\n  private show(): void {\n    this.notesService.modalType$.pipe(take(1)).subscribe(modalType => {\n      if (modalType === 'add') {\n        this.modalService.openModal(this.addNoteModal);\n      }\n    });\n  }\n\n  formValueChange(data: any): void {\n    this.formData$.next(data);\n    this.setValid(data);\n  }\n\n  private setValid(data: any): void {\n    this.valid$.next(\n      !!data.content\n    );\n  }\n\n}\n","<!--\n  ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<v-modal #addNoteModal  *ngIf=\"{ disabled: disabled$ | async, valid: valid$ | async} as obs\">\n  <div role=\"header\">\n    <div class=\"add-note-title\">\n      <v-title [margin]=\"false\">{{ 'dossier.notes.addNote' | translate }}</v-title>\n    </div>\n  </div>\n  <div role=\"content\">\n    <ng-container *ngTemplateOutlet=\"addForm\"></ng-container>\n  </div>\n  <div role=\"footer\">\n    <div class=\"buttons\">\n      <v-button (clickEvent)=\"cancel()\" [disabled]=\"obs.disabled\" type=\"secondary\">\n        {{ 'document.cancel' | translate }}\n      </v-button>\n      <v-button (clickEvent)=\"save()\" [disabled]=\"obs.disabled || !obs.valid\" mdiIcon=\"plus\" type=\"success\">\n        {{ 'dossier.notes.addNote' | translate }}\n      </v-button>\n    </div>\n  </div>\n</v-modal>\n\n<ng-template #addForm>\n  <ng-container *ngIf=\"showForm$ | async\">\n    <v-form (valueChange)=\"formValueChange($event)\">\n      <v-input\n              type=\"textarea\"\n              [margin]=\"true\"\n              [required]=\"true\"\n              [title]=\"'dossier.notes.input.content' | translate\"\n              name=\"content\"\n              [fullWidth]=\"true\"\n              [rows]=\"10\"\n      >\n      </v-input>\n    </v-form>\n  </ng-container>\n</ng-template>\n"]}
|
|
@@ -85,7 +85,11 @@ export class DossierAssignUserComponent {
|
|
|
85
85
|
mapUsersForDropdown(users) {
|
|
86
86
|
return (users &&
|
|
87
87
|
users
|
|
88
|
-
.sort((a, b) =>
|
|
88
|
+
.sort((a, b) => {
|
|
89
|
+
if (a.lastName && b.lastName) {
|
|
90
|
+
return a.lastName.localeCompare(b.lastName);
|
|
91
|
+
}
|
|
92
|
+
})
|
|
89
93
|
.map(user => ({ text: `${user.firstName} ${user.lastName}`, id: user.id })));
|
|
90
94
|
}
|
|
91
95
|
clear() {
|
|
@@ -116,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
116
120
|
}], assignmentOfDocumentChanged: [{
|
|
117
121
|
type: Output
|
|
118
122
|
}] } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-assign-user.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/dossier-assign-user/dossier-assign-user.component.ts","../../../../../../projects/valtimo/dossier/src/lib/dossier-assign-user/dossier-assign-user.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  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport {DropdownItem} from '@valtimo/components';\nimport {BehaviorSubject, Subscription} from 'rxjs';\nimport {tap} from 'rxjs/operators';\nimport {User} from '@valtimo/config';\nimport {DocumentService} from '@valtimo/document';\n\n@Component({\n  selector: 'valtimo-dossier-assign-user',\n  templateUrl: './dossier-assign-user.component.html',\n  styleUrls: ['./dossier-assign-user.component.css'],\n})\nexport class DossierAssignUserComponent implements OnInit, OnChanges, OnDestroy {\n  @Input() documentId: string;\n  @Input() assigneeId: string;\n  @Input() assigneeFullName: string;\n\n  @Output() assignmentOfDocumentChanged = new EventEmitter();\n\n  userIdToAssign: string | null = null;\n\n  readonly candidateUsersForDocument$ = new BehaviorSubject<User[]>(undefined);\n  readonly disabled$ = new BehaviorSubject<boolean>(true);\n  readonly assignedIdOnServer$ = new BehaviorSubject<string>(null);\n  readonly assignedUserFullName$ = new BehaviorSubject<string>(null);\n\n  private _subscriptions = new Subscription();\n\n  constructor(private readonly documentService: DocumentService) {}\n\n  ngOnInit(): void {\n    this._subscriptions.add(\n      this.documentService.getCandidateUsers(this.documentId).subscribe(candidateUsers => {\n        this.candidateUsersForDocument$.next(candidateUsers);\n        if (this.assigneeId) {\n          this.assignedIdOnServer$.next(this.assigneeId);\n          this.userIdToAssign = this.assigneeId;\n          this.assignedUserFullName$.next(this.assigneeFullName);\n        }\n        this.enable();\n      })\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const assigneeId = changes?.assigneeId?.currentValue;\n    const assigneeFullName = changes?.assigneeFullName?.currentValue;\n\n    if (assigneeId && assigneeFullName) {\n      this.assignedIdOnServer$.next(assigneeId || null);\n      this.userIdToAssign = assigneeId || null;\n      this.assignedUserFullName$.next(assigneeFullName);\n    } else {\n      this.clear();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  assignDocument(userId: string): void {\n    this.disable();\n\n    this.documentService\n      .assignHandlerToDocument(this.documentId, userId)\n      .pipe(\n        tap(() => {\n          this.userIdToAssign = userId;\n          this.assignedIdOnServer$.next(userId);\n          this.assignedUserFullName$.next(this.assigneeFullName);\n          this.emitChange();\n          this.enable();\n        })\n      )\n      .subscribe();\n  }\n\n  unassignDocument(): void {\n    this.disable();\n    this.documentService\n      .unassignHandlerFromDocument(this.documentId)\n      .pipe(\n        tap(() => {\n          this.clear();\n          this.emitChange();\n          this.enable();\n        })\n      )\n      .subscribe();\n  }\n\n  mapUsersForDropdown(users: User[]): DropdownItem[] {\n    return (\n      users &&\n      users\n        .sort((a, b) => a.lastName.localeCompare(b.lastName))\n        .map(user => ({text: `${user.firstName} ${user.lastName}`, id: user.id}))\n    );\n  }\n\n  private clear(): void {\n    this.assignedIdOnServer$.next(null);\n    this.userIdToAssign = null;\n  }\n\n  private emitChange(): void {\n    this.assignmentOfDocumentChanged.emit();\n  }\n\n  private enable(): void {\n    this.disabled$.next(false);\n  }\n\n  private disable(): void {\n    this.disabled$.next(true);\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    candidateUsers: candidateUsersForDocument$ | async,\n    idOnServer: assignedIdOnServer$ | async,\n    fullName: assignedUserFullName$ | async,\n    disabled: disabled$ | async\n  } as obs\"\n>\n  <div class=\"container-fluid\">\n    <div class=\"row\">\n      <div class=\"col-12 pl-0 d-flex flex-row align-items-center\">\n        <ng-container *ngIf=\"obs.candidateUsers; else loading\">\n          <valtimo-searchable-dropdown-select\n            [disabled]=\"obs.disabled\"\n            id=\"dossier-candidates-dropdown\"\n            [style]=\"'underlinedText'\"\n            [items]=\"mapUsersForDropdown(obs.candidateUsers)\"\n            [buttonText]=\"'assignDocument.header' | translate\"\n            [searchText]=\"'interface.typeToSearch' | translate\"\n            [noResultsText]=\"'interface.noSearchResults' | translate\"\n            [selectedText]=\"'assignDocument.assignedTo' | translate\"\n            [selectedTextValue]=\"assignedUserFullName$ | async\"\n            [clearSelectionButtonTitle]=\"'assignDocument.remove' | translate\"\n            [hasSelection]=\"\n              userIdToAssign === obs.idOnServer && obs.idOnServer !== null && obs.fullName\n            \"\n            [width]=\"250\"\n            (itemSelected)=\"assignDocument($event)\"\n            (clearSelection)=\"unassignDocument()\"\n          >\n          </valtimo-searchable-dropdown-select>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n</ng-container>\n\n<ng-template #loading>\n  <h5>\n    <b>{{ 'assignDocument.fetchingUsers' | translate }}</b>\n  </h5>\n</ng-template>\n"]}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-assign-user.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/dossier-assign-user/dossier-assign-user.component.ts","../../../../../../projects/valtimo/dossier/src/lib/dossier-assign-user/dossier-assign-user.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAIL,MAAM,GAEP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,eAAe,EAAE,YAAY,EAAC,MAAM,MAAM,CAAC;AACnD,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;;;;;;AASnC,MAAM,OAAO,0BAA0B;IAgBrC,YAA6B,eAAgC;QAAhC,oBAAe,GAAf,eAAe,CAAiB;QAXnD,gCAA2B,GAAG,IAAI,YAAY,EAAE,CAAC;QAE3D,mBAAc,GAAkB,IAAI,CAAC;QAE5B,+BAA0B,GAAG,IAAI,eAAe,CAAS,SAAS,CAAC,CAAC;QACpE,cAAS,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QAC/C,wBAAmB,GAAG,IAAI,eAAe,CAAS,IAAI,CAAC,CAAC;QACxD,0BAAqB,GAAG,IAAI,eAAe,CAAS,IAAI,CAAC,CAAC;QAE3D,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;IAEoB,CAAC;IAEjE,QAAQ;QACN,IAAI,CAAC,cAAc,CAAC,GAAG,CACrB,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE;YACjF,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACrD,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC/C,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC;gBACtC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;aACxD;YACD,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,MAAM,UAAU,GAAG,OAAO,EAAE,UAAU,EAAE,YAAY,CAAC;QACrD,MAAM,gBAAgB,GAAG,OAAO,EAAE,gBAAgB,EAAE,YAAY,CAAC;QAEjE,IAAI,UAAU,IAAI,gBAAgB,EAAE;YAClC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,CAAC;YAClD,IAAI,CAAC,cAAc,GAAG,UAAU,IAAI,IAAI,CAAC;YACzC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SACnD;aAAM;YACL,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAED,cAAc,CAAC,MAAc;QAC3B,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,CAAC,eAAe;aACjB,uBAAuB,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC;aAChD,IAAI,CACH,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;YAC7B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACtC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACvD,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,eAAe;aACjB,2BAA2B,CAAC,IAAI,CAAC,UAAU,CAAC;aAC5C,IAAI,CACH,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAED,mBAAmB,CAAC,KAAa;QAC/B,OAAO,CACL,KAAK;YACL,KAAK;iBACF,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBACb,IAAI,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,EAAE;oBAC5B,OAAO,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;iBAC5C;YACH,CAAC,CAAC;iBACD,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAC,IAAI,EAAE,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAC,CAAC,CAAC,CAC5E,CAAC;IACJ,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;IAC7B,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,2BAA2B,CAAC,IAAI,EAAE,CAAC;IAC1C,CAAC;IAEO,MAAM;QACZ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAEO,OAAO;QACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;;wHA5GU,0BAA0B;4GAA1B,0BAA0B,uQCrCvC,+uEA0DA;4FDrBa,0BAA0B;kBALtC,SAAS;+BACE,6BAA6B;sGAK9B,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEI,2BAA2B;sBAApC,MAAM","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  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport {DropdownItem} from '@valtimo/components';\nimport {BehaviorSubject, Subscription} from 'rxjs';\nimport {tap} from 'rxjs/operators';\nimport {User} from '@valtimo/config';\nimport {DocumentService} from '@valtimo/document';\n\n@Component({\n  selector: 'valtimo-dossier-assign-user',\n  templateUrl: './dossier-assign-user.component.html',\n  styleUrls: ['./dossier-assign-user.component.css'],\n})\nexport class DossierAssignUserComponent implements OnInit, OnChanges, OnDestroy {\n  @Input() documentId: string;\n  @Input() assigneeId: string;\n  @Input() assigneeFullName: string;\n\n  @Output() assignmentOfDocumentChanged = new EventEmitter();\n\n  userIdToAssign: string | null = null;\n\n  readonly candidateUsersForDocument$ = new BehaviorSubject<User[]>(undefined);\n  readonly disabled$ = new BehaviorSubject<boolean>(true);\n  readonly assignedIdOnServer$ = new BehaviorSubject<string>(null);\n  readonly assignedUserFullName$ = new BehaviorSubject<string>(null);\n\n  private _subscriptions = new Subscription();\n\n  constructor(private readonly documentService: DocumentService) {}\n\n  ngOnInit(): void {\n    this._subscriptions.add(\n      this.documentService.getCandidateUsers(this.documentId).subscribe(candidateUsers => {\n        this.candidateUsersForDocument$.next(candidateUsers);\n        if (this.assigneeId) {\n          this.assignedIdOnServer$.next(this.assigneeId);\n          this.userIdToAssign = this.assigneeId;\n          this.assignedUserFullName$.next(this.assigneeFullName);\n        }\n        this.enable();\n      })\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const assigneeId = changes?.assigneeId?.currentValue;\n    const assigneeFullName = changes?.assigneeFullName?.currentValue;\n\n    if (assigneeId && assigneeFullName) {\n      this.assignedIdOnServer$.next(assigneeId || null);\n      this.userIdToAssign = assigneeId || null;\n      this.assignedUserFullName$.next(assigneeFullName);\n    } else {\n      this.clear();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  assignDocument(userId: string): void {\n    this.disable();\n\n    this.documentService\n      .assignHandlerToDocument(this.documentId, userId)\n      .pipe(\n        tap(() => {\n          this.userIdToAssign = userId;\n          this.assignedIdOnServer$.next(userId);\n          this.assignedUserFullName$.next(this.assigneeFullName);\n          this.emitChange();\n          this.enable();\n        })\n      )\n      .subscribe();\n  }\n\n  unassignDocument(): void {\n    this.disable();\n    this.documentService\n      .unassignHandlerFromDocument(this.documentId)\n      .pipe(\n        tap(() => {\n          this.clear();\n          this.emitChange();\n          this.enable();\n        })\n      )\n      .subscribe();\n  }\n\n  mapUsersForDropdown(users: User[]): DropdownItem[] {\n    return (\n      users &&\n      users\n        .sort((a, b) => {\n          if (a.lastName && b.lastName) {\n            return a.lastName.localeCompare(b.lastName)\n          }\n        })\n        .map(user => ({text: `${user.firstName} ${user.lastName}`, id: user.id}))\n    );\n  }\n\n  private clear(): void {\n    this.assignedIdOnServer$.next(null);\n    this.userIdToAssign = null;\n  }\n\n  private emitChange(): void {\n    this.assignmentOfDocumentChanged.emit();\n  }\n\n  private enable(): void {\n    this.disabled$.next(false);\n  }\n\n  private disable(): void {\n    this.disabled$.next(true);\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    candidateUsers: candidateUsersForDocument$ | async,\n    idOnServer: assignedIdOnServer$ | async,\n    fullName: assignedUserFullName$ | async,\n    disabled: disabled$ | async\n  } as obs\"\n>\n  <div class=\"container-fluid\">\n    <div class=\"row\">\n      <div class=\"col-12 pl-0 d-flex flex-row align-items-center\">\n        <ng-container *ngIf=\"obs.candidateUsers; else loading\">\n          <valtimo-searchable-dropdown-select\n            [disabled]=\"obs.disabled\"\n            id=\"dossier-candidates-dropdown\"\n            [style]=\"'underlinedText'\"\n            [items]=\"mapUsersForDropdown(obs.candidateUsers)\"\n            [buttonText]=\"'assignDocument.header' | translate\"\n            [searchText]=\"'interface.typeToSearch' | translate\"\n            [noResultsText]=\"'interface.noSearchResults' | translate\"\n            [selectedText]=\"'assignDocument.assignedTo' | translate\"\n            [selectedTextValue]=\"assignedUserFullName$ | async\"\n            [clearSelectionButtonTitle]=\"'assignDocument.remove' | translate\"\n            [hasSelection]=\"\n              userIdToAssign === obs.idOnServer && obs.idOnServer !== null && obs.fullName\n            \"\n            [width]=\"250\"\n            (itemSelected)=\"assignDocument($event)\"\n            (clearSelection)=\"unassignDocument()\"\n          >\n          </valtimo-searchable-dropdown-select>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n</ng-container>\n\n<ng-template #loading>\n  <h5>\n    <b>{{ 'assignDocument.fetchingUsers' | translate }}</b>\n  </h5>\n</ng-template>\n"]}
|
|
@@ -148,10 +148,10 @@ export class DossierDetailComponent {
|
|
|
148
148
|
}
|
|
149
149
|
}
|
|
150
150
|
DossierDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", 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 });
|
|
151
|
-
DossierDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", 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\" *ngIf=\"{canHaveAssignee: canHaveAssignee$ | async} as obs\">\n <div class=\"col\">\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailHeader;\n context: {canHaveAssignee: obs.canHaveAssignee}\n \"\n ></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\n *ngTemplateOutlet=\"claimButton; context: {canHaveAssignee: obs.canHaveAssignee}\"\n ></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?.id?.processDefinitionKey | translate) !== processDocumentDefinition?.id?.processDefinitionKey\n ? (processDocumentDefinition.id.processDefinitionKey | translate)\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 let-canHaveAssignee=\"canHaveAssignee\">\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\n *ngTemplateOutlet=\"caseDetailAssignee; context: {canHaveAssignee: canHaveAssignee}\"\n ></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 let-canHaveAssignee=\"canHaveAssignee\">\n <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"canHaveAssignee &&
|
|
151
|
+
DossierDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", 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\" *ngIf=\"{canHaveAssignee: canHaveAssignee$ | async, document: document$ | async} as obs\">\n <div class=\"col\">\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailHeader;\n context: {canHaveAssignee: obs.canHaveAssignee, document: obs.document}\n \"\n ></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\n *ngTemplateOutlet=\"claimButton; context: {canHaveAssignee: obs.canHaveAssignee}\"\n ></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?.id?.processDefinitionKey | translate) !== processDocumentDefinition?.id?.processDefinitionKey\n ? (processDocumentDefinition.id.processDefinitionKey | translate)\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 let-canHaveAssignee=\"canHaveAssignee\" let-document=\"document\">\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\n *ngTemplateOutlet=\"caseDetailAssignee; context: {canHaveAssignee: canHaveAssignee, document: document}\"\n ></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 let-canHaveAssignee=\"canHaveAssignee\" let-document=\"document\">\n <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"canHaveAssignee && document\">\n <valtimo-dossier-assign-user\n [documentId]=\"document.id\"\n [assigneeId]=\"document.assigneeId\"\n [assigneeFullName]=\"document?.assigneeFullName\"\n (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n ></valtimo-dossier-assign-user>\n </div>\n</ng-template>\n\n<ng-template #claimButton let-canHaveAssignee=\"canHaveAssignee\">\n <div class=\"user-full-name\" *ngIf=\"canHaveAssignee\">\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"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i10.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { kind: "directive", type: i11.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "component", type: i7.ExtensionComponent, selector: "valtimo-extension", inputs: ["module", "page", "section"] }, { kind: "component", type: i12.DossierSupportingProcessStartModalComponent, selector: "valtimo-dossier-supporting-process-start-modal", outputs: ["formSubmit"] }, { kind: "component", type: i13.DossierAssignUserComponent, selector: "valtimo-dossier-assign-user", inputs: ["documentId", "assigneeId", "assigneeFullName"], outputs: ["assignmentOfDocumentChanged"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
|
|
152
152
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DossierDetailComponent, decorators: [{
|
|
153
153
|
type: Component,
|
|
154
|
-
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\" *ngIf=\"{canHaveAssignee: canHaveAssignee$ | async} as obs\">\n <div class=\"col\">\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailHeader;\n context: {canHaveAssignee: obs.canHaveAssignee}\n \"\n ></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\n *ngTemplateOutlet=\"claimButton; context: {canHaveAssignee: obs.canHaveAssignee}\"\n ></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?.id?.processDefinitionKey | translate) !== processDocumentDefinition?.id?.processDefinitionKey\n ? (processDocumentDefinition.id.processDefinitionKey | translate)\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 let-canHaveAssignee=\"canHaveAssignee\">\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\n *ngTemplateOutlet=\"caseDetailAssignee; context: {canHaveAssignee: canHaveAssignee}\"\n ></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 let-canHaveAssignee=\"canHaveAssignee\">\n <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"canHaveAssignee &&
|
|
154
|
+
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\" *ngIf=\"{canHaveAssignee: canHaveAssignee$ | async, document: document$ | async} as obs\">\n <div class=\"col\">\n <ng-container\n *ngTemplateOutlet=\"\n caseDetailHeader;\n context: {canHaveAssignee: obs.canHaveAssignee, document: obs.document}\n \"\n ></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\n *ngTemplateOutlet=\"claimButton; context: {canHaveAssignee: obs.canHaveAssignee}\"\n ></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?.id?.processDefinitionKey | translate) !== processDocumentDefinition?.id?.processDefinitionKey\n ? (processDocumentDefinition.id.processDefinitionKey | translate)\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 let-canHaveAssignee=\"canHaveAssignee\" let-document=\"document\">\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\n *ngTemplateOutlet=\"caseDetailAssignee; context: {canHaveAssignee: canHaveAssignee, document: document}\"\n ></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 let-canHaveAssignee=\"canHaveAssignee\" let-document=\"document\">\n <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"canHaveAssignee && document\">\n <valtimo-dossier-assign-user\n [documentId]=\"document.id\"\n [assigneeId]=\"document.assigneeId\"\n [assigneeFullName]=\"document?.assigneeFullName\"\n (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n ></valtimo-dossier-assign-user>\n </div>\n</ng-template>\n\n<ng-template #claimButton let-canHaveAssignee=\"canHaveAssignee\">\n <div class=\"user-full-name\" *ngIf=\"canHaveAssignee\">\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"] }]
|
|
155
155
|
}], 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: [{
|
|
156
156
|
type: ViewChild,
|
|
157
157
|
args: ['tabContainer', { read: ViewContainerRef, static: true }]
|
|
@@ -159,4 +159,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
159
159
|
type: ViewChild,
|
|
160
160
|
args: ['supportingProcessStartModal']
|
|
161
161
|
}] } });
|
|
162
|
-
//# 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 {Component, ComponentFactoryResolver, OnInit, ViewChild, ViewContainerRef,} 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, DossierListTab} from '@valtimo/config';\nimport moment from 'moment';\nimport {BehaviorSubject, combineLatest, from, map, Observable, of, startWith, switchMap, take, tap,} 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  public dossierStatusTabs: Array<DossierListTab> | null = null;\n\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  readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params.documentDefinitionName || '')\n  );\n\n  readonly canHaveAssignee$: Observable<boolean> = this.documentDefinitionName$.pipe(\n    switchMap(documentDefinitionName =>\n      this.documentService.getCaseSettings(documentDefinitionName)\n    ),\n    map(caseSettings => caseSettings?.canHaveAssignee)\n  );\n\n  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  assignmentOfDocumentChanged(): void {\n    this.refreshDocument$.next(null);\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 = [moment.ISO_8601, 'MM-DD-YYYY', 'DD-MM-YYYY', 'YYYY-MM-DD'];\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\" *ngIf=\"{canHaveAssignee: canHaveAssignee$ | async} as obs\">\n            <div class=\"col\">\n              <ng-container\n                *ngTemplateOutlet=\"\n                  caseDetailHeader;\n                  context: {canHaveAssignee: obs.canHaveAssignee}\n                \"\n              ></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\n                *ngTemplateOutlet=\"claimButton; context: {canHaveAssignee: obs.canHaveAssignee}\"\n              ></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?.id?.processDefinitionKey | translate) !== processDocumentDefinition?.id?.processDefinitionKey\n                    ? (processDocumentDefinition.id.processDefinitionKey | translate)\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 let-canHaveAssignee=\"canHaveAssignee\">\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\n    *ngTemplateOutlet=\"caseDetailAssignee; context: {canHaveAssignee: canHaveAssignee}\"\n  ></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 let-canHaveAssignee=\"canHaveAssignee\">\n  <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"canHaveAssignee && (document$ | async) as document\">\n    <valtimo-dossier-assign-user\n      [documentId]=\"document.id\"\n      [assigneeId]=\"document.assigneeId\"\n      [assigneeFullName]=\"document?.assigneeFullName\"\n      (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n    ></valtimo-dossier-assign-user>\n  </div>\n</ng-template>\n\n<ng-template #claimButton let-canHaveAssignee=\"canHaveAssignee\">\n  <div class=\"user-full-name\" *ngIf=\"canHaveAssignee\">\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"]}
|
|
162
|
+
//# 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 {Component, ComponentFactoryResolver, OnInit, ViewChild, ViewContainerRef,} 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, DossierListTab} from '@valtimo/config';\nimport moment from 'moment';\nimport {BehaviorSubject, combineLatest, from, map, Observable, of, startWith, switchMap, take, tap,} 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  public dossierStatusTabs: Array<DossierListTab> | null = null;\n\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  readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params.documentDefinitionName || '')\n  );\n\n  readonly canHaveAssignee$: Observable<boolean> = this.documentDefinitionName$.pipe(\n    switchMap(documentDefinitionName =>\n      this.documentService.getCaseSettings(documentDefinitionName)\n    ),\n    map(caseSettings => caseSettings?.canHaveAssignee)\n  );\n\n  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  assignmentOfDocumentChanged(): void {\n    this.refreshDocument$.next(null);\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 = [moment.ISO_8601, 'MM-DD-YYYY', 'DD-MM-YYYY', 'YYYY-MM-DD'];\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\" *ngIf=\"{canHaveAssignee: canHaveAssignee$ | async, document: document$ | async} as obs\">\n            <div class=\"col\">\n              <ng-container\n                *ngTemplateOutlet=\"\n                  caseDetailHeader;\n                  context: {canHaveAssignee: obs.canHaveAssignee, document: obs.document}\n                \"\n              ></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\n                *ngTemplateOutlet=\"claimButton; context: {canHaveAssignee: obs.canHaveAssignee}\"\n              ></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?.id?.processDefinitionKey | translate) !== processDocumentDefinition?.id?.processDefinitionKey\n                    ? (processDocumentDefinition.id.processDefinitionKey | translate)\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 let-canHaveAssignee=\"canHaveAssignee\" let-document=\"document\">\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\n    *ngTemplateOutlet=\"caseDetailAssignee; context: {canHaveAssignee: canHaveAssignee, document: document}\"\n  ></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 let-canHaveAssignee=\"canHaveAssignee\" let-document=\"document\">\n  <div class=\"row ml-0 mr-0 mt-1 mb-1\" *ngIf=\"canHaveAssignee && document\">\n    <valtimo-dossier-assign-user\n      [documentId]=\"document.id\"\n      [assigneeId]=\"document.assigneeId\"\n      [assigneeFullName]=\"document?.assigneeFullName\"\n      (assignmentOfDocumentChanged)=\"assignmentOfDocumentChanged()\"\n    ></valtimo-dossier-assign-user>\n  </div>\n</ng-template>\n\n<ng-template #claimButton let-canHaveAssignee=\"canHaveAssignee\">\n  <div class=\"user-full-name\" *ngIf=\"canHaveAssignee\">\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"]}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2020 Ritense BV, the Netherlands.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under EUPL, Version 1.2 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" basis,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
import { Component } from '@angular/core';
|
|
17
|
+
import { BehaviorSubject, combineLatest, map } from 'rxjs';
|
|
18
|
+
import { switchMap, take, tap } from 'rxjs/operators';
|
|
19
|
+
import { TimelineItemImpl } from '@valtimo/components';
|
|
20
|
+
import moment from 'moment';
|
|
21
|
+
import * as i0 from "@angular/core";
|
|
22
|
+
import * as i1 from "@angular/router";
|
|
23
|
+
import * as i2 from "../../../services/notes.service";
|
|
24
|
+
import * as i3 from "@ngx-translate/core";
|
|
25
|
+
import * as i4 from "@angular/common";
|
|
26
|
+
import * as i5 from "@valtimo/components";
|
|
27
|
+
import * as i6 from "@ng-bootstrap/ng-bootstrap";
|
|
28
|
+
import * as i7 from "../../../components/note-modal/note-modal.component";
|
|
29
|
+
export class DossierDetailTabNotesComponent {
|
|
30
|
+
constructor(route, notesService, translateService) {
|
|
31
|
+
this.route = route;
|
|
32
|
+
this.notesService = notesService;
|
|
33
|
+
this.translateService = translateService;
|
|
34
|
+
this.timelineItems = [];
|
|
35
|
+
this.loading$ = new BehaviorSubject(true);
|
|
36
|
+
this.fields$ = new BehaviorSubject([]);
|
|
37
|
+
this.documentId$ = this.route.params.pipe(map(params => params.documentId));
|
|
38
|
+
this.currentPageAndSize$ = new BehaviorSubject({
|
|
39
|
+
page: 0,
|
|
40
|
+
size: 10,
|
|
41
|
+
});
|
|
42
|
+
this.pageSizes$ = new BehaviorSubject({
|
|
43
|
+
collectionSize: 0,
|
|
44
|
+
maxPaginationItemSize: 5,
|
|
45
|
+
});
|
|
46
|
+
this.pagination$ = combineLatest([
|
|
47
|
+
this.currentPageAndSize$,
|
|
48
|
+
this.pageSizes$,
|
|
49
|
+
]).pipe(map(([currentPage, sizes]) => ({ ...currentPage, ...sizes, page: currentPage.page + 1 })));
|
|
50
|
+
this.notes$ = combineLatest([
|
|
51
|
+
this.documentId$,
|
|
52
|
+
this.currentPageAndSize$,
|
|
53
|
+
this.notesService.refresh$
|
|
54
|
+
]).pipe(tap(() => this.timelineItems = []), switchMap(([documentId, currentPage]) => this.notesService.getDocumentNotes(documentId, { page: currentPage.page, size: currentPage.size })), tap((res) => {
|
|
55
|
+
this.timelineItems = [];
|
|
56
|
+
this.pageSizes$.pipe(take(1)).subscribe(sizes => {
|
|
57
|
+
this.pageSizes$.next({ ...sizes, collectionSize: res.totalElements });
|
|
58
|
+
});
|
|
59
|
+
}), map((res) => res.content.map((note) => {
|
|
60
|
+
const noteCreatedDate = moment(note.createdDate).locale(this.translateService.currentLang);
|
|
61
|
+
this.timelineItems.push(new TimelineItemImpl(noteCreatedDate.format('DD MMM YYYY'), noteCreatedDate.format('HH:mm'), note.createdByUserFullName, noteCreatedDate.fromNow(), note.content, {}));
|
|
62
|
+
return ({
|
|
63
|
+
...note
|
|
64
|
+
});
|
|
65
|
+
})), tap(() => this.loading$.next(false)));
|
|
66
|
+
}
|
|
67
|
+
ngOnInit() {
|
|
68
|
+
this.translateService.onLangChange.subscribe(() => {
|
|
69
|
+
this.notesService.refresh();
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
paginationClicked(newPageNumber) {
|
|
73
|
+
this.currentPageAndSize$.pipe(take(1)).subscribe(currentPage => {
|
|
74
|
+
this.currentPageAndSize$.next({ ...currentPage, page: newPageNumber - 1 });
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
showAddModal() {
|
|
78
|
+
this.notesService.setModalType('add');
|
|
79
|
+
this.notesService.showModal();
|
|
80
|
+
}
|
|
81
|
+
createNewNote(content) {
|
|
82
|
+
this.documentId$
|
|
83
|
+
.pipe(take(1))
|
|
84
|
+
.pipe(tap(documentId => {
|
|
85
|
+
this.notesService.createDocumentNote(documentId, content)
|
|
86
|
+
.subscribe(() => {
|
|
87
|
+
this.notesService.refresh();
|
|
88
|
+
this.notesService.hideModal();
|
|
89
|
+
});
|
|
90
|
+
}))
|
|
91
|
+
.subscribe();
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
DossierDetailTabNotesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DossierDetailTabNotesComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.NotesService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
95
|
+
DossierDetailTabNotesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DossierDetailTabNotesComponent, selector: "valtimo-dossier-detail-tab-notes", 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<div class=\"notes\" *ngIf=\"{\n notes: notes$ | async,\n pagination: pagination$ | async,\n loading: loading$ | async\n } as obs\">\n\n <button\n class=\"btn btn-space btn-primary mr-1 add-note\"\n type=\"button\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n (click)=\"showAddModal()\"\n [disabled]=\"obs.loading\"\n >\n <span>{{ 'dossier.notes.addNote' | translate }}</span>\n <i class=\"ml-1 icon mdi mdi-plus\"></i>\n </button>\n\n <div *ngIf=\"timelineItems\">\n <valtimo-timeline [items]=\"timelineItems\"></valtimo-timeline>\n </div>\n\n <valtimo-spinner\n [useBootstrapSpinner]=\"false\"\n name=\"auditSpinner\"\n bdColor=\"rgba(125, 125, 125, 0.35)\"\n color=\"#264251\"\n type=\"square-jelly-box\"\n >\n </valtimo-spinner>\n\n <div class=\"d-flex justify-content-end row mr-0 ml-0\" *ngIf=\"obs.pagination\">\n <ngb-pagination\n *ngIf=\"obs.pagination.collectionSize > obs.pagination.size\"\n [collectionSize]=\"obs.pagination.collectionSize\"\n [(page)]=\"obs.pagination.page\"\n [pageSize]=\"obs.pagination.size\"\n [maxSize]=\"obs.pagination.size\"\n [rotate]=\"true\"\n (pageChange)=\"paginationClicked($event)\"\n ></ngb-pagination>\n </div>\n\n</div>\n\n<valtimo-note-modal (createNoteEvent)=\"createNewNote($event)\"></valtimo-note-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 */.notes{position:relative}.add-note{position:absolute;right:0}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.TimelineComponent, selector: "valtimo-timeline", inputs: ["items"] }, { kind: "component", type: i5.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "component", type: i6.NgbPagination, selector: "ngb-pagination", inputs: ["disabled", "boundaryLinks", "directionLinks", "ellipses", "rotate", "collectionSize", "maxSize", "page", "pageSize", "size"], outputs: ["pageChange"] }, { kind: "component", type: i7.NoteModalComponent, selector: "valtimo-note-modal", outputs: ["createNoteEvent"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] });
|
|
96
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DossierDetailTabNotesComponent, decorators: [{
|
|
97
|
+
type: Component,
|
|
98
|
+
args: [{ selector: 'valtimo-dossier-detail-tab-notes', 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<div class=\"notes\" *ngIf=\"{\n notes: notes$ | async,\n pagination: pagination$ | async,\n loading: loading$ | async\n } as obs\">\n\n <button\n class=\"btn btn-space btn-primary mr-1 add-note\"\n type=\"button\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n (click)=\"showAddModal()\"\n [disabled]=\"obs.loading\"\n >\n <span>{{ 'dossier.notes.addNote' | translate }}</span>\n <i class=\"ml-1 icon mdi mdi-plus\"></i>\n </button>\n\n <div *ngIf=\"timelineItems\">\n <valtimo-timeline [items]=\"timelineItems\"></valtimo-timeline>\n </div>\n\n <valtimo-spinner\n [useBootstrapSpinner]=\"false\"\n name=\"auditSpinner\"\n bdColor=\"rgba(125, 125, 125, 0.35)\"\n color=\"#264251\"\n type=\"square-jelly-box\"\n >\n </valtimo-spinner>\n\n <div class=\"d-flex justify-content-end row mr-0 ml-0\" *ngIf=\"obs.pagination\">\n <ngb-pagination\n *ngIf=\"obs.pagination.collectionSize > obs.pagination.size\"\n [collectionSize]=\"obs.pagination.collectionSize\"\n [(page)]=\"obs.pagination.page\"\n [pageSize]=\"obs.pagination.size\"\n [maxSize]=\"obs.pagination.size\"\n [rotate]=\"true\"\n (pageChange)=\"paginationClicked($event)\"\n ></ngb-pagination>\n </div>\n\n</div>\n\n<valtimo-note-modal (createNoteEvent)=\"createNewNote($event)\"></valtimo-note-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 */.notes{position:relative}.add-note{position:absolute;right:0}\n"] }]
|
|
99
|
+
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.NotesService }, { type: i3.TranslateService }]; } });
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notes.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/notes/notes.component.ts","../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/notes/notes.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, OnInit} from '@angular/core';\nimport {NotesService} from '../../../services/notes.service';\nimport {BehaviorSubject, combineLatest, map, Observable} from 'rxjs';\nimport {Note} from '../../../models/notes.model';\nimport {switchMap, take, tap} from 'rxjs/operators';\nimport {ActivatedRoute} from '@angular/router';\nimport {Pagination, TimelineItem, TimelineItemImpl} from '@valtimo/components';\nimport {Page} from '@valtimo/config';\nimport moment from 'moment';\nimport {LangChangeEvent, TranslateService} from '@ngx-translate/core';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-notes',\n  templateUrl: './notes.component.html',\n  styleUrls: ['./notes.component.scss'],\n})\nexport class DossierDetailTabNotesComponent implements OnInit {\n  public timelineItems: TimelineItem[] = [];\n  readonly loading$ = new BehaviorSubject<boolean>(true);\n  readonly fields$ = new BehaviorSubject<Array<{key: string; label: string}>>([]);\n  private readonly documentId$ = this.route.params.pipe(map(params => params.documentId));\n\n  readonly currentPageAndSize$ = new BehaviorSubject<Partial<Pagination>>({\n    page: 0,\n    size: 10,\n  });\n\n  readonly pageSizes$ = new BehaviorSubject<Partial<Pagination>>({\n    collectionSize: 0,\n    maxPaginationItemSize: 5,\n  });\n\n  readonly pagination$: Observable<Pagination> = combineLatest([\n    this.currentPageAndSize$,\n    this.pageSizes$,\n  ]).pipe(\n    map(\n      ([currentPage, sizes]) =>\n        ({...currentPage, ...sizes, page: currentPage.page + 1} as Pagination)\n    )\n  );\n\n  readonly notes$: Observable<Array<Note>> = combineLatest([\n    this.documentId$,\n    this.currentPageAndSize$,\n    this.notesService.refresh$\n  ]).pipe(\n    tap(() => this.timelineItems = []),\n    switchMap(([documentId, currentPage]) =>\n      this.notesService.getDocumentNotes(documentId, {page: currentPage.page, size: currentPage.size})\n    ),\n    tap((res: Page<Note>) => {\n      this.timelineItems = [];\n      this.pageSizes$.pipe(take(1)).subscribe(sizes => {\n        this.pageSizes$.next({...sizes, collectionSize: res.totalElements});\n      });\n    }),\n    map((res) =>\n      res.content.map((note: Note) => {\n        const noteCreatedDate = moment(note.createdDate).locale(this.translateService.currentLang);\n        this.timelineItems.push(\n          new TimelineItemImpl(\n            noteCreatedDate.format('DD MMM YYYY'),\n            noteCreatedDate.format('HH:mm'),\n            note.createdByUserFullName,\n            noteCreatedDate.fromNow(),\n            note.content,\n            {}\n          )\n        )\n        return ({\n          ...note\n        })\n      })\n    ),\n    tap(() => this.loading$.next(false))\n  );\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private notesService: NotesService,\n    private translateService: TranslateService\n  ) {\n  }\n\n  ngOnInit() {\n    this.translateService.onLangChange.subscribe(() => {\n      this.notesService.refresh();\n    });\n  }\n\n  paginationClicked(newPageNumber): void {\n    this.currentPageAndSize$.pipe(take(1)).subscribe(currentPage => {\n      this.currentPageAndSize$.next({...currentPage, page: newPageNumber - 1});\n    });\n  }\n\n  showAddModal(): void {\n    this.notesService.setModalType('add');\n    this.notesService.showModal();\n  }\n\n  createNewNote(content) {\n    this.documentId$\n      .pipe(take(1))\n      .pipe(\n        tap(documentId => {\n          this.notesService.createDocumentNote(documentId, content)\n            .subscribe(() => {\n              this.notesService.refresh();\n              this.notesService.hideModal();\n            });\n        })\n      )\n      .subscribe();\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<div class=\"notes\" *ngIf=\"{\n    notes: notes$ | async,\n    pagination: pagination$ | async,\n    loading: loading$ | async\n  } as obs\">\n\n  <button\n          class=\"btn btn-space btn-primary mr-1 add-note\"\n          type=\"button\"\n          aria-haspopup=\"true\"\n          aria-expanded=\"false\"\n          (click)=\"showAddModal()\"\n          [disabled]=\"obs.loading\"\n  >\n    <span>{{ 'dossier.notes.addNote' | translate }}</span>\n    <i class=\"ml-1 icon mdi mdi-plus\"></i>\n  </button>\n\n  <div *ngIf=\"timelineItems\">\n    <valtimo-timeline [items]=\"timelineItems\"></valtimo-timeline>\n  </div>\n\n  <valtimo-spinner\n          [useBootstrapSpinner]=\"false\"\n          name=\"auditSpinner\"\n          bdColor=\"rgba(125, 125, 125, 0.35)\"\n          color=\"#264251\"\n          type=\"square-jelly-box\"\n  >\n  </valtimo-spinner>\n\n  <div class=\"d-flex justify-content-end row mr-0 ml-0\" *ngIf=\"obs.pagination\">\n      <ngb-pagination\n              *ngIf=\"obs.pagination.collectionSize > obs.pagination.size\"\n              [collectionSize]=\"obs.pagination.collectionSize\"\n              [(page)]=\"obs.pagination.page\"\n              [pageSize]=\"obs.pagination.size\"\n              [maxSize]=\"obs.pagination.size\"\n              [rotate]=\"true\"\n              (pageChange)=\"paginationClicked($event)\"\n      ></ngb-pagination>\n  </div>\n\n</div>\n\n<valtimo-note-modal (createNoteEvent)=\"createNewNote($event)\"></valtimo-note-modal>\n"]}
|
|
@@ -21,5 +21,6 @@ export var DefaultTabs;
|
|
|
21
21
|
DefaultTabs["documents"] = "documents";
|
|
22
22
|
DefaultTabs["contactMoments"] = "contact-moments";
|
|
23
23
|
DefaultTabs["zaakobjecten"] = "zaakobjecten";
|
|
24
|
+
DefaultTabs["notes"] = "notes";
|
|
24
25
|
})(DefaultTabs || (DefaultTabs = {}));
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9zc2llci1kZXRhaWwtdGFiLWVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0aW1vL2Rvc3NpZXIvc3JjL2xpYi9kb3NzaWVyLWRldGFpbC10YWItZW51bS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUVILE1BQU0sQ0FBTixJQUFZLFdBUVg7QUFSRCxXQUFZLFdBQVc7SUFDckIsa0NBQW1CLENBQUE7SUFDbkIsb0NBQXFCLENBQUE7SUFDckIsOEJBQWUsQ0FBQTtJQUNmLHNDQUF1QixDQUFBO0lBQ3ZCLGlEQUFrQyxDQUFBO0lBQ2xDLDRDQUE2QixDQUFBO0lBQzdCLDhCQUFlLENBQUE7QUFDakIsQ0FBQyxFQVJXLFdBQVcsS0FBWCxXQUFXLFFBUXRCIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjAgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuZXhwb3J0IGVudW0gRGVmYXVsdFRhYnMge1xuICBzdW1tYXJ5ID0gJ3N1bW1hcnknLFxuICBwcm9ncmVzcyA9ICdwcm9ncmVzcycsXG4gIGF1ZGl0ID0gJ2F1ZGl0JyxcbiAgZG9jdW1lbnRzID0gJ2RvY3VtZW50cycsXG4gIGNvbnRhY3RNb21lbnRzID0gJ2NvbnRhY3QtbW9tZW50cycsXG4gIHphYWtvYmplY3RlbiA9ICd6YWFrb2JqZWN0ZW4nLFxuICBub3RlcyA9ICdub3Rlcydcbn1cbiJdfQ==
|