@valtimo/dossier 12.3.1 → 12.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dossier-assign-user/dossier-assign-user.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/dossier-detail.component.mjs +149 -24
- package/esm2022/lib/components/dossier-detail/tab/formio/formio.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/tab/notes/notes.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/tab/progress/progress.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/tab/summary/summary.component.mjs +1 -1
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/field/widget-field.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/formio/widget-formio.component.mjs +1 -1
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/table/widget-table.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/tab/widgets/components/widget-block/widget-block.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail/tab/widgets/widgets.component.mjs +3 -3
- package/esm2022/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.mjs +104 -0
- package/esm2022/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.mjs +34 -15
- package/esm2022/lib/components/dossier-list/dossier-list.component.mjs +3 -3
- package/esm2022/lib/components/dossier-list-actions/dossier-list-actions.component.mjs +1 -1
- package/esm2022/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.mjs +21 -6
- package/esm2022/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +3 -3
- package/esm2022/lib/constants/dossier-detail-layout.constants.mjs +13 -0
- package/esm2022/lib/constants/index.mjs +2 -1
- package/esm2022/lib/dossier-routing.module.mjs +3 -1
- package/esm2022/lib/dossier.module.mjs +12 -4
- package/esm2022/lib/models/dossier-detail-layout.model.mjs +2 -0
- package/esm2022/lib/models/index.mjs +2 -1
- package/esm2022/lib/models/tabs.model.mjs +13 -23
- package/esm2022/lib/services/dossier-detail-layout.service.mjs +93 -0
- package/esm2022/lib/services/dossier-tab.service.mjs +2 -2
- package/esm2022/lib/services/index.mjs +2 -1
- package/esm2022/public_api.mjs +2 -1
- package/fesm2022/valtimo-dossier.mjs +445 -105
- package/fesm2022/valtimo-dossier.mjs.map +1 -1
- package/lib/components/dossier-detail/dossier-detail.component.d.ts +44 -13
- package/lib/components/dossier-detail/dossier-detail.component.d.ts.map +1 -1
- package/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.d.ts +38 -0
- package/lib/components/dossier-detail-task-detail/dossier-detail-task-detail.component.d.ts.map +1 -0
- package/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.d.ts +17 -4
- package/lib/components/dossier-detail-task-list/dossier-detail-task-list.component.d.ts.map +1 -1
- package/lib/components/dossier-list-actions/dossier-list-actions.component.d.ts.map +1 -1
- package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts +4 -3
- package/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
- package/lib/constants/dossier-detail-layout.constants.d.ts +10 -0
- package/lib/constants/dossier-detail-layout.constants.d.ts.map +1 -0
- package/lib/constants/index.d.ts +1 -0
- package/lib/constants/index.d.ts.map +1 -1
- package/lib/dossier-routing.module.d.ts.map +1 -1
- package/lib/dossier.module.d.ts +3 -1
- package/lib/dossier.module.d.ts.map +1 -1
- package/lib/models/dossier-detail-layout.model.d.ts +18 -0
- package/lib/models/dossier-detail-layout.model.d.ts.map +1 -0
- package/lib/models/index.d.ts +1 -0
- package/lib/models/index.d.ts.map +1 -1
- package/lib/models/tabs.model.d.ts +2 -2
- package/lib/models/tabs.model.d.ts.map +1 -1
- package/lib/services/dossier-detail-layout.service.d.ts +29 -0
- package/lib/services/dossier-detail-layout.service.d.ts.map +1 -0
- package/lib/services/dossier-tab.service.d.ts.map +1 -1
- package/lib/services/index.d.ts +1 -0
- package/lib/services/index.d.ts.map +1 -1
- package/package.json +3 -2
- package/public_api.d.ts +1 -0
- package/public_api.d.ts.map +1 -1
|
@@ -52,10 +52,10 @@ export class DossierDetailTabFormioComponent {
|
|
|
52
52
|
}));
|
|
53
53
|
}
|
|
54
54
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabFormioComponent, deps: [{ token: i1.DossierTabService }, { token: i2.ActivatedRoute }, { token: i3.FormService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
55
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailTabFormioComponent, selector: "ng-component", 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 prefilledForm: prefilledForm$ | async,\n loading: loading$ | async,\n formNotFound: formNotFound$ | async,\n noFormSpecified: noFormSpecified$ | async
|
|
55
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailTabFormioComponent, selector: "ng-component", 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 prefilledForm: prefilledForm$ | async,\n loading: loading$ | async,\n formNotFound: formNotFound$ | async,\n noFormSpecified: noFormSpecified$ | async,\n } as obs\"\n>\n <div *ngIf=\"obs.loading\" class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n\n <p *ngIf=\"obs.formNotFound\" class=\"error-message\">\n {{ 'dossier.formio.formNotFound' | translate: {formDefinitionName: obs.formNotFound} }}\n </p>\n\n <p *ngIf=\"obs.noFormSpecified\" class=\"error-message\">\n {{ 'dossier.formio.noFormSpecified' | translate }}\n </p>\n\n <valtimo-form-io *ngIf=\"obs.prefilledForm\" [form]=\"obs.prefilledForm\"> </valtimo-form-io>\n</ng-container>\n", styles: [".loading-container{display:flex;width:100%;flex-direction:row;justify-content:center}.error-message{text-align:center}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }, { kind: "component", type: i6.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
56
56
|
}
|
|
57
57
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabFormioComponent, decorators: [{
|
|
58
58
|
type: Component,
|
|
59
|
-
args: [{ 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<ng-container\n *ngIf=\"{\n prefilledForm: prefilledForm$ | async,\n loading: loading$ | async,\n formNotFound: formNotFound$ | async,\n noFormSpecified: noFormSpecified$ | async
|
|
59
|
+
args: [{ 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<ng-container\n *ngIf=\"{\n prefilledForm: prefilledForm$ | async,\n loading: loading$ | async,\n formNotFound: formNotFound$ | async,\n noFormSpecified: noFormSpecified$ | async,\n } as obs\"\n>\n <div *ngIf=\"obs.loading\" class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n\n <p *ngIf=\"obs.formNotFound\" class=\"error-message\">\n {{ 'dossier.formio.formNotFound' | translate: {formDefinitionName: obs.formNotFound} }}\n </p>\n\n <p *ngIf=\"obs.noFormSpecified\" class=\"error-message\">\n {{ 'dossier.formio.noFormSpecified' | translate }}\n </p>\n\n <valtimo-form-io *ngIf=\"obs.prefilledForm\" [form]=\"obs.prefilledForm\"> </valtimo-form-io>\n</ng-container>\n", styles: [".loading-container{display:flex;width:100%;flex-direction:row;justify-content:center}.error-message{text-align:center}\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"] }]
|
|
60
60
|
}], ctorParameters: () => [{ type: i1.DossierTabService }, { type: i2.ActivatedRoute }, { type: i3.FormService }] });
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWlvLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vZG9zc2llci9zcmMvbGliL2NvbXBvbmVudHMvZG9zc2llci1kZXRhaWwvdGFiL2Zvcm1pby9mb3JtaW8uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGltby9kb3NzaWVyL3NyYy9saWIvY29tcG9uZW50cy9kb3NzaWVyLWRldGFpbC90YWIvZm9ybWlvL2Zvcm1pby5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUVILE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFJakUsT0FBTyxFQUFDLGVBQWUsRUFBRSxhQUFhLEVBQWMsRUFBRSxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFFcEYsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7Ozs7QUFPMUMsTUFBTSxPQUFPLCtCQUErQjtJQThCMUMsWUFDbUIsVUFBNkIsRUFDN0IsS0FBcUIsRUFDckIsV0FBd0I7UUFGeEIsZUFBVSxHQUFWLFVBQVUsQ0FBbUI7UUFDN0IsVUFBSyxHQUFMLEtBQUssQ0FBZ0I7UUFDckIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFoQzNCLGFBQVEsR0FBRyxJQUFJLGVBQWUsQ0FBVSxJQUFJLENBQUMsQ0FBQztRQUM5QyxrQkFBYSxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBQ2hELHFCQUFnQixHQUFHLElBQUksZUFBZSxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBRXZELG1CQUFjLEdBQWtDLGFBQWEsQ0FBQztZQUM1RSxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUs7WUFDckIsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNO1NBQ2xCLENBQUMsQ0FBQyxJQUFJLENBQ0wsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLEVBQUUsRUFBRTtZQUMzQixNQUFNLGNBQWMsR0FBRyxNQUFNLEVBQUUsR0FBRyxDQUFDO1lBQ25DLE1BQU0sVUFBVSxHQUFHLE1BQU0sRUFBRSxVQUFVLENBQUM7WUFDdEMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEtBQUssY0FBYyxDQUFDLENBQUM7WUFFakUsSUFBSSxDQUFDLFVBQVUsSUFBSSxDQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUUsQ0FBQztnQkFDM0MsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDakMsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDbEIsQ0FBQztZQUVELElBQUksQ0FBQyxtQkFBbUIsR0FBRyxVQUFVLENBQUMsVUFBVSxDQUFDO1lBQ2pELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxnQ0FBZ0MsQ0FBQyxVQUFVLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzlGLENBQUMsQ0FBQyxFQUNGLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUNwQyxVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLENBQUM7WUFDbEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDMUIsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbEIsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQU1DLENBQUM7K0dBbENPLCtCQUErQjttR0FBL0IsK0JBQStCLG9EQzdCNUMsKzFDQXNDQTs7NEZEVGEsK0JBQStCO2tCQUwzQyxTQUFTO3NDQUdTLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gKlxuICogTGljZW5zZWQgdW5kZXIgRVVQTCwgVmVyc2lvbiAxLjIgKHRoZSBcIkxpY2Vuc2VcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuXG5pbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtEb3NzaWVyVGFiU2VydmljZX0gZnJvbSAnLi4vLi4vLi4vLi4vc2VydmljZXMnO1xuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7Rm9ybVNlcnZpY2V9IGZyb20gJ0B2YWx0aW1vL2Zvcm0nO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIGNvbWJpbmVMYXRlc3QsIE9ic2VydmFibGUsIG9mLCBzd2l0Y2hNYXAsIHRhcH0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0Zvcm1pb0Zvcm19IGZyb20gJ0Bmb3JtaW8vYW5ndWxhcic7XG5pbXBvcnQge2NhdGNoRXJyb3J9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlVXJsOiAnLi9mb3JtaW8uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9mb3JtaW8uY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIERvc3NpZXJEZXRhaWxUYWJGb3JtaW9Db21wb25lbnQge1xuICBwdWJsaWMgcmVhZG9ubHkgbG9hZGluZyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KHRydWUpO1xuICBwdWJsaWMgcmVhZG9ubHkgZm9ybU5vdEZvdW5kJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignJyk7XG4gIHB1YmxpYyByZWFkb25seSBub0Zvcm1TcGVjaWZpZWQkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XG4gIHByaXZhdGUgX2Zvcm1EZWZpbml0aW9uTmFtZSE6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IHByZWZpbGxlZEZvcm0kOiBPYnNlcnZhYmxlPEZvcm1pb0Zvcm0gfCBudWxsPiA9IGNvbWJpbmVMYXRlc3QoW1xuICAgIHRoaXMudGFiU2VydmljZS50YWJzJCxcbiAgICB0aGlzLnJvdXRlLnBhcmFtcyxcbiAgXSkucGlwZShcbiAgICBzd2l0Y2hNYXAoKFt0YWJzLCBwYXJhbXNdKSA9PiB7XG4gICAgICBjb25zdCBjdXJyZW50VGFiTmFtZSA9IHBhcmFtcz8udGFiO1xuICAgICAgY29uc3QgZG9jdW1lbnRJZCA9IHBhcmFtcz8uZG9jdW1lbnRJZDtcbiAgICAgIGNvbnN0IGN1cnJlbnRUYWIgPSB0YWJzLmZpbmQodGFiID0+IHRhYi5uYW1lID09PSBjdXJyZW50VGFiTmFtZSk7XG5cbiAgICAgIGlmICghZG9jdW1lbnRJZCB8fCAhY3VycmVudFRhYj8uY29udGVudEtleSkge1xuICAgICAgICB0aGlzLm5vRm9ybVNwZWNpZmllZCQubmV4dCh0cnVlKTtcbiAgICAgICAgcmV0dXJuIG9mKG51bGwpO1xuICAgICAgfVxuXG4gICAgICB0aGlzLl9mb3JtRGVmaW5pdGlvbk5hbWUgPSBjdXJyZW50VGFiLmNvbnRlbnRLZXk7XG4gICAgICByZXR1cm4gdGhpcy5mb3JtU2VydmljZS5nZXRGb3JtRGVmaW5pdGlvbkJ5TmFtZVByZUZpbGxlZChjdXJyZW50VGFiLmNvbnRlbnRLZXksIGRvY3VtZW50SWQpO1xuICAgIH0pLFxuICAgIHRhcCgoKSA9PiB0aGlzLmxvYWRpbmckLm5leHQoZmFsc2UpKSxcbiAgICBjYXRjaEVycm9yKCgpID0+IHtcbiAgICAgIHRoaXMuZm9ybU5vdEZvdW5kJC5uZXh0KHRoaXMuX2Zvcm1EZWZpbml0aW9uTmFtZSk7XG4gICAgICB0aGlzLmxvYWRpbmckLm5leHQoZmFsc2UpO1xuICAgICAgcmV0dXJuIG9mKG51bGwpO1xuICAgIH0pXG4gICk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZWFkb25seSB0YWJTZXJ2aWNlOiBEb3NzaWVyVGFiU2VydmljZSxcbiAgICBwcml2YXRlIHJlYWRvbmx5IHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSxcbiAgICBwcml2YXRlIHJlYWRvbmx5IGZvcm1TZXJ2aWNlOiBGb3JtU2VydmljZVxuICApIHt9XG59XG4iLCI8IS0tXG4gIH4gQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gIH5cbiAgfiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAgfiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gIH4gWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gIH5cbiAgfiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gIH5cbiAgfiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gIH4gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICB+IFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICB+IFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAgfiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAgLS0+XG5cbjxuZy1jb250YWluZXJcbiAgKm5nSWY9XCJ7XG4gICAgcHJlZmlsbGVkRm9ybTogcHJlZmlsbGVkRm9ybSQgfCBhc3luYyxcbiAgICBsb2FkaW5nOiBsb2FkaW5nJCB8IGFzeW5jLFxuICAgIGZvcm1Ob3RGb3VuZDogZm9ybU5vdEZvdW5kJCB8IGFzeW5jLFxuICAgIG5vRm9ybVNwZWNpZmllZDogbm9Gb3JtU3BlY2lmaWVkJCB8IGFzeW5jLFxuICB9IGFzIG9ic1wiXG4+XG4gIDxkaXYgKm5nSWY9XCJvYnMubG9hZGluZ1wiIGNsYXNzPVwibG9hZGluZy1jb250YWluZXJcIj5cbiAgICA8Y2RzLWxvYWRpbmc+PC9jZHMtbG9hZGluZz5cbiAgPC9kaXY+XG5cbiAgPHAgKm5nSWY9XCJvYnMuZm9ybU5vdEZvdW5kXCIgY2xhc3M9XCJlcnJvci1tZXNzYWdlXCI+XG4gICAge3sgJ2Rvc3NpZXIuZm9ybWlvLmZvcm1Ob3RGb3VuZCcgfCB0cmFuc2xhdGU6IHtmb3JtRGVmaW5pdGlvbk5hbWU6IG9icy5mb3JtTm90Rm91bmR9IH19XG4gIDwvcD5cblxuICA8cCAqbmdJZj1cIm9icy5ub0Zvcm1TcGVjaWZpZWRcIiBjbGFzcz1cImVycm9yLW1lc3NhZ2VcIj5cbiAgICB7eyAnZG9zc2llci5mb3JtaW8ubm9Gb3JtU3BlY2lmaWVkJyB8IHRyYW5zbGF0ZSB9fVxuICA8L3A+XG5cbiAgPHZhbHRpbW8tZm9ybS1pbyAqbmdJZj1cIm9icy5wcmVmaWxsZWRGb3JtXCIgW2Zvcm1dPVwib2JzLnByZWZpbGxlZEZvcm1cIj4gPC92YWx0aW1vLWZvcm0taW8+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -159,13 +159,13 @@ export class DossierDetailTabNotesComponent {
|
|
|
159
159
|
});
|
|
160
160
|
}
|
|
161
161
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabNotesComponent, deps: [{ token: i1.NotesService }, { token: i2.PermissionService }, { token: i3.PromptService }, { token: i4.ActivatedRoute }, { token: i5.ToastrService }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
162
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailTabNotesComponent, selector: "valtimo-dossier-detail-tab-notes", host: { properties: { "class.tab--no-margin": "this.noMargin" } }, 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<ng-container\n *ngIf=\"{\n canAdd: canAdd$ | async,\n notes: notes$ | async,\n pagination: pagination$ | async,\n loading: loading$ | async
|
|
162
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailTabNotesComponent, selector: "valtimo-dossier-detail-tab-notes", host: { properties: { "class.tab--no-margin": "this.noMargin" } }, 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<ng-container\n *ngIf=\"{\n canAdd: canAdd$ | async,\n notes: notes$ | async,\n pagination: pagination$ | async,\n loading: loading$ | async,\n } as obs\"\n>\n <div class=\"cds--toolbar-content\">\n <button\n cdsButton=\"primary\"\n *ngIf=\"obs.canAdd\"\n [disabled]=\"obs.loading\"\n (click)=\"showAddModal()\"\n aria-expanded=\"false\"\n aria-haspopup=\"true\"\n >\n {{ 'dossier.notes.addNote' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n </button>\n </div>\n\n <div *ngIf=\"timelineItems\">\n <valtimo-timeline\n *ngIf=\"timelineItems.length > 0\"\n [actions]=\"actions\"\n [items]=\"timelineItems\"\n ></valtimo-timeline>\n <valtimo-no-results\n *ngIf=\"timelineItems.length === 0\"\n [description]=\"'dossier.notes.noResults.description' | translate\"\n [title]=\"'dossier.notes.noResults.title' | translate\"\n illustration=\"valtimo-layout/img/emptystate-no-result.svg\"\n ></valtimo-no-results>\n </div>\n\n <valtimo-spinner\n [useBootstrapSpinner]=\"false\"\n name=\"auditSpinner\"\n bdColor=\"rgba(125, 125, 125, 0.35)\"\n color=\"#264251\"\n type=\"square-jelly-box\"\n >\n </valtimo-spinner>\n\n <div *ngIf=\"obs.pagination\" class=\"d-flex justify-content-end row mr-0 ml-0\">\n <ngb-pagination\n *ngIf=\"obs.pagination.collectionSize > obs.pagination.size\"\n [collectionSize]=\"obs.pagination.collectionSize\"\n [maxSize]=\"obs.pagination.size\"\n [pageSize]=\"obs.pagination.size\"\n [rotate]=\"true\"\n [(page)]=\"obs.pagination.page\"\n (pageChange)=\"paginationClicked($event)\"\n ></ngb-pagination>\n </div>\n</ng-container>\n\n<valtimo-note-modal\n [customData]=\"customData$ | async\"\n (createNoteEvent)=\"createNewNote($event)\"\n (editNoteEvent)=\"editNoteEvent($event)\"\n></valtimo-note-modal>\n", styles: [":host{display:flex;flex-direction:column}.add-note{align-self:flex-end}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.TimelineComponent, selector: "valtimo-timeline", inputs: ["items", "actions"] }, { kind: "component", type: i3.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "component", type: i8.NgbPagination, selector: "ngb-pagination", inputs: ["disabled", "boundaryLinks", "directionLinks", "ellipses", "rotate", "collectionSize", "maxSize", "page", "pageSize", "size"], outputs: ["pageChange"] }, { kind: "directive", type: i9.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "directive", type: i9.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "component", type: i3.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "component", type: i10.NoteModalComponent, selector: "valtimo-note-modal", inputs: ["customData"], outputs: ["createNoteEvent", "editNoteEvent"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] }); }
|
|
163
163
|
}
|
|
164
164
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabNotesComponent, decorators: [{
|
|
165
165
|
type: Component,
|
|
166
|
-
args: [{ selector: 'valtimo-dossier-detail-tab-notes', 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<ng-container\n *ngIf=\"{\n canAdd: canAdd$ | async,\n notes: notes$ | async,\n pagination: pagination$ | async,\n loading: loading$ | async
|
|
166
|
+
args: [{ selector: 'valtimo-dossier-detail-tab-notes', 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<ng-container\n *ngIf=\"{\n canAdd: canAdd$ | async,\n notes: notes$ | async,\n pagination: pagination$ | async,\n loading: loading$ | async,\n } as obs\"\n>\n <div class=\"cds--toolbar-content\">\n <button\n cdsButton=\"primary\"\n *ngIf=\"obs.canAdd\"\n [disabled]=\"obs.loading\"\n (click)=\"showAddModal()\"\n aria-expanded=\"false\"\n aria-haspopup=\"true\"\n >\n {{ 'dossier.notes.addNote' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n </button>\n </div>\n\n <div *ngIf=\"timelineItems\">\n <valtimo-timeline\n *ngIf=\"timelineItems.length > 0\"\n [actions]=\"actions\"\n [items]=\"timelineItems\"\n ></valtimo-timeline>\n <valtimo-no-results\n *ngIf=\"timelineItems.length === 0\"\n [description]=\"'dossier.notes.noResults.description' | translate\"\n [title]=\"'dossier.notes.noResults.title' | translate\"\n illustration=\"valtimo-layout/img/emptystate-no-result.svg\"\n ></valtimo-no-results>\n </div>\n\n <valtimo-spinner\n [useBootstrapSpinner]=\"false\"\n name=\"auditSpinner\"\n bdColor=\"rgba(125, 125, 125, 0.35)\"\n color=\"#264251\"\n type=\"square-jelly-box\"\n >\n </valtimo-spinner>\n\n <div *ngIf=\"obs.pagination\" class=\"d-flex justify-content-end row mr-0 ml-0\">\n <ngb-pagination\n *ngIf=\"obs.pagination.collectionSize > obs.pagination.size\"\n [collectionSize]=\"obs.pagination.collectionSize\"\n [maxSize]=\"obs.pagination.size\"\n [pageSize]=\"obs.pagination.size\"\n [rotate]=\"true\"\n [(page)]=\"obs.pagination.page\"\n (pageChange)=\"paginationClicked($event)\"\n ></ngb-pagination>\n </div>\n</ng-container>\n\n<valtimo-note-modal\n [customData]=\"customData$ | async\"\n (createNoteEvent)=\"createNewNote($event)\"\n (editNoteEvent)=\"editNoteEvent($event)\"\n></valtimo-note-modal>\n", styles: [":host{display:flex;flex-direction:column}.add-note{align-self:flex-end}\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"] }]
|
|
167
167
|
}], ctorParameters: () => [{ type: i1.NotesService }, { type: i2.PermissionService }, { type: i3.PromptService }, { type: i4.ActivatedRoute }, { type: i5.ToastrService }, { type: i6.TranslateService }], propDecorators: { noMargin: [{
|
|
168
168
|
type: HostBinding,
|
|
169
169
|
args: ['class.tab--no-margin']
|
|
170
170
|
}] } });
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notes.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/notes/notes.component.ts","../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/notes/notes.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 {Component, HostBinding, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateService} from '@ngx-translate/core';\nimport {PermissionService} from '@valtimo/access-control';\nimport {Pagination, PromptService, TimelineItem, TimelineItemImpl} from '@valtimo/components';\nimport {Page} from '@valtimo/config';\nimport moment from 'moment';\nimport {ToastrService} from 'ngx-toastr';\nimport {BehaviorSubject, combineLatest, map, Observable, of} from 'rxjs';\nimport {switchMap, take, tap} from 'rxjs/operators';\nimport {Note} from '../../../../models/notes.model';\nimport {\n  CAN_ADD_NOTE_PERMISSION,\n  CAN_DELETE_NOTE_PERMISSION,\n  CAN_EDIT_NOTE_PERMISSION,\n  DOSSIER_DETAIL_PERMISSION_RESOURCE,\n} from '../../../../permissions';\nimport {NotesService} from '../../../../services/notes.service';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-notes',\n  templateUrl: './notes.component.html',\n  styleUrls: ['./notes.component.scss'],\n})\nexport class DossierDetailTabNotesComponent implements OnInit {\n  @HostBinding('class.tab--no-margin') noMargin = true;\n\n  public timelineItems: TimelineItem[] = [];\n\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n  public readonly fields$ = new BehaviorSubject<Array<{key: string; label: string}>>([]);\n  public readonly customData$ = new BehaviorSubject<object>({});\n\n  private readonly documentId$ = this.route.params.pipe(map(params => params.documentId));\n  public readonly actions = [\n    {id: 'edit', label: 'Edit', icon: 'mdi-pencil', callback: this.editNote.bind(this)},\n    {id: 'delete', label: 'Delete', icon: 'mdi-delete', callback: this.deleteNote.bind(this)},\n  ];\n\n  public readonly canAdd$: Observable<boolean> = this.documentId$.pipe(\n    switchMap((identifier: string) =>\n      this.permissionService.requestPermission(CAN_ADD_NOTE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier,\n      })\n    )\n  );\n\n  public readonly currentPageAndSize$ = new BehaviorSubject<Partial<Pagination>>({\n    page: 0,\n    size: 10,\n  });\n\n  public readonly pageSizes$ = new BehaviorSubject<Partial<Pagination>>({\n    collectionSize: 0,\n  });\n\n  public readonly pagination$: Observable<Pagination> = combineLatest([\n    this.currentPageAndSize$,\n    this.pageSizes$,\n  ]).pipe(\n    map(\n      ([currentPage, sizes]) =>\n        ({...currentPage, ...sizes, page: (currentPage.page ?? 0) + 1}) as Pagination\n    )\n  );\n\n  public readonly notes$: Observable<Array<Note>> = combineLatest([\n    this.documentId$,\n    this.currentPageAndSize$,\n    this.notesService.refresh$,\n    this.notesService.refresh$,\n  ]).pipe(\n    tap(() => (this.timelineItems = [])),\n    switchMap(([documentId, currentPage]) =>\n      this.notesService.getDocumentNotes(documentId, {\n        page: currentPage.page,\n        size: currentPage.size,\n      })\n    ),\n    tap((res: Page<Note>) => {\n      this.timelineItems = [];\n      this.pageSizes$.pipe(take(1)).subscribe(sizes => {\n        this.pageSizes$.next({...sizes, collectionSize: res.totalElements});\n      });\n    }),\n    switchMap(res =>\n      combineLatest([\n        of(res),\n        ...res.content.map(note =>\n          this.permissionService.requestPermission(CAN_DELETE_NOTE_PERMISSION, {\n            resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.note,\n            identifier: note.id,\n          })\n        ),\n        ...res.content.map(note =>\n          this.permissionService.requestPermission(CAN_EDIT_NOTE_PERMISSION, {\n            resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.note,\n            identifier: note.id,\n          })\n        ),\n      ])\n    ),\n    map(combinedResults => {\n      const permissionResults = combinedResults.filter((curr, index) => index !== 0);\n      const halfIndex = Math.ceil(permissionResults.length / 2);\n      const deletePermissions = permissionResults.slice(0, halfIndex);\n      const editPermissions = permissionResults.slice(halfIndex);\n\n      return combinedResults[0].content.map((note: Note, index) => {\n        const noteCreatedDate = moment(note.createdDate).locale(this.translateService.currentLang);\n        this.timelineItems.push(\n          new TimelineItemImpl(\n            noteCreatedDate.format('DD MMM YYYY'),\n            noteCreatedDate.format('HH:mm'),\n            note.createdByUserFullName,\n            noteCreatedDate.fromNow(),\n            note.content,\n            {},\n            {id: note.id},\n            [\n              ...(deletePermissions[index] ? ['delete'] : []),\n              ...(editPermissions[index] ? ['edit'] : []),\n            ]\n          )\n        );\n        return {\n          ...note,\n        };\n      });\n    }),\n    tap(() => this.loading$.next(false))\n  );\n\n  constructor(\n    private readonly notesService: NotesService,\n    private readonly permissionService: PermissionService,\n    private readonly promptService: PromptService,\n    private readonly route: ActivatedRoute,\n    private readonly toastrService: ToastrService,\n    private readonly translateService: TranslateService\n  ) {}\n\n  public ngOnInit(): void {\n    this.translateService.onLangChange.subscribe(() => {\n      this.notesService.refresh();\n    });\n  }\n\n  public paginationClicked(newPageNumber): void {\n    this.currentPageAndSize$.pipe(take(1)).subscribe(currentPage => {\n      this.currentPageAndSize$.next({...currentPage, page: newPageNumber - 1});\n    });\n  }\n\n  public showAddModal(): void {\n    this.customData$.next({});\n    this.notesService.setModalType('add');\n    this.notesService.showModal();\n  }\n\n  public createNewNote(content): void {\n    this.documentId$\n      .pipe(\n        take(1),\n        switchMap((documentId: string) => this.notesService.createDocumentNote(documentId, content))\n      )\n      .subscribe(() => {\n        this.notesService.refresh();\n        this.notesService.hideModal();\n      });\n  }\n\n  public editNoteEvent(content): void {\n    this.notesService.updateNote(content.data.customData.id, content.formData).subscribe(() => {\n      this.notesService.refresh();\n      this.notesService.hideModal();\n      this.toastrService.success(this.translateService.instant('dossier.notes.editedMessage'));\n    });\n  }\n\n  public editNote(data): void {\n    this.customData$.next(data);\n    this.notesService.setModalType('modify');\n    this.notesService.showModal();\n  }\n\n  public deleteNote(data): void {\n    this.promptService.openPrompt({\n      headerText: this.translateService.instant('dossier.notes.deleteConfirmation.title'),\n      bodyText: this.translateService.instant('dossier.notes.deleteConfirmation.description'),\n      cancelButtonText: this.translateService.instant('dossier.deleteConfirmation.cancel'),\n      confirmButtonText: this.translateService.instant('dossier.deleteConfirmation.delete'),\n      cancelMdiIcon: 'cancel',\n      confirmMdiIcon: 'delete',\n      cancelButtonType: 'secondary',\n      confirmButtonType: 'primary',\n      closeOnConfirm: true,\n      closeOnCancel: true,\n      confirmCallBackFunction: () => {\n        this.notesService.deleteNote(data.customData.id).subscribe(() => {\n          this.notesService.refresh();\n          this.toastrService.success(\n            this.translateService.instant('dossier.notes.deleteConfirmation.deletedMessage')\n          );\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<ng-container\n  *ngIf=\"{\n    canAdd: canAdd$ | async,\n    notes: notes$ | async,\n    pagination: pagination$ | async,\n    loading: loading$ | async\n  } as obs\"\n>\n  <div class=\"cds--toolbar-content\">\n    <button\n      cdsButton=\"primary\"\n      *ngIf=\"obs.canAdd\"\n      [disabled]=\"obs.loading\"\n      (click)=\"showAddModal()\"\n      aria-expanded=\"false\"\n      aria-haspopup=\"true\"\n    >\n      {{ 'dossier.notes.addNote' | translate }}\n\n      <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n    </button>\n  </div>\n\n  <div *ngIf=\"timelineItems\">\n    <valtimo-timeline\n      *ngIf=\"timelineItems.length > 0\"\n      [actions]=\"actions\"\n      [items]=\"timelineItems\"\n    ></valtimo-timeline>\n    <valtimo-no-results\n      *ngIf=\"timelineItems.length === 0\"\n      [description]=\"'dossier.notes.noResults.description' | translate\"\n      [title]=\"'dossier.notes.noResults.title' | translate\"\n      illustration=\"valtimo-layout/img/emptystate-no-result.svg\"\n    ></valtimo-no-results>\n  </div>\n\n  <valtimo-spinner\n    [useBootstrapSpinner]=\"false\"\n    name=\"auditSpinner\"\n    bdColor=\"rgba(125, 125, 125, 0.35)\"\n    color=\"#264251\"\n    type=\"square-jelly-box\"\n  >\n  </valtimo-spinner>\n\n  <div *ngIf=\"obs.pagination\" class=\"d-flex justify-content-end row mr-0 ml-0\">\n    <ngb-pagination\n      *ngIf=\"obs.pagination.collectionSize > obs.pagination.size\"\n      [collectionSize]=\"obs.pagination.collectionSize\"\n      [maxSize]=\"obs.pagination.size\"\n      [pageSize]=\"obs.pagination.size\"\n      [rotate]=\"true\"\n      [(page)]=\"obs.pagination.page\"\n      (pageChange)=\"paginationClicked($event)\"\n    ></ngb-pagination>\n  </div>\n</ng-container>\n\n<valtimo-note-modal\n  [customData]=\"customData$ | async\"\n  (createNoteEvent)=\"createNewNote($event)\"\n  (editNoteEvent)=\"editNoteEvent($event)\"\n></valtimo-note-modal>\n"]}
|
|
171
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notes.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/notes/notes.component.ts","../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/notes/notes.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EAAC,SAAS,EAAE,WAAW,EAAS,MAAM,eAAe,CAAC;AAI7D,OAAO,EAA0C,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AAE9F,OAAO,MAAM,MAAM,QAAQ,CAAC;AAE5B,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,GAAG,EAAc,EAAE,EAAC,MAAM,MAAM,CAAC;AACzE,OAAO,EAAC,SAAS,EAAE,IAAI,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAEpD,OAAO,EACL,uBAAuB,EACvB,0BAA0B,EAC1B,wBAAwB,EACxB,kCAAkC,GACnC,MAAM,yBAAyB,CAAC;;;;;;;;;;;;AAQjC,MAAM,OAAO,8BAA8B;IA8GzC,YACmB,YAA0B,EAC1B,iBAAoC,EACpC,aAA4B,EAC5B,KAAqB,EACrB,aAA4B,EAC5B,gBAAkC;QALlC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,kBAAa,GAAb,aAAa,CAAe;QAC5B,UAAK,GAAL,KAAK,CAAgB;QACrB,kBAAa,GAAb,aAAa,CAAe;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAnHhB,aAAQ,GAAG,IAAI,CAAC;QAE9C,kBAAa,GAAmB,EAAE,CAAC;QAE1B,aAAQ,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QAC9C,YAAO,GAAG,IAAI,eAAe,CAAsC,EAAE,CAAC,CAAC;QACvE,gBAAW,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAE7C,gBAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;QACxE,YAAO,GAAG;YACxB,EAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAC;YACnF,EAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAC;SAC1F,CAAC;QAEc,YAAO,GAAwB,IAAI,CAAC,WAAW,CAAC,IAAI,CAClE,SAAS,CAAC,CAAC,UAAkB,EAAE,EAAE,CAC/B,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,uBAAuB,EAAE;YAChE,QAAQ,EAAE,kCAAkC,CAAC,kBAAkB;YAC/D,UAAU;SACX,CAAC,CACH,CACF,CAAC;QAEc,wBAAmB,GAAG,IAAI,eAAe,CAAsB;YAC7E,IAAI,EAAE,CAAC;YACP,IAAI,EAAE,EAAE;SACT,CAAC,CAAC;QAEa,eAAU,GAAG,IAAI,eAAe,CAAsB;YACpE,cAAc,EAAE,CAAC;SAClB,CAAC,CAAC;QAEa,gBAAW,GAA2B,aAAa,CAAC;YAClE,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,UAAU;SAChB,CAAC,CAAC,IAAI,CACL,GAAG,CACD,CAAC,CAAC,WAAW,EAAE,KAAK,CAAC,EAAE,EAAE,CACvB,CAAC,EAAC,GAAG,WAAW,EAAE,GAAG,KAAK,EAAE,IAAI,EAAE,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,EAAC,CAAe,CAChF,CACF,CAAC;QAEc,WAAM,GAA4B,aAAa,CAAC;YAC9D,IAAI,CAAC,WAAW;YAChB,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,YAAY,CAAC,QAAQ;YAC1B,IAAI,CAAC,YAAY,CAAC,QAAQ;SAC3B,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC,CAAC,EACpC,SAAS,CAAC,CAAC,CAAC,UAAU,EAAE,WAAW,CAAC,EAAE,EAAE,CACtC,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,UAAU,EAAE;YAC7C,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,IAAI,EAAE,WAAW,CAAC,IAAI;SACvB,CAAC,CACH,EACD,GAAG,CAAC,CAAC,GAAe,EAAE,EAAE;YACtB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;gBAC9C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAC,GAAG,KAAK,EAAE,cAAc,EAAE,GAAG,CAAC,aAAa,EAAC,CAAC,CAAC;YACtE,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,EACF,SAAS,CAAC,GAAG,CAAC,EAAE,CACd,aAAa,CAAC;YACZ,EAAE,CAAC,GAAG,CAAC;YACP,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CACxB,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,0BAA0B,EAAE;gBACnE,QAAQ,EAAE,kCAAkC,CAAC,IAAI;gBACjD,UAAU,EAAE,IAAI,CAAC,EAAE;aACpB,CAAC,CACH;YACD,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CACxB,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,wBAAwB,EAAE;gBACjE,QAAQ,EAAE,kCAAkC,CAAC,IAAI;gBACjD,UAAU,EAAE,IAAI,CAAC,EAAE;aACpB,CAAC,CACH;SACF,CAAC,CACH,EACD,GAAG,CAAC,eAAe,CAAC,EAAE;YACpB,MAAM,iBAAiB,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;YAC/E,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAC1D,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;YAChE,MAAM,eAAe,GAAG,iBAAiB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAE3D,OAAO,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,IAAU,EAAE,KAAK,EAAE,EAAE;gBAC1D,MAAM,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;gBAC3F,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,gBAAgB,CAClB,eAAe,CAAC,MAAM,CAAC,aAAa,CAAC,EACrC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,EAC/B,IAAI,CAAC,qBAAqB,EAC1B,eAAe,CAAC,OAAO,EAAE,EACzB,IAAI,CAAC,OAAO,EACZ,EAAE,EACF,EAAC,EAAE,EAAE,IAAI,CAAC,EAAE,EAAC,EACb;oBACE,GAAG,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBAC/C,GAAG,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;iBAC5C,CACF,CACF,CAAC;gBACF,OAAO;oBACL,GAAG,IAAI;iBACR,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACrC,CAAC;IASC,CAAC;IAEG,QAAQ;QACb,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;YAChD,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,iBAAiB,CAAC,aAAa;QACpC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE;YAC7D,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAC,GAAG,WAAW,EAAE,IAAI,EAAE,aAAa,GAAG,CAAC,EAAC,CAAC,CAAC;QAC3E,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC1B,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACtC,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;IAChC,CAAC;IAEM,aAAa,CAAC,OAAO;QAC1B,IAAI,CAAC,WAAW;aACb,IAAI,CACH,IAAI,CAAC,CAAC,CAAC,EACP,SAAS,CAAC,CAAC,UAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,CAC7F;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;YAC5B,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,aAAa,CAAC,OAAO;QAC1B,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACxF,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;YAC5B,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,6BAA6B,CAAC,CAAC,CAAC;QAC3F,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,QAAQ,CAAC,IAAI;QAClB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QACzC,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;IAChC,CAAC;IAEM,UAAU,CAAC,IAAI;QACpB,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;YAC5B,UAAU,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,wCAAwC,CAAC;YACnF,QAAQ,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,8CAA8C,CAAC;YACvF,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,mCAAmC,CAAC;YACpF,iBAAiB,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,mCAAmC,CAAC;YACrF,aAAa,EAAE,QAAQ;YACvB,cAAc,EAAE,QAAQ;YACxB,gBAAgB,EAAE,WAAW;YAC7B,iBAAiB,EAAE,SAAS;YAC5B,cAAc,EAAE,IAAI;YACpB,aAAa,EAAE,IAAI;YACnB,uBAAuB,EAAE,GAAG,EAAE;gBAC5B,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;oBAC9D,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;oBAC5B,IAAI,CAAC,aAAa,CAAC,OAAO,CACxB,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,iDAAiD,CAAC,CACjF,CAAC;gBACJ,CAAC,CAAC,CAAC;YACL,CAAC;SACF,CAAC,CAAC;IACL,CAAC;+GAxLU,8BAA8B;mGAA9B,8BAA8B,2ICvC3C,qiFA+EA;;4FDxCa,8BAA8B;kBAL1C,SAAS;+BACE,kCAAkC;qOAKP,QAAQ;sBAA5C,WAAW;uBAAC,sBAAsB","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 {Component, HostBinding, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateService} from '@ngx-translate/core';\nimport {PermissionService} from '@valtimo/access-control';\nimport {Pagination, PromptService, TimelineItem, TimelineItemImpl} from '@valtimo/components';\nimport {Page} from '@valtimo/config';\nimport moment from 'moment';\nimport {ToastrService} from 'ngx-toastr';\nimport {BehaviorSubject, combineLatest, map, Observable, of} from 'rxjs';\nimport {switchMap, take, tap} from 'rxjs/operators';\nimport {Note} from '../../../../models/notes.model';\nimport {\n  CAN_ADD_NOTE_PERMISSION,\n  CAN_DELETE_NOTE_PERMISSION,\n  CAN_EDIT_NOTE_PERMISSION,\n  DOSSIER_DETAIL_PERMISSION_RESOURCE,\n} from '../../../../permissions';\nimport {NotesService} from '../../../../services/notes.service';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-notes',\n  templateUrl: './notes.component.html',\n  styleUrls: ['./notes.component.scss'],\n})\nexport class DossierDetailTabNotesComponent implements OnInit {\n  @HostBinding('class.tab--no-margin') noMargin = true;\n\n  public timelineItems: TimelineItem[] = [];\n\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n  public readonly fields$ = new BehaviorSubject<Array<{key: string; label: string}>>([]);\n  public readonly customData$ = new BehaviorSubject<object>({});\n\n  private readonly documentId$ = this.route.params.pipe(map(params => params.documentId));\n  public readonly actions = [\n    {id: 'edit', label: 'Edit', icon: 'mdi-pencil', callback: this.editNote.bind(this)},\n    {id: 'delete', label: 'Delete', icon: 'mdi-delete', callback: this.deleteNote.bind(this)},\n  ];\n\n  public readonly canAdd$: Observable<boolean> = this.documentId$.pipe(\n    switchMap((identifier: string) =>\n      this.permissionService.requestPermission(CAN_ADD_NOTE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier,\n      })\n    )\n  );\n\n  public readonly currentPageAndSize$ = new BehaviorSubject<Partial<Pagination>>({\n    page: 0,\n    size: 10,\n  });\n\n  public readonly pageSizes$ = new BehaviorSubject<Partial<Pagination>>({\n    collectionSize: 0,\n  });\n\n  public readonly pagination$: Observable<Pagination> = combineLatest([\n    this.currentPageAndSize$,\n    this.pageSizes$,\n  ]).pipe(\n    map(\n      ([currentPage, sizes]) =>\n        ({...currentPage, ...sizes, page: (currentPage.page ?? 0) + 1}) as Pagination\n    )\n  );\n\n  public readonly notes$: Observable<Array<Note>> = combineLatest([\n    this.documentId$,\n    this.currentPageAndSize$,\n    this.notesService.refresh$,\n    this.notesService.refresh$,\n  ]).pipe(\n    tap(() => (this.timelineItems = [])),\n    switchMap(([documentId, currentPage]) =>\n      this.notesService.getDocumentNotes(documentId, {\n        page: currentPage.page,\n        size: currentPage.size,\n      })\n    ),\n    tap((res: Page<Note>) => {\n      this.timelineItems = [];\n      this.pageSizes$.pipe(take(1)).subscribe(sizes => {\n        this.pageSizes$.next({...sizes, collectionSize: res.totalElements});\n      });\n    }),\n    switchMap(res =>\n      combineLatest([\n        of(res),\n        ...res.content.map(note =>\n          this.permissionService.requestPermission(CAN_DELETE_NOTE_PERMISSION, {\n            resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.note,\n            identifier: note.id,\n          })\n        ),\n        ...res.content.map(note =>\n          this.permissionService.requestPermission(CAN_EDIT_NOTE_PERMISSION, {\n            resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.note,\n            identifier: note.id,\n          })\n        ),\n      ])\n    ),\n    map(combinedResults => {\n      const permissionResults = combinedResults.filter((curr, index) => index !== 0);\n      const halfIndex = Math.ceil(permissionResults.length / 2);\n      const deletePermissions = permissionResults.slice(0, halfIndex);\n      const editPermissions = permissionResults.slice(halfIndex);\n\n      return combinedResults[0].content.map((note: Note, index) => {\n        const noteCreatedDate = moment(note.createdDate).locale(this.translateService.currentLang);\n        this.timelineItems.push(\n          new TimelineItemImpl(\n            noteCreatedDate.format('DD MMM YYYY'),\n            noteCreatedDate.format('HH:mm'),\n            note.createdByUserFullName,\n            noteCreatedDate.fromNow(),\n            note.content,\n            {},\n            {id: note.id},\n            [\n              ...(deletePermissions[index] ? ['delete'] : []),\n              ...(editPermissions[index] ? ['edit'] : []),\n            ]\n          )\n        );\n        return {\n          ...note,\n        };\n      });\n    }),\n    tap(() => this.loading$.next(false))\n  );\n\n  constructor(\n    private readonly notesService: NotesService,\n    private readonly permissionService: PermissionService,\n    private readonly promptService: PromptService,\n    private readonly route: ActivatedRoute,\n    private readonly toastrService: ToastrService,\n    private readonly translateService: TranslateService\n  ) {}\n\n  public ngOnInit(): void {\n    this.translateService.onLangChange.subscribe(() => {\n      this.notesService.refresh();\n    });\n  }\n\n  public paginationClicked(newPageNumber): void {\n    this.currentPageAndSize$.pipe(take(1)).subscribe(currentPage => {\n      this.currentPageAndSize$.next({...currentPage, page: newPageNumber - 1});\n    });\n  }\n\n  public showAddModal(): void {\n    this.customData$.next({});\n    this.notesService.setModalType('add');\n    this.notesService.showModal();\n  }\n\n  public createNewNote(content): void {\n    this.documentId$\n      .pipe(\n        take(1),\n        switchMap((documentId: string) => this.notesService.createDocumentNote(documentId, content))\n      )\n      .subscribe(() => {\n        this.notesService.refresh();\n        this.notesService.hideModal();\n      });\n  }\n\n  public editNoteEvent(content): void {\n    this.notesService.updateNote(content.data.customData.id, content.formData).subscribe(() => {\n      this.notesService.refresh();\n      this.notesService.hideModal();\n      this.toastrService.success(this.translateService.instant('dossier.notes.editedMessage'));\n    });\n  }\n\n  public editNote(data): void {\n    this.customData$.next(data);\n    this.notesService.setModalType('modify');\n    this.notesService.showModal();\n  }\n\n  public deleteNote(data): void {\n    this.promptService.openPrompt({\n      headerText: this.translateService.instant('dossier.notes.deleteConfirmation.title'),\n      bodyText: this.translateService.instant('dossier.notes.deleteConfirmation.description'),\n      cancelButtonText: this.translateService.instant('dossier.deleteConfirmation.cancel'),\n      confirmButtonText: this.translateService.instant('dossier.deleteConfirmation.delete'),\n      cancelMdiIcon: 'cancel',\n      confirmMdiIcon: 'delete',\n      cancelButtonType: 'secondary',\n      confirmButtonType: 'primary',\n      closeOnConfirm: true,\n      closeOnCancel: true,\n      confirmCallBackFunction: () => {\n        this.notesService.deleteNote(data.customData.id).subscribe(() => {\n          this.notesService.refresh();\n          this.toastrService.success(\n            this.translateService.instant('dossier.notes.deleteConfirmation.deletedMessage')\n          );\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<ng-container\n  *ngIf=\"{\n    canAdd: canAdd$ | async,\n    notes: notes$ | async,\n    pagination: pagination$ | async,\n    loading: loading$ | async,\n  } as obs\"\n>\n  <div class=\"cds--toolbar-content\">\n    <button\n      cdsButton=\"primary\"\n      *ngIf=\"obs.canAdd\"\n      [disabled]=\"obs.loading\"\n      (click)=\"showAddModal()\"\n      aria-expanded=\"false\"\n      aria-haspopup=\"true\"\n    >\n      {{ 'dossier.notes.addNote' | translate }}\n\n      <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n    </button>\n  </div>\n\n  <div *ngIf=\"timelineItems\">\n    <valtimo-timeline\n      *ngIf=\"timelineItems.length > 0\"\n      [actions]=\"actions\"\n      [items]=\"timelineItems\"\n    ></valtimo-timeline>\n    <valtimo-no-results\n      *ngIf=\"timelineItems.length === 0\"\n      [description]=\"'dossier.notes.noResults.description' | translate\"\n      [title]=\"'dossier.notes.noResults.title' | translate\"\n      illustration=\"valtimo-layout/img/emptystate-no-result.svg\"\n    ></valtimo-no-results>\n  </div>\n\n  <valtimo-spinner\n    [useBootstrapSpinner]=\"false\"\n    name=\"auditSpinner\"\n    bdColor=\"rgba(125, 125, 125, 0.35)\"\n    color=\"#264251\"\n    type=\"square-jelly-box\"\n  >\n  </valtimo-spinner>\n\n  <div *ngIf=\"obs.pagination\" class=\"d-flex justify-content-end row mr-0 ml-0\">\n    <ngb-pagination\n      *ngIf=\"obs.pagination.collectionSize > obs.pagination.size\"\n      [collectionSize]=\"obs.pagination.collectionSize\"\n      [maxSize]=\"obs.pagination.size\"\n      [pageSize]=\"obs.pagination.size\"\n      [rotate]=\"true\"\n      [(page)]=\"obs.pagination.page\"\n      (pageChange)=\"paginationClicked($event)\"\n    ></ngb-pagination>\n  </div>\n</ng-container>\n\n<valtimo-note-modal\n  [customData]=\"customData$ | async\"\n  (createNoteEvent)=\"createNewNote($event)\"\n  (editNoteEvent)=\"editNoteEvent($event)\"\n></valtimo-note-modal>\n"]}
|
|
@@ -55,10 +55,10 @@ export class DossierDetailTabProgressComponent {
|
|
|
55
55
|
}
|
|
56
56
|
}
|
|
57
57
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabProgressComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.DocumentService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
58
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailTabProgressComponent, selector: "valtimo-dossier-detail-tab-progress", 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 class=\"full-height-tab-content\"\n *ngIf=\"{\n processInstanceItems: processInstanceItems$ | async,\n selectedProcessInstance: selectedProcessInstance$ | async
|
|
58
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailTabProgressComponent, selector: "valtimo-dossier-detail-tab-progress", 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 class=\"full-height-tab-content\"\n *ngIf=\"{\n processInstanceItems: processInstanceItems$ | async,\n selectedProcessInstance: selectedProcessInstance$ | async,\n } as obs\"\n>\n <span *ngIf=\"!obs.processInstanceItems.isLoading && !obs.processInstanceItems.value\">{{\n 'progress.noProcessDocumentInstances' | translate\n }}</span>\n <div class=\"process-info-row\">\n <cds-dropdown\n [dropUp]=\"false\"\n [label]=\"'progress.process' | translate\"\n [skeleton]=\"obs.processInstanceItems.isLoading\"\n [style.width.px]=\"350\"\n (selected)=\"loadProcessInstance($event.item.processInstanceId)\"\n >\n <cds-dropdown-list [items]=\"obs.processInstanceItems.value || []\"></cds-dropdown-list>\n </cds-dropdown>\n <div>\n <v-input-label [title]=\"'progress.version' | translate\"></v-input-label>\n <cds-skeleton-text\n *ngIf=\"obs.selectedProcessInstance.isLoading\"\n [lines]=\"1\"\n [maxLineWidth]=\"30\"\n ></cds-skeleton-text>\n <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n {{ obs.selectedProcessInstance.value.version }} ({{ 'progress.of' | translate }}\n {{ obs.selectedProcessInstance.value.latestVersion }})\n </span>\n </div>\n <div>\n <v-input-label [title]=\"'progress.startedBy' | translate\"></v-input-label>\n <cds-skeleton-text\n *ngIf=\"obs.selectedProcessInstance.isLoading\"\n [lines]=\"1\"\n [maxLineWidth]=\"50\"\n ></cds-skeleton-text>\n <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n {{ obs.selectedProcessInstance.value.startedBy || ('progress.system' | translate) }}\n </span>\n </div>\n <div>\n <v-input-label [title]=\"'progress.startedOn' | translate\"></v-input-label>\n <cds-skeleton-text\n *ngIf=\"obs.selectedProcessInstance.isLoading\"\n [lines]=\"1\"\n [maxLineWidth]=\"50\"\n ></cds-skeleton-text>\n <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n {{ obs.selectedProcessInstance.value.startedOn.toLocaleDateString() }}\n </span>\n </div>\n </div>\n <div>\n <valtimo-process-diagram\n *ngIf=\"!obs.selectedProcessInstance.isLoading\"\n [processInstanceId]=\"obs.selectedProcessInstance.value.id.processInstanceId\"\n ></valtimo-process-diagram>\n </div>\n</ng-container>\n", styles: [".full-height-tab-content{height:calc(100vh - 380px);width:100%}.process-info-row{display:flex;gap:24px}.process-info-text{color:var(--v-color-black);font-size:var(--v-font-size-default)}.process-info-text{display:flex;height:40px;align-items:center}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ProcessDiagramComponent, selector: "valtimo-process-diagram", inputs: ["processDefinitionKey", "processInstanceId"], outputs: ["importDone"] }, { kind: "component", type: i5.InputLabelComponent, selector: "v-input-label", inputs: ["name", "tooltip", "largeMargin", "small", "noMargin", "title", "titleTranslationKey", "required", "disabled", "carbonTheme"] }, { kind: "component", type: i6.Dropdown, selector: "cds-dropdown, ibm-dropdown", inputs: ["id", "label", "hideLabel", "helperText", "placeholder", "displayValue", "clearText", "size", "type", "theme", "disabled", "skeleton", "inline", "disableArrowKeys", "invalid", "invalidText", "warn", "warnText", "appendInline", "scrollableContainer", "itemValueKey", "selectionFeedback", "menuButtonLabel", "selectedLabel", "dropUp"], outputs: ["selected", "onClose", "close"] }, { kind: "component", type: i6.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "component", type: i6.SkeletonText, selector: "cds-skeleton-text, ibm-skeleton-text", inputs: ["lines", "minLineWidth", "maxLineWidth"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
|
|
59
59
|
}
|
|
60
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabProgressComponent, decorators: [{
|
|
61
61
|
type: Component,
|
|
62
|
-
args: [{ selector: 'valtimo-dossier-detail-tab-progress', 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 class=\"full-height-tab-content\"\n *ngIf=\"{\n processInstanceItems: processInstanceItems$ | async,\n selectedProcessInstance: selectedProcessInstance$ | async
|
|
62
|
+
args: [{ selector: 'valtimo-dossier-detail-tab-progress', 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 class=\"full-height-tab-content\"\n *ngIf=\"{\n processInstanceItems: processInstanceItems$ | async,\n selectedProcessInstance: selectedProcessInstance$ | async,\n } as obs\"\n>\n <span *ngIf=\"!obs.processInstanceItems.isLoading && !obs.processInstanceItems.value\">{{\n 'progress.noProcessDocumentInstances' | translate\n }}</span>\n <div class=\"process-info-row\">\n <cds-dropdown\n [dropUp]=\"false\"\n [label]=\"'progress.process' | translate\"\n [skeleton]=\"obs.processInstanceItems.isLoading\"\n [style.width.px]=\"350\"\n (selected)=\"loadProcessInstance($event.item.processInstanceId)\"\n >\n <cds-dropdown-list [items]=\"obs.processInstanceItems.value || []\"></cds-dropdown-list>\n </cds-dropdown>\n <div>\n <v-input-label [title]=\"'progress.version' | translate\"></v-input-label>\n <cds-skeleton-text\n *ngIf=\"obs.selectedProcessInstance.isLoading\"\n [lines]=\"1\"\n [maxLineWidth]=\"30\"\n ></cds-skeleton-text>\n <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n {{ obs.selectedProcessInstance.value.version }} ({{ 'progress.of' | translate }}\n {{ obs.selectedProcessInstance.value.latestVersion }})\n </span>\n </div>\n <div>\n <v-input-label [title]=\"'progress.startedBy' | translate\"></v-input-label>\n <cds-skeleton-text\n *ngIf=\"obs.selectedProcessInstance.isLoading\"\n [lines]=\"1\"\n [maxLineWidth]=\"50\"\n ></cds-skeleton-text>\n <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n {{ obs.selectedProcessInstance.value.startedBy || ('progress.system' | translate) }}\n </span>\n </div>\n <div>\n <v-input-label [title]=\"'progress.startedOn' | translate\"></v-input-label>\n <cds-skeleton-text\n *ngIf=\"obs.selectedProcessInstance.isLoading\"\n [lines]=\"1\"\n [maxLineWidth]=\"50\"\n ></cds-skeleton-text>\n <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n {{ obs.selectedProcessInstance.value.startedOn.toLocaleDateString() }}\n </span>\n </div>\n </div>\n <div>\n <valtimo-process-diagram\n *ngIf=\"!obs.selectedProcessInstance.isLoading\"\n [processInstanceId]=\"obs.selectedProcessInstance.value.id.processInstanceId\"\n ></valtimo-process-diagram>\n </div>\n</ng-container>\n", styles: [".full-height-tab-content{height:calc(100vh - 380px);width:100%}.process-info-row{display:flex;gap:24px}.process-info-text{color:var(--v-color-black);font-size:var(--v-font-size-default)}.process-info-text{display:flex;height:40px;align-items:center}\n"] }]
|
|
63
63
|
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.DocumentService }] });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/progress/progress.component.ts","../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/progress/progress.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component} from '@angular/core';\nimport {ActivatedRoute, ParamMap} from '@angular/router';\nimport {DocumentService, LoadedValue, ProcessDocumentInstance} from '@valtimo/document';\nimport {BehaviorSubject, combineLatest, map, Observable, startWith, switchMap, tap} from 'rxjs';\nimport {ListItem} from 'carbon-components-angular/dropdown';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-progress',\n  templateUrl: './progress.component.html',\n  styleUrls: ['./progress.component.css'],\n})\nexport class DossierDetailTabProgressComponent {\n  private readonly processDocumentInstances$: Observable<Array<ProcessDocumentInstance>> =\n    this.route.paramMap.pipe(\n      switchMap((params: ParamMap) =>\n        this.documentService.findProcessDocumentInstances(params.get('documentId'))\n      ),\n      map(processDocumentInstances =>\n        processDocumentInstances.map(processDocumentInstance => ({\n          ...processDocumentInstance,\n          startedOn: new Date(processDocumentInstance.startedOn),\n        }))\n      ),\n      map(processDocumentInstances =>\n        processDocumentInstances.sort((a, b) =>\n          a.active === b.active ? b.startedOn.getTime() - a.startedOn.getTime() : a.active ? -1 : 1\n        )\n      ),\n      tap(processDocumentInstances => {\n        if (processDocumentInstances.length > 0) {\n          this.selectedProcessInstanceId$.next(processDocumentInstances[0].id.processInstanceId);\n        }\n      })\n    );\n\n  public readonly processInstanceItems$: Observable<LoadedValue<Array<ListItem>>> =\n    this.processDocumentInstances$.pipe(\n      map(processDocumentInstances =>\n        processDocumentInstances.map((processDocumentInstance, index) => ({\n          processInstanceId: processDocumentInstance.id.processInstanceId,\n          content: processDocumentInstance.processName || '-',\n          selected: index === 0,\n        }))\n      ),\n      map(processInstanceItems => ({\n        value: processInstanceItems,\n        isLoading: false,\n      })),\n      startWith({isLoading: true})\n    );\n\n  public readonly selectedProcessInstanceId$ = new BehaviorSubject<string | null>(null);\n  public readonly selectedProcessInstance$: Observable<LoadedValue<ProcessDocumentInstance>> =\n    combineLatest([this.processDocumentInstances$, this.selectedProcessInstanceId$]).pipe(\n      map(([processDocumentInstances, selectedProcessInstanceId]) =>\n        processDocumentInstances.find(\n          instance => instance.id.processInstanceId === selectedProcessInstanceId\n        )\n      ),\n      map(processInstanceItems => ({\n        value: processInstanceItems,\n        isLoading: false,\n      })),\n      startWith({isLoading: true})\n    );\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly documentService: DocumentService\n  ) {}\n\n  public loadProcessInstance(processInstanceId: string) {\n    if (!!processInstanceId) {\n      this.selectedProcessInstanceId$.next(processInstanceId);\n    }\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  class=\"full-height-tab-content\"\n  *ngIf=\"{\n    processInstanceItems: processInstanceItems$ | async,\n    selectedProcessInstance: selectedProcessInstance$ | async\n  } as obs\"\n>\n  <span *ngIf=\"!obs.processInstanceItems.isLoading && !obs.processInstanceItems.value\">{{\n    'progress.noProcessDocumentInstances' | translate\n  }}</span>\n  <div class=\"process-info-row\">\n    <cds-dropdown\n      [dropUp]=\"false\"\n      [label]=\"'progress.process' | translate\"\n      [skeleton]=\"obs.processInstanceItems.isLoading\"\n      [style.width.px]=\"350\"\n      (selected)=\"loadProcessInstance($event.item.processInstanceId)\"\n    >\n      <cds-dropdown-list [items]=\"obs.processInstanceItems.value || []\"></cds-dropdown-list>\n    </cds-dropdown>\n    <div>\n      <v-input-label [title]=\"'progress.version' | translate\"></v-input-label>\n      <cds-skeleton-text\n        *ngIf=\"obs.selectedProcessInstance.isLoading\"\n        [lines]=\"1\"\n        [maxLineWidth]=\"30\"\n      ></cds-skeleton-text>\n      <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n        {{ obs.selectedProcessInstance.value.version }} ({{ 'progress.of' | translate }}\n        {{ obs.selectedProcessInstance.value.latestVersion }})\n      </span>\n    </div>\n    <div>\n      <v-input-label [title]=\"'progress.startedBy' | translate\"></v-input-label>\n      <cds-skeleton-text\n        *ngIf=\"obs.selectedProcessInstance.isLoading\"\n        [lines]=\"1\"\n        [maxLineWidth]=\"50\"\n      ></cds-skeleton-text>\n      <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n        {{ obs.selectedProcessInstance.value.startedBy || ('progress.system' | translate) }}\n      </span>\n    </div>\n    <div>\n      <v-input-label [title]=\"'progress.startedOn' | translate\"></v-input-label>\n      <cds-skeleton-text\n        *ngIf=\"obs.selectedProcessInstance.isLoading\"\n        [lines]=\"1\"\n        [maxLineWidth]=\"50\"\n      ></cds-skeleton-text>\n      <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n        {{ obs.selectedProcessInstance.value.startedOn.toLocaleDateString() }}\n      </span>\n    </div>\n  </div>\n  <div>\n    <valtimo-process-diagram\n      *ngIf=\"!obs.selectedProcessInstance.isLoading\"\n      [processInstanceId]=\"obs.selectedProcessInstance.value.id.processInstanceId\"\n    ></valtimo-process-diagram>\n  </div>\n</ng-container>\n"]}
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/progress/progress.component.ts","../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/progress/progress.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component} from '@angular/core';\nimport {ActivatedRoute, ParamMap} from '@angular/router';\nimport {DocumentService, LoadedValue, ProcessDocumentInstance} from '@valtimo/document';\nimport {BehaviorSubject, combineLatest, map, Observable, startWith, switchMap, tap} from 'rxjs';\nimport {ListItem} from 'carbon-components-angular/dropdown';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-progress',\n  templateUrl: './progress.component.html',\n  styleUrls: ['./progress.component.css'],\n})\nexport class DossierDetailTabProgressComponent {\n  private readonly processDocumentInstances$: Observable<Array<ProcessDocumentInstance>> =\n    this.route.paramMap.pipe(\n      switchMap((params: ParamMap) =>\n        this.documentService.findProcessDocumentInstances(params.get('documentId'))\n      ),\n      map(processDocumentInstances =>\n        processDocumentInstances.map(processDocumentInstance => ({\n          ...processDocumentInstance,\n          startedOn: new Date(processDocumentInstance.startedOn),\n        }))\n      ),\n      map(processDocumentInstances =>\n        processDocumentInstances.sort((a, b) =>\n          a.active === b.active ? b.startedOn.getTime() - a.startedOn.getTime() : a.active ? -1 : 1\n        )\n      ),\n      tap(processDocumentInstances => {\n        if (processDocumentInstances.length > 0) {\n          this.selectedProcessInstanceId$.next(processDocumentInstances[0].id.processInstanceId);\n        }\n      })\n    );\n\n  public readonly processInstanceItems$: Observable<LoadedValue<Array<ListItem>>> =\n    this.processDocumentInstances$.pipe(\n      map(processDocumentInstances =>\n        processDocumentInstances.map((processDocumentInstance, index) => ({\n          processInstanceId: processDocumentInstance.id.processInstanceId,\n          content: processDocumentInstance.processName || '-',\n          selected: index === 0,\n        }))\n      ),\n      map(processInstanceItems => ({\n        value: processInstanceItems,\n        isLoading: false,\n      })),\n      startWith({isLoading: true})\n    );\n\n  public readonly selectedProcessInstanceId$ = new BehaviorSubject<string | null>(null);\n  public readonly selectedProcessInstance$: Observable<LoadedValue<ProcessDocumentInstance>> =\n    combineLatest([this.processDocumentInstances$, this.selectedProcessInstanceId$]).pipe(\n      map(([processDocumentInstances, selectedProcessInstanceId]) =>\n        processDocumentInstances.find(\n          instance => instance.id.processInstanceId === selectedProcessInstanceId\n        )\n      ),\n      map(processInstanceItems => ({\n        value: processInstanceItems,\n        isLoading: false,\n      })),\n      startWith({isLoading: true})\n    );\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly documentService: DocumentService\n  ) {}\n\n  public loadProcessInstance(processInstanceId: string) {\n    if (!!processInstanceId) {\n      this.selectedProcessInstanceId$.next(processInstanceId);\n    }\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  class=\"full-height-tab-content\"\n  *ngIf=\"{\n    processInstanceItems: processInstanceItems$ | async,\n    selectedProcessInstance: selectedProcessInstance$ | async,\n  } as obs\"\n>\n  <span *ngIf=\"!obs.processInstanceItems.isLoading && !obs.processInstanceItems.value\">{{\n    'progress.noProcessDocumentInstances' | translate\n  }}</span>\n  <div class=\"process-info-row\">\n    <cds-dropdown\n      [dropUp]=\"false\"\n      [label]=\"'progress.process' | translate\"\n      [skeleton]=\"obs.processInstanceItems.isLoading\"\n      [style.width.px]=\"350\"\n      (selected)=\"loadProcessInstance($event.item.processInstanceId)\"\n    >\n      <cds-dropdown-list [items]=\"obs.processInstanceItems.value || []\"></cds-dropdown-list>\n    </cds-dropdown>\n    <div>\n      <v-input-label [title]=\"'progress.version' | translate\"></v-input-label>\n      <cds-skeleton-text\n        *ngIf=\"obs.selectedProcessInstance.isLoading\"\n        [lines]=\"1\"\n        [maxLineWidth]=\"30\"\n      ></cds-skeleton-text>\n      <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n        {{ obs.selectedProcessInstance.value.version }} ({{ 'progress.of' | translate }}\n        {{ obs.selectedProcessInstance.value.latestVersion }})\n      </span>\n    </div>\n    <div>\n      <v-input-label [title]=\"'progress.startedBy' | translate\"></v-input-label>\n      <cds-skeleton-text\n        *ngIf=\"obs.selectedProcessInstance.isLoading\"\n        [lines]=\"1\"\n        [maxLineWidth]=\"50\"\n      ></cds-skeleton-text>\n      <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n        {{ obs.selectedProcessInstance.value.startedBy || ('progress.system' | translate) }}\n      </span>\n    </div>\n    <div>\n      <v-input-label [title]=\"'progress.startedOn' | translate\"></v-input-label>\n      <cds-skeleton-text\n        *ngIf=\"obs.selectedProcessInstance.isLoading\"\n        [lines]=\"1\"\n        [maxLineWidth]=\"50\"\n      ></cds-skeleton-text>\n      <span *ngIf=\"!obs.selectedProcessInstance.isLoading\" class=\"process-info-text\">\n        {{ obs.selectedProcessInstance.value.startedOn.toLocaleDateString() }}\n      </span>\n    </div>\n  </div>\n  <div>\n    <valtimo-process-diagram\n      *ngIf=\"!obs.selectedProcessInstance.isLoading\"\n      [processInstanceId]=\"obs.selectedProcessInstance.value.id.processInstanceId\"\n    ></valtimo-process-diagram>\n  </div>\n</ng-container>\n"]}
|
|
@@ -56,7 +56,7 @@ export class DossierDetailTabSummaryComponent {
|
|
|
56
56
|
}));
|
|
57
57
|
}
|
|
58
58
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabSummaryComponent, deps: [{ token: i1.DocumentService }, { token: i2.ActivatedRoute }, { token: i3.FormService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
59
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailTabSummaryComponent, selector: "valtimo-dossier-detail-tab-summary", ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\">\n <div class=\"row py-4\">\n <div class=\"col-12\">\n <div *ngIf=\"document\">\n <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n <div class=\"mb-4\">\n <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".hoverable:hover{background-color:#eee}.summaryForm .formio-component{margin-bottom:0!important}.summaryForm .formio-component div[ref=element] .form-control{height:24px!important;background-color:#fff;border:0px;margin:0;padding:0!important;font-size:13px}.summaryForm .formio-field div[ref=element] .form-control{font-weight:400}.summaryForm .formio-value div[ref=element] .form-control{font-weight:700}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
59
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierDetailTabSummaryComponent, selector: "valtimo-dossier-detail-tab-summary", ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div class=\"container-fluid\">\n <div class=\"row py-4\">\n <div class=\"col-12\">\n <div *ngIf=\"document\">\n <div *ngIf=\"formDefinition\" class=\"summaryForm\">\n <div class=\"mb-4\">\n <valtimo-form-io [form]=\"formDefinition\" [options]=\"options\"></valtimo-form-io>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".hoverable:hover{background-color:#eee}.summaryForm .formio-component{margin-bottom:0!important}.summaryForm .formio-component div[ref=element] .form-control{height:24px!important;background-color:#fff;border:0px;margin:0;padding:0!important;font-size:13px}.summaryForm .formio-field div[ref=element] .form-control{font-weight:400}.summaryForm .formio-value div[ref=element] .form-control{font-weight:700}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
60
60
|
}
|
|
61
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabSummaryComponent, decorators: [{
|
|
62
62
|
type: Component,
|
|
@@ -160,7 +160,7 @@ export class WidgetCollectionComponent {
|
|
|
160
160
|
return '-';
|
|
161
161
|
}
|
|
162
162
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetCollectionComponent, deps: [{ token: i1.ViewContentService }, { token: i0.ChangeDetectorRef }, { token: i2.DossierWidgetsApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
163
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetCollectionComponent, isStandalone: true, selector: "valtimo-widget-collection", inputs: { documentId: "documentId", tabKey: "tabKey", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_widgetCollectionRef", first: true, predicate: ["widgetCollection"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async
|
|
163
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: WidgetCollectionComponent, isStandalone: true, selector: "valtimo-widget-collection", inputs: { documentId: "documentId", tabKey: "tabKey", widgetConfiguration: "widgetConfiguration", widgetData: "widgetData" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_widgetCollectionRef", first: true, predicate: ["widgetCollection"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async,\n } as obs\"\n>\n <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n <div\n #widgetCollection\n [ngClass]=\"{\n 'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n 'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n 'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n 'valtimo-widget-collection__container': amountOfColumns() === 4,\n }\"\n >\n @for (card of obs?.collectionWidgetCards; track card.key) {\n <div\n class=\"valtimo-widget-collection__card\"\n [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n >\n <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n @for (field of card.fields; track field.key) {\n <div\n [ngClass]=\"{\n 'valtimo-widget-collection__full-width-input': field?.width === 'full',\n 'valtimo-widget-collection__half-width-input': field?.width === 'half',\n }\"\n >\n <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n {{ field?.title }}\n\n <input\n [value]=\"field?.value\"\n [readonly]=\"true\"\n class=\"valtimo-widget-collection__card-input\"\n cdsText\n />\n </cds-label>\n </div>\n }\n </div>\n }\n </div>\n\n @if (!obs?.collectionWidgetCards?.length) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n\n <cds-pagination-nav\n *ngIf=\"paginationModel() && (showPagination$ | async)\"\n class=\"valtimo-widget-collection__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n</ng-container>\n", styles: [".valtimo-widget-collection{padding:24px}.valtimo-widget-collection .cds--label{overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-widget-collection__container{display:flex;column-gap:16px}.valtimo-widget-collection,.valtimo-widget-collection__column{display:flex;flex-direction:column;width:100%;overflow:hidden}.valtimo-widget-collection__card{margin-top:16px;display:flex;flex-flow:row wrap;background-color:var(--cds-background);padding:16px;width:100%;gap:16px}.valtimo-widget-collection__card--hidden{visibility:hidden}.valtimo-widget-collection__card-title{color:var(--cds-text-primary);font-weight:500;font-size:14px;line-height:22px;font-style:italic;width:100%}.valtimo-widget-collection__card-input{background:transparent}.valtimo-widget-collection__full-width-input{width:100%}.valtimo-widget-collection__half-width-input{width:calc(50% - 16px);box-sizing:border-box}.valtimo-widget-collection__pagination{padding:8px 0;display:flex;justify-content:center}.valtimo-widget-collection__render-vertically,.valtimo-widget-collection__render-two-columns,.valtimo-widget-collection__render-three-columns{grid-gap:16px;align-items:stretch;overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__render-vertically{display:flex!important}.valtimo-widget-collection__render-two-columns{grid-template-columns:repeat(2,1fr)}.valtimo-widget-collection__render-three-columns{grid-template-columns:repeat(3,1fr)}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i4.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i4.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "ngmodule", type: PaginationModule }, { kind: "component", type: i4.PaginationNav, selector: "cds-pagination-nav, ibm-pagination-navm", inputs: ["model", "disabled", "numOfItemsToShow", "translations"], outputs: ["selectPage"] }, { kind: "ngmodule", type: TilesModule }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i1.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
164
164
|
}
|
|
165
165
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetCollectionComponent, decorators: [{
|
|
166
166
|
type: Component,
|
|
@@ -171,7 +171,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
171
171
|
TilesModule,
|
|
172
172
|
CarbonListModule,
|
|
173
173
|
TranslateModule,
|
|
174
|
-
], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async
|
|
174
|
+
], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n widgetConfiguration: widgetConfiguration$ | async,\n collectionWidgetCards: collectionWidgetCards$ | async,\n } as obs\"\n>\n <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n <div\n #widgetCollection\n [ngClass]=\"{\n 'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n 'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n 'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n 'valtimo-widget-collection__container': amountOfColumns() === 4,\n }\"\n >\n @for (card of obs?.collectionWidgetCards; track card.key) {\n <div\n class=\"valtimo-widget-collection__card\"\n [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n >\n <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n @for (field of card.fields; track field.key) {\n <div\n [ngClass]=\"{\n 'valtimo-widget-collection__full-width-input': field?.width === 'full',\n 'valtimo-widget-collection__half-width-input': field?.width === 'half',\n }\"\n >\n <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n {{ field?.title }}\n\n <input\n [value]=\"field?.value\"\n [readonly]=\"true\"\n class=\"valtimo-widget-collection__card-input\"\n cdsText\n />\n </cds-label>\n </div>\n }\n </div>\n }\n </div>\n\n @if (!obs?.collectionWidgetCards?.length) {\n <valtimo-no-results\n [collapseVertically]=\"true\"\n [description]=\"'dossier.widgets.noData' | translate\"\n [smallPadding]=\"true\"\n ></valtimo-no-results>\n }\n\n <cds-pagination-nav\n *ngIf=\"paginationModel() && (showPagination$ | async)\"\n class=\"valtimo-widget-collection__pagination\"\n [model]=\"paginationModel()\"\n (selectPage)=\"onSelectPage($event)\"\n >\n </cds-pagination-nav>\n</ng-container>\n", styles: [".valtimo-widget-collection{padding:24px}.valtimo-widget-collection .cds--label{overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__title{color:var(--cds-text-primary);font-weight:600;font-size:16px;line-height:24px}.valtimo-widget-collection__container{display:flex;column-gap:16px}.valtimo-widget-collection,.valtimo-widget-collection__column{display:flex;flex-direction:column;width:100%;overflow:hidden}.valtimo-widget-collection__card{margin-top:16px;display:flex;flex-flow:row wrap;background-color:var(--cds-background);padding:16px;width:100%;gap:16px}.valtimo-widget-collection__card--hidden{visibility:hidden}.valtimo-widget-collection__card-title{color:var(--cds-text-primary);font-weight:500;font-size:14px;line-height:22px;font-style:italic;width:100%}.valtimo-widget-collection__card-input{background:transparent}.valtimo-widget-collection__full-width-input{width:100%}.valtimo-widget-collection__half-width-input{width:calc(50% - 16px);box-sizing:border-box}.valtimo-widget-collection__pagination{padding:8px 0;display:flex;justify-content:center}.valtimo-widget-collection__render-vertically,.valtimo-widget-collection__render-two-columns,.valtimo-widget-collection__render-three-columns{grid-gap:16px;align-items:stretch;overflow:hidden;text-overflow:ellipsis;width:100%}.valtimo-widget-collection__render-vertically{display:flex!important}.valtimo-widget-collection__render-two-columns{grid-template-columns:repeat(2,1fr)}.valtimo-widget-collection__render-three-columns{grid-template-columns:repeat(3,1fr)}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
|
|
175
175
|
}], ctorParameters: () => [{ type: i1.ViewContentService }, { type: i0.ChangeDetectorRef }, { type: i2.DossierWidgetsApiService }], propDecorators: { class: [{
|
|
176
176
|
type: HostBinding,
|
|
177
177
|
args: ['class']
|
|
@@ -189,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
189
189
|
}], widgetData: [{
|
|
190
190
|
type: Input
|
|
191
191
|
}] } });
|
|
192
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-collection.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {\n  InputModule,\n  PaginationModel,\n  PaginationModule,\n  TilesModule,\n} from 'carbon-components-angular';\nimport {\n  CaseWidgetDisplayTypeKey,\n  CollectionCaseWidget,\n  CollectionCaseWidgetCardData,\n  CollectionCaseWidgetField,\n  CollectionCaseWidgetTitle,\n  CollectionWidgetResolvedField,\n} from '../../../../../../models';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap, tap} from 'rxjs';\nimport {CarbonListModule, ViewContentService} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Page} from '@valtimo/config';\nimport {DossierWidgetsApiService} from '../../../../../../services';\n\n@Component({\n  selector: 'valtimo-widget-collection',\n  templateUrl: './widget-collection.component.html',\n  styleUrls: ['./widget-collection.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    InputModule,\n    PaginationModule,\n    TilesModule,\n    CarbonListModule,\n    TranslateModule,\n  ],\n})\nexport class WidgetCollectionComponent implements AfterViewInit, OnDestroy {\n  @HostBinding('class') public readonly class = 'valtimo-widget-collection';\n  @ViewChild('widgetCollection') private _widgetCollectionRef: ElementRef<HTMLDivElement>;\n\n  @Input({required: true}) public documentId: string;\n  @Input({required: true}) public tabKey: string;\n  @Input() public set widgetConfiguration(value: CollectionCaseWidget) {\n    if (!value) return;\n    this.widgetConfiguration$.next(value);\n  }\n  public readonly showPagination$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _initialNumberOfElementsSubject$ = new BehaviorSubject<number>(null);\n\n  private get _initialNumberOfElements$(): Observable<number> {\n    return this._initialNumberOfElementsSubject$.pipe(\n      filter(numberOfElements => numberOfElements !== null)\n    );\n  }\n\n  @Input() public set widgetData(value: Page<CollectionCaseWidgetCardData> | null) {\n    if (!value) return;\n\n    this.showPagination$.next(value.totalElements > value.size);\n    this._initialNumberOfElementsSubject$.next(value.numberOfElements);\n    this._widgetDataSubject$.next(value.content);\n\n    this.paginationModel.set(\n      value.totalPages < 0\n        ? null\n        : {\n            currentPage: 1,\n            totalDataLength: Math.ceil(value.totalElements / value.size),\n            pageLength: value.size,\n          }\n    );\n    this.cdr.detectChanges();\n  }\n\n  public readonly widgetTitle = signal('-');\n\n  public readonly widgetConfiguration$ = new BehaviorSubject<CollectionCaseWidget | null>(null);\n  public readonly paginationModel = signal<PaginationModel>(new PaginationModel());\n  public readonly amountOfColumns = signal(0);\n\n  private readonly _widgetDataSubject$ = new BehaviorSubject<CollectionCaseWidgetCardData[]>(null);\n\n  private readonly _queryParams$ = new BehaviorSubject<string | null>(null);\n\n  private readonly _widgetData$: Observable<CollectionCaseWidgetCardData[]> = combineLatest([\n    this._widgetDataSubject$,\n    this._queryParams$,\n    this._initialNumberOfElements$,\n    this.widgetConfiguration$,\n  ]).pipe(\n    switchMap(([data, queryParams, initialNumberOfElements, widgetConfiguration]) =>\n      combineLatest([\n        !queryParams\n          ? of(data)\n          : this.widgetApiService\n              .getWidgetData(this.documentId, this.tabKey, widgetConfiguration.key, queryParams)\n              .pipe(map((res: Page<CollectionCaseWidgetCardData>) => res.content)),\n        of(initialNumberOfElements),\n      ])\n    ),\n    filter(([items]) => !!items),\n    map(([items, initialNumberOfElements]) => {\n      if (items.length === initialNumberOfElements) {\n        return items;\n      }\n\n      const rows = new Array<number>(initialNumberOfElements).fill(null);\n\n      return rows.map((_, index) => items[index] || {...items[0], hidden: true});\n    })\n  );\n\n  public readonly collectionWidgetCards$: Observable<\n    {title: string; fields: CollectionWidgetResolvedField[]; key: number; hidden: boolean}[]\n  > = combineLatest([this.widgetConfiguration$, this._widgetData$]).pipe(\n    filter(([widgetConfig, widgetData]) => !!widgetConfig && !!widgetData),\n    tap(([widgetConfig]) => this.widgetTitle.set(widgetConfig.title)),\n    map(([widgetConfig, widgetData]) =>\n      widgetData.map((cardData, index) => ({\n        hidden: cardData.hidden,\n        key: index,\n        title: this.getCardTitle({\n          value: cardData.title,\n          displayProperties: widgetConfig?.properties?.title?.displayProperties,\n        }),\n        fields: widgetConfig?.properties.fields.reduce(\n          (cardFieldsAccumulator, currentField) => [\n            ...cardFieldsAccumulator,\n            this.getCardField(currentField, cardData),\n          ],\n          []\n        ),\n      }))\n    )\n  );\n\n  private _observer!: ResizeObserver;\n\n  constructor(\n    private readonly viewContentService: ViewContentService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly widgetApiService: DossierWidgetsApiService\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this.openWidthObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._observer?.disconnect();\n  }\n\n  public onSelectPage(page: number): void {\n    this._queryParams$.next(`page=${page - 1}&size=${this.paginationModel().pageLength}`);\n    this.paginationModel.update((model: PaginationModel) => ({\n      ...model,\n      currentPage: page,\n    }));\n  }\n\n  private getCardField(\n    field: CollectionCaseWidgetField,\n    data: CollectionCaseWidgetCardData\n  ): CollectionWidgetResolvedField {\n    const resolvedValue = this.viewContentService.get(data.fields[field.key], {\n      ...field.displayProperties,\n      viewType: field.displayProperties?.type ?? CaseWidgetDisplayTypeKey.TEXT,\n    });\n\n    return {\n      key: field.key,\n      title: field.title,\n      width: field.width,\n      value: resolvedValue || data.fields[field.key],\n    };\n  }\n\n  private openWidthObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetCollectionRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const elementWidth = event[0]?.borderBoxSize[0]?.inlineSize;\n\n    if (typeof elementWidth === 'number' && elementWidth !== 0) {\n      if (elementWidth < 640) {\n        this.amountOfColumns.set(1);\n      } else if (elementWidth > 640 && elementWidth <= 768) {\n        this.amountOfColumns.set(2);\n      } else if (elementWidth > 768 && elementWidth <= 1080) {\n        this.amountOfColumns.set(3);\n      } else if (elementWidth > 1080) {\n        this.amountOfColumns.set(4);\n      }\n    }\n  }\n\n  private getCardTitle(collectionCaseWidgetTitle: CollectionCaseWidgetTitle): string {\n    const widgetTitleValue = collectionCaseWidgetTitle.value;\n    const widgetTitleDisplayProperties = collectionCaseWidgetTitle.displayProperties;\n\n    if (!widgetTitleDisplayProperties && widgetTitleValue) {\n      return widgetTitleValue;\n    } else if (widgetTitleDisplayProperties && widgetTitleValue) {\n      const convertedTitle = this.viewContentService.get(widgetTitleValue, {\n        ...widgetTitleDisplayProperties,\n        viewType: widgetTitleDisplayProperties.type,\n      });\n\n      if (convertedTitle) return convertedTitle;\n    }\n\n    return '-';\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    widgetConfiguration: widgetConfiguration$ | async,\n    collectionWidgetCards: collectionWidgetCards$ | async\n  } as obs\"\n>\n  <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n  <div\n    #widgetCollection\n    [ngClass]=\"{\n      'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n      'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n      'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n      'valtimo-widget-collection__container': amountOfColumns() === 4\n    }\"\n  >\n    @for (card of obs?.collectionWidgetCards; track card.key) {\n      <div\n        class=\"valtimo-widget-collection__card\"\n        [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n      >\n        <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n        @for (field of card.fields; track field.key) {\n          <div\n            [ngClass]=\"{\n              'valtimo-widget-collection__full-width-input': field?.width === 'full',\n              'valtimo-widget-collection__half-width-input': field?.width === 'half'\n            }\"\n          >\n            <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n              {{ field?.title }}\n\n              <input\n                [value]=\"field?.value\"\n                [readonly]=\"true\"\n                class=\"valtimo-widget-collection__card-input\"\n                cdsText\n              />\n            </cds-label>\n          </div>\n        }\n      </div>\n    }\n  </div>\n\n  @if (!obs?.collectionWidgetCards?.length) {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  }\n\n  <cds-pagination-nav\n    *ngIf=\"paginationModel() && (showPagination$ | async)\"\n    class=\"valtimo-widget-collection__pagination\"\n    [model]=\"paginationModel()\"\n    (selectPage)=\"onSelectPage($event)\"\n  >\n  </cds-pagination-nav>\n</ng-container>\n"]}
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-collection.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.ts","../../../../../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-detail/tab/widgets/components/collection/widget-collection.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {\n  InputModule,\n  PaginationModel,\n  PaginationModule,\n  TilesModule,\n} from 'carbon-components-angular';\nimport {\n  CaseWidgetDisplayTypeKey,\n  CollectionCaseWidget,\n  CollectionCaseWidgetCardData,\n  CollectionCaseWidgetField,\n  CollectionCaseWidgetTitle,\n  CollectionWidgetResolvedField,\n} from '../../../../../../models';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, of, switchMap, tap} from 'rxjs';\nimport {CarbonListModule, ViewContentService} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Page} from '@valtimo/config';\nimport {DossierWidgetsApiService} from '../../../../../../services';\n\n@Component({\n  selector: 'valtimo-widget-collection',\n  templateUrl: './widget-collection.component.html',\n  styleUrls: ['./widget-collection.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    InputModule,\n    PaginationModule,\n    TilesModule,\n    CarbonListModule,\n    TranslateModule,\n  ],\n})\nexport class WidgetCollectionComponent implements AfterViewInit, OnDestroy {\n  @HostBinding('class') public readonly class = 'valtimo-widget-collection';\n  @ViewChild('widgetCollection') private _widgetCollectionRef: ElementRef<HTMLDivElement>;\n\n  @Input({required: true}) public documentId: string;\n  @Input({required: true}) public tabKey: string;\n  @Input() public set widgetConfiguration(value: CollectionCaseWidget) {\n    if (!value) return;\n    this.widgetConfiguration$.next(value);\n  }\n  public readonly showPagination$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _initialNumberOfElementsSubject$ = new BehaviorSubject<number>(null);\n\n  private get _initialNumberOfElements$(): Observable<number> {\n    return this._initialNumberOfElementsSubject$.pipe(\n      filter(numberOfElements => numberOfElements !== null)\n    );\n  }\n\n  @Input() public set widgetData(value: Page<CollectionCaseWidgetCardData> | null) {\n    if (!value) return;\n\n    this.showPagination$.next(value.totalElements > value.size);\n    this._initialNumberOfElementsSubject$.next(value.numberOfElements);\n    this._widgetDataSubject$.next(value.content);\n\n    this.paginationModel.set(\n      value.totalPages < 0\n        ? null\n        : {\n            currentPage: 1,\n            totalDataLength: Math.ceil(value.totalElements / value.size),\n            pageLength: value.size,\n          }\n    );\n    this.cdr.detectChanges();\n  }\n\n  public readonly widgetTitle = signal('-');\n\n  public readonly widgetConfiguration$ = new BehaviorSubject<CollectionCaseWidget | null>(null);\n  public readonly paginationModel = signal<PaginationModel>(new PaginationModel());\n  public readonly amountOfColumns = signal(0);\n\n  private readonly _widgetDataSubject$ = new BehaviorSubject<CollectionCaseWidgetCardData[]>(null);\n\n  private readonly _queryParams$ = new BehaviorSubject<string | null>(null);\n\n  private readonly _widgetData$: Observable<CollectionCaseWidgetCardData[]> = combineLatest([\n    this._widgetDataSubject$,\n    this._queryParams$,\n    this._initialNumberOfElements$,\n    this.widgetConfiguration$,\n  ]).pipe(\n    switchMap(([data, queryParams, initialNumberOfElements, widgetConfiguration]) =>\n      combineLatest([\n        !queryParams\n          ? of(data)\n          : this.widgetApiService\n              .getWidgetData(this.documentId, this.tabKey, widgetConfiguration.key, queryParams)\n              .pipe(map((res: Page<CollectionCaseWidgetCardData>) => res.content)),\n        of(initialNumberOfElements),\n      ])\n    ),\n    filter(([items]) => !!items),\n    map(([items, initialNumberOfElements]) => {\n      if (items.length === initialNumberOfElements) {\n        return items;\n      }\n\n      const rows = new Array<number>(initialNumberOfElements).fill(null);\n\n      return rows.map((_, index) => items[index] || {...items[0], hidden: true});\n    })\n  );\n\n  public readonly collectionWidgetCards$: Observable<\n    {title: string; fields: CollectionWidgetResolvedField[]; key: number; hidden: boolean}[]\n  > = combineLatest([this.widgetConfiguration$, this._widgetData$]).pipe(\n    filter(([widgetConfig, widgetData]) => !!widgetConfig && !!widgetData),\n    tap(([widgetConfig]) => this.widgetTitle.set(widgetConfig.title)),\n    map(([widgetConfig, widgetData]) =>\n      widgetData.map((cardData, index) => ({\n        hidden: cardData.hidden,\n        key: index,\n        title: this.getCardTitle({\n          value: cardData.title,\n          displayProperties: widgetConfig?.properties?.title?.displayProperties,\n        }),\n        fields: widgetConfig?.properties.fields.reduce(\n          (cardFieldsAccumulator, currentField) => [\n            ...cardFieldsAccumulator,\n            this.getCardField(currentField, cardData),\n          ],\n          []\n        ),\n      }))\n    )\n  );\n\n  private _observer!: ResizeObserver;\n\n  constructor(\n    private readonly viewContentService: ViewContentService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly widgetApiService: DossierWidgetsApiService\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this.openWidthObserver();\n  }\n\n  public ngOnDestroy(): void {\n    this._observer?.disconnect();\n  }\n\n  public onSelectPage(page: number): void {\n    this._queryParams$.next(`page=${page - 1}&size=${this.paginationModel().pageLength}`);\n    this.paginationModel.update((model: PaginationModel) => ({\n      ...model,\n      currentPage: page,\n    }));\n  }\n\n  private getCardField(\n    field: CollectionCaseWidgetField,\n    data: CollectionCaseWidgetCardData\n  ): CollectionWidgetResolvedField {\n    const resolvedValue = this.viewContentService.get(data.fields[field.key], {\n      ...field.displayProperties,\n      viewType: field.displayProperties?.type ?? CaseWidgetDisplayTypeKey.TEXT,\n    });\n\n    return {\n      key: field.key,\n      title: field.title,\n      width: field.width,\n      value: resolvedValue || data.fields[field.key],\n    };\n  }\n\n  private openWidthObserver(): void {\n    this._observer = new ResizeObserver(event => {\n      this.observerMutation(event);\n    });\n    this._observer.observe(this._widgetCollectionRef.nativeElement);\n  }\n\n  private observerMutation(event: Array<ResizeObserverEntry>): void {\n    const elementWidth = event[0]?.borderBoxSize[0]?.inlineSize;\n\n    if (typeof elementWidth === 'number' && elementWidth !== 0) {\n      if (elementWidth < 640) {\n        this.amountOfColumns.set(1);\n      } else if (elementWidth > 640 && elementWidth <= 768) {\n        this.amountOfColumns.set(2);\n      } else if (elementWidth > 768 && elementWidth <= 1080) {\n        this.amountOfColumns.set(3);\n      } else if (elementWidth > 1080) {\n        this.amountOfColumns.set(4);\n      }\n    }\n  }\n\n  private getCardTitle(collectionCaseWidgetTitle: CollectionCaseWidgetTitle): string {\n    const widgetTitleValue = collectionCaseWidgetTitle.value;\n    const widgetTitleDisplayProperties = collectionCaseWidgetTitle.displayProperties;\n\n    if (!widgetTitleDisplayProperties && widgetTitleValue) {\n      return widgetTitleValue;\n    } else if (widgetTitleDisplayProperties && widgetTitleValue) {\n      const convertedTitle = this.viewContentService.get(widgetTitleValue, {\n        ...widgetTitleDisplayProperties,\n        viewType: widgetTitleDisplayProperties.type,\n      });\n\n      if (convertedTitle) return convertedTitle;\n    }\n\n    return '-';\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    widgetConfiguration: widgetConfiguration$ | async,\n    collectionWidgetCards: collectionWidgetCards$ | async,\n  } as obs\"\n>\n  <span class=\"valtimo-widget-collection__title\">{{ widgetTitle() }}</span>\n\n  <div\n    #widgetCollection\n    [ngClass]=\"{\n      'valtimo-widget-collection__render-vertically': amountOfColumns() === 1,\n      'valtimo-widget-collection__render-two-columns': amountOfColumns() === 2,\n      'valtimo-widget-collection__render-three-columns': amountOfColumns() === 3,\n      'valtimo-widget-collection__container': amountOfColumns() === 4,\n    }\"\n  >\n    @for (card of obs?.collectionWidgetCards; track card.key) {\n      <div\n        class=\"valtimo-widget-collection__card\"\n        [ngClass]=\"{'valtimo-widget-collection__card--hidden': card.hidden}\"\n      >\n        <span class=\"valtimo-widget-collection__card-title\">{{ card.title }}</span>\n\n        @for (field of card.fields; track field.key) {\n          <div\n            [ngClass]=\"{\n              'valtimo-widget-collection__full-width-input': field?.width === 'full',\n              'valtimo-widget-collection__half-width-input': field?.width === 'half',\n            }\"\n          >\n            <cds-label class=\"valtimo-widget-collection__label\" [attr.title]=\"field?.title\">\n              {{ field?.title }}\n\n              <input\n                [value]=\"field?.value\"\n                [readonly]=\"true\"\n                class=\"valtimo-widget-collection__card-input\"\n                cdsText\n              />\n            </cds-label>\n          </div>\n        }\n      </div>\n    }\n  </div>\n\n  @if (!obs?.collectionWidgetCards?.length) {\n    <valtimo-no-results\n      [collapseVertically]=\"true\"\n      [description]=\"'dossier.widgets.noData' | translate\"\n      [smallPadding]=\"true\"\n    ></valtimo-no-results>\n  }\n\n  <cds-pagination-nav\n    *ngIf=\"paginationModel() && (showPagination$ | async)\"\n    class=\"valtimo-widget-collection__pagination\"\n    [model]=\"paginationModel()\"\n    (selectPage)=\"onSelectPage($event)\"\n  >\n  </cds-pagination-nav>\n</ng-container>\n"]}
|