@valtimo/dossier 12.0.0 → 12.1.1
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/esm2022/lib/components/dossier-detail/dossier-detail.component.mjs +11 -7
- package/esm2022/lib/components/dossier-detail/tab/not-found/not-found.component.mjs +1 -1
- package/esm2022/lib/components/dossier-detail/tab/notes/notes.component.mjs +1 -1
- package/esm2022/lib/components/dossier-detail/tab/progress/progress.component.mjs +1 -1
- package/esm2022/lib/components/dossier-detail/tab/summary/summary.component.mjs +13 -78
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.mjs +192 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.mjs +80 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.mjs +116 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.mjs +67 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.mjs +126 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.mjs +154 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/widgets-container/widgets-container.component.mjs +74 -0
- package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.component.mjs +74 -0
- package/esm2022/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.mjs +131 -0
- package/esm2022/lib/components/dossier-list/dossier-list.component.mjs +4 -4
- package/esm2022/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.mjs +47 -7
- package/esm2022/lib/constants/case-widget.constants.mjs +19 -0
- package/esm2022/lib/constants/custom-case-widget-token.mjs +19 -0
- package/esm2022/lib/constants/index.mjs +3 -1
- package/esm2022/lib/dossier.module.mjs +11 -3
- package/esm2022/lib/models/case-widget-content.model.mjs +17 -0
- package/esm2022/lib/models/case-widget-display.model.mjs +13 -0
- package/esm2022/lib/models/case-widget.model.mjs +25 -0
- package/esm2022/lib/models/index.mjs +6 -3
- package/esm2022/lib/models/tab-api.model.mjs +2 -1
- package/esm2022/lib/models/tabs.model.mjs +16 -7
- package/esm2022/lib/services/dossier-tab-api.service.mjs +17 -11
- package/esm2022/lib/services/dossier-tab.service.mjs +39 -11
- package/esm2022/lib/services/dossier-widgets-api.service.mjs +46 -0
- package/esm2022/lib/services/dossier-widgets-layout.service.mjs +97 -0
- package/esm2022/lib/services/index.mjs +3 -1
- package/fesm2022/valtimo-dossier.mjs +1383 -233
- package/fesm2022/valtimo-dossier.mjs.map +1 -1
- package/lib/components/dossier-detail/dossier-detail.component.d.ts +2 -0
- package/lib/components/dossier-detail/dossier-detail.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/summary/summary.component.d.ts +7 -26
- package/lib/components/dossier-detail/tab/summary/summary.component.d.ts.map +1 -1
- package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts +47 -0
- package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts +22 -0
- package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts +31 -0
- package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts +21 -0
- package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts +31 -0
- package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.d.ts +43 -0
- package/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/components/widgets-container/widgets-container.component.d.ts +20 -0
- package/lib/components/dossier-detail/tab/widgets/components/widgets-container/widgets-container.component.d.ts.map +1 -0
- package/lib/components/dossier-detail/tab/widgets/widgets.component.d.ts +25 -0
- package/lib/components/dossier-detail/tab/widgets/widgets.component.d.ts.map +1 -0
- package/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.d.ts +26 -0
- package/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.d.ts.map +1 -0
- package/lib/components/dossier-list/dossier-list.component.d.ts +1 -1
- package/lib/components/dossier-list/dossier-list.component.d.ts.map +1 -1
- package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +12 -4
- package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
- package/lib/constants/case-widget.constants.d.ts +4 -0
- package/lib/constants/case-widget.constants.d.ts.map +1 -0
- package/lib/constants/custom-case-widget-token.d.ts +5 -0
- package/lib/constants/custom-case-widget-token.d.ts.map +1 -0
- package/lib/constants/index.d.ts +2 -0
- package/lib/constants/index.d.ts.map +1 -1
- package/lib/dossier.module.d.ts +3 -1
- package/lib/dossier.module.d.ts.map +1 -1
- package/lib/models/case-widget-content.model.d.ts +51 -0
- package/lib/models/case-widget-content.model.d.ts.map +1 -0
- package/lib/models/case-widget-display.model.d.ts +44 -0
- package/lib/models/case-widget-display.model.d.ts.map +1 -0
- package/lib/models/case-widget.model.d.ts +105 -0
- package/lib/models/case-widget.model.d.ts.map +1 -0
- package/lib/models/index.d.ts +5 -2
- package/lib/models/index.d.ts.map +1 -1
- package/lib/models/tab-api.model.d.ts +13 -2
- package/lib/models/tab-api.model.d.ts.map +1 -1
- package/lib/models/tabs.model.d.ts +6 -1
- package/lib/models/tabs.model.d.ts.map +1 -1
- package/lib/services/dossier-tab-api.service.d.ts +6 -7
- package/lib/services/dossier-tab-api.service.d.ts.map +1 -1
- package/lib/services/dossier-tab.service.d.ts +12 -2
- package/lib/services/dossier-tab.service.d.ts.map +1 -1
- package/lib/services/dossier-widgets-api.service.d.ts +15 -0
- package/lib/services/dossier-widgets-api.service.d.ts.map +1 -0
- package/lib/services/dossier-widgets-layout.service.d.ts +35 -0
- package/lib/services/dossier-widgets-layout.service.d.ts.map +1 -0
- package/lib/services/index.d.ts +2 -0
- package/lib/services/index.d.ts.map +1 -1
- package/package.json +4 -2
|
@@ -13,43 +13,24 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import { Component,
|
|
17
|
-
import { CAN_VIEW_TASK_PERMISSION, TASK_DETAIL_PERMISSION_RESOURCE, } from '@valtimo/task';
|
|
16
|
+
import { Component, ViewEncapsulation } from '@angular/core';
|
|
18
17
|
import { FormioOptionsImpl } from '@valtimo/components';
|
|
19
18
|
import moment from 'moment';
|
|
20
|
-
import {
|
|
19
|
+
import { Subscription } from 'rxjs';
|
|
21
20
|
import * as i0 from "@angular/core";
|
|
22
|
-
import * as i1 from "@
|
|
23
|
-
import * as i2 from "@
|
|
24
|
-
import * as i3 from "@valtimo/
|
|
25
|
-
import * as i4 from "@
|
|
26
|
-
import * as i5 from "@valtimo/
|
|
27
|
-
import * as i6 from "@valtimo/security";
|
|
28
|
-
import * as i7 from "@valtimo/access-control";
|
|
29
|
-
import * as i8 from "@angular/common";
|
|
30
|
-
import * as i9 from "@valtimo/components";
|
|
31
|
-
import * as i10 from "@ng-bootstrap/ng-bootstrap";
|
|
32
|
-
import * as i11 from "carbon-components-angular";
|
|
33
|
-
import * as i12 from "@ngx-translate/core";
|
|
21
|
+
import * as i1 from "@valtimo/document";
|
|
22
|
+
import * as i2 from "@angular/router";
|
|
23
|
+
import * as i3 from "@valtimo/form";
|
|
24
|
+
import * as i4 from "@angular/common";
|
|
25
|
+
import * as i5 from "@valtimo/components";
|
|
34
26
|
moment.locale(localStorage.getItem('langKey') || '');
|
|
35
27
|
moment.defaultFormat = 'DD MMM YYYY HH:mm';
|
|
36
28
|
export class DossierDetailTabSummaryComponent {
|
|
37
|
-
constructor(
|
|
38
|
-
this.router = router;
|
|
29
|
+
constructor(documentService, route, formService) {
|
|
39
30
|
this.documentService = documentService;
|
|
40
|
-
this.taskService = taskService;
|
|
41
|
-
this.processService = processService;
|
|
42
|
-
this.el = el;
|
|
43
|
-
this.renderer = renderer;
|
|
44
31
|
this.route = route;
|
|
45
32
|
this.formService = formService;
|
|
46
|
-
this.userProviderService = userProviderService;
|
|
47
|
-
this.permissionService = permissionService;
|
|
48
|
-
this.processDocumentInstances = [];
|
|
49
|
-
this.tasks = [];
|
|
50
33
|
this.formDefinition = null;
|
|
51
|
-
this.roles = [];
|
|
52
|
-
this.loadingTasks$ = new BehaviorSubject(true);
|
|
53
34
|
this._subscriptions = new Subscription();
|
|
54
35
|
this.snapshot = this.route.snapshot.paramMap;
|
|
55
36
|
this.documentDefinitionName = this.snapshot.get('documentDefinitionName') || '';
|
|
@@ -73,58 +54,12 @@ export class DossierDetailTabSummaryComponent {
|
|
|
73
54
|
.subscribe(formDefinition => {
|
|
74
55
|
this.formDefinition = formDefinition;
|
|
75
56
|
}));
|
|
76
|
-
this._subscriptions.add(this.userProviderService.getUserSubject().subscribe(user => {
|
|
77
|
-
this.roles = user.roles;
|
|
78
|
-
this.tasks = [];
|
|
79
|
-
this.loadProcessDocumentInstances(this.documentId);
|
|
80
|
-
}));
|
|
81
|
-
}
|
|
82
|
-
loadProcessDocumentInstances(documentId) {
|
|
83
|
-
this._subscriptions.add(this.documentService
|
|
84
|
-
.findProcessDocumentInstances(documentId)
|
|
85
|
-
.subscribe(processDocumentInstances => {
|
|
86
|
-
this.processDocumentInstances = processDocumentInstances;
|
|
87
|
-
this.processDocumentInstances.forEach(instance => {
|
|
88
|
-
this.loadProcessInstanceTasks(instance.id.processInstanceId);
|
|
89
|
-
});
|
|
90
|
-
}));
|
|
91
|
-
}
|
|
92
|
-
rowTaskClick(task) {
|
|
93
|
-
this.taskDetail.openTaskDetails(task);
|
|
94
|
-
}
|
|
95
|
-
loadProcessInstanceTasks(processInstanceId) {
|
|
96
|
-
this._subscriptions.add(this.processService
|
|
97
|
-
.getProcessInstanceTasks(processInstanceId)
|
|
98
|
-
.pipe(switchMap(tasks => combineLatest([
|
|
99
|
-
of(tasks),
|
|
100
|
-
...(tasks || []).map(task => this.permissionService.requestPermission(CAN_VIEW_TASK_PERMISSION, {
|
|
101
|
-
resource: TASK_DETAIL_PERMISSION_RESOURCE.task,
|
|
102
|
-
identifier: task.id,
|
|
103
|
-
})),
|
|
104
|
-
])))
|
|
105
|
-
.subscribe(res => {
|
|
106
|
-
const tasks = res?.[0];
|
|
107
|
-
const permissions = res?.filter((_, index) => index !== 0);
|
|
108
|
-
if (!!tasks) {
|
|
109
|
-
tasks.forEach((task, taskIndex) => {
|
|
110
|
-
task.createdUnix = this.moment(task.created).unix();
|
|
111
|
-
task.created = this.moment(task.created).format('DD MMM YYYY HH:mm');
|
|
112
|
-
task.isLocked = !permissions[taskIndex];
|
|
113
|
-
});
|
|
114
|
-
this.tasks = this.tasks.concat(tasks);
|
|
115
|
-
this.tasks.sort((t1, t2) => t2.createdUnix - t1.createdUnix);
|
|
116
|
-
}
|
|
117
|
-
this.loadingTasks$.next(false);
|
|
118
|
-
}));
|
|
119
57
|
}
|
|
120
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DossierDetailTabSummaryComponent, deps: [{ token: i1.
|
|
121
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.3", type: DossierDetailTabSummaryComponent, selector: "valtimo-dossier-detail-tab-summary",
|
|
58
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DossierDetailTabSummaryComponent, deps: [{ token: i1.DocumentService }, { token: i2.ActivatedRoute }, { token: i3.FormService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
59
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.3", type: DossierDetailTabSummaryComponent, selector: "valtimo-dossier-detail-tab-summary", ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\">\n <div class=\"row py-4\">\n <div class=\"col-sm-12 col-md-8 col-xl-9\">\n <div *ngIf=\"document\">\n <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n <div class=\"mb-4\">\n <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".hoverable:hover{background-color:#eee}.summaryForm .formio-component{margin-bottom:0!important}.summaryForm .formio-component div[ref=element] .form-control{height:24px!important;background-color:#fff;border:0px;margin:0;padding:0!important;font-size:13px}.summaryForm .formio-field div[ref=element] .form-control{font-weight:400}.summaryForm .formio-value div[ref=element] .form-control{font-weight:700}\n/*!\n * Copyright 2015-2024 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"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
122
60
|
}
|
|
123
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DossierDetailTabSummaryComponent, decorators: [{
|
|
124
62
|
type: Component,
|
|
125
|
-
args: [{ selector: 'valtimo-dossier-detail-tab-summary', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\"
|
|
126
|
-
}], ctorParameters: () => [{ type: i1.
|
|
127
|
-
|
|
128
|
-
args: ['taskDetail']
|
|
129
|
-
}] } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/summary/summary.component.ts","../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/summary/summary.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  Component,\n  ElementRef,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {ProcessInstanceTask, ProcessService} from '@valtimo/process';\nimport {ActivatedRoute, ParamMap, Router} from '@angular/router';\nimport {Document, DocumentService, ProcessDocumentInstance} from '@valtimo/document';\nimport {\n  CAN_VIEW_TASK_PERMISSION,\n  TASK_DETAIL_PERMISSION_RESOURCE,\n  TaskDetailModalComponent,\n  TaskService,\n} from '@valtimo/task';\nimport {FormService} from '@valtimo/form';\nimport {FormioOptionsImpl, ValtimoFormioOptions} from '@valtimo/components';\nimport moment from 'moment';\nimport {FormioForm} from '@formio/angular';\nimport {UserProviderService} from '@valtimo/security';\nimport {BehaviorSubject, combineLatest, of, Subscription, switchMap} from 'rxjs';\nimport {PermissionService} from '@valtimo/access-control';\n\nmoment.locale(localStorage.getItem('langKey') || '');\nmoment.defaultFormat = 'DD MMM YYYY HH:mm';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-summary',\n  templateUrl: './summary.component.html',\n  styleUrls: ['./summary.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DossierDetailTabSummaryComponent implements OnInit, OnDestroy {\n  @ViewChild('taskDetail') taskDetail: TaskDetailModalComponent;\n  public readonly documentDefinitionName: string;\n  public document: Document;\n  public documentId: string;\n  public processDocumentInstances: ProcessDocumentInstance[] = [];\n  private snapshot: ParamMap;\n  public tasks: ProcessInstanceTask[] = [];\n  public moment;\n  public formDefinition: FormioForm = null;\n  public options: ValtimoFormioOptions;\n  public roles: string[] = [];\n  public readonly loadingTasks$ = new BehaviorSubject<boolean>(true);\n  private _subscriptions = new Subscription();\n\n  constructor(\n    private readonly router: Router,\n    private readonly documentService: DocumentService,\n    private readonly taskService: TaskService,\n    private readonly processService: ProcessService,\n    private readonly el: ElementRef,\n    private readonly renderer: Renderer2,\n    private readonly route: ActivatedRoute,\n    private readonly formService: FormService,\n    private readonly userProviderService: UserProviderService,\n    private readonly permissionService: PermissionService\n  ) {\n    this.snapshot = this.route.snapshot.paramMap;\n    this.documentDefinitionName = this.snapshot.get('documentDefinitionName') || '';\n    this.documentId = this.snapshot.get('documentId') || '';\n    this.options = new FormioOptionsImpl();\n    this.options.disableAlerts = true;\n  }\n\n  public ngOnInit(): void {\n    this.moment = moment;\n    this.init();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n  public init(): void {\n    this._subscriptions.add(\n      this.documentService.getDocument(this.documentId).subscribe(document => {\n        this.document = document;\n      })\n    );\n\n    this._subscriptions.add(\n      this.formService\n        .getFormDefinitionByNamePreFilled(`${this.documentDefinitionName}.summary`, this.documentId)\n        .subscribe(formDefinition => {\n          this.formDefinition = formDefinition;\n        })\n    );\n\n    this._subscriptions.add(\n      this.userProviderService.getUserSubject().subscribe(user => {\n        this.roles = user.roles;\n        this.tasks = [];\n        this.loadProcessDocumentInstances(this.documentId);\n      })\n    );\n  }\n\n  public loadProcessDocumentInstances(documentId: string): void {\n    this._subscriptions.add(\n      this.documentService\n        .findProcessDocumentInstances(documentId)\n        .subscribe(processDocumentInstances => {\n          this.processDocumentInstances = processDocumentInstances;\n          this.processDocumentInstances.forEach(instance => {\n            this.loadProcessInstanceTasks(instance.id.processInstanceId);\n          });\n        })\n    );\n  }\n\n  public rowTaskClick(task: any): void {\n    this.taskDetail.openTaskDetails(task);\n  }\n\n  private loadProcessInstanceTasks(processInstanceId: string): void {\n    this._subscriptions.add(\n      this.processService\n        .getProcessInstanceTasks(processInstanceId)\n        .pipe(\n          switchMap(tasks =>\n            combineLatest([\n              of(tasks),\n              ...(tasks || []).map(task =>\n                this.permissionService.requestPermission(CAN_VIEW_TASK_PERMISSION, {\n                  resource: TASK_DETAIL_PERMISSION_RESOURCE.task,\n                  identifier: task.id,\n                })\n              ),\n            ])\n          )\n        )\n        .subscribe(res => {\n          const tasks = res?.[0];\n          const permissions = res?.filter((_, index) => index !== 0);\n\n          if (!!tasks) {\n            tasks.forEach((task, taskIndex) => {\n              task.createdUnix = this.moment(task.created).unix();\n              task.created = this.moment(task.created).format('DD MMM YYYY HH:mm');\n              task.isLocked = !permissions[taskIndex];\n            });\n            this.tasks = this.tasks.concat(tasks);\n            this.tasks.sort((t1, t2) => t2.createdUnix - t1.createdUnix);\n          }\n\n          this.loadingTasks$.next(false);\n        })\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div class=\"container-fluid\" *ngIf=\"{loadingTasks: loadingTasks$ | async} as obs\">\n  <div class=\"row py-4\">\n    <div class=\"col-sm-12 col-md-8 col-xl-9\">\n      <div *ngIf=\"document\">\n        <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n          <div class=\"mb-4\">\n            <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!--Current user tasks right side-->\n    <div class=\"col-sm-12 col-md-4 col-xl-3\">\n      <h4 class=\"user-tasks-title\">{{ 'summary.userTasks' | translate }}</h4>\n      <ng-container *ngIf=\"!obs.loadingTasks; else loadingTasksTemplate\">\n        <ng-container *ngIf=\"!tasks.length\">\n          <valtimo-widget>\n            <div class=\"p-3\">\n              <img class=\"float-left\" src=\"assets/audit-2.png\" height=\"25\" />\n              <span class=\"float-right\">{{ 'summary.userTasksDoneState' | translate }}</span>\n              <div class=\"clearfix\"></div>\n            </div>\n          </valtimo-widget>\n        </ng-container>\n\n        <ng-container *ngFor=\"let task of tasks\">\n          <valtimo-widget>\n            <div\n              *ngIf=\"!task.isLocked\"\n              class=\"p-3 clickable hoverable\"\n              (click)=\"rowTaskClick(task)\"\n            >\n              <span class=\"float-right badge badge-pill badge-primary\">{{\n                'summary.taskOpen' | translate\n              }}</span>\n              <strong>{{ task.name }}</strong>\n              <div class=\"mt-1\">{{ 'summary.taskCreated' | translate }} {{ task.created }}</div>\n            </div>\n            <div class=\"p-3 hoverable\" *ngIf=\"task.isLocked\">\n              <span\n                class=\"float-right badge badge-pill badge-secondary bg-grey\"\n                ngbTooltip=\"{{ 'summary.taskLocked' | translate }}\"\n              >\n                <i class=\"icon mdi mdi-lock\"></i>\n              </span>\n              <strong>{{ task.name }}</strong>\n              <div>{{ 'summary.taskCreated' | translate }} {{ task.created }}</div>\n            </div>\n          </valtimo-widget>\n        </ng-container>\n      </ng-container>\n\n      <valtimo-task-detail-modal\n        #taskDetail\n        (formSubmit)=\"init()\"\n        (assignmentOfTaskChanged)=\"init()\"\n      ></valtimo-task-detail-modal>\n    </div>\n  </div>\n</div>\n\n<ng-template #loadingTasksTemplate>\n  <div class=\"loading-container\">\n    <cds-loading size=\"sm\"></cds-loading>\n  </div>\n</ng-template>\n"]}
|
|
63
|
+
args: [{ selector: 'valtimo-dossier-detail-tab-summary', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\">\n <div class=\"row py-4\">\n <div class=\"col-sm-12 col-md-8 col-xl-9\">\n <div *ngIf=\"document\">\n <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n <div class=\"mb-4\">\n <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".hoverable:hover{background-color:#eee}.summaryForm .formio-component{margin-bottom:0!important}.summaryForm .formio-component div[ref=element] .form-control{height:24px!important;background-color:#fff;border:0px;margin:0;padding:0!important;font-size:13px}.summaryForm .formio-field div[ref=element] .form-control{font-weight:400}.summaryForm .formio-value div[ref=element] .form-control{font-weight:700}\n/*!\n * Copyright 2015-2024 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"] }]
|
|
64
|
+
}], ctorParameters: () => [{ type: i1.DocumentService }, { type: i2.ActivatedRoute }, { type: i3.FormService }] });
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VtbWFyeS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0aW1vL2Rvc3NpZXIvc3JjL2xpYi9jb21wb25lbnRzL2Rvc3NpZXItZGV0YWlsL3RhYi9zdW1tYXJ5L3N1bW1hcnkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGltby9kb3NzaWVyL3NyYy9saWIvY29tcG9uZW50cy9kb3NzaWVyLWRldGFpbC90YWIvc3VtbWFyeS9zdW1tYXJ5LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBRUgsT0FBTyxFQUFDLFNBQVMsRUFBcUIsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFJOUUsT0FBTyxFQUFDLGlCQUFpQixFQUF1QixNQUFNLHFCQUFxQixDQUFDO0FBQzVFLE9BQU8sTUFBTSxNQUFNLFFBQVEsQ0FBQztBQUU1QixPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sTUFBTSxDQUFDOzs7Ozs7O0FBRWxDLE1BQU0sQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNyRCxNQUFNLENBQUMsYUFBYSxHQUFHLG1CQUFtQixDQUFDO0FBUTNDLE1BQU0sT0FBTyxnQ0FBZ0M7SUFXM0MsWUFDbUIsZUFBZ0MsRUFDaEMsS0FBcUIsRUFDckIsV0FBd0I7UUFGeEIsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBQ2hDLFVBQUssR0FBTCxLQUFLLENBQWdCO1FBQ3JCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBUHBDLG1CQUFjLEdBQWUsSUFBSSxDQUFDO1FBRWpDLG1CQUFjLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQU8xQyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztRQUM3QyxJQUFJLENBQUMsc0JBQXNCLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsd0JBQXdCLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDaEYsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDeEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLGlCQUFpQixFQUFFLENBQUM7UUFDdkMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO0lBQ3BDLENBQUM7SUFFTSxRQUFRO1FBQ2IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNwQyxDQUFDO0lBQ00sSUFBSTtRQUNULElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUNyQixJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxFQUFFO1lBQ3JFLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBQzNCLENBQUMsQ0FBQyxDQUNILENBQUM7UUFFRixJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FDckIsSUFBSSxDQUFDLFdBQVc7YUFDYixnQ0FBZ0MsQ0FBQyxHQUFHLElBQUksQ0FBQyxzQkFBc0IsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUM7YUFDM0YsU0FBUyxDQUFDLGNBQWMsQ0FBQyxFQUFFO1lBQzFCLElBQUksQ0FBQyxjQUFjLEdBQUcsY0FBYyxDQUFDO1FBQ3ZDLENBQUMsQ0FBQyxDQUNMLENBQUM7SUFDSixDQUFDOzhHQTdDVSxnQ0FBZ0M7a0dBQWhDLGdDQUFnQywwRUNsQzdDLDZpQ0E2QkE7OzJGREthLGdDQUFnQztrQkFONUMsU0FBUzsrQkFDRSxvQ0FBb0MsaUJBRy9CLGlCQUFpQixDQUFDLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gKlxuICogTGljZW5zZWQgdW5kZXIgRVVQTCwgVmVyc2lvbiAxLjIgKHRoZSBcIkxpY2Vuc2VcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuXG5pbXBvcnQge0NvbXBvbmVudCwgT25EZXN0cm95LCBPbkluaXQsIFZpZXdFbmNhcHN1bGF0aW9ufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGUsIFBhcmFtTWFwfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHtEb2N1bWVudCwgRG9jdW1lbnRTZXJ2aWNlfSBmcm9tICdAdmFsdGltby9kb2N1bWVudCc7XG5pbXBvcnQge0Zvcm1TZXJ2aWNlfSBmcm9tICdAdmFsdGltby9mb3JtJztcbmltcG9ydCB7Rm9ybWlvT3B0aW9uc0ltcGwsIFZhbHRpbW9Gb3JtaW9PcHRpb25zfSBmcm9tICdAdmFsdGltby9jb21wb25lbnRzJztcbmltcG9ydCBtb21lbnQgZnJvbSAnbW9tZW50JztcbmltcG9ydCB7Rm9ybWlvRm9ybX0gZnJvbSAnQGZvcm1pby9hbmd1bGFyJztcbmltcG9ydCB7U3Vic2NyaXB0aW9ufSBmcm9tICdyeGpzJztcblxubW9tZW50LmxvY2FsZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnbGFuZ0tleScpIHx8ICcnKTtcbm1vbWVudC5kZWZhdWx0Rm9ybWF0ID0gJ0REIE1NTSBZWVlZIEhIOm1tJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsdGltby1kb3NzaWVyLWRldGFpbC10YWItc3VtbWFyeScsXG4gIHRlbXBsYXRlVXJsOiAnLi9zdW1tYXJ5LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3VtbWFyeS5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxufSlcbmV4cG9ydCBjbGFzcyBEb3NzaWVyRGV0YWlsVGFiU3VtbWFyeUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgcHVibGljIHJlYWRvbmx5IGRvY3VtZW50RGVmaW5pdGlvbk5hbWU6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IGRvY3VtZW50SWQhOiBzdHJpbmc7XG5cbiAgcHVibGljIGRvY3VtZW50ITogRG9jdW1lbnQ7XG4gIHByaXZhdGUgc25hcHNob3Q6IFBhcmFtTWFwO1xuICBwdWJsaWMgbW9tZW50ITogdHlwZW9mIG1vbWVudDtcbiAgcHVibGljIGZvcm1EZWZpbml0aW9uOiBGb3JtaW9Gb3JtID0gbnVsbDtcbiAgcHVibGljIG9wdGlvbnM6IFZhbHRpbW9Gb3JtaW9PcHRpb25zO1xuICBwcml2YXRlIF9zdWJzY3JpcHRpb25zID0gbmV3IFN1YnNjcmlwdGlvbigpO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgcmVhZG9ubHkgZG9jdW1lbnRTZXJ2aWNlOiBEb2N1bWVudFNlcnZpY2UsXG4gICAgcHJpdmF0ZSByZWFkb25seSByb3V0ZTogQWN0aXZhdGVkUm91dGUsXG4gICAgcHJpdmF0ZSByZWFkb25seSBmb3JtU2VydmljZTogRm9ybVNlcnZpY2VcbiAgKSB7XG4gICAgdGhpcy5zbmFwc2hvdCA9IHRoaXMucm91dGUuc25hcHNob3QucGFyYW1NYXA7XG4gICAgdGhpcy5kb2N1bWVudERlZmluaXRpb25OYW1lID0gdGhpcy5zbmFwc2hvdC5nZXQoJ2RvY3VtZW50RGVmaW5pdGlvbk5hbWUnKSB8fCAnJztcbiAgICB0aGlzLmRvY3VtZW50SWQgPSB0aGlzLnNuYXBzaG90LmdldCgnZG9jdW1lbnRJZCcpIHx8ICcnO1xuICAgIHRoaXMub3B0aW9ucyA9IG5ldyBGb3JtaW9PcHRpb25zSW1wbCgpO1xuICAgIHRoaXMub3B0aW9ucy5kaXNhYmxlQWxlcnRzID0gdHJ1ZTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLm1vbWVudCA9IG1vbWVudDtcbiAgICB0aGlzLmluaXQoKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLl9zdWJzY3JpcHRpb25zLnVuc3Vic2NyaWJlKCk7XG4gIH1cbiAgcHVibGljIGluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fc3Vic2NyaXB0aW9ucy5hZGQoXG4gICAgICB0aGlzLmRvY3VtZW50U2VydmljZS5nZXREb2N1bWVudCh0aGlzLmRvY3VtZW50SWQpLnN1YnNjcmliZShkb2N1bWVudCA9PiB7XG4gICAgICAgIHRoaXMuZG9jdW1lbnQgPSBkb2N1bWVudDtcbiAgICAgIH0pXG4gICAgKTtcblxuICAgIHRoaXMuX3N1YnNjcmlwdGlvbnMuYWRkKFxuICAgICAgdGhpcy5mb3JtU2VydmljZVxuICAgICAgICAuZ2V0Rm9ybURlZmluaXRpb25CeU5hbWVQcmVGaWxsZWQoYCR7dGhpcy5kb2N1bWVudERlZmluaXRpb25OYW1lfS5zdW1tYXJ5YCwgdGhpcy5kb2N1bWVudElkKVxuICAgICAgICAuc3Vic2NyaWJlKGZvcm1EZWZpbml0aW9uID0+IHtcbiAgICAgICAgICB0aGlzLmZvcm1EZWZpbml0aW9uID0gZm9ybURlZmluaXRpb247XG4gICAgICAgIH0pXG4gICAgKTtcbiAgfVxufVxuIiwiPCEtLVxuICB+IENvcHlyaWdodCAyMDE1LTIwMjQgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICB+XG4gIH4gTGljZW5zZWQgdW5kZXIgRVVQTCwgVmVyc2lvbiAxLjIgKHRoZSBcIkxpY2Vuc2VcIik7XG4gIH4geW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICB+IFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICB+XG4gIH4gaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICB+XG4gIH4gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICB+IGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAgfiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAgfiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gIH4gbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gIC0tPlxuXG48ZGl2IGNsYXNzPVwiY29udGFpbmVyLWZsdWlkXCI+XG4gIDxkaXYgY2xhc3M9XCJyb3cgcHktNFwiPlxuICAgIDxkaXYgY2xhc3M9XCJjb2wtc20tMTIgY29sLW1kLTggY29sLXhsLTlcIj5cbiAgICAgIDxkaXYgKm5nSWY9XCJkb2N1bWVudFwiPlxuICAgICAgICA8ZGl2ICpuZ0lmPVwiZm9ybURlZmluaXRpb25cIiBjbGFzcz1cInN1bW1hcnlGb3JtXCI+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cIm1iLTRcIj5cbiAgICAgICAgICAgIDx2YWx0aW1vLWZvcm0taW8gW2Zvcm1dPVwiZm9ybURlZmluaXRpb25cIiBbb3B0aW9uc109XCJvcHRpb25zXCI+PC92YWx0aW1vLWZvcm0taW8+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2024 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 { ChangeDetectionStrategy, Component, HostBinding, Input, signal, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
17
|
+
import { CommonModule } from '@angular/common';
|
|
18
|
+
import { InputModule, PaginationModel, PaginationModule, TilesModule, } from 'carbon-components-angular';
|
|
19
|
+
import { CaseWidgetDisplayTypeKey, } from '../../../../../../models';
|
|
20
|
+
import { BehaviorSubject, combineLatest, filter, map, of, switchMap, tap } from 'rxjs';
|
|
21
|
+
import { CarbonListModule } from '@valtimo/components';
|
|
22
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
23
|
+
import * as i0 from "@angular/core";
|
|
24
|
+
import * as i1 from "@valtimo/components";
|
|
25
|
+
import * as i2 from "../../../../../../services";
|
|
26
|
+
import * as i3 from "@angular/common";
|
|
27
|
+
import * as i4 from "carbon-components-angular";
|
|
28
|
+
import * as i5 from "@ngx-translate/core";
|
|
29
|
+
export class WidgetCollectionComponent {
|
|
30
|
+
set widgetConfiguration(value) {
|
|
31
|
+
if (!value)
|
|
32
|
+
return;
|
|
33
|
+
this.widgetConfiguration$.next(value);
|
|
34
|
+
}
|
|
35
|
+
get _initialNumberOfElements$() {
|
|
36
|
+
return this._initialNumberOfElementsSubject$.pipe(filter(numberOfElements => numberOfElements !== null));
|
|
37
|
+
}
|
|
38
|
+
set widgetData(value) {
|
|
39
|
+
if (!value)
|
|
40
|
+
return;
|
|
41
|
+
this.showPagination$.next(value.totalElements > value.size);
|
|
42
|
+
this._initialNumberOfElementsSubject$.next(value.numberOfElements);
|
|
43
|
+
this._widgetDataSubject$.next(value.content);
|
|
44
|
+
this.paginationModel.set(value.totalPages < 0
|
|
45
|
+
? null
|
|
46
|
+
: {
|
|
47
|
+
currentPage: 1,
|
|
48
|
+
totalDataLength: Math.ceil(value.totalElements / value.size),
|
|
49
|
+
pageLength: value.size,
|
|
50
|
+
});
|
|
51
|
+
this.cdr.detectChanges();
|
|
52
|
+
}
|
|
53
|
+
constructor(viewContentService, cdr, widgetApiService) {
|
|
54
|
+
this.viewContentService = viewContentService;
|
|
55
|
+
this.cdr = cdr;
|
|
56
|
+
this.widgetApiService = widgetApiService;
|
|
57
|
+
this.class = 'valtimo-widget-collection';
|
|
58
|
+
this.showPagination$ = new BehaviorSubject(false);
|
|
59
|
+
this._initialNumberOfElementsSubject$ = new BehaviorSubject(null);
|
|
60
|
+
this.widgetTitle = signal('-');
|
|
61
|
+
this.widgetConfiguration$ = new BehaviorSubject(null);
|
|
62
|
+
this.paginationModel = signal(new PaginationModel());
|
|
63
|
+
this.amountOfColumns = signal(0);
|
|
64
|
+
this._widgetDataSubject$ = new BehaviorSubject(null);
|
|
65
|
+
this._queryParams$ = new BehaviorSubject(null);
|
|
66
|
+
this._widgetData$ = combineLatest([
|
|
67
|
+
this._widgetDataSubject$,
|
|
68
|
+
this._queryParams$,
|
|
69
|
+
this._initialNumberOfElements$,
|
|
70
|
+
this.widgetConfiguration$,
|
|
71
|
+
]).pipe(switchMap(([data, queryParams, initialNumberOfElements, widgetConfiguration]) => combineLatest([
|
|
72
|
+
!queryParams
|
|
73
|
+
? of(data)
|
|
74
|
+
: this.widgetApiService
|
|
75
|
+
.getWidgetData(this.documentId, this.tabKey, widgetConfiguration.key, queryParams)
|
|
76
|
+
.pipe(map((res) => res.content)),
|
|
77
|
+
of(initialNumberOfElements),
|
|
78
|
+
])), filter(([items]) => !!items), map(([items, initialNumberOfElements]) => {
|
|
79
|
+
if (items.length === initialNumberOfElements) {
|
|
80
|
+
return items;
|
|
81
|
+
}
|
|
82
|
+
const rows = new Array(initialNumberOfElements).fill(null);
|
|
83
|
+
return rows.map((_, index) => items[index] || { ...items[0], hidden: true });
|
|
84
|
+
}));
|
|
85
|
+
this.collectionWidgetCards$ = combineLatest([this.widgetConfiguration$, this._widgetData$]).pipe(filter(([widgetConfig, widgetData]) => !!widgetConfig && !!widgetData), tap(([widgetConfig]) => this.widgetTitle.set(widgetConfig.title)), map(([widgetConfig, widgetData]) => widgetData.map((cardData, index) => ({
|
|
86
|
+
hidden: cardData.hidden,
|
|
87
|
+
key: index,
|
|
88
|
+
title: this.getCardTitle({
|
|
89
|
+
value: cardData.title,
|
|
90
|
+
displayProperties: widgetConfig?.properties?.title?.displayProperties,
|
|
91
|
+
}),
|
|
92
|
+
fields: widgetConfig?.properties.fields.reduce((cardFieldsAccumulator, currentField) => [
|
|
93
|
+
...cardFieldsAccumulator,
|
|
94
|
+
this.getCardField(currentField, cardData),
|
|
95
|
+
], []),
|
|
96
|
+
}))));
|
|
97
|
+
}
|
|
98
|
+
ngAfterViewInit() {
|
|
99
|
+
this.openWidthObserver();
|
|
100
|
+
}
|
|
101
|
+
ngOnDestroy() {
|
|
102
|
+
this._observer?.disconnect();
|
|
103
|
+
}
|
|
104
|
+
onSelectPage(page) {
|
|
105
|
+
this._queryParams$.next(`page=${page - 1}&size=${this.paginationModel().pageLength}`);
|
|
106
|
+
this.paginationModel.update((model) => ({
|
|
107
|
+
...model,
|
|
108
|
+
currentPage: page,
|
|
109
|
+
}));
|
|
110
|
+
}
|
|
111
|
+
getCardField(field, data) {
|
|
112
|
+
const resolvedValue = this.viewContentService.get(data.fields[field.key], {
|
|
113
|
+
...field.displayProperties,
|
|
114
|
+
viewType: field.displayProperties?.type ?? CaseWidgetDisplayTypeKey.TEXT,
|
|
115
|
+
});
|
|
116
|
+
return {
|
|
117
|
+
key: field.key,
|
|
118
|
+
title: field.title,
|
|
119
|
+
width: field.width,
|
|
120
|
+
value: resolvedValue || data.fields[field.key],
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
openWidthObserver() {
|
|
124
|
+
this._observer = new ResizeObserver(event => {
|
|
125
|
+
this.observerMutation(event);
|
|
126
|
+
});
|
|
127
|
+
this._observer.observe(this._widgetCollectionRef.nativeElement);
|
|
128
|
+
}
|
|
129
|
+
observerMutation(event) {
|
|
130
|
+
const elementWidth = event[0]?.borderBoxSize[0]?.inlineSize;
|
|
131
|
+
if (typeof elementWidth === 'number' && elementWidth !== 0) {
|
|
132
|
+
if (elementWidth < 640) {
|
|
133
|
+
this.amountOfColumns.set(1);
|
|
134
|
+
}
|
|
135
|
+
else if (elementWidth > 640 && elementWidth <= 768) {
|
|
136
|
+
this.amountOfColumns.set(2);
|
|
137
|
+
}
|
|
138
|
+
else if (elementWidth > 768 && elementWidth <= 1080) {
|
|
139
|
+
this.amountOfColumns.set(3);
|
|
140
|
+
}
|
|
141
|
+
else if (elementWidth > 1080) {
|
|
142
|
+
this.amountOfColumns.set(4);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
getCardTitle(collectionCaseWidgetTitle) {
|
|
147
|
+
const widgetTitleValue = collectionCaseWidgetTitle.value;
|
|
148
|
+
const widgetTitleDisplayProperties = collectionCaseWidgetTitle.displayProperties;
|
|
149
|
+
if (!widgetTitleDisplayProperties && widgetTitleValue) {
|
|
150
|
+
return widgetTitleValue;
|
|
151
|
+
}
|
|
152
|
+
else if (widgetTitleDisplayProperties && widgetTitleValue) {
|
|
153
|
+
const convertedTitle = this.viewContentService.get(widgetTitleValue, {
|
|
154
|
+
...widgetTitleDisplayProperties,
|
|
155
|
+
viewType: widgetTitleDisplayProperties.type,
|
|
156
|
+
});
|
|
157
|
+
if (convertedTitle)
|
|
158
|
+
return convertedTitle;
|
|
159
|
+
}
|
|
160
|
+
return '-';
|
|
161
|
+
}
|
|
162
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: WidgetCollectionComponent, deps: [{ token: i1.ViewContentService }, { token: i0.ChangeDetectorRef }, { token: i2.DossierWidgetsApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
163
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: WidgetCollectionComponent, isStandalone: true, selector: "valtimo-widget-collection", inputs: { documentId: "documentId", tabKey: "tabKey", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_widgetCollectionRef", first: true, predicate: ["widgetCollection"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 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 widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async\n } as obs\"\n>\n <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n <div\n #widgetCollection\n [ngClass]=\"{\n 'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n 'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n 'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n 'valtimo-widget-collection__container': amountOfColumns() === 4\n }\"\n >\n @for (card of obs?.collectionWidgetCards; track card.key) {\n <div\n class=\"valtimo-widget-collection__card\"\n [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n >\n <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n @for (field of card.fields; track field.key) {\n <div\n [ngClass]=\"{\n 'valtimo-widget-collection__full-width-input': field?.width === 'full',\n 'valtimo-widget-collection__half-width-input': field?.width === 'half'\n }\"\n >\n <cds-label>\n {{ field?.title }}\n\n <input\n [value]=\"field?.value\"\n [readonly]=\"true\"\n class=\"valtimo-widget-collection__card-input\"\n cdsText\n />\n </cds-label>\n </div>\n }\n </div>\n }\n </div>\n\n @if (!obs?.collectionWidgetCards?.length) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n\n <cds-pagination-nav\n *ngIf=\"paginationModel() && (showPagination$ | async)\"\n class=\"valtimo-widget-collection__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n</ng-container>\n", styles: [".valtimo-widget-collection{padding:24px}.valtimo-widget-collection__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-widget-collection__container{display:flex;column-gap:16px}.valtimo-widget-collection,.valtimo-widget-collection__column{display:flex;flex-direction:column}.valtimo-widget-collection__card{margin-top:16px;display:flex;flex-flow:row wrap;background-color:var(--cds-background);padding:16px;width:100%;gap:16px}.valtimo-widget-collection__card--hidden{visibility:hidden}.valtimo-widget-collection__card-title{color:var(--cds-text-primary);font-weight:500;font-size:14px;line-height:22px;font-style:italic;width:100%}.valtimo-widget-collection__card-input{background:transparent}.valtimo-widget-collection__full-width-input{width:100%}.valtimo-widget-collection__half-width-input{width:calc(50% - 16px);box-sizing:border-box}.valtimo-widget-collection__pagination{padding:8px 0;display:flex;justify-content:center}.valtimo-widget-collection__render-vertically,.valtimo-widget-collection__render-two-columns,.valtimo-widget-collection__render-three-columns{display:grid;grid-gap:16px}.valtimo-widget-collection__render-two-columns{grid-template-columns:repeat(2,1fr)}.valtimo-widget-collection__render-three-columns{grid-template-columns:repeat(3,1fr)}\n/*!\n * Copyright 2015-2024 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"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i4.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i4.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "ngmodule", type: PaginationModule }, { kind: "component", type: i4.PaginationNav, selector: "cds-pagination-nav, ibm-pagination-navm", inputs: ["model", "disabled", "numOfItemsToShow", "translations"], outputs: ["selectPage"] }, { kind: "ngmodule", type: TilesModule }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i1.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
164
|
+
}
|
|
165
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: WidgetCollectionComponent, decorators: [{
|
|
166
|
+
type: Component,
|
|
167
|
+
args: [{ selector: 'valtimo-widget-collection', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [
|
|
168
|
+
CommonModule,
|
|
169
|
+
InputModule,
|
|
170
|
+
PaginationModule,
|
|
171
|
+
TilesModule,
|
|
172
|
+
CarbonListModule,
|
|
173
|
+
TranslateModule,
|
|
174
|
+
], template: "<!--\n ~ Copyright 2015-2024 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 widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async\n } as obs\"\n>\n <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n <div\n #widgetCollection\n [ngClass]=\"{\n 'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n 'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n 'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n 'valtimo-widget-collection__container': amountOfColumns() === 4\n }\"\n >\n @for (card of obs?.collectionWidgetCards; track card.key) {\n <div\n class=\"valtimo-widget-collection__card\"\n [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n >\n <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n @for (field of card.fields; track field.key) {\n <div\n [ngClass]=\"{\n 'valtimo-widget-collection__full-width-input': field?.width === 'full',\n 'valtimo-widget-collection__half-width-input': field?.width === 'half'\n }\"\n >\n <cds-label>\n {{ field?.title }}\n\n <input\n [value]=\"field?.value\"\n [readonly]=\"true\"\n class=\"valtimo-widget-collection__card-input\"\n cdsText\n />\n </cds-label>\n </div>\n }\n </div>\n }\n </div>\n\n @if (!obs?.collectionWidgetCards?.length) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n\n <cds-pagination-nav\n *ngIf=\"paginationModel() && (showPagination$ | async)\"\n class=\"valtimo-widget-collection__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n</ng-container>\n", styles: [".valtimo-widget-collection{padding:24px}.valtimo-widget-collection__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-widget-collection__container{display:flex;column-gap:16px}.valtimo-widget-collection,.valtimo-widget-collection__column{display:flex;flex-direction:column}.valtimo-widget-collection__card{margin-top:16px;display:flex;flex-flow:row wrap;background-color:var(--cds-background);padding:16px;width:100%;gap:16px}.valtimo-widget-collection__card--hidden{visibility:hidden}.valtimo-widget-collection__card-title{color:var(--cds-text-primary);font-weight:500;font-size:14px;line-height:22px;font-style:italic;width:100%}.valtimo-widget-collection__card-input{background:transparent}.valtimo-widget-collection__full-width-input{width:100%}.valtimo-widget-collection__half-width-input{width:calc(50% - 16px);box-sizing:border-box}.valtimo-widget-collection__pagination{padding:8px 0;display:flex;justify-content:center}.valtimo-widget-collection__render-vertically,.valtimo-widget-collection__render-two-columns,.valtimo-widget-collection__render-three-columns{display:grid;grid-gap:16px}.valtimo-widget-collection__render-two-columns{grid-template-columns:repeat(2,1fr)}.valtimo-widget-collection__render-three-columns{grid-template-columns:repeat(3,1fr)}\n/*!\n * Copyright 2015-2024 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"] }]
|
|
175
|
+
}], ctorParameters: () => [{ type: i1.ViewContentService }, { type: i0.ChangeDetectorRef }, { type: i2.DossierWidgetsApiService }], propDecorators: { class: [{
|
|
176
|
+
type: HostBinding,
|
|
177
|
+
args: ['class']
|
|
178
|
+
}], _widgetCollectionRef: [{
|
|
179
|
+
type: ViewChild,
|
|
180
|
+
args: ['widgetCollection']
|
|
181
|
+
}], documentId: [{
|
|
182
|
+
type: Input,
|
|
183
|
+
args: [{ required: true }]
|
|
184
|
+
}], tabKey: [{
|
|
185
|
+
type: Input,
|
|
186
|
+
args: [{ required: true }]
|
|
187
|
+
}], widgetConfiguration: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}], widgetData: [{
|
|
190
|
+
type: Input
|
|
191
|
+
}] } });
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-collection.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 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  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {\n  InputModule,\n  PaginationModel,\n  PaginationModule,\n  TilesModule,\n} from 'carbon-components-angular';\nimport {\n  CaseWidgetDisplayTypeKey,\n  CollectionCaseWidget,\n  CollectionCaseWidgetCardData,\n  CollectionCaseWidgetField,\n  CollectionCaseWidgetTitle,\n  CollectionWidgetResolvedField,\n} from '../../../../../../models';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap, tap} from 'rxjs';\nimport {CarbonListModule, ViewContentService} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Page} from '@valtimo/config';\nimport {DossierWidgetsApiService} from '../../../../../../services';\n\n@Component({\n  selector: 'valtimo-widget-collection',\n  templateUrl: './widget-collection.component.html',\n  styleUrls: ['./widget-collection.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    InputModule,\n    PaginationModule,\n    TilesModule,\n    CarbonListModule,\n    TranslateModule,\n  ],\n})\nexport class WidgetCollectionComponent implements AfterViewInit, OnDestroy {\n  @HostBinding('class') public readonly class = 'valtimo-widget-collection';\n  @ViewChild('widgetCollection') private _widgetCollectionRef: ElementRef<HTMLDivElement>;\n\n  @Input({required: true}) public documentId: string;\n  @Input({required: true}) public tabKey: string;\n  @Input() public set widgetConfiguration(value: CollectionCaseWidget) {\n    if (!value) return;\n    this.widgetConfiguration$.next(value);\n  }\n  public readonly showPagination$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _initialNumberOfElementsSubject$ = new BehaviorSubject<number>(null);\n\n  private get _initialNumberOfElements$(): Observable<number> {\n    return this._initialNumberOfElementsSubject$.pipe(\n      filter(numberOfElements => numberOfElements !== null)\n    );\n  }\n\n  @Input() public set widgetData(value: Page<CollectionCaseWidgetCardData> | null) {\n    if (!value) return;\n\n    this.showPagination$.next(value.totalElements > value.size);\n    this._initialNumberOfElementsSubject$.next(value.numberOfElements);\n    this._widgetDataSubject$.next(value.content);\n\n    this.paginationModel.set(\n      value.totalPages < 0\n        ? null\n        : {\n            currentPage: 1,\n            totalDataLength: Math.ceil(value.totalElements / value.size),\n            pageLength: value.size,\n          }\n    );\n    this.cdr.detectChanges();\n  }\n\n  public readonly widgetTitle = signal('-');\n\n  public readonly widgetConfiguration$ = new BehaviorSubject<CollectionCaseWidget | null>(null);\n  public readonly paginationModel = signal<PaginationModel>(new PaginationModel());\n  public readonly amountOfColumns = signal(0);\n\n  private readonly _widgetDataSubject$ = new BehaviorSubject<CollectionCaseWidgetCardData[]>(null);\n\n  private readonly _queryParams$ = new BehaviorSubject<string | null>(null);\n\n  private readonly _widgetData$: Observable<CollectionCaseWidgetCardData[]> = combineLatest([\n    this._widgetDataSubject$,\n    this._queryParams$,\n    this._initialNumberOfElements$,\n    this.widgetConfiguration$,\n  ]).pipe(\n    switchMap(([data, queryParams, initialNumberOfElements, widgetConfiguration]) =>\n      combineLatest([\n        !queryParams\n          ? of(data)\n          : this.widgetApiService\n              .getWidgetData(this.documentId, this.tabKey, widgetConfiguration.key, queryParams)\n              .pipe(map((res: Page<CollectionCaseWidgetCardData>) => res.content)),\n        of(initialNumberOfElements),\n      ])\n    ),\n    filter(([items]) => !!items),\n    map(([items, initialNumberOfElements]) => {\n      if (items.length === initialNumberOfElements) {\n        return items;\n      }\n\n      const rows = new Array<number>(initialNumberOfElements).fill(null);\n\n      return rows.map((_, index) => items[index] || {...items[0], hidden: true});\n    })\n  );\n\n  public readonly collectionWidgetCards$: Observable<\n    {title: string; fields: CollectionWidgetResolvedField[]; key: number; hidden: boolean}[]\n  > = combineLatest([this.widgetConfiguration$, this._widgetData$]).pipe(\n    filter(([widgetConfig, widgetData]) => !!widgetConfig && !!widgetData),\n    tap(([widgetConfig]) => this.widgetTitle.set(widgetConfig.title)),\n    map(([widgetConfig, widgetData]) =>\n      widgetData.map((cardData, index) => ({\n        hidden: cardData.hidden,\n        key: index,\n        title: this.getCardTitle({\n          value: cardData.title,\n          displayProperties: widgetConfig?.properties?.title?.displayProperties,\n        }),\n        fields: widgetConfig?.properties.fields.reduce(\n          (cardFieldsAccumulator, currentField) => [\n            ...cardFieldsAccumulator,\n            this.getCardField(currentField, cardData),\n          ],\n          []\n        ),\n      }))\n    )\n  );\n\n  private _observer!: ResizeObserver;\n\n  constructor(\n    private readonly viewContentService: ViewContentService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly widgetApiService: DossierWidgetsApiService\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this.openWidthObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._observer?.disconnect();\n  }\n\n  public onSelectPage(page: number): void {\n    this._queryParams$.next(`page=${page - 1}&size=${this.paginationModel().pageLength}`);\n    this.paginationModel.update((model: PaginationModel) => ({\n      ...model,\n      currentPage: page,\n    }));\n  }\n\n  private getCardField(\n    field: CollectionCaseWidgetField,\n    data: CollectionCaseWidgetCardData\n  ): CollectionWidgetResolvedField {\n    const resolvedValue = this.viewContentService.get(data.fields[field.key], {\n      ...field.displayProperties,\n      viewType: field.displayProperties?.type ?? CaseWidgetDisplayTypeKey.TEXT,\n    });\n\n    return {\n      key: field.key,\n      title: field.title,\n      width: field.width,\n      value: resolvedValue || data.fields[field.key],\n    };\n  }\n\n  private openWidthObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetCollectionRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const elementWidth = event[0]?.borderBoxSize[0]?.inlineSize;\n\n    if (typeof elementWidth === 'number' && elementWidth !== 0) {\n      if (elementWidth < 640) {\n        this.amountOfColumns.set(1);\n      } else if (elementWidth > 640 && elementWidth <= 768) {\n        this.amountOfColumns.set(2);\n      } else if (elementWidth > 768 && elementWidth <= 1080) {\n        this.amountOfColumns.set(3);\n      } else if (elementWidth > 1080) {\n        this.amountOfColumns.set(4);\n      }\n    }\n  }\n\n  private getCardTitle(collectionCaseWidgetTitle: CollectionCaseWidgetTitle): string {\n    const widgetTitleValue = collectionCaseWidgetTitle.value;\n    const widgetTitleDisplayProperties = collectionCaseWidgetTitle.displayProperties;\n\n    if (!widgetTitleDisplayProperties && widgetTitleValue) {\n      return widgetTitleValue;\n    } else if (widgetTitleDisplayProperties && widgetTitleValue) {\n      const convertedTitle = this.viewContentService.get(widgetTitleValue, {\n        ...widgetTitleDisplayProperties,\n        viewType: widgetTitleDisplayProperties.type,\n      });\n\n      if (convertedTitle) return convertedTitle;\n    }\n\n    return '-';\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 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    widgetConfiguration: widgetConfiguration$ | async,\n    collectionWidgetCards: collectionWidgetCards$ | async\n  } as obs\"\n>\n  <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n  <div\n    #widgetCollection\n    [ngClass]=\"{\n      'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n      'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n      'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n      'valtimo-widget-collection__container': amountOfColumns() === 4\n    }\"\n  >\n    @for (card of obs?.collectionWidgetCards; track card.key) {\n      <div\n        class=\"valtimo-widget-collection__card\"\n        [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n      >\n        <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n        @for (field of card.fields; track field.key) {\n          <div\n            [ngClass]=\"{\n              'valtimo-widget-collection__full-width-input': field?.width === 'full',\n              'valtimo-widget-collection__half-width-input': field?.width === 'half'\n            }\"\n          >\n            <cds-label>\n              {{ field?.title }}\n\n              <input\n                [value]=\"field?.value\"\n                [readonly]=\"true\"\n                class=\"valtimo-widget-collection__card-input\"\n                cdsText\n              />\n            </cds-label>\n          </div>\n        }\n      </div>\n    }\n  </div>\n\n  @if (!obs?.collectionWidgetCards?.length) {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  }\n\n  <cds-pagination-nav\n    *ngIf=\"paginationModel() && (showPagination$ | async)\"\n    class=\"valtimo-widget-collection__pagination\"\n    [model]=\"paginationModel()\"\n    (selectPage)=\"onSelectPage($event)\"\n  >\n  </cds-pagination-nav>\n</ng-container>\n"]}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2024 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 { ChangeDetectionStrategy, Component, Inject, Input, Optional, signal, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
17
|
+
import { CommonModule } from '@angular/common';
|
|
18
|
+
import { CUSTOM_CASE_WIDGET_TOKEN } from '../../../../../../constants';
|
|
19
|
+
import { BehaviorSubject, combineLatest, filter, Subscription } from 'rxjs';
|
|
20
|
+
import { CarbonListModule } from '@valtimo/components';
|
|
21
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
22
|
+
import * as i0 from "@angular/core";
|
|
23
|
+
import * as i1 from "@angular/common";
|
|
24
|
+
import * as i2 from "@valtimo/components";
|
|
25
|
+
import * as i3 from "@ngx-translate/core";
|
|
26
|
+
export class WidgetCustomComponent {
|
|
27
|
+
set widgetConfig(value) {
|
|
28
|
+
if (value)
|
|
29
|
+
this._widgetConfigSubject$.next(value);
|
|
30
|
+
}
|
|
31
|
+
get widgetConfig$() {
|
|
32
|
+
return this._widgetConfigSubject$.pipe(filter(config => config !== null));
|
|
33
|
+
}
|
|
34
|
+
constructor(customCaseWidgetConfig, cdr) {
|
|
35
|
+
this.customCaseWidgetConfig = customCaseWidgetConfig;
|
|
36
|
+
this.cdr = cdr;
|
|
37
|
+
this._customCaseWidgetConfig$ = new BehaviorSubject({});
|
|
38
|
+
this._widgetConfigSubject$ = new BehaviorSubject(null);
|
|
39
|
+
this.noCustomComponentAvailable = signal(false);
|
|
40
|
+
this._subscriptions = new Subscription();
|
|
41
|
+
if (customCaseWidgetConfig)
|
|
42
|
+
this._customCaseWidgetConfig$.next(customCaseWidgetConfig);
|
|
43
|
+
}
|
|
44
|
+
ngAfterViewInit() {
|
|
45
|
+
this.openCustomWidgetSubscription();
|
|
46
|
+
}
|
|
47
|
+
ngOnDestroy() {
|
|
48
|
+
this._subscriptions.unsubscribe();
|
|
49
|
+
}
|
|
50
|
+
openCustomWidgetSubscription() {
|
|
51
|
+
this._subscriptions.add(combineLatest([this.widgetConfig$, this._customCaseWidgetConfig$]).subscribe(([widgetConfig, customCaseWidgetConfig]) => {
|
|
52
|
+
const customWidgetComponentKey = widgetConfig?.properties?.componentKey;
|
|
53
|
+
const customComponent = customCaseWidgetConfig[customWidgetComponentKey];
|
|
54
|
+
if (!customComponent) {
|
|
55
|
+
this.noCustomComponentAvailable.set(true);
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
const componentRef = this._customWidgetContainerRef.createComponent(customComponent);
|
|
59
|
+
componentRef.changeDetectorRef.detectChanges();
|
|
60
|
+
this.cdr.detectChanges();
|
|
61
|
+
}));
|
|
62
|
+
}
|
|
63
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: WidgetCustomComponent, deps: [{ token: CUSTOM_CASE_WIDGET_TOKEN, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
64
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: WidgetCustomComponent, isStandalone: true, selector: "valtimo-widget-custom", inputs: { widgetConfig: "widgetConfig" }, viewQueries: [{ propertyName: "_customWidgetContainerRef", first: true, predicate: ["customWidgetContainer"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 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=\"custom-widget\">\n <h4 class=\"custom-widget__title\">{{ (widgetConfig$ | async)?.title || '-' }}</h4>\n\n <div class=\"custom-widget__content\">\n <ng-template #customWidgetContainer></ng-template>\n\n @if (noCustomComponentAvailable()) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n </div>\n</div>\n", styles: [".custom-widget{padding:24px}.custom-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n/*!\n * Copyright 2015-2024 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"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i2.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
65
|
+
}
|
|
66
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: WidgetCustomComponent, decorators: [{
|
|
67
|
+
type: Component,
|
|
68
|
+
args: [{ selector: 'valtimo-widget-custom', standalone: true, imports: [CommonModule, CarbonListModule, TranslateModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--\n ~ Copyright 2015-2024 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=\"custom-widget\">\n <h4 class=\"custom-widget__title\">{{ (widgetConfig$ | async)?.title || '-' }}</h4>\n\n <div class=\"custom-widget__content\">\n <ng-template #customWidgetContainer></ng-template>\n\n @if (noCustomComponentAvailable()) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n </div>\n</div>\n", styles: [".custom-widget{padding:24px}.custom-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n/*!\n * Copyright 2015-2024 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"] }]
|
|
69
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
70
|
+
type: Optional
|
|
71
|
+
}, {
|
|
72
|
+
type: Inject,
|
|
73
|
+
args: [CUSTOM_CASE_WIDGET_TOKEN]
|
|
74
|
+
}] }, { type: i0.ChangeDetectorRef }], propDecorators: { _customWidgetContainerRef: [{
|
|
75
|
+
type: ViewChild,
|
|
76
|
+
args: ['customWidgetContainer', { read: ViewContainerRef }]
|
|
77
|
+
}], widgetConfig: [{
|
|
78
|
+
type: Input
|
|
79
|
+
}] } });
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-custom.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 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  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  signal,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {CustomCaseWidget, CustomCaseWidgetConfig} from '../../../../../../models';\nimport {CUSTOM_CASE_WIDGET_TOKEN} from '../../../../../../constants';\nimport {BehaviorSubject, combineLatest, filter, Observable, Subscription} from 'rxjs';\nimport {CarbonListModule} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\n\n@Component({\n  selector: 'valtimo-widget-custom',\n  templateUrl: './widget-custom.component.html',\n  styleUrls: ['./widget-custom.component.scss'],\n  standalone: true,\n  imports: [CommonModule, CarbonListModule, TranslateModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetCustomComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('customWidgetContainer', {read: ViewContainerRef})\n  private readonly _customWidgetContainerRef: ViewContainerRef;\n\n  @Input() public set widgetConfig(value: CustomCaseWidget) {\n    if (value) this._widgetConfigSubject$.next(value);\n  }\n\n  private readonly _customCaseWidgetConfig$ = new BehaviorSubject<CustomCaseWidgetConfig | {}>({});\n\n  private readonly _widgetConfigSubject$ = new BehaviorSubject<CustomCaseWidget | null>(null);\n\n  public get widgetConfig$(): Observable<CustomCaseWidget> {\n    return this._widgetConfigSubject$.pipe(filter(config => config !== null));\n  }\n\n  public readonly noCustomComponentAvailable = signal(false);\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    @Optional()\n    @Inject(CUSTOM_CASE_WIDGET_TOKEN)\n    private readonly customCaseWidgetConfig: CustomCaseWidgetConfig,\n    private readonly cdr: ChangeDetectorRef\n  ) {\n    if (customCaseWidgetConfig) this._customCaseWidgetConfig$.next(customCaseWidgetConfig);\n  }\n\n  public ngAfterViewInit(): void {\n    this.openCustomWidgetSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  private openCustomWidgetSubscription(): void {\n    this._subscriptions.add(\n      combineLatest([this.widgetConfig$, this._customCaseWidgetConfig$]).subscribe(\n        ([widgetConfig, customCaseWidgetConfig]) => {\n          const customWidgetComponentKey = widgetConfig?.properties?.componentKey;\n          const customComponent = customCaseWidgetConfig[customWidgetComponentKey];\n\n          if (!customComponent) {\n            this.noCustomComponentAvailable.set(true);\n            return;\n          }\n\n          const componentRef = this._customWidgetContainerRef.createComponent(customComponent);\n\n          componentRef.changeDetectorRef.detectChanges();\n          this.cdr.detectChanges();\n        }\n      )\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 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=\"custom-widget\">\n  <h4 class=\"custom-widget__title\">{{ (widgetConfig$ | async)?.title || '-' }}</h4>\n\n  <div class=\"custom-widget__content\">\n    <ng-template #customWidgetContainer></ng-template>\n\n    @if (noCustomComponentAvailable()) {\n      <valtimo-no-results\n        [collapseVertically]=\"true\"\n        [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n        [smallPadding]=\"true\"\n      ></valtimo-no-results>\n    }\n  </div>\n</div>\n"]}
|