@valtimo/zgw 12.0.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/dossier-management-zgw/dossier-management-zgw.component.mjs +43 -0
- package/esm2022/lib/components/index.mjs +17 -0
- package/esm2022/lib/models/dossier-management-zgw.model.mjs +20 -0
- package/esm2022/lib/models/index.mjs +17 -0
- package/esm2022/lib/modules/contactmomenten/components/contact-moments/contact-moments.component.mjs +89 -0
- package/esm2022/lib/modules/contactmomenten/components/index.mjs +17 -0
- package/esm2022/lib/modules/contactmomenten/index.mjs +19 -0
- package/esm2022/lib/modules/contactmomenten/models/contact-moment.model.mjs +17 -0
- package/esm2022/lib/modules/contactmomenten/models/index.mjs +17 -0
- package/esm2022/lib/modules/contactmomenten/services/contact-moment.service.mjs +43 -0
- package/esm2022/lib/modules/contactmomenten/services/index.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.mjs +301 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.mjs +170 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.mjs +256 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-link-upload-process/dossier-management-link-process.component.mjs +100 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.mjs +233 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-version/documenten-api-version.component.mjs +43 -0
- package/esm2022/lib/modules/documenten-api/components/index.mjs +22 -0
- package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader-edit-form.mjs +305 -0
- package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.mjs +143 -0
- package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.formio.mjs +46 -0
- package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/index.mjs +19 -0
- package/esm2022/lib/modules/documenten-api/formio/index.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/index.mjs +20 -0
- package/esm2022/lib/modules/documenten-api/models/configured-column.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-column-modal.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-link-process.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-metadata.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-version.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/index.mjs +22 -0
- package/esm2022/lib/modules/documenten-api/services/documenten-api-column.service.mjs +37 -0
- package/esm2022/lib/modules/documenten-api/services/documenten-api-document.service.mjs +42 -0
- package/esm2022/lib/modules/documenten-api/services/documenten-api-link-process.service.mjs +66 -0
- package/esm2022/lib/modules/documenten-api/services/documenten-api-version.service.mjs +47 -0
- package/esm2022/lib/modules/documenten-api/services/index.mjs +20 -0
- package/esm2022/lib/modules/haalcentraal-brp/components/cases-list/cases-list.component.mjs +56 -0
- package/esm2022/lib/modules/haalcentraal-brp/components/customer-list/customer-list.component.mjs +133 -0
- package/esm2022/lib/modules/haalcentraal-brp/customer-routing.module.mjs +51 -0
- package/esm2022/lib/modules/haalcentraal-brp/customer.module.mjs +76 -0
- package/esm2022/lib/modules/haalcentraal-brp/index.mjs +19 -0
- package/esm2022/lib/modules/haalcentraal-brp/models/case.mjs +17 -0
- package/esm2022/lib/modules/haalcentraal-brp/models/customer.mjs +17 -0
- package/esm2022/lib/modules/haalcentraal-brp/models/index.mjs +18 -0
- package/esm2022/lib/modules/haalcentraal-brp/services/customer.service.mjs +43 -0
- package/esm2022/lib/modules/haalcentraal-brp/services/index.mjs +17 -0
- package/esm2022/lib/modules/index.mjs +22 -0
- package/esm2022/lib/modules/objecten-api/components/index.mjs +18 -0
- package/esm2022/lib/modules/objecten-api/components/object-type/object-type.component.mjs +122 -0
- package/esm2022/lib/modules/objecten-api/components/zaakobjecten/zaakobjecten.component.mjs +125 -0
- package/esm2022/lib/modules/objecten-api/index.mjs +19 -0
- package/esm2022/lib/modules/objecten-api/models/index.mjs +17 -0
- package/esm2022/lib/modules/objecten-api/models/zaakobjecten.model.mjs +17 -0
- package/esm2022/lib/modules/objecten-api/services/index.mjs +17 -0
- package/esm2022/lib/modules/objecten-api/services/zaakobjecten.service.mjs +44 -0
- package/esm2022/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.mjs +127 -0
- package/esm2022/lib/modules/zaakdetails/components/index.mjs +17 -0
- package/esm2022/lib/modules/zaakdetails/index.mjs +19 -0
- package/esm2022/lib/modules/zaakdetails/models/document-objecten-api-sync.model.mjs +2 -0
- package/esm2022/lib/modules/zaakdetails/models/index.mjs +17 -0
- package/esm2022/lib/modules/zaakdetails/services/document-objecten-api-sync.service.mjs +51 -0
- package/esm2022/lib/modules/zaakdetails/services/index.mjs +17 -0
- package/esm2022/lib/modules/zaken-api/components/index.mjs +17 -0
- package/esm2022/lib/modules/zaken-api/components/zaken-api-zaaktype-link/zaken-api-zaaktype-link.component.mjs +183 -0
- package/esm2022/lib/modules/zaken-api/index.mjs +19 -0
- package/esm2022/lib/modules/zaken-api/models/index.mjs +17 -0
- package/esm2022/lib/modules/zaken-api/models/zaken-api-zaaktype-link.model.mjs +2 -0
- package/esm2022/lib/modules/zaken-api/services/index.mjs +17 -0
- package/esm2022/lib/modules/zaken-api/services/zaken-api-zaaktype-link.service.mjs +39 -0
- package/esm2022/lib/services/dossier-management-zgw.service.mjs +39 -0
- package/esm2022/lib/services/index.mjs +17 -0
- package/esm2022/lib/zgw.module.mjs +106 -0
- package/esm2022/public_api.mjs +27 -0
- package/esm2022/valtimo-zgw.mjs +5 -0
- package/fesm2022/valtimo-zgw.mjs +3577 -0
- package/fesm2022/valtimo-zgw.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts +13 -0
- package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts.map +1 -0
- package/lib/components/index.d.ts +2 -0
- package/lib/components/index.d.ts.map +1 -0
- package/lib/models/dossier-management-zgw.model.d.ts +4 -0
- package/lib/models/dossier-management-zgw.model.d.ts.map +1 -0
- package/lib/models/index.d.ts +2 -0
- package/lib/models/index.d.ts.map +1 -0
- package/lib/modules/contactmomenten/components/contact-moments/contact-moments.component.d.ts +29 -0
- package/lib/modules/contactmomenten/components/contact-moments/contact-moments.component.d.ts.map +1 -0
- package/lib/modules/contactmomenten/components/index.d.ts +2 -0
- package/lib/modules/contactmomenten/components/index.d.ts.map +1 -0
- package/lib/modules/contactmomenten/index.d.ts +4 -0
- package/lib/modules/contactmomenten/index.d.ts.map +1 -0
- package/lib/modules/contactmomenten/models/contact-moment.model.d.ts +14 -0
- package/lib/modules/contactmomenten/models/contact-moment.model.d.ts.map +1 -0
- package/lib/modules/contactmomenten/models/index.d.ts +2 -0
- package/lib/modules/contactmomenten/models/index.d.ts.map +1 -0
- package/lib/modules/contactmomenten/services/contact-moment.service.d.ts +18 -0
- package/lib/modules/contactmomenten/services/contact-moment.service.d.ts.map +1 -0
- package/lib/modules/contactmomenten/services/index.d.ts +2 -0
- package/lib/modules/contactmomenten/services/index.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts +77 -0
- package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts +40 -0
- package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts +66 -0
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-link-upload-process/dossier-management-link-process.component.d.ts +28 -0
- package/lib/modules/documenten-api/components/documenten-api-link-upload-process/dossier-management-link-process.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts +75 -0
- package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-version/documenten-api-version.component.d.ts +16 -0
- package/lib/modules/documenten-api/components/documenten-api-version/documenten-api-version.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/index.d.ts +7 -0
- package/lib/modules/documenten-api/components/index.d.ts.map +1 -0
- package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader-edit-form.d.ts +105 -0
- package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader-edit-form.d.ts.map +1 -0
- package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.d.ts +58 -0
- package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.formio.d.ts +4 -0
- package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.formio.d.ts.map +1 -0
- package/lib/modules/documenten-api/formio/documenten-api-uploader/index.d.ts +4 -0
- package/lib/modules/documenten-api/formio/documenten-api-uploader/index.d.ts.map +1 -0
- package/lib/modules/documenten-api/formio/index.d.ts +2 -0
- package/lib/modules/documenten-api/formio/index.d.ts.map +1 -0
- package/lib/modules/documenten-api/index.d.ts +5 -0
- package/lib/modules/documenten-api/index.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/configured-column.model.d.ts +6 -0
- package/lib/modules/documenten-api/models/configured-column.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-column-modal.model.d.ts +4 -0
- package/lib/modules/documenten-api/models/documenten-api-column-modal.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-link-process.model.d.ts +23 -0
- package/lib/modules/documenten-api/models/documenten-api-link-process.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts +19 -0
- package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts +6 -0
- package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api.model.d.ts +18 -0
- package/lib/modules/documenten-api/models/documenten-api.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/index.d.ts +7 -0
- package/lib/modules/documenten-api/models/index.d.ts.map +1 -0
- package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts +17 -0
- package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts.map +1 -0
- package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts +15 -0
- package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts.map +1 -0
- package/lib/modules/documenten-api/services/documenten-api-link-process.service.d.ts +17 -0
- package/lib/modules/documenten-api/services/documenten-api-link-process.service.d.ts.map +1 -0
- package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts +17 -0
- package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts.map +1 -0
- package/lib/modules/documenten-api/services/index.d.ts +5 -0
- package/lib/modules/documenten-api/services/index.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/components/cases-list/cases-list.component.d.ts +20 -0
- package/lib/modules/haalcentraal-brp/components/cases-list/cases-list.component.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/components/customer-list/customer-list.component.d.ts +39 -0
- package/lib/modules/haalcentraal-brp/components/customer-list/customer-list.component.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/customer-routing.module.d.ts +9 -0
- package/lib/modules/haalcentraal-brp/customer-routing.module.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/customer.module.d.ts +17 -0
- package/lib/modules/haalcentraal-brp/customer.module.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/index.d.ts +4 -0
- package/lib/modules/haalcentraal-brp/index.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/models/case.d.ts +8 -0
- package/lib/modules/haalcentraal-brp/models/case.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/models/customer.d.ts +22 -0
- package/lib/modules/haalcentraal-brp/models/customer.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/models/index.d.ts +3 -0
- package/lib/modules/haalcentraal-brp/models/index.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/services/customer.service.d.ts +18 -0
- package/lib/modules/haalcentraal-brp/services/customer.service.d.ts.map +1 -0
- package/lib/modules/haalcentraal-brp/services/index.d.ts +2 -0
- package/lib/modules/haalcentraal-brp/services/index.d.ts.map +1 -0
- package/lib/modules/index.d.ts +7 -0
- package/lib/modules/index.d.ts.map +1 -0
- package/lib/modules/objecten-api/components/index.d.ts +3 -0
- package/lib/modules/objecten-api/components/index.d.ts.map +1 -0
- package/lib/modules/objecten-api/components/object-type/object-type.component.d.ts +32 -0
- package/lib/modules/objecten-api/components/object-type/object-type.component.d.ts.map +1 -0
- package/lib/modules/objecten-api/components/zaakobjecten/zaakobjecten.component.d.ts +32 -0
- package/lib/modules/objecten-api/components/zaakobjecten/zaakobjecten.component.d.ts.map +1 -0
- package/lib/modules/objecten-api/index.d.ts +4 -0
- package/lib/modules/objecten-api/index.d.ts.map +1 -0
- package/lib/modules/objecten-api/models/index.d.ts +2 -0
- package/lib/modules/objecten-api/models/index.d.ts.map +1 -0
- package/lib/modules/objecten-api/models/zaakobjecten.model.d.ts +26 -0
- package/lib/modules/objecten-api/models/zaakobjecten.model.d.ts.map +1 -0
- package/lib/modules/objecten-api/services/index.d.ts +2 -0
- package/lib/modules/objecten-api/services/index.d.ts.map +1 -0
- package/lib/modules/objecten-api/services/zaakobjecten.service.d.ts +17 -0
- package/lib/modules/objecten-api/services/zaakobjecten.service.d.ts.map +1 -0
- package/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.d.ts +39 -0
- package/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.d.ts.map +1 -0
- package/lib/modules/zaakdetails/components/index.d.ts +2 -0
- package/lib/modules/zaakdetails/components/index.d.ts.map +1 -0
- package/lib/modules/zaakdetails/index.d.ts +4 -0
- package/lib/modules/zaakdetails/index.d.ts.map +1 -0
- package/lib/modules/zaakdetails/models/document-objecten-api-sync.model.d.ts +21 -0
- package/lib/modules/zaakdetails/models/document-objecten-api-sync.model.d.ts.map +1 -0
- package/lib/modules/zaakdetails/models/index.d.ts +2 -0
- package/lib/modules/zaakdetails/models/index.d.ts.map +1 -0
- package/lib/modules/zaakdetails/services/document-objecten-api-sync.service.d.ts +22 -0
- package/lib/modules/zaakdetails/services/document-objecten-api-sync.service.d.ts.map +1 -0
- package/lib/modules/zaakdetails/services/index.d.ts +2 -0
- package/lib/modules/zaakdetails/services/index.d.ts.map +1 -0
- package/lib/modules/zaken-api/components/index.d.ts +2 -0
- package/lib/modules/zaken-api/components/index.d.ts.map +1 -0
- package/lib/modules/zaken-api/components/zaken-api-zaaktype-link/zaken-api-zaaktype-link.component.d.ts +46 -0
- package/lib/modules/zaken-api/components/zaken-api-zaaktype-link/zaken-api-zaaktype-link.component.d.ts.map +1 -0
- package/lib/modules/zaken-api/index.d.ts +4 -0
- package/lib/modules/zaken-api/index.d.ts.map +1 -0
- package/lib/modules/zaken-api/models/index.d.ts +2 -0
- package/lib/modules/zaken-api/models/index.d.ts.map +1 -0
- package/lib/modules/zaken-api/models/zaken-api-zaaktype-link.model.d.ts +15 -0
- package/lib/modules/zaken-api/models/zaken-api-zaaktype-link.model.d.ts.map +1 -0
- package/lib/modules/zaken-api/services/index.d.ts +2 -0
- package/lib/modules/zaken-api/services/index.d.ts.map +1 -0
- package/lib/modules/zaken-api/services/zaken-api-zaaktype-link.service.d.ts +14 -0
- package/lib/modules/zaken-api/services/zaken-api-zaaktype-link.service.d.ts.map +1 -0
- package/lib/services/dossier-management-zgw.service.d.ts +12 -0
- package/lib/services/dossier-management-zgw.service.d.ts.map +1 -0
- package/lib/services/index.d.ts +2 -0
- package/lib/services/index.d.ts.map +1 -0
- package/lib/zgw.module.d.ts +17 -0
- package/lib/zgw.module.d.ts.map +1 -0
- package/package.json +29 -0
- package/public_api.d.ts +8 -0
- package/public_api.d.ts.map +1 -0
- package/valtimo-zgw.d.ts.map +1 -0
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2024 Ritense BV, the Netherlands.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under EUPL, Version 1.2 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" basis,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
17
|
+
import { BehaviorSubject, combineLatest, map, Subscription, switchMap, take, tap, } from 'rxjs';
|
|
18
|
+
import { CARBON_CONSTANTS } from '@valtimo/components';
|
|
19
|
+
import { ReactiveFormsModule, Validators, } from '@angular/forms';
|
|
20
|
+
import { InternalCaseStatusColor, InternalCaseStatusUtils, } from '@valtimo/document';
|
|
21
|
+
import { ButtonModule, DropdownModule, InputModule, ModalModule, TagModule, ToggleModule, } from 'carbon-components-angular';
|
|
22
|
+
import { Edit16 } from '@carbon/icons';
|
|
23
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
24
|
+
import { CommonModule } from '@angular/common';
|
|
25
|
+
import * as i0 from "@angular/core";
|
|
26
|
+
import * as i1 from "@angular/forms";
|
|
27
|
+
import * as i2 from "carbon-components-angular";
|
|
28
|
+
import * as i3 from "@valtimo/document";
|
|
29
|
+
import * as i4 from "@ngx-translate/core";
|
|
30
|
+
import * as i5 from "@angular/common";
|
|
31
|
+
export class DocumentenApiColumnModalComponent {
|
|
32
|
+
set type(value) {
|
|
33
|
+
this._type.next(value);
|
|
34
|
+
if (value === 'closed') {
|
|
35
|
+
setTimeout(() => {
|
|
36
|
+
this._typeAnimationDelay$.next(value);
|
|
37
|
+
}, CARBON_CONSTANTS.modalAnimationMs);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
this._typeAnimationDelay$.next(value);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
set prefill(value) {
|
|
44
|
+
this._prefillStatus.next(value);
|
|
45
|
+
}
|
|
46
|
+
get visibleInCaseListByDefault() {
|
|
47
|
+
return this.statusFormGroup?.get('visibleInCaseListByDefault');
|
|
48
|
+
}
|
|
49
|
+
get key() {
|
|
50
|
+
return this.statusFormGroup?.get('key');
|
|
51
|
+
}
|
|
52
|
+
get title() {
|
|
53
|
+
return this.statusFormGroup?.get('title');
|
|
54
|
+
}
|
|
55
|
+
get color() {
|
|
56
|
+
return this.statusFormGroup?.get('color');
|
|
57
|
+
}
|
|
58
|
+
get invalid() {
|
|
59
|
+
return !!this.statusFormGroup?.invalid;
|
|
60
|
+
}
|
|
61
|
+
get pristine() {
|
|
62
|
+
return !!this.statusFormGroup?.pristine;
|
|
63
|
+
}
|
|
64
|
+
constructor(fb, iconService, caseStatusService, translateService) {
|
|
65
|
+
this.fb = fb;
|
|
66
|
+
this.iconService = iconService;
|
|
67
|
+
this.caseStatusService = caseStatusService;
|
|
68
|
+
this.translateService = translateService;
|
|
69
|
+
this.closeModalEvent = new EventEmitter();
|
|
70
|
+
this._type = new BehaviorSubject(undefined);
|
|
71
|
+
this._typeAnimationDelay$ = new BehaviorSubject(undefined);
|
|
72
|
+
this._prefillStatus = new BehaviorSubject(undefined);
|
|
73
|
+
this.isClosed$ = this._type.pipe(map(type => type === 'closed'));
|
|
74
|
+
this.statusFormGroup = this.fb.group({
|
|
75
|
+
title: this.fb.control('', Validators.required),
|
|
76
|
+
key: this.fb.control('', [Validators.required, this.uniqueKeyValidator()]),
|
|
77
|
+
visibleInCaseListByDefault: this.fb.control(true, Validators.required),
|
|
78
|
+
color: this.fb.control('', Validators.required),
|
|
79
|
+
});
|
|
80
|
+
this.isEdit$ = combineLatest([this._typeAnimationDelay$, this._prefillStatus]).pipe(tap(([type, prefillStatus]) => {
|
|
81
|
+
if (type === 'edit' && prefillStatus)
|
|
82
|
+
this.prefillForm(prefillStatus);
|
|
83
|
+
}), map(([type]) => type === 'edit'));
|
|
84
|
+
this.isAdd$ = this._typeAnimationDelay$.pipe(map(type => type === 'add'), tap(isAdd => {
|
|
85
|
+
if (isAdd)
|
|
86
|
+
this.resetForm();
|
|
87
|
+
}));
|
|
88
|
+
this.disabled$ = new BehaviorSubject(false);
|
|
89
|
+
this.COLORS = [
|
|
90
|
+
InternalCaseStatusColor.Red,
|
|
91
|
+
InternalCaseStatusColor.Magenta,
|
|
92
|
+
InternalCaseStatusColor.Purple,
|
|
93
|
+
InternalCaseStatusColor.Blue,
|
|
94
|
+
InternalCaseStatusColor.Teal,
|
|
95
|
+
InternalCaseStatusColor.Green,
|
|
96
|
+
InternalCaseStatusColor.Cyan,
|
|
97
|
+
InternalCaseStatusColor.Gray,
|
|
98
|
+
InternalCaseStatusColor.CoolGray,
|
|
99
|
+
InternalCaseStatusColor.WarmGray,
|
|
100
|
+
InternalCaseStatusColor.HighContrast,
|
|
101
|
+
InternalCaseStatusColor.Outline,
|
|
102
|
+
];
|
|
103
|
+
this._selectedColor$ = new BehaviorSubject(undefined);
|
|
104
|
+
this.colorListItems$ = combineLatest([
|
|
105
|
+
this._selectedColor$,
|
|
106
|
+
this.translateService.stream('key'),
|
|
107
|
+
]).pipe(map(([selectedColor]) => this.COLORS.map(color => ({
|
|
108
|
+
selected: color === selectedColor,
|
|
109
|
+
content: this.translateService.instant('interface.tagType.' +
|
|
110
|
+
InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(color)),
|
|
111
|
+
color,
|
|
112
|
+
tagType: InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(color),
|
|
113
|
+
}))));
|
|
114
|
+
this._editingKey$ = new BehaviorSubject(false);
|
|
115
|
+
this.editingKey$ = this._editingKey$.pipe(tap(editing => {
|
|
116
|
+
if (editing) {
|
|
117
|
+
this.key?.enable();
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
this.key?.disable();
|
|
121
|
+
}
|
|
122
|
+
}));
|
|
123
|
+
this._originalStatusKey$ = new BehaviorSubject('');
|
|
124
|
+
this._subscriptions = new Subscription();
|
|
125
|
+
this.iconService.registerAll([Edit16]);
|
|
126
|
+
}
|
|
127
|
+
ngOnInit() {
|
|
128
|
+
this.openAutoKeySubscription();
|
|
129
|
+
}
|
|
130
|
+
ngOnDestroy() {
|
|
131
|
+
this._subscriptions.unsubscribe();
|
|
132
|
+
}
|
|
133
|
+
onClose() {
|
|
134
|
+
this.close();
|
|
135
|
+
}
|
|
136
|
+
toggleCheckedChange(checked) {
|
|
137
|
+
this.statusFormGroup.patchValue({
|
|
138
|
+
visibleInCaseListByDefault: checked,
|
|
139
|
+
});
|
|
140
|
+
this.statusFormGroup.markAsDirty();
|
|
141
|
+
}
|
|
142
|
+
addStatus() {
|
|
143
|
+
this.disable();
|
|
144
|
+
this.caseStatusService
|
|
145
|
+
.saveInternalCaseStatus(this.documentDefinitionName, this.getFormValue())
|
|
146
|
+
.subscribe({
|
|
147
|
+
next: () => {
|
|
148
|
+
this.enable();
|
|
149
|
+
this.closeAndRefresh();
|
|
150
|
+
},
|
|
151
|
+
error: () => {
|
|
152
|
+
this.enable(false);
|
|
153
|
+
},
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
editStatus() {
|
|
157
|
+
this.disable();
|
|
158
|
+
this._originalStatusKey$
|
|
159
|
+
.pipe(take(1), switchMap(originalStatusKey => this.caseStatusService.updateInternalCaseStatus(this.documentDefinitionName, originalStatusKey, this.getFormValue())))
|
|
160
|
+
.subscribe({
|
|
161
|
+
next: () => {
|
|
162
|
+
this.enable();
|
|
163
|
+
this.closeAndRefresh();
|
|
164
|
+
},
|
|
165
|
+
error: () => {
|
|
166
|
+
this.enable(false);
|
|
167
|
+
},
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
editKeyButtonClick() {
|
|
171
|
+
this._editingKey$.next(true);
|
|
172
|
+
}
|
|
173
|
+
colorDropdownChange(event) {
|
|
174
|
+
const newColor = event?.item?.color;
|
|
175
|
+
if (newColor) {
|
|
176
|
+
this._selectedColor$.next(newColor);
|
|
177
|
+
this.statusFormGroup.patchValue({ color: newColor });
|
|
178
|
+
this.statusFormGroup.markAsDirty();
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
prefillForm(prefillStatus) {
|
|
182
|
+
this._originalStatusKey$.next(prefillStatus.key);
|
|
183
|
+
this.statusFormGroup.patchValue({
|
|
184
|
+
key: prefillStatus.key,
|
|
185
|
+
title: prefillStatus.title,
|
|
186
|
+
visibleInCaseListByDefault: prefillStatus.visibleInCaseListByDefault,
|
|
187
|
+
color: prefillStatus.color,
|
|
188
|
+
});
|
|
189
|
+
this._selectedColor$.next(prefillStatus.color);
|
|
190
|
+
this.statusFormGroup.markAsPristine();
|
|
191
|
+
this.resetEditingKey();
|
|
192
|
+
}
|
|
193
|
+
resetForm() {
|
|
194
|
+
this.statusFormGroup.patchValue({
|
|
195
|
+
key: '',
|
|
196
|
+
title: '',
|
|
197
|
+
visibleInCaseListByDefault: true,
|
|
198
|
+
color: InternalCaseStatusColor.Blue,
|
|
199
|
+
});
|
|
200
|
+
this._selectedColor$.next(InternalCaseStatusColor.Blue);
|
|
201
|
+
this.statusFormGroup.markAsPristine();
|
|
202
|
+
this.resetEditingKey();
|
|
203
|
+
}
|
|
204
|
+
resetEditingKey() {
|
|
205
|
+
this._editingKey$.next(false);
|
|
206
|
+
}
|
|
207
|
+
openAutoKeySubscription() {
|
|
208
|
+
this._subscriptions.add(combineLatest([this.isAdd$, this.title.valueChanges, this.editingKey$]).subscribe(([isAdd, titleValue, editingKey]) => {
|
|
209
|
+
if (isAdd && !editingKey) {
|
|
210
|
+
if (titleValue) {
|
|
211
|
+
this.statusFormGroup.patchValue({ key: this.getUniqueKey(titleValue) });
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
this.clearKey();
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
}));
|
|
218
|
+
}
|
|
219
|
+
getUniqueKey(title) {
|
|
220
|
+
const dashCaseKey = `${title}`
|
|
221
|
+
.toLowerCase()
|
|
222
|
+
.replace(/[^a-z0-9-_]+|-[^a-z0-9]+/g, '-')
|
|
223
|
+
.replace(/_[-_]+/g, '_')
|
|
224
|
+
.replace(/^[^a-z]+/g, '');
|
|
225
|
+
const usedKeys = this.usedKeys;
|
|
226
|
+
if (!usedKeys.includes(dashCaseKey)) {
|
|
227
|
+
return dashCaseKey;
|
|
228
|
+
}
|
|
229
|
+
return this.getUniqueKeyWithNumber(dashCaseKey, usedKeys);
|
|
230
|
+
}
|
|
231
|
+
getUniqueKeyWithNumber(dashCaseKey, usedKeys) {
|
|
232
|
+
const numbersFromCurrentKey = (dashCaseKey.match(/^\d+|\d+\b|\d+(?=\w)/g) || []).map((numberValue) => +numberValue);
|
|
233
|
+
const lastNumberFromCurrentKey = numbersFromCurrentKey.length > 0 && numbersFromCurrentKey[numbersFromCurrentKey.length - 1];
|
|
234
|
+
const newKey = lastNumberFromCurrentKey
|
|
235
|
+
? `${dashCaseKey.replace(`${lastNumberFromCurrentKey}`, `${lastNumberFromCurrentKey + 1}`)}`
|
|
236
|
+
: `${dashCaseKey}-1`;
|
|
237
|
+
if (usedKeys.includes(newKey)) {
|
|
238
|
+
return this.getUniqueKeyWithNumber(newKey, usedKeys);
|
|
239
|
+
}
|
|
240
|
+
return newKey;
|
|
241
|
+
}
|
|
242
|
+
clearKey() {
|
|
243
|
+
this.statusFormGroup.patchValue({ key: '' });
|
|
244
|
+
}
|
|
245
|
+
uniqueKeyValidator() {
|
|
246
|
+
return (control) => this.usedKeys?.every((key) => key !== control.value)
|
|
247
|
+
? null
|
|
248
|
+
: { uniqueKey: { value: control.value } };
|
|
249
|
+
}
|
|
250
|
+
disable() {
|
|
251
|
+
this.disabled$.next(true);
|
|
252
|
+
this.statusFormGroup.disable();
|
|
253
|
+
}
|
|
254
|
+
enable(delay = true) {
|
|
255
|
+
setTimeout(() => {
|
|
256
|
+
this.disabled$.next(false);
|
|
257
|
+
this.statusFormGroup.enable();
|
|
258
|
+
}, delay ? CARBON_CONSTANTS.modalAnimationMs : 0);
|
|
259
|
+
}
|
|
260
|
+
close() {
|
|
261
|
+
this.closeModalEvent.emit('close');
|
|
262
|
+
}
|
|
263
|
+
closeAndRefresh() {
|
|
264
|
+
this.closeModalEvent.emit('closeAndRefresh');
|
|
265
|
+
}
|
|
266
|
+
getFormValue() {
|
|
267
|
+
return {
|
|
268
|
+
key: this.key.value,
|
|
269
|
+
title: this.title.value,
|
|
270
|
+
visibleInCaseListByDefault: this.visibleInCaseListByDefault.value,
|
|
271
|
+
color: this.color.value,
|
|
272
|
+
};
|
|
273
|
+
}
|
|
274
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiColumnModalComponent, deps: [{ token: i1.FormBuilder }, { token: i2.IconService }, { token: i3.CaseStatusService }, { token: i4.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
275
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.3", type: DocumentenApiColumnModalComponent, isStandalone: true, selector: "valtimo-documenten-api-column-modal", inputs: { type: "type", prefill: "prefill", usedKeys: "usedKeys", documentDefinitionName: "documentDefinitionName" }, outputs: { closeModalEvent: "closeModalEvent" }, ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<cds-modal\n valtimoCdsModal\n *ngIf=\"{\n isAdd: isAdd$ | async,\n isEdit: isEdit$ | async,\n isClosed: isClosed$ | async,\n editingKey: editingKey$ | async,\n disabled: disabled$ | async\n } as obs\"\n [open]=\"!obs.isClosed\"\n size=\"sm\"\n>\n <cds-modal-header showCloseButton=\"true\" (closeSelect)=\"onClose()\">\n <h3 cdsModalHeaderHeading>\n {{ obs.isAdd ? ('dossierManagement.statuses.add' | translate) : '' }}\n {{ obs.isEdit ? ('dossierManagement.statuses.edit' | translate) : '' }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent>\n <ng-container *ngTemplateOutlet=\"statusForm; context: {obs: obs}\"></ng-container>\n </section>\n\n <cds-modal-footer>\n <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n </cds-modal-footer>\n</cds-modal>\n\n<ng-template #colorDropdownItemTemplate let-item=\"item\">\n <div class=\"dropdown-color-tag\">\n <cds-tag *ngIf=\"item && item.content\" class=\"cds-tag--no-margin\" [type]=\"item?.tagType\">\n {{ 'interface.tagType.' + item?.tagType | translate }}\n </cds-tag>\n </div>\n</ng-template>\n\n<ng-template #statusForm let-obs=\"obs\">\n <form [formGroup]=\"statusFormGroup\" class=\"status-form\">\n <cds-label>\n {{ 'dossierManagement.statuses.columns.title' | translate }}\n\n <input cdsText formControlName=\"title\" [attr.modal-primary-focus]=\"true\" />\n </cds-label>\n\n <cds-label>\n {{ 'dossierManagement.statuses.columns.key' | translate }}\n\n <div class=\"edit-key-input\">\n <input\n cdsText\n formControlName=\"key\"\n [disabled]=\"!obs.editingKey\"\n [placeholder]=\"\n obs.isAdd && !obs.editingKey\n ? ('dossierManagement.statuses.keyAutoGenerated' | translate)\n : ''\n \"\n />\n\n <cds-icon-button\n *ngIf=\"!obs.editingKey && obs.isAdd\"\n [disabled]=\"obs.disabled\"\n (click)=\"editKeyButtonClick()\"\n kind=\"secondary\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"edit\" size=\"16\"></svg>\n </cds-icon-button>\n </div>\n </cds-label>\n\n <div class=\"horizontal-inputs\">\n <cds-label>\n {{ 'dossierManagement.statuses.columns.color' | translate }}\n\n <cds-dropdown\n [appendInline]=\"false\"\n [placeholder]=\"'dossierManagement.statuses.colorPlaceholder' | translate\"\n (selected)=\"colorDropdownChange($event)\"\n >\n <cds-dropdown-list [items]=\"colorListItems$\" [listTpl]=\"colorDropdownItemTemplate\">\n </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n\n <cds-toggle\n [label]=\"'dossierManagement.statuses.visibleTitle' | translate\"\n [onText]=\"'dossierManagement.statuses.visible' | translate\"\n [offText]=\"'dossierManagement.statuses.invisible' | translate\"\n [disabled]=\"obs.disabled\"\n [checked]=\"visibleInCaseListByDefault?.value\"\n (checkedChange)=\"toggleCheckedChange($event)\"\n ></cds-toggle>\n </div>\n </form>\n</ng-template>\n\n<ng-template #buttons let-obs=\"obs\">\n <button cdsButton=\"secondary\" (click)=\"onClose()\" [disabled]=\"obs.disabled\">\n {{ 'interface.cancel' | translate }}\n </button>\n\n <button\n *ngIf=\"obs.isAdd\"\n cdsButton=\"primary\"\n [disabled]=\"invalid || pristine || obs.disabled\"\n (click)=\"addStatus()\"\n >\n {{ 'interface.add' | translate }}\n </button>\n\n <button\n *ngIf=\"obs.isEdit\"\n cdsButton=\"primary\"\n [disabled]=\"invalid || pristine || obs.disabled\"\n (click)=\"editStatus()\"\n >\n {{ 'interface.save' | translate }}\n </button>\n</ng-template>\n", styles: [".status-form{display:flex;flex-direction:column;gap:16px}.edit-key-input{height:40px;display:flex;width:100%;flex-direction:row;gap:16px;align-items:flex-end}::ng-deep .horizontal-inputs{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}::ng-deep .horizontal-inputs .cds--label{width:100%;display:flex;flex-direction:column;gap:8px}::ng-deep .dropdown-color-tag .cds--tag{margin-top:-4px;margin-left:2px}\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: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ModalModule }, { kind: "component", type: i2.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i2.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i2.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i2.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i2.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "ngmodule", type: TagModule }, { kind: "component", type: i2.Tag, selector: "cds-tag, ibm-tag", inputs: ["type", "size", "class"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i2.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i2.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i2.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "component", type: i2.IconButton, selector: "cds-icon-button, ibm-icon-button", inputs: ["buttonNgClass", "buttonAttributes", "buttonId", "kind", "size", "type", "isExpressive", "disabled", "description"], outputs: ["click", "focus", "blur", "tooltipClick"] }, { kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i2.Dropdown, selector: "cds-dropdown, ibm-dropdown", inputs: ["id", "label", "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: i2.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "ngmodule", type: ToggleModule }, { kind: "component", type: i2.Toggle, selector: "cds-toggle, ibm-toggle", inputs: ["offText", "onText", "label", "size", "hideLabel", "skeleton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
276
|
+
}
|
|
277
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiColumnModalComponent, decorators: [{
|
|
278
|
+
type: Component,
|
|
279
|
+
args: [{ selector: 'valtimo-documenten-api-column-modal', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
280
|
+
CommonModule,
|
|
281
|
+
ModalModule,
|
|
282
|
+
TagModule,
|
|
283
|
+
TranslateModule,
|
|
284
|
+
InputModule,
|
|
285
|
+
ReactiveFormsModule,
|
|
286
|
+
ButtonModule,
|
|
287
|
+
DropdownModule,
|
|
288
|
+
ToggleModule,
|
|
289
|
+
], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<cds-modal\n valtimoCdsModal\n *ngIf=\"{\n isAdd: isAdd$ | async,\n isEdit: isEdit$ | async,\n isClosed: isClosed$ | async,\n editingKey: editingKey$ | async,\n disabled: disabled$ | async\n } as obs\"\n [open]=\"!obs.isClosed\"\n size=\"sm\"\n>\n <cds-modal-header showCloseButton=\"true\" (closeSelect)=\"onClose()\">\n <h3 cdsModalHeaderHeading>\n {{ obs.isAdd ? ('dossierManagement.statuses.add' | translate) : '' }}\n {{ obs.isEdit ? ('dossierManagement.statuses.edit' | translate) : '' }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent>\n <ng-container *ngTemplateOutlet=\"statusForm; context: {obs: obs}\"></ng-container>\n </section>\n\n <cds-modal-footer>\n <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n </cds-modal-footer>\n</cds-modal>\n\n<ng-template #colorDropdownItemTemplate let-item=\"item\">\n <div class=\"dropdown-color-tag\">\n <cds-tag *ngIf=\"item && item.content\" class=\"cds-tag--no-margin\" [type]=\"item?.tagType\">\n {{ 'interface.tagType.' + item?.tagType | translate }}\n </cds-tag>\n </div>\n</ng-template>\n\n<ng-template #statusForm let-obs=\"obs\">\n <form [formGroup]=\"statusFormGroup\" class=\"status-form\">\n <cds-label>\n {{ 'dossierManagement.statuses.columns.title' | translate }}\n\n <input cdsText formControlName=\"title\" [attr.modal-primary-focus]=\"true\" />\n </cds-label>\n\n <cds-label>\n {{ 'dossierManagement.statuses.columns.key' | translate }}\n\n <div class=\"edit-key-input\">\n <input\n cdsText\n formControlName=\"key\"\n [disabled]=\"!obs.editingKey\"\n [placeholder]=\"\n obs.isAdd && !obs.editingKey\n ? ('dossierManagement.statuses.keyAutoGenerated' | translate)\n : ''\n \"\n />\n\n <cds-icon-button\n *ngIf=\"!obs.editingKey && obs.isAdd\"\n [disabled]=\"obs.disabled\"\n (click)=\"editKeyButtonClick()\"\n kind=\"secondary\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"edit\" size=\"16\"></svg>\n </cds-icon-button>\n </div>\n </cds-label>\n\n <div class=\"horizontal-inputs\">\n <cds-label>\n {{ 'dossierManagement.statuses.columns.color' | translate }}\n\n <cds-dropdown\n [appendInline]=\"false\"\n [placeholder]=\"'dossierManagement.statuses.colorPlaceholder' | translate\"\n (selected)=\"colorDropdownChange($event)\"\n >\n <cds-dropdown-list [items]=\"colorListItems$\" [listTpl]=\"colorDropdownItemTemplate\">\n </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n\n <cds-toggle\n [label]=\"'dossierManagement.statuses.visibleTitle' | translate\"\n [onText]=\"'dossierManagement.statuses.visible' | translate\"\n [offText]=\"'dossierManagement.statuses.invisible' | translate\"\n [disabled]=\"obs.disabled\"\n [checked]=\"visibleInCaseListByDefault?.value\"\n (checkedChange)=\"toggleCheckedChange($event)\"\n ></cds-toggle>\n </div>\n </form>\n</ng-template>\n\n<ng-template #buttons let-obs=\"obs\">\n <button cdsButton=\"secondary\" (click)=\"onClose()\" [disabled]=\"obs.disabled\">\n {{ 'interface.cancel' | translate }}\n </button>\n\n <button\n *ngIf=\"obs.isAdd\"\n cdsButton=\"primary\"\n [disabled]=\"invalid || pristine || obs.disabled\"\n (click)=\"addStatus()\"\n >\n {{ 'interface.add' | translate }}\n </button>\n\n <button\n *ngIf=\"obs.isEdit\"\n cdsButton=\"primary\"\n [disabled]=\"invalid || pristine || obs.disabled\"\n (click)=\"editStatus()\"\n >\n {{ 'interface.save' | translate }}\n </button>\n</ng-template>\n", styles: [".status-form{display:flex;flex-direction:column;gap:16px}.edit-key-input{height:40px;display:flex;width:100%;flex-direction:row;gap:16px;align-items:flex-end}::ng-deep .horizontal-inputs{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}::ng-deep .horizontal-inputs .cds--label{width:100%;display:flex;flex-direction:column;gap:8px}::ng-deep .dropdown-color-tag .cds--tag{margin-top:-4px;margin-left:2px}\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"] }]
|
|
290
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.IconService }, { type: i3.CaseStatusService }, { type: i4.TranslateService }], propDecorators: { type: [{
|
|
291
|
+
type: Input
|
|
292
|
+
}], prefill: [{
|
|
293
|
+
type: Input
|
|
294
|
+
}], usedKeys: [{
|
|
295
|
+
type: Input
|
|
296
|
+
}], documentDefinitionName: [{
|
|
297
|
+
type: Input
|
|
298
|
+
}], closeModalEvent: [{
|
|
299
|
+
type: Output
|
|
300
|
+
}] } });
|
|
301
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-column-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.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  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {DocumentenApiColumnModalType, DocumentenApiColumnModalTypeCloseEvent} from '../../models';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  map,\n  Observable,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {CARBON_CONSTANTS} from '@valtimo/components';\nimport {\n  AbstractControl,\n  FormBuilder,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport {\n  CaseStatusService,\n  InternalCaseStatus,\n  InternalCaseStatusColor,\n  InternalCaseStatusUtils,\n} from '@valtimo/document';\nimport {\n  ButtonModule,\n  DropdownModule,\n  IconService,\n  InputModule,\n  ListItem,\n  ModalModule,\n  TagModule,\n  ToggleModule,\n} from 'carbon-components-angular';\nimport {Edit16} from '@carbon/icons';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {CommonModule} from '@angular/common';\n\n@Component({\n  selector: 'valtimo-documenten-api-column-modal',\n  templateUrl: './documenten-api-column-modal.component.html',\n  styleUrls: ['./documenten-api-column-modal.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ModalModule,\n    TagModule,\n    TranslateModule,\n    InputModule,\n    ReactiveFormsModule,\n    ButtonModule,\n    DropdownModule,\n    ToggleModule,\n  ],\n})\nexport class DocumentenApiColumnModalComponent implements OnInit, OnDestroy {\n  @Input() public set type(value: DocumentenApiColumnModalType) {\n    this._type.next(value);\n\n    if (value === 'closed') {\n      setTimeout(() => {\n        this._typeAnimationDelay$.next(value);\n      }, CARBON_CONSTANTS.modalAnimationMs);\n    } else {\n      this._typeAnimationDelay$.next(value);\n    }\n  }\n\n  @Input() public set prefill(value: InternalCaseStatus) {\n    this._prefillStatus.next(value);\n  }\n\n  @Input() public usedKeys!: string[];\n  @Input() public documentDefinitionName!: string;\n\n  @Output() public closeModalEvent = new EventEmitter<DocumentenApiColumnModalTypeCloseEvent>();\n\n  private readonly _type = new BehaviorSubject<DocumentenApiColumnModalType>(undefined);\n  private readonly _typeAnimationDelay$ = new BehaviorSubject<DocumentenApiColumnModalType>(\n    undefined\n  );\n  private readonly _prefillStatus = new BehaviorSubject<InternalCaseStatus>(undefined);\n\n  public readonly isClosed$ = this._type.pipe(map(type => type === 'closed'));\n\n  public readonly statusFormGroup = this.fb.group({\n    title: this.fb.control('', Validators.required),\n    key: this.fb.control('', [Validators.required, this.uniqueKeyValidator()]),\n    visibleInCaseListByDefault: this.fb.control(true, Validators.required),\n    color: this.fb.control('', Validators.required),\n  });\n\n  public readonly isEdit$ = combineLatest([this._typeAnimationDelay$, this._prefillStatus]).pipe(\n    tap(([type, prefillStatus]) => {\n      if (type === 'edit' && prefillStatus) this.prefillForm(prefillStatus);\n    }),\n    map(([type]) => type === 'edit')\n  );\n\n  public readonly isAdd$ = this._typeAnimationDelay$.pipe(\n    map(type => type === 'add'),\n    tap(isAdd => {\n      if (isAdd) this.resetForm();\n    })\n  );\n\n  public readonly disabled$ = new BehaviorSubject<boolean>(false);\n\n  private readonly COLORS: InternalCaseStatusColor[] = [\n    InternalCaseStatusColor.Red,\n    InternalCaseStatusColor.Magenta,\n    InternalCaseStatusColor.Purple,\n    InternalCaseStatusColor.Blue,\n    InternalCaseStatusColor.Teal,\n    InternalCaseStatusColor.Green,\n    InternalCaseStatusColor.Cyan,\n    InternalCaseStatusColor.Gray,\n    InternalCaseStatusColor.CoolGray,\n    InternalCaseStatusColor.WarmGray,\n    InternalCaseStatusColor.HighContrast,\n    InternalCaseStatusColor.Outline,\n  ];\n\n  private readonly _selectedColor$ = new BehaviorSubject<InternalCaseStatusColor>(undefined);\n\n  public readonly colorListItems$: Observable<ListItem[]> = combineLatest([\n    this._selectedColor$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([selectedColor]) =>\n      this.COLORS.map(color => ({\n        selected: color === selectedColor,\n        content: this.translateService.instant(\n          'interface.tagType.' +\n            InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(color)\n        ),\n        color,\n        tagType: InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(color),\n      }))\n    )\n  );\n\n  public get visibleInCaseListByDefault(): AbstractControl<boolean, boolean> {\n    return this.statusFormGroup?.get('visibleInCaseListByDefault');\n  }\n\n  public get key(): AbstractControl<string, string> {\n    return this.statusFormGroup?.get('key');\n  }\n\n  public get title(): AbstractControl<string, string> {\n    return this.statusFormGroup?.get('title');\n  }\n\n  public get color(): AbstractControl<string, string> {\n    return this.statusFormGroup?.get('color');\n  }\n\n  public get invalid(): boolean {\n    return !!this.statusFormGroup?.invalid;\n  }\n\n  public get pristine(): boolean {\n    return !!this.statusFormGroup?.pristine;\n  }\n\n  private readonly _editingKey$ = new BehaviorSubject<boolean>(false);\n\n  public readonly editingKey$ = this._editingKey$.pipe(\n    tap(editing => {\n      if (editing) {\n        this.key?.enable();\n      } else {\n        this.key?.disable();\n      }\n    })\n  );\n\n  private readonly _originalStatusKey$ = new BehaviorSubject<string>('');\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly fb: FormBuilder,\n    private readonly iconService: IconService,\n    private readonly caseStatusService: CaseStatusService,\n    private readonly translateService: TranslateService\n  ) {\n    this.iconService.registerAll([Edit16]);\n  }\n\n  public ngOnInit(): void {\n    this.openAutoKeySubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public onClose(): void {\n    this.close();\n  }\n\n  public toggleCheckedChange(checked: boolean): void {\n    this.statusFormGroup.patchValue({\n      visibleInCaseListByDefault: checked,\n    });\n    this.statusFormGroup.markAsDirty();\n  }\n\n  public addStatus(): void {\n    this.disable();\n\n    this.caseStatusService\n      .saveInternalCaseStatus(this.documentDefinitionName, this.getFormValue())\n      .subscribe({\n        next: () => {\n          this.enable();\n          this.closeAndRefresh();\n        },\n        error: () => {\n          this.enable(false);\n        },\n      });\n  }\n\n  public editStatus(): void {\n    this.disable();\n\n    this._originalStatusKey$\n      .pipe(\n        take(1),\n        switchMap(originalStatusKey =>\n          this.caseStatusService.updateInternalCaseStatus(\n            this.documentDefinitionName,\n            originalStatusKey,\n            this.getFormValue()\n          )\n        )\n      )\n      .subscribe({\n        next: () => {\n          this.enable();\n          this.closeAndRefresh();\n        },\n        error: () => {\n          this.enable(false);\n        },\n      });\n  }\n\n  public editKeyButtonClick(): void {\n    this._editingKey$.next(true);\n  }\n\n  public colorDropdownChange(event: {\n    item: {color: string; content: string; selected: boolean};\n    isUpdate: boolean;\n  }): void {\n    const newColor = event?.item?.color as InternalCaseStatusColor;\n\n    if (newColor) {\n      this._selectedColor$.next(newColor);\n      this.statusFormGroup.patchValue({color: newColor});\n      this.statusFormGroup.markAsDirty();\n    }\n  }\n\n  private prefillForm(prefillStatus: InternalCaseStatus): void {\n    this._originalStatusKey$.next(prefillStatus.key);\n    this.statusFormGroup.patchValue({\n      key: prefillStatus.key,\n      title: prefillStatus.title,\n      visibleInCaseListByDefault: prefillStatus.visibleInCaseListByDefault,\n      color: prefillStatus.color,\n    });\n    this._selectedColor$.next(prefillStatus.color);\n    this.statusFormGroup.markAsPristine();\n    this.resetEditingKey();\n  }\n\n  private resetForm(): void {\n    this.statusFormGroup.patchValue({\n      key: '',\n      title: '',\n      visibleInCaseListByDefault: true,\n      color: InternalCaseStatusColor.Blue,\n    });\n    this._selectedColor$.next(InternalCaseStatusColor.Blue);\n    this.statusFormGroup.markAsPristine();\n    this.resetEditingKey();\n  }\n\n  private resetEditingKey(): void {\n    this._editingKey$.next(false);\n  }\n\n  private openAutoKeySubscription(): void {\n    this._subscriptions.add(\n      combineLatest([this.isAdd$, this.title.valueChanges, this.editingKey$]).subscribe(\n        ([isAdd, titleValue, editingKey]) => {\n          if (isAdd && !editingKey) {\n            if (titleValue) {\n              this.statusFormGroup.patchValue({key: this.getUniqueKey(titleValue)});\n            } else {\n              this.clearKey();\n            }\n          }\n        }\n      )\n    );\n  }\n\n  private getUniqueKey(title: string): string {\n    const dashCaseKey = `${title}`\n      .toLowerCase()\n      .replace(/[^a-z0-9-_]+|-[^a-z0-9]+/g, '-')\n      .replace(/_[-_]+/g, '_')\n      .replace(/^[^a-z]+/g, '');\n    const usedKeys = this.usedKeys;\n\n    if (!usedKeys.includes(dashCaseKey)) {\n      return dashCaseKey;\n    }\n\n    return this.getUniqueKeyWithNumber(dashCaseKey, usedKeys);\n  }\n\n  private getUniqueKeyWithNumber(dashCaseKey: string, usedKeys: string[]): string {\n    const numbersFromCurrentKey = (dashCaseKey.match(/^\\d+|\\d+\\b|\\d+(?=\\w)/g) || []).map(\n      (numberValue: string) => +numberValue\n    );\n    const lastNumberFromCurrentKey =\n      numbersFromCurrentKey.length > 0 && numbersFromCurrentKey[numbersFromCurrentKey.length - 1];\n    const newKey = lastNumberFromCurrentKey\n      ? `${dashCaseKey.replace(`${lastNumberFromCurrentKey}`, `${lastNumberFromCurrentKey + 1}`)}`\n      : `${dashCaseKey}-1`;\n\n    if (usedKeys.includes(newKey)) {\n      return this.getUniqueKeyWithNumber(newKey, usedKeys);\n    }\n\n    return newKey;\n  }\n\n  private clearKey(): void {\n    this.statusFormGroup.patchValue({key: ''});\n  }\n\n  private uniqueKeyValidator(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null =>\n      this.usedKeys?.every((key: string) => key !== control.value)\n        ? null\n        : {uniqueKey: {value: control.value}};\n  }\n\n  private disable(): void {\n    this.disabled$.next(true);\n    this.statusFormGroup.disable();\n  }\n\n  private enable(delay = true): void {\n    setTimeout(\n      () => {\n        this.disabled$.next(false);\n        this.statusFormGroup.enable();\n      },\n      delay ? CARBON_CONSTANTS.modalAnimationMs : 0\n    );\n  }\n\n  private close(): void {\n    this.closeModalEvent.emit('close');\n  }\n\n  private closeAndRefresh(): void {\n    this.closeModalEvent.emit('closeAndRefresh');\n  }\n\n  private getFormValue(): InternalCaseStatus {\n    return {\n      key: this.key.value,\n      title: this.title.value,\n      visibleInCaseListByDefault: this.visibleInCaseListByDefault.value,\n      color: this.color.value as InternalCaseStatusColor,\n    };\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<cds-modal\n  valtimoCdsModal\n  *ngIf=\"{\n    isAdd: isAdd$ | async,\n    isEdit: isEdit$ | async,\n    isClosed: isClosed$ | async,\n    editingKey: editingKey$ | async,\n    disabled: disabled$ | async\n  } as obs\"\n  [open]=\"!obs.isClosed\"\n  size=\"sm\"\n>\n  <cds-modal-header showCloseButton=\"true\" (closeSelect)=\"onClose()\">\n    <h3 cdsModalHeaderHeading>\n      {{ obs.isAdd ? ('dossierManagement.statuses.add' | translate) : '' }}\n      {{ obs.isEdit ? ('dossierManagement.statuses.edit' | translate) : '' }}\n    </h3>\n  </cds-modal-header>\n\n  <section cdsModalContent>\n    <ng-container *ngTemplateOutlet=\"statusForm; context: {obs: obs}\"></ng-container>\n  </section>\n\n  <cds-modal-footer>\n    <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n  </cds-modal-footer>\n</cds-modal>\n\n<ng-template #colorDropdownItemTemplate let-item=\"item\">\n  <div class=\"dropdown-color-tag\">\n    <cds-tag *ngIf=\"item && item.content\" class=\"cds-tag--no-margin\" [type]=\"item?.tagType\">\n      {{ 'interface.tagType.' + item?.tagType | translate }}\n    </cds-tag>\n  </div>\n</ng-template>\n\n<ng-template #statusForm let-obs=\"obs\">\n  <form [formGroup]=\"statusFormGroup\" class=\"status-form\">\n    <cds-label>\n      {{ 'dossierManagement.statuses.columns.title' | translate }}\n\n      <input cdsText formControlName=\"title\" [attr.modal-primary-focus]=\"true\" />\n    </cds-label>\n\n    <cds-label>\n      {{ 'dossierManagement.statuses.columns.key' | translate }}\n\n      <div class=\"edit-key-input\">\n        <input\n          cdsText\n          formControlName=\"key\"\n          [disabled]=\"!obs.editingKey\"\n          [placeholder]=\"\n            obs.isAdd && !obs.editingKey\n              ? ('dossierManagement.statuses.keyAutoGenerated' | translate)\n              : ''\n          \"\n        />\n\n        <cds-icon-button\n          *ngIf=\"!obs.editingKey && obs.isAdd\"\n          [disabled]=\"obs.disabled\"\n          (click)=\"editKeyButtonClick()\"\n          kind=\"secondary\"\n        >\n          <svg class=\"cds--btn__icon\" cdsIcon=\"edit\" size=\"16\"></svg>\n        </cds-icon-button>\n      </div>\n    </cds-label>\n\n    <div class=\"horizontal-inputs\">\n      <cds-label>\n        {{ 'dossierManagement.statuses.columns.color' | translate }}\n\n        <cds-dropdown\n          [appendInline]=\"false\"\n          [placeholder]=\"'dossierManagement.statuses.colorPlaceholder' | translate\"\n          (selected)=\"colorDropdownChange($event)\"\n        >\n          <cds-dropdown-list [items]=\"colorListItems$\" [listTpl]=\"colorDropdownItemTemplate\">\n          </cds-dropdown-list>\n        </cds-dropdown>\n      </cds-label>\n\n      <cds-toggle\n        [label]=\"'dossierManagement.statuses.visibleTitle' | translate\"\n        [onText]=\"'dossierManagement.statuses.visible' | translate\"\n        [offText]=\"'dossierManagement.statuses.invisible' | translate\"\n        [disabled]=\"obs.disabled\"\n        [checked]=\"visibleInCaseListByDefault?.value\"\n        (checkedChange)=\"toggleCheckedChange($event)\"\n      ></cds-toggle>\n    </div>\n  </form>\n</ng-template>\n\n<ng-template #buttons let-obs=\"obs\">\n  <button cdsButton=\"secondary\" (click)=\"onClose()\" [disabled]=\"obs.disabled\">\n    {{ 'interface.cancel' | translate }}\n  </button>\n\n  <button\n    *ngIf=\"obs.isAdd\"\n    cdsButton=\"primary\"\n    [disabled]=\"invalid || pristine || obs.disabled\"\n    (click)=\"addStatus()\"\n  >\n    {{ 'interface.add' | translate }}\n  </button>\n\n  <button\n    *ngIf=\"obs.isEdit\"\n    cdsButton=\"primary\"\n    [disabled]=\"invalid || pristine || obs.disabled\"\n    (click)=\"editStatus()\"\n  >\n    {{ 'interface.save' | translate }}\n  </button>\n</ng-template>\n"]}
|