@valtimo/plugin 12.5.1 → 12.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/default-plugin-configuration/default-plugin-configuration.component.mjs +1 -1
- package/esm2022/lib/components/plugin-configuration-container/plugin-configuration-container.component.mjs +16 -3
- package/esm2022/lib/models/plugin.mjs +1 -1
- package/esm2022/lib/plugins/besluiten-api/components/besluiten-api-configuration/besluiten-api-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/besluiten-api/components/create-zaak-besluit/create-zaak-besluit-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/besluiten-api/components/link-document-to-besluit/link-document-to-besluit-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/catalogi-api/components/catalogi-api-configuration/catalogi-api-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/catalogi-api/components/get-besluittype/get-besluittype-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/catalogi-api/components/get-resultaattype/get-resultaattype-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/catalogi-api/components/get-statustype/get-statustype-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/documenten-api/components/documenten-api-configuration/documenten-api-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/documenten-api/components/download-document/download-document-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/documenten-api/components/store-temp-document/store-temp-document-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/exact/components/exact-action-get-request-configuration/exact-get-request-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/exact/components/exact-action-post-request-configuration/exact-post-request-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/exact/components/exact-action-put-request-configuration/exact-put-request-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/exact/components/exact-plugin-configuration/exact-plugin-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/notificaties-api/components/notificaties-api-configuration/notificaties-api-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/notificaties-api-authentication/components/open-notificaties-configuration/open-notificaties-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/object-token-authentication/components/object-token-authentication-configuration/object-token-authencation-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/objecten-api/components/delete-object/delete-object.component.mjs +3 -3
- package/esm2022/lib/plugins/objecten-api/components/objecten-api-configuration/objecten-api-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/objecttypen-api/components/objecttypen-api-configuration/objecttypen-api-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/open-zaak/components/open-zaak-configuration/open-zaak-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/portaaltaak/components/create-portal-task/create-portal-task.component.mjs +5 -3
- package/esm2022/lib/plugins/portaaltaak/components/portaaltaak-configuration/portaaltaak-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/portaaltaak/portaaltaak-plugin.specification.mjs +27 -15
- package/esm2022/lib/plugins/smart-documents/components/generate-document-configuration/generate-document-configuration.component.mjs +5 -3
- package/esm2022/lib/plugins/smart-documents/components/get-template-names/get-template-names.component.mjs +3 -3
- package/esm2022/lib/plugins/smart-documents/components/smart-documents-configuration/smart-documents-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/smart-documents/smart-documents-plugin.specification.mjs +7 -1
- package/esm2022/lib/plugins/verzoek/components/verzoek-configuration/verzoek-configuration.component.mjs +9 -4
- package/esm2022/lib/plugins/zaken-api/components/create-natuurlijk-persoon-zaak-rol/create-natuurlijk-persoon-zaak-rol.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/create-niet-natuurlijk-persoon-zaak-rol/create-niet-natuurlijk-persoon-zaak-rol.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/create-zaak/create-zaak-configuration.component.mjs +43 -11
- package/esm2022/lib/plugins/zaken-api/components/create-zaak-resultaat/create-zaak-resultaat-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/create-zaakeigenschap/create-zaakeigenschap.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/delete-zaakeigenschap/delete-zaakeigenschap.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/link-document-to-zaak/link-document-to-zaak-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/set-zaak-status/set-zaak-status-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/set-zaakopschorting/set-zaakopschorting.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/start-hersteltermijn/start-hersteltermijn-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/update-zaakeigenschap/update-zaakeigenschap.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/components/zaken-api-configuration/zaken-api-configuration.component.mjs +3 -3
- package/esm2022/lib/plugins/zaken-api/models/config.mjs +1 -1
- package/esm2022/lib/plugins/zaken-api/models/create-zaak-properties.mjs +6 -0
- package/esm2022/lib/plugins/zaken-api/zaken-api-plugin.module.mjs +20 -4
- package/esm2022/lib/plugins/zaken-api/zaken-api-plugin.specification.mjs +13 -1
- package/fesm2022/valtimo-plugin.mjs +217 -115
- package/fesm2022/valtimo-plugin.mjs.map +1 -1
- package/lib/components/plugin-configuration-container/plugin-configuration-container.component.d.ts +3 -2
- package/lib/components/plugin-configuration-container/plugin-configuration-container.component.d.ts.map +1 -1
- package/lib/models/plugin.d.ts +1 -0
- package/lib/models/plugin.d.ts.map +1 -1
- package/lib/plugins/documenten-api/components/store-temp-document/store-temp-document-configuration.component.d.ts.map +1 -1
- package/lib/plugins/portaaltaak/components/create-portal-task/create-portal-task.component.d.ts +2 -1
- package/lib/plugins/portaaltaak/components/create-portal-task/create-portal-task.component.d.ts.map +1 -1
- package/lib/plugins/portaaltaak/portaaltaak-plugin.specification.d.ts.map +1 -1
- package/lib/plugins/smart-documents/components/generate-document-configuration/generate-document-configuration.component.d.ts +2 -0
- package/lib/plugins/smart-documents/components/generate-document-configuration/generate-document-configuration.component.d.ts.map +1 -1
- package/lib/plugins/smart-documents/smart-documents-plugin.specification.d.ts.map +1 -1
- package/lib/plugins/verzoek/components/verzoek-configuration/verzoek-configuration.component.d.ts +3 -1
- package/lib/plugins/verzoek/components/verzoek-configuration/verzoek-configuration.component.d.ts.map +1 -1
- package/lib/plugins/zaken-api/components/create-zaak/create-zaak-configuration.component.d.ts +10 -1
- package/lib/plugins/zaken-api/components/create-zaak/create-zaak-configuration.component.d.ts.map +1 -1
- package/lib/plugins/zaken-api/models/config.d.ts +3 -0
- package/lib/plugins/zaken-api/models/config.d.ts.map +1 -1
- package/lib/plugins/zaken-api/models/create-zaak-properties.d.ts +3 -0
- package/lib/plugins/zaken-api/models/create-zaak-properties.d.ts.map +1 -0
- package/lib/plugins/zaken-api/zaken-api-plugin.module.d.ts +2 -1
- package/lib/plugins/zaken-api/zaken-api-plugin.module.d.ts.map +1 -1
- package/lib/plugins/zaken-api/zaken-api-plugin.specification.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -53,11 +53,11 @@ export class CreateNietNatuurlijkPersoonZaakRolComponent {
|
|
|
53
53
|
});
|
|
54
54
|
}
|
|
55
55
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateNietNatuurlijkPersoonZaakRolComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
56
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateNietNatuurlijkPersoonZaakRolComponent, selector: "valtimo-create-niet-natuurlijk-persoon-zaak-rol-configuration", inputs: { save$: "save$", disabled$: "disabled$", pluginId: "pluginId", prefillConfiguration$: "prefillConfiguration$" }, outputs: { valid: "valid", configuration: "configuration" }, 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<v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"{\n disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n } as obs\"\n>\n <v-input\n name=\"roltypeUrl\"\n [title]=\"'roltypeUrl' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.roltypeUrl\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [tooltip]=\"'roltypeUrlTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"rolToelichting\"\n [title]=\"'rolToelichting' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.rolToelichting\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [tooltip]=\"'rolToelichtingTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"innNnpId\"\n [title]=\"'innNnpId' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.innNnpId\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [tooltip]=\"'innNnpIdTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"annIdentificatie\"\n [title]=\"'annIdentificatie' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.annIdentificatie\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [tooltip]=\"'annIdentificatieTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n</v-form>\n", styles: ["/*!\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: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormComponent, selector: "v-form", inputs: ["className"], outputs: ["valueChange"] }, { kind: "component", type: i2.InputComponent, selector: "v-input", inputs: ["name", "type", "title", "titleTranslationKey", "defaultValue", "widthPx", "fullWidth", "margin", "smallMargin", "disabled", "step", "min", "maxLength", "tooltip", "required", "hideNumberSpinBox", "smallLabel", "rows", "clear$", "carbonTheme", "placeholder", "dataTestId"], outputs: ["valueChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.PluginTranslatePipe, name: "pluginTranslate" }] }); }
|
|
56
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateNietNatuurlijkPersoonZaakRolComponent, selector: "valtimo-create-niet-natuurlijk-persoon-zaak-rol-configuration", inputs: { save$: "save$", disabled$: "disabled$", pluginId: "pluginId", prefillConfiguration$: "prefillConfiguration$" }, outputs: { valid: "valid", configuration: "configuration" }, 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<v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"{\n disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n } as obs\"\n>\n <v-input\n name=\"roltypeUrl\"\n [title]=\"'roltypeUrl' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.roltypeUrl\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'roltypeUrlTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"rolToelichting\"\n [title]=\"'rolToelichting' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.rolToelichting\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [tooltip]=\"'rolToelichtingTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"innNnpId\"\n [title]=\"'innNnpId' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.innNnpId\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [trim]=\"true\"\n [tooltip]=\"'innNnpIdTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"annIdentificatie\"\n [title]=\"'annIdentificatie' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.annIdentificatie\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [trim]=\"true\"\n [tooltip]=\"'annIdentificatieTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n</v-form>\n", styles: ["/*!\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: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormComponent, selector: "v-form", inputs: ["className"], outputs: ["valueChange"] }, { kind: "component", type: i2.InputComponent, selector: "v-input", inputs: ["name", "type", "title", "titleTranslationKey", "defaultValue", "widthPx", "fullWidth", "margin", "smallMargin", "disabled", "step", "min", "maxLength", "tooltip", "required", "hideNumberSpinBox", "smallLabel", "rows", "clear$", "carbonTheme", "placeholder", "dataTestId", "trim"], outputs: ["valueChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.PluginTranslatePipe, name: "pluginTranslate" }] }); }
|
|
57
57
|
}
|
|
58
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateNietNatuurlijkPersoonZaakRolComponent, decorators: [{
|
|
59
59
|
type: Component,
|
|
60
|
-
args: [{ selector: 'valtimo-create-niet-natuurlijk-persoon-zaak-rol-configuration', 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<v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"{\n disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n } as obs\"\n>\n <v-input\n name=\"roltypeUrl\"\n [title]=\"'roltypeUrl' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.roltypeUrl\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [tooltip]=\"'roltypeUrlTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"rolToelichting\"\n [title]=\"'rolToelichting' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.rolToelichting\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [tooltip]=\"'rolToelichtingTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"innNnpId\"\n [title]=\"'innNnpId' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.innNnpId\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [tooltip]=\"'innNnpIdTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"annIdentificatie\"\n [title]=\"'annIdentificatie' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.annIdentificatie\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [tooltip]=\"'annIdentificatieTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n</v-form>\n", styles: ["/*!\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
|
+
args: [{ selector: 'valtimo-create-niet-natuurlijk-persoon-zaak-rol-configuration', 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<v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"{\n disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n } as obs\"\n>\n <v-input\n name=\"roltypeUrl\"\n [title]=\"'roltypeUrl' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.roltypeUrl\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'roltypeUrlTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"rolToelichting\"\n [title]=\"'rolToelichting' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.rolToelichting\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [tooltip]=\"'rolToelichtingTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"innNnpId\"\n [title]=\"'innNnpId' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.innNnpId\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [trim]=\"true\"\n [tooltip]=\"'innNnpIdTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-input\n name=\"annIdentificatie\"\n [title]=\"'annIdentificatie' | pluginTranslate: pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.annIdentificatie\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [trim]=\"true\"\n [tooltip]=\"'annIdentificatieTooltip' | pluginTranslate: pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n</v-form>\n", styles: ["/*!\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"] }]
|
|
61
61
|
}], propDecorators: { save$: [{
|
|
62
62
|
type: Input
|
|
63
63
|
}], disabled$: [{
|
|
@@ -71,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
71
71
|
}], configuration: [{
|
|
72
72
|
type: Output
|
|
73
73
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-niet-natuurlijk-persoon-zaak-rol.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/create-niet-natuurlijk-persoon-zaak-rol/create-niet-natuurlijk-persoon-zaak-rol.component.ts","../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/create-niet-natuurlijk-persoon-zaak-rol/create-niet-natuurlijk-persoon-zaak-rol.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAC,MAAM,eAAe,CAAC;AAExF,OAAO,EAAC,eAAe,EAAE,aAAa,EAA4B,IAAI,EAAC,MAAM,MAAM,CAAC;;;;;AAQpF,MAAM,OAAO,2CAA2C;IALxD;QAYY,UAAK,GAA0B,IAAI,YAAY,EAAW,CAAC;QAC3D,kBAAa,GACrB,IAAI,YAAY,EAA6C,CAAC;QAI/C,eAAU,GACzB,IAAI,eAAe,CAAmD,IAAI,CAAC,CAAC;QAC7D,WAAM,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;KAiC/D;IA/BC,QAAQ;QACN,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,EAAE,WAAW,EAAE,CAAC;IACvC,CAAC;IAED,eAAe,CAAC,SAAoD;QAClE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAChC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IAC9B,CAAC;IAEO,WAAW,CAAC,SAAoD;QACtE,MAAM,KAAK,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,cAAc,IAAI,SAAS,CAAC,UAAU,CAAC,CAAC;QAEnE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAEO,oBAAoB;QAC1B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE;YACnD,aAAa,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;iBAC1C,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACb,SAAS,CAAC,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC,EAAE,EAAE;gBAChC,IAAI,KAAK,EAAE,CAAC;oBACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBACrC,CAAC;YACH,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;+GA/CU,2CAA2C;mGAA3C,2CAA2C,4RC1BxD,k0EAuEA;;4FD7Ca,2CAA2C;kBALvD,SAAS;+BACE,+DAA+D;8BAOhE,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACI,KAAK;sBAAd,MAAM;gBACG,aAAa;sBAAtB,MAAM","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, EventEmitter, Input, OnDestroy, OnInit, Output} from '@angular/core';\nimport {FunctionConfigurationComponent} from '../../../../models';\nimport {BehaviorSubject, combineLatest, Observable, Subscription, take} from 'rxjs';\nimport {CreateNietNatuurlijkePersoonZaakRolConfig} from '../../models';\n\n@Component({\n  selector: 'valtimo-create-niet-natuurlijk-persoon-zaak-rol-configuration',\n  templateUrl: './create-niet-natuurlijk-persoon-zaak-rol.component.html',\n  styleUrls: ['./create-niet-natuurlijk-persoon-zaak-rol.component.scss'],\n})\nexport class CreateNietNatuurlijkPersoonZaakRolComponent\n  implements FunctionConfigurationComponent, OnInit, OnDestroy\n{\n  @Input() save$: Observable<void>;\n  @Input() disabled$: Observable<boolean>;\n  @Input() pluginId: string;\n  @Input() prefillConfiguration$: Observable<CreateNietNatuurlijkePersoonZaakRolConfig>;\n  @Output() valid: EventEmitter<boolean> = new EventEmitter<boolean>();\n  @Output() configuration: EventEmitter<CreateNietNatuurlijkePersoonZaakRolConfig> =\n    new EventEmitter<CreateNietNatuurlijkePersoonZaakRolConfig>();\n\n  private saveSubscription!: Subscription;\n\n  private readonly formValue$ =\n    new BehaviorSubject<CreateNietNatuurlijkePersoonZaakRolConfig | null>(null);\n  private readonly valid$ = new BehaviorSubject<boolean>(false);\n\n  ngOnInit(): void {\n    this.openSaveSubscription();\n  }\n\n  ngOnDestroy() {\n    this.saveSubscription?.unsubscribe();\n  }\n\n  formValueChange(formValue: CreateNietNatuurlijkePersoonZaakRolConfig): void {\n    this.formValue$.next(formValue);\n    this.handleValid(formValue);\n  }\n\n  private handleValid(formValue: CreateNietNatuurlijkePersoonZaakRolConfig): void {\n    const valid = !!(formValue.rolToelichting && formValue.roltypeUrl);\n\n    this.valid$.next(valid);\n    this.valid.emit(valid);\n  }\n\n  private openSaveSubscription(): void {\n    this.saveSubscription = this.save$?.subscribe(save => {\n      combineLatest([this.formValue$, this.valid$])\n        .pipe(take(1))\n        .subscribe(([formValue, valid]) => {\n          if (valid) {\n            this.configuration.emit(formValue);\n          }\n        });\n    });\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<v-form\n  (valueChange)=\"formValueChange($event)\"\n  *ngIf=\"{\n    disabled: disabled$ | async,\n    prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n  } as obs\"\n>\n  <v-input\n    name=\"roltypeUrl\"\n    [title]=\"'roltypeUrl' | pluginTranslate: pluginId | async\"\n    [margin]=\"true\"\n    [defaultValue]=\"obs.prefill?.roltypeUrl\"\n    [disabled]=\"obs.disabled\"\n    [required]=\"true\"\n    [trim]=\"true\"\n    [tooltip]=\"'roltypeUrlTooltip' | pluginTranslate: pluginId | async\"\n    [fullWidth]=\"true\"\n  >\n  </v-input>\n  <v-input\n    name=\"rolToelichting\"\n    [title]=\"'rolToelichting' | pluginTranslate: pluginId | async\"\n    [margin]=\"true\"\n    [defaultValue]=\"obs.prefill?.rolToelichting\"\n    [disabled]=\"obs.disabled\"\n    [required]=\"true\"\n    [tooltip]=\"'rolToelichtingTooltip' | pluginTranslate: pluginId | async\"\n    [fullWidth]=\"true\"\n  >\n  </v-input>\n  <v-input\n    name=\"innNnpId\"\n    [title]=\"'innNnpId' | pluginTranslate: pluginId | async\"\n    [margin]=\"true\"\n    [defaultValue]=\"obs.prefill?.innNnpId\"\n    [disabled]=\"obs.disabled\"\n    [required]=\"false\"\n    [trim]=\"true\"\n    [tooltip]=\"'innNnpIdTooltip' | pluginTranslate: pluginId | async\"\n    [fullWidth]=\"true\"\n  >\n  </v-input>\n  <v-input\n    name=\"annIdentificatie\"\n    [title]=\"'annIdentificatie' | pluginTranslate: pluginId | async\"\n    [margin]=\"true\"\n    [defaultValue]=\"obs.prefill?.annIdentificatie\"\n    [disabled]=\"obs.disabled\"\n    [required]=\"false\"\n    [trim]=\"true\"\n    [tooltip]=\"'annIdentificatieTooltip' | pluginTranslate: pluginId | async\"\n    [fullWidth]=\"true\"\n  >\n  </v-input>\n</v-form>\n"]}
|
package/esm2022/lib/plugins/zaken-api/components/create-zaak/create-zaak-configuration.component.mjs
CHANGED
|
@@ -16,25 +16,29 @@
|
|
|
16
16
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
17
17
|
import { BehaviorSubject, combineLatest, filter, map, switchMap, take, tap, } from 'rxjs';
|
|
18
18
|
import { PluginTranslatePipe } from '../../../../pipes';
|
|
19
|
+
import { Add16, TrashCan16 } from '@carbon/icons';
|
|
20
|
+
import { ExtraPropertiesOptions } from '../../models/create-zaak-properties';
|
|
19
21
|
import * as i0 from "@angular/core";
|
|
20
22
|
import * as i1 from "@valtimo/resource";
|
|
21
23
|
import * as i2 from "@valtimo/document";
|
|
22
24
|
import * as i3 from "@valtimo/components";
|
|
23
25
|
import * as i4 from "../../../../pipes";
|
|
24
|
-
import * as i5 from "
|
|
25
|
-
import * as i6 from "
|
|
26
|
+
import * as i5 from "carbon-components-angular";
|
|
27
|
+
import * as i6 from "@angular/common";
|
|
26
28
|
import * as i7 from "../../../../pipes/plugin-translate/plugin-translate.pipe";
|
|
27
29
|
export class CreateZaakConfigurationComponent {
|
|
28
30
|
set pluginId(value) {
|
|
29
31
|
this.pluginId$.next(value);
|
|
30
32
|
}
|
|
31
|
-
constructor(openZaakService, documentService, modalService, pluginTranslatePipe) {
|
|
33
|
+
constructor(openZaakService, documentService, modalService, pluginTranslatePipe, iconService) {
|
|
32
34
|
this.openZaakService = openZaakService;
|
|
33
35
|
this.documentService = documentService;
|
|
34
36
|
this.modalService = modalService;
|
|
35
37
|
this.pluginTranslatePipe = pluginTranslatePipe;
|
|
38
|
+
this.iconService = iconService;
|
|
36
39
|
this.valid = new EventEmitter();
|
|
37
40
|
this.configuration = new EventEmitter();
|
|
41
|
+
this.propertyList = [];
|
|
38
42
|
this.pluginId$ = new BehaviorSubject('');
|
|
39
43
|
this.selectedInputOption$ = new BehaviorSubject('selection');
|
|
40
44
|
this.inputTypeOptions$ = this.pluginId$.pipe(filter(pluginId => !!pluginId), switchMap(pluginId => combineLatest([
|
|
@@ -46,6 +50,7 @@ export class CreateZaakConfigurationComponent {
|
|
|
46
50
|
]));
|
|
47
51
|
this.formValue$ = new BehaviorSubject(null);
|
|
48
52
|
this.valid$ = new BehaviorSubject(false);
|
|
53
|
+
this._properties = new Map();
|
|
49
54
|
this.loading$ = new BehaviorSubject(true);
|
|
50
55
|
this.zaakTypeItems$ = this.modalService.modalData$.pipe(switchMap(params => this.documentService.findProcessDocumentDefinitionsByProcessDefinitionKey(params?.processDefinitionKey)), switchMap(processDocumentDefinitions => combineLatest([
|
|
51
56
|
this.openZaakService.getZaakTypes(),
|
|
@@ -71,14 +76,19 @@ export class CreateZaakConfigurationComponent {
|
|
|
71
76
|
}), tap(() => {
|
|
72
77
|
this.loading$.next(false);
|
|
73
78
|
}));
|
|
79
|
+
this.iconService.registerAll([Add16, TrashCan16]);
|
|
74
80
|
}
|
|
75
81
|
ngOnInit() {
|
|
76
82
|
this.openSaveSubscription();
|
|
83
|
+
this.prefillConfiguration$.pipe(take(1)).subscribe(prefill => {
|
|
84
|
+
ExtraPropertiesOptions.filter(property => !!prefill[property]).forEach(property => this.addCaseProperty(property));
|
|
85
|
+
});
|
|
77
86
|
}
|
|
78
87
|
ngOnDestroy() {
|
|
79
88
|
this.saveSubscription?.unsubscribe();
|
|
80
89
|
}
|
|
81
90
|
formValueChange(formValue) {
|
|
91
|
+
this._properties.forEach((value, key) => (formValue[key] = value));
|
|
82
92
|
const inputTypeZaakTypeToggle = formValue.inputTypeZaakTypeToggle;
|
|
83
93
|
this.formValue$.next(formValue);
|
|
84
94
|
this.handleValid(formValue);
|
|
@@ -99,7 +109,8 @@ export class CreateZaakConfigurationComponent {
|
|
|
99
109
|
return false;
|
|
100
110
|
}
|
|
101
111
|
handleValid(formValue) {
|
|
102
|
-
const
|
|
112
|
+
const isPropertyInvalid = this.propertyList.some(property => !!!formValue[property]);
|
|
113
|
+
const valid = !!(formValue.rsin && formValue.zaaktypeUrl) && !isPropertyInvalid;
|
|
103
114
|
this.valid$.next(valid);
|
|
104
115
|
this.valid.emit(valid);
|
|
105
116
|
}
|
|
@@ -109,22 +120,43 @@ export class CreateZaakConfigurationComponent {
|
|
|
109
120
|
.pipe(take(1))
|
|
110
121
|
.subscribe(([formValue, valid]) => {
|
|
111
122
|
if (valid) {
|
|
112
|
-
|
|
123
|
+
const payload = {
|
|
113
124
|
rsin: formValue.rsin,
|
|
114
125
|
zaaktypeUrl: formValue.zaaktypeUrl,
|
|
115
126
|
manualZaakTypeUrl: formValue.manualZaakTypeUrl,
|
|
116
|
-
}
|
|
127
|
+
};
|
|
128
|
+
this.propertyList.forEach(property => (payload[property] = formValue[property]));
|
|
129
|
+
this.configuration.emit(payload);
|
|
117
130
|
}
|
|
118
131
|
});
|
|
119
132
|
});
|
|
120
133
|
}
|
|
121
|
-
|
|
122
|
-
|
|
134
|
+
addCaseProperty(property) {
|
|
135
|
+
this.propertyList.push(property);
|
|
136
|
+
}
|
|
137
|
+
removeCaseProperty(property) {
|
|
138
|
+
this.propertyList.splice(this.propertyList.indexOf(property), 1);
|
|
139
|
+
this._properties.delete(property);
|
|
140
|
+
this.onPropertyChanged(property, undefined);
|
|
141
|
+
}
|
|
142
|
+
hasPropertyBeenAdded(property) {
|
|
143
|
+
return this.propertyList.indexOf(property) !== -1;
|
|
144
|
+
}
|
|
145
|
+
onPropertyChanged(property, value) {
|
|
146
|
+
this._properties.set(property, value);
|
|
147
|
+
this.formValue$
|
|
148
|
+
.pipe(filter(formValue => formValue !== null), take(1))
|
|
149
|
+
.subscribe(formValue => {
|
|
150
|
+
this.formValueChange(formValue);
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateZaakConfigurationComponent, deps: [{ token: i1.OpenZaakService }, { token: i2.DocumentService }, { token: i3.ModalService }, { token: i4.PluginTranslatePipe }, { token: i5.IconService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
154
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: CreateZaakConfigurationComponent, selector: "valtimo-create-zaak-configuration", inputs: { save$: "save$", disabled$: "disabled$", pluginId: "pluginId", prefillConfiguration$: "prefillConfiguration$" }, outputs: { valid: "valid", configuration: "configuration" }, providers: [PluginTranslatePipe], 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 disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n pluginId: pluginId$ | async,\n selectedInputOption: selectedInputOption$ | async,\n zaakTypeSelectItems: zaakTypeItems$ | async,\n loading: loading$ | async,\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <v-paragraph [margin]=\"true\" [italic]=\"true\">\n {{ 'createZaakInformation' | pluginTranslate: obs.pluginId | async }}\n </v-paragraph>\n <v-form (valueChange)=\"formValueChange($event)\">\n <v-input\n name=\"rsin\"\n [title]=\"'rsin' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.rsin\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'rsinTooltip' | pluginTranslate: obs.pluginId | async\"\n [widthPx]=\"350\"\n >\n </v-input>\n <v-radio\n name=\"inputTypeZaakTypeToggle\"\n [disabled]=\"obs.disabled\"\n [title]=\"'inputTypeZaakTypeToggle' | pluginTranslate: obs.pluginId | async\"\n [radioValues]=\"inputTypeOptions$ | async\"\n [defaultValue]=\"selectedInputOption$ | async\"\n [margin]=\"true\"\n >\n </v-radio>\n <v-input\n *ngIf=\"obs.selectedInputOption === 'text'\"\n name=\"zaaktypeUrl\"\n [title]=\"'zaakTypeUrl' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.zaaktypeUrl\"\n [disabled]=\"obs.disabled || obs.selectedInputOption === 'selection'\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'zaakTypeTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n <v-select\n [items]=\"obs.zaakTypeSelectItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"zaaktypeUrl\"\n [title]=\"'zaakType' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n oneSelectItem(obs.zaakTypeSelectItems)\n \"\n [defaultSelectionId]=\"\n (selectItemsIncludeId(obs.zaakTypeSelectItems, obs.prefill?.zaaktypeUrl) &&\n obs.prefill?.zaaktypeUrl) ||\n (oneSelectItem(obs.zaakTypeSelectItems) && obs.zaakTypeSelectItems[0].id)\n \"\n [required]=\"true\"\n [loading]=\"!obs.zaakTypeSelectItems\"\n [tooltip]=\"'zaakTypeSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n ></v-select>\n </ng-container>\n\n @for (property of propertyList; track property) {\n @if (property === 'description') {\n <div class=\"property-input\">\n <v-input\n name=\"description\"\n [title]=\"'beschrijving' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.description\"\n [required]=\"true\"\n (valueChange)=\"onPropertyChanged('description', $event)\"\n />\n\n <button class=\"btn btn-space delete-button\" (click)=\"removeCaseProperty('description')\">\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n </div>\n } @else if (property === 'plannedEndDate') {\n <div class=\"property-input\">\n <v-input\n name=\"plannedEndDate\"\n [title]=\"'plannedEndDate' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.plannedEndDate\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'dateformatTooltip' | pluginTranslate: obs.pluginId | async\"\n (valueChange)=\"onPropertyChanged('plannedEndDate', $event)\"\n ></v-input>\n\n <button\n class=\"btn btn-space delete-button\"\n (click)=\"removeCaseProperty('plannedEndDate')\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n </div>\n } @else if (property === 'finalDeliveryDate') {\n <div class=\"property-input\">\n <v-input\n name=\"finalDeliveryDate\"\n [title]=\"'finalDeliveryDate' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.finalDeliveryDate\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'dateformatTooltip' | pluginTranslate: obs.pluginId | async\"\n (valueChange)=\"onPropertyChanged('finalDeliveryDate', $event)\"\n ></v-input>\n\n <button\n class=\"btn btn-space delete-button\"\n (click)=\"removeCaseProperty('finalDeliveryDate')\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n </div>\n }\n }\n\n <button\n cdsButton=\"primary\"\n [size]=\"'md'\"\n [cdsOverflowMenu]=\"addCasePropertyList\"\n [customPane]=\"true\"\n placement=\"bottom\"\n >\n {{ 'addZaakProperty' | pluginTranslate: obs.pluginId | async }}\n <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n </button>\n </v-form>\n </ng-container>\n</ng-container>\n\n<ng-template #loading>\n <div class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n</ng-template>\n\n<ng-template #addCasePropertyList>\n <cds-overflow-menu-option\n (click)=\"addCaseProperty('description')\"\n *ngIf=\"!hasPropertyBeenAdded('description')\"\n >\n {{ 'beschrijving' | pluginTranslate: (pluginId$ | async) | async }}\n </cds-overflow-menu-option>\n <cds-overflow-menu-option\n (click)=\"addCaseProperty('plannedEndDate')\"\n *ngIf=\"!hasPropertyBeenAdded('plannedEndDate')\"\n >\n {{ 'plannedEndDate' | pluginTranslate: (pluginId$ | async) | async }}\n </cds-overflow-menu-option>\n <cds-overflow-menu-option\n (click)=\"addCaseProperty('finalDeliveryDate')\"\n *ngIf=\"!hasPropertyBeenAdded('finalDeliveryDate')\"\n >\n {{ 'finalDeliveryDate' | pluginTranslate: (pluginId$ | async) | async }}\n </cds-overflow-menu-option>\n</ng-template>\n", styles: [".loading-container{display:flex;flex-direction:row;justify-content:center;height:100%;width:100%;align-items:center}::ng-deep .cds--overflow-menu-options{z-index:10000!important;width:230px}.property-input{display:flex}.property-input v-input,.property-input cds-date-picker-input{flex-grow:1}.property-input button{height:46px;width:46px;margin:16px}.delete-button:hover{background-color:#e12717}\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: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.FormComponent, selector: "v-form", inputs: ["className"], outputs: ["valueChange"] }, { kind: "component", type: i3.InputComponent, selector: "v-input", inputs: ["name", "type", "title", "titleTranslationKey", "defaultValue", "widthPx", "fullWidth", "margin", "smallMargin", "disabled", "step", "min", "maxLength", "tooltip", "required", "hideNumberSpinBox", "smallLabel", "rows", "clear$", "carbonTheme", "placeholder", "dataTestId", "trim"], outputs: ["valueChange"] }, { kind: "component", type: i3.SelectComponent, selector: "v-select", inputs: ["items", "defaultSelection", "defaultSelectionId", "defaultSelectionIds", "disabled", "dropUp", "multiple", "margin", "widthInPx", "notFoundText", "clearAllText", "clearText", "name", "title", "titleTranslationKey", "clearSelectionSubject$", "tooltip", "required", "loading", "loadingText", "placeholder", "smallMargin", "carbonTheme", "appendInline", "dataTestId"], outputs: ["selectedChange"] }, { kind: "component", type: i3.ParagraphComponent, selector: "v-paragraph", inputs: ["center", "fullWidth", "margin", "italic", "loading", "dataTestId"] }, { kind: "component", type: i3.RadioComponent, selector: "v-radio", inputs: ["name", "title", "titleTranslationKey", "defaultValue", "widthPx", "fullWidth", "margin", "smallMargin", "disabled", "tooltip", "required", "smallLabel", "rows", "clear$", "radioValues"], outputs: ["valueChange"] }, { kind: "component", type: i5.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "directive", type: i5.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "directive", type: i5.OverflowMenuDirective, selector: "[cdsOverflowMenu], [ibmOverflowMenu]", inputs: ["ibmOverflowMenu", "cdsOverflowMenu", "flip", "offset", "wrapperClass", "customPane"], exportAs: ["overflowMenu"] }, { kind: "component", type: i5.OverflowMenuOption, selector: "cds-overflow-menu-option, ibm-overflow-menu-option", inputs: ["divider", "type", "disabled", "href", "target", "innerClass"], outputs: ["selected"] }, { kind: "directive", type: i5.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.PluginTranslatePipe, name: "pluginTranslate" }] }); }
|
|
123
155
|
}
|
|
124
156
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateZaakConfigurationComponent, decorators: [{
|
|
125
157
|
type: Component,
|
|
126
|
-
args: [{ selector: 'valtimo-create-zaak-configuration', providers: [PluginTranslatePipe], 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 disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n pluginId: pluginId$ | async,\n selectedInputOption: selectedInputOption$ | async,\n zaakTypeSelectItems: zaakTypeItems$ | async,\n loading: loading$ | async,\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <v-paragraph [margin]=\"true\" [italic]=\"true\">\n {{ 'createZaakInformation' | pluginTranslate: obs.pluginId | async }}\n </v-paragraph>\n <v-form (valueChange)=\"formValueChange($event)\">\n <v-input\n name=\"rsin\"\n [title]=\"'rsin' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.rsin\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [tooltip]=\"'rsinTooltip' | pluginTranslate: obs.pluginId | async\"\n [widthPx]=\"350\"\n >\n </v-input>\n <v-radio\n name=\"inputTypeZaakTypeToggle\"\n [disabled]=\"obs.disabled\"\n [title]=\"'inputTypeZaakTypeToggle' | pluginTranslate: obs.pluginId | async\"\n [radioValues]=\"inputTypeOptions$ | async\"\n [defaultValue]=\"selectedInputOption$ | async\"\n [margin]=\"true\"\n >\n </v-radio>\n <v-input\n *ngIf=\"obs.selectedInputOption === 'text'\"\n name=\"zaaktypeUrl\"\n [title]=\"'zaakTypeUrl' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.zaaktypeUrl\"\n [disabled]=\"obs.disabled || obs.selectedInputOption === 'selection'\"\n [required]=\"true\"\n [tooltip]=\"'zaakTypeTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n <v-select\n [items]=\"obs.zaakTypeSelectItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"zaaktypeUrl\"\n [title]=\"'zaakType' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n oneSelectItem(obs.zaakTypeSelectItems)\n \"\n [defaultSelectionId]=\"\n (selectItemsIncludeId(obs.zaakTypeSelectItems, obs.prefill?.zaaktypeUrl) &&\n obs.prefill?.zaaktypeUrl) ||\n (oneSelectItem(obs.zaakTypeSelectItems) && obs.zaakTypeSelectItems[0].id)\n \"\n [required]=\"true\"\n [loading]=\"!obs.zaakTypeSelectItems\"\n [tooltip]=\"'zaakTypeSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n ></v-select>\n </ng-container>\n </v-form>\n </ng-container>\n</ng-container>\n\n<ng-template #loading>\n <div class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n</ng-template>\n", styles: [".loading-container{display:flex;flex-direction:row;justify-content:center;height:100%;width:100%;align-items: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"] }]
|
|
127
|
-
}], ctorParameters: () => [{ type: i1.OpenZaakService }, { type: i2.DocumentService }, { type: i3.ModalService }, { type: i4.PluginTranslatePipe }], propDecorators: { save$: [{
|
|
158
|
+
args: [{ selector: 'valtimo-create-zaak-configuration', providers: [PluginTranslatePipe], 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 disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n pluginId: pluginId$ | async,\n selectedInputOption: selectedInputOption$ | async,\n zaakTypeSelectItems: zaakTypeItems$ | async,\n loading: loading$ | async,\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <v-paragraph [margin]=\"true\" [italic]=\"true\">\n {{ 'createZaakInformation' | pluginTranslate: obs.pluginId | async }}\n </v-paragraph>\n <v-form (valueChange)=\"formValueChange($event)\">\n <v-input\n name=\"rsin\"\n [title]=\"'rsin' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.rsin\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'rsinTooltip' | pluginTranslate: obs.pluginId | async\"\n [widthPx]=\"350\"\n >\n </v-input>\n <v-radio\n name=\"inputTypeZaakTypeToggle\"\n [disabled]=\"obs.disabled\"\n [title]=\"'inputTypeZaakTypeToggle' | pluginTranslate: obs.pluginId | async\"\n [radioValues]=\"inputTypeOptions$ | async\"\n [defaultValue]=\"selectedInputOption$ | async\"\n [margin]=\"true\"\n >\n </v-radio>\n <v-input\n *ngIf=\"obs.selectedInputOption === 'text'\"\n name=\"zaaktypeUrl\"\n [title]=\"'zaakTypeUrl' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.zaaktypeUrl\"\n [disabled]=\"obs.disabled || obs.selectedInputOption === 'selection'\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'zaakTypeTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n <v-select\n [items]=\"obs.zaakTypeSelectItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"zaaktypeUrl\"\n [title]=\"'zaakType' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n oneSelectItem(obs.zaakTypeSelectItems)\n \"\n [defaultSelectionId]=\"\n (selectItemsIncludeId(obs.zaakTypeSelectItems, obs.prefill?.zaaktypeUrl) &&\n obs.prefill?.zaaktypeUrl) ||\n (oneSelectItem(obs.zaakTypeSelectItems) && obs.zaakTypeSelectItems[0].id)\n \"\n [required]=\"true\"\n [loading]=\"!obs.zaakTypeSelectItems\"\n [tooltip]=\"'zaakTypeSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n ></v-select>\n </ng-container>\n\n @for (property of propertyList; track property) {\n @if (property === 'description') {\n <div class=\"property-input\">\n <v-input\n name=\"description\"\n [title]=\"'beschrijving' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.description\"\n [required]=\"true\"\n (valueChange)=\"onPropertyChanged('description', $event)\"\n />\n\n <button class=\"btn btn-space delete-button\" (click)=\"removeCaseProperty('description')\">\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n </div>\n } @else if (property === 'plannedEndDate') {\n <div class=\"property-input\">\n <v-input\n name=\"plannedEndDate\"\n [title]=\"'plannedEndDate' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.plannedEndDate\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'dateformatTooltip' | pluginTranslate: obs.pluginId | async\"\n (valueChange)=\"onPropertyChanged('plannedEndDate', $event)\"\n ></v-input>\n\n <button\n class=\"btn btn-space delete-button\"\n (click)=\"removeCaseProperty('plannedEndDate')\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n </div>\n } @else if (property === 'finalDeliveryDate') {\n <div class=\"property-input\">\n <v-input\n name=\"finalDeliveryDate\"\n [title]=\"'finalDeliveryDate' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.finalDeliveryDate\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'dateformatTooltip' | pluginTranslate: obs.pluginId | async\"\n (valueChange)=\"onPropertyChanged('finalDeliveryDate', $event)\"\n ></v-input>\n\n <button\n class=\"btn btn-space delete-button\"\n (click)=\"removeCaseProperty('finalDeliveryDate')\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n </div>\n }\n }\n\n <button\n cdsButton=\"primary\"\n [size]=\"'md'\"\n [cdsOverflowMenu]=\"addCasePropertyList\"\n [customPane]=\"true\"\n placement=\"bottom\"\n >\n {{ 'addZaakProperty' | pluginTranslate: obs.pluginId | async }}\n <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n </button>\n </v-form>\n </ng-container>\n</ng-container>\n\n<ng-template #loading>\n <div class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n</ng-template>\n\n<ng-template #addCasePropertyList>\n <cds-overflow-menu-option\n (click)=\"addCaseProperty('description')\"\n *ngIf=\"!hasPropertyBeenAdded('description')\"\n >\n {{ 'beschrijving' | pluginTranslate: (pluginId$ | async) | async }}\n </cds-overflow-menu-option>\n <cds-overflow-menu-option\n (click)=\"addCaseProperty('plannedEndDate')\"\n *ngIf=\"!hasPropertyBeenAdded('plannedEndDate')\"\n >\n {{ 'plannedEndDate' | pluginTranslate: (pluginId$ | async) | async }}\n </cds-overflow-menu-option>\n <cds-overflow-menu-option\n (click)=\"addCaseProperty('finalDeliveryDate')\"\n *ngIf=\"!hasPropertyBeenAdded('finalDeliveryDate')\"\n >\n {{ 'finalDeliveryDate' | pluginTranslate: (pluginId$ | async) | async }}\n </cds-overflow-menu-option>\n</ng-template>\n", styles: [".loading-container{display:flex;flex-direction:row;justify-content:center;height:100%;width:100%;align-items:center}::ng-deep .cds--overflow-menu-options{z-index:10000!important;width:230px}.property-input{display:flex}.property-input v-input,.property-input cds-date-picker-input{flex-grow:1}.property-input button{height:46px;width:46px;margin:16px}.delete-button:hover{background-color:#e12717}\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"] }]
|
|
159
|
+
}], ctorParameters: () => [{ type: i1.OpenZaakService }, { type: i2.DocumentService }, { type: i3.ModalService }, { type: i4.PluginTranslatePipe }, { type: i5.IconService }], propDecorators: { save$: [{
|
|
128
160
|
type: Input
|
|
129
161
|
}], disabled$: [{
|
|
130
162
|
type: Input
|
|
@@ -137,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
137
169
|
}], configuration: [{
|
|
138
170
|
type: Output
|
|
139
171
|
}] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-zaak-configuration.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/create-zaak/create-zaak-configuration.component.ts","../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/create-zaak/create-zaak-configuration.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, EventEmitter, Input, OnDestroy, OnInit, Output} from '@angular/core';\nimport {FunctionConfigurationComponent} from '../../../../models';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {CreateZaakConfig, InputOption} from '../../models';\nimport {OpenZaakService, ZaakType, ZaakTypeLink} from '@valtimo/resource';\nimport {DocumentService} from '@valtimo/document';\nimport {ModalService, RadioValue, SelectItem} from '@valtimo/components';\nimport {PluginTranslatePipe} from '../../../../pipes';\n\n@Component({\n  selector: 'valtimo-create-zaak-configuration',\n  templateUrl: './create-zaak-configuration.component.html',\n  styleUrls: ['./create-zaak-configuration.component.scss'],\n  providers: [PluginTranslatePipe],\n})\nexport class CreateZaakConfigurationComponent\n  implements FunctionConfigurationComponent, OnInit, OnDestroy\n{\n  @Input() save$: Observable<void>;\n  @Input() disabled$: Observable<boolean>;\n  @Input() set pluginId(value: string) {\n    this.pluginId$.next(value);\n  }\n  @Input() prefillConfiguration$: Observable<CreateZaakConfig>;\n  @Output() valid: EventEmitter<boolean> = new EventEmitter<boolean>();\n  @Output() configuration: EventEmitter<CreateZaakConfig> = new EventEmitter<CreateZaakConfig>();\n\n  readonly pluginId$ = new BehaviorSubject<string>('');\n  readonly selectedInputOption$ = new BehaviorSubject<InputOption>('selection');\n\n  readonly inputTypeOptions$: Observable<Array<RadioValue>> = this.pluginId$.pipe(\n    filter(pluginId => !!pluginId),\n    switchMap(pluginId =>\n      combineLatest([\n        this.pluginTranslatePipe.transform('selection', pluginId),\n        this.pluginTranslatePipe.transform('text', pluginId),\n      ])\n    ),\n    map(([selectionTranslation, textTranslation]) => [\n      {value: 'selection', title: selectionTranslation},\n      {value: 'text', title: textTranslation},\n    ])\n  );\n\n  private saveSubscription!: Subscription;\n\n  private readonly formValue$ = new BehaviorSubject<CreateZaakConfig | null>(null);\n  private readonly valid$ = new BehaviorSubject<boolean>(false);\n\n  readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  readonly zaakTypeItems$: Observable<Array<SelectItem>> = this.modalService.modalData$.pipe(\n    switchMap(params =>\n      this.documentService.findProcessDocumentDefinitionsByProcessDefinitionKey(\n        params?.processDefinitionKey\n      )\n    ),\n    switchMap(processDocumentDefinitions =>\n      combineLatest([\n        this.openZaakService.getZaakTypes(),\n        ...processDocumentDefinitions.map(processDocumentDefinition =>\n          this.openZaakService.getZaakTypeLink(\n            processDocumentDefinition.id.documentDefinitionId.name\n          )\n        ),\n      ])\n    ),\n    map(results => {\n      const zaakTypes = results[0] as Array<ZaakType>;\n      const zaakTypeLinks = results.filter((result, index) => index !== 0) as Array<ZaakTypeLink>;\n\n      return zaakTypeLinks\n        .filter(zaakTypeLink => !!zaakTypeLink?.zaakTypeUrl)\n        .map(zaakTypeLink => ({\n          id: zaakTypeLink.zaakTypeUrl,\n          text:\n            zaakTypes.find(zaakType => zaakType.url === zaakTypeLink.zaakTypeUrl)?.omschrijving ||\n            zaakTypeLink.zaakTypeUrl,\n        }));\n    }),\n    tap(zaakTypeSelectItems => {\n      this.prefillConfiguration$.pipe(take(1)).subscribe(prefillConfig => {\n        const zaakTypeUrl = prefillConfig?.zaaktypeUrl;\n\n        if (\n          zaakTypeUrl &&\n          !((zaakTypeSelectItems as Array<SelectItem>) || []).find(item => item.id === zaakTypeUrl)\n        ) {\n          this.selectedInputOption$.next('text');\n        }\n      });\n    }),\n    tap(() => {\n      this.loading$.next(false);\n    })\n  );\n\n  constructor(\n    private readonly openZaakService: OpenZaakService,\n    private readonly documentService: DocumentService,\n    private readonly modalService: ModalService,\n    private readonly pluginTranslatePipe: PluginTranslatePipe\n  ) {}\n\n  ngOnInit(): void {\n    this.openSaveSubscription();\n  }\n\n  ngOnDestroy() {\n    this.saveSubscription?.unsubscribe();\n  }\n\n  formValueChange(formValue: CreateZaakConfig): void {\n    const inputTypeZaakTypeToggle = formValue.inputTypeZaakTypeToggle;\n    this.formValue$.next(formValue);\n    this.handleValid(formValue);\n\n    if (inputTypeZaakTypeToggle) {\n      this.selectedInputOption$.next(inputTypeZaakTypeToggle);\n    }\n  }\n\n  oneSelectItem(selectItems: Array<SelectItem>): boolean {\n    if (Array.isArray(selectItems)) {\n      return selectItems.length === 1;\n    }\n\n    return false;\n  }\n\n  selectItemsIncludeId(selectItems: Array<SelectItem>, id: string): boolean {\n    if (Array.isArray(selectItems)) {\n      return !!selectItems.find(item => item.id === id);\n    }\n\n    return false;\n  }\n\n  private handleValid(formValue: CreateZaakConfig): void {\n    const valid = !!(formValue.rsin && formValue.zaaktypeUrl);\n\n    this.valid$.next(valid);\n    this.valid.emit(valid);\n  }\n\n  private openSaveSubscription(): void {\n    this.saveSubscription = this.save$?.subscribe(save => {\n      combineLatest([this.formValue$, this.valid$])\n        .pipe(take(1))\n        .subscribe(([formValue, valid]) => {\n          if (valid) {\n            this.configuration.emit({\n              rsin: formValue.rsin,\n              zaaktypeUrl: formValue.zaaktypeUrl,\n              manualZaakTypeUrl: formValue.manualZaakTypeUrl,\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\n<ng-container\n  *ngIf=\"{\n    disabled: disabled$ | async,\n    prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n    pluginId: pluginId$ | async,\n    selectedInputOption: selectedInputOption$ | async,\n    zaakTypeSelectItems: zaakTypeItems$ | async,\n    loading: loading$ | async,\n  } as obs\"\n>\n  <ng-container *ngIf=\"obs.loading === false; else loading\">\n    <v-paragraph [margin]=\"true\" [italic]=\"true\">\n      {{ 'createZaakInformation' | pluginTranslate: obs.pluginId | async }}\n    </v-paragraph>\n    <v-form (valueChange)=\"formValueChange($event)\">\n      <v-input\n        name=\"rsin\"\n        [title]=\"'rsin' | pluginTranslate: obs.pluginId | async\"\n        [margin]=\"true\"\n        [defaultValue]=\"obs.prefill?.rsin\"\n        [disabled]=\"obs.disabled\"\n        [required]=\"true\"\n        [tooltip]=\"'rsinTooltip' | pluginTranslate: obs.pluginId | async\"\n        [widthPx]=\"350\"\n      >\n      </v-input>\n      <v-radio\n        name=\"inputTypeZaakTypeToggle\"\n        [disabled]=\"obs.disabled\"\n        [title]=\"'inputTypeZaakTypeToggle' | pluginTranslate: obs.pluginId | async\"\n        [radioValues]=\"inputTypeOptions$ | async\"\n        [defaultValue]=\"selectedInputOption$ | async\"\n        [margin]=\"true\"\n      >\n      </v-radio>\n      <v-input\n        *ngIf=\"obs.selectedInputOption === 'text'\"\n        name=\"zaaktypeUrl\"\n        [title]=\"'zaakTypeUrl' | pluginTranslate: obs.pluginId | async\"\n        [margin]=\"true\"\n        [defaultValue]=\"obs.prefill?.zaaktypeUrl\"\n        [disabled]=\"obs.disabled || obs.selectedInputOption === 'selection'\"\n        [required]=\"true\"\n        [tooltip]=\"'zaakTypeTooltip' | pluginTranslate: obs.pluginId | async\"\n        [fullWidth]=\"true\"\n      >\n      </v-input>\n      <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n        <v-select\n          [items]=\"obs.zaakTypeSelectItems\"\n          [margin]=\"true\"\n          [widthInPx]=\"350\"\n          name=\"zaaktypeUrl\"\n          [title]=\"'zaakType' | pluginTranslate: obs.pluginId | async\"\n          [disabled]=\"\n            obs.disabled ||\n            obs.selectedInputOption === 'text' ||\n            oneSelectItem(obs.zaakTypeSelectItems)\n          \"\n          [defaultSelectionId]=\"\n            (selectItemsIncludeId(obs.zaakTypeSelectItems, obs.prefill?.zaaktypeUrl) &&\n              obs.prefill?.zaaktypeUrl) ||\n            (oneSelectItem(obs.zaakTypeSelectItems) && obs.zaakTypeSelectItems[0].id)\n          \"\n          [required]=\"true\"\n          [loading]=\"!obs.zaakTypeSelectItems\"\n          [tooltip]=\"'zaakTypeSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n        ></v-select>\n      </ng-container>\n    </v-form>\n  </ng-container>\n</ng-container>\n\n<ng-template #loading>\n  <div class=\"loading-container\">\n    <cds-loading></cds-loading>\n  </div>\n</ng-template>\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-zaak-configuration.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/create-zaak/create-zaak-configuration.component.ts","../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/create-zaak/create-zaak-configuration.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, EventEmitter, Input, OnDestroy, OnInit, Output} from '@angular/core';\nimport {FunctionConfigurationComponent} from '../../../../models';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {CreateZaakConfig, InputOption} from '../../models';\nimport {OpenZaakService, ZaakType, ZaakTypeLink} from '@valtimo/resource';\nimport {DocumentService} from '@valtimo/document';\nimport {ModalService, RadioValue, SelectItem} from '@valtimo/components';\nimport {PluginTranslatePipe} from '../../../../pipes';\nimport {Add16, TrashCan16} from '@carbon/icons';\nimport {IconService} from 'carbon-components-angular';\nimport {ExtraPropertiesOptions, ExtraProperties} from '../../models/create-zaak-properties';\n\n@Component({\n  selector: 'valtimo-create-zaak-configuration',\n  templateUrl: './create-zaak-configuration.component.html',\n  styleUrls: ['./create-zaak-configuration.component.scss'],\n  providers: [PluginTranslatePipe],\n})\nexport class CreateZaakConfigurationComponent\n  implements FunctionConfigurationComponent, OnInit, OnDestroy\n{\n  @Input() save$: Observable<void>;\n  @Input() disabled$: Observable<boolean>;\n  @Input() set pluginId(value: string) {\n    this.pluginId$.next(value);\n  }\n  @Input() prefillConfiguration$: Observable<CreateZaakConfig>;\n  @Output() valid: EventEmitter<boolean> = new EventEmitter<boolean>();\n  @Output() configuration: EventEmitter<CreateZaakConfig> = new EventEmitter<CreateZaakConfig>();\n\n  public readonly propertyList: Array<ExtraProperties> = [];\n\n  readonly pluginId$ = new BehaviorSubject<string>('');\n  readonly selectedInputOption$ = new BehaviorSubject<InputOption>('selection');\n\n  readonly inputTypeOptions$: Observable<Array<RadioValue>> = this.pluginId$.pipe(\n    filter(pluginId => !!pluginId),\n    switchMap(pluginId =>\n      combineLatest([\n        this.pluginTranslatePipe.transform('selection', pluginId),\n        this.pluginTranslatePipe.transform('text', pluginId),\n      ])\n    ),\n    map(([selectionTranslation, textTranslation]) => [\n      {value: 'selection', title: selectionTranslation},\n      {value: 'text', title: textTranslation},\n    ])\n  );\n\n  private saveSubscription!: Subscription;\n\n  private readonly formValue$ = new BehaviorSubject<CreateZaakConfig | null>(null);\n  private readonly valid$ = new BehaviorSubject<boolean>(false);\n  private readonly _properties = new Map<ExtraProperties, string>();\n\n  readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  readonly zaakTypeItems$: Observable<Array<SelectItem>> = this.modalService.modalData$.pipe(\n    switchMap(params =>\n      this.documentService.findProcessDocumentDefinitionsByProcessDefinitionKey(\n        params?.processDefinitionKey\n      )\n    ),\n    switchMap(processDocumentDefinitions =>\n      combineLatest([\n        this.openZaakService.getZaakTypes(),\n        ...processDocumentDefinitions.map(processDocumentDefinition =>\n          this.openZaakService.getZaakTypeLink(\n            processDocumentDefinition.id.documentDefinitionId.name\n          )\n        ),\n      ])\n    ),\n    map(results => {\n      const zaakTypes = results[0] as Array<ZaakType>;\n      const zaakTypeLinks = results.filter((result, index) => index !== 0) as Array<ZaakTypeLink>;\n\n      return zaakTypeLinks\n        .filter(zaakTypeLink => !!zaakTypeLink?.zaakTypeUrl)\n        .map(zaakTypeLink => ({\n          id: zaakTypeLink.zaakTypeUrl,\n          text:\n            zaakTypes.find(zaakType => zaakType.url === zaakTypeLink.zaakTypeUrl)?.omschrijving ||\n            zaakTypeLink.zaakTypeUrl,\n        }));\n    }),\n    tap(zaakTypeSelectItems => {\n      this.prefillConfiguration$.pipe(take(1)).subscribe(prefillConfig => {\n        const zaakTypeUrl = prefillConfig?.zaaktypeUrl;\n\n        if (\n          zaakTypeUrl &&\n          !((zaakTypeSelectItems as Array<SelectItem>) || []).find(item => item.id === zaakTypeUrl)\n        ) {\n          this.selectedInputOption$.next('text');\n        }\n      });\n    }),\n    tap(() => {\n      this.loading$.next(false);\n    })\n  );\n\n  constructor(\n    private readonly openZaakService: OpenZaakService,\n    private readonly documentService: DocumentService,\n    private readonly modalService: ModalService,\n    private readonly pluginTranslatePipe: PluginTranslatePipe,\n    private readonly iconService: IconService\n  ) {\n    this.iconService.registerAll([Add16, TrashCan16]);\n  }\n\n  ngOnInit(): void {\n    this.openSaveSubscription();\n\n    this.prefillConfiguration$.pipe(take(1)).subscribe(prefill => {\n      ExtraPropertiesOptions.filter(property => !!prefill[property]).forEach(property =>\n        this.addCaseProperty(property)\n      );\n    });\n  }\n\n  ngOnDestroy() {\n    this.saveSubscription?.unsubscribe();\n  }\n\n  formValueChange(formValue: CreateZaakConfig): void {\n    this._properties.forEach((value, key) => (formValue[key] = value));\n\n    const inputTypeZaakTypeToggle = formValue.inputTypeZaakTypeToggle;\n    this.formValue$.next(formValue);\n    this.handleValid(formValue);\n\n    if (inputTypeZaakTypeToggle) {\n      this.selectedInputOption$.next(inputTypeZaakTypeToggle);\n    }\n  }\n\n  oneSelectItem(selectItems: Array<SelectItem>): boolean {\n    if (Array.isArray(selectItems)) {\n      return selectItems.length === 1;\n    }\n\n    return false;\n  }\n\n  selectItemsIncludeId(selectItems: Array<SelectItem>, id: string): boolean {\n    if (Array.isArray(selectItems)) {\n      return !!selectItems.find(item => item.id === id);\n    }\n\n    return false;\n  }\n\n  private handleValid(formValue: CreateZaakConfig): void {\n    const isPropertyInvalid = this.propertyList.some(property => !!!formValue[property]);\n    const valid = !!(formValue.rsin && formValue.zaaktypeUrl) && !isPropertyInvalid;\n\n    this.valid$.next(valid);\n    this.valid.emit(valid);\n  }\n\n  private openSaveSubscription(): void {\n    this.saveSubscription = this.save$?.subscribe(save => {\n      combineLatest([this.formValue$, this.valid$])\n        .pipe(take(1))\n        .subscribe(([formValue, valid]) => {\n          if (valid) {\n            const payload: CreateZaakConfig = {\n              rsin: formValue.rsin,\n              zaaktypeUrl: formValue.zaaktypeUrl,\n              manualZaakTypeUrl: formValue.manualZaakTypeUrl,\n            };\n            this.propertyList.forEach(property => (payload[property] = formValue[property]));\n            this.configuration.emit(payload);\n          }\n        });\n    });\n  }\n\n  public addCaseProperty(property: ExtraProperties): void {\n    this.propertyList.push(property);\n  }\n\n  public removeCaseProperty(property: ExtraProperties): void {\n    this.propertyList.splice(this.propertyList.indexOf(property), 1);\n    this._properties.delete(property);\n    this.onPropertyChanged(property, undefined);\n  }\n\n  public hasPropertyBeenAdded(property: ExtraProperties): boolean {\n    return this.propertyList.indexOf(property) !== -1;\n  }\n\n  public onPropertyChanged(property: ExtraProperties, value: any): void {\n    this._properties.set(property, value);\n    this.formValue$\n      .pipe(\n        filter(formValue => formValue !== null),\n        take(1)\n      )\n      .subscribe(formValue => {\n        this.formValueChange(formValue);\n      });\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    disabled: disabled$ | async,\n    prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n    pluginId: pluginId$ | async,\n    selectedInputOption: selectedInputOption$ | async,\n    zaakTypeSelectItems: zaakTypeItems$ | async,\n    loading: loading$ | async,\n  } as obs\"\n>\n  <ng-container *ngIf=\"obs.loading === false; else loading\">\n    <v-paragraph [margin]=\"true\" [italic]=\"true\">\n      {{ 'createZaakInformation' | pluginTranslate: obs.pluginId | async }}\n    </v-paragraph>\n    <v-form (valueChange)=\"formValueChange($event)\">\n      <v-input\n        name=\"rsin\"\n        [title]=\"'rsin' | pluginTranslate: obs.pluginId | async\"\n        [margin]=\"true\"\n        [defaultValue]=\"obs.prefill?.rsin\"\n        [disabled]=\"obs.disabled\"\n        [required]=\"true\"\n        [trim]=\"true\"\n        [tooltip]=\"'rsinTooltip' | pluginTranslate: obs.pluginId | async\"\n        [widthPx]=\"350\"\n      >\n      </v-input>\n      <v-radio\n        name=\"inputTypeZaakTypeToggle\"\n        [disabled]=\"obs.disabled\"\n        [title]=\"'inputTypeZaakTypeToggle' | pluginTranslate: obs.pluginId | async\"\n        [radioValues]=\"inputTypeOptions$ | async\"\n        [defaultValue]=\"selectedInputOption$ | async\"\n        [margin]=\"true\"\n      >\n      </v-radio>\n      <v-input\n        *ngIf=\"obs.selectedInputOption === 'text'\"\n        name=\"zaaktypeUrl\"\n        [title]=\"'zaakTypeUrl' | pluginTranslate: obs.pluginId | async\"\n        [margin]=\"true\"\n        [defaultValue]=\"obs.prefill?.zaaktypeUrl\"\n        [disabled]=\"obs.disabled || obs.selectedInputOption === 'selection'\"\n        [required]=\"true\"\n        [trim]=\"true\"\n        [tooltip]=\"'zaakTypeTooltip' | pluginTranslate: obs.pluginId | async\"\n        [fullWidth]=\"true\"\n      >\n      </v-input>\n      <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n        <v-select\n          [items]=\"obs.zaakTypeSelectItems\"\n          [margin]=\"true\"\n          [widthInPx]=\"350\"\n          name=\"zaaktypeUrl\"\n          [title]=\"'zaakType' | pluginTranslate: obs.pluginId | async\"\n          [disabled]=\"\n            obs.disabled ||\n            obs.selectedInputOption === 'text' ||\n            oneSelectItem(obs.zaakTypeSelectItems)\n          \"\n          [defaultSelectionId]=\"\n            (selectItemsIncludeId(obs.zaakTypeSelectItems, obs.prefill?.zaaktypeUrl) &&\n              obs.prefill?.zaaktypeUrl) ||\n            (oneSelectItem(obs.zaakTypeSelectItems) && obs.zaakTypeSelectItems[0].id)\n          \"\n          [required]=\"true\"\n          [loading]=\"!obs.zaakTypeSelectItems\"\n          [tooltip]=\"'zaakTypeSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n        ></v-select>\n      </ng-container>\n\n      @for (property of propertyList; track property) {\n        @if (property === 'description') {\n          <div class=\"property-input\">\n            <v-input\n              name=\"description\"\n              [title]=\"'beschrijving' | pluginTranslate: obs.pluginId | async\"\n              [margin]=\"true\"\n              [defaultValue]=\"obs.prefill?.description\"\n              [required]=\"true\"\n              (valueChange)=\"onPropertyChanged('description', $event)\"\n            />\n\n            <button class=\"btn btn-space delete-button\" (click)=\"removeCaseProperty('description')\">\n              <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n            </button>\n          </div>\n        } @else if (property === 'plannedEndDate') {\n          <div class=\"property-input\">\n            <v-input\n              name=\"plannedEndDate\"\n              [title]=\"'plannedEndDate' | pluginTranslate: obs.pluginId | async\"\n              [margin]=\"true\"\n              [defaultValue]=\"obs.prefill?.plannedEndDate\"\n              [required]=\"true\"\n              [trim]=\"true\"\n              [tooltip]=\"'dateformatTooltip' | pluginTranslate: obs.pluginId | async\"\n              (valueChange)=\"onPropertyChanged('plannedEndDate', $event)\"\n            ></v-input>\n\n            <button\n              class=\"btn btn-space delete-button\"\n              (click)=\"removeCaseProperty('plannedEndDate')\"\n            >\n              <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n            </button>\n          </div>\n        } @else if (property === 'finalDeliveryDate') {\n          <div class=\"property-input\">\n            <v-input\n              name=\"finalDeliveryDate\"\n              [title]=\"'finalDeliveryDate' | pluginTranslate: obs.pluginId | async\"\n              [margin]=\"true\"\n              [defaultValue]=\"obs.prefill?.finalDeliveryDate\"\n              [required]=\"true\"\n              [trim]=\"true\"\n              [tooltip]=\"'dateformatTooltip' | pluginTranslate: obs.pluginId | async\"\n              (valueChange)=\"onPropertyChanged('finalDeliveryDate', $event)\"\n            ></v-input>\n\n            <button\n              class=\"btn btn-space delete-button\"\n              (click)=\"removeCaseProperty('finalDeliveryDate')\"\n            >\n              <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n            </button>\n          </div>\n        }\n      }\n\n      <button\n        cdsButton=\"primary\"\n        [size]=\"'md'\"\n        [cdsOverflowMenu]=\"addCasePropertyList\"\n        [customPane]=\"true\"\n        placement=\"bottom\"\n      >\n        {{ 'addZaakProperty' | pluginTranslate: obs.pluginId | async }}\n        <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n      </button>\n    </v-form>\n  </ng-container>\n</ng-container>\n\n<ng-template #loading>\n  <div class=\"loading-container\">\n    <cds-loading></cds-loading>\n  </div>\n</ng-template>\n\n<ng-template #addCasePropertyList>\n  <cds-overflow-menu-option\n    (click)=\"addCaseProperty('description')\"\n    *ngIf=\"!hasPropertyBeenAdded('description')\"\n  >\n    {{ 'beschrijving' | pluginTranslate: (pluginId$ | async) | async }}\n  </cds-overflow-menu-option>\n  <cds-overflow-menu-option\n    (click)=\"addCaseProperty('plannedEndDate')\"\n    *ngIf=\"!hasPropertyBeenAdded('plannedEndDate')\"\n  >\n    {{ 'plannedEndDate' | pluginTranslate: (pluginId$ | async) | async }}\n  </cds-overflow-menu-option>\n  <cds-overflow-menu-option\n    (click)=\"addCaseProperty('finalDeliveryDate')\"\n    *ngIf=\"!hasPropertyBeenAdded('finalDeliveryDate')\"\n  >\n    {{ 'finalDeliveryDate' | pluginTranslate: (pluginId$ | async) | async }}\n  </cds-overflow-menu-option>\n</ng-template>\n"]}
|