@valtimo/plugin 12.20.1 → 12.21.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/plugins/besluiten-api/besluiten-api-plugin.module.mjs +25 -6
- package/esm2022/lib/plugins/besluiten-api/besluiten-api-plugin.specification.mjs +35 -10
- package/esm2022/lib/plugins/besluiten-api/components/get-besluit/get-besluit-configuration.component.mjs +75 -0
- package/esm2022/lib/plugins/besluiten-api/components/patch-zaak-besluit/patch-zaak-besluit-configuration.component.mjs +132 -0
- package/esm2022/lib/plugins/besluiten-api/models/config.mjs +1 -1
- package/esm2022/lib/plugins/besluiten-api/models/patch-besluit-properties.mjs +27 -0
- package/esm2022/lib/plugins/zaken-api/components/get-zaakbesluiten/get-zaakbesluiten-configuration.component.mjs +75 -0
- package/esm2022/lib/plugins/zaken-api/components/set-zaak-status/set-zaak-status-configuration.component.mjs +154 -12
- package/esm2022/lib/plugins/zaken-api/models/config.mjs +1 -1
- package/esm2022/lib/plugins/zaken-api/zaken-api-plugin.module.mjs +17 -6
- package/esm2022/lib/plugins/zaken-api/zaken-api-plugin.specification.mjs +24 -1
- package/esm2022/public-api.mjs +4 -1
- package/fesm2022/valtimo-plugin.mjs +534 -34
- package/fesm2022/valtimo-plugin.mjs.map +1 -1
- package/lib/plugins/besluiten-api/besluiten-api-plugin.module.d.ts +8 -6
- package/lib/plugins/besluiten-api/besluiten-api-plugin.module.d.ts.map +1 -1
- package/lib/plugins/besluiten-api/besluiten-api-plugin.specification.d.ts.map +1 -1
- package/lib/plugins/besluiten-api/components/get-besluit/get-besluit-configuration.component.d.ts +24 -0
- package/lib/plugins/besluiten-api/components/get-besluit/get-besluit-configuration.component.d.ts.map +1 -0
- package/lib/plugins/besluiten-api/components/patch-zaak-besluit/patch-zaak-besluit-configuration.component.d.ts +39 -0
- package/lib/plugins/besluiten-api/components/patch-zaak-besluit/patch-zaak-besluit-configuration.component.d.ts.map +1 -0
- package/lib/plugins/besluiten-api/models/config.d.ts +17 -1
- package/lib/plugins/besluiten-api/models/config.d.ts.map +1 -1
- package/lib/plugins/besluiten-api/models/patch-besluit-properties.d.ts +3 -0
- package/lib/plugins/besluiten-api/models/patch-besluit-properties.d.ts.map +1 -0
- package/lib/plugins/zaken-api/components/get-zaakbesluiten/get-zaakbesluiten-configuration.component.d.ts +24 -0
- package/lib/plugins/zaken-api/components/get-zaakbesluiten/get-zaakbesluiten-configuration.component.d.ts.map +1 -0
- package/lib/plugins/zaken-api/components/set-zaak-status/set-zaak-status-configuration.component.d.ts +18 -2
- package/lib/plugins/zaken-api/components/set-zaak-status/set-zaak-status-configuration.component.d.ts.map +1 -1
- package/lib/plugins/zaken-api/models/config.d.ts +6 -1
- package/lib/plugins/zaken-api/models/config.d.ts.map +1 -1
- package/lib/plugins/zaken-api/zaken-api-plugin.module.d.ts +7 -6
- 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
- package/public-api.d.ts +3 -0
- package/public-api.d.ts.map +1 -1
|
@@ -14,9 +14,11 @@
|
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
16
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
17
|
-
import { BehaviorSubject, combineLatest, filter, of, Subject, switchMap, take, tap, } from 'rxjs';
|
|
17
|
+
import { BehaviorSubject, combineLatest, filter, of, Subject, Subscription, switchMap, take, tap, } from 'rxjs';
|
|
18
|
+
import { CARBON_THEME, CurrentCarbonTheme } from '@valtimo/components';
|
|
18
19
|
import { map } from 'rxjs/operators';
|
|
19
20
|
import { PluginTranslatePipe } from '../../../../pipes';
|
|
21
|
+
import flatpickr from 'flatpickr';
|
|
20
22
|
import * as i0 from "@angular/core";
|
|
21
23
|
import * as i1 from "@valtimo/components";
|
|
22
24
|
import * as i2 from "@valtimo/document";
|
|
@@ -25,15 +27,17 @@ import * as i4 from "../../../../pipes";
|
|
|
25
27
|
import * as i5 from "@angular/common";
|
|
26
28
|
import * as i6 from "carbon-components-angular";
|
|
27
29
|
import * as i7 from "../../../../pipes/plugin-translate/plugin-translate.pipe";
|
|
30
|
+
import * as i8 from "@ngx-translate/core";
|
|
28
31
|
export class SetZaakStatusConfigurationComponent {
|
|
29
32
|
set pluginId(value) {
|
|
30
33
|
this.pluginId$.next(value);
|
|
31
34
|
}
|
|
32
|
-
constructor(modalService, documentService, zakenApiService, pluginTranslatePipe) {
|
|
35
|
+
constructor(modalService, documentService, zakenApiService, pluginTranslatePipe, cdsThemeService) {
|
|
33
36
|
this.modalService = modalService;
|
|
34
37
|
this.documentService = documentService;
|
|
35
38
|
this.zakenApiService = zakenApiService;
|
|
36
39
|
this.pluginTranslatePipe = pluginTranslatePipe;
|
|
40
|
+
this.cdsThemeService = cdsThemeService;
|
|
37
41
|
this.valid = new EventEmitter();
|
|
38
42
|
this.configuration = new EventEmitter();
|
|
39
43
|
this.caseDefinitionSelectItems$ = new BehaviorSubject(null);
|
|
@@ -85,7 +89,10 @@ export class SetZaakStatusConfigurationComponent {
|
|
|
85
89
|
this.loading$.next(false);
|
|
86
90
|
}));
|
|
87
91
|
this.selectedInputOption$ = new BehaviorSubject('selection');
|
|
92
|
+
this.datumStatusGezetSelectedInputOption$ = new BehaviorSubject('now');
|
|
93
|
+
this.datePickerInvalid$ = new BehaviorSubject(false);
|
|
88
94
|
this.pluginId$ = new BehaviorSubject('');
|
|
95
|
+
this._subscriptions = new Subscription();
|
|
89
96
|
this.inputTypeOptions$ = this.pluginId$.pipe(filter(pluginId => !!pluginId), switchMap(pluginId => combineLatest([
|
|
90
97
|
this.pluginTranslatePipe.transform('selection', pluginId),
|
|
91
98
|
this.pluginTranslatePipe.transform('text', pluginId),
|
|
@@ -93,20 +100,46 @@ export class SetZaakStatusConfigurationComponent {
|
|
|
93
100
|
{ value: 'selection', title: selectionTranslation },
|
|
94
101
|
{ value: 'text', title: textTranslation },
|
|
95
102
|
]));
|
|
103
|
+
this.datePickerInputTypeOptions$ = this.pluginId$.pipe(filter(pluginId => !!pluginId), switchMap(pluginId => combineLatest([
|
|
104
|
+
this.pluginTranslatePipe.transform('now', pluginId),
|
|
105
|
+
this.pluginTranslatePipe.transform('selection', pluginId),
|
|
106
|
+
this.pluginTranslatePipe.transform('text', pluginId),
|
|
107
|
+
])), map(([nowTranslation, selectionTranslation, textTranslation]) => [
|
|
108
|
+
{ value: 'now', title: nowTranslation },
|
|
109
|
+
{ value: 'selection', title: selectionTranslation },
|
|
110
|
+
{ value: 'text', title: textTranslation },
|
|
111
|
+
]));
|
|
112
|
+
this.theme$ = this.cdsThemeService.currentTheme$.pipe(map((theme) => theme === CurrentCarbonTheme.G10 ? CARBON_THEME.WHITE : CARBON_THEME.G100));
|
|
96
113
|
this.formValue$ = new BehaviorSubject(null);
|
|
97
114
|
this.valid$ = new BehaviorSubject(false);
|
|
115
|
+
this.selectedDate = null;
|
|
116
|
+
this.selectedTime = null;
|
|
98
117
|
}
|
|
99
118
|
ngOnInit() {
|
|
100
119
|
this.openSaveSubscription();
|
|
120
|
+
this.prefillToday();
|
|
101
121
|
}
|
|
102
122
|
ngOnDestroy() {
|
|
103
123
|
this.saveSubscription?.unsubscribe();
|
|
124
|
+
this._subscriptions.unsubscribe();
|
|
104
125
|
}
|
|
105
126
|
formValueChange(formValue) {
|
|
106
|
-
this.formValue$.
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
127
|
+
const currentFormValue = this.formValue$.value ?? {};
|
|
128
|
+
const updatedFormValue = {
|
|
129
|
+
...currentFormValue,
|
|
130
|
+
...formValue,
|
|
131
|
+
};
|
|
132
|
+
this.formValue$.next(updatedFormValue);
|
|
133
|
+
this.handleValid(updatedFormValue);
|
|
134
|
+
if (updatedFormValue.inputTypeZaakStatusToggle) {
|
|
135
|
+
this.selectedInputOption$.next(updatedFormValue.inputTypeZaakStatusToggle);
|
|
136
|
+
}
|
|
137
|
+
if (updatedFormValue.inputDatumStatusGezetToggle) {
|
|
138
|
+
this.datumStatusGezetSelectedInputOption$.next(updatedFormValue.inputDatumStatusGezetToggle);
|
|
139
|
+
}
|
|
140
|
+
if (updatedFormValue.inputDatumStatusGezetToggle === 'now') {
|
|
141
|
+
this.selectedDate = null;
|
|
142
|
+
this.selectedTime = null;
|
|
110
143
|
}
|
|
111
144
|
}
|
|
112
145
|
selectCaseDefinition(caseDefinitionId) {
|
|
@@ -120,7 +153,11 @@ export class SetZaakStatusConfigurationComponent {
|
|
|
120
153
|
return false;
|
|
121
154
|
}
|
|
122
155
|
handleValid(formValue) {
|
|
123
|
-
const
|
|
156
|
+
const hasStatusType = !!formValue.statustypeUrl;
|
|
157
|
+
const hasValidDatumStatusGezet = this.isValidDatumStatusGezet(formValue.datumStatusGezet);
|
|
158
|
+
const dateIsNotInFuture = this.isDateNotInFuture(formValue.datumStatusGezet);
|
|
159
|
+
const hasEnteredDateText = this.hasEnteredDateText(formValue.datumStatusGezet);
|
|
160
|
+
const valid = hasStatusType && hasValidDatumStatusGezet && dateIsNotInFuture && hasEnteredDateText;
|
|
124
161
|
this.valid$.next(valid);
|
|
125
162
|
this.valid.emit(valid);
|
|
126
163
|
}
|
|
@@ -130,21 +167,126 @@ export class SetZaakStatusConfigurationComponent {
|
|
|
130
167
|
.pipe(take(1))
|
|
131
168
|
.subscribe(([formValue, valid]) => {
|
|
132
169
|
if (valid) {
|
|
170
|
+
if (formValue.inputDatumStatusGezetToggle == 'now') {
|
|
171
|
+
formValue.datumStatusGezet = null;
|
|
172
|
+
}
|
|
133
173
|
this.configuration.emit({
|
|
134
174
|
statustoelichting: formValue.statustoelichting,
|
|
135
175
|
statustypeUrl: formValue.statustypeUrl,
|
|
176
|
+
datumStatusGezet: formValue.datumStatusGezet,
|
|
136
177
|
});
|
|
137
178
|
}
|
|
138
179
|
});
|
|
139
180
|
});
|
|
140
181
|
}
|
|
141
|
-
|
|
142
|
-
|
|
182
|
+
onDateSelected(event) {
|
|
183
|
+
const date = Array.isArray(event) && event[0];
|
|
184
|
+
if (!date)
|
|
185
|
+
return;
|
|
186
|
+
this.selectedDate = date.toISOString();
|
|
187
|
+
this.updateDatumStatusGezet();
|
|
188
|
+
}
|
|
189
|
+
onTimeSelected(event) {
|
|
190
|
+
this.selectedTime = event;
|
|
191
|
+
this.updateDatumStatusGezet();
|
|
192
|
+
}
|
|
193
|
+
updateDatumStatusGezet() {
|
|
194
|
+
if (!this.selectedDate && !this.selectedTime) {
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
197
|
+
let hoursStr;
|
|
198
|
+
let minutesStr;
|
|
199
|
+
let secondsStr;
|
|
200
|
+
try {
|
|
201
|
+
[hoursStr, minutesStr = '00', secondsStr = '00'] = this.selectedTime.split(':');
|
|
202
|
+
}
|
|
203
|
+
catch (error) {
|
|
204
|
+
[hoursStr, minutesStr = '00', secondsStr = '00'] = ['00', '00'];
|
|
205
|
+
}
|
|
206
|
+
const date = new Date(this.selectedDate);
|
|
207
|
+
const year = date.getFullYear();
|
|
208
|
+
const month = String(date.getMonth() + 1).padStart(2, '0');
|
|
209
|
+
const day = String(date.getDate()).padStart(2, '0');
|
|
210
|
+
const hh = hoursStr.padStart(2, '0');
|
|
211
|
+
const mm = minutesStr.padStart(2, '0');
|
|
212
|
+
const ss = secondsStr.padStart(2, '0');
|
|
213
|
+
const isoWithoutMs = `${year}-${month}-${day}T${hh}:${mm}:${ss}Z`;
|
|
214
|
+
const currentFormValue = this.formValue$.value ?? {};
|
|
215
|
+
const updatedFormValue = {
|
|
216
|
+
...currentFormValue,
|
|
217
|
+
datumStatusGezet: isoWithoutMs,
|
|
218
|
+
};
|
|
219
|
+
this.formValueChange(updatedFormValue);
|
|
220
|
+
}
|
|
221
|
+
prefillToday() {
|
|
222
|
+
this._subscriptions.add(this.prefillConfiguration$.subscribe(config => {
|
|
223
|
+
console.log('Prefilling configuration', config?.datumStatusGezet);
|
|
224
|
+
let baseDate;
|
|
225
|
+
if (config?.datumStatusGezet) {
|
|
226
|
+
try {
|
|
227
|
+
baseDate = flatpickr.formatDate(!!config?.datumStatusGezet ? new Date(config.datumStatusGezet) : new Date(), 'Z');
|
|
228
|
+
this.datumStatusGezetSelectedInputOption$.next('selection');
|
|
229
|
+
}
|
|
230
|
+
catch (error) {
|
|
231
|
+
baseDate = config.datumStatusGezet;
|
|
232
|
+
this.datumStatusGezetSelectedInputOption$.next('text');
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
else {
|
|
236
|
+
baseDate = null;
|
|
237
|
+
this.datumStatusGezetSelectedInputOption$.next('now');
|
|
238
|
+
}
|
|
239
|
+
this.selectedDate = baseDate;
|
|
240
|
+
this.selectedTime = this.formatTime(baseDate);
|
|
241
|
+
}));
|
|
242
|
+
this.updateDatumStatusGezet();
|
|
243
|
+
}
|
|
244
|
+
formatTime(date) {
|
|
245
|
+
const [hours, minutes, seconds] = date.split('T')[1].split(':');
|
|
246
|
+
return `${hours}:${minutes}:${seconds.split('.')[0]}`;
|
|
247
|
+
}
|
|
248
|
+
isValidDatumStatusGezet(value) {
|
|
249
|
+
if (['text', 'now'].includes(this.datumStatusGezetSelectedInputOption$.getValue())) {
|
|
250
|
+
return true;
|
|
251
|
+
}
|
|
252
|
+
if (!value) {
|
|
253
|
+
return false;
|
|
254
|
+
}
|
|
255
|
+
const trimmed = value.trim();
|
|
256
|
+
// Required format: YYYY-MM-DDTHH:mm:ssZ
|
|
257
|
+
const regex = /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}Z$/;
|
|
258
|
+
if (!regex.test(trimmed)) {
|
|
259
|
+
return false;
|
|
260
|
+
}
|
|
261
|
+
const date = new Date(trimmed);
|
|
262
|
+
return !isNaN(date.getTime());
|
|
263
|
+
}
|
|
264
|
+
isDateNotInFuture(value) {
|
|
265
|
+
if (['text', 'now'].includes(this.datumStatusGezetSelectedInputOption$.getValue())) {
|
|
266
|
+
return true;
|
|
267
|
+
}
|
|
268
|
+
if (!value) {
|
|
269
|
+
return false;
|
|
270
|
+
}
|
|
271
|
+
const date = new Date(value);
|
|
272
|
+
const now = new Date();
|
|
273
|
+
const isDateNotInFuture = date.getTime() <= now.getTime();
|
|
274
|
+
this.datePickerInvalid$.next(!isDateNotInFuture);
|
|
275
|
+
return isDateNotInFuture;
|
|
276
|
+
}
|
|
277
|
+
hasEnteredDateText(value) {
|
|
278
|
+
if (this.datumStatusGezetSelectedInputOption$.getValue() !== 'text') {
|
|
279
|
+
return true;
|
|
280
|
+
}
|
|
281
|
+
return !value === false;
|
|
282
|
+
}
|
|
283
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SetZaakStatusConfigurationComponent, deps: [{ token: i1.ModalService }, { token: i2.DocumentService }, { token: i3.ZakenApiService }, { token: i4.PluginTranslatePipe }, { token: i1.CdsThemeService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
284
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SetZaakStatusConfigurationComponent, selector: "valtimo-set-zaak-status-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<v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"{\n disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n pluginId: pluginId$ | async,\n selectedInputOption: selectedInputOption$ | async,\n datumStatusGezetSelectedInputOption: datumStatusGezetSelectedInputOption$ | async,\n loading: loading$ | async,\n caseDefinitionItems: caseDefinitionSelectItems$ | async,\n statusTypeItems: statusTypeSelectItems$ | async,\n selectedCaseDefinitionId: selectedCaseDefinitionId$ | async,\n datePickerInvalid: datePickerInvalid$ | async\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <v-input\n name=\"statustoelichting\"\n [title]=\"'statustoelichting' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.statustoelichting\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [tooltip]=\"'statustoelichtingTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n [placeholder]=\"'statustoelichting' | pluginTranslate: obs.pluginId | async\"\n >\n </v-input>\n\n <v-radio\n name=\"inputDatumStatusGezetToggle\"\n [disabled]=\"obs.disabled\"\n [title]=\"'inputDatumStatusGezetToggle' | pluginTranslate: obs.pluginId | async\"\n [radioValues]=\"datePickerInputTypeOptions$ | async\"\n [defaultValue]=\"obs.datumStatusGezetSelectedInputOption\"\n [margin]=\"true\"\n ></v-radio>\n\n <div class=\"date-time-row\" *ngIf=\"obs.datumStatusGezetSelectedInputOption === 'selection'\">\n <cds-date-picker\n [attr.data-carbon-theme]=\"theme$ | async\"\n [label]=\"'logging.search.afterTimestamp' | translate\"\n placeholder=\"DD-MM-YYYY\"\n [dateFormat]=\"'d-m-Y'\"\n [value]=\"[selectedDate]\"\n [invalid]=\"obs.datePickerInvalid\"\n [invalidText]=\"'datumStatusGezetInvalidText' | pluginTranslate: obs.pluginId | async\"\n (valueChange)=\"onDateSelected($event)\"\n ></cds-date-picker>\n\n <cds-timepicker\n class=\"timepicker\"\n [attr.data-carbon-theme]=\"theme$ | async\"\n [value]=\"selectedTime\"\n [invalid]=\"obs.datePickerInvalid\"\n (valueChange)=\"onTimeSelected($event)\"\n ></cds-timepicker>\n </div>\n\n <v-input\n *ngIf=\"obs.datumStatusGezetSelectedInputOption === 'text'\"\n name=\"datumStatusGezet\"\n [title]=\"'datumStatusGezet' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.datumStatusGezet\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'datumStatusGezetTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n ></v-input>\n\n <v-radio\n name=\"inputTypeZaakStatusToggle\"\n [disabled]=\"obs.disabled\"\n [title]=\"'inputTypeZaakStatusToggle' | 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=\"statustypeUrl\"\n [title]=\"'statustypeUrl' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.statustypeUrl\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'statustypeUrlTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n <v-select\n [items]=\"obs.caseDefinitionItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"caseDefinition\"\n [title]=\"'caseDefinition' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n !obs.caseDefinitionItems ||\n oneSelectItem(obs.caseDefinitionItems)\n \"\n [required]=\"true\"\n [loading]=\"!obs.caseDefinitionItems\"\n [tooltip]=\"'caseDefinitionTooltip' | pluginTranslate: obs.pluginId | async\"\n (selectedChange)=\"selectCaseDefinition($event)\"\n [defaultSelectionId]=\"obs?.selectedCaseDefinitionId\"\n ></v-select>\n <v-select\n [items]=\"obs.statusTypeItems && obs.statusTypeItems[obs.selectedCaseDefinitionId]\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"statustypeUrl\"\n [title]=\"'statustypeUrlSelect' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n !obs.statusTypeItems ||\n !obs.statusTypeItems[obs.selectedCaseDefinitionId]\n \"\n [defaultSelectionId]=\"obs.prefill?.statustypeUrl\"\n [required]=\"true\"\n [loading]=\"!obs.statusTypeItems\"\n [tooltip]=\"'statustypeUrlSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n [clearSelectionSubject$]=\"clearStatusSelection$\"\n ></v-select>\n </ng-container>\n </ng-container>\n</v-form>\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}.date-time-row{display:flex;align-items:flex-start;gap:16px;margin-bottom:34px}.timepicker{margin-top:24px!important;height:48px!important}.date-time-row cds-date-picker,.date-time-row cds-timepicker{display:block}\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: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i1.FormComponent, selector: "v-form", inputs: ["className"], outputs: ["valueChange"] }, { kind: "component", type: i1.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: i1.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: i1.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: i6.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "component", type: i6.DatePicker, selector: "cds-date-picker, ibm-date-picker", inputs: ["range", "dateFormat", "language", "label", "helperText", "rangeHelperText", "rangeLabel", "placeholder", "ariaLabel", "inputPattern", "id", "value", "theme", "disabled", "invalid", "invalidText", "warn", "warnText", "size", "rangeInvalid", "rangeInvalidText", "rangeWarn", "rangeWarnText", "skeleton", "plugins", "flatpickrOptions"], outputs: ["valueChange", "onClose"] }, { kind: "component", type: i6.TimePicker, selector: "cds-timepicker, ibm-timepicker", inputs: ["invalid", "invalidText", "label", "hideLabel", "placeholder", "pattern", "id", "disabled", "value", "maxLength", "skeleton", "theme", "size"], outputs: ["valueChange"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.PluginTranslatePipe, name: "pluginTranslate" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
|
|
143
285
|
}
|
|
144
286
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SetZaakStatusConfigurationComponent, decorators: [{
|
|
145
287
|
type: Component,
|
|
146
|
-
args: [{ selector: 'valtimo-set-zaak-status-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<v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"{\n disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n pluginId: pluginId$ | async,\n selectedInputOption: selectedInputOption$ | async,\n loading: loading$ | async,\n caseDefinitionItems: caseDefinitionSelectItems$ | async,\n statusTypeItems: statusTypeSelectItems$ | async,\n selectedCaseDefinitionId: selectedCaseDefinitionId$ | async,\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <v-input\n name=\"statustoelichting\"\n [title]=\"'statustoelichting' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.statustoelichting\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [tooltip]=\"'statustoelichtingTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <v-radio\n name=\"inputTypeZaakStatusToggle\"\n [disabled]=\"obs.disabled\"\n [title]=\"'inputTypeZaakStatusToggle' | 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=\"statustypeUrl\"\n [title]=\"'statustypeUrl' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.statustypeUrl\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'statustypeUrlTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n <v-select\n [items]=\"obs.caseDefinitionItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"caseDefinition\"\n [title]=\"'caseDefinition' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n !obs.caseDefinitionItems ||\n oneSelectItem(obs.caseDefinitionItems)\n \"\n [required]=\"true\"\n [loading]=\"!obs.caseDefinitionItems\"\n [tooltip]=\"'caseDefinitionTooltip' | pluginTranslate: obs.pluginId | async\"\n (selectedChange)=\"selectCaseDefinition($event)\"\n [defaultSelectionId]=\"obs?.selectedCaseDefinitionId\"\n ></v-select>\n <v-select\n [items]=\"obs.statusTypeItems && obs.statusTypeItems[obs.selectedCaseDefinitionId]\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"statustypeUrl\"\n [title]=\"'statustypeUrlSelect' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n !obs.statusTypeItems ||\n !obs.statusTypeItems[obs.selectedCaseDefinitionId]\n \"\n [defaultSelectionId]=\"obs.prefill?.statustypeUrl\"\n [required]=\"true\"\n [loading]=\"!obs.statusTypeItems\"\n [tooltip]=\"'statustypeUrlSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n [clearSelectionSubject$]=\"clearStatusSelection$\"\n ></v-select>\n </ng-container>\n </ng-container>\n</v-form>\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"] }]
|
|
147
|
-
}], ctorParameters: () => [{ type: i1.ModalService }, { type: i2.DocumentService }, { type: i3.ZakenApiService }, { type: i4.PluginTranslatePipe }], propDecorators: { save$: [{
|
|
288
|
+
args: [{ selector: 'valtimo-set-zaak-status-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<v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"{\n disabled: disabled$ | async,\n prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n pluginId: pluginId$ | async,\n selectedInputOption: selectedInputOption$ | async,\n datumStatusGezetSelectedInputOption: datumStatusGezetSelectedInputOption$ | async,\n loading: loading$ | async,\n caseDefinitionItems: caseDefinitionSelectItems$ | async,\n statusTypeItems: statusTypeSelectItems$ | async,\n selectedCaseDefinitionId: selectedCaseDefinitionId$ | async,\n datePickerInvalid: datePickerInvalid$ | async\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <v-input\n name=\"statustoelichting\"\n [title]=\"'statustoelichting' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.statustoelichting\"\n [disabled]=\"obs.disabled\"\n [required]=\"false\"\n [tooltip]=\"'statustoelichtingTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n [placeholder]=\"'statustoelichting' | pluginTranslate: obs.pluginId | async\"\n >\n </v-input>\n\n <v-radio\n name=\"inputDatumStatusGezetToggle\"\n [disabled]=\"obs.disabled\"\n [title]=\"'inputDatumStatusGezetToggle' | pluginTranslate: obs.pluginId | async\"\n [radioValues]=\"datePickerInputTypeOptions$ | async\"\n [defaultValue]=\"obs.datumStatusGezetSelectedInputOption\"\n [margin]=\"true\"\n ></v-radio>\n\n <div class=\"date-time-row\" *ngIf=\"obs.datumStatusGezetSelectedInputOption === 'selection'\">\n <cds-date-picker\n [attr.data-carbon-theme]=\"theme$ | async\"\n [label]=\"'logging.search.afterTimestamp' | translate\"\n placeholder=\"DD-MM-YYYY\"\n [dateFormat]=\"'d-m-Y'\"\n [value]=\"[selectedDate]\"\n [invalid]=\"obs.datePickerInvalid\"\n [invalidText]=\"'datumStatusGezetInvalidText' | pluginTranslate: obs.pluginId | async\"\n (valueChange)=\"onDateSelected($event)\"\n ></cds-date-picker>\n\n <cds-timepicker\n class=\"timepicker\"\n [attr.data-carbon-theme]=\"theme$ | async\"\n [value]=\"selectedTime\"\n [invalid]=\"obs.datePickerInvalid\"\n (valueChange)=\"onTimeSelected($event)\"\n ></cds-timepicker>\n </div>\n\n <v-input\n *ngIf=\"obs.datumStatusGezetSelectedInputOption === 'text'\"\n name=\"datumStatusGezet\"\n [title]=\"'datumStatusGezet' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.datumStatusGezet\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'datumStatusGezetTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n ></v-input>\n\n <v-radio\n name=\"inputTypeZaakStatusToggle\"\n [disabled]=\"obs.disabled\"\n [title]=\"'inputTypeZaakStatusToggle' | 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=\"statustypeUrl\"\n [title]=\"'statustypeUrl' | pluginTranslate: obs.pluginId | async\"\n [margin]=\"true\"\n [defaultValue]=\"obs.prefill?.statustypeUrl\"\n [disabled]=\"obs.disabled\"\n [required]=\"true\"\n [trim]=\"true\"\n [tooltip]=\"'statustypeUrlTooltip' | pluginTranslate: obs.pluginId | async\"\n [fullWidth]=\"true\"\n >\n </v-input>\n <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n <v-select\n [items]=\"obs.caseDefinitionItems\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"caseDefinition\"\n [title]=\"'caseDefinition' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n !obs.caseDefinitionItems ||\n oneSelectItem(obs.caseDefinitionItems)\n \"\n [required]=\"true\"\n [loading]=\"!obs.caseDefinitionItems\"\n [tooltip]=\"'caseDefinitionTooltip' | pluginTranslate: obs.pluginId | async\"\n (selectedChange)=\"selectCaseDefinition($event)\"\n [defaultSelectionId]=\"obs?.selectedCaseDefinitionId\"\n ></v-select>\n <v-select\n [items]=\"obs.statusTypeItems && obs.statusTypeItems[obs.selectedCaseDefinitionId]\"\n [margin]=\"true\"\n [widthInPx]=\"350\"\n name=\"statustypeUrl\"\n [title]=\"'statustypeUrlSelect' | pluginTranslate: obs.pluginId | async\"\n [disabled]=\"\n obs.disabled ||\n obs.selectedInputOption === 'text' ||\n !obs.statusTypeItems ||\n !obs.statusTypeItems[obs.selectedCaseDefinitionId]\n \"\n [defaultSelectionId]=\"obs.prefill?.statustypeUrl\"\n [required]=\"true\"\n [loading]=\"!obs.statusTypeItems\"\n [tooltip]=\"'statustypeUrlSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n [clearSelectionSubject$]=\"clearStatusSelection$\"\n ></v-select>\n </ng-container>\n </ng-container>\n</v-form>\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}.date-time-row{display:flex;align-items:flex-start;gap:16px;margin-bottom:34px}.timepicker{margin-top:24px!important;height:48px!important}.date-time-row cds-date-picker,.date-time-row cds-timepicker{display:block}\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"] }]
|
|
289
|
+
}], ctorParameters: () => [{ type: i1.ModalService }, { type: i2.DocumentService }, { type: i3.ZakenApiService }, { type: i4.PluginTranslatePipe }, { type: i1.CdsThemeService }], propDecorators: { save$: [{
|
|
148
290
|
type: Input
|
|
149
291
|
}], disabled$: [{
|
|
150
292
|
type: Input
|
|
@@ -157,4 +299,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
157
299
|
}], configuration: [{
|
|
158
300
|
type: Output
|
|
159
301
|
}] } });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"set-zaak-status-configuration.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/set-zaak-status/set-zaak-status-configuration.component.ts","../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/set-zaak-status/set-zaak-status-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  Observable,\n  of,\n  Subject,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {InputOption, SetZaakStatusConfig} from '../../models';\nimport {ModalService, RadioValue, SelectItem} from '@valtimo/components';\nimport {DocumentService} from '@valtimo/document';\nimport {map} from 'rxjs/operators';\nimport {ZakenApiService} from '../../services';\nimport {PluginTranslatePipe} from '../../../../pipes';\n\n@Component({\n  selector: 'valtimo-set-zaak-status-configuration',\n  templateUrl: './set-zaak-status-configuration.component.html',\n  styleUrls: ['./set-zaak-status-configuration.component.scss'],\n  providers: [PluginTranslatePipe],\n})\nexport class SetZaakStatusConfigurationComponent\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<SetZaakStatusConfig>;\n  @Output() valid: EventEmitter<boolean> = new EventEmitter<boolean>();\n  @Output() configuration: EventEmitter<SetZaakStatusConfig> =\n    new EventEmitter<SetZaakStatusConfig>();\n\n  readonly caseDefinitionSelectItems$ = new BehaviorSubject<Array<SelectItem>>(null);\n  readonly selectedCaseDefinitionId$ = new BehaviorSubject<string>('');\n  readonly clearStatusSelection$ = new Subject<void>();\n\n  readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  readonly statusTypeSelectItems$: Observable<{[caseDefinitionId: string]: Array<SelectItem>}> =\n    this.modalService.modalData$.pipe(\n      switchMap(params =>\n        this.documentService.findProcessDocumentDefinitionsByProcessDefinitionKey(\n          params?.processDefinitionKey\n        )\n      ),\n      tap(processDocumentDefinitions => {\n        const caseDefSelectItems = processDocumentDefinitions.map(processDocDef => ({\n          text: processDocDef.id.documentDefinitionId.name,\n          id: processDocDef.id.documentDefinitionId.name,\n        }));\n\n        this.caseDefinitionSelectItems$.next(caseDefSelectItems);\n\n        if (this.oneSelectItem(caseDefSelectItems)) {\n          this.selectedCaseDefinitionId$.next(caseDefSelectItems[0].id);\n        }\n      }),\n      switchMap(processDocumentDefinitions =>\n        combineLatest([\n          of(processDocumentDefinitions.map(processDoc => processDoc.id.documentDefinitionId.name)),\n          ...processDocumentDefinitions.map(processDocDef =>\n            this.zakenApiService.getStatusTypesByCaseDefinition(\n              processDocDef.id.documentDefinitionId.name\n            )\n          ),\n        ])\n      ),\n      map(res => {\n        const caseDefinitionIds = res[0];\n        const statusTypes = res.filter((curr, index) => index !== 0);\n        const selectObject = {};\n\n        caseDefinitionIds.forEach((caseDefinitionId, index) => {\n          selectObject[caseDefinitionId] = statusTypes[index].map(statusType => ({\n            id: statusType.url,\n            text: statusType.name,\n          }));\n        });\n\n        return selectObject;\n      }),\n      tap(selectObject => {\n        this.prefillConfiguration$.pipe(take(1)).subscribe(prefillConfig => {\n          const statusTypeUrl = prefillConfig?.statustypeUrl;\n\n          if (statusTypeUrl) {\n            let selectedCaseDefinitionId!: string;\n\n            Object.keys(selectObject).forEach(caseDefinitionId => {\n              if (selectObject[caseDefinitionId].find(item => item.id === statusTypeUrl)) {\n                selectedCaseDefinitionId = caseDefinitionId;\n              }\n\n              if (selectedCaseDefinitionId) {\n                this.selectedCaseDefinitionId$.next(selectedCaseDefinitionId);\n              } else {\n                this.selectedInputOption$.next('text');\n              }\n            });\n          }\n        });\n      }),\n      tap(() => {\n        this.loading$.next(false);\n      })\n    );\n\n  readonly selectedInputOption$ = new BehaviorSubject<InputOption>('selection');\n\n  readonly pluginId$ = new BehaviorSubject<string>('');\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<SetZaakStatusConfig | null>(null);\n  private readonly valid$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private readonly modalService: ModalService,\n    private readonly documentService: DocumentService,\n    private readonly zakenApiService: ZakenApiService,\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: SetZaakStatusConfig): void {\n    this.formValue$.next(formValue);\n    this.handleValid(formValue);\n\n    if (formValue.inputTypeZaakStatusToggle) {\n      this.selectedInputOption$.next(formValue.inputTypeZaakStatusToggle);\n    }\n  }\n\n  selectCaseDefinition(caseDefinitionId: string): void {\n    this.selectedCaseDefinitionId$.next(caseDefinitionId);\n    this.clearStatusSelection$.next();\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  private handleValid(formValue: SetZaakStatusConfig): void {\n    const valid = !!formValue.statustypeUrl;\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              statustoelichting: formValue.statustoelichting,\n              statustypeUrl: formValue.statustypeUrl,\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<v-form\n  (valueChange)=\"formValueChange($event)\"\n  *ngIf=\"{\n    disabled: disabled$ | async,\n    prefill: prefillConfiguration$ ? (prefillConfiguration$ | async) : null,\n    pluginId: pluginId$ | async,\n    selectedInputOption: selectedInputOption$ | async,\n    loading: loading$ | async,\n    caseDefinitionItems: caseDefinitionSelectItems$ | async,\n    statusTypeItems: statusTypeSelectItems$ | async,\n    selectedCaseDefinitionId: selectedCaseDefinitionId$ | async,\n  } as obs\"\n>\n  <ng-container *ngIf=\"obs.loading === false; else loading\">\n    <v-input\n      name=\"statustoelichting\"\n      [title]=\"'statustoelichting' | pluginTranslate: obs.pluginId | async\"\n      [margin]=\"true\"\n      [defaultValue]=\"obs.prefill?.statustoelichting\"\n      [disabled]=\"obs.disabled\"\n      [required]=\"false\"\n      [tooltip]=\"'statustoelichtingTooltip' | pluginTranslate: obs.pluginId | async\"\n      [fullWidth]=\"true\"\n    >\n    </v-input>\n    <v-radio\n      name=\"inputTypeZaakStatusToggle\"\n      [disabled]=\"obs.disabled\"\n      [title]=\"'inputTypeZaakStatusToggle' | 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=\"statustypeUrl\"\n      [title]=\"'statustypeUrl' | pluginTranslate: obs.pluginId | async\"\n      [margin]=\"true\"\n      [defaultValue]=\"obs.prefill?.statustypeUrl\"\n      [disabled]=\"obs.disabled\"\n      [required]=\"true\"\n      [trim]=\"true\"\n      [tooltip]=\"'statustypeUrlTooltip' | pluginTranslate: obs.pluginId | async\"\n      [fullWidth]=\"true\"\n    >\n    </v-input>\n    <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n      <v-select\n        [items]=\"obs.caseDefinitionItems\"\n        [margin]=\"true\"\n        [widthInPx]=\"350\"\n        name=\"caseDefinition\"\n        [title]=\"'caseDefinition' | pluginTranslate: obs.pluginId | async\"\n        [disabled]=\"\n          obs.disabled ||\n          obs.selectedInputOption === 'text' ||\n          !obs.caseDefinitionItems ||\n          oneSelectItem(obs.caseDefinitionItems)\n        \"\n        [required]=\"true\"\n        [loading]=\"!obs.caseDefinitionItems\"\n        [tooltip]=\"'caseDefinitionTooltip' | pluginTranslate: obs.pluginId | async\"\n        (selectedChange)=\"selectCaseDefinition($event)\"\n        [defaultSelectionId]=\"obs?.selectedCaseDefinitionId\"\n      ></v-select>\n      <v-select\n        [items]=\"obs.statusTypeItems && obs.statusTypeItems[obs.selectedCaseDefinitionId]\"\n        [margin]=\"true\"\n        [widthInPx]=\"350\"\n        name=\"statustypeUrl\"\n        [title]=\"'statustypeUrlSelect' | pluginTranslate: obs.pluginId | async\"\n        [disabled]=\"\n          obs.disabled ||\n          obs.selectedInputOption === 'text' ||\n          !obs.statusTypeItems ||\n          !obs.statusTypeItems[obs.selectedCaseDefinitionId]\n        \"\n        [defaultSelectionId]=\"obs.prefill?.statustypeUrl\"\n        [required]=\"true\"\n        [loading]=\"!obs.statusTypeItems\"\n        [tooltip]=\"'statustypeUrlSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n        [clearSelectionSubject$]=\"clearStatusSelection$\"\n      ></v-select>\n    </ng-container>\n  </ng-container>\n</v-form>\n\n<ng-template #loading>\n  <div class=\"loading-container\">\n    <cds-loading></cds-loading>\n  </div>\n</ng-template>\n"]}
|
|
302
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"set-zaak-status-configuration.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/set-zaak-status/set-zaak-status-configuration.component.ts","../../../../../../../../../projects/valtimo/plugin/src/lib/plugins/zaken-api/components/set-zaak-status/set-zaak-status-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  Observable,\n  of,\n  Subject,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {InputOption, SetZaakStatusConfig} from '../../models';\nimport {CARBON_THEME, CdsThemeService, CurrentCarbonTheme, ModalService, RadioValue, SelectItem} from '@valtimo/components';\nimport {DocumentService} from '@valtimo/document';\nimport {map} from 'rxjs/operators';\nimport {ZakenApiService} from '../../services';\nimport {PluginTranslatePipe} from '../../../../pipes';\nimport flatpickr from 'flatpickr';\n\n@Component({\n  selector: 'valtimo-set-zaak-status-configuration',\n  templateUrl: './set-zaak-status-configuration.component.html',\n  styleUrls: ['./set-zaak-status-configuration.component.scss'],\n  providers: [PluginTranslatePipe],\n})\nexport class SetZaakStatusConfigurationComponent\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<SetZaakStatusConfig>;\n  @Output() valid: EventEmitter<boolean> = new EventEmitter<boolean>();\n  @Output() configuration: EventEmitter<SetZaakStatusConfig> =\n    new EventEmitter<SetZaakStatusConfig>();\n\n  readonly caseDefinitionSelectItems$ = new BehaviorSubject<Array<SelectItem>>(null);\n  readonly selectedCaseDefinitionId$ = new BehaviorSubject<string>('');\n  readonly clearStatusSelection$ = new Subject<void>();\n\n  readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  readonly statusTypeSelectItems$: Observable<{[caseDefinitionId: string]: Array<SelectItem>}> =\n    this.modalService.modalData$.pipe(\n      switchMap(params =>\n        this.documentService.findProcessDocumentDefinitionsByProcessDefinitionKey(\n          params?.processDefinitionKey\n        )\n      ),\n      tap(processDocumentDefinitions => {\n        const caseDefSelectItems = processDocumentDefinitions.map(processDocDef => ({\n          text: processDocDef.id.documentDefinitionId.name,\n          id: processDocDef.id.documentDefinitionId.name,\n        }));\n\n        this.caseDefinitionSelectItems$.next(caseDefSelectItems);\n\n        if (this.oneSelectItem(caseDefSelectItems)) {\n          this.selectedCaseDefinitionId$.next(caseDefSelectItems[0].id);\n        }\n      }),\n      switchMap(processDocumentDefinitions =>\n        combineLatest([\n          of(processDocumentDefinitions.map(processDoc => processDoc.id.documentDefinitionId.name)),\n          ...processDocumentDefinitions.map(processDocDef =>\n            this.zakenApiService.getStatusTypesByCaseDefinition(\n              processDocDef.id.documentDefinitionId.name\n            )\n          ),\n        ])\n      ),\n      map(res => {\n        const caseDefinitionIds = res[0];\n        const statusTypes = res.filter((curr, index) => index !== 0);\n        const selectObject = {};\n\n        caseDefinitionIds.forEach((caseDefinitionId, index) => {\n          selectObject[caseDefinitionId] = statusTypes[index].map(statusType => ({\n            id: statusType.url,\n            text: statusType.name,\n          }));\n        });\n\n        return selectObject;\n      }),\n      tap(selectObject => {\n        this.prefillConfiguration$.pipe(take(1)).subscribe(prefillConfig => {\n          const statusTypeUrl = prefillConfig?.statustypeUrl;\n\n          if (statusTypeUrl) {\n            let selectedCaseDefinitionId!: string;\n\n            Object.keys(selectObject).forEach(caseDefinitionId => {\n              if (selectObject[caseDefinitionId].find(item => item.id === statusTypeUrl)) {\n                selectedCaseDefinitionId = caseDefinitionId;\n              }\n\n              if (selectedCaseDefinitionId) {\n                this.selectedCaseDefinitionId$.next(selectedCaseDefinitionId);\n              } else {\n                this.selectedInputOption$.next('text');\n              }\n            });\n          }\n        });\n      }),\n      tap(() => {\n        this.loading$.next(false);\n      })\n    );\n\n  readonly selectedInputOption$ = new BehaviorSubject<InputOption>('selection');\n  readonly datumStatusGezetSelectedInputOption$ = new BehaviorSubject<string>('now');\n  readonly datePickerInvalid$ = new BehaviorSubject<boolean>(false);\n\n  readonly pluginId$ = new BehaviorSubject<string>('');\n  private readonly _subscriptions = new Subscription();\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  readonly datePickerInputTypeOptions$: Observable<Array<RadioValue>> = this.pluginId$.pipe(\n    filter(pluginId => !!pluginId),\n    switchMap(pluginId =>\n      combineLatest([\n        this.pluginTranslatePipe.transform('now', pluginId),\n        this.pluginTranslatePipe.transform('selection', pluginId),\n        this.pluginTranslatePipe.transform('text', pluginId),\n      ])\n    ),\n    map(([nowTranslation, selectionTranslation, textTranslation]) => [\n      {value: 'now', title: nowTranslation},\n      {value: 'selection', title: selectionTranslation},\n      {value: 'text', title: textTranslation},\n    ])\n  );\n\n  public readonly theme$: Observable<CARBON_THEME> = this.cdsThemeService.currentTheme$.pipe(\n    map((theme: CurrentCarbonTheme) =>\n      theme === CurrentCarbonTheme.G10 ? CARBON_THEME.WHITE : CARBON_THEME.G100\n    )\n  );\n\n  private saveSubscription!: Subscription;\n\n  private readonly formValue$ = new BehaviorSubject<SetZaakStatusConfig | null>(null);\n  private readonly valid$ = new BehaviorSubject<boolean>(false);\n\n  public selectedDate: string | null = null;\n  public selectedTime: string | null = null;\n\n  constructor(\n    private readonly modalService: ModalService,\n    private readonly documentService: DocumentService,\n    private readonly zakenApiService: ZakenApiService,\n    private readonly pluginTranslatePipe: PluginTranslatePipe,\n    private readonly cdsThemeService: CdsThemeService\n  ) {}\n\n  public ngOnInit(): void {\n    this.openSaveSubscription();\n    this.prefillToday();\n  }\n\n  public ngOnDestroy() {\n    this.saveSubscription?.unsubscribe();\n    this._subscriptions.unsubscribe();\n  }\n\n  formValueChange(formValue: SetZaakStatusConfig): void {\n    const currentFormValue = this.formValue$.value ?? ({} as SetZaakStatusConfig);\n    const updatedFormValue: SetZaakStatusConfig = {\n      ...currentFormValue,\n      ...formValue,\n    };\n\n    this.formValue$.next(updatedFormValue);\n    this.handleValid(updatedFormValue);\n    if (updatedFormValue.inputTypeZaakStatusToggle) {\n      this.selectedInputOption$.next(updatedFormValue.inputTypeZaakStatusToggle);\n    }\n    if (updatedFormValue.inputDatumStatusGezetToggle) {\n      this.datumStatusGezetSelectedInputOption$.next(updatedFormValue.inputDatumStatusGezetToggle);\n    }\n    if (updatedFormValue.inputDatumStatusGezetToggle === 'now') {\n      this.selectedDate = null;\n      this.selectedTime = null;\n    }\n  }\n\n  selectCaseDefinition(caseDefinitionId: string): void {\n    this.selectedCaseDefinitionId$.next(caseDefinitionId);\n    this.clearStatusSelection$.next();\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  private handleValid(formValue: SetZaakStatusConfig): void {\n    const hasStatusType = !!formValue.statustypeUrl;\n    const hasValidDatumStatusGezet = this.isValidDatumStatusGezet(formValue.datumStatusGezet);\n    const dateIsNotInFuture = this.isDateNotInFuture(formValue.datumStatusGezet);\n    const hasEnteredDateText = this.hasEnteredDateText(formValue.datumStatusGezet);\n\n    const valid = hasStatusType && hasValidDatumStatusGezet && dateIsNotInFuture && hasEnteredDateText;\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            if (formValue.inputDatumStatusGezetToggle == 'now') {\n              formValue.datumStatusGezet = null;\n            }\n            this.configuration.emit({\n              statustoelichting: formValue.statustoelichting,\n              statustypeUrl: formValue.statustypeUrl,\n              datumStatusGezet: formValue.datumStatusGezet,\n            });\n          }\n        });\n    });\n  }\n\n  public onDateSelected(event: Date[]): void {\n    const date = Array.isArray(event) && event[0];\n    if (!date) return;\n    this.selectedDate = date.toISOString();\n    this.updateDatumStatusGezet();\n  }\n\n  public onTimeSelected(event: string): void {\n    this.selectedTime = event;\n    this.updateDatumStatusGezet();\n  }\n\n  private updateDatumStatusGezet(): void {\n    if (!this.selectedDate && !this.selectedTime) {\n      return;\n    }\n\n    let hoursStr;\n    let minutesStr;\n    let secondsStr;\n    try {\n      [hoursStr, minutesStr = '00', secondsStr = '00'] = this.selectedTime.split(':');\n    } catch (error) {\n      [hoursStr, minutesStr = '00', secondsStr = '00'] = ['00', '00'];\n    }\n    const date = new Date(this.selectedDate);\n\n    const year = date.getFullYear();\n    const month = String(date.getMonth() + 1).padStart(2, '0');\n    const day = String(date.getDate()).padStart(2, '0');\n    const hh = hoursStr.padStart(2, '0');\n    const mm = minutesStr.padStart(2, '0');\n    const ss = secondsStr.padStart(2, '0');\n\n    const isoWithoutMs = `${year}-${month}-${day}T${hh}:${mm}:${ss}Z`;\n\n    const currentFormValue = this.formValue$.value ?? ({} as SetZaakStatusConfig);\n    const updatedFormValue: SetZaakStatusConfig = {\n      ...currentFormValue,\n      datumStatusGezet: isoWithoutMs,\n    };\n\n    this.formValueChange(updatedFormValue);\n  }\n\n  private prefillToday(): void {\n    this._subscriptions.add(\n      this.prefillConfiguration$.subscribe(config => {\n        console.log('Prefilling configuration', config?.datumStatusGezet);\n        let baseDate;\n\n        if (config?.datumStatusGezet) {\n          try {\n            baseDate = flatpickr.formatDate(\n              !!config?.datumStatusGezet ? new Date(config!.datumStatusGezet) : new Date(),\n              'Z'\n            );\n            this.datumStatusGezetSelectedInputOption$.next('selection');\n          } catch (error) {\n            baseDate = config.datumStatusGezet;\n            this.datumStatusGezetSelectedInputOption$.next('text');\n          }\n        } else {\n          baseDate = null;\n          this.datumStatusGezetSelectedInputOption$.next('now');\n        }\n\n        this.selectedDate = baseDate;\n        this.selectedTime = this.formatTime(baseDate);\n      })\n    );\n\n    this.updateDatumStatusGezet();\n  }\n\n  private formatTime(date: string): string {\n    const [hours, minutes, seconds] = date.split('T')[1].split(':');\n    return `${hours}:${minutes}:${seconds.split('.')[0]}`;\n  }\n\n  private isValidDatumStatusGezet(value: string | null | undefined): boolean {\n    if (['text', 'now'].includes(this.datumStatusGezetSelectedInputOption$.getValue())) {\n      return true;\n    }\n\n    if (!value) {\n      return false;\n    }\n\n    const trimmed = value.trim();\n\n    // Required format: YYYY-MM-DDTHH:mm:ssZ\n    const regex = /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}Z$/;\n\n    if (!regex.test(trimmed)) {\n      return false;\n    }\n\n    const date = new Date(trimmed);\n    return !isNaN(date.getTime());\n  }\n\n  private isDateNotInFuture(value: string | null | undefined): boolean {\n    if (['text', 'now'].includes(this.datumStatusGezetSelectedInputOption$.getValue())) {\n      return true;\n    }\n\n    if (!value) {\n      return false;\n    }\n\n    const date = new Date(value);\n    const now = new Date();\n    const isDateNotInFuture = date.getTime() <= now.getTime();\n\n    this.datePickerInvalid$.next(!isDateNotInFuture);\n\n    return isDateNotInFuture;\n  }\n\n  private hasEnteredDateText(value: string | null | undefined): boolean {\n    if (this.datumStatusGezetSelectedInputOption$.getValue() !== 'text') {\n      return true;\n    }\n\n    return !value === false;\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    pluginId: pluginId$ | async,\n    selectedInputOption: selectedInputOption$ | async,\n    datumStatusGezetSelectedInputOption: datumStatusGezetSelectedInputOption$ | async,\n    loading: loading$ | async,\n    caseDefinitionItems: caseDefinitionSelectItems$ | async,\n    statusTypeItems: statusTypeSelectItems$ | async,\n    selectedCaseDefinitionId: selectedCaseDefinitionId$ | async,\n    datePickerInvalid: datePickerInvalid$ | async\n  } as obs\"\n>\n  <ng-container *ngIf=\"obs.loading === false; else loading\">\n    <v-input\n      name=\"statustoelichting\"\n      [title]=\"'statustoelichting' | pluginTranslate: obs.pluginId | async\"\n      [margin]=\"true\"\n      [defaultValue]=\"obs.prefill?.statustoelichting\"\n      [disabled]=\"obs.disabled\"\n      [required]=\"false\"\n      [tooltip]=\"'statustoelichtingTooltip' | pluginTranslate: obs.pluginId | async\"\n      [fullWidth]=\"true\"\n      [placeholder]=\"'statustoelichting' | pluginTranslate: obs.pluginId | async\"\n    >\n    </v-input>\n\n    <v-radio\n      name=\"inputDatumStatusGezetToggle\"\n      [disabled]=\"obs.disabled\"\n      [title]=\"'inputDatumStatusGezetToggle' | pluginTranslate: obs.pluginId | async\"\n      [radioValues]=\"datePickerInputTypeOptions$ | async\"\n      [defaultValue]=\"obs.datumStatusGezetSelectedInputOption\"\n      [margin]=\"true\"\n    ></v-radio>\n\n    <div class=\"date-time-row\" *ngIf=\"obs.datumStatusGezetSelectedInputOption === 'selection'\">\n      <cds-date-picker\n        [attr.data-carbon-theme]=\"theme$ | async\"\n        [label]=\"'logging.search.afterTimestamp' | translate\"\n        placeholder=\"DD-MM-YYYY\"\n        [dateFormat]=\"'d-m-Y'\"\n        [value]=\"[selectedDate]\"\n        [invalid]=\"obs.datePickerInvalid\"\n        [invalidText]=\"'datumStatusGezetInvalidText' | pluginTranslate: obs.pluginId | async\"\n        (valueChange)=\"onDateSelected($event)\"\n      ></cds-date-picker>\n\n      <cds-timepicker\n        class=\"timepicker\"\n        [attr.data-carbon-theme]=\"theme$ | async\"\n        [value]=\"selectedTime\"\n        [invalid]=\"obs.datePickerInvalid\"\n        (valueChange)=\"onTimeSelected($event)\"\n      ></cds-timepicker>\n    </div>\n\n    <v-input\n      *ngIf=\"obs.datumStatusGezetSelectedInputOption === 'text'\"\n      name=\"datumStatusGezet\"\n      [title]=\"'datumStatusGezet' | pluginTranslate: obs.pluginId | async\"\n      [margin]=\"true\"\n      [defaultValue]=\"obs.prefill?.datumStatusGezet\"\n      [disabled]=\"obs.disabled\"\n      [required]=\"true\"\n      [trim]=\"true\"\n      [tooltip]=\"'datumStatusGezetTooltip' | pluginTranslate: obs.pluginId | async\"\n      [fullWidth]=\"true\"\n    ></v-input>\n\n    <v-radio\n      name=\"inputTypeZaakStatusToggle\"\n      [disabled]=\"obs.disabled\"\n      [title]=\"'inputTypeZaakStatusToggle' | 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=\"statustypeUrl\"\n      [title]=\"'statustypeUrl' | pluginTranslate: obs.pluginId | async\"\n      [margin]=\"true\"\n      [defaultValue]=\"obs.prefill?.statustypeUrl\"\n      [disabled]=\"obs.disabled\"\n      [required]=\"true\"\n      [trim]=\"true\"\n      [tooltip]=\"'statustypeUrlTooltip' | pluginTranslate: obs.pluginId | async\"\n      [fullWidth]=\"true\"\n    >\n    </v-input>\n    <ng-container *ngIf=\"obs.selectedInputOption === 'selection'\">\n      <v-select\n        [items]=\"obs.caseDefinitionItems\"\n        [margin]=\"true\"\n        [widthInPx]=\"350\"\n        name=\"caseDefinition\"\n        [title]=\"'caseDefinition' | pluginTranslate: obs.pluginId | async\"\n        [disabled]=\"\n          obs.disabled ||\n          obs.selectedInputOption === 'text' ||\n          !obs.caseDefinitionItems ||\n          oneSelectItem(obs.caseDefinitionItems)\n        \"\n        [required]=\"true\"\n        [loading]=\"!obs.caseDefinitionItems\"\n        [tooltip]=\"'caseDefinitionTooltip' | pluginTranslate: obs.pluginId | async\"\n        (selectedChange)=\"selectCaseDefinition($event)\"\n        [defaultSelectionId]=\"obs?.selectedCaseDefinitionId\"\n      ></v-select>\n      <v-select\n        [items]=\"obs.statusTypeItems && obs.statusTypeItems[obs.selectedCaseDefinitionId]\"\n        [margin]=\"true\"\n        [widthInPx]=\"350\"\n        name=\"statustypeUrl\"\n        [title]=\"'statustypeUrlSelect' | pluginTranslate: obs.pluginId | async\"\n        [disabled]=\"\n          obs.disabled ||\n          obs.selectedInputOption === 'text' ||\n          !obs.statusTypeItems ||\n          !obs.statusTypeItems[obs.selectedCaseDefinitionId]\n        \"\n        [defaultSelectionId]=\"obs.prefill?.statustypeUrl\"\n        [required]=\"true\"\n        [loading]=\"!obs.statusTypeItems\"\n        [tooltip]=\"'statustypeUrlSelectTooltip' | pluginTranslate: obs.pluginId | async\"\n        [clearSelectionSubject$]=\"clearStatusSelection$\"\n      ></v-select>\n    </ng-container>\n  </ng-container>\n</v-form>\n\n<ng-template #loading>\n  <div class=\"loading-container\">\n    <cds-loading></cds-loading>\n  </div>\n</ng-template>\n"]}
|
|
@@ -14,4 +14,4 @@
|
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
16
|
export {};
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGltby9wbHVnaW4vc3JjL2xpYi9wbHVnaW5zL3pha2VuLWFwaS9tb2RlbHMvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjUgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0IHtQbHVnaW5Db25maWd1cmF0aW9uRGF0YX0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzJztcbmltcG9ydCB7SW5wdXRPcHRpb259IGZyb20gJy4vaW5wdXQnO1xuXG5pbnRlcmZhY2UgWmFrZW5BcGlDb25maWcgZXh0ZW5kcyBQbHVnaW5Db25maWd1cmF0aW9uRGF0YSB7XG4gIHVybDogc3RyaW5nO1xuICBhdXRoZW50aWNhdGlvblBsdWdpbkNvbmZpZ3VyYXRpb246IHN0cmluZztcbn1cblxuaW50ZXJmYWNlIExpbmtEb2N1bWVudFRvWmFha0NvbmZpZyB7XG4gIGRvY3VtZW50VXJsOiBzdHJpbmc7XG4gIHRpdGVsOiBzdHJpbmc7XG4gIGJlc2NocmlqdmluZzogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgU2V0WmFha1N0YXR1c0NvbmZpZyB7XG4gIHN0YXR1c3R5cGVVcmw6IHN0cmluZztcbiAgc3RhdHVzdG9lbGljaHRpbmc6IHN0cmluZztcbiAgaW5wdXRUeXBlWmFha1N0YXR1c1RvZ2dsZT86IElucHV0T3B0aW9uO1xuICBpbnB1dERhdHVtU3RhdHVzR2V6ZXRUb2dnbGU/OiBzdHJpbmc7XG4gIGRhdHVtU3RhdHVzR2V6ZXQ/OiBzdHJpbmc7XG59XG5cbmludGVyZmFjZSBDcmVhdGVaYWFrUmVzdWx0YWF0Q29uZmlnIHtcbiAgcmVzdWx0YWF0dHlwZVVybDogc3RyaW5nO1xuICB0b2VsaWNodGluZzogc3RyaW5nO1xuICBpbnB1dFR5cGVaYWFrUmVzdWx0YWF0VG9nZ2xlPzogSW5wdXRPcHRpb247XG59XG5cbmludGVyZmFjZSBDcmVhdGVOYXR1dXJsaWprZVBlcnNvb25aYWFrUm9sQ29uZmlnIHtcbiAgcm9sdHlwZVVybDogc3RyaW5nO1xuICByb2xUb2VsaWNodGluZzogc3RyaW5nO1xuICBpbnBCc246IHN0cmluZztcbiAgYW5wSWRlbnRpZmljYXRpZTogc3RyaW5nO1xuICBpbnBBX251bW1lcjogc3RyaW5nO1xuICByZXN1bHRQcm9jZXNzVmFyaWFibGU/OiBzdHJpbmc7XG59XG5cbmludGVyZmFjZSBDcmVhdGVOaWV0TmF0dXVybGlqa2VQZXJzb29uWmFha1JvbENvbmZpZyB7XG4gIHJvbHR5cGVVcmw6IHN0cmluZztcbiAgcm9sVG9lbGljaHRpbmc6IHN0cmluZztcbiAgaW5uTm5wSWQ6IHN0cmluZztcbiAgYW5uSWRlbnRpZmljYXRpZTogc3RyaW5nO1xuICByZXN1bHRQcm9jZXNzVmFyaWFibGU/OiBzdHJpbmc7XG59XG5cbmludGVyZmFjZSBEZWxldGVaYWFrUm9sQ29uZmlnIHtcbiAgcm9sVXVpZDogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgQ3JlYXRlWmFha0NvbmZpZyB7XG4gIHJzaW46IHN0cmluZztcbiAgbWFudWFsWmFha1R5cGVVcmw6IGJvb2xlYW47XG4gIHphYWt0eXBlVXJsOiBzdHJpbmc7XG4gIGlucHV0VHlwZVphYWtUeXBlVG9nZ2xlPzogSW5wdXRPcHRpb247XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICBwbGFubmVkRW5kRGF0ZT86IHN0cmluZztcbiAgZmluYWxEZWxpdmVyeURhdGU/OiBzdHJpbmc7XG59XG5cbmludGVyZmFjZSBTZXRaYWFrb3BzY2hvcnRpbmdDb25maWcge1xuICB2ZXJsZW5naW5nc2R1dXI6IHN0cmluZztcbiAgdG9lbGljaHRpbmdWZXJsZW5naW5nOiBzdHJpbmc7XG4gIHRvZWxpY2h0aW5nT3BzY2hvcnRpbmc6IHN0cmluZztcbn1cblxuaW50ZXJmYWNlIFN0YXJ0SGVyc3RlbHRlcm1pam5Db25maWcge1xuICBtYXhEdXJhdGlvbkluRGF5czogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgQ3JlYXRlWmFha2VpZ2Vuc2NoYXBDb25maWcge1xuICBlaWdlbnNjaGFwVXJsOiBzdHJpbmc7XG4gIGVpZ2Vuc2NoYXBWYWx1ZTogc3RyaW5nO1xuICBpbnB1dFR5cGVFaWdlbnNjaGFwVG9nZ2xlPzogSW5wdXRPcHRpb247XG59XG5cbmludGVyZmFjZSBVcGRhdGVaYWFrZWlnZW5zY2hhcENvbmZpZyB7XG4gIGVpZ2Vuc2NoYXBVcmw6IHN0cmluZztcbiAgZWlnZW5zY2hhcFZhbHVlOiBzdHJpbmc7XG4gIGlucHV0VHlwZUVpZ2Vuc2NoYXBUb2dnbGU/OiBJbnB1dE9wdGlvbjtcbn1cblxuaW50ZXJmYWNlIERlbGV0ZVphYWtlaWdlbnNjaGFwQ29uZmlnIHtcbiAgZWlnZW5zY2hhcFVybDogc3RyaW5nO1xuICBpbnB1dFR5cGVFaWdlbnNjaGFwVG9nZ2xlPzogSW5wdXRPcHRpb247XG59XG5cbmludGVyZmFjZSBSZWxhdGVlclpha2VuQ29uZmlnIHtcbiAgdGVSZWxhdGVyZW5aYWFrVXJpOiBzdHJpbmc7XG4gIGFhcmRSZWxhdGllOiBzdHJpbmc7XG59XG5cbmludGVyZmFjZSBHZXRaYWFrYmVzbHVpdGVuQ29uZmlnIHtcbiAgcmVzdWx0UHJvY2Vzc1ZhcmlhYmxlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCB7XG4gIFpha2VuQXBpQ29uZmlnLFxuICBMaW5rRG9jdW1lbnRUb1phYWtDb25maWcsXG4gIFNldFphYWtTdGF0dXNDb25maWcsXG4gIENyZWF0ZVphYWtSZXN1bHRhYXRDb25maWcsXG4gIENyZWF0ZVphYWtDb25maWcsXG4gIENyZWF0ZU5hdHV1cmxpamtlUGVyc29vblphYWtSb2xDb25maWcsXG4gIENyZWF0ZU5pZXROYXR1dXJsaWprZVBlcnNvb25aYWFrUm9sQ29uZmlnLFxuICBEZWxldGVaYWFrUm9sQ29uZmlnLFxuICBTZXRaYWFrb3BzY2hvcnRpbmdDb25maWcsXG4gIFN0YXJ0SGVyc3RlbHRlcm1pam5Db25maWcsXG4gIENyZWF0ZVphYWtlaWdlbnNjaGFwQ29uZmlnLFxuICBVcGRhdGVaYWFrZWlnZW5zY2hhcENvbmZpZyxcbiAgRGVsZXRlWmFha2VpZ2Vuc2NoYXBDb25maWcsXG4gIFJlbGF0ZWVyWmFrZW5Db25maWcsXG4gIEdldFphYWtiZXNsdWl0ZW5Db25maWcsXG59O1xuIl19
|