@valtimo/dossier 12.1.0 → 12.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dossier-assign-user/dossier-assign-user.component.mjs +4 -4
- package/esm2022/lib/components/dossier-bulk-assign-modal/dossier-bulk-assign-modal.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/dossier-detail.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/audit/audit.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/documents/documents.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/formio/formio.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/not-found/not-found.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/notes/notes.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/progress/progress.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/s3-documents/s3-documents.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/summary/summary.component.mjs +5 -5
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/custom/widget-custom.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/widgets-container/widgets-container.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.component.mjs +4 -4
- package/esm2022/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.mjs +5 -5
- package/esm2022/lib/components/dossier-list/dossier-list.component.mjs +4 -4
- package/esm2022/lib/components/dossier-list-actions/dossier-list-actions.component.mjs +4 -4
- package/esm2022/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.mjs +4 -4
- package/esm2022/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +4 -4
- package/esm2022/lib/components/dossier-update/dossier-update.component.mjs +4 -4
- package/esm2022/lib/components/note-modal/note-modal.component.mjs +4 -4
- package/esm2022/lib/dossier-routing.module.mjs +5 -5
- package/esm2022/lib/dossier.module.mjs +5 -5
- package/esm2022/lib/models/tabs.model.mjs +2 -3
- package/esm2022/lib/pipes/tab-translate/tab-translate-pipe.module.mjs +5 -5
- package/esm2022/lib/pipes/tab-translate/tab-translate.pipe.mjs +4 -4
- package/esm2022/lib/services/dossier-bulk-assign.service.mjs +4 -4
- package/esm2022/lib/services/dossier-column.service.mjs +4 -4
- package/esm2022/lib/services/dossier-list-assignee.service.mjs +4 -4
- package/esm2022/lib/services/dossier-list-pagination.service.mjs +4 -4
- package/esm2022/lib/services/dossier-list-search.service.mjs +4 -4
- package/esm2022/lib/services/dossier-list-status.service.mjs +4 -4
- package/esm2022/lib/services/dossier-list.service.mjs +4 -4
- package/esm2022/lib/services/dossier-parameter.service.mjs +4 -4
- package/esm2022/lib/services/dossier-tab-api.service.mjs +4 -4
- package/esm2022/lib/services/dossier-tab.service.mjs +4 -4
- package/esm2022/lib/services/dossier-widgets-api.service.mjs +4 -4
- package/esm2022/lib/services/dossier-widgets-layout.service.mjs +4 -4
- package/esm2022/lib/services/dossier.service.mjs +4 -4
- package/esm2022/lib/services/notes.service.mjs +4 -4
- package/esm2022/lib/services/start-modal.service.mjs +4 -4
- package/fesm2022/valtimo-dossier.mjs +141 -142
- package/fesm2022/valtimo-dossier.mjs.map +1 -1
- package/lib/models/tabs.model.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -53,10 +53,10 @@ export class WidgetFormioComponent {
|
|
|
53
53
|
of(config),
|
|
54
54
|
])), tap(([_, config]) => this.layoutService.setWidgetWithExternalDataReady(config.uuid)), map(([formDef]) => formDef));
|
|
55
55
|
}
|
|
56
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
57
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.
|
|
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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
58
58
|
}
|
|
59
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
59
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetFormioComponent, decorators: [{
|
|
60
60
|
type: Component,
|
|
61
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
62
|
}], ctorParameters: () => [{ type: i1.FormService }, { type: i2.DossierWidgetsLayoutService }], propDecorators: { documentId: [{
|
|
@@ -64,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
64
64
|
}], widgetConfiguration: [{
|
|
65
65
|
type: Input
|
|
66
66
|
}] } });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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"]}
|
|
@@ -104,10 +104,10 @@ export class WidgetTableComponent {
|
|
|
104
104
|
currentPage: page,
|
|
105
105
|
}));
|
|
106
106
|
}
|
|
107
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
108
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.
|
|
107
|
+
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 }); }
|
|
108
|
+
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 }); }
|
|
109
109
|
}
|
|
110
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
110
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetTableComponent, decorators: [{
|
|
111
111
|
type: Component,
|
|
112
112
|
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"] }]
|
|
113
113
|
}], ctorParameters: () => [{ type: i1.DossierWidgetsApiService }, { type: i0.ChangeDetectorRef }], propDecorators: { documentId: [{
|
|
@@ -123,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
123
123
|
type: Input,
|
|
124
124
|
args: [{ required: true }]
|
|
125
125
|
}] } });
|
|
126
|
-
//# 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":"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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  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      }))\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"]}
|
|
126
|
+
//# 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":"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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  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      }))\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"]}
|
|
@@ -125,10 +125,10 @@ export class WidgetBlockComponent {
|
|
|
125
125
|
getPageSizeParam(widgetConfiguration) {
|
|
126
126
|
return `size=${widgetConfiguration.properties.defaultPageSize}`;
|
|
127
127
|
}
|
|
128
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
129
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.
|
|
128
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetBlockComponent, deps: [{ token: i1.DossierWidgetsLayoutService }, { token: i1.DossierTabService }, { token: i2.ActivatedRoute }, { token: i1.DossierWidgetsApiService }, { token: i3.CdsThemeService }, { token: i0.Renderer2 }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
129
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetBlockComponent, isStandalone: true, selector: "valtimo-dossier-widget-block", inputs: { widget: "widget" }, viewQueries: [{ propertyName: "_widgetBlockContentRef", first: true, predicate: ["widgetBlockContent"], descendants: true }, { propertyName: "_widgetBlockRef", first: true, predicate: ["widgetBlock"], 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 documentId: documentId$ | async,\n tabKey: tabKey$ | async,\n widgetConfiguration: widget$ | async,\n widgetData: widgetData$ | async,\n theme: theme$ | async,\n blockHeightPx: blockHeightPx$ | async,\n blockWidthPercentage: blockWidthPercentage$ | async\n } as obs\"\n>\n <div #widgetBlock class=\"widget-block\" [attr.data-carbon-theme]=\"obs.theme\">\n <div #widgetBlockContent class=\"widget-block__content\">\n @if (obs.widgetData) {\n @switch (obs.widgetConfiguration.type) {\n @case (CaseWidgetType.TABLE) {\n <valtimo-widget-table\n [documentId]=\"obs.documentId\"\n [tabKey]=\"obs.tabKey\"\n [widgetConfiguration]=\"obs.widgetConfiguration\"\n [widgetData]=\"obs.widgetData\"\n ></valtimo-widget-table>\n }\n\n @case (CaseWidgetType.COLLECTION) {\n <valtimo-widget-collection\n [documentId]=\"obs.documentId\"\n [tabKey]=\"obs.tabKey\"\n [widgetConfiguration]=\"obs.widgetConfiguration\"\n [widgetData]=\"obs.widgetData\"\n ></valtimo-widget-collection>\n }\n\n @case (CaseWidgetType.CUSTOM) {\n <valtimo-widget-custom [widgetConfig]=\"obs.widgetConfiguration\"></valtimo-widget-custom>\n }\n\n @case (CaseWidgetType.FIELDS) {\n <valtimo-widget-field\n [collapseVertically]=\"true\"\n [widgetConfiguration]=\"obs.widgetConfiguration\"\n [widgetData]=\"obs.widgetData\"\n ></valtimo-widget-field>\n }\n\n @case (CaseWidgetType.FORMIO) {\n <valtimo-widget-formio\n [widgetConfiguration]=\"obs.widgetConfiguration\"\n [documentId]=\"obs.documentId\"\n ></valtimo-widget-formio>\n }\n\n @default {\n <div class=\"widget-block__not-available\">\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noWidget' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n </div>\n }\n }\n } @else {\n <div class=\"widget-block__not-available\">\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n </div>\n }\n </div>\n </div>\n</ng-container>\n", styles: [":host{display:block;position:absolute}.widget-block{width:100%;height:100%;box-sizing:border-box;padding:8px;overflow-wrap:break-word;background-color:var(--cds-layer-01);background-clip:content-box}.widget-block__not-available{padding: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: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: LoadingModule }, { kind: "component", type: WidgetTableComponent, selector: "valtimo-widget-table", inputs: ["documentId", "tabKey", "widgetConfiguration", "widgetData"] }, { kind: "component", type: WidgetCustomComponent, selector: "valtimo-widget-custom", inputs: ["widgetConfig"] }, { 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: i5.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: TilesModule }, { kind: "component", type: WidgetFieldComponent, selector: "valtimo-widget-field", inputs: ["collapseVertically", "widgetConfiguration", "widgetData"] }, { kind: "component", type: WidgetFormioComponent, selector: "valtimo-widget-formio", inputs: ["documentId", "widgetConfiguration"] }, { kind: "component", type: WidgetCollectionComponent, selector: "valtimo-widget-collection", inputs: ["documentId", "tabKey", "widgetConfiguration", "widgetData"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
130
130
|
}
|
|
131
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
131
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetBlockComponent, decorators: [{
|
|
132
132
|
type: Component,
|
|
133
133
|
args: [{ selector: 'valtimo-dossier-widget-block', standalone: true, imports: [
|
|
134
134
|
CommonModule,
|
|
@@ -151,4 +151,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
151
151
|
}], widget: [{
|
|
152
152
|
type: Input
|
|
153
153
|
}] } });
|
|
154
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-block.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.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 {HttpErrorResponse} from '@angular/common/http';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  Renderer2,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {\n  CARBON_THEME,\n  CarbonListModule,\n  CdsThemeService,\n  CurrentCarbonTheme,\n} from '@valtimo/components';\nimport {LoadingModule, TilesModule} from 'carbon-components-angular';\nimport {\n  BehaviorSubject,\n  catchError,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  of,\n  Subscription,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport {CaseWidgetType, CaseWidgetWithUuid, WidgetTableContent} from '../../../../../../models';\nimport {\n  DossierTabService,\n  DossierWidgetsApiService,\n  DossierWidgetsLayoutService,\n} from '../../../../../../services';\nimport {WidgetCustomComponent} from '../custom/widget-custom.component';\nimport {WidgetFieldComponent} from '../field/widget-field.component';\nimport {WidgetFormioComponent} from '../formio/widget-formio.component';\nimport {WidgetTableComponent} from '../table/widget-table.component';\nimport {WidgetCollectionComponent} from '../collection/widget-collection.component';\nimport {WIDGET_HEIGHT_1X} from '../../../../../../constants';\n\n@Component({\n  selector: 'valtimo-dossier-widget-block',\n  templateUrl: './widget-block.component.html',\n  styleUrls: ['./widget-block.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    LoadingModule,\n    WidgetTableComponent,\n    WidgetCustomComponent,\n    CarbonListModule,\n    TranslateModule,\n    TilesModule,\n    WidgetFieldComponent,\n    WidgetFormioComponent,\n    WidgetCollectionComponent,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetBlockComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('widgetBlockContent') private _widgetBlockContentRef: ElementRef<HTMLDivElement>;\n  @ViewChild('widgetBlock') private _widgetBlockRef: ElementRef<HTMLDivElement>;\n\n  @Input() public set widget(value: CaseWidgetWithUuid) {\n    this._widgetUuid = value.uuid;\n    this._widget$.next(value);\n  }\n\n  private readonly _widget$ = new BehaviorSubject<CaseWidgetWithUuid | null>(null);\n\n  public get widget$(): Observable<CaseWidgetWithUuid> {\n    return this._widget$.pipe(filter(widget => widget !== null));\n  }\n\n  private readonly _viewContainerRefSubject$ = new BehaviorSubject<ViewContainerRef | null>(null);\n\n  private get _viewContainerRef$(): Observable<ViewContainerRef> {\n    return this._viewContainerRefSubject$.pipe(filter(ref => !!ref));\n  }\n\n  private readonly _contentHeight$ = new BehaviorSubject<number>(0);\n\n  public readonly blockHeightPx$ = combineLatest([\n    this._contentHeight$,\n    this._viewContainerRef$,\n  ]).pipe(\n    filter(([contentHeight]) => contentHeight !== 0),\n    tap(([contentHeight, viewRef]) => {\n      const blockHeight = Math.ceil((contentHeight + 16) / WIDGET_HEIGHT_1X) * WIDGET_HEIGHT_1X;\n\n      this.renderer.setStyle(viewRef.element.nativeElement, 'height', `${blockHeight}px`);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    })\n  );\n\n  public readonly blockWidthPercentage$ = combineLatest([\n    this.dossierWidgetsLayoutService.amountOfColumns$,\n    this.widget$,\n    this._viewContainerRef$,\n  ]).pipe(\n    tap(([amountOfColumns, widget, viewRef]) => {\n      const percentage =\n        widget.width > amountOfColumns ? 100 : (widget.width / amountOfColumns) * 100;\n\n      this.renderer.setStyle(viewRef.element.nativeElement, 'width', `${percentage}%`);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    })\n  );\n\n  public readonly CaseWidgetType = CaseWidgetType;\n\n  public readonly documentId$ = this.route.params.pipe(\n    map(params => params?.documentId),\n    filter(documentId => !!documentId)\n  );\n\n  public readonly tabKey$: Observable<string> = this.dossierTabService.activeTabKey$;\n\n  public readonly widgetData$: Observable<any[] | {} | null> = combineLatest([\n    this.widget$,\n    this.tabKey$,\n    this.documentId$,\n  ]).pipe(\n    switchMap(([widget, tabkey, documentId]) =>\n      // custom component and formio widgets do not fetch additional data\n      widget.type === CaseWidgetType.CUSTOM || widget.type === CaseWidgetType.FORMIO\n        ? of({})\n        : this.widgetsApiService.getWidgetData(\n            documentId,\n            tabkey,\n            widget.key,\n            widget.type === CaseWidgetType.TABLE || widget.type === CaseWidgetType.COLLECTION\n              ? this.getPageSizeParam(widget)\n              : undefined\n          )\n    ),\n    tap(() => {\n      this.dossierWidgetsLayoutService.setCaseWidgetDataLoaded(this._widgetUuid);\n    }),\n    catchError((error: HttpErrorResponse) => {\n      if (error.status === 404)\n        this.dossierWidgetsLayoutService.setCaseWidgetDataLoaded(this._widgetUuid);\n\n      return of(null);\n    })\n  );\n\n  public readonly theme$ = combineLatest([this.cdsThemeService.currentTheme$, this.widget$]).pipe(\n    map(([currentTheme, widgetConfiguration]) => {\n      return currentTheme === CurrentCarbonTheme.G10\n        ? widgetConfiguration.highContrast\n          ? CARBON_THEME.G100\n          : CARBON_THEME.G10\n        : widgetConfiguration.highContrast\n          ? CARBON_THEME.WHITE\n          : CARBON_THEME.G90;\n    })\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  private _observer!: ResizeObserver;\n\n  private _widgetUuid!: string;\n\n  constructor(\n    private readonly dossierWidgetsLayoutService: DossierWidgetsLayoutService,\n    private readonly dossierTabService: DossierTabService,\n    private readonly route: ActivatedRoute,\n    private readonly widgetsApiService: DossierWidgetsApiService,\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly renderer: Renderer2,\n    private readonly viewRef: ViewContainerRef\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this._viewContainerRefSubject$.next(this.viewRef);\n    this.openContentHeightObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n    this._observer?.disconnect();\n  }\n\n  private openContentHeightObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetBlockContentRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const widgetContentHeight = event[0]?.borderBoxSize[0]?.blockSize;\n\n    if (typeof widgetContentHeight === 'number' && widgetContentHeight !== 0) {\n      this._contentHeight$.next(widgetContentHeight);\n    }\n  }\n\n  private getPageSizeParam(widgetConfiguration: CaseWidgetWithUuid): string {\n    return `size=${(widgetConfiguration.properties as WidgetTableContent).defaultPageSize}`;\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    documentId: documentId$ | async,\n    tabKey: tabKey$ | async,\n    widgetConfiguration: widget$ | async,\n    widgetData: widgetData$ | async,\n    theme: theme$ | async,\n    blockHeightPx: blockHeightPx$ | async,\n    blockWidthPercentage: blockWidthPercentage$ | async\n  } as obs\"\n>\n  <div #widgetBlock class=\"widget-block\" [attr.data-carbon-theme]=\"obs.theme\">\n    <div #widgetBlockContent class=\"widget-block__content\">\n      @if (obs.widgetData) {\n        @switch (obs.widgetConfiguration.type) {\n          @case (CaseWidgetType.TABLE) {\n            <valtimo-widget-table\n              [documentId]=\"obs.documentId\"\n              [tabKey]=\"obs.tabKey\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-table>\n          }\n\n          @case (CaseWidgetType.COLLECTION) {\n            <valtimo-widget-collection\n              [documentId]=\"obs.documentId\"\n              [tabKey]=\"obs.tabKey\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-collection>\n          }\n\n          @case (CaseWidgetType.CUSTOM) {\n            <valtimo-widget-custom [widgetConfig]=\"obs.widgetConfiguration\"></valtimo-widget-custom>\n          }\n\n          @case (CaseWidgetType.FIELDS) {\n            <valtimo-widget-field\n              [collapseVertically]=\"true\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-field>\n          }\n\n          @case (CaseWidgetType.FORMIO) {\n            <valtimo-widget-formio\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [documentId]=\"obs.documentId\"\n            ></valtimo-widget-formio>\n          }\n\n          @default {\n            <div class=\"widget-block__not-available\">\n              <valtimo-no-results\n                [collapseVertically]=\"true\"\n                [description]=\"'dossier.widgets.noWidget' | translate\"\n                [smallPadding]=\"true\"\n              ></valtimo-no-results>\n            </div>\n          }\n        }\n      } @else {\n        <div class=\"widget-block__not-available\">\n          <valtimo-no-results\n            [collapseVertically]=\"true\"\n            [description]=\"'dossier.widgets.noData' | translate\"\n            [smallPadding]=\"true\"\n          ></valtimo-no-results>\n        </div>\n      }\n    </div>\n  </div>\n</ng-container>\n"]}
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-block.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.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 {HttpErrorResponse} from '@angular/common/http';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  Renderer2,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {\n  CARBON_THEME,\n  CarbonListModule,\n  CdsThemeService,\n  CurrentCarbonTheme,\n} from '@valtimo/components';\nimport {LoadingModule, TilesModule} from 'carbon-components-angular';\nimport {\n  BehaviorSubject,\n  catchError,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  of,\n  Subscription,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport {CaseWidgetType, CaseWidgetWithUuid, WidgetTableContent} from '../../../../../../models';\nimport {\n  DossierTabService,\n  DossierWidgetsApiService,\n  DossierWidgetsLayoutService,\n} from '../../../../../../services';\nimport {WidgetCustomComponent} from '../custom/widget-custom.component';\nimport {WidgetFieldComponent} from '../field/widget-field.component';\nimport {WidgetFormioComponent} from '../formio/widget-formio.component';\nimport {WidgetTableComponent} from '../table/widget-table.component';\nimport {WidgetCollectionComponent} from '../collection/widget-collection.component';\nimport {WIDGET_HEIGHT_1X} from '../../../../../../constants';\n\n@Component({\n  selector: 'valtimo-dossier-widget-block',\n  templateUrl: './widget-block.component.html',\n  styleUrls: ['./widget-block.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    LoadingModule,\n    WidgetTableComponent,\n    WidgetCustomComponent,\n    CarbonListModule,\n    TranslateModule,\n    TilesModule,\n    WidgetFieldComponent,\n    WidgetFormioComponent,\n    WidgetCollectionComponent,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetBlockComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('widgetBlockContent') private _widgetBlockContentRef: ElementRef<HTMLDivElement>;\n  @ViewChild('widgetBlock') private _widgetBlockRef: ElementRef<HTMLDivElement>;\n\n  @Input() public set widget(value: CaseWidgetWithUuid) {\n    this._widgetUuid = value.uuid;\n    this._widget$.next(value);\n  }\n\n  private readonly _widget$ = new BehaviorSubject<CaseWidgetWithUuid | null>(null);\n\n  public get widget$(): Observable<CaseWidgetWithUuid> {\n    return this._widget$.pipe(filter(widget => widget !== null));\n  }\n\n  private readonly _viewContainerRefSubject$ = new BehaviorSubject<ViewContainerRef | null>(null);\n\n  private get _viewContainerRef$(): Observable<ViewContainerRef> {\n    return this._viewContainerRefSubject$.pipe(filter(ref => !!ref));\n  }\n\n  private readonly _contentHeight$ = new BehaviorSubject<number>(0);\n\n  public readonly blockHeightPx$ = combineLatest([\n    this._contentHeight$,\n    this._viewContainerRef$,\n  ]).pipe(\n    filter(([contentHeight]) => contentHeight !== 0),\n    tap(([contentHeight, viewRef]) => {\n      const blockHeight = Math.ceil((contentHeight + 16) / WIDGET_HEIGHT_1X) * WIDGET_HEIGHT_1X;\n\n      this.renderer.setStyle(viewRef.element.nativeElement, 'height', `${blockHeight}px`);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    })\n  );\n\n  public readonly blockWidthPercentage$ = combineLatest([\n    this.dossierWidgetsLayoutService.amountOfColumns$,\n    this.widget$,\n    this._viewContainerRef$,\n  ]).pipe(\n    tap(([amountOfColumns, widget, viewRef]) => {\n      const percentage =\n        widget.width > amountOfColumns ? 100 : (widget.width / amountOfColumns) * 100;\n\n      this.renderer.setStyle(viewRef.element.nativeElement, 'width', `${percentage}%`);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    })\n  );\n\n  public readonly CaseWidgetType = CaseWidgetType;\n\n  public readonly documentId$ = this.route.params.pipe(\n    map(params => params?.documentId),\n    filter(documentId => !!documentId)\n  );\n\n  public readonly tabKey$: Observable<string> = this.dossierTabService.activeTabKey$;\n\n  public readonly widgetData$: Observable<any[] | {} | null> = combineLatest([\n    this.widget$,\n    this.tabKey$,\n    this.documentId$,\n  ]).pipe(\n    switchMap(([widget, tabkey, documentId]) =>\n      // custom component and formio widgets do not fetch additional data\n      widget.type === CaseWidgetType.CUSTOM || widget.type === CaseWidgetType.FORMIO\n        ? of({})\n        : this.widgetsApiService.getWidgetData(\n            documentId,\n            tabkey,\n            widget.key,\n            widget.type === CaseWidgetType.TABLE || widget.type === CaseWidgetType.COLLECTION\n              ? this.getPageSizeParam(widget)\n              : undefined\n          )\n    ),\n    tap(() => {\n      this.dossierWidgetsLayoutService.setCaseWidgetDataLoaded(this._widgetUuid);\n    }),\n    catchError((error: HttpErrorResponse) => {\n      if (error.status === 404)\n        this.dossierWidgetsLayoutService.setCaseWidgetDataLoaded(this._widgetUuid);\n\n      return of(null);\n    })\n  );\n\n  public readonly theme$ = combineLatest([this.cdsThemeService.currentTheme$, this.widget$]).pipe(\n    map(([currentTheme, widgetConfiguration]) => {\n      return currentTheme === CurrentCarbonTheme.G10\n        ? widgetConfiguration.highContrast\n          ? CARBON_THEME.G100\n          : CARBON_THEME.G10\n        : widgetConfiguration.highContrast\n          ? CARBON_THEME.WHITE\n          : CARBON_THEME.G90;\n    })\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  private _observer!: ResizeObserver;\n\n  private _widgetUuid!: string;\n\n  constructor(\n    private readonly dossierWidgetsLayoutService: DossierWidgetsLayoutService,\n    private readonly dossierTabService: DossierTabService,\n    private readonly route: ActivatedRoute,\n    private readonly widgetsApiService: DossierWidgetsApiService,\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly renderer: Renderer2,\n    private readonly viewRef: ViewContainerRef\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this._viewContainerRefSubject$.next(this.viewRef);\n    this.openContentHeightObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n    this._observer?.disconnect();\n  }\n\n  private openContentHeightObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetBlockContentRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const widgetContentHeight = event[0]?.borderBoxSize[0]?.blockSize;\n\n    if (typeof widgetContentHeight === 'number' && widgetContentHeight !== 0) {\n      this._contentHeight$.next(widgetContentHeight);\n    }\n  }\n\n  private getPageSizeParam(widgetConfiguration: CaseWidgetWithUuid): string {\n    return `size=${(widgetConfiguration.properties as WidgetTableContent).defaultPageSize}`;\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    documentId: documentId$ | async,\n    tabKey: tabKey$ | async,\n    widgetConfiguration: widget$ | async,\n    widgetData: widgetData$ | async,\n    theme: theme$ | async,\n    blockHeightPx: blockHeightPx$ | async,\n    blockWidthPercentage: blockWidthPercentage$ | async\n  } as obs\"\n>\n  <div #widgetBlock class=\"widget-block\" [attr.data-carbon-theme]=\"obs.theme\">\n    <div #widgetBlockContent class=\"widget-block__content\">\n      @if (obs.widgetData) {\n        @switch (obs.widgetConfiguration.type) {\n          @case (CaseWidgetType.TABLE) {\n            <valtimo-widget-table\n              [documentId]=\"obs.documentId\"\n              [tabKey]=\"obs.tabKey\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-table>\n          }\n\n          @case (CaseWidgetType.COLLECTION) {\n            <valtimo-widget-collection\n              [documentId]=\"obs.documentId\"\n              [tabKey]=\"obs.tabKey\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-collection>\n          }\n\n          @case (CaseWidgetType.CUSTOM) {\n            <valtimo-widget-custom [widgetConfig]=\"obs.widgetConfiguration\"></valtimo-widget-custom>\n          }\n\n          @case (CaseWidgetType.FIELDS) {\n            <valtimo-widget-field\n              [collapseVertically]=\"true\"\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [widgetData]=\"obs.widgetData\"\n            ></valtimo-widget-field>\n          }\n\n          @case (CaseWidgetType.FORMIO) {\n            <valtimo-widget-formio\n              [widgetConfiguration]=\"obs.widgetConfiguration\"\n              [documentId]=\"obs.documentId\"\n            ></valtimo-widget-formio>\n          }\n\n          @default {\n            <div class=\"widget-block__not-available\">\n              <valtimo-no-results\n                [collapseVertically]=\"true\"\n                [description]=\"'dossier.widgets.noWidget' | translate\"\n                [smallPadding]=\"true\"\n              ></valtimo-no-results>\n            </div>\n          }\n        }\n      } @else {\n        <div class=\"widget-block__not-available\">\n          <valtimo-no-results\n            [collapseVertically]=\"true\"\n            [description]=\"'dossier.widgets.noData' | translate\"\n            [smallPadding]=\"true\"\n          ></valtimo-no-results>\n        </div>\n      }\n    </div>\n  </div>\n</ng-container>\n"]}
|
|
@@ -59,10 +59,10 @@ export class WidgetsContainerComponent {
|
|
|
59
59
|
}));
|
|
60
60
|
});
|
|
61
61
|
}
|
|
62
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
63
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.
|
|
62
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetsContainerComponent, deps: [{ token: i1.DossierWidgetsLayoutService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
63
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetsContainerComponent, isStandalone: true, selector: "valtimo-dossier-widgets-container", inputs: { widgets: "widgets" }, viewQueries: [{ propertyName: "_widgetsContainerRef", first: true, predicate: ["widgetsContainer"], 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<div #widgetsContainer class=\"widgets-container\">\n @for (widget of widgetsWithUuids$ | async; track widget.uuid) {\n <valtimo-dossier-widget-block [widget]=\"widget\"></valtimo-dossier-widget-block>\n }\n</div>\n", styles: [".widgets-container{position:relative;width:calc(100% + 16px);margin-left:-8px;margin-top:-8px}\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: i2.AsyncPipe, name: "async" }, { kind: "component", type: WidgetBlockComponent, selector: "valtimo-dossier-widget-block", inputs: ["widget"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
64
64
|
}
|
|
65
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetsContainerComponent, decorators: [{
|
|
66
66
|
type: Component,
|
|
67
67
|
args: [{ selector: 'valtimo-dossier-widgets-container', standalone: true, imports: [CommonModule, WidgetBlockComponent], 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 #widgetsContainer class=\"widgets-container\">\n @for (widget of widgetsWithUuids$ | async; track widget.uuid) {\n <valtimo-dossier-widget-block [widget]=\"widget\"></valtimo-dossier-widget-block>\n }\n</div>\n", styles: [".widgets-container{position:relative;width:calc(100% + 16px);margin-left:-8px;margin-top:-8px}\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"] }]
|
|
68
68
|
}], ctorParameters: () => [{ type: i1.DossierWidgetsLayoutService }], propDecorators: { _widgetsContainerRef: [{
|
|
@@ -71,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
71
71
|
}], widgets: [{
|
|
72
72
|
type: Input
|
|
73
73
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widgets-container.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widgets-container/widgets-container.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/widgets-container/widgets-container.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAEL,uBAAuB,EACvB,SAAS,EAET,KAAK,EAEL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAE7C,OAAO,EAAC,oBAAoB,EAAC,MAAM,wCAAwC,CAAC;AAE5E,OAAO,EAAC,EAAE,IAAI,IAAI,EAAC,MAAM,MAAM,CAAC;AAChC,OAAO,EAAC,eAAe,EAAE,KAAK,EAAE,IAAI,EAAC,MAAM,MAAM,CAAC;AAClD,OAAO,KAAK,MAAM,OAAO,CAAC;;;;AAU1B,MAAM,OAAO,yBAAyB;IAKpC,IAAoB,OAAO,CAAC,KAAmB;QAC7C,MAAM,gBAAgB,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAC,GAAG,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,EAAC,CAAC,CAAC,CAAC;QAC1E,IAAI,CAAC,2BAA2B,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;QAC9D,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAChD,CAAC;IAID,YAA6B,2BAAwD;QAAxD,gCAA2B,GAA3B,2BAA2B,CAA6B;QAVrE,sBAAiB,GAAG,IAAI,eAAe,CAAuB,EAAE,CAAC,CAAC;IAUM,CAAC;IAElF,eAAe;QACpB,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;QAEhE,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,EAAE,UAAU,EAAE,CAAC;IAC/B,CAAC;IAEO,gBAAgB,CAAC,KAAiC;QACxD,MAAM,cAAc,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC;QAE9D,IAAI,OAAO,cAAc,KAAK,QAAQ,IAAI,cAAc,KAAK,CAAC,EAAE,CAAC;YAC/D,IAAI,CAAC,2BAA2B,CAAC,iBAAiB,CAAC,cAAc,CAAC,CAAC;YACnE,IAAI,CAAC,2BAA2B,CAAC,kBAAkB,EAAE,CAAC;QACxD,CAAC;IACH,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,2BAA2B,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAChF,IAAI,CAAC,2BAA2B,CAAC,QAAQ,CACvC,IAAI,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,aAAa,EAAE;gBACjD,MAAM,EAAE;oBACN,QAAQ,EAAE,IAAI;iBACf;gBACD,cAAc,EAAE,KAAK;aACtB,CAAC,CACH,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;+GAhDU,yBAAyB;mGAAzB,yBAAyB,uPCzCtC,82BAqBA,uxBDiBY,YAAY,oFAAE,oBAAoB;;4FAGjC,yBAAyB;kBARrC,SAAS;+BACE,mCAAmC,cAGjC,IAAI,WACP,CAAC,YAAY,EAAE,oBAAoB,CAAC,mBAC5B,uBAAuB,CAAC,MAAM;gGAGR,oBAAoB;sBAA1D,SAAS;uBAAC,kBAAkB;gBAIT,OAAO;sBAA1B,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  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {CaseWidget, CaseWidgetWithUuid} from '../../../../../../models';\nimport {WidgetBlockComponent} from '../widget-block/widget-block.component';\nimport {DossierWidgetsLayoutService} from '../../../../../../services';\nimport {v4 as uuid} from 'uuid';\nimport {BehaviorSubject, delay, take} from 'rxjs';\nimport Muuri from 'muuri';\n\n@Component({\n  selector: 'valtimo-dossier-widgets-container',\n  templateUrl: './widgets-container.component.html',\n  styleUrls: ['./widgets-container.component.scss'],\n  standalone: true,\n  imports: [CommonModule, WidgetBlockComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WidgetsContainerComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('widgetsContainer') private _widgetsContainerRef: ElementRef<HTMLDivElement>;\n\n  public readonly widgetsWithUuids$ = new BehaviorSubject<CaseWidgetWithUuid[]>([]);\n\n  @Input() public set widgets(value: CaseWidget[]) {\n    const widgetsWithUuids = value.map(widget => ({...widget, uuid: uuid()}));\n    this.dossierWidgetsLayoutService.setWidgets(widgetsWithUuids);\n    this.widgetsWithUuids$.next(widgetsWithUuids);\n  }\n\n  private _observer!: ResizeObserver;\n\n  constructor(private readonly dossierWidgetsLayoutService: DossierWidgetsLayoutService) {}\n\n  public ngAfterViewInit(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetsContainerRef.nativeElement);\n\n    this.initMuuri();\n  }\n\n  public ngOnDestroy(): void {\n    this._observer?.disconnect();\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const containerWidth = event[0]?.borderBoxSize[0]?.inlineSize;\n\n    if (typeof containerWidth === 'number' && containerWidth !== 0) {\n      this.dossierWidgetsLayoutService.setContainerWidth(containerWidth);\n      this.dossierWidgetsLayoutService.triggerMuuriLayout();\n    }\n  }\n\n  private initMuuri(): void {\n    this.dossierWidgetsLayoutService.loaded$.pipe(take(1), delay(300)).subscribe(() => {\n      this.dossierWidgetsLayoutService.setMuuri(\n        new Muuri(this._widgetsContainerRef.nativeElement, {\n          layout: {\n            fillGaps: true,\n          },\n          layoutOnResize: false,\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 #widgetsContainer class=\"widgets-container\">\n  @for (widget of widgetsWithUuids$ | async; track widget.uuid) {\n    <valtimo-dossier-widget-block [widget]=\"widget\"></valtimo-dossier-widget-block>\n  }\n</div>\n"]}
|
|
@@ -49,10 +49,10 @@ export class DossierDetailWidgetsComponent {
|
|
|
49
49
|
this.dossierWidgetsLayoutService.reset();
|
|
50
50
|
this.dossierTabService.enableTabHorizontalOverflow();
|
|
51
51
|
}
|
|
52
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
53
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.
|
|
52
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailWidgetsComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.DossierTabService }, { token: i2.DossierWidgetsApiService }, { token: i2.DossierWidgetsLayoutService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
53
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierDetailWidgetsComponent, isStandalone: true, selector: "ng-component", host: { properties: { "class.tab--no-margin": "this._noMargin", "class.tab--no-background": "this._noBackground", "class.tab--no-min-height": "this._noMinHeight" } }, 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 loadingWidgetConfiguration: loadingWidgetConfiguration$ | async,\n widgetConfiguration: widgetConfiguration$ | async,\n loaded: loaded$ | async\n } as obs\"\n>\n <ng-container\n *ngIf=\"{\n noWidgetsConfigured:\n obs.widgetConfiguration?.widgets && obs.widgetConfiguration.widgets.length === 0\n } as vars\"\n >\n @if (!obs.loaded && !vars.noWidgetsConfigured) {\n <div class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n }\n\n @if (vars.noWidgetsConfigured) {\n <valtimo-no-results\n [title]=\"'dossier.widgets.noWidgets' | translate\"\n [description]=\"'dossier.widgets.noWidgetsDescription' | translate\"\n illustration=\"valtimo-layout/img/no-widgets.svg\"\n ></valtimo-no-results>\n }\n\n <div [style.visibility]=\"!obs.loaded ? 'hidden' : 'visible'\">\n <valtimo-dossier-widgets-container\n [widgets]=\"obs.widgetConfiguration?.widgets || []\"\n ></valtimo-dossier-widgets-container>\n </div>\n </ng-container>\n</ng-container>\n", styles: [".loading-container{display:flex;justify-content:center;padding:16px 0}\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: LoadingModule }, { kind: "component", type: i4.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "component", type: WidgetsContainerComponent, selector: "valtimo-dossier-widgets-container", inputs: ["widgets"] }, { 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" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
54
54
|
}
|
|
55
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
55
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailWidgetsComponent, decorators: [{
|
|
56
56
|
type: Component,
|
|
57
57
|
args: [{ standalone: true, imports: [
|
|
58
58
|
CommonModule,
|
|
@@ -71,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
71
71
|
type: HostBinding,
|
|
72
72
|
args: ['class.tab--no-min-height']
|
|
73
73
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widgets.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/widgets.component.ts","../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/widgets.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAoB,MAAM,eAAe,CAAC;AAEjG,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,EAAc,SAAS,EAAE,GAAG,EAAC,MAAM,MAAM,CAAC;AAMpG,OAAO,EAAC,aAAa,EAAC,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAC,yBAAyB,EAAC,MAAM,4DAA4D,CAAC;AACrG,OAAO,EAAC,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;;;;;;;;AAepD,MAAM,OAAO,6BAA6B;IAuBxC,YACmB,KAAqB,EACrB,iBAAoC,EACpC,iBAA2C,EAC3C,2BAAwD;QAHxD,UAAK,GAAL,KAAK,CAAgB;QACrB,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,sBAAiB,GAAjB,iBAAiB,CAA0B;QAC3C,gCAA2B,GAA3B,2BAA2B,CAA6B;QA1BrB,cAAS,GAAG,IAAI,CAAC;QACb,kBAAa,GAAG,IAAI,CAAC;QACrB,iBAAY,GAAG,IAAI,CAAC;QAE7D,iBAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CACpD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC,EACjC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CACnC,CAAC;QAEe,aAAQ,GAAuB,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;QAErE,gCAA2B,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QAEjE,yBAAoB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAC3F,SAAS,CAAC,CAAC,CAAC,UAAU,EAAE,MAAM,CAAC,EAAE,EAAE,CACjC,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,UAAU,EAAE,MAAM,CAAC,CACrE,EACD,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACxD,CAAC;QAEc,YAAO,GAAG,IAAI,CAAC,2BAA2B,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IAOjF,CAAC;IAEG,QAAQ;QACb,IAAI,CAAC,iBAAiB,CAAC,4BAA4B,EAAE,CAAC;IACxD,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,2BAA2B,CAAC,KAAK,EAAE,CAAC;QACzC,IAAI,CAAC,iBAAiB,CAAC,2BAA2B,EAAE,CAAC;IACvD,CAAC;+GArCU,6BAA6B;mGAA7B,6BAA6B,+OC3C1C,0tDAkDA,iIDfI,YAAY,uLACZ,aAAa,gKACb,yBAAyB,kGACzB,gBAAgB,oPAChB,eAAe;;4FAIN,6BAA6B;kBAbzC,SAAS;iCAGI,IAAI,WACP;wBACP,YAAY;wBACZ,aAAa;wBACb,yBAAyB;wBACzB,gBAAgB;wBAChB,eAAe;qBAChB,mBACgB,uBAAuB,CAAC,MAAM;oMAGO,SAAS;sBAA9D,WAAW;uBAAC,sBAAsB;gBACuB,aAAa;sBAAtE,WAAW;uBAAC,0BAA0B;gBACmB,YAAY;sBAArE,WAAW;uBAAC,0BAA0B","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 {CommonModule} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, HostBinding, OnDestroy, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {BehaviorSubject, combineLatest, delay, filter, map, Observable, switchMap, tap} from 'rxjs';\nimport {\n  DossierTabService,\n  DossierWidgetsApiService,\n  DossierWidgetsLayoutService,\n} from '../../../../services';\nimport {LoadingModule} from 'carbon-components-angular';\nimport {WidgetsContainerComponent} from './components/widgets-container/widgets-container.component';\nimport {CarbonListModule} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\n\n@Component({\n  templateUrl: './widgets.component.html',\n  styleUrls: ['./widgets.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    LoadingModule,\n    WidgetsContainerComponent,\n    CarbonListModule,\n    TranslateModule,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DossierDetailWidgetsComponent implements OnInit, OnDestroy {\n  @HostBinding('class.tab--no-margin') private readonly _noMargin = true;\n  @HostBinding('class.tab--no-background') private readonly _noBackground = true;\n  @HostBinding('class.tab--no-min-height') private readonly _noMinHeight = true;\n\n  private readonly _documentId$ = this.route.params.pipe(\n    map(params => params?.documentId),\n    filter(documentId => !!documentId)\n  );\n\n  private readonly _tabKey$: Observable<string> = this.dossierTabService.activeTabKey$;\n\n  public readonly loadingWidgetConfiguration$ = new BehaviorSubject<boolean>(true);\n\n  public readonly widgetConfiguration$ = combineLatest([this._documentId$, this._tabKey$]).pipe(\n    switchMap(([documentId, tabKey]) =>\n      this.widgetsApiService.getWidgetTabConfiguration(documentId, tabKey)\n    ),\n    tap(() => this.loadingWidgetConfiguration$.next(false))\n  );\n\n  public readonly loaded$ = this.dossierWidgetsLayoutService.loaded$.pipe(delay(400));\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly dossierTabService: DossierTabService,\n    private readonly widgetsApiService: DossierWidgetsApiService,\n    private readonly dossierWidgetsLayoutService: DossierWidgetsLayoutService\n  ) {}\n\n  public ngOnInit(): void {\n    this.dossierTabService.disableTabHorizontalOverflow();\n  }\n\n  public ngOnDestroy(): void {\n    this.dossierWidgetsLayoutService.reset();\n    this.dossierTabService.enableTabHorizontalOverflow();\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    loadingWidgetConfiguration: loadingWidgetConfiguration$ | async,\n    widgetConfiguration: widgetConfiguration$ | async,\n    loaded: loaded$ | async\n  } as obs\"\n>\n  <ng-container\n    *ngIf=\"{\n      noWidgetsConfigured:\n        obs.widgetConfiguration?.widgets && obs.widgetConfiguration.widgets.length === 0\n    } as vars\"\n  >\n    @if (!obs.loaded && !vars.noWidgetsConfigured) {\n      <div class=\"loading-container\">\n        <cds-loading></cds-loading>\n      </div>\n    }\n\n    @if (vars.noWidgetsConfigured) {\n      <valtimo-no-results\n        [title]=\"'dossier.widgets.noWidgets' | translate\"\n        [description]=\"'dossier.widgets.noWidgetsDescription' | translate\"\n        illustration=\"valtimo-layout/img/no-widgets.svg\"\n      ></valtimo-no-results>\n    }\n\n    <div [style.visibility]=\"!obs.loaded ? 'hidden' : 'visible'\">\n      <valtimo-dossier-widgets-container\n        [widgets]=\"obs.widgetConfiguration?.widgets || []\"\n      ></valtimo-dossier-widgets-container>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
|