@valtimo/dossier 12.6.1 → 12.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/esm2022/lib/components/dossier-detail/dossier-detail.component.mjs +55 -23
  2. package/esm2022/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.mjs +41 -15
  3. package/esm2022/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.mjs +27 -12
  4. package/esm2022/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.mjs +46 -13
  5. package/esm2022/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.mjs +25 -11
  6. package/esm2022/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.mjs +32 -13
  7. package/esm2022/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.mjs +17 -0
  8. package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.component.mjs +4 -4
  9. package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.permissions.mjs +30 -0
  10. package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.service.mjs +45 -0
  11. package/esm2022/lib/components/dossier-list/dossier-list.component.mjs +27 -12
  12. package/esm2022/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.mjs +38 -6
  13. package/esm2022/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +44 -6
  14. package/esm2022/lib/constants/dossier-detail-layout.constants.mjs +7 -2
  15. package/esm2022/lib/models/case-widget-content.model.mjs +1 -1
  16. package/esm2022/lib/models/case-widget-display.model.mjs +1 -1
  17. package/esm2022/lib/models/case-widget.model.mjs +1 -1
  18. package/fesm2022/valtimo-dossier.mjs +424 -139
  19. package/fesm2022/valtimo-dossier.mjs.map +1 -1
  20. package/lib/components/dossier-detail/dossier-detail.component.d.ts +10 -2
  21. package/lib/components/dossier-detail/dossier-detail.component.d.ts.map +1 -1
  22. package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts +13 -3
  23. package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts.map +1 -1
  24. package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts +12 -4
  25. package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts.map +1 -1
  26. package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts +17 -4
  27. package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts.map +1 -1
  28. package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts +11 -3
  29. package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts.map +1 -1
  30. package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts +11 -3
  31. package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts.map +1 -1
  32. package/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.d.ts +13 -0
  33. package/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.d.ts.map +1 -0
  34. package/lib/components/dossier-detail/tab/widgets/widgets.component.d.ts.map +1 -1
  35. package/lib/components/dossier-detail/tab/widgets/widgets.permissions.d.ts +8 -0
  36. package/lib/components/dossier-detail/tab/widgets/widgets.permissions.d.ts.map +1 -0
  37. package/lib/components/dossier-detail/tab/widgets/widgets.service.d.ts +16 -0
  38. package/lib/components/dossier-detail/tab/widgets/widgets.service.d.ts.map +1 -0
  39. package/lib/components/dossier-list/dossier-list.component.d.ts +2 -0
  40. package/lib/components/dossier-list/dossier-list.component.d.ts.map +1 -1
  41. package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +8 -3
  42. package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
  43. package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts +8 -3
  44. package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -1
  45. package/lib/constants/dossier-detail-layout.constants.d.ts +6 -1
  46. package/lib/constants/dossier-detail-layout.constants.d.ts.map +1 -1
  47. package/lib/models/case-widget-content.model.d.ts +1 -0
  48. package/lib/models/case-widget-content.model.d.ts.map +1 -1
  49. package/lib/models/case-widget-display.model.d.ts +8 -0
  50. package/lib/models/case-widget-display.model.d.ts.map +1 -1
  51. package/lib/models/case-widget.model.d.ts +6 -1
  52. package/lib/models/case-widget.model.d.ts.map +1 -1
  53. package/package.json +1 -1
@@ -17,17 +17,24 @@ import { CommonModule } from '@angular/common';
17
17
  import { ChangeDetectionStrategy, Component, HostBinding, Input, signal, ViewChild, ViewEncapsulation, } from '@angular/core';
18
18
  import { TranslateModule } from '@ngx-translate/core';
19
19
  import { CarbonListModule, EllipsisPipe, ViewType } from '@valtimo/components';
20
- import { InputModule } from 'carbon-components-angular';
21
- import { BehaviorSubject, combineLatest, map } from 'rxjs';
20
+ import { ButtonModule, InputModule } from 'carbon-components-angular';
21
+ import { BehaviorSubject, combineLatest, map, tap } from 'rxjs';
22
+ import { WidgetProcess } from '../widget-process/widget-process';
22
23
  import * as i0 from "@angular/core";
23
- import * as i1 from "@valtimo/components";
24
- import * as i2 from "@angular/common";
25
- import * as i3 from "@ngx-translate/core";
26
- export class WidgetFieldComponent {
24
+ import * as i1 from "@valtimo/document";
25
+ import * as i2 from "@valtimo/access-control";
26
+ import * as i3 from "@angular/router";
27
+ import * as i4 from "@valtimo/components";
28
+ import * as i5 from "../../widgets.service";
29
+ import * as i6 from "@angular/common";
30
+ import * as i7 from "@ngx-translate/core";
31
+ import * as i8 from "carbon-components-angular";
32
+ export class WidgetFieldComponent extends WidgetProcess {
27
33
  set widgetConfiguration(value) {
28
34
  if (!value)
29
35
  return;
30
36
  this.widgetConfiguration$.next(value);
37
+ this.baseWidgetConfiguration = value;
31
38
  }
32
39
  set widgetData(value) {
33
40
  if (!value)
@@ -35,11 +42,17 @@ export class WidgetFieldComponent {
35
42
  this.widgetData$.next(value);
36
43
  this.isEmptyWidgetData$.next(this.checkEmptyWidgetData(value));
37
44
  }
38
- constructor(viewContentService) {
45
+ constructor(documentService, permissionService, route, viewContentService, widgetsService) {
46
+ super(documentService, permissionService);
47
+ this.documentService = documentService;
48
+ this.permissionService = permissionService;
49
+ this.route = route;
39
50
  this.viewContentService = viewContentService;
51
+ this.widgetsService = widgetsService;
40
52
  this.class = 'widget-field';
41
53
  this.collapseVertically = false;
42
54
  this.isEmptyWidgetData$ = new BehaviorSubject(false);
55
+ this.noVisibleFields$ = new BehaviorSubject(true);
43
56
  this.renderVertically = signal(0);
44
57
  this.widgetConfiguration$ = new BehaviorSubject(null);
45
58
  this.widgetData$ = new BehaviorSubject(null);
@@ -51,6 +64,8 @@ export class WidgetFieldComponent {
51
64
  title: property.title,
52
65
  ellipsisCharacterLimit: property.displayProperties
53
66
  ?.ellipsisCharacterLimit ?? null,
67
+ hideWhenEmpty: property.displayProperties?.hideWhenEmpty ??
68
+ false,
54
69
  value: this.viewContentService.get(widgetData[property.key], {
55
70
  ...property.displayProperties,
56
71
  viewType: property.displayProperties?.type ?? ViewType.TEXT,
@@ -58,7 +73,7 @@ export class WidgetFieldComponent {
58
73
  },
59
74
  ]
60
75
  : []),
61
- ], []))));
76
+ ], []))), tap(columns => this.checkEmptyFields(columns)));
62
77
  }
63
78
  ngAfterViewInit() {
64
79
  if (this.collapseVertically && this._widgetFieldRef)
@@ -67,6 +82,9 @@ export class WidgetFieldComponent {
67
82
  ngOnDestroy() {
68
83
  this._observer?.disconnect();
69
84
  }
85
+ onProcessStartClick(process) {
86
+ this.widgetsService.startProcess(process.processDefinitionKey);
87
+ }
70
88
  openWidthObserver() {
71
89
  this._observer = new ResizeObserver(event => {
72
90
  this.observerMutation(event);
@@ -93,13 +111,28 @@ export class WidgetFieldComponent {
93
111
  checkEmptyWidgetData(widgetData) {
94
112
  return widgetData && Object.keys(widgetData).length === 0;
95
113
  }
96
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetFieldComponent, deps: [{ token: i1.ViewContentService }], target: i0.ɵɵFactoryTarget.Component }); }
97
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetFieldComponent, isStandalone: true, selector: "valtimo-widget-field", inputs: { collapseVertically: "collapseVertically", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_widgetFieldRef", first: true, predicate: ["widgetField"], 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 widgetPropertyValue: widgetPropertyValue$ | async,\n widgetData: widgetData$ | async,\n isEmptyWidgetData: isEmptyWidgetData$ | async,\n } as obs\"\n>\n <h4 class=\"widget-field__title\">{{ obs?.widgetConfiguration?.title }}</h4>\n\n @if (obs?.isEmptyWidgetData) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n } @else {\n <div\n #widgetField\n [ngClass]=\"{\n 'widget-field__render-vertically': renderVertically() === 1,\n 'widget-field__render-two-columns': renderVertically() === 2,\n 'widget-field__render-three-columns': renderVertically() === 3,\n 'widget-field__container': renderVertically() === 4,\n }\"\n >\n @for (column of obs?.widgetPropertyValue; track column.key) {\n <div class=\"widget-field__column\">\n @for (property of column; track property) {\n <div class=\"widget-field__field\">\n <label class=\"widget-field__field-label\" [attr.title]=\"property?.title\">\n {{ property?.title }}</label\n >\n\n <div [attr.title]=\"property?.value\" class=\"widget-field__field-value\">\n {{ property?.value | valtimoEllipsis: property?.ellipsisCharacterLimit }}\n </div>\n </div>\n }\n </div>\n }\n </div>\n }\n</ng-container>\n", styles: [".widget-field{padding:24px}.widget-field,.widget-field__column{display:flex;flex-direction:column;gap:16px;width:100%;overflow:hidden}.widget-field__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.widget-field__container{display:grid;grid-gap:24px;grid-template-columns:repeat(4,1fr)}.widget-field__field{display:flex;width:100%;flex-direction:column;gap:8px}.widget-field__field-label{font-size:12px;color:var(--cds-text-secondary)}.widget-field__field-value{color:var(--cds-text-primary);padding:8px 16px;border-bottom:1px solid var(--cds-border-subtle-01);font-size:14px}.widget-field .cds--label{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-field__render-vertically,.widget-field__render-two-columns,.widget-field__render-three-columns{display:grid;align-items:stretch;gap:24px}.widget-field__render-vertically{grid-template-columns:repeat(1,1fr)}.widget-field__render-two-columns{grid-template-columns:repeat(2,1fr)}.widget-field__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: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: InputModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i1.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "pipe", type: EllipsisPipe, name: "valtimoEllipsis" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
114
+ checkEmptyFields(columns) {
115
+ columns.forEach(column => {
116
+ column.forEach(field => {
117
+ if (!field?.hideWhenEmpty || (field?.hideWhenEmpty && field?.value && field?.value !== '-'))
118
+ this.noVisibleFields$.next(false);
119
+ });
120
+ });
121
+ }
122
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetFieldComponent, deps: [{ token: i1.DocumentService }, { token: i2.PermissionService }, { token: i3.ActivatedRoute }, { token: i4.ViewContentService }, { token: i5.WidgetsService }], target: i0.ɵɵFactoryTarget.Component }); }
123
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetFieldComponent, isStandalone: true, selector: "valtimo-widget-field", inputs: { collapseVertically: "collapseVertically", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_widgetFieldRef", first: true, predicate: ["widgetField"], descendants: true }], usesInheritance: 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 widgetPropertyValue: widgetPropertyValue$ | async,\n widgetData: widgetData$ | async,\n isEmptyWidgetData: isEmptyWidgetData$ | async,\n noVisibleFields: noVisibleFields$ | async,\n } as obs\"\n>\n <section class=\"widget-field__header\">\n <h4 class=\"widget-field__title\">{{ obs?.widgetConfiguration?.title }}</h4>\n\n @if (obs.widgetConfiguration.actions?.length === 1) {\n <button\n *ngIf=\"canCreateCamundaExecution$ | async\"\n cdsButton=\"ghost\"\n (click)=\"onProcessStartClick(obs.widgetConfiguration.actions[0])\"\n >\n {{ obs.widgetConfiguration.actions[0].name }}\n </button>\n }\n </section>\n\n @if (obs?.isEmptyWidgetData) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n } @else {\n <div\n #widgetField\n [ngClass]=\"{\n 'widget-field__render-vertically': renderVertically() === 1,\n 'widget-field__render-two-columns': renderVertically() === 2,\n 'widget-field__render-three-columns': renderVertically() === 3,\n 'widget-field__container': renderVertically() === 4,\n }\"\n >\n @if (obs.noVisibleFields) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.emptyFields' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n } @else {\n @for (column of obs?.widgetPropertyValue; track column.key) {\n <div class=\"widget-field__column\">\n @for (property of column; track property) {\n <div\n *ngIf=\"\n (property?.value !== null &&\n property?.value !== '-' &&\n property?.hideWhenEmpty) ||\n !property?.hideWhenEmpty\n \"\n class=\"widget-field__field\"\n >\n <label class=\"widget-field__field-label\" [attr.title]=\"property?.title\">\n {{ property?.title }}</label\n >\n\n <div [attr.title]=\"property?.value\" class=\"widget-field__field-value\">\n {{ property?.value | valtimoEllipsis: property?.ellipsisCharacterLimit }}\n </div>\n </div>\n }\n </div>\n }\n }\n </div>\n }\n</ng-container>\n", styles: [".widget-field{padding:24px}.widget-field__header{display:flex;align-items:center;justify-content:space-between}.widget-field,.widget-field__column{display:flex;flex-direction:column;gap:16px;width:100%;overflow:hidden}.widget-field__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.widget-field__container{display:grid;grid-gap:24px;grid-template-columns:repeat(4,1fr)}.widget-field__field{display:flex;width:100%;flex-direction:column;gap:8px}.widget-field__field-label{font-size:12px;color:var(--cds-text-secondary)}.widget-field__field-value{color:var(--cds-text-primary);padding:8px 16px;border-bottom:1px solid var(--cds-border-subtle-01);font-size:14px}.widget-field .cds--label{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-field__render-vertically,.widget-field__render-two-columns,.widget-field__render-three-columns{display:grid;align-items:stretch;gap:24px}.widget-field__render-vertically{grid-template-columns:repeat(1,1fr)}.widget-field__render-two-columns{grid-template-columns:repeat(2,1fr)}.widget-field__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: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "ngmodule", type: InputModule }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i4.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "pipe", type: EllipsisPipe, name: "valtimoEllipsis" }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i8.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
98
124
  }
99
125
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetFieldComponent, decorators: [{
100
126
  type: Component,
101
- args: [{ selector: 'valtimo-widget-field', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [CommonModule, InputModule, TranslateModule, CarbonListModule, EllipsisPipe], 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 widgetPropertyValue: widgetPropertyValue$ | async,\n widgetData: widgetData$ | async,\n isEmptyWidgetData: isEmptyWidgetData$ | async,\n } as obs\"\n>\n <h4 class=\"widget-field__title\">{{ obs?.widgetConfiguration?.title }}</h4>\n\n @if (obs?.isEmptyWidgetData) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n } @else {\n <div\n #widgetField\n [ngClass]=\"{\n 'widget-field__render-vertically': renderVertically() === 1,\n 'widget-field__render-two-columns': renderVertically() === 2,\n 'widget-field__render-three-columns': renderVertically() === 3,\n 'widget-field__container': renderVertically() === 4,\n }\"\n >\n @for (column of obs?.widgetPropertyValue; track column.key) {\n <div class=\"widget-field__column\">\n @for (property of column; track property) {\n <div class=\"widget-field__field\">\n <label class=\"widget-field__field-label\" [attr.title]=\"property?.title\">\n {{ property?.title }}</label\n >\n\n <div [attr.title]=\"property?.value\" class=\"widget-field__field-value\">\n {{ property?.value | valtimoEllipsis: property?.ellipsisCharacterLimit }}\n </div>\n </div>\n }\n </div>\n }\n </div>\n }\n</ng-container>\n", styles: [".widget-field{padding:24px}.widget-field,.widget-field__column{display:flex;flex-direction:column;gap:16px;width:100%;overflow:hidden}.widget-field__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.widget-field__container{display:grid;grid-gap:24px;grid-template-columns:repeat(4,1fr)}.widget-field__field{display:flex;width:100%;flex-direction:column;gap:8px}.widget-field__field-label{font-size:12px;color:var(--cds-text-secondary)}.widget-field__field-value{color:var(--cds-text-primary);padding:8px 16px;border-bottom:1px solid var(--cds-border-subtle-01);font-size:14px}.widget-field .cds--label{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-field__render-vertically,.widget-field__render-two-columns,.widget-field__render-three-columns{display:grid;align-items:stretch;gap:24px}.widget-field__render-vertically{grid-template-columns:repeat(1,1fr)}.widget-field__render-two-columns{grid-template-columns:repeat(2,1fr)}.widget-field__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"] }]
102
- }], ctorParameters: () => [{ type: i1.ViewContentService }], propDecorators: { class: [{
127
+ args: [{ selector: 'valtimo-widget-field', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [
128
+ CommonModule,
129
+ InputModule,
130
+ TranslateModule,
131
+ CarbonListModule,
132
+ EllipsisPipe,
133
+ ButtonModule,
134
+ ], 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 widgetPropertyValue: widgetPropertyValue$ | async,\n widgetData: widgetData$ | async,\n isEmptyWidgetData: isEmptyWidgetData$ | async,\n noVisibleFields: noVisibleFields$ | async,\n } as obs\"\n>\n <section class=\"widget-field__header\">\n <h4 class=\"widget-field__title\">{{ obs?.widgetConfiguration?.title }}</h4>\n\n @if (obs.widgetConfiguration.actions?.length === 1) {\n <button\n *ngIf=\"canCreateCamundaExecution$ | async\"\n cdsButton=\"ghost\"\n (click)=\"onProcessStartClick(obs.widgetConfiguration.actions[0])\"\n >\n {{ obs.widgetConfiguration.actions[0].name }}\n </button>\n }\n </section>\n\n @if (obs?.isEmptyWidgetData) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n } @else {\n <div\n #widgetField\n [ngClass]=\"{\n 'widget-field__render-vertically': renderVertically() === 1,\n 'widget-field__render-two-columns': renderVertically() === 2,\n 'widget-field__render-three-columns': renderVertically() === 3,\n 'widget-field__container': renderVertically() === 4,\n }\"\n >\n @if (obs.noVisibleFields) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.emptyFields' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n } @else {\n @for (column of obs?.widgetPropertyValue; track column.key) {\n <div class=\"widget-field__column\">\n @for (property of column; track property) {\n <div\n *ngIf=\"\n (property?.value !== null &&\n property?.value !== '-' &&\n property?.hideWhenEmpty) ||\n !property?.hideWhenEmpty\n \"\n class=\"widget-field__field\"\n >\n <label class=\"widget-field__field-label\" [attr.title]=\"property?.title\">\n {{ property?.title }}</label\n >\n\n <div [attr.title]=\"property?.value\" class=\"widget-field__field-value\">\n {{ property?.value | valtimoEllipsis: property?.ellipsisCharacterLimit }}\n </div>\n </div>\n }\n </div>\n }\n }\n </div>\n }\n</ng-container>\n", styles: [".widget-field{padding:24px}.widget-field__header{display:flex;align-items:center;justify-content:space-between}.widget-field,.widget-field__column{display:flex;flex-direction:column;gap:16px;width:100%;overflow:hidden}.widget-field__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.widget-field__container{display:grid;grid-gap:24px;grid-template-columns:repeat(4,1fr)}.widget-field__field{display:flex;width:100%;flex-direction:column;gap:8px}.widget-field__field-label{font-size:12px;color:var(--cds-text-secondary)}.widget-field__field-value{color:var(--cds-text-primary);padding:8px 16px;border-bottom:1px solid var(--cds-border-subtle-01);font-size:14px}.widget-field .cds--label{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-field__render-vertically,.widget-field__render-two-columns,.widget-field__render-three-columns{display:grid;align-items:stretch;gap:24px}.widget-field__render-vertically{grid-template-columns:repeat(1,1fr)}.widget-field__render-two-columns{grid-template-columns:repeat(2,1fr)}.widget-field__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"] }]
135
+ }], ctorParameters: () => [{ type: i1.DocumentService }, { type: i2.PermissionService }, { type: i3.ActivatedRoute }, { type: i4.ViewContentService }, { type: i5.WidgetsService }], propDecorators: { class: [{
103
136
  type: HostBinding,
104
137
  args: ['class']
105
138
  }], _widgetFieldRef: [{
@@ -112,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
112
145
  }], widgetData: [{
113
146
  type: Input
114
147
  }] } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-field.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAEL,uBAAuB,EACvB,SAAS,EAET,WAAW,EACX,KAAK,EAEL,MAAM,EACN,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAC,gBAAgB,EAAE,YAAY,EAAsB,QAAQ,EAAC,MAAM,qBAAqB,CAAC;AACjG,OAAO,EAAC,WAAW,EAAC,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,GAAG,EAAa,MAAM,MAAM,CAAC;;;;;AAYrE,MAAM,OAAO,oBAAoB;IAM/B,IAAoB,mBAAmB,CAAC,KAAuB;QAC7D,IAAI,CAAC,KAAK;YAAE,OAAO;QACnB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAGD,IAAoB,UAAU,CAAC,KAAa;QAC1C,IAAI,CAAC,KAAK;YAAE,OAAO;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAC;IACjE,CAAC;IAqCD,YAAoB,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;QApDpB,UAAK,GAAG,cAAc,CAAC;QAIpD,uBAAkB,GAAG,KAAK,CAAC;QAKpB,uBAAkB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAQzD,qBAAgB,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC7B,yBAAoB,GAAG,IAAI,eAAe,CAA0B,IAAI,CAAC,CAAC;QAC1E,gBAAW,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC,CAAC;QAEvD,yBAAoB,GAEhC,aAAa,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CACnE,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,EAAE,CAC3B,MAAM,EAAE,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CACtC,MAAM,CAAC,MAAM,CACX,CAAC,YAAY,EAAE,QAAQ,EAAE,EAAE,CAAC;YAC1B,GAAG,YAAY;YACf,GAAG,CAAC,UAAU,EAAE,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC;gBAC1C,CAAC,CAAC;oBACE;wBACE,KAAK,EAAE,QAAQ,CAAC,KAAK;wBACrB,sBAAsB,EACnB,QAAQ,CAAC,iBAA+C;4BACvD,EAAE,sBAAsB,IAAI,IAAI;wBACpC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;4BAC3D,GAAG,QAAQ,CAAC,iBAAiB;4BAC7B,QAAQ,EAAE,QAAQ,CAAC,iBAAiB,EAAE,IAAI,IAAI,QAAQ,CAAC,IAAI;yBAC5D,CAAC;qBACH;iBACF;gBACH,CAAC,CAAC,EAAE,CAAC;SACR,EACD,EAAE,CACH,CACF,CACF,CACF,CAAC;IAI2D,CAAC;IAEvD,eAAe;QACpB,IAAI,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,eAAe;YAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAChF,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,EAAE,UAAU,EAAE,CAAC;IAC/B,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,SAAS,GAAG,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE;YAC1C,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAEO,gBAAgB,CAAC,KAAiC;QACxD,MAAM,YAAY,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC;QAE5D,IAAI,OAAO,YAAY,KAAK,QAAQ,IAAI,YAAY,KAAK,CAAC,EAAE,CAAC;YAC3D,IAAI,YAAY,GAAG,GAAG,EAAE,CAAC;gBACvB,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC/B,CAAC;iBAAM,IAAI,YAAY,GAAG,GAAG,IAAI,YAAY,IAAI,GAAG,EAAE,CAAC;gBACrD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC/B,CAAC;iBAAM,IAAI,YAAY,GAAG,GAAG,IAAI,YAAY,IAAI,IAAI,EAAE,CAAC;gBACtD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC/B,CAAC;iBAAM,IAAI,YAAY,GAAG,IAAI,EAAE,CAAC;gBAC/B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC/B,CAAC;QACH,CAAC;IACH,CAAC;IAEO,oBAAoB,CAAC,UAAkB;QAC7C,OAAO,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;IAC5D,CAAC;+GAxFU,oBAAoB;mGAApB,oBAAoB,6WC3CjC,yrEA4DA,+tDDnBY,YAAY,qRAAE,WAAW,8BAAE,eAAe,2FAAE,gBAAgB,gPAAE,YAAY;;4FAEzE,oBAAoB;kBAThC,SAAS;+BACE,sBAAsB,mBAGf,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,cACzB,IAAI,WACP,CAAC,YAAY,EAAE,WAAW,EAAE,eAAe,EAAE,gBAAgB,EAAE,YAAY,CAAC;uFAG/C,KAAK;sBAA1C,WAAW;uBAAC,OAAO;gBAEc,eAAe;sBAAhD,SAAS;uBAAC,aAAa;gBAEf,kBAAkB;sBAA1B,KAAK;gBACc,mBAAmB;sBAAtC,KAAK;gBAMc,UAAU;sBAA7B,KAAK","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 */\nimport {CommonModule} from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CarbonListModule, EllipsisPipe, ViewContentService, ViewType} from '@valtimo/components';\nimport {InputModule} from 'carbon-components-angular';\nimport {BehaviorSubject, combineLatest, map, Observable} from 'rxjs';\nimport {CaseWidgetTextDisplayType, FieldsCaseWidget} from '../../../../../../models';\n\n@Component({\n  selector: 'valtimo-widget-field',\n  templateUrl: './widget-field.component.html',\n  styleUrls: ['./widget-field.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [CommonModule, InputModule, TranslateModule, CarbonListModule, EllipsisPipe],\n})\nexport class WidgetFieldComponent implements AfterViewInit, OnDestroy {\n  @HostBinding('class') public readonly class = 'widget-field';\n\n  @ViewChild('widgetField') private _widgetFieldRef: ElementRef<HTMLDivElement>;\n\n  @Input() collapseVertically = false;\n  @Input() public set widgetConfiguration(value: FieldsCaseWidget) {\n    if (!value) return;\n    this.widgetConfiguration$.next(value);\n  }\n  public readonly isEmptyWidgetData$ = new BehaviorSubject<boolean>(false);\n\n  @Input() public set widgetData(value: object) {\n    if (!value) return;\n    this.widgetData$.next(value);\n    this.isEmptyWidgetData$.next(this.checkEmptyWidgetData(value));\n  }\n\n  public readonly renderVertically = signal(0);\n  public readonly widgetConfiguration$ = new BehaviorSubject<FieldsCaseWidget | null>(null);\n  public readonly widgetData$ = new BehaviorSubject<object | null>(null);\n\n  public readonly widgetPropertyValue$: Observable<\n    {title: string; value: string; ellipsisCharacterLimit: number | null}[][]\n  > = combineLatest([this.widgetConfiguration$, this.widgetData$]).pipe(\n    map(([widget, widgetData]) =>\n      widget?.properties.columns.map(column =>\n        column.reduce(\n          (columnFields, property) => [\n            ...columnFields,\n            ...(widgetData?.hasOwnProperty(property.key)\n              ? [\n                  {\n                    title: property.title,\n                    ellipsisCharacterLimit:\n                      (property.displayProperties as CaseWidgetTextDisplayType)\n                        ?.ellipsisCharacterLimit ?? null,\n                    value: this.viewContentService.get(widgetData[property.key], {\n                      ...property.displayProperties,\n                      viewType: property.displayProperties?.type ?? ViewType.TEXT,\n                    }),\n                  },\n                ]\n              : []),\n          ],\n          []\n        )\n      )\n    )\n  );\n\n  private _observer!: ResizeObserver;\n\n  constructor(private viewContentService: ViewContentService) {}\n\n  public ngAfterViewInit(): void {\n    if (this.collapseVertically && this._widgetFieldRef) this.openWidthObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._observer?.disconnect();\n  }\n\n  private openWidthObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetFieldRef.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.renderVertically.set(1);\n      } else if (elementWidth > 640 && elementWidth <= 768) {\n        this.renderVertically.set(2);\n      } else if (elementWidth > 768 && elementWidth <= 1080) {\n        this.renderVertically.set(3);\n      } else if (elementWidth > 1080) {\n        this.renderVertically.set(4);\n      }\n    }\n  }\n\n  private checkEmptyWidgetData(widgetData: Object): boolean {\n    return widgetData && Object.keys(widgetData).length === 0;\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    widgetPropertyValue: widgetPropertyValue$ | async,\n    widgetData: widgetData$ | async,\n    isEmptyWidgetData: isEmptyWidgetData$ | async,\n  } as obs\"\n>\n  <h4 class=\"widget-field__title\">{{ obs?.widgetConfiguration?.title }}</h4>\n\n  @if (obs?.isEmptyWidgetData) {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  } @else {\n    <div\n      #widgetField\n      [ngClass]=\"{\n        'widget-field__render-vertically': renderVertically() === 1,\n        'widget-field__render-two-columns': renderVertically() === 2,\n        'widget-field__render-three-columns': renderVertically() === 3,\n        'widget-field__container': renderVertically() === 4,\n      }\"\n    >\n      @for (column of obs?.widgetPropertyValue; track column.key) {\n        <div class=\"widget-field__column\">\n          @for (property of column; track property) {\n            <div class=\"widget-field__field\">\n              <label class=\"widget-field__field-label\" [attr.title]=\"property?.title\">\n                {{ property?.title }}</label\n              >\n\n              <div [attr.title]=\"property?.value\" class=\"widget-field__field-value\">\n                {{ property?.value | valtimoEllipsis: property?.ellipsisCharacterLimit }}\n              </div>\n            </div>\n          }\n        </div>\n      }\n    </div>\n  }\n</ng-container>\n"]}
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-field.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/field/widget-field.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 */\nimport {CommonModule} from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CarbonListModule, EllipsisPipe, ViewContentService, ViewType} from '@valtimo/components';\nimport {ButtonModule, InputModule} from 'carbon-components-angular';\nimport {BehaviorSubject, combineLatest, map, Observable, tap} from 'rxjs';\nimport {\n  CaseWidgetAction,\n  CaseWidgetTextDisplayType,\n  FieldsCaseWidget,\n} from '../../../../../../models';\nimport {WidgetsService} from '../../widgets.service';\nimport {PermissionService} from '@valtimo/access-control';\nimport {ActivatedRoute} from '@angular/router';\nimport {WidgetProcess} from '../widget-process/widget-process';\nimport {DocumentService} from '@valtimo/document';\n\n@Component({\n  selector: 'valtimo-widget-field',\n  templateUrl: './widget-field.component.html',\n  styleUrls: ['./widget-field.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    InputModule,\n    TranslateModule,\n    CarbonListModule,\n    EllipsisPipe,\n    ButtonModule,\n  ],\n})\nexport class WidgetFieldComponent extends WidgetProcess implements AfterViewInit, OnDestroy {\n  @HostBinding('class') public readonly class = 'widget-field';\n\n  @ViewChild('widgetField') private _widgetFieldRef: ElementRef<HTMLDivElement>;\n\n  @Input() collapseVertically = false;\n  @Input() public set widgetConfiguration(value: FieldsCaseWidget) {\n    if (!value) return;\n    this.widgetConfiguration$.next(value);\n    this.baseWidgetConfiguration = value;\n  }\n  public readonly isEmptyWidgetData$ = new BehaviorSubject<boolean>(false);\n  public readonly noVisibleFields$ = new BehaviorSubject<boolean>(true);\n\n  @Input() public set widgetData(value: object) {\n    if (!value) return;\n    this.widgetData$.next(value);\n    this.isEmptyWidgetData$.next(this.checkEmptyWidgetData(value));\n  }\n\n  public readonly renderVertically = signal(0);\n  public readonly widgetConfiguration$ = new BehaviorSubject<FieldsCaseWidget | null>(null);\n  public readonly widgetData$ = new BehaviorSubject<object | null>(null);\n\n  public readonly widgetPropertyValue$: Observable<\n    {\n      title: string;\n      value: string;\n      ellipsisCharacterLimit: number | null;\n      hideWhenEmpty: boolean | false;\n    }[][]\n  > = combineLatest([this.widgetConfiguration$, this.widgetData$]).pipe(\n    map(([widget, widgetData]) =>\n      widget?.properties.columns.map(column =>\n        column.reduce(\n          (columnFields, property) => [\n            ...columnFields,\n            ...(widgetData?.hasOwnProperty(property.key)\n              ? [\n                  {\n                    title: property.title,\n                    ellipsisCharacterLimit:\n                      (property.displayProperties as CaseWidgetTextDisplayType)\n                        ?.ellipsisCharacterLimit ?? null,\n                    hideWhenEmpty:\n                      (property.displayProperties as CaseWidgetTextDisplayType)?.hideWhenEmpty ??\n                      false,\n                    value: this.viewContentService.get(widgetData[property.key], {\n                      ...property.displayProperties,\n                      viewType: property.displayProperties?.type ?? ViewType.TEXT,\n                    }),\n                  },\n                ]\n              : []),\n          ],\n          []\n        )\n      )\n    ),\n    tap(columns => this.checkEmptyFields(columns))\n  );\n\n  private _observer!: ResizeObserver;\n\n  constructor(\n    protected readonly documentService: DocumentService,\n    protected readonly permissionService: PermissionService,\n    private readonly route: ActivatedRoute,\n    private readonly viewContentService: ViewContentService,\n    private readonly widgetsService: WidgetsService\n  ) {\n    super(documentService, permissionService);\n  }\n\n  public ngAfterViewInit(): void {\n    if (this.collapseVertically && this._widgetFieldRef) this.openWidthObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._observer?.disconnect();\n  }\n\n  public onProcessStartClick(process: CaseWidgetAction): void {\n    this.widgetsService.startProcess(process.processDefinitionKey);\n  }\n\n  private openWidthObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetFieldRef.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.renderVertically.set(1);\n      } else if (elementWidth > 640 && elementWidth <= 768) {\n        this.renderVertically.set(2);\n      } else if (elementWidth > 768 && elementWidth <= 1080) {\n        this.renderVertically.set(3);\n      } else if (elementWidth > 1080) {\n        this.renderVertically.set(4);\n      }\n    }\n  }\n\n  private checkEmptyWidgetData(widgetData: Object): boolean {\n    return widgetData && Object.keys(widgetData).length === 0;\n  }\n\n  private checkEmptyFields(columns: any[][]): void {\n    columns.forEach(column => {\n      column.forEach(field => {\n        if (!field?.hideWhenEmpty || (field?.hideWhenEmpty && field?.value && field?.value !== '-'))\n          this.noVisibleFields$.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<ng-container\n  *ngIf=\"{\n    widgetConfiguration: widgetConfiguration$ | async,\n    widgetPropertyValue: widgetPropertyValue$ | async,\n    widgetData: widgetData$ | async,\n    isEmptyWidgetData: isEmptyWidgetData$ | async,\n    noVisibleFields: noVisibleFields$ | async,\n  } as obs\"\n>\n  <section class=\"widget-field__header\">\n    <h4 class=\"widget-field__title\">{{ obs?.widgetConfiguration?.title }}</h4>\n\n    @if (obs.widgetConfiguration.actions?.length === 1) {\n      <button\n        *ngIf=\"canCreateCamundaExecution$ | async\"\n        cdsButton=\"ghost\"\n        (click)=\"onProcessStartClick(obs.widgetConfiguration.actions[0])\"\n      >\n        {{ obs.widgetConfiguration.actions[0].name }}\n      </button>\n    }\n  </section>\n\n  @if (obs?.isEmptyWidgetData) {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  } @else {\n    <div\n      #widgetField\n      [ngClass]=\"{\n        'widget-field__render-vertically': renderVertically() === 1,\n        'widget-field__render-two-columns': renderVertically() === 2,\n        'widget-field__render-three-columns': renderVertically() === 3,\n        'widget-field__container': renderVertically() === 4,\n      }\"\n    >\n      @if (obs.noVisibleFields) {\n        <valtimo-no-results\n          [collapseVertically]=\"true\"\n          [description]=\"'dossier.widgets.emptyFields' | translate\"\n          [smallPadding]=\"true\"\n        ></valtimo-no-results>\n      } @else {\n        @for (column of obs?.widgetPropertyValue; track column.key) {\n          <div class=\"widget-field__column\">\n            @for (property of column; track property) {\n              <div\n                *ngIf=\"\n                  (property?.value !== null &&\n                    property?.value !== '-' &&\n                    property?.hideWhenEmpty) ||\n                  !property?.hideWhenEmpty\n                \"\n                class=\"widget-field__field\"\n              >\n                <label class=\"widget-field__field-label\" [attr.title]=\"property?.title\">\n                  {{ property?.title }}</label\n                >\n\n                <div [attr.title]=\"property?.value\" class=\"widget-field__field-value\">\n                  {{ property?.value | valtimoEllipsis: property?.ellipsisCharacterLimit }}\n                </div>\n              </div>\n            }\n          </div>\n        }\n      }\n    </div>\n  }\n</ng-container>\n"]}
@@ -18,12 +18,18 @@ import { CommonModule } from '@angular/common';
18
18
  import { TranslateModule } from '@ngx-translate/core';
19
19
  import { BehaviorSubject, combineLatest, filter, map, of, switchMap, tap } from 'rxjs';
20
20
  import { FormIoModule } from '@valtimo/components';
21
+ import { WidgetProcess } from '../widget-process/widget-process';
22
+ import { ButtonModule } from 'carbon-components-angular';
21
23
  import * as i0 from "@angular/core";
22
- import * as i1 from "@valtimo/form";
23
- import * as i2 from "../../../../../../services";
24
- import * as i3 from "@angular/common";
25
- import * as i4 from "@valtimo/components";
26
- export class WidgetFormioComponent {
24
+ import * as i1 from "@valtimo/document";
25
+ import * as i2 from "@valtimo/access-control";
26
+ import * as i3 from "@valtimo/form";
27
+ import * as i4 from "../../../../../../services";
28
+ import * as i5 from "../../widgets.service";
29
+ import * as i6 from "@angular/common";
30
+ import * as i7 from "@valtimo/components";
31
+ import * as i8 from "carbon-components-angular";
32
+ export class WidgetFormioComponent extends WidgetProcess {
27
33
  set documentId(value) {
28
34
  if (value)
29
35
  this._documentIdSubject$.next(value);
@@ -32,6 +38,7 @@ export class WidgetFormioComponent {
32
38
  if (!value)
33
39
  return;
34
40
  this.layoutService.setWidgetWithExternalData(value.uuid);
41
+ this.baseWidgetConfiguration = value;
35
42
  this._widgetConfigurationSubject$.next(value);
36
43
  }
37
44
  get widgetConfiguration$() {
@@ -40,9 +47,13 @@ export class WidgetFormioComponent {
40
47
  get _documentId$() {
41
48
  return this._documentIdSubject$.pipe(filter(id => !!id));
42
49
  }
43
- constructor(formService, layoutService) {
50
+ constructor(documentService, permissionService, formService, layoutService, widgetsService) {
51
+ super(documentService, permissionService);
52
+ this.documentService = documentService;
53
+ this.permissionService = permissionService;
44
54
  this.formService = formService;
45
55
  this.layoutService = layoutService;
56
+ this.widgetsService = widgetsService;
46
57
  this._widgetConfigurationSubject$ = new BehaviorSubject(null);
47
58
  this._documentIdSubject$ = new BehaviorSubject('');
48
59
  this.prefilledFormDefinition$ = combineLatest([
@@ -53,15 +64,18 @@ export class WidgetFormioComponent {
53
64
  of(config),
54
65
  ])), tap(([_, config]) => this.layoutService.setWidgetWithExternalDataReady(config.uuid)), map(([formDef]) => formDef));
55
66
  }
56
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetFormioComponent, deps: [{ token: i1.FormService }, { token: i2.DossierWidgetsLayoutService }], target: i0.ɵɵFactoryTarget.Component }); }
57
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WidgetFormioComponent, isStandalone: true, selector: "valtimo-widget-formio", inputs: { documentId: "documentId", widgetConfiguration: "widgetConfiguration" }, 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=\"formio-widget\" *ngIf=\"prefilledFormDefinition$ | async as prefilledFormDefinition\">\n <h4 class=\"formio-widget__title\">{{ (widgetConfiguration$ | async)?.title || '-' }}</h4>\n\n <valtimo-form-io [form]=\"prefilledFormDefinition\"></valtimo-form-io>\n</div>\n", styles: [".formio-widget{padding:24px}.formio-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px;margin-bottom:16px}\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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: FormIoModule }, { kind: "component", type: i4.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
67
+ onProcessStartClick(process) {
68
+ this.widgetsService.startProcess(process.processDefinitionKey);
69
+ }
70
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetFormioComponent, deps: [{ token: i1.DocumentService }, { token: i2.PermissionService }, { token: i3.FormService }, { token: i4.DossierWidgetsLayoutService }, { token: i5.WidgetsService }], target: i0.ɵɵFactoryTarget.Component }); }
71
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetFormioComponent, isStandalone: true, selector: "valtimo-widget-formio", inputs: { documentId: "documentId", widgetConfiguration: "widgetConfiguration" }, usesInheritance: 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<div\n class=\"formio-widget\"\n *ngIf=\"{\n prefilledFormDefinition: prefilledFormDefinition$ | async,\n widgetConfiguration: widgetConfiguration$ | async,\n } as obs\"\n>\n <section class=\"formio-widget__header\">\n <h4 class=\"formio-widget__title\">{{ obs.widgetConfiguration$?.title || '-' }}</h4>\n\n @if (obs.widgetConfiguration?.actions?.length === 1) {\n <button\n *ngIf=\"canCreateCamundaExecution$ | async\"\n cdsButton=\"ghost\"\n (click)=\"onProcessStartClick(obs.widgetConfiguration?.actions[0])\"\n >\n {{ obs.widgetConfiguration?.actions[0].name }}\n </button>\n }\n </section>\n\n <valtimo-form-io [form]=\"obs.prefilledFormDefinition\"></valtimo-form-io>\n</div>\n", styles: [".formio-widget{padding:24px}.formio-widget__header{display:flex;align-items:center;justify-content:space-between}.formio-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px;margin-bottom:16px}\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: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "ngmodule", type: FormIoModule }, { kind: "component", type: i7.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i8.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
58
72
  }
59
73
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetFormioComponent, decorators: [{
60
74
  type: Component,
61
- args: [{ selector: 'valtimo-widget-formio', standalone: true, imports: [CommonModule, TranslateModule, FormIoModule], 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=\"formio-widget\" *ngIf=\"prefilledFormDefinition$ | async as prefilledFormDefinition\">\n <h4 class=\"formio-widget__title\">{{ (widgetConfiguration$ | async)?.title || '-' }}</h4>\n\n <valtimo-form-io [form]=\"prefilledFormDefinition\"></valtimo-form-io>\n</div>\n", styles: [".formio-widget{padding:24px}.formio-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px;margin-bottom:16px}\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"] }]
62
- }], ctorParameters: () => [{ type: i1.FormService }, { type: i2.DossierWidgetsLayoutService }], propDecorators: { documentId: [{
75
+ args: [{ selector: 'valtimo-widget-formio', standalone: true, imports: [CommonModule, TranslateModule, FormIoModule, ButtonModule], 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\n class=\"formio-widget\"\n *ngIf=\"{\n prefilledFormDefinition: prefilledFormDefinition$ | async,\n widgetConfiguration: widgetConfiguration$ | async,\n } as obs\"\n>\n <section class=\"formio-widget__header\">\n <h4 class=\"formio-widget__title\">{{ obs.widgetConfiguration$?.title || '-' }}</h4>\n\n @if (obs.widgetConfiguration?.actions?.length === 1) {\n <button\n *ngIf=\"canCreateCamundaExecution$ | async\"\n cdsButton=\"ghost\"\n (click)=\"onProcessStartClick(obs.widgetConfiguration?.actions[0])\"\n >\n {{ obs.widgetConfiguration?.actions[0].name }}\n </button>\n }\n </section>\n\n <valtimo-form-io [form]=\"obs.prefilledFormDefinition\"></valtimo-form-io>\n</div>\n", styles: [".formio-widget{padding:24px}.formio-widget__header{display:flex;align-items:center;justify-content:space-between}.formio-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px;margin-bottom:16px}\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"] }]
76
+ }], ctorParameters: () => [{ type: i1.DocumentService }, { type: i2.PermissionService }, { type: i3.FormService }, { type: i4.DossierWidgetsLayoutService }, { type: i5.WidgetsService }], propDecorators: { documentId: [{
63
77
  type: Input
64
78
  }], widgetConfiguration: [{
65
79
  type: Input
66
80
  }] } });
67
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-formio.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AACxE,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,EAAc,EAAE,EAAE,SAAS,EAAE,GAAG,EAAC,MAAM,MAAM,CAAC;AAIjG,OAAO,EAAC,YAAY,EAAC,MAAM,qBAAqB,CAAC;;;;;;AAUjD,MAAM,OAAO,qBAAqB;IAChC,IAAoB,UAAU,CAAC,KAAa;QAC1C,IAAI,KAAK;YAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC;IACD,IAAoB,mBAAmB,CAAC,KAAqC;QAC3E,IAAI,CAAC,KAAK;YAAE,OAAO;QACnB,IAAI,CAAC,aAAa,CAAC,yBAAyB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAID,IAAW,oBAAoB;QAC7B,OAAO,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IAC5E,CAAC;IAGD,IAAY,YAAY;QACtB,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3D,CAAC;IAmBD,YACmB,WAAwB,EACxB,aAA0C;QAD1C,gBAAW,GAAX,WAAW,CAAa;QACxB,kBAAa,GAAb,aAAa,CAA6B;QA9B5C,iCAA4B,GAC3C,IAAI,eAAe,CAAwC,IAAI,CAAC,CAAC;QAKlD,wBAAmB,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAKvD,6BAAwB,GAA2B,aAAa,CAAC;YAC/E,IAAI,CAAC,oBAAoB;YACzB,IAAI,CAAC,YAAY;SAClB,CAAC,CAAC,IAAI,CACL,SAAS,CAAC,CAAC,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,EAAE,CACjC,aAAa,CAAC;YACZ,IAAI,CAAC,WAAW,CAAC,gCAAgC,CAC/C,MAAM,CAAC,UAAU,CAAC,kBAAkB,EACpC,UAAU,CACX;YACD,EAAE,CAAC,MAAM,CAAC;SACX,CAAC,CACH,EACD,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,8BAA8B,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EACpF,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAC5B,CAAC;IAKC,CAAC;+GAzCO,qBAAqB;mGAArB,qBAAqB,mKClClC,y6BAqBA,40BDUY,YAAY,uLAAE,eAAe,8BAAE,YAAY;;4FAG1C,qBAAqB;kBARjC,SAAS;+BACE,uBAAuB,cAGrB,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,EAAE,YAAY,CAAC,mBACrC,uBAAuB,CAAC,MAAM;0HAG3B,UAAU;sBAA7B,KAAK;gBAGc,mBAAmB;sBAAtC,KAAK","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 {ChangeDetectionStrategy, Component, Input} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {FormioCaseWidgetWidgetWithUuid} from '../../../../../../models';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap, tap} from 'rxjs';\nimport {FormService} from '@valtimo/form';\nimport {DossierWidgetsLayoutService} from '../../../../../../services';\nimport {FormioForm} from '@formio/angular';\nimport {FormIoModule} from '@valtimo/components';\n\n@Component({\n  selector: 'valtimo-widget-formio',\n  templateUrl: './widget-formio.component.html',\n  styleUrls: ['./widget-formio.component.scss'],\n  standalone: true,\n  imports: [CommonModule, TranslateModule, FormIoModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetFormioComponent {\n  @Input() public set documentId(value: string) {\n    if (value) this._documentIdSubject$.next(value);\n  }\n  @Input() public set widgetConfiguration(value: FormioCaseWidgetWidgetWithUuid) {\n    if (!value) return;\n    this.layoutService.setWidgetWithExternalData(value.uuid);\n    this._widgetConfigurationSubject$.next(value);\n  }\n\n  private readonly _widgetConfigurationSubject$ =\n    new BehaviorSubject<FormioCaseWidgetWidgetWithUuid | null>(null);\n  public get widgetConfiguration$(): Observable<FormioCaseWidgetWidgetWithUuid> {\n    return this._widgetConfigurationSubject$.pipe(filter(config => !!config));\n  }\n\n  private readonly _documentIdSubject$ = new BehaviorSubject<string>('');\n  private get _documentId$(): Observable<string> {\n    return this._documentIdSubject$.pipe(filter(id => !!id));\n  }\n\n  public readonly prefilledFormDefinition$: Observable<FormioForm> = combineLatest([\n    this.widgetConfiguration$,\n    this._documentId$,\n  ]).pipe(\n    switchMap(([config, documentId]) =>\n      combineLatest([\n        this.formService.getFormDefinitionByNamePreFilled(\n          config.properties.formDefinitionName,\n          documentId\n        ),\n        of(config),\n      ])\n    ),\n    tap(([_, config]) => this.layoutService.setWidgetWithExternalDataReady(config.uuid)),\n    map(([formDef]) => formDef)\n  );\n\n  constructor(\n    private readonly formService: FormService,\n    private readonly layoutService: DossierWidgetsLayoutService\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=\"formio-widget\" *ngIf=\"prefilledFormDefinition$ | async as prefilledFormDefinition\">\n  <h4 class=\"formio-widget__title\">{{ (widgetConfiguration$ | async)?.title || '-' }}</h4>\n\n  <valtimo-form-io [form]=\"prefilledFormDefinition\"></valtimo-form-io>\n</div>\n"]}
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-formio.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.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 {ChangeDetectionStrategy, Component, Input} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CaseWidgetAction, FormioCaseWidgetWidgetWithUuid} from '../../../../../../models';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap, tap} from 'rxjs';\nimport {FormService} from '@valtimo/form';\nimport {DossierWidgetsLayoutService} from '../../../../../../services';\nimport {FormioForm} from '@formio/angular';\nimport {FormIoModule} from '@valtimo/components';\nimport {WidgetProcess} from '../widget-process/widget-process';\nimport {PermissionService} from '@valtimo/access-control';\nimport {DocumentService} from '@valtimo/document';\nimport {ButtonModule} from 'carbon-components-angular';\nimport {WidgetsService} from '../../widgets.service';\n\n@Component({\n  selector: 'valtimo-widget-formio',\n  templateUrl: './widget-formio.component.html',\n  styleUrls: ['./widget-formio.component.scss'],\n  standalone: true,\n  imports: [CommonModule, TranslateModule, FormIoModule, ButtonModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetFormioComponent extends WidgetProcess {\n  @Input() public set documentId(value: string) {\n    if (value) this._documentIdSubject$.next(value);\n  }\n  @Input() public set widgetConfiguration(value: FormioCaseWidgetWidgetWithUuid) {\n    if (!value) return;\n    this.layoutService.setWidgetWithExternalData(value.uuid);\n    this.baseWidgetConfiguration = value;\n    this._widgetConfigurationSubject$.next(value);\n  }\n\n  private readonly _widgetConfigurationSubject$ =\n    new BehaviorSubject<FormioCaseWidgetWidgetWithUuid | null>(null);\n  public get widgetConfiguration$(): Observable<FormioCaseWidgetWidgetWithUuid> {\n    return this._widgetConfigurationSubject$.pipe(filter(config => !!config));\n  }\n\n  private readonly _documentIdSubject$ = new BehaviorSubject<string>('');\n  private get _documentId$(): Observable<string> {\n    return this._documentIdSubject$.pipe(filter(id => !!id));\n  }\n\n  public readonly prefilledFormDefinition$: Observable<FormioForm> = combineLatest([\n    this.widgetConfiguration$,\n    this._documentId$,\n  ]).pipe(\n    switchMap(([config, documentId]) =>\n      combineLatest([\n        this.formService.getFormDefinitionByNamePreFilled(\n          config.properties.formDefinitionName,\n          documentId\n        ),\n        of(config),\n      ])\n    ),\n    tap(([_, config]) => this.layoutService.setWidgetWithExternalDataReady(config.uuid)),\n    map(([formDef]) => formDef)\n  );\n\n  constructor(\n    protected readonly documentService: DocumentService,\n    protected readonly permissionService: PermissionService,\n    private readonly formService: FormService,\n    private readonly layoutService: DossierWidgetsLayoutService,\n    private readonly widgetsService: WidgetsService\n  ) {\n    super(documentService, permissionService);\n  }\n\n  public onProcessStartClick(process: CaseWidgetAction): void {\n    this.widgetsService.startProcess(process.processDefinitionKey);\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\n  class=\"formio-widget\"\n  *ngIf=\"{\n    prefilledFormDefinition: prefilledFormDefinition$ | async,\n    widgetConfiguration: widgetConfiguration$ | async,\n  } as obs\"\n>\n  <section class=\"formio-widget__header\">\n    <h4 class=\"formio-widget__title\">{{ obs.widgetConfiguration$?.title || '-' }}</h4>\n\n    @if (obs.widgetConfiguration?.actions?.length === 1) {\n      <button\n        *ngIf=\"canCreateCamundaExecution$ | async\"\n        cdsButton=\"ghost\"\n        (click)=\"onProcessStartClick(obs.widgetConfiguration?.actions[0])\"\n      >\n        {{ obs.widgetConfiguration?.actions[0].name }}\n      </button>\n    }\n  </section>\n\n  <valtimo-form-io [form]=\"obs.prefilledFormDefinition\"></valtimo-form-io>\n</div>\n"]}
@@ -17,17 +17,22 @@ import { CommonModule } from '@angular/common';
17
17
  import { ChangeDetectionStrategy, Component, Input, signal, ViewEncapsulation, } from '@angular/core';
18
18
  import { TranslateModule } from '@ngx-translate/core';
19
19
  import { CarbonListModule, ViewType } from '@valtimo/components';
20
- import { PaginationModel, PaginationModule, TilesModule } from 'carbon-components-angular';
20
+ import { ButtonModule, PaginationModel, PaginationModule, TilesModule, } from 'carbon-components-angular';
21
21
  import { BehaviorSubject, combineLatest, filter, map, of, switchMap } from 'rxjs';
22
+ import { WidgetProcess } from '../widget-process/widget-process';
22
23
  import * as i0 from "@angular/core";
23
- import * as i1 from "../../../../../../services";
24
- import * as i2 from "@angular/common";
25
- import * as i3 from "@valtimo/components";
26
- import * as i4 from "carbon-components-angular";
27
- import * as i5 from "@ngx-translate/core";
28
- export class WidgetTableComponent {
24
+ import * as i1 from "@valtimo/document";
25
+ import * as i2 from "@valtimo/access-control";
26
+ import * as i3 from "../../../../../../services";
27
+ import * as i4 from "../../widgets.service";
28
+ import * as i5 from "@angular/common";
29
+ import * as i6 from "@valtimo/components";
30
+ import * as i7 from "carbon-components-angular";
31
+ import * as i8 from "@ngx-translate/core";
32
+ export class WidgetTableComponent extends WidgetProcess {
29
33
  set widgetConfiguration(value) {
30
34
  this._widgetConfiguration = value;
35
+ this.baseWidgetConfiguration = value;
31
36
  this.fields$.next(value.properties.columns.map((column, index) => ({
32
37
  key: column.key,
33
38
  label: column.title,
@@ -72,9 +77,13 @@ export class WidgetTableComponent {
72
77
  });
73
78
  this.cdr.detectChanges();
74
79
  }
75
- constructor(dossierWidgetsApiService, cdr) {
80
+ constructor(documentService, permissionService, dossierWidgetsApiService, cdr, widgetsService) {
81
+ super(documentService, permissionService);
82
+ this.documentService = documentService;
83
+ this.permissionService = permissionService;
76
84
  this.dossierWidgetsApiService = dossierWidgetsApiService;
77
85
  this.cdr = cdr;
86
+ this.widgetsService = widgetsService;
78
87
  this._initialNumberOfElementsSubject$ = new BehaviorSubject(null);
79
88
  this.showPagination$ = new BehaviorSubject(false);
80
89
  this._widgetData$ = new BehaviorSubject(null);
@@ -107,13 +116,23 @@ export class WidgetTableComponent {
107
116
  currentPage: page,
108
117
  }));
109
118
  }
110
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetTableComponent, deps: [{ token: i1.DossierWidgetsApiService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
111
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetTableComponent, isStandalone: true, selector: "valtimo-widget-table", inputs: { documentId: "documentId", tabKey: "tabKey", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, 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<cds-tile\n *ngIf=\"{\n fields: fields$ | async,\n widgetData: widgetData$ | async,\n } as obs\"\n class=\"valtimo-widget-table\"\n>\n <span class=\"widget-title\">{{ widgetConfiguration?.title }}</span>\n\n @if (obs.widgetData && obs.fields && obs.widgetData.length) {\n <section class=\"valtimo-widget-table__content\">\n <valtimo-carbon-list\n [header]=\"false\"\n [hideToolbar]=\"true\"\n [fields]=\"obs.fields\"\n [items]=\"obs.widgetData\"\n >\n </valtimo-carbon-list>\n\n <cds-pagination-nav\n *ngIf=\"paginationModel()\"\n class=\"valtimo-widget-table__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n </section>\n } @else {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n</cds-tile>\n", styles: [".valtimo-widget-table{padding:24px;display:flex;flex-direction:column;gap:16px}.valtimo-widget-table__content{display:flex;align-items:center;flex-direction:column}.valtimo-widget-table__content valtimo-carbon-list{width:100%}.valtimo-widget-table__pagination{padding:8px 0}.valtimo-widget-table .cds--data-table>thead{background:transparent!important}.valtimo-widget-table .cds--data-table td,.valtimo-widget-table .cds--data-table tr,.valtimo-widget-table .cds--data-table th{display:flex;width:100%}.valtimo-widget-table .cds--data-table td{white-space:nowrap;overflow:hidden}.valtimo-widget-table .cds--data-table td span{text-overflow:ellipsis;overflow:hidden}.valtimo-widget-table .cds--data-table tr{gap:16px}.valtimo-widget-table .cds--table-header-label>span{font-weight:400;font-size:12px;color:var(--cds-text-secondary)}.valtimo-widget-table--transparent{background:transparent!important}.valtimo-widget-table--title{border:none!important;font-style:italic}.valtimo-widget-table .widget-title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i3.CarbonListComponent, selector: "valtimo-carbon-list", inputs: ["items", "fields", "tableTranslations", "paginatorConfig", "pagination", "loading", "actions", "actionItems", "header", "hideColumnHeader", "initialSortState", "sortState", "isSearchable", "enableSingleSelection", "lastColumnTemplate", "paginationIdentifier", "showSelectionColumn", "striped", "hideToolbar", "lockedTooltipTranslationKey", "movingRowsEnabled", "dragAndDrop", "dragAndDropDisabled"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged", "moveRow", "itemsReordered"] }, { kind: "component", type: i3.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { 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: "component", type: i4.Tile, selector: "cds-tile, ibm-tile", inputs: ["theme"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
119
+ onProcessStartClick(process) {
120
+ this.widgetsService.startProcess(process.processDefinitionKey);
121
+ }
122
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetTableComponent, deps: [{ token: i1.DocumentService }, { token: i2.PermissionService }, { token: i3.DossierWidgetsApiService }, { token: i0.ChangeDetectorRef }, { token: i4.WidgetsService }], target: i0.ɵɵFactoryTarget.Component }); }
123
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetTableComponent, isStandalone: true, selector: "valtimo-widget-table", inputs: { documentId: "documentId", tabKey: "tabKey", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, usesInheritance: 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<cds-tile\n *ngIf=\"{\n fields: fields$ | async,\n widgetData: widgetData$ | async,\n } as obs\"\n class=\"valtimo-widget-table\"\n>\n <section class=\"valtimo-widget-table__header\">\n <span class=\"widget-title\">{{ widgetConfiguration?.title }}</span>\n\n @if (widgetConfiguration?.actions?.length === 1) {\n <button\n *ngIf=\"canCreateCamundaExecution$ | async\"\n cdsButton=\"ghost\"\n (click)=\"onProcessStartClick(widgetConfiguration?.actions[0])\"\n >\n {{ widgetConfiguration?.actions[0].name }}\n </button>\n }\n </section>\n\n @if (obs.widgetData && obs.fields && obs.widgetData.length) {\n <section class=\"valtimo-widget-table__content\">\n <valtimo-carbon-list\n [header]=\"false\"\n [hideToolbar]=\"true\"\n [fields]=\"obs.fields\"\n [items]=\"obs.widgetData\"\n >\n </valtimo-carbon-list>\n\n <cds-pagination-nav\n *ngIf=\"paginationModel()\"\n class=\"valtimo-widget-table__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n </section>\n } @else {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n</cds-tile>\n", styles: [".valtimo-widget-table{padding:24px;display:flex;flex-direction:column;gap:16px}.valtimo-widget-table__header{display:flex;align-items:center;justify-content:space-between}.valtimo-widget-table__content{display:flex;align-items:center;flex-direction:column}.valtimo-widget-table__content valtimo-carbon-list{width:100%}.valtimo-widget-table__pagination{padding:8px 0}.valtimo-widget-table .cds--data-table>thead{background:transparent!important}.valtimo-widget-table .cds--data-table td,.valtimo-widget-table .cds--data-table tr,.valtimo-widget-table .cds--data-table th{display:flex;width:100%}.valtimo-widget-table .cds--data-table td{white-space:nowrap;overflow:hidden}.valtimo-widget-table .cds--data-table td span{text-overflow:ellipsis;overflow:hidden}.valtimo-widget-table .cds--data-table tr{gap:16px}.valtimo-widget-table .cds--table-header-label>span{font-weight:400;font-size:12px;color:var(--cds-text-secondary)}.valtimo-widget-table--transparent{background:transparent!important}.valtimo-widget-table--title{border:none!important;font-style:italic}.valtimo-widget-table .widget-title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i6.CarbonListComponent, selector: "valtimo-carbon-list", inputs: ["items", "fields", "tableTranslations", "paginatorConfig", "pagination", "loading", "actions", "actionItems", "header", "hideColumnHeader", "initialSortState", "sortState", "isSearchable", "enableSingleSelection", "lastColumnTemplate", "paginationIdentifier", "showSelectionColumn", "striped", "hideToolbar", "lockedTooltipTranslationKey", "movingRowsEnabled", "dragAndDrop", "dragAndDropDisabled"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged", "moveRow", "itemsReordered"] }, { kind: "component", type: i6.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "ngmodule", type: PaginationModule }, { kind: "component", type: i7.PaginationNav, selector: "cds-pagination-nav, ibm-pagination-navm", inputs: ["model", "disabled", "numOfItemsToShow", "translations"], outputs: ["selectPage"] }, { kind: "ngmodule", type: TilesModule }, { kind: "component", type: i7.Tile, selector: "cds-tile, ibm-tile", inputs: ["theme"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i7.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
112
124
  }
113
125
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetTableComponent, decorators: [{
114
126
  type: Component,
115
- args: [{ selector: 'valtimo-widget-table', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [CommonModule, CarbonListModule, PaginationModule, TilesModule, TranslateModule], 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<cds-tile\n *ngIf=\"{\n fields: fields$ | async,\n widgetData: widgetData$ | async,\n } as obs\"\n class=\"valtimo-widget-table\"\n>\n <span class=\"widget-title\">{{ widgetConfiguration?.title }}</span>\n\n @if (obs.widgetData && obs.fields && obs.widgetData.length) {\n <section class=\"valtimo-widget-table__content\">\n <valtimo-carbon-list\n [header]=\"false\"\n [hideToolbar]=\"true\"\n [fields]=\"obs.fields\"\n [items]=\"obs.widgetData\"\n >\n </valtimo-carbon-list>\n\n <cds-pagination-nav\n *ngIf=\"paginationModel()\"\n class=\"valtimo-widget-table__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n </section>\n } @else {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n</cds-tile>\n", styles: [".valtimo-widget-table{padding:24px;display:flex;flex-direction:column;gap:16px}.valtimo-widget-table__content{display:flex;align-items:center;flex-direction:column}.valtimo-widget-table__content valtimo-carbon-list{width:100%}.valtimo-widget-table__pagination{padding:8px 0}.valtimo-widget-table .cds--data-table>thead{background:transparent!important}.valtimo-widget-table .cds--data-table td,.valtimo-widget-table .cds--data-table tr,.valtimo-widget-table .cds--data-table th{display:flex;width:100%}.valtimo-widget-table .cds--data-table td{white-space:nowrap;overflow:hidden}.valtimo-widget-table .cds--data-table td span{text-overflow:ellipsis;overflow:hidden}.valtimo-widget-table .cds--data-table tr{gap:16px}.valtimo-widget-table .cds--table-header-label>span{font-weight:400;font-size:12px;color:var(--cds-text-secondary)}.valtimo-widget-table--transparent{background:transparent!important}.valtimo-widget-table--title{border:none!important;font-style:italic}.valtimo-widget-table .widget-title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n"] }]
116
- }], ctorParameters: () => [{ type: i1.DossierWidgetsApiService }, { type: i0.ChangeDetectorRef }], propDecorators: { documentId: [{
127
+ args: [{ selector: 'valtimo-widget-table', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [
128
+ CommonModule,
129
+ CarbonListModule,
130
+ PaginationModule,
131
+ TilesModule,
132
+ TranslateModule,
133
+ ButtonModule,
134
+ ], 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<cds-tile\n *ngIf=\"{\n fields: fields$ | async,\n widgetData: widgetData$ | async,\n } as obs\"\n class=\"valtimo-widget-table\"\n>\n <section class=\"valtimo-widget-table__header\">\n <span class=\"widget-title\">{{ widgetConfiguration?.title }}</span>\n\n @if (widgetConfiguration?.actions?.length === 1) {\n <button\n *ngIf=\"canCreateCamundaExecution$ | async\"\n cdsButton=\"ghost\"\n (click)=\"onProcessStartClick(widgetConfiguration?.actions[0])\"\n >\n {{ widgetConfiguration?.actions[0].name }}\n </button>\n }\n </section>\n\n @if (obs.widgetData && obs.fields && obs.widgetData.length) {\n <section class=\"valtimo-widget-table__content\">\n <valtimo-carbon-list\n [header]=\"false\"\n [hideToolbar]=\"true\"\n [fields]=\"obs.fields\"\n [items]=\"obs.widgetData\"\n >\n </valtimo-carbon-list>\n\n <cds-pagination-nav\n *ngIf=\"paginationModel()\"\n class=\"valtimo-widget-table__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n </section>\n } @else {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n</cds-tile>\n", styles: [".valtimo-widget-table{padding:24px;display:flex;flex-direction:column;gap:16px}.valtimo-widget-table__header{display:flex;align-items:center;justify-content:space-between}.valtimo-widget-table__content{display:flex;align-items:center;flex-direction:column}.valtimo-widget-table__content valtimo-carbon-list{width:100%}.valtimo-widget-table__pagination{padding:8px 0}.valtimo-widget-table .cds--data-table>thead{background:transparent!important}.valtimo-widget-table .cds--data-table td,.valtimo-widget-table .cds--data-table tr,.valtimo-widget-table .cds--data-table th{display:flex;width:100%}.valtimo-widget-table .cds--data-table td{white-space:nowrap;overflow:hidden}.valtimo-widget-table .cds--data-table td span{text-overflow:ellipsis;overflow:hidden}.valtimo-widget-table .cds--data-table tr{gap:16px}.valtimo-widget-table .cds--table-header-label>span{font-weight:400;font-size:12px;color:var(--cds-text-secondary)}.valtimo-widget-table--transparent{background:transparent!important}.valtimo-widget-table--title{border:none!important;font-style:italic}.valtimo-widget-table .widget-title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n"] }]
135
+ }], ctorParameters: () => [{ type: i1.DocumentService }, { type: i2.PermissionService }, { type: i3.DossierWidgetsApiService }, { type: i0.ChangeDetectorRef }, { type: i4.WidgetsService }], propDecorators: { documentId: [{
117
136
  type: Input,
118
137
  args: [{ required: true }]
119
138
  }], tabKey: [{
@@ -126,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
126
145
  type: Input,
127
146
  args: [{ required: true }]
128
147
  }] } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-table.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACL,uBAAuB,EAEvB,SAAS,EACT,KAAK,EACL,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAiB,gBAAgB,EAAgB,QAAQ,EAAC,MAAM,qBAAqB,CAAC;AAE7F,OAAO,EAAC,eAAe,EAAE,gBAAgB,EAAE,WAAW,EAAC,MAAM,2BAA2B,CAAC;AACzF,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,EAAc,EAAE,EAAE,SAAS,EAAC,MAAM,MAAM,CAAC;;;;;;;AAa5F,MAAM,OAAO,oBAAoB;IAK/B,IAAoC,mBAAmB,CAAC,KAAsB;QAC5E,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAA6B,EAAE,KAAa,EAAE,EAAE,CAAC,CAAC;YAC9E,GAAG,EAAE,MAAM,CAAC,GAAG;YACf,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,QAAQ,EAAE,MAAM,CAAC,iBAAiB,EAAE,IAAI,IAAI,QAAQ,CAAC,IAAI;YACzD,SAAS,EAAE,qCAAqC,KAAK,KAAK,CAAC,IAAI,KAAK,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC,CAAC,6BAA6B,CAAC,CAAC,CAAC,EAAE,EAAE;YACzI,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,IAAI;gBAC5C,MAAM,EAAE,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC;aAC3C,CAAC;YACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,YAAY,CAAC,IAAI;gBAChD,UAAU,EAAE,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC;aACnD,CAAC;YACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,SAAS,CAAC,IAAI;gBAC7C,OAAO,EAAE,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC;aAC7C,CAAC;YACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,cAAc,CAAC,IAAI;gBAClD,YAAY,EAAE,MAAM,CAAC,iBAAiB,CAAC,cAAc,CAAC;aACvD,CAAC;YACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,IAAI;gBAC5C,MAAM,EAAE,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC;aAC3C,CAAC;SACH,CAAC,CAAC,CACJ,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IACD,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAID,IAAY,yBAAyB;QACnC,OAAO,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAC/C,MAAM,CAAC,gBAAgB,CAAC,EAAE,CAAC,gBAAgB,KAAK,IAAI,CAAC,CACtD,CAAC;IACJ,CAAC;IAKD,IAA6B,UAAU,CAAC,KAAkC;QACxE,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAC5D,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QACnE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAEtC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,KAAK,CAAC,UAAU,GAAG,CAAC;YAClB,CAAC,CAAC,IAAI;YACN,CAAC,CAAC;gBACE,WAAW,EAAE,CAAC;gBACd,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC;gBAC5D,UAAU,EAAE,KAAK,CAAC,IAAI;aACvB,CACN,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAuCD,YACmB,wBAAkD,EAClD,GAAsB;QADtB,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,QAAG,GAAH,GAAG,CAAmB;QArExB,qCAAgC,GAAG,IAAI,eAAe,CAAS,IAAI,CAAC,CAAC;QAQtE,oBAAe,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAE9D,iBAAY,GAAG,IAAI,eAAe,CAA0B,IAAI,CAAC,CAAC;QAoB1D,YAAO,GAAG,IAAI,eAAe,CAAiB,EAAE,CAAC,CAAC;QACjD,kBAAa,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC,CAAC;QAE1D,oBAAe,GAAG,MAAM,CAAkB,IAAI,eAAe,EAAE,CAAC,CAAC;QAEjE,gBAAW,GAAG,aAAa,CAAC;YAC1C,IAAI,CAAC,YAAY;YACjB,IAAI,CAAC,aAAa;YAClB,IAAI,CAAC,yBAAyB;SAC/B,CAAC,CAAC,IAAI,CACL,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,WAAW,EAAE,uBAAuB,CAAC,EAAE,EAAE,CACzD,aAAa,CAAC;YACZ,CAAC,WAAW;gBACV,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC;gBACV,CAAC,CAAC,IAAI,CAAC,wBAAwB;qBAC1B,aAAa,CACZ,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAC5B,WAAW,CACZ;qBACA,IAAI,CAAC,GAAG,CAAC,CAAC,GAAyB,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAC5D,EAAE,CAAC,uBAAuB,CAAC;SAC5B,CAAC,CACH,EACD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAC5B,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,uBAAuB,CAAC,EAAE,EAAE;YACvC,IAAI,KAAK,CAAC,MAAM,KAAK,uBAAuB,EAAE,CAAC;gBAC7C,OAAO,KAAK,CAAC;YACf,CAAC;YAED,MAAM,IAAI,GAAG,IAAI,KAAK,CAAS,uBAAuB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAEnE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QACpD,CAAC,CAAC,CACH,CAAC;IAKC,CAAC;IAEG,YAAY,CAAC,IAAY;QAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,IAAI,GAAG,CAAC,SAAS,IAAI,CAAC,eAAe,EAAE,CAAC,UAAU,EAAE,CAAC,CAAC;QACtF,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,KAAsB,EAAE,EAAE,CAAC,CAAC;YACvD,GAAG,KAAK;YACR,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC,CAAC;IACN,CAAC;+GAlHU,oBAAoB;mGAApB,oBAAoB,8MCzCjC,+nDAmDA,qnCDZY,YAAY,uLAAE,gBAAgB,w1BAAE,gBAAgB,8NAAE,WAAW,uHAAE,eAAe;;4FAE7E,oBAAoB;kBAThC,SAAS;+BACE,sBAAsB,mBAGf,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,cACzB,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,WAAW,EAAE,eAAe,CAAC;6HAGzD,UAAU;sBAAzC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBACS,MAAM;sBAArC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBAGa,mBAAmB;sBAAtD,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBA0CM,UAAU;sBAAtC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC","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 */\nimport {CommonModule} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  signal,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CarbonListItem, CarbonListModule, ColumnConfig, ViewType} from '@valtimo/components';\nimport {Page} from '@valtimo/config';\nimport {PaginationModel, PaginationModule, TilesModule} from 'carbon-components-angular';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap} from 'rxjs';\nimport {FieldsCaseWidgetValue, TableCaseWidget} from '../../../../../../models';\nimport {DossierWidgetsApiService} from '../../../../../../services';\n\n@Component({\n  selector: 'valtimo-widget-table',\n  templateUrl: './widget-table.component.html',\n  styleUrls: ['./widget-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [CommonModule, CarbonListModule, PaginationModule, TilesModule, TranslateModule],\n})\nexport class WidgetTableComponent {\n  @Input({required: true}) public documentId: string;\n  @Input({required: true}) public tabKey: string;\n\n  private _widgetConfiguration: TableCaseWidget;\n  @Input({required: true}) public set widgetConfiguration(value: TableCaseWidget) {\n    this._widgetConfiguration = value;\n    this.fields$.next(\n      value.properties.columns.map((column: FieldsCaseWidgetValue, index: number) => ({\n        key: column.key,\n        label: column.title,\n        viewType: column.displayProperties?.type ?? ViewType.TEXT,\n        className: `valtimo-widget-table--transparent ${index === 0 && value.properties.firstColumnAsTitle ? 'valtimo-widget-table--title' : ''}`,\n        ...(!!column.displayProperties?.['format'] && {\n          format: column.displayProperties['format'],\n        }),\n        ...(!!column.displayProperties?.['digitsInfo'] && {\n          digitsInfo: column.displayProperties['digitsInfo'],\n        }),\n        ...(!!column.displayProperties?.['display'] && {\n          display: column.displayProperties['display'],\n        }),\n        ...(!!column.displayProperties?.['currencyCode'] && {\n          currencyCode: column.displayProperties['currencyCode'],\n        }),\n        ...(!!column.displayProperties?.['values'] && {\n          values: column.displayProperties['values'],\n        }),\n      }))\n    );\n    this.cdr.detectChanges();\n  }\n  public get widgetConfiguration(): TableCaseWidget {\n    return this._widgetConfiguration;\n  }\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  public readonly showPagination$ = new BehaviorSubject<boolean>(false);\n\n  private _widgetData$ = new BehaviorSubject<CarbonListItem[] | null>(null);\n  @Input({required: true}) set widgetData(value: Page<CarbonListItem> | null) {\n    if (!value) return;\n\n    this.showPagination$.next(value.totalElements > value.size);\n    this._initialNumberOfElementsSubject$.next(value.numberOfElements);\n    this._widgetData$.next(value.content);\n\n    this.paginationModel.set(\n      value.totalPages < 2\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 fields$ = new BehaviorSubject<ColumnConfig[]>([]);\n  private readonly _queryParams$ = new BehaviorSubject<string | null>(null);\n\n  public readonly paginationModel = signal<PaginationModel>(new PaginationModel());\n\n  public readonly widgetData$ = combineLatest([\n    this._widgetData$,\n    this._queryParams$,\n    this._initialNumberOfElements$,\n  ]).pipe(\n    switchMap(([data, queryParams, initialNumberOfElements]) =>\n      combineLatest([\n        !queryParams\n          ? of(data)\n          : this.dossierWidgetsApiService\n              .getWidgetData(\n                this.documentId,\n                this.tabKey,\n                this.widgetConfiguration.key,\n                queryParams\n              )\n              .pipe(map((res: Page<CarbonListItem>) => 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] || {});\n    })\n  );\n\n  constructor(\n    private readonly dossierWidgetsApiService: DossierWidgetsApiService,\n    private readonly cdr: ChangeDetectorRef\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","<!--\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<cds-tile\n  *ngIf=\"{\n    fields: fields$ | async,\n    widgetData: widgetData$ | async,\n  } as obs\"\n  class=\"valtimo-widget-table\"\n>\n  <span class=\"widget-title\">{{ widgetConfiguration?.title }}</span>\n\n  @if (obs.widgetData && obs.fields && obs.widgetData.length) {\n    <section class=\"valtimo-widget-table__content\">\n      <valtimo-carbon-list\n        [header]=\"false\"\n        [hideToolbar]=\"true\"\n        [fields]=\"obs.fields\"\n        [items]=\"obs.widgetData\"\n      >\n      </valtimo-carbon-list>\n\n      <cds-pagination-nav\n        *ngIf=\"paginationModel()\"\n        class=\"valtimo-widget-table__pagination\"\n        [model]=\"paginationModel()\"\n        (selectPage)=\"onSelectPage($event)\"\n      >\n      </cds-pagination-nav>\n    </section>\n  } @else {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  }\n</cds-tile>\n"]}
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-table.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACL,uBAAuB,EAEvB,SAAS,EACT,KAAK,EACL,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAiB,gBAAgB,EAAgB,QAAQ,EAAC,MAAM,qBAAqB,CAAC;AAE7F,OAAO,EACL,YAAY,EACZ,eAAe,EACf,gBAAgB,EAChB,WAAW,GACZ,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,EAAc,EAAE,EAAE,SAAS,EAAC,MAAM,MAAM,CAAC;AAG5F,OAAO,EAAC,aAAa,EAAC,MAAM,kCAAkC,CAAC;;;;;;;;;;AAqB/D,MAAM,OAAO,oBAAqB,SAAQ,aAAa;IAKrD,IAAoC,mBAAmB,CAAC,KAAsB;QAC5E,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,uBAAuB,GAAG,KAAK,CAAC;QACrC,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAA6B,EAAE,KAAa,EAAE,EAAE,CAAC,CAAC;YAC9E,GAAG,EAAE,MAAM,CAAC,GAAG;YACf,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,QAAQ,EAAE,MAAM,CAAC,iBAAiB,EAAE,IAAI,IAAI,QAAQ,CAAC,IAAI;YACzD,SAAS,EAAE,qCAAqC,KAAK,KAAK,CAAC,IAAI,KAAK,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC,CAAC,6BAA6B,CAAC,CAAC,CAAC,EAAE,EAAE;YACzI,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,IAAI;gBAC5C,MAAM,EAAE,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC;aAC3C,CAAC;YACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,YAAY,CAAC,IAAI;gBAChD,UAAU,EAAE,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC;aACnD,CAAC;YACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,SAAS,CAAC,IAAI;gBAC7C,OAAO,EAAE,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC;aAC7C,CAAC;YACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,cAAc,CAAC,IAAI;gBAClD,YAAY,EAAE,MAAM,CAAC,iBAAiB,CAAC,cAAc,CAAC;aACvD,CAAC;YACF,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,IAAI;gBAC5C,MAAM,EAAE,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC;aAC3C,CAAC;SACH,CAAC,CAAC,CACJ,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IACD,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAID,IAAY,yBAAyB;QACnC,OAAO,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAC/C,MAAM,CAAC,gBAAgB,CAAC,EAAE,CAAC,gBAAgB,KAAK,IAAI,CAAC,CACtD,CAAC;IACJ,CAAC;IAKD,IAA6B,UAAU,CAAC,KAAkC;QACxE,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC;QAC5D,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QACnE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAEtC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,KAAK,CAAC,UAAU,GAAG,CAAC;YAClB,CAAC,CAAC,IAAI;YACN,CAAC,CAAC;gBACE,WAAW,EAAE,CAAC;gBACd,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC;gBAC5D,UAAU,EAAE,KAAK,CAAC,IAAI;aACvB,CACN,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAuCD,YACqB,eAAgC,EAChC,iBAAoC,EACtC,wBAAkD,EAClD,GAAsB,EACtB,cAA8B;QAE/C,KAAK,CAAC,eAAe,EAAE,iBAAiB,CAAC,CAAC;QANvB,oBAAe,GAAf,eAAe,CAAiB;QAChC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACtC,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,QAAG,GAAH,GAAG,CAAmB;QACtB,mBAAc,GAAd,cAAc,CAAgB;QAxEhC,qCAAgC,GAAG,IAAI,eAAe,CAAS,IAAI,CAAC,CAAC;QAQtE,oBAAe,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAE9D,iBAAY,GAAG,IAAI,eAAe,CAA0B,IAAI,CAAC,CAAC;QAoB1D,YAAO,GAAG,IAAI,eAAe,CAAiB,EAAE,CAAC,CAAC;QACjD,kBAAa,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC,CAAC;QAE1D,oBAAe,GAAG,MAAM,CAAkB,IAAI,eAAe,EAAE,CAAC,CAAC;QAEjE,gBAAW,GAAG,aAAa,CAAC;YAC1C,IAAI,CAAC,YAAY;YACjB,IAAI,CAAC,aAAa;YAClB,IAAI,CAAC,yBAAyB;SAC/B,CAAC,CAAC,IAAI,CACL,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,WAAW,EAAE,uBAAuB,CAAC,EAAE,EAAE,CACzD,aAAa,CAAC;YACZ,CAAC,WAAW;gBACV,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC;gBACV,CAAC,CAAC,IAAI,CAAC,wBAAwB;qBAC1B,aAAa,CACZ,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAC5B,WAAW,CACZ;qBACA,IAAI,CAAC,GAAG,CAAC,CAAC,GAAyB,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAC5D,EAAE,CAAC,uBAAuB,CAAC;SAC5B,CAAC,CACH,EACD,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAC5B,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,uBAAuB,CAAC,EAAE,EAAE;YACvC,IAAI,KAAK,CAAC,MAAM,KAAK,uBAAuB,EAAE,CAAC;gBAC7C,OAAO,KAAK,CAAC;YACf,CAAC;YAED,MAAM,IAAI,GAAG,IAAI,KAAK,CAAS,uBAAuB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAEnE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QACpD,CAAC,CAAC,CACH,CAAC;IAUF,CAAC;IAEM,YAAY,CAAC,IAAY;QAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,IAAI,GAAG,CAAC,SAAS,IAAI,CAAC,eAAe,EAAE,CAAC,UAAU,EAAE,CAAC,CAAC;QACtF,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,KAAsB,EAAE,EAAE,CAAC,CAAC;YACvD,GAAG,KAAK;YACR,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC,CAAC;IACN,CAAC;IAEM,mBAAmB,CAAC,OAAyB;QAClD,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;IACjE,CAAC;+GA5HU,oBAAoB;mGAApB,oBAAoB,qOCzDjC,8/DA+DA,itCDdI,YAAY,uLACZ,gBAAgB,w1BAChB,gBAAgB,8NAChB,WAAW,uHACX,eAAe,2FACf,YAAY;;4FAGH,oBAAoB;kBAhBhC,SAAS;+BACE,sBAAsB,mBAGf,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,cACzB,IAAI,WACP;wBACP,YAAY;wBACZ,gBAAgB;wBAChB,gBAAgB;wBAChB,WAAW;wBACX,eAAe;wBACf,YAAY;qBACb;wNAG+B,UAAU;sBAAzC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBACS,MAAM;sBAArC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBAGa,mBAAmB;sBAAtD,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBA2CM,UAAU;sBAAtC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC","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 */\nimport {CommonModule} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  signal,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CarbonListItem, CarbonListModule, ColumnConfig, ViewType} from '@valtimo/components';\nimport {Page} from '@valtimo/config';\nimport {\n  ButtonModule,\n  PaginationModel,\n  PaginationModule,\n  TilesModule,\n} from 'carbon-components-angular';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap} from 'rxjs';\nimport {CaseWidgetAction, FieldsCaseWidgetValue, TableCaseWidget} from '../../../../../../models';\nimport {DossierWidgetsApiService} from '../../../../../../services';\nimport {WidgetProcess} from '../widget-process/widget-process';\nimport {DocumentService} from '@valtimo/document';\nimport {PermissionService} from '@valtimo/access-control';\nimport {WidgetsService} from '../../widgets.service';\n\n@Component({\n  selector: 'valtimo-widget-table',\n  templateUrl: './widget-table.component.html',\n  styleUrls: ['./widget-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    CarbonListModule,\n    PaginationModule,\n    TilesModule,\n    TranslateModule,\n    ButtonModule,\n  ],\n})\nexport class WidgetTableComponent extends WidgetProcess {\n  @Input({required: true}) public documentId: string;\n  @Input({required: true}) public tabKey: string;\n\n  private _widgetConfiguration: TableCaseWidget;\n  @Input({required: true}) public set widgetConfiguration(value: TableCaseWidget) {\n    this._widgetConfiguration = value;\n    this.baseWidgetConfiguration = value;\n    this.fields$.next(\n      value.properties.columns.map((column: FieldsCaseWidgetValue, index: number) => ({\n        key: column.key,\n        label: column.title,\n        viewType: column.displayProperties?.type ?? ViewType.TEXT,\n        className: `valtimo-widget-table--transparent ${index === 0 && value.properties.firstColumnAsTitle ? 'valtimo-widget-table--title' : ''}`,\n        ...(!!column.displayProperties?.['format'] && {\n          format: column.displayProperties['format'],\n        }),\n        ...(!!column.displayProperties?.['digitsInfo'] && {\n          digitsInfo: column.displayProperties['digitsInfo'],\n        }),\n        ...(!!column.displayProperties?.['display'] && {\n          display: column.displayProperties['display'],\n        }),\n        ...(!!column.displayProperties?.['currencyCode'] && {\n          currencyCode: column.displayProperties['currencyCode'],\n        }),\n        ...(!!column.displayProperties?.['values'] && {\n          values: column.displayProperties['values'],\n        }),\n      }))\n    );\n    this.cdr.detectChanges();\n  }\n  public get widgetConfiguration(): TableCaseWidget {\n    return this._widgetConfiguration;\n  }\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  public readonly showPagination$ = new BehaviorSubject<boolean>(false);\n\n  private _widgetData$ = new BehaviorSubject<CarbonListItem[] | null>(null);\n  @Input({required: true}) set widgetData(value: Page<CarbonListItem> | null) {\n    if (!value) return;\n\n    this.showPagination$.next(value.totalElements > value.size);\n    this._initialNumberOfElementsSubject$.next(value.numberOfElements);\n    this._widgetData$.next(value.content);\n\n    this.paginationModel.set(\n      value.totalPages < 2\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 fields$ = new BehaviorSubject<ColumnConfig[]>([]);\n  private readonly _queryParams$ = new BehaviorSubject<string | null>(null);\n\n  public readonly paginationModel = signal<PaginationModel>(new PaginationModel());\n\n  public readonly widgetData$ = combineLatest([\n    this._widgetData$,\n    this._queryParams$,\n    this._initialNumberOfElements$,\n  ]).pipe(\n    switchMap(([data, queryParams, initialNumberOfElements]) =>\n      combineLatest([\n        !queryParams\n          ? of(data)\n          : this.dossierWidgetsApiService\n              .getWidgetData(\n                this.documentId,\n                this.tabKey,\n                this.widgetConfiguration.key,\n                queryParams\n              )\n              .pipe(map((res: Page<CarbonListItem>) => 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] || {});\n    })\n  );\n\n  constructor(\n    protected readonly documentService: DocumentService,\n    protected readonly permissionService: PermissionService,\n    private readonly dossierWidgetsApiService: DossierWidgetsApiService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly widgetsService: WidgetsService\n  ) {\n    super(documentService, permissionService);\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  public onProcessStartClick(process: CaseWidgetAction): void {\n    this.widgetsService.startProcess(process.processDefinitionKey);\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<cds-tile\n  *ngIf=\"{\n    fields: fields$ | async,\n    widgetData: widgetData$ | async,\n  } as obs\"\n  class=\"valtimo-widget-table\"\n>\n  <section class=\"valtimo-widget-table__header\">\n    <span class=\"widget-title\">{{ widgetConfiguration?.title }}</span>\n\n    @if (widgetConfiguration?.actions?.length === 1) {\n      <button\n        *ngIf=\"canCreateCamundaExecution$ | async\"\n        cdsButton=\"ghost\"\n        (click)=\"onProcessStartClick(widgetConfiguration?.actions[0])\"\n      >\n        {{ widgetConfiguration?.actions[0].name }}\n      </button>\n    }\n  </section>\n\n  @if (obs.widgetData && obs.fields && obs.widgetData.length) {\n    <section class=\"valtimo-widget-table__content\">\n      <valtimo-carbon-list\n        [header]=\"false\"\n        [hideToolbar]=\"true\"\n        [fields]=\"obs.fields\"\n        [items]=\"obs.widgetData\"\n      >\n      </valtimo-carbon-list>\n\n      <cds-pagination-nav\n        *ngIf=\"paginationModel()\"\n        class=\"valtimo-widget-table__pagination\"\n        [model]=\"paginationModel()\"\n        (selectPage)=\"onSelectPage($event)\"\n      >\n      </cds-pagination-nav>\n    </section>\n  } @else {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  }\n</cds-tile>\n"]}