@valtimo/dossier 12.6.0 → 12.7.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 (41) hide show
  1. package/esm2022/lib/components/dossier-detail/dossier-detail.component.mjs +26 -16
  2. package/esm2022/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.mjs +26 -13
  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 +33 -11
  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-process-start-modal/dossier-process-start-modal.component.mjs +38 -6
  12. package/esm2022/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +40 -5
  13. package/esm2022/lib/models/case-widget.model.mjs +1 -1
  14. package/fesm2022/valtimo-dossier.mjs +331 -115
  15. package/fesm2022/valtimo-dossier.mjs.map +1 -1
  16. package/lib/components/dossier-detail/dossier-detail.component.d.ts +4 -1
  17. package/lib/components/dossier-detail/dossier-detail.component.d.ts.map +1 -1
  18. package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts +11 -3
  19. package/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.d.ts.map +1 -1
  20. package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts +12 -4
  21. package/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.d.ts.map +1 -1
  22. package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts +14 -4
  23. package/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.d.ts.map +1 -1
  24. package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts +11 -3
  25. package/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.d.ts.map +1 -1
  26. package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts +11 -3
  27. package/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.d.ts.map +1 -1
  28. package/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.d.ts +13 -0
  29. package/lib/components/dossier-detail/tab/widgets/components/widget-process/widget-process.d.ts.map +1 -0
  30. package/lib/components/dossier-detail/tab/widgets/widgets.component.d.ts.map +1 -1
  31. package/lib/components/dossier-detail/tab/widgets/widgets.permissions.d.ts +8 -0
  32. package/lib/components/dossier-detail/tab/widgets/widgets.permissions.d.ts.map +1 -0
  33. package/lib/components/dossier-detail/tab/widgets/widgets.service.d.ts +16 -0
  34. package/lib/components/dossier-detail/tab/widgets/widgets.service.d.ts.map +1 -0
  35. package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +8 -3
  36. package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
  37. package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts +8 -3
  38. package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -1
  39. package/lib/models/case-widget.model.d.ts +6 -1
  40. package/lib/models/case-widget.model.d.ts.map +1 -1
  41. package/package.json +1 -1
@@ -15,21 +15,26 @@
15
15
  */
16
16
  import { ChangeDetectionStrategy, Component, HostBinding, Input, signal, ViewChild, ViewEncapsulation, } from '@angular/core';
17
17
  import { CommonModule } from '@angular/common';
18
- import { InputModule, PaginationModel, PaginationModule, TilesModule, } from 'carbon-components-angular';
18
+ import { ButtonModule, InputModule, PaginationModel, PaginationModule, TilesModule, } from 'carbon-components-angular';
19
19
  import { CaseWidgetDisplayTypeKey, } from '../../../../../../models';
20
20
  import { BehaviorSubject, combineLatest, filter, map, of, switchMap, tap } from 'rxjs';
21
21
  import { CarbonListModule } from '@valtimo/components';
22
22
  import { TranslateModule } from '@ngx-translate/core';
23
+ import { WidgetProcess } from '../widget-process/widget-process';
23
24
  import * as i0 from "@angular/core";
24
- import * as i1 from "@valtimo/components";
25
- import * as i2 from "../../../../../../services";
26
- import * as i3 from "@angular/common";
27
- import * as i4 from "carbon-components-angular";
28
- import * as i5 from "@ngx-translate/core";
29
- export class WidgetCollectionComponent {
25
+ import * as i1 from "@valtimo/document";
26
+ import * as i2 from "@valtimo/access-control";
27
+ import * as i3 from "@valtimo/components";
28
+ import * as i4 from "../../../../../../services";
29
+ import * as i5 from "../../widgets.service";
30
+ import * as i6 from "@angular/common";
31
+ import * as i7 from "carbon-components-angular";
32
+ import * as i8 from "@ngx-translate/core";
33
+ export class WidgetCollectionComponent extends WidgetProcess {
30
34
  set widgetConfiguration(value) {
31
35
  if (!value)
32
36
  return;
37
+ this.baseWidgetConfiguration = value;
33
38
  this.widgetConfiguration$.next(value);
34
39
  }
35
40
  get _initialNumberOfElements$() {
@@ -50,10 +55,14 @@ export class WidgetCollectionComponent {
50
55
  });
51
56
  this.cdr.detectChanges();
52
57
  }
53
- constructor(viewContentService, cdr, widgetApiService) {
58
+ constructor(documentService, permissionService, viewContentService, cdr, widgetApiService, widgetsService) {
59
+ super(documentService, permissionService);
60
+ this.documentService = documentService;
61
+ this.permissionService = permissionService;
54
62
  this.viewContentService = viewContentService;
55
63
  this.cdr = cdr;
56
64
  this.widgetApiService = widgetApiService;
65
+ this.widgetsService = widgetsService;
57
66
  this.class = 'valtimo-widget-collection';
58
67
  this.showPagination$ = new BehaviorSubject(false);
59
68
  this._initialNumberOfElementsSubject$ = new BehaviorSubject(null);
@@ -108,6 +117,9 @@ export class WidgetCollectionComponent {
108
117
  currentPage: page,
109
118
  }));
110
119
  }
120
+ onProcessStartClick(process) {
121
+ this.widgetsService.startProcess(process.processDefinitionKey);
122
+ }
111
123
  getCardField(field, data) {
112
124
  const resolvedValue = this.viewContentService.get(data.fields[field.key], {
113
125
  ...field.displayProperties,
@@ -159,8 +171,8 @@ export class WidgetCollectionComponent {
159
171
  }
160
172
  return '-';
161
173
  }
162
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetCollectionComponent, deps: [{ token: i1.ViewContentService }, { token: i0.ChangeDetectorRef }, { token: i2.DossierWidgetsApiService }], target: i0.ɵɵFactoryTarget.Component }); }
163
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetCollectionComponent, isStandalone: true, selector: "valtimo-widget-collection", inputs: { documentId: "documentId", tabKey: "tabKey", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_widgetCollectionRef", first: true, predicate: ["widgetCollection"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async,\n } as obs\"\n>\n <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n <div\n #widgetCollection\n [ngClass]=\"{\n 'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n 'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n 'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n 'valtimo-widget-collection__container': amountOfColumns() === 4,\n }\"\n >\n @for (card of obs?.collectionWidgetCards; track card.key) {\n <div\n class=\"valtimo-widget-collection__card\"\n [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n >\n <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n @for (field of card.fields; track field.key) {\n <div\n [ngClass]=\"{\n 'valtimo-widget-collection__full-width-input': field?.width === 'full',\n 'valtimo-widget-collection__half-width-input': field?.width === 'half',\n }\"\n >\n <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n {{ field?.title }}\n\n <input\n [value]=\"field?.value\"\n [readonly]=\"true\"\n class=\"valtimo-widget-collection__card-input\"\n cdsText\n />\n </cds-label>\n </div>\n }\n </div>\n }\n </div>\n\n @if (!obs?.collectionWidgetCards?.length) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n\n <cds-pagination-nav\n *ngIf=\"paginationModel() && (showPagination$ | async)\"\n class=\"valtimo-widget-collection__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n</ng-container>\n", styles: [".valtimo-widget-collection{padding:24px}.valtimo-widget-collection .cds--label{overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-widget-collection__container{display:flex;column-gap:16px}.valtimo-widget-collection,.valtimo-widget-collection__column{display:flex;flex-direction:column;width:100%;overflow:hidden}.valtimo-widget-collection__card{margin-top:16px;display:flex;flex-flow:row wrap;background-color:var(--cds-background);padding:16px;width:100%;gap:16px}.valtimo-widget-collection__card--hidden{visibility:hidden}.valtimo-widget-collection__card-title{color:var(--cds-text-primary);font-weight:500;font-size:14px;line-height:22px;font-style:italic;width:100%}.valtimo-widget-collection__card-input{background:transparent}.valtimo-widget-collection__full-width-input{width:100%}.valtimo-widget-collection__half-width-input{width:calc(50% - 16px);box-sizing:border-box}.valtimo-widget-collection__pagination{padding:8px 0;display:flex;justify-content:center}.valtimo-widget-collection__render-vertically,.valtimo-widget-collection__render-two-columns,.valtimo-widget-collection__render-three-columns{grid-gap:16px;align-items:stretch;overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__render-vertically{display:flex!important}.valtimo-widget-collection__render-two-columns{grid-template-columns:repeat(2,1fr)}.valtimo-widget-collection__render-three-columns{grid-template-columns:repeat(3,1fr)}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i4.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i4.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "ngmodule", type: PaginationModule }, { kind: "component", type: i4.PaginationNav, selector: "cds-pagination-nav, ibm-pagination-navm", inputs: ["model", "disabled", "numOfItemsToShow", "translations"], outputs: ["selectPage"] }, { kind: "ngmodule", type: TilesModule }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i1.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
174
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetCollectionComponent, deps: [{ token: i1.DocumentService }, { token: i2.PermissionService }, { token: i3.ViewContentService }, { token: i0.ChangeDetectorRef }, { token: i4.DossierWidgetsApiService }, { token: i5.WidgetsService }], target: i0.ɵɵFactoryTarget.Component }); }
175
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetCollectionComponent, isStandalone: true, selector: "valtimo-widget-collection", inputs: { documentId: "documentId", tabKey: "tabKey", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_widgetCollectionRef", first: true, predicate: ["widgetCollection"], descendants: true }], 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 collectionWidgetCards: collectionWidgetCards$ | async,\n } as obs\"\n>\n <section class=\"valtimo-widget-collection__header\">\n <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\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 <div\n #widgetCollection\n [ngClass]=\"{\n 'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n 'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n 'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n 'valtimo-widget-collection__container': amountOfColumns() === 4,\n }\"\n >\n @for (card of obs?.collectionWidgetCards; track card.key) {\n <div\n class=\"valtimo-widget-collection__card\"\n [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n >\n <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n @for (field of card.fields; track field.key) {\n <div\n [ngClass]=\"{\n 'valtimo-widget-collection__full-width-input': field?.width === 'full',\n 'valtimo-widget-collection__half-width-input': field?.width === 'half',\n }\"\n >\n <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n {{ field?.title }}\n\n <input\n [value]=\"field?.value\"\n [readonly]=\"true\"\n class=\"valtimo-widget-collection__card-input\"\n cdsText\n />\n </cds-label>\n </div>\n }\n </div>\n }\n </div>\n\n @if (!obs?.collectionWidgetCards?.length) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n\n <cds-pagination-nav\n *ngIf=\"paginationModel() && (showPagination$ | async)\"\n class=\"valtimo-widget-collection__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n</ng-container>\n", styles: [".valtimo-widget-collection{padding:24px}.valtimo-widget-collection .cds--label{overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__header{display:flex;align-items:center;justify-content:space-between}.valtimo-widget-collection__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-widget-collection__container{display:flex;column-gap:16px}.valtimo-widget-collection,.valtimo-widget-collection__column{display:flex;flex-direction:column;width:100%;overflow:hidden}.valtimo-widget-collection__card{margin-top:16px;display:flex;flex-flow:row wrap;background-color:var(--cds-background);padding:16px;width:100%;gap:16px}.valtimo-widget-collection__card--hidden{visibility:hidden}.valtimo-widget-collection__card-title{color:var(--cds-text-primary);font-weight:500;font-size:14px;line-height:22px;font-style:italic;width:100%}.valtimo-widget-collection__card-input{background:transparent}.valtimo-widget-collection__full-width-input{width:100%}.valtimo-widget-collection__half-width-input{width:calc(50% - 16px);box-sizing:border-box}.valtimo-widget-collection__pagination{padding:8px 0;display:flex;justify-content:center}.valtimo-widget-collection__render-vertically,.valtimo-widget-collection__render-two-columns,.valtimo-widget-collection__render-three-columns{grid-gap:16px;align-items:stretch;overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__render-vertically{display:flex!important}.valtimo-widget-collection__render-two-columns{grid-template-columns:repeat(2,1fr)}.valtimo-widget-collection__render-three-columns{grid-template-columns:repeat(3,1fr)}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: 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: "component", type: i7.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i7.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { 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: "ngmodule", type: CarbonListModule }, { kind: "component", type: i3.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { 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 }); }
164
176
  }
165
177
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetCollectionComponent, decorators: [{
166
178
  type: Component,
@@ -171,8 +183,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
171
183
  TilesModule,
172
184
  CarbonListModule,
173
185
  TranslateModule,
174
- ], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async,\n } as obs\"\n>\n <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n <div\n #widgetCollection\n [ngClass]=\"{\n 'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n 'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n 'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n 'valtimo-widget-collection__container': amountOfColumns() === 4,\n }\"\n >\n @for (card of obs?.collectionWidgetCards; track card.key) {\n <div\n class=\"valtimo-widget-collection__card\"\n [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n >\n <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n @for (field of card.fields; track field.key) {\n <div\n [ngClass]=\"{\n 'valtimo-widget-collection__full-width-input': field?.width === 'full',\n 'valtimo-widget-collection__half-width-input': field?.width === 'half',\n }\"\n >\n <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n {{ field?.title }}\n\n <input\n [value]=\"field?.value\"\n [readonly]=\"true\"\n class=\"valtimo-widget-collection__card-input\"\n cdsText\n />\n </cds-label>\n </div>\n }\n </div>\n }\n </div>\n\n @if (!obs?.collectionWidgetCards?.length) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n\n <cds-pagination-nav\n *ngIf=\"paginationModel() && (showPagination$ | async)\"\n class=\"valtimo-widget-collection__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n</ng-container>\n", styles: [".valtimo-widget-collection{padding:24px}.valtimo-widget-collection .cds--label{overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-widget-collection__container{display:flex;column-gap:16px}.valtimo-widget-collection,.valtimo-widget-collection__column{display:flex;flex-direction:column;width:100%;overflow:hidden}.valtimo-widget-collection__card{margin-top:16px;display:flex;flex-flow:row wrap;background-color:var(--cds-background);padding:16px;width:100%;gap:16px}.valtimo-widget-collection__card--hidden{visibility:hidden}.valtimo-widget-collection__card-title{color:var(--cds-text-primary);font-weight:500;font-size:14px;line-height:22px;font-style:italic;width:100%}.valtimo-widget-collection__card-input{background:transparent}.valtimo-widget-collection__full-width-input{width:100%}.valtimo-widget-collection__half-width-input{width:calc(50% - 16px);box-sizing:border-box}.valtimo-widget-collection__pagination{padding:8px 0;display:flex;justify-content:center}.valtimo-widget-collection__render-vertically,.valtimo-widget-collection__render-two-columns,.valtimo-widget-collection__render-three-columns{grid-gap:16px;align-items:stretch;overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__render-vertically{display:flex!important}.valtimo-widget-collection__render-two-columns{grid-template-columns:repeat(2,1fr)}.valtimo-widget-collection__render-three-columns{grid-template-columns:repeat(3,1fr)}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
175
- }], ctorParameters: () => [{ type: i1.ViewContentService }, { type: i0.ChangeDetectorRef }, { type: i2.DossierWidgetsApiService }], propDecorators: { class: [{
186
+ ButtonModule,
187
+ ], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async,\n } as obs\"\n>\n <section class=\"valtimo-widget-collection__header\">\n <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\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 <div\n #widgetCollection\n [ngClass]=\"{\n 'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n 'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n 'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n 'valtimo-widget-collection__container': amountOfColumns() === 4,\n }\"\n >\n @for (card of obs?.collectionWidgetCards; track card.key) {\n <div\n class=\"valtimo-widget-collection__card\"\n [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n >\n <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n @for (field of card.fields; track field.key) {\n <div\n [ngClass]=\"{\n 'valtimo-widget-collection__full-width-input': field?.width === 'full',\n 'valtimo-widget-collection__half-width-input': field?.width === 'half',\n }\"\n >\n <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n {{ field?.title }}\n\n <input\n [value]=\"field?.value\"\n [readonly]=\"true\"\n class=\"valtimo-widget-collection__card-input\"\n cdsText\n />\n </cds-label>\n </div>\n }\n </div>\n }\n </div>\n\n @if (!obs?.collectionWidgetCards?.length) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n\n <cds-pagination-nav\n *ngIf=\"paginationModel() && (showPagination$ | async)\"\n class=\"valtimo-widget-collection__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n</ng-container>\n", styles: [".valtimo-widget-collection{padding:24px}.valtimo-widget-collection .cds--label{overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__header{display:flex;align-items:center;justify-content:space-between}.valtimo-widget-collection__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-widget-collection__container{display:flex;column-gap:16px}.valtimo-widget-collection,.valtimo-widget-collection__column{display:flex;flex-direction:column;width:100%;overflow:hidden}.valtimo-widget-collection__card{margin-top:16px;display:flex;flex-flow:row wrap;background-color:var(--cds-background);padding:16px;width:100%;gap:16px}.valtimo-widget-collection__card--hidden{visibility:hidden}.valtimo-widget-collection__card-title{color:var(--cds-text-primary);font-weight:500;font-size:14px;line-height:22px;font-style:italic;width:100%}.valtimo-widget-collection__card-input{background:transparent}.valtimo-widget-collection__full-width-input{width:100%}.valtimo-widget-collection__half-width-input{width:calc(50% - 16px);box-sizing:border-box}.valtimo-widget-collection__pagination{padding:8px 0;display:flex;justify-content:center}.valtimo-widget-collection__render-vertically,.valtimo-widget-collection__render-two-columns,.valtimo-widget-collection__render-three-columns{grid-gap:16px;align-items:stretch;overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__render-vertically{display:flex!important}.valtimo-widget-collection__render-two-columns{grid-template-columns:repeat(2,1fr)}.valtimo-widget-collection__render-three-columns{grid-template-columns:repeat(3,1fr)}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
188
+ }], ctorParameters: () => [{ type: i1.DocumentService }, { type: i2.PermissionService }, { type: i3.ViewContentService }, { type: i0.ChangeDetectorRef }, { type: i4.DossierWidgetsApiService }, { type: i5.WidgetsService }], propDecorators: { class: [{
176
189
  type: HostBinding,
177
190
  args: ['class']
178
191
  }], _widgetCollectionRef: [{
@@ -189,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
189
202
  }], widgetData: [{
190
203
  type: Input
191
204
  }] } });
192
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-collection.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {\n  InputModule,\n  PaginationModel,\n  PaginationModule,\n  TilesModule,\n} from 'carbon-components-angular';\nimport {\n  CaseWidgetDisplayTypeKey,\n  CollectionCaseWidget,\n  CollectionCaseWidgetCardData,\n  CollectionCaseWidgetField,\n  CollectionCaseWidgetTitle,\n  CollectionWidgetResolvedField,\n} from '../../../../../../models';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap, tap} from 'rxjs';\nimport {CarbonListModule, ViewContentService} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Page} from '@valtimo/config';\nimport {DossierWidgetsApiService} from '../../../../../../services';\n\n@Component({\n  selector: 'valtimo-widget-collection',\n  templateUrl: './widget-collection.component.html',\n  styleUrls: ['./widget-collection.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    InputModule,\n    PaginationModule,\n    TilesModule,\n    CarbonListModule,\n    TranslateModule,\n  ],\n})\nexport class WidgetCollectionComponent implements AfterViewInit, OnDestroy {\n  @HostBinding('class') public readonly class = 'valtimo-widget-collection';\n  @ViewChild('widgetCollection') private _widgetCollectionRef: ElementRef<HTMLDivElement>;\n\n  @Input({required: true}) public documentId: string;\n  @Input({required: true}) public tabKey: string;\n  @Input() public set widgetConfiguration(value: CollectionCaseWidget) {\n    if (!value) return;\n    this.widgetConfiguration$.next(value);\n  }\n  public readonly showPagination$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _initialNumberOfElementsSubject$ = new BehaviorSubject<number>(null);\n\n  private get _initialNumberOfElements$(): Observable<number> {\n    return this._initialNumberOfElementsSubject$.pipe(\n      filter(numberOfElements => numberOfElements !== null)\n    );\n  }\n\n  @Input() public set widgetData(value: Page<CollectionCaseWidgetCardData> | null) {\n    if (!value) return;\n\n    this.showPagination$.next(value.totalElements > value.size);\n    this._initialNumberOfElementsSubject$.next(value.numberOfElements);\n    this._widgetDataSubject$.next(value.content);\n\n    this.paginationModel.set(\n      value.totalPages < 0\n        ? null\n        : {\n            currentPage: 1,\n            totalDataLength: Math.ceil(value.totalElements / value.size),\n            pageLength: value.size,\n          }\n    );\n    this.cdr.detectChanges();\n  }\n\n  public readonly widgetTitle = signal('-');\n\n  public readonly widgetConfiguration$ = new BehaviorSubject<CollectionCaseWidget | null>(null);\n  public readonly paginationModel = signal<PaginationModel>(new PaginationModel());\n  public readonly amountOfColumns = signal(0);\n\n  private readonly _widgetDataSubject$ = new BehaviorSubject<CollectionCaseWidgetCardData[]>(null);\n\n  private readonly _queryParams$ = new BehaviorSubject<string | null>(null);\n\n  private readonly _widgetData$: Observable<CollectionCaseWidgetCardData[]> = combineLatest([\n    this._widgetDataSubject$,\n    this._queryParams$,\n    this._initialNumberOfElements$,\n    this.widgetConfiguration$,\n  ]).pipe(\n    switchMap(([data, queryParams, initialNumberOfElements, widgetConfiguration]) =>\n      combineLatest([\n        !queryParams\n          ? of(data)\n          : this.widgetApiService\n              .getWidgetData(this.documentId, this.tabKey, widgetConfiguration.key, queryParams)\n              .pipe(map((res: Page<CollectionCaseWidgetCardData>) => res.content)),\n        of(initialNumberOfElements),\n      ])\n    ),\n    filter(([items]) => !!items),\n    map(([items, initialNumberOfElements]) => {\n      if (items.length === initialNumberOfElements) {\n        return items;\n      }\n\n      const rows = new Array<number>(initialNumberOfElements).fill(null);\n\n      return rows.map((_, index) => items[index] || {...items[0], hidden: true});\n    })\n  );\n\n  public readonly collectionWidgetCards$: Observable<\n    {title: string; fields: CollectionWidgetResolvedField[]; key: number; hidden: boolean}[]\n  > = combineLatest([this.widgetConfiguration$, this._widgetData$]).pipe(\n    filter(([widgetConfig, widgetData]) => !!widgetConfig && !!widgetData),\n    tap(([widgetConfig]) => this.widgetTitle.set(widgetConfig.title)),\n    map(([widgetConfig, widgetData]) =>\n      widgetData.map((cardData, index) => ({\n        hidden: cardData.hidden,\n        key: index,\n        title: this.getCardTitle({\n          value: cardData.title,\n          displayProperties: widgetConfig?.properties?.title?.displayProperties,\n        }),\n        fields: widgetConfig?.properties.fields.reduce(\n          (cardFieldsAccumulator, currentField) => [\n            ...cardFieldsAccumulator,\n            this.getCardField(currentField, cardData),\n          ],\n          []\n        ),\n      }))\n    )\n  );\n\n  private _observer!: ResizeObserver;\n\n  constructor(\n    private readonly viewContentService: ViewContentService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly widgetApiService: DossierWidgetsApiService\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this.openWidthObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._observer?.disconnect();\n  }\n\n  public onSelectPage(page: number): void {\n    this._queryParams$.next(`page=${page - 1}&size=${this.paginationModel().pageLength}`);\n    this.paginationModel.update((model: PaginationModel) => ({\n      ...model,\n      currentPage: page,\n    }));\n  }\n\n  private getCardField(\n    field: CollectionCaseWidgetField,\n    data: CollectionCaseWidgetCardData\n  ): CollectionWidgetResolvedField {\n    const resolvedValue = this.viewContentService.get(data.fields[field.key], {\n      ...field.displayProperties,\n      viewType: field.displayProperties?.type ?? CaseWidgetDisplayTypeKey.TEXT,\n    });\n\n    return {\n      key: field.key,\n      title: field.title,\n      width: field.width,\n      value: resolvedValue || data.fields[field.key],\n    };\n  }\n\n  private openWidthObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetCollectionRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const elementWidth = event[0]?.borderBoxSize[0]?.inlineSize;\n\n    if (typeof elementWidth === 'number' && elementWidth !== 0) {\n      if (elementWidth < 640) {\n        this.amountOfColumns.set(1);\n      } else if (elementWidth > 640 && elementWidth <= 768) {\n        this.amountOfColumns.set(2);\n      } else if (elementWidth > 768 && elementWidth <= 1080) {\n        this.amountOfColumns.set(3);\n      } else if (elementWidth > 1080) {\n        this.amountOfColumns.set(4);\n      }\n    }\n  }\n\n  private getCardTitle(collectionCaseWidgetTitle: CollectionCaseWidgetTitle): string {\n    const widgetTitleValue = collectionCaseWidgetTitle.value;\n    const widgetTitleDisplayProperties = collectionCaseWidgetTitle.displayProperties;\n\n    if (!widgetTitleDisplayProperties && widgetTitleValue) {\n      return widgetTitleValue;\n    } else if (widgetTitleDisplayProperties && widgetTitleValue) {\n      const convertedTitle = this.viewContentService.get(widgetTitleValue, {\n        ...widgetTitleDisplayProperties,\n        viewType: widgetTitleDisplayProperties.type,\n      });\n\n      if (convertedTitle) return convertedTitle;\n    }\n\n    return '-';\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    widgetConfiguration: widgetConfiguration$ | async,\n    collectionWidgetCards: collectionWidgetCards$ | async,\n  } as obs\"\n>\n  <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n  <div\n    #widgetCollection\n    [ngClass]=\"{\n      'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n      'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n      'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n      'valtimo-widget-collection__container': amountOfColumns() === 4,\n    }\"\n  >\n    @for (card of obs?.collectionWidgetCards; track card.key) {\n      <div\n        class=\"valtimo-widget-collection__card\"\n        [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n      >\n        <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n        @for (field of card.fields; track field.key) {\n          <div\n            [ngClass]=\"{\n              'valtimo-widget-collection__full-width-input': field?.width === 'full',\n              'valtimo-widget-collection__half-width-input': field?.width === 'half',\n            }\"\n          >\n            <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n              {{ field?.title }}\n\n              <input\n                [value]=\"field?.value\"\n                [readonly]=\"true\"\n                class=\"valtimo-widget-collection__card-input\"\n                cdsText\n              />\n            </cds-label>\n          </div>\n        }\n      </div>\n    }\n  </div>\n\n  @if (!obs?.collectionWidgetCards?.length) {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  }\n\n  <cds-pagination-nav\n    *ngIf=\"paginationModel() && (showPagination$ | async)\"\n    class=\"valtimo-widget-collection__pagination\"\n    [model]=\"paginationModel()\"\n    (selectPage)=\"onSelectPage($event)\"\n  >\n  </cds-pagination-nav>\n</ng-container>\n"]}
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-collection.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EAET,WAAW,EACX,KAAK,EAEL,MAAM,EACN,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACL,YAAY,EACZ,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,WAAW,GACZ,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAEL,wBAAwB,GAMzB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,EAAc,EAAE,EAAE,SAAS,EAAE,GAAG,EAAC,MAAM,MAAM,CAAC;AACjG,OAAO,EAAC,gBAAgB,EAAqB,MAAM,qBAAqB,CAAC;AACzE,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AAGpD,OAAO,EAAC,aAAa,EAAC,MAAM,kCAAkC,CAAC;;;;;;;;;;AAsB/D,MAAM,OAAO,yBAA0B,SAAQ,aAAa;IAM1D,IAAoB,mBAAmB,CAAC,KAA2B;QACjE,IAAI,CAAC,KAAK;YAAE,OAAO;QACnB,IAAI,CAAC,uBAAuB,GAAG,KAAK,CAAC;QACrC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAKD,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;IAED,IAAoB,UAAU,CAAC,KAAgD;QAC7E,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,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAE7C,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;IAkED,YACqB,eAAgC,EAChC,iBAAoC,EACtC,kBAAsC,EACtC,GAAsB,EACtB,gBAA0C,EAC1C,cAA8B;QAE/C,KAAK,CAAC,eAAe,EAAE,iBAAiB,CAAC,CAAC;QAPvB,oBAAe,GAAf,eAAe,CAAiB;QAChC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACtC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,QAAG,GAAH,GAAG,CAAmB;QACtB,qBAAgB,GAAhB,gBAAgB,CAA0B;QAC1C,mBAAc,GAAd,cAAc,CAAgB;QA7GX,UAAK,GAAG,2BAA2B,CAAC;QAU1D,oBAAe,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAErD,qCAAgC,GAAG,IAAI,eAAe,CAAS,IAAI,CAAC,CAAC;QA2BtE,gBAAW,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;QAE1B,yBAAoB,GAAG,IAAI,eAAe,CAA8B,IAAI,CAAC,CAAC;QAC9E,oBAAe,GAAG,MAAM,CAAkB,IAAI,eAAe,EAAE,CAAC,CAAC;QACjE,oBAAe,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAE3B,wBAAmB,GAAG,IAAI,eAAe,CAAiC,IAAI,CAAC,CAAC;QAEhF,kBAAa,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC,CAAC;QAEzD,iBAAY,GAA+C,aAAa,CAAC;YACxF,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,aAAa;YAClB,IAAI,CAAC,yBAAyB;YAC9B,IAAI,CAAC,oBAAoB;SAC1B,CAAC,CAAC,IAAI,CACL,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,WAAW,EAAE,uBAAuB,EAAE,mBAAmB,CAAC,EAAE,EAAE,CAC9E,aAAa,CAAC;YACZ,CAAC,WAAW;gBACV,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC;gBACV,CAAC,CAAC,IAAI,CAAC,gBAAgB;qBAClB,aAAa,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,EAAE,mBAAmB,CAAC,GAAG,EAAE,WAAW,CAAC;qBACjF,IAAI,CAAC,GAAG,CAAC,CAAC,GAAuC,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAC1E,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,EAAC,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,EAAC,CAAC,CAAC;QAC7E,CAAC,CAAC,CACH,CAAC;QAEc,2BAAsB,GAElC,aAAa,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CACpE,MAAM,CAAC,CAAC,CAAC,YAAY,EAAE,UAAU,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,IAAI,CAAC,CAAC,UAAU,CAAC,EACtE,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EACjE,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,UAAU,CAAC,EAAE,EAAE,CACjC,UAAU,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;YACnC,MAAM,EAAE,QAAQ,CAAC,MAAM;YACvB,GAAG,EAAE,KAAK;YACV,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC;gBACvB,KAAK,EAAE,QAAQ,CAAC,KAAK;gBACrB,iBAAiB,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAE,iBAAiB;aACtE,CAAC;YACF,MAAM,EAAE,YAAY,EAAE,UAAU,CAAC,MAAM,CAAC,MAAM,CAC5C,CAAC,qBAAqB,EAAE,YAAY,EAAE,EAAE,CAAC;gBACvC,GAAG,qBAAqB;gBACxB,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,QAAQ,CAAC;aAC1C,EACD,EAAE,CACH;SACF,CAAC,CAAC,CACJ,CACF,CAAC;IAaF,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,EAAE,UAAU,EAAE,CAAC;IAC/B,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;IAEO,YAAY,CAClB,KAAgC,EAChC,IAAkC;QAElC,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;YACxE,GAAG,KAAK,CAAC,iBAAiB;YAC1B,QAAQ,EAAE,KAAK,CAAC,iBAAiB,EAAE,IAAI,IAAI,wBAAwB,CAAC,IAAI;SACzE,CAAC,CAAC;QAEH,OAAO;YACL,GAAG,EAAE,KAAK,CAAC,GAAG;YACd,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,KAAK,EAAE,aAAa,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC;SAC/C,CAAC;IACJ,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,oBAAoB,CAAC,aAAa,CAAC,CAAC;IAClE,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,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC9B,CAAC;iBAAM,IAAI,YAAY,GAAG,GAAG,IAAI,YAAY,IAAI,GAAG,EAAE,CAAC;gBACrD,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC9B,CAAC;iBAAM,IAAI,YAAY,GAAG,GAAG,IAAI,YAAY,IAAI,IAAI,EAAE,CAAC;gBACtD,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC9B,CAAC;iBAAM,IAAI,YAAY,GAAG,IAAI,EAAE,CAAC;gBAC/B,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC9B,CAAC;QACH,CAAC;IACH,CAAC;IAEO,YAAY,CAAC,yBAAoD;QACvE,MAAM,gBAAgB,GAAG,yBAAyB,CAAC,KAAK,CAAC;QACzD,MAAM,4BAA4B,GAAG,yBAAyB,CAAC,iBAAiB,CAAC;QAEjF,IAAI,CAAC,4BAA4B,IAAI,gBAAgB,EAAE,CAAC;YACtD,OAAO,gBAAgB,CAAC;QAC1B,CAAC;aAAM,IAAI,4BAA4B,IAAI,gBAAgB,EAAE,CAAC;YAC5D,MAAM,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,gBAAgB,EAAE;gBACnE,GAAG,4BAA4B;gBAC/B,QAAQ,EAAE,4BAA4B,CAAC,IAAI;aAC5C,CAAC,CAAC;YAEH,IAAI,cAAc;gBAAE,OAAO,cAAc,CAAC;QAC5C,CAAC;QAED,OAAO,GAAG,CAAC;IACb,CAAC;+GA/LU,yBAAyB;mGAAzB,yBAAyB,qZCzEtC,opGA2FA,wyED3BI,YAAY,qRACZ,WAAW,yWACX,gBAAgB,8NAChB,WAAW,8BACX,gBAAgB,oPAChB,eAAe,2FACf,YAAY;;4FAGH,yBAAyB;kBAjBrC,SAAS;+BACE,2BAA2B,mBAGpB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,cACzB,IAAI,WACP;wBACP,YAAY;wBACZ,WAAW;wBACX,gBAAgB;wBAChB,WAAW;wBACX,gBAAgB;wBAChB,eAAe;wBACf,YAAY;qBACb;yPAGqC,KAAK;sBAA1C,WAAW;uBAAC,OAAO;gBACmB,oBAAoB;sBAA1D,SAAS;uBAAC,kBAAkB;gBAEG,UAAU;sBAAzC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBACS,MAAM;sBAArC,KAAK;uBAAC,EAAC,QAAQ,EAAE,IAAI,EAAC;gBACH,mBAAmB;sBAAtC,KAAK;gBAec,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 */\n\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {\n  ButtonModule,\n  InputModule,\n  PaginationModel,\n  PaginationModule,\n  TilesModule,\n} from 'carbon-components-angular';\nimport {\n  CaseWidgetAction,\n  CaseWidgetDisplayTypeKey,\n  CollectionCaseWidget,\n  CollectionCaseWidgetCardData,\n  CollectionCaseWidgetField,\n  CollectionCaseWidgetTitle,\n  CollectionWidgetResolvedField,\n} from '../../../../../../models';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap, tap} from 'rxjs';\nimport {CarbonListModule, ViewContentService} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Page} from '@valtimo/config';\nimport {DossierWidgetsApiService} from '../../../../../../services';\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-collection',\n  templateUrl: './widget-collection.component.html',\n  styleUrls: ['./widget-collection.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    InputModule,\n    PaginationModule,\n    TilesModule,\n    CarbonListModule,\n    TranslateModule,\n    ButtonModule,\n  ],\n})\nexport class WidgetCollectionComponent extends WidgetProcess implements AfterViewInit, OnDestroy {\n  @HostBinding('class') public readonly class = 'valtimo-widget-collection';\n  @ViewChild('widgetCollection') private _widgetCollectionRef: ElementRef<HTMLDivElement>;\n\n  @Input({required: true}) public documentId: string;\n  @Input({required: true}) public tabKey: string;\n  @Input() public set widgetConfiguration(value: CollectionCaseWidget) {\n    if (!value) return;\n    this.baseWidgetConfiguration = value;\n    this.widgetConfiguration$.next(value);\n  }\n  public readonly showPagination$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _initialNumberOfElementsSubject$ = new BehaviorSubject<number>(null);\n\n  private get _initialNumberOfElements$(): Observable<number> {\n    return this._initialNumberOfElementsSubject$.pipe(\n      filter(numberOfElements => numberOfElements !== null)\n    );\n  }\n\n  @Input() public set widgetData(value: Page<CollectionCaseWidgetCardData> | null) {\n    if (!value) return;\n\n    this.showPagination$.next(value.totalElements > value.size);\n    this._initialNumberOfElementsSubject$.next(value.numberOfElements);\n    this._widgetDataSubject$.next(value.content);\n\n    this.paginationModel.set(\n      value.totalPages < 0\n        ? null\n        : {\n            currentPage: 1,\n            totalDataLength: Math.ceil(value.totalElements / value.size),\n            pageLength: value.size,\n          }\n    );\n    this.cdr.detectChanges();\n  }\n\n  public readonly widgetTitle = signal('-');\n\n  public readonly widgetConfiguration$ = new BehaviorSubject<CollectionCaseWidget | null>(null);\n  public readonly paginationModel = signal<PaginationModel>(new PaginationModel());\n  public readonly amountOfColumns = signal(0);\n\n  private readonly _widgetDataSubject$ = new BehaviorSubject<CollectionCaseWidgetCardData[]>(null);\n\n  private readonly _queryParams$ = new BehaviorSubject<string | null>(null);\n\n  private readonly _widgetData$: Observable<CollectionCaseWidgetCardData[]> = combineLatest([\n    this._widgetDataSubject$,\n    this._queryParams$,\n    this._initialNumberOfElements$,\n    this.widgetConfiguration$,\n  ]).pipe(\n    switchMap(([data, queryParams, initialNumberOfElements, widgetConfiguration]) =>\n      combineLatest([\n        !queryParams\n          ? of(data)\n          : this.widgetApiService\n              .getWidgetData(this.documentId, this.tabKey, widgetConfiguration.key, queryParams)\n              .pipe(map((res: Page<CollectionCaseWidgetCardData>) => res.content)),\n        of(initialNumberOfElements),\n      ])\n    ),\n    filter(([items]) => !!items),\n    map(([items, initialNumberOfElements]) => {\n      if (items.length === initialNumberOfElements) {\n        return items;\n      }\n\n      const rows = new Array<number>(initialNumberOfElements).fill(null);\n\n      return rows.map((_, index) => items[index] || {...items[0], hidden: true});\n    })\n  );\n\n  public readonly collectionWidgetCards$: Observable<\n    {title: string; fields: CollectionWidgetResolvedField[]; key: number; hidden: boolean}[]\n  > = combineLatest([this.widgetConfiguration$, this._widgetData$]).pipe(\n    filter(([widgetConfig, widgetData]) => !!widgetConfig && !!widgetData),\n    tap(([widgetConfig]) => this.widgetTitle.set(widgetConfig.title)),\n    map(([widgetConfig, widgetData]) =>\n      widgetData.map((cardData, index) => ({\n        hidden: cardData.hidden,\n        key: index,\n        title: this.getCardTitle({\n          value: cardData.title,\n          displayProperties: widgetConfig?.properties?.title?.displayProperties,\n        }),\n        fields: widgetConfig?.properties.fields.reduce(\n          (cardFieldsAccumulator, currentField) => [\n            ...cardFieldsAccumulator,\n            this.getCardField(currentField, cardData),\n          ],\n          []\n        ),\n      }))\n    )\n  );\n\n  private _observer!: ResizeObserver;\n\n  constructor(\n    protected readonly documentService: DocumentService,\n    protected readonly permissionService: PermissionService,\n    private readonly viewContentService: ViewContentService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly widgetApiService: DossierWidgetsApiService,\n    private readonly widgetsService: WidgetsService\n  ) {\n    super(documentService, permissionService);\n  }\n\n  public ngAfterViewInit(): void {\n    this.openWidthObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._observer?.disconnect();\n  }\n\n  public onSelectPage(page: number): void {\n    this._queryParams$.next(`page=${page - 1}&size=${this.paginationModel().pageLength}`);\n    this.paginationModel.update((model: PaginationModel) => ({\n      ...model,\n      currentPage: page,\n    }));\n  }\n\n  public onProcessStartClick(process: CaseWidgetAction): void {\n    this.widgetsService.startProcess(process.processDefinitionKey);\n  }\n\n  private getCardField(\n    field: CollectionCaseWidgetField,\n    data: CollectionCaseWidgetCardData\n  ): CollectionWidgetResolvedField {\n    const resolvedValue = this.viewContentService.get(data.fields[field.key], {\n      ...field.displayProperties,\n      viewType: field.displayProperties?.type ?? CaseWidgetDisplayTypeKey.TEXT,\n    });\n\n    return {\n      key: field.key,\n      title: field.title,\n      width: field.width,\n      value: resolvedValue || data.fields[field.key],\n    };\n  }\n\n  private openWidthObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetCollectionRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const elementWidth = event[0]?.borderBoxSize[0]?.inlineSize;\n\n    if (typeof elementWidth === 'number' && elementWidth !== 0) {\n      if (elementWidth < 640) {\n        this.amountOfColumns.set(1);\n      } else if (elementWidth > 640 && elementWidth <= 768) {\n        this.amountOfColumns.set(2);\n      } else if (elementWidth > 768 && elementWidth <= 1080) {\n        this.amountOfColumns.set(3);\n      } else if (elementWidth > 1080) {\n        this.amountOfColumns.set(4);\n      }\n    }\n  }\n\n  private getCardTitle(collectionCaseWidgetTitle: CollectionCaseWidgetTitle): string {\n    const widgetTitleValue = collectionCaseWidgetTitle.value;\n    const widgetTitleDisplayProperties = collectionCaseWidgetTitle.displayProperties;\n\n    if (!widgetTitleDisplayProperties && widgetTitleValue) {\n      return widgetTitleValue;\n    } else if (widgetTitleDisplayProperties && widgetTitleValue) {\n      const convertedTitle = this.viewContentService.get(widgetTitleValue, {\n        ...widgetTitleDisplayProperties,\n        viewType: widgetTitleDisplayProperties.type,\n      });\n\n      if (convertedTitle) return convertedTitle;\n    }\n\n    return '-';\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    widgetConfiguration: widgetConfiguration$ | async,\n    collectionWidgetCards: collectionWidgetCards$ | async,\n  } as obs\"\n>\n  <section class=\"valtimo-widget-collection__header\">\n    <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\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  <div\n    #widgetCollection\n    [ngClass]=\"{\n      'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n      'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n      'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n      'valtimo-widget-collection__container': amountOfColumns() === 4,\n    }\"\n  >\n    @for (card of obs?.collectionWidgetCards; track card.key) {\n      <div\n        class=\"valtimo-widget-collection__card\"\n        [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n      >\n        <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n        @for (field of card.fields; track field.key) {\n          <div\n            [ngClass]=\"{\n              'valtimo-widget-collection__full-width-input': field?.width === 'full',\n              'valtimo-widget-collection__half-width-input': field?.width === 'half',\n            }\"\n          >\n            <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n              {{ field?.title }}\n\n              <input\n                [value]=\"field?.value\"\n                [readonly]=\"true\"\n                class=\"valtimo-widget-collection__card-input\"\n                cdsText\n              />\n            </cds-label>\n          </div>\n        }\n      </div>\n    }\n  </div>\n\n  @if (!obs?.collectionWidgetCards?.length) {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  }\n\n  <cds-pagination-nav\n    *ngIf=\"paginationModel() && (showPagination$ | async)\"\n    class=\"valtimo-widget-collection__pagination\"\n    [model]=\"paginationModel()\"\n    (selectPage)=\"onSelectPage($event)\"\n  >\n  </cds-pagination-nav>\n</ng-container>\n"]}
@@ -19,21 +19,33 @@ import { CUSTOM_CASE_WIDGET_TOKEN } from '../../../../../../constants';
19
19
  import { BehaviorSubject, combineLatest, filter, Subscription } from 'rxjs';
20
20
  import { CarbonListModule } from '@valtimo/components';
21
21
  import { TranslateModule } from '@ngx-translate/core';
22
+ import { WidgetProcess } from '../widget-process/widget-process';
23
+ import { ButtonModule } from 'carbon-components-angular';
22
24
  import * as i0 from "@angular/core";
23
- import * as i1 from "@angular/common";
24
- import * as i2 from "@valtimo/components";
25
- import * as i3 from "@ngx-translate/core";
26
- export class WidgetCustomComponent {
25
+ import * as i1 from "../../widgets.service";
26
+ import * as i2 from "@valtimo/document";
27
+ import * as i3 from "@valtimo/access-control";
28
+ import * as i4 from "@angular/common";
29
+ import * as i5 from "@valtimo/components";
30
+ import * as i6 from "@ngx-translate/core";
31
+ import * as i7 from "carbon-components-angular";
32
+ export class WidgetCustomComponent extends WidgetProcess {
27
33
  set widgetConfig(value) {
28
- if (value)
29
- this._widgetConfigSubject$.next(value);
34
+ if (!value)
35
+ return;
36
+ this.baseWidgetConfiguration = value;
37
+ this._widgetConfigSubject$.next(value);
30
38
  }
31
39
  get widgetConfig$() {
32
40
  return this._widgetConfigSubject$.pipe(filter(config => config !== null));
33
41
  }
34
- constructor(customCaseWidgetConfig, cdr) {
42
+ constructor(customCaseWidgetConfig, cdr, widgetsService, documentService, permissionService) {
43
+ super(documentService, permissionService);
35
44
  this.customCaseWidgetConfig = customCaseWidgetConfig;
36
45
  this.cdr = cdr;
46
+ this.widgetsService = widgetsService;
47
+ this.documentService = documentService;
48
+ this.permissionService = permissionService;
37
49
  this._customCaseWidgetConfig$ = new BehaviorSubject({});
38
50
  this._widgetConfigSubject$ = new BehaviorSubject(null);
39
51
  this.noCustomComponentAvailable = signal(false);
@@ -47,6 +59,9 @@ export class WidgetCustomComponent {
47
59
  ngOnDestroy() {
48
60
  this._subscriptions.unsubscribe();
49
61
  }
62
+ onProcessStartClick(process) {
63
+ this.widgetsService.startProcess(process.processDefinitionKey);
64
+ }
50
65
  openCustomWidgetSubscription() {
51
66
  this._subscriptions.add(combineLatest([this.widgetConfig$, this._customCaseWidgetConfig$]).subscribe(([widgetConfig, customCaseWidgetConfig]) => {
52
67
  const customWidgetComponentKey = widgetConfig?.properties?.componentKey;
@@ -60,21 +75,21 @@ export class WidgetCustomComponent {
60
75
  this.cdr.detectChanges();
61
76
  }));
62
77
  }
63
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetCustomComponent, deps: [{ token: CUSTOM_CASE_WIDGET_TOKEN, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
64
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetCustomComponent, isStandalone: true, selector: "valtimo-widget-custom", inputs: { widgetConfig: "widgetConfig" }, viewQueries: [{ propertyName: "_customWidgetContainerRef", first: true, predicate: ["customWidgetContainer"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"custom-widget\">\n <h4 class=\"custom-widget__title\">{{ (widgetConfig$ | async)?.title || '-' }}</h4>\n\n <div class=\"custom-widget__content\">\n <ng-template #customWidgetContainer></ng-template>\n\n @if (noCustomComponentAvailable()) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n </div>\n</div>\n", styles: [".custom-widget{padding:24px}.custom-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i2.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
78
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetCustomComponent, deps: [{ token: CUSTOM_CASE_WIDGET_TOKEN, optional: true }, { token: i0.ChangeDetectorRef }, { token: i1.WidgetsService }, { token: i2.DocumentService }, { token: i3.PermissionService }], target: i0.ɵɵFactoryTarget.Component }); }
79
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetCustomComponent, isStandalone: true, selector: "valtimo-widget-custom", inputs: { widgetConfig: "widgetConfig" }, viewQueries: [{ propertyName: "_customWidgetContainerRef", first: true, predicate: ["customWidgetContainer"], descendants: true, read: ViewContainerRef }], 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 *ngIf=\"{widgetConfig: widgetConfig$ | async} as obs\" class=\"custom-widget\">\n <section class=\"custom-widget__header\">\n <h4 class=\"custom-widget__title\">{{ obs.widgetConfig$?.title || '-' }}</h4>\n\n @if (obs.widgetConfig?.actions?.length === 1) {\n <button\n *ngIf=\"canCreateCamundaExecution$ | async\"\n cdsButton=\"ghost\"\n (click)=\"onProcessStartClick(obs.widgetConfig?.actions[0])\"\n >\n {{ obs.widgetConfig?.actions[0].name }}\n </button>\n }\n </section>\n\n <div class=\"custom-widget__content\">\n <ng-template #customWidgetContainer></ng-template>\n\n @if (noCustomComponentAvailable()) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n </div>\n</div>\n", styles: [".custom-widget{padding:24px}.custom-widget__header{display:flex;align-items:center;justify-content:space-between}.custom-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i5.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i6.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 }); }
65
80
  }
66
81
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetCustomComponent, decorators: [{
67
82
  type: Component,
68
- args: [{ selector: 'valtimo-widget-custom', standalone: true, imports: [CommonModule, CarbonListModule, TranslateModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"custom-widget\">\n <h4 class=\"custom-widget__title\">{{ (widgetConfig$ | async)?.title || '-' }}</h4>\n\n <div class=\"custom-widget__content\">\n <ng-template #customWidgetContainer></ng-template>\n\n @if (noCustomComponentAvailable()) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n </div>\n</div>\n", styles: [".custom-widget{padding:24px}.custom-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
83
+ args: [{ selector: 'valtimo-widget-custom', standalone: true, imports: [CommonModule, CarbonListModule, TranslateModule, 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 *ngIf=\"{widgetConfig: widgetConfig$ | async} as obs\" class=\"custom-widget\">\n <section class=\"custom-widget__header\">\n <h4 class=\"custom-widget__title\">{{ obs.widgetConfig$?.title || '-' }}</h4>\n\n @if (obs.widgetConfig?.actions?.length === 1) {\n <button\n *ngIf=\"canCreateCamundaExecution$ | async\"\n cdsButton=\"ghost\"\n (click)=\"onProcessStartClick(obs.widgetConfig?.actions[0])\"\n >\n {{ obs.widgetConfig?.actions[0].name }}\n </button>\n }\n </section>\n\n <div class=\"custom-widget__content\">\n <ng-template #customWidgetContainer></ng-template>\n\n @if (noCustomComponentAvailable()) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n </div>\n</div>\n", styles: [".custom-widget{padding:24px}.custom-widget__header{display:flex;align-items:center;justify-content:space-between}.custom-widget__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
69
84
  }], ctorParameters: () => [{ type: undefined, decorators: [{
70
85
  type: Optional
71
86
  }, {
72
87
  type: Inject,
73
88
  args: [CUSTOM_CASE_WIDGET_TOKEN]
74
- }] }, { type: i0.ChangeDetectorRef }], propDecorators: { _customWidgetContainerRef: [{
89
+ }] }, { type: i0.ChangeDetectorRef }, { type: i1.WidgetsService }, { type: i2.DocumentService }, { type: i3.PermissionService }], propDecorators: { _customWidgetContainerRef: [{
75
90
  type: ViewChild,
76
91
  args: ['customWidgetContainer', { read: ViewContainerRef }]
77
92
  }], widgetConfig: [{
78
93
  type: Input
79
94
  }] } });
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-custom.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  signal,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {CustomCaseWidget, CustomCaseWidgetConfig} from '../../../../../../models';\nimport {CUSTOM_CASE_WIDGET_TOKEN} from '../../../../../../constants';\nimport {BehaviorSubject, combineLatest, filter, Observable, Subscription} from 'rxjs';\nimport {CarbonListModule} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\n\n@Component({\n  selector: 'valtimo-widget-custom',\n  templateUrl: './widget-custom.component.html',\n  styleUrls: ['./widget-custom.component.scss'],\n  standalone: true,\n  imports: [CommonModule, CarbonListModule, TranslateModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetCustomComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('customWidgetContainer', {read: ViewContainerRef})\n  private readonly _customWidgetContainerRef: ViewContainerRef;\n\n  @Input() public set widgetConfig(value: CustomCaseWidget) {\n    if (value) this._widgetConfigSubject$.next(value);\n  }\n\n  private readonly _customCaseWidgetConfig$ = new BehaviorSubject<CustomCaseWidgetConfig | {}>({});\n\n  private readonly _widgetConfigSubject$ = new BehaviorSubject<CustomCaseWidget | null>(null);\n\n  public get widgetConfig$(): Observable<CustomCaseWidget> {\n    return this._widgetConfigSubject$.pipe(filter(config => config !== null));\n  }\n\n  public readonly noCustomComponentAvailable = signal(false);\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    @Optional()\n    @Inject(CUSTOM_CASE_WIDGET_TOKEN)\n    private readonly customCaseWidgetConfig: CustomCaseWidgetConfig,\n    private readonly cdr: ChangeDetectorRef\n  ) {\n    if (customCaseWidgetConfig) this._customCaseWidgetConfig$.next(customCaseWidgetConfig);\n  }\n\n  public ngAfterViewInit(): void {\n    this.openCustomWidgetSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  private openCustomWidgetSubscription(): void {\n    this._subscriptions.add(\n      combineLatest([this.widgetConfig$, this._customCaseWidgetConfig$]).subscribe(\n        ([widgetConfig, customCaseWidgetConfig]) => {\n          const customWidgetComponentKey = widgetConfig?.properties?.componentKey;\n          const customComponent = customCaseWidgetConfig[customWidgetComponentKey];\n\n          if (!customComponent) {\n            this.noCustomComponentAvailable.set(true);\n            return;\n          }\n\n          const componentRef = this._customWidgetContainerRef.createComponent(customComponent);\n\n          componentRef.changeDetectorRef.detectChanges();\n          this.cdr.detectChanges();\n        }\n      )\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div class=\"custom-widget\">\n  <h4 class=\"custom-widget__title\">{{ (widgetConfig$ | async)?.title || '-' }}</h4>\n\n  <div class=\"custom-widget__content\">\n    <ng-template #customWidgetContainer></ng-template>\n\n    @if (noCustomComponentAvailable()) {\n      <valtimo-no-results\n        [collapseVertically]=\"true\"\n        [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n        [smallPadding]=\"true\"\n      ></valtimo-no-results>\n    }\n  </div>\n</div>\n"]}
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-custom.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  signal,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {CaseWidgetAction, CustomCaseWidget, CustomCaseWidgetConfig} from '../../../../../../models';\nimport {CUSTOM_CASE_WIDGET_TOKEN} from '../../../../../../constants';\nimport {BehaviorSubject, combineLatest, filter, Observable, Subscription} from 'rxjs';\nimport {CarbonListModule} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {WidgetProcess} from '../widget-process/widget-process';\nimport {DocumentService} from '@valtimo/document';\nimport {PermissionService} from '@valtimo/access-control';\nimport {WidgetsService} from '../../widgets.service';\nimport {ButtonModule} from 'carbon-components-angular';\n\n@Component({\n  selector: 'valtimo-widget-custom',\n  templateUrl: './widget-custom.component.html',\n  styleUrls: ['./widget-custom.component.scss'],\n  standalone: true,\n  imports: [CommonModule, CarbonListModule, TranslateModule, ButtonModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetCustomComponent extends WidgetProcess implements AfterViewInit, OnDestroy {\n  @ViewChild('customWidgetContainer', {read: ViewContainerRef})\n  private readonly _customWidgetContainerRef: ViewContainerRef;\n\n  @Input() public set widgetConfig(value: CustomCaseWidget) {\n    if (!value) return;\n    this.baseWidgetConfiguration = value;\n    this._widgetConfigSubject$.next(value);\n  }\n\n  private readonly _customCaseWidgetConfig$ = new BehaviorSubject<CustomCaseWidgetConfig | {}>({});\n\n  private readonly _widgetConfigSubject$ = new BehaviorSubject<CustomCaseWidget | null>(null);\n\n  public get widgetConfig$(): Observable<CustomCaseWidget> {\n    return this._widgetConfigSubject$.pipe(filter(config => config !== null));\n  }\n\n  public readonly noCustomComponentAvailable = signal(false);\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    @Optional()\n    @Inject(CUSTOM_CASE_WIDGET_TOKEN)\n    private readonly customCaseWidgetConfig: CustomCaseWidgetConfig,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly widgetsService: WidgetsService,\n    protected readonly documentService: DocumentService,\n    protected readonly permissionService: PermissionService\n  ) {\n    super(documentService, permissionService);\n    if (customCaseWidgetConfig) this._customCaseWidgetConfig$.next(customCaseWidgetConfig);\n  }\n\n  public ngAfterViewInit(): void {\n    this.openCustomWidgetSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public onProcessStartClick(process: CaseWidgetAction): void {\n    this.widgetsService.startProcess(process.processDefinitionKey);\n  }\n\n  private openCustomWidgetSubscription(): void {\n    this._subscriptions.add(\n      combineLatest([this.widgetConfig$, this._customCaseWidgetConfig$]).subscribe(\n        ([widgetConfig, customCaseWidgetConfig]) => {\n          const customWidgetComponentKey = widgetConfig?.properties?.componentKey;\n          const customComponent = customCaseWidgetConfig[customWidgetComponentKey];\n\n          if (!customComponent) {\n            this.noCustomComponentAvailable.set(true);\n            return;\n          }\n\n          const componentRef = this._customWidgetContainerRef.createComponent(customComponent);\n\n          componentRef.changeDetectorRef.detectChanges();\n          this.cdr.detectChanges();\n        }\n      )\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div *ngIf=\"{widgetConfig: widgetConfig$ | async} as obs\" class=\"custom-widget\">\n  <section class=\"custom-widget__header\">\n    <h4 class=\"custom-widget__title\">{{ obs.widgetConfig$?.title || '-' }}</h4>\n\n    @if (obs.widgetConfig?.actions?.length === 1) {\n      <button\n        *ngIf=\"canCreateCamundaExecution$ | async\"\n        cdsButton=\"ghost\"\n        (click)=\"onProcessStartClick(obs.widgetConfig?.actions[0])\"\n      >\n        {{ obs.widgetConfig?.actions[0].name }}\n      </button>\n    }\n  </section>\n\n  <div class=\"custom-widget__content\">\n    <ng-template #customWidgetContainer></ng-template>\n\n    @if (noCustomComponentAvailable()) {\n      <valtimo-no-results\n        [collapseVertically]=\"true\"\n        [description]=\"'dossier.widgets.noCustomComponentDescription' | translate\"\n        [smallPadding]=\"true\"\n      ></valtimo-no-results>\n    }\n  </div>\n</div>\n"]}