@valtimo/dossier-management 11.1.2 → 11.2.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.
Files changed (67) hide show
  1. package/esm2022/lib/components/dossier-management-assignee/dossier-management-assignee.component.mjs +5 -5
  2. package/esm2022/lib/components/dossier-management-connect-modal/dossier-management-connect-modal.component.mjs +56 -27
  3. package/esm2022/lib/components/dossier-management-detail/dossier-management-detail.component.mjs +13 -74
  4. package/esm2022/lib/components/dossier-management-detail-container/dossier-management-detail-container.component.mjs +17 -13
  5. package/esm2022/lib/components/dossier-management-detail-container-actions/dossier-management-detail-container-actions.mjs +152 -0
  6. package/esm2022/lib/components/dossier-management-document-definition/dossier-management-document-definition.mjs +48 -0
  7. package/esm2022/lib/components/dossier-management-link-process/dossier-management-link-process.component.mjs +3 -3
  8. package/esm2022/lib/components/dossier-management-list/dossier-management-list.component.mjs +47 -30
  9. package/esm2022/lib/components/dossier-management-list-columns/dossier-management-list-columns.component.mjs +45 -43
  10. package/esm2022/lib/components/dossier-management-processes/dossier-management-processes.component.mjs +110 -0
  11. package/esm2022/lib/components/dossier-management-search-fields/dossier-management-search-fields.component.mjs +67 -58
  12. package/esm2022/lib/components/dossier-management-tabs/dossier-management-edit-tab-modal/dossier-management-edit-tab-modal.component.mjs +1 -1
  13. package/esm2022/lib/components/dossier-management-tabs/dossier-management-tabs.component.mjs +14 -27
  14. package/esm2022/lib/components/dossier-management-upload/dossier-management-upload.component.mjs +167 -111
  15. package/esm2022/lib/components/dossier-management-upload/dossier-management-upload.constants.mjs +23 -0
  16. package/esm2022/lib/components/dossier-management-upload/step/dossier-management-upload-step.component.mjs +17 -0
  17. package/esm2022/lib/dossier-management.module.mjs +48 -9
  18. package/esm2022/lib/models/tab.enum.mjs +3 -1
  19. package/esm2022/lib/services/dossier-detail.service.mjs +84 -0
  20. package/esm2022/lib/services/dossier-export.service.mjs +39 -0
  21. package/esm2022/lib/services/dossier-import.service.mjs +38 -0
  22. package/esm2022/lib/services/index.mjs +3 -1
  23. package/esm2022/lib/services/tab.service.mjs +2 -2
  24. package/fesm2022/valtimo-dossier-management.mjs +1174 -654
  25. package/fesm2022/valtimo-dossier-management.mjs.map +1 -1
  26. package/lib/components/dossier-management-assignee/dossier-management-assignee.component.d.ts +1 -1
  27. package/lib/components/dossier-management-assignee/dossier-management-assignee.component.d.ts.map +1 -1
  28. package/lib/components/dossier-management-connect-modal/dossier-management-connect-modal.component.d.ts +13 -10
  29. package/lib/components/dossier-management-connect-modal/dossier-management-connect-modal.component.d.ts.map +1 -1
  30. package/lib/components/dossier-management-detail/dossier-management-detail.component.d.ts +7 -22
  31. package/lib/components/dossier-management-detail/dossier-management-detail.component.d.ts.map +1 -1
  32. package/lib/components/dossier-management-detail-container/dossier-management-detail-container.component.d.ts +3 -1
  33. package/lib/components/dossier-management-detail-container/dossier-management-detail-container.component.d.ts.map +1 -1
  34. package/lib/components/dossier-management-detail-container-actions/dossier-management-detail-container-actions.d.ts +40 -0
  35. package/lib/components/dossier-management-detail-container-actions/dossier-management-detail-container-actions.d.ts.map +1 -0
  36. package/lib/components/dossier-management-document-definition/dossier-management-document-definition.d.ts +15 -0
  37. package/lib/components/dossier-management-document-definition/dossier-management-document-definition.d.ts.map +1 -0
  38. package/lib/components/dossier-management-list/dossier-management-list.component.d.ts +16 -19
  39. package/lib/components/dossier-management-list/dossier-management-list.component.d.ts.map +1 -1
  40. package/lib/components/dossier-management-list-columns/dossier-management-list-columns.component.d.ts +14 -11
  41. package/lib/components/dossier-management-list-columns/dossier-management-list-columns.component.d.ts.map +1 -1
  42. package/lib/components/dossier-management-processes/dossier-management-processes.component.d.ts +29 -0
  43. package/lib/components/dossier-management-processes/dossier-management-processes.component.d.ts.map +1 -0
  44. package/lib/components/dossier-management-search-fields/dossier-management-search-fields.component.d.ts +14 -13
  45. package/lib/components/dossier-management-search-fields/dossier-management-search-fields.component.d.ts.map +1 -1
  46. package/lib/components/dossier-management-tabs/dossier-management-tabs.component.d.ts +3 -2
  47. package/lib/components/dossier-management-tabs/dossier-management-tabs.component.d.ts.map +1 -1
  48. package/lib/components/dossier-management-upload/dossier-management-upload.component.d.ts +42 -30
  49. package/lib/components/dossier-management-upload/dossier-management-upload.component.d.ts.map +1 -1
  50. package/lib/components/dossier-management-upload/dossier-management-upload.constants.d.ts +15 -0
  51. package/lib/components/dossier-management-upload/dossier-management-upload.constants.d.ts.map +1 -0
  52. package/lib/components/dossier-management-upload/step/dossier-management-upload-step.component.d.ts +9 -0
  53. package/lib/components/dossier-management-upload/step/dossier-management-upload-step.component.d.ts.map +1 -0
  54. package/lib/dossier-management.module.d.ts +13 -9
  55. package/lib/dossier-management.module.d.ts.map +1 -1
  56. package/lib/models/tab.enum.d.ts +2 -0
  57. package/lib/models/tab.enum.d.ts.map +1 -1
  58. package/lib/services/dossier-detail.service.d.ts +30 -0
  59. package/lib/services/dossier-detail.service.d.ts.map +1 -0
  60. package/lib/services/dossier-export.service.d.ts +14 -0
  61. package/lib/services/dossier-export.service.d.ts.map +1 -0
  62. package/lib/services/dossier-import.service.d.ts +14 -0
  63. package/lib/services/dossier-import.service.d.ts.map +1 -0
  64. package/lib/services/index.d.ts +2 -0
  65. package/lib/services/index.d.ts.map +1 -1
  66. package/lib/services/tab.service.d.ts.map +1 -1
  67. package/package.json +1 -1
@@ -13,121 +13,169 @@
13
13
  * See the License for the specific language governing permissions and
14
14
  * limitations under the License.
15
15
  */
16
- import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
16
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
17
+ import { Validators } from '@angular/forms';
18
+ import { WarningFilled16 } from '@carbon/icons';
19
+ import { CARBON_CONSTANTS } from '@valtimo/components';
17
20
  import { DocumentDefinitionCreateRequest } from '@valtimo/document';
18
- import { BehaviorSubject, Subject } from 'rxjs';
19
- import { switchMap, take, tap } from 'rxjs/operators';
21
+ import { BehaviorSubject, combineLatest, map, Subscription, switchMap, take } from 'rxjs';
22
+ import { STEPS, UPLOAD_STATUS, UPLOAD_STEP } from './dossier-management-upload.constants';
20
23
  import * as i0 from "@angular/core";
21
24
  import * as i1 from "@valtimo/document";
22
- import * as i2 from "@ngx-translate/core";
23
- import * as i3 from "@valtimo/components";
24
- import * as i4 from "@angular/common";
25
+ import * as i2 from "../../services/dossier-import.service";
26
+ import * as i3 from "@angular/forms";
27
+ import * as i4 from "carbon-components-angular";
28
+ import * as i5 from "@ngx-translate/core";
29
+ import * as i6 from "@angular/common";
30
+ import * as i7 from "@valtimo/components";
31
+ import * as i8 from "./step/dossier-management-upload-step.component";
25
32
  export class DossierManagementUploadComponent {
26
- constructor(documentService, translateService, menuService) {
33
+ constructor(documentService, dossierImportService, fb, iconService, translateService) {
27
34
  this.documentService = documentService;
35
+ this.dossierImportService = dossierImportService;
36
+ this.fb = fb;
37
+ this.iconService = iconService;
28
38
  this.translateService = translateService;
29
- this.menuService = menuService;
30
- this.definitionUploaded = new EventEmitter();
31
- this.clear$ = new Subject();
32
- this.jsonString$ = new BehaviorSubject('');
33
- this.error$ = new BehaviorSubject('');
34
- this.disabled$ = new BehaviorSubject(false);
35
- this.file$ = new BehaviorSubject(undefined);
36
- }
37
- ngAfterViewInit() {
38
- this.openShowSubscription();
39
- this.openFileSubscription();
39
+ this.open = false;
40
+ this.closeModal = new EventEmitter();
41
+ this.acceptedFiles = ['.json', '.zip'];
42
+ this._disabled$ = new BehaviorSubject(true);
43
+ this.UPLOAD_STEP = UPLOAD_STEP;
44
+ this.UPLOAD_STATUS = UPLOAD_STATUS;
45
+ this.activeStep$ = new BehaviorSubject(UPLOAD_STEP.PLUGINS);
46
+ this.backButtonEnabled$ = this.activeStep$.pipe(map((activeStep) => [UPLOAD_STEP.FILE_SELECT, UPLOAD_STEP.ACCESS_CONTROL, UPLOAD_STEP.DASHBOARD].includes(activeStep)));
47
+ this.isStepAfterUpload$ = this.activeStep$.pipe(map((activeStep) => ![UPLOAD_STEP.PLUGINS, UPLOAD_STEP.FILE_SELECT].includes(activeStep)));
48
+ this.showCloseButton$ = this.activeStep$.pipe(map((activeStep) => [UPLOAD_STEP.PLUGINS, UPLOAD_STEP.FILE_SELECT, UPLOAD_STEP.FILE_UPLOAD].includes(activeStep)));
49
+ this.nextButtonDisabled$ = combineLatest([
50
+ this.activeStep$,
51
+ this._disabled$,
52
+ ]).pipe(map(([activeStep, disabled]) => activeStep !== UPLOAD_STEP.PLUGINS && disabled));
53
+ this.notificationObj$ = combineLatest([
54
+ this.translateService.stream('interface.warning'),
55
+ this.translateService.stream('dossierManagement.importDefinition.overwriteWarning'),
56
+ ]).pipe(map(([title, message]) => ({
57
+ type: 'warning',
58
+ title,
59
+ message,
60
+ showClose: false,
61
+ lowContrast: true,
62
+ })));
63
+ this.showCheckboxError$ = new BehaviorSubject(false);
64
+ this.uploadStatus$ = new BehaviorSubject(UPLOAD_STATUS.ACTIVE);
65
+ this.form = this.fb.group({
66
+ file: this.fb.control(new Set(), [Validators.required]),
67
+ });
68
+ this._checked = false;
69
+ this._importFile$ = new BehaviorSubject('');
70
+ this._subscriptions = new Subscription();
71
+ this.iconService.register(WarningFilled16);
72
+ }
73
+ ngOnInit() {
74
+ const control = this.form.get('file');
75
+ if (!control) {
76
+ return;
77
+ }
78
+ this._subscriptions.add(control.valueChanges.subscribe((fileSet) => {
79
+ const [fileItem] = fileSet;
80
+ if (!fileItem) {
81
+ this._disabled$.next(true);
82
+ this.showCheckboxError$.next(false);
83
+ this._checked = false;
84
+ return;
85
+ }
86
+ if (fileItem.file.type === 'application/json') {
87
+ this.setJsonFile(fileItem);
88
+ return;
89
+ }
90
+ this.setZipFile(fileItem);
91
+ }));
40
92
  }
41
93
  ngOnDestroy() {
42
- this.showSubscription.unsubscribe();
43
- this.fileSubscription.unsubscribe();
44
- this.closeErrorSubscription();
45
- }
46
- setFile(file) {
47
- this.clearError();
48
- this.file$.next(file);
49
- }
50
- uploadDefinition() {
51
- this.disable();
52
- this.jsonString$
53
- .pipe(switchMap(jsonString => this.documentService
54
- .createDocumentDefinitionForManagement(new DocumentDefinitionCreateRequest(jsonString))
55
- .pipe(tap(
56
- // success
57
- () => {
58
- this.closeErrorSubscription();
59
- this.clearError();
60
- this.enable();
61
- this.hideModal();
62
- this.menuService.reload();
63
- this.definitionUploaded.emit();
64
- },
65
- // error
66
- () => {
67
- this.openErrorSubscription('dropzone.error.invalidDocDef');
68
- this.enable();
69
- }))), take(1))
70
- .subscribe();
94
+ this.resetModal();
71
95
  }
72
- openErrorSubscription(errorCode) {
73
- this.closeErrorSubscription();
74
- this.errorSubscription = this.translateService.stream(errorCode).subscribe(error => {
75
- this.error$.next(error);
76
- });
96
+ onCloseModal(definitionUploaded) {
97
+ this.closeModal.emit(definitionUploaded ?? false);
98
+ this.resetModal();
77
99
  }
78
- closeErrorSubscription() {
79
- if (this.errorSubscription) {
80
- this.errorSubscription.unsubscribe();
100
+ onBackClick(activeStep) {
101
+ const prevIndex = STEPS.findIndex((step) => step === activeStep) - 1;
102
+ if (prevIndex === -1) {
103
+ return;
81
104
  }
105
+ this.activeStep$.next(STEPS[prevIndex]);
82
106
  }
83
- clearError() {
84
- this.error$.next('');
107
+ onNextClick(activeStep) {
108
+ const nextIndex = STEPS.findIndex((step) => step === activeStep) + 1;
109
+ if (nextIndex === STEPS.length) {
110
+ return;
111
+ }
112
+ if (activeStep === UPLOAD_STEP.FILE_SELECT && !this._checked) {
113
+ this.showCheckboxError$.next(true);
114
+ return;
115
+ }
116
+ this.activeStep$.next(STEPS[nextIndex]);
117
+ if (STEPS[nextIndex] !== UPLOAD_STEP.FILE_UPLOAD) {
118
+ return;
119
+ }
120
+ this.uploadDefinition();
85
121
  }
86
- openFileSubscription() {
87
- this.fileSubscription = this.file$.subscribe(file => {
88
- if (file) {
89
- const reader = new FileReader();
90
- reader.onloadend = () => {
91
- const result = reader.result.toString();
92
- if (this.stringIsValidJson(result)) {
93
- this.jsonString$.next(result);
94
- }
95
- else {
96
- this.clearJsonString();
97
- this.error$.next(this.translateService.instant('dropzone.error.invalidJson'));
98
- }
99
- };
100
- reader.readAsText(file);
101
- }
102
- else {
103
- this.clearJsonString();
104
- }
105
- });
122
+ onCheckedChange(checked) {
123
+ this._checked = checked;
124
+ if (!checked) {
125
+ return;
126
+ }
127
+ this.showCheckboxError$.next(false);
106
128
  }
107
- openShowSubscription() {
108
- this.showSubscription = this.show$.subscribe(show => {
109
- if (show) {
110
- this.showModal();
111
- }
112
- else {
113
- this.hideModal();
129
+ setJsonFile(fileItem) {
130
+ const file = fileItem?.file;
131
+ if (!file) {
132
+ this.clearJsonString();
133
+ return;
134
+ }
135
+ const reader = new FileReader();
136
+ reader.onloadend = () => {
137
+ const result = (reader.result ?? '').toString();
138
+ if (this.stringIsValidJson(result)) {
139
+ this._disabled$.next(false);
140
+ this._importFile$.next(result);
141
+ return;
114
142
  }
115
143
  this.clearJsonString();
116
- this.clearError();
117
- this.clearDropzone();
144
+ this.setErrorState(fileItem);
145
+ };
146
+ reader.readAsText(file);
147
+ }
148
+ setZipFile(fileItem) {
149
+ const file = fileItem?.file;
150
+ if (!file) {
151
+ this._importFile$.next('');
152
+ return;
153
+ }
154
+ const blob = new Blob([fileItem.file], { type: fileItem.file.type });
155
+ const fd = new FormData();
156
+ fd.append('file', blob, fileItem.file.name);
157
+ this._importFile$.next(fd);
158
+ this._disabled$.next(false);
159
+ }
160
+ uploadDefinition() {
161
+ this._disabled$.next(true);
162
+ this._importFile$
163
+ .pipe(switchMap((file) => file instanceof FormData
164
+ ? this.dossierImportService.importDocumentDefinitionZip(file)
165
+ : this.documentService.createDocumentDefinitionForManagement(new DocumentDefinitionCreateRequest(file))), take(1))
166
+ .subscribe({
167
+ next: () => {
168
+ this._disabled$.next(false);
169
+ this.uploadStatus$.next(UPLOAD_STATUS.FINISHED);
170
+ },
171
+ error: () => {
172
+ this.uploadStatus$.next(UPLOAD_STATUS.ERROR);
173
+ this._disabled$.next(false);
174
+ },
118
175
  });
119
176
  }
120
177
  clearJsonString() {
121
- this.jsonString$.next('');
122
- }
123
- clearDropzone() {
124
- this.clear$.next(null);
125
- }
126
- showModal() {
127
- this.modal.show();
128
- }
129
- hideModal() {
130
- this.modal.hide();
178
+ this._importFile$.next('');
131
179
  }
132
180
  stringIsValidJson(string) {
133
181
  try {
@@ -138,24 +186,32 @@ export class DossierManagementUploadComponent {
138
186
  }
139
187
  return true;
140
188
  }
141
- disable() {
142
- this.disabled$.next(true);
143
- }
144
- enable() {
145
- this.disabled$.next(false);
146
- }
147
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierManagementUploadComponent, deps: [{ token: i1.DocumentService }, { token: i2.TranslateService }, { token: i3.MenuService }], target: i0.ɵɵFactoryTarget.Component }); }
148
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DossierManagementUploadComponent, selector: "valtimo-dossier-management-upload", inputs: { show$: "show$" }, outputs: { definitionUploaded: "definitionUploaded" }, viewQueries: [{ propertyName: "modal", first: true, predicate: ["uploadDefinitionModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 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<valtimo-modal\n #uploadDefinitionModal\n [title]=\"'Upload document definition' | translate\"\n showFooter=\"true\"\n>\n <div class=\"mt-2\" body>\n <valtimo-dropzone\n [clear$]=\"clear$\"\n (fileSelected)=\"setFile($event)\"\n [disabled]=\"disabled$ | async\"\n [subtitle]=\"'dropzone.jsonDocDef' | translate\"\n [externalError$]=\"error$\"\n [maxFiles]=\"1\"\n ></valtimo-dropzone>\n </div>\n <div footer>\n <ng-container *ngIf=\"(jsonString$ | async) && (error$ | async) === ''; else disabledUpload\">\n <button [disabled]=\"disabled$ | async\" class=\"btn btn-primary\" (click)=\"uploadDefinition()\">\n <i class=\"icon mdi mdi-upload mr-1\"></i>\n {{ 'Upload' | translate }}\n </button>\n </ng-container>\n </div>\n</valtimo-modal>\n\n<ng-template #disabledUpload>\n <button [disabled]=\"true\" class=\"btn btn-primary\">\n <i class=\"icon mdi mdi-upload mr-1\"></i>\n {{ 'Upload' | translate }}\n </button>\n</ng-template>\n", styles: ["/*!\n * Copyright 2015-2023 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.DropzoneComponent, selector: "valtimo-dropzone", inputs: ["title", "hideTitle", "subtitle", "externalError$", "maxFileSize", "showMaxFileSize", "acceptedFiles", "clear$", "disabled", "hideFilePreview", "uploading", "camera", "maxFiles"], outputs: ["fileSelected"] }, { kind: "component", type: i3.ModalComponent, selector: "valtimo-modal", inputs: ["elementId", "title", "subtitle", "templateBelowSubtitle", "showFooter"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
189
+ setErrorState(fileItem) {
190
+ this._disabled$.next(true);
191
+ fileItem.invalid = true;
192
+ fileItem.invalidTitle = this.translateService.instant('dossierManagement.importDefinition.invalidJsonError.title');
193
+ fileItem.invalidText = this.translateService.instant('dossierManagement.importDefinition.invalidJsonError.text');
194
+ }
195
+ resetModal() {
196
+ setTimeout(() => {
197
+ this.activeStep$.next(UPLOAD_STEP.PLUGINS);
198
+ this.uploadStatus$.next(UPLOAD_STATUS.ACTIVE);
199
+ this.showCheckboxError$.next(false);
200
+ this._subscriptions.unsubscribe();
201
+ }, CARBON_CONSTANTS.modalAnimationMs);
202
+ }
203
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierManagementUploadComponent, deps: [{ token: i1.DocumentService }, { token: i2.DossierImportService }, { token: i3.FormBuilder }, { token: i4.IconService }, { token: i5.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
204
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DossierManagementUploadComponent, selector: "valtimo-dossier-management-upload", inputs: { open: "open" }, outputs: { closeModal: "closeModal" }, viewQueries: [{ propertyName: "modal", first: true, predicate: ["uploadDefinitionModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 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 *ngIf=\"{\n activeStep: activeStep$ | async,\n backButtonEnabled: backButtonEnabled$ | async,\n isStepAfterUpload: isStepAfterUpload$ | async,\n nextButtonDisabled: nextButtonDisabled$ | async,\n notificationObj: notificationObj$ | async,\n showCheckboxError: showCheckboxError$ | async,\n showCloseButton: showCloseButton$ | async,\n uploadStatus: uploadStatus$ | async\n } as obs\"\n valtimoCdsModal\n [open]=\"open\"\n showFooter=\"true\"\n class=\"valtimo-definition-uploader\"\n (close)=\"onCloseModal()\"\n>\n <cds-modal-header\n [showCloseButton]=\"obs.showCloseButton\"\n (closeSelect)=\"onCloseModal(obs.isStepAfterUpload && obs.uploadStatus !== UPLOAD_STATUS.ERROR)\"\n >\n <h3 cdsModalHeaderHeading>\n {{ 'dossierManagement.importDefinition.title' | translate }}\n </h3>\n </cds-modal-header>\n\n <section [ngSwitch]=\"obs.activeStep\" cdsModalContent class=\"valtimo-definition-uploader__content\">\n <ng-template ngSwitchDefault>\n <valtimo-dossier-management-upload-step\n [message]=\"\n 'dossierManagement.importDefinition.steps.' + obs.activeStep + '.message' | translate\n \"\n [title]=\"\n 'dossierManagement.importDefinition.steps.' + obs.activeStep + '.title' | translate\n \"\n [illustration]=\"'valtimo-layout/img/' + obs.activeStep + '.svg'\"\n >\n </valtimo-dossier-management-upload-step>\n </ng-template>\n\n <form *ngSwitchCase=\"UPLOAD_STEP.FILE_SELECT\" [formGroup]=\"form\">\n <cds-file-uploader\n [accept]=\"acceptedFiles\"\n [buttonText]=\"'dossierManagement.importDefinition.upload.buttonText' | translate\"\n [description]=\"'dossierManagement.importDefinition.upload.description' | translate\"\n [multiple]=\"false\"\n [title]=\"'dossierManagement.importDefinition.upload.title' | translate\"\n buttonType=\"primary\"\n data-carbon-theme=\"g10\"\n formControlName=\"file\"\n class=\"valtimo-definition-uploader__file-uploader\"\n >\n </cds-file-uploader>\n\n <ng-container *ngIf=\"!obs.nextButtonDisabled\">\n <cds-inline-notification [notificationObj]=\"obs.notificationObj\"></cds-inline-notification>\n\n <div class=\"valtimo-uploader__checkbox\">\n <cds-checkbox\n [class.valtimo-definition-uploader__checkbox--invalid]=\"obs.showCheckboxError\"\n (checkedChange)=\"onCheckedChange($event)\"\n >\n {{ 'dossierManagement.importDefinition.checkbox.message' | translate }}\n </cds-checkbox>\n\n <div *ngIf=\"obs.showCheckboxError\" class=\"valtimo-definition-uploader__error\">\n <svg cdsIcon=\"warning--filled\" size=\"16\"></svg>\n\n {{ 'dossierManagement.importDefinition.checkbox.error' | translate }}\n </div>\n </div>\n </ng-container>\n </form>\n\n <cds-progress-bar\n *ngSwitchCase=\"UPLOAD_STEP.FILE_UPLOAD\"\n class=\"valtimo-definition-uploader__progress-bar\"\n [label]=\"'dossierManagement.importDefinition.progressBar.label' | translate\"\n [status]=\"obs.uploadStatus\"\n [helperText]=\"\n 'dossierManagement.importDefinition.progressBar.' + obs.uploadStatus | translate\n \"\n ></cds-progress-bar>\n </section>\n\n <cds-modal-footer\n class=\"valtimo-definition-uploader__footer\"\n [class.valtimo-definition-uploader__footer--double]=\"obs.activeStep === UPLOAD_STEP.PLUGINS\"\n >\n <button\n *ngIf=\"obs.uploadStatus !== UPLOAD_STATUS.ERROR && obs.activeStep !== UPLOAD_STEP.FILE_UPLOAD\"\n class=\"valtimo-definition-uploader__cancel\"\n cdsButton=\"ghost\"\n (click)=\"onCloseModal(obs.isStepAfterUpload)\"\n >\n {{ (obs.isStepAfterUpload ? 'interface.skip' : 'interface.cancel') | translate }}\n </button>\n\n <div class=\"valtimo-definition-uploader__actions\">\n <button\n *ngIf=\"obs.backButtonEnabled\"\n cdsButton=\"secondary\"\n (click)=\"onBackClick(obs.activeStep)\"\n >\n {{ 'interface.back' | translate }}\n </button>\n\n <button\n *ngIf=\"obs.uploadStatus !== UPLOAD_STATUS.ERROR && obs.activeStep !== UPLOAD_STEP.DASHBOARD\"\n cdsButton=\"primary\"\n [disabled]=\"obs.nextButtonDisabled\"\n (click)=\"onNextClick(obs.activeStep)\"\n >\n {{\n (obs.activeStep === UPLOAD_STEP.FILE_SELECT\n ? 'dossierManagement.importDefinition.startUpload'\n : 'interface.next'\n ) | translate\n }}\n </button>\n\n <button\n *ngIf=\"obs.uploadStatus === UPLOAD_STATUS.ERROR || obs.activeStep === UPLOAD_STEP.DASHBOARD\"\n class=\"valtimo-definition-uploader__cancel\"\n cdsButton=\"primary\"\n (click)=\"onCloseModal(true)\"\n >\n {{ 'interface.finish' | translate }}\n </button>\n </div>\n </cds-modal-footer>\n</cds-modal>\n", styles: ["/*!\n * Copyright 2015-2023 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 */.valtimo-definition-uploader__content,.valtimo-definition-uploader__content form{display:flex;flex-direction:column;gap:16px}.valtimo-definition-uploader__footer ::ng-deep .cds--modal-footer{justify-content:unset!important;display:grid!important;grid-template-columns:1fr 1fr 2fr!important;grid-template-areas:\"cancel . actions\"!important}.valtimo-definition-uploader__footer--double ::ng-deep .cds--modal-footer{grid-template-columns:1fr 1fr!important;grid-template-areas:\"cancel actions\"!important}.valtimo-definition-uploader__progress-bar{height:100%;display:flex;flex-direction:column;justify-content:center}.valtimo-definition-uploader__error{display:flex;align-items:center;gap:10px;color:#da1e28;fill:#da1e28;font-size:12px}.valtimo-definition-uploader__cancel{grid-area:cancel;width:100%}.valtimo-definition-uploader__actions{grid-area:actions;display:flex}.valtimo-definition-uploader__actions button{flex:unset;width:100%}.valtimo-definition-uploader__file-uploader ::ng-deep cds-file{max-width:unset}.valtimo-definition-uploader__checkbox{display:flex;flex-direction:column;gap:8px}.valtimo-definition-uploader__checkbox--invalid ::ng-deep label:before{border-color:#da1e28;margin-inline:0}.valtimo-definition-uploader ::ng-deep .cds--modal-container{height:550px}.valtimo-definition-uploader ::ng-deep .cds--checkbox-label-text{color:#000}\n"], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i6.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i4.Notification, selector: "cds-notification, cds-inline-notification, ibm-notification, ibm-inline-notification", inputs: ["notificationObj"] }, { kind: "directive", type: i4.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "directive", type: i4.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "component", type: i4.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i4.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i4.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i4.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i4.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i4.Checkbox, selector: "cds-checkbox, ibm-checkbox", inputs: ["disabled", "skeleton", "hideLabel", "name", "id", "required", "value", "ariaLabel", "ariaLabelledby", "indeterminate", "checked"], outputs: ["click", "checkedChange", "indeterminateChange"] }, { kind: "directive", type: i7.ValtimoCdsModalDirective, selector: "[valtimoCdsModal]" }, { kind: "component", type: i4.FileUploader, selector: "cds-file-uploader, ibm-file-uploader", inputs: ["buttonText", "buttonType", "title", "description", "accept", "multiple", "skeleton", "size", "fileItemSize", "drop", "dropText", "fileUploaderId", "files", "disabled"], outputs: ["filesChange"] }, { kind: "component", type: i4.ProgressBar, selector: "cds-progress-bar, ibm-progress-bar", inputs: ["value", "id", "label", "helperText", "max", "type", "status", "size"] }, { kind: "component", type: i8.DossierManagementUploadStepComponent, selector: "valtimo-dossier-management-upload-step", inputs: ["illustration", "message", "title"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
149
205
  }
150
206
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierManagementUploadComponent, decorators: [{
151
207
  type: Component,
152
- args: [{ selector: 'valtimo-dossier-management-upload', template: "<!--\n ~ Copyright 2015-2023 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<valtimo-modal\n #uploadDefinitionModal\n [title]=\"'Upload document definition' | translate\"\n showFooter=\"true\"\n>\n <div class=\"mt-2\" body>\n <valtimo-dropzone\n [clear$]=\"clear$\"\n (fileSelected)=\"setFile($event)\"\n [disabled]=\"disabled$ | async\"\n [subtitle]=\"'dropzone.jsonDocDef' | translate\"\n [externalError$]=\"error$\"\n [maxFiles]=\"1\"\n ></valtimo-dropzone>\n </div>\n <div footer>\n <ng-container *ngIf=\"(jsonString$ | async) && (error$ | async) === ''; else disabledUpload\">\n <button [disabled]=\"disabled$ | async\" class=\"btn btn-primary\" (click)=\"uploadDefinition()\">\n <i class=\"icon mdi mdi-upload mr-1\"></i>\n {{ 'Upload' | translate }}\n </button>\n </ng-container>\n </div>\n</valtimo-modal>\n\n<ng-template #disabledUpload>\n <button [disabled]=\"true\" class=\"btn btn-primary\">\n <i class=\"icon mdi mdi-upload mr-1\"></i>\n {{ 'Upload' | translate }}\n </button>\n</ng-template>\n", styles: ["/*!\n * Copyright 2015-2023 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"] }]
153
- }], ctorParameters: function () { return [{ type: i1.DocumentService }, { type: i2.TranslateService }, { type: i3.MenuService }]; }, propDecorators: { show$: [{
154
- type: Input
155
- }], definitionUploaded: [{
156
- type: Output
157
- }], modal: [{
208
+ args: [{ selector: 'valtimo-dossier-management-upload', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--\n ~ Copyright 2015-2023 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 *ngIf=\"{\n activeStep: activeStep$ | async,\n backButtonEnabled: backButtonEnabled$ | async,\n isStepAfterUpload: isStepAfterUpload$ | async,\n nextButtonDisabled: nextButtonDisabled$ | async,\n notificationObj: notificationObj$ | async,\n showCheckboxError: showCheckboxError$ | async,\n showCloseButton: showCloseButton$ | async,\n uploadStatus: uploadStatus$ | async\n } as obs\"\n valtimoCdsModal\n [open]=\"open\"\n showFooter=\"true\"\n class=\"valtimo-definition-uploader\"\n (close)=\"onCloseModal()\"\n>\n <cds-modal-header\n [showCloseButton]=\"obs.showCloseButton\"\n (closeSelect)=\"onCloseModal(obs.isStepAfterUpload && obs.uploadStatus !== UPLOAD_STATUS.ERROR)\"\n >\n <h3 cdsModalHeaderHeading>\n {{ 'dossierManagement.importDefinition.title' | translate }}\n </h3>\n </cds-modal-header>\n\n <section [ngSwitch]=\"obs.activeStep\" cdsModalContent class=\"valtimo-definition-uploader__content\">\n <ng-template ngSwitchDefault>\n <valtimo-dossier-management-upload-step\n [message]=\"\n 'dossierManagement.importDefinition.steps.' + obs.activeStep + '.message' | translate\n \"\n [title]=\"\n 'dossierManagement.importDefinition.steps.' + obs.activeStep + '.title' | translate\n \"\n [illustration]=\"'valtimo-layout/img/' + obs.activeStep + '.svg'\"\n >\n </valtimo-dossier-management-upload-step>\n </ng-template>\n\n <form *ngSwitchCase=\"UPLOAD_STEP.FILE_SELECT\" [formGroup]=\"form\">\n <cds-file-uploader\n [accept]=\"acceptedFiles\"\n [buttonText]=\"'dossierManagement.importDefinition.upload.buttonText' | translate\"\n [description]=\"'dossierManagement.importDefinition.upload.description' | translate\"\n [multiple]=\"false\"\n [title]=\"'dossierManagement.importDefinition.upload.title' | translate\"\n buttonType=\"primary\"\n data-carbon-theme=\"g10\"\n formControlName=\"file\"\n class=\"valtimo-definition-uploader__file-uploader\"\n >\n </cds-file-uploader>\n\n <ng-container *ngIf=\"!obs.nextButtonDisabled\">\n <cds-inline-notification [notificationObj]=\"obs.notificationObj\"></cds-inline-notification>\n\n <div class=\"valtimo-uploader__checkbox\">\n <cds-checkbox\n [class.valtimo-definition-uploader__checkbox--invalid]=\"obs.showCheckboxError\"\n (checkedChange)=\"onCheckedChange($event)\"\n >\n {{ 'dossierManagement.importDefinition.checkbox.message' | translate }}\n </cds-checkbox>\n\n <div *ngIf=\"obs.showCheckboxError\" class=\"valtimo-definition-uploader__error\">\n <svg cdsIcon=\"warning--filled\" size=\"16\"></svg>\n\n {{ 'dossierManagement.importDefinition.checkbox.error' | translate }}\n </div>\n </div>\n </ng-container>\n </form>\n\n <cds-progress-bar\n *ngSwitchCase=\"UPLOAD_STEP.FILE_UPLOAD\"\n class=\"valtimo-definition-uploader__progress-bar\"\n [label]=\"'dossierManagement.importDefinition.progressBar.label' | translate\"\n [status]=\"obs.uploadStatus\"\n [helperText]=\"\n 'dossierManagement.importDefinition.progressBar.' + obs.uploadStatus | translate\n \"\n ></cds-progress-bar>\n </section>\n\n <cds-modal-footer\n class=\"valtimo-definition-uploader__footer\"\n [class.valtimo-definition-uploader__footer--double]=\"obs.activeStep === UPLOAD_STEP.PLUGINS\"\n >\n <button\n *ngIf=\"obs.uploadStatus !== UPLOAD_STATUS.ERROR && obs.activeStep !== UPLOAD_STEP.FILE_UPLOAD\"\n class=\"valtimo-definition-uploader__cancel\"\n cdsButton=\"ghost\"\n (click)=\"onCloseModal(obs.isStepAfterUpload)\"\n >\n {{ (obs.isStepAfterUpload ? 'interface.skip' : 'interface.cancel') | translate }}\n </button>\n\n <div class=\"valtimo-definition-uploader__actions\">\n <button\n *ngIf=\"obs.backButtonEnabled\"\n cdsButton=\"secondary\"\n (click)=\"onBackClick(obs.activeStep)\"\n >\n {{ 'interface.back' | translate }}\n </button>\n\n <button\n *ngIf=\"obs.uploadStatus !== UPLOAD_STATUS.ERROR && obs.activeStep !== UPLOAD_STEP.DASHBOARD\"\n cdsButton=\"primary\"\n [disabled]=\"obs.nextButtonDisabled\"\n (click)=\"onNextClick(obs.activeStep)\"\n >\n {{\n (obs.activeStep === UPLOAD_STEP.FILE_SELECT\n ? 'dossierManagement.importDefinition.startUpload'\n : 'interface.next'\n ) | translate\n }}\n </button>\n\n <button\n *ngIf=\"obs.uploadStatus === UPLOAD_STATUS.ERROR || obs.activeStep === UPLOAD_STEP.DASHBOARD\"\n class=\"valtimo-definition-uploader__cancel\"\n cdsButton=\"primary\"\n (click)=\"onCloseModal(true)\"\n >\n {{ 'interface.finish' | translate }}\n </button>\n </div>\n </cds-modal-footer>\n</cds-modal>\n", styles: ["/*!\n * Copyright 2015-2023 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 */.valtimo-definition-uploader__content,.valtimo-definition-uploader__content form{display:flex;flex-direction:column;gap:16px}.valtimo-definition-uploader__footer ::ng-deep .cds--modal-footer{justify-content:unset!important;display:grid!important;grid-template-columns:1fr 1fr 2fr!important;grid-template-areas:\"cancel . actions\"!important}.valtimo-definition-uploader__footer--double ::ng-deep .cds--modal-footer{grid-template-columns:1fr 1fr!important;grid-template-areas:\"cancel actions\"!important}.valtimo-definition-uploader__progress-bar{height:100%;display:flex;flex-direction:column;justify-content:center}.valtimo-definition-uploader__error{display:flex;align-items:center;gap:10px;color:#da1e28;fill:#da1e28;font-size:12px}.valtimo-definition-uploader__cancel{grid-area:cancel;width:100%}.valtimo-definition-uploader__actions{grid-area:actions;display:flex}.valtimo-definition-uploader__actions button{flex:unset;width:100%}.valtimo-definition-uploader__file-uploader ::ng-deep cds-file{max-width:unset}.valtimo-definition-uploader__checkbox{display:flex;flex-direction:column;gap:8px}.valtimo-definition-uploader__checkbox--invalid ::ng-deep label:before{border-color:#da1e28;margin-inline:0}.valtimo-definition-uploader ::ng-deep .cds--modal-container{height:550px}.valtimo-definition-uploader ::ng-deep .cds--checkbox-label-text{color:#000}\n"] }]
209
+ }], ctorParameters: function () { return [{ type: i1.DocumentService }, { type: i2.DossierImportService }, { type: i3.FormBuilder }, { type: i4.IconService }, { type: i5.TranslateService }]; }, propDecorators: { modal: [{
158
210
  type: ViewChild,
159
211
  args: ['uploadDefinitionModal']
212
+ }], open: [{
213
+ type: Input
214
+ }], closeModal: [{
215
+ type: Output
160
216
  }] } });
161
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-upload.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-upload/dossier-management-upload.component.ts","../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-upload/dossier-management-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {TranslateService} from '@ngx-translate/core';\nimport {MenuService, ModalComponent} from '@valtimo/components';\nimport {DocumentService, DocumentDefinitionCreateRequest} from '@valtimo/document';\nimport {BehaviorSubject, Observable, Subject, Subscription} from 'rxjs';\nimport {switchMap, take, tap} from 'rxjs/operators';\n\n@Component({\n  selector: 'valtimo-dossier-management-upload',\n  templateUrl: './dossier-management-upload.component.html',\n  styleUrls: ['./dossier-management-upload.component.scss'],\n})\nexport class DossierManagementUploadComponent implements AfterViewInit, OnDestroy {\n  @Input() show$: Observable<boolean>;\n  @Output() definitionUploaded: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild('uploadDefinitionModal') modal: ModalComponent;\n\n  readonly clear$ = new Subject();\n\n  readonly jsonString$ = new BehaviorSubject<string>('');\n\n  readonly error$ = new BehaviorSubject<string>('');\n\n  readonly disabled$ = new BehaviorSubject<boolean>(false);\n\n  private showSubscription: Subscription;\n\n  private fileSubscription: Subscription;\n\n  private errorSubscription: Subscription;\n\n  private readonly file$ = new BehaviorSubject<File>(undefined);\n\n  constructor(\n    private readonly documentService: DocumentService,\n    private readonly translateService: TranslateService,\n    private readonly menuService: MenuService\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.openShowSubscription();\n    this.openFileSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this.showSubscription.unsubscribe();\n    this.fileSubscription.unsubscribe();\n    this.closeErrorSubscription();\n  }\n\n  setFile(file: File): void {\n    this.clearError();\n    this.file$.next(file);\n  }\n\n  uploadDefinition(): void {\n    this.disable();\n\n    this.jsonString$\n      .pipe(\n        switchMap(jsonString =>\n          this.documentService\n            .createDocumentDefinitionForManagement(new DocumentDefinitionCreateRequest(jsonString))\n            .pipe(\n              tap(\n                // success\n                () => {\n                  this.closeErrorSubscription();\n                  this.clearError();\n                  this.enable();\n                  this.hideModal();\n                  this.menuService.reload();\n                  this.definitionUploaded.emit();\n                },\n                // error\n                () => {\n                  this.openErrorSubscription('dropzone.error.invalidDocDef');\n                  this.enable();\n                }\n              )\n            )\n        ),\n        take(1)\n      )\n      .subscribe();\n  }\n\n  private openErrorSubscription(errorCode: string): void {\n    this.closeErrorSubscription();\n    this.errorSubscription = this.translateService.stream(errorCode).subscribe(error => {\n      this.error$.next(error);\n    });\n  }\n\n  private closeErrorSubscription(): void {\n    if (this.errorSubscription) {\n      this.errorSubscription.unsubscribe();\n    }\n  }\n\n  private clearError(): void {\n    this.error$.next('');\n  }\n\n  private openFileSubscription(): void {\n    this.fileSubscription = this.file$.subscribe(file => {\n      if (file) {\n        const reader = new FileReader();\n\n        reader.onloadend = () => {\n          const result = reader.result.toString();\n          if (this.stringIsValidJson(result)) {\n            this.jsonString$.next(result);\n          } else {\n            this.clearJsonString();\n            this.error$.next(this.translateService.instant('dropzone.error.invalidJson'));\n          }\n        };\n\n        reader.readAsText(file);\n      } else {\n        this.clearJsonString();\n      }\n    });\n  }\n\n  private openShowSubscription(): void {\n    this.showSubscription = this.show$.subscribe(show => {\n      if (show) {\n        this.showModal();\n      } else {\n        this.hideModal();\n      }\n\n      this.clearJsonString();\n      this.clearError();\n      this.clearDropzone();\n    });\n  }\n\n  private clearJsonString(): void {\n    this.jsonString$.next('');\n  }\n\n  private clearDropzone(): void {\n    this.clear$.next(null);\n  }\n\n  private showModal(): void {\n    this.modal.show();\n  }\n\n  private hideModal(): void {\n    this.modal.hide();\n  }\n\n  private stringIsValidJson(string: string) {\n    try {\n      JSON.parse(string);\n    } catch (e) {\n      return false;\n    }\n    return true;\n  }\n\n  private disable(): void {\n    this.disabled$.next(true);\n  }\n\n  private enable(): void {\n    this.disabled$.next(false);\n  }\n}\n","<!--\n  ~ Copyright 2015-2023 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<valtimo-modal\n  #uploadDefinitionModal\n  [title]=\"'Upload document definition' | translate\"\n  showFooter=\"true\"\n>\n  <div class=\"mt-2\" body>\n    <valtimo-dropzone\n      [clear$]=\"clear$\"\n      (fileSelected)=\"setFile($event)\"\n      [disabled]=\"disabled$ | async\"\n      [subtitle]=\"'dropzone.jsonDocDef' | translate\"\n      [externalError$]=\"error$\"\n      [maxFiles]=\"1\"\n    ></valtimo-dropzone>\n  </div>\n  <div footer>\n    <ng-container *ngIf=\"(jsonString$ | async) && (error$ | async) === ''; else disabledUpload\">\n      <button [disabled]=\"disabled$ | async\" class=\"btn btn-primary\" (click)=\"uploadDefinition()\">\n        <i class=\"icon mdi mdi-upload mr-1\"></i>\n        {{ 'Upload' | translate }}\n      </button>\n    </ng-container>\n  </div>\n</valtimo-modal>\n\n<ng-template #disabledUpload>\n  <button [disabled]=\"true\" class=\"btn btn-primary\">\n    <i class=\"icon mdi mdi-upload mr-1\"></i>\n    {{ 'Upload' | translate }}\n  </button>\n</ng-template>\n"]}
217
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-upload.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-upload/dossier-management-upload.component.ts","../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-upload/dossier-management-upload.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAA0C,UAAU,EAAC,MAAM,gBAAgB,CAAC;AACnF,OAAO,EAAC,eAAe,EAAC,MAAM,eAAe,CAAC;AAE9C,OAAO,EAAC,gBAAgB,EAAiB,MAAM,qBAAqB,CAAC;AACrE,OAAO,EAAC,+BAA+B,EAAkB,MAAM,mBAAmB,CAAC;AAEnF,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,GAAG,EAAc,YAAY,EAAE,SAAS,EAAE,IAAI,EAAC,MAAM,MAAM,CAAC;AAEpG,OAAO,EAAC,KAAK,EAAE,aAAa,EAAE,WAAW,EAAC,MAAM,uCAAuC,CAAC;;;;;;;;;;AAQxF,MAAM,OAAO,gCAAgC;IA4D3C,YACmB,eAAgC,EAChC,oBAA0C,EAC1C,EAAe,EACf,WAAwB,EACxB,gBAAkC;QAJlC,oBAAe,GAAf,eAAe,CAAiB;QAChC,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,OAAE,GAAF,EAAE,CAAa;QACf,gBAAW,GAAX,WAAW,CAAa;QACxB,qBAAgB,GAAhB,gBAAgB,CAAkB;QA9D5C,SAAI,GAAG,KAAK,CAAC;QACZ,eAAU,GAAG,IAAI,YAAY,EAAW,CAAC;QAE5C,kBAAa,GAAa,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAGlC,eAAU,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QAEjD,gBAAW,GAAG,WAAW,CAAC;QAC1B,kBAAa,GAAG,aAAa,CAAC;QAC9B,gBAAW,GAAG,IAAI,eAAe,CAAc,WAAW,CAAC,OAAO,CAAC,CAAC;QACpE,uBAAkB,GAAwB,IAAI,CAAC,WAAW,CAAC,IAAI,CAC7E,GAAG,CAAC,CAAC,UAAuB,EAAE,EAAE,CAC9B,CAAC,WAAW,CAAC,WAAW,EAAE,WAAW,CAAC,cAAc,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC,QAAQ,CACnF,UAAU,CACX,CACF,CACF,CAAC;QACc,uBAAkB,GAAwB,IAAI,CAAC,WAAW,CAAC,IAAI,CAC7E,GAAG,CACD,CAAC,UAAuB,EAAE,EAAE,CAC1B,CAAC,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CACvE,CACF,CAAC;QACc,qBAAgB,GAAwB,IAAI,CAAC,WAAW,CAAC,IAAI,CAC3E,GAAG,CAAC,CAAC,UAAuB,EAAE,EAAE,CAC9B,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,WAAW,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAC7F,CACF,CAAC;QACc,wBAAmB,GAAwB,aAAa,CAAC;YACvE,IAAI,CAAC,WAAW;YAChB,IAAI,CAAC,UAAU;SAChB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,UAAU,KAAK,WAAW,CAAC,OAAO,IAAI,QAAQ,CAAC,CAAC,CAAC;QACzE,qBAAgB,GAAoC,aAAa,CAAC;YAChF,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,mBAAmB,CAAC;YACjD,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,qDAAqD,CAAC;SACpF,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;YACzB,IAAI,EAAE,SAAS;YACf,KAAK;YACL,OAAO;YACP,SAAS,EAAE,KAAK;YAChB,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC,CACJ,CAAC;QACc,uBAAkB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACzD,kBAAa,GAAG,IAAI,eAAe,CAAgB,aAAa,CAAC,MAAM,CAAC,CAAC;QAElF,SAAI,GAAc,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YACrC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,GAAG,EAAO,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAC7D,CAAC,CAAC;QAEK,aAAQ,GAAG,KAAK,CAAC;QAER,iBAAY,GAAG,IAAI,eAAe,CAAoB,EAAE,CAAC,CAAC;QAC1D,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QASnD,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;IAC7C,CAAC;IAEM,QAAQ;QACb,MAAM,OAAO,GAA2B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC9D,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO;SACR;QAED,IAAI,CAAC,cAAc,CAAC,GAAG,CACrB,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,OAAsB,EAAE,EAAE;YACxD,MAAM,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC;YAC3B,IAAI,CAAC,QAAQ,EAAE;gBACb,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACpC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACtB,OAAO;aACR;YAED,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE;gBAC7C,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;gBAC3B,OAAO;aACR;YAED,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QAC5B,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAEM,YAAY,CAAC,kBAA4B;QAC9C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,kBAAkB,IAAI,KAAK,CAAC,CAAC;QAClD,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAEM,WAAW,CAAC,UAAuB;QACxC,MAAM,SAAS,GAAW,KAAK,CAAC,SAAS,CAAC,CAAC,IAAiB,EAAE,EAAE,CAAC,IAAI,KAAK,UAAU,CAAC,GAAG,CAAC,CAAC;QAC1F,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE;YACpB,OAAO;SACR;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;IAC1C,CAAC;IAEM,WAAW,CAAC,UAAuB;QACxC,MAAM,SAAS,GAAW,KAAK,CAAC,SAAS,CAAC,CAAC,IAAiB,EAAE,EAAE,CAAC,IAAI,KAAK,UAAU,CAAC,GAAG,CAAC,CAAC;QAC1F,IAAI,SAAS,KAAK,KAAK,CAAC,MAAM,EAAE;YAC9B,OAAO;SACR;QAED,IAAI,UAAU,KAAK,WAAW,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC5D,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnC,OAAO;SACR;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;QACxC,IAAI,KAAK,CAAC,SAAS,CAAC,KAAK,WAAW,CAAC,WAAW,EAAE;YAChD,OAAO;SACR;QAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAEM,eAAe,CAAC,OAAgB;QACrC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QAExB,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO;SACR;QAED,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEO,WAAW,CAAC,QAA8B;QAChD,MAAM,IAAI,GAAG,QAAQ,EAAE,IAAI,CAAC;QAE5B,IAAI,CAAC,IAAI,EAAE;YACT,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,OAAO;SACR;QACD,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAEhC,MAAM,CAAC,SAAS,GAAG,GAAG,EAAE;YACtB,MAAM,MAAM,GAAG,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;YAChD,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE;gBAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC5B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC/B,OAAO;aACR;YAED,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC/B,CAAC,CAAC;QAEF,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAEO,UAAU,CAAC,QAAkB;QACnC,MAAM,IAAI,GAAG,QAAQ,EAAE,IAAI,CAAC;QAE5B,IAAI,CAAC,IAAI,EAAE;YACT,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC3B,OAAO;SACR;QAED,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,EAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAC,CAAC,CAAC;QACnE,MAAM,EAAE,GAAG,IAAI,QAAQ,EAAE,CAAC;QAC1B,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,YAAY;aACd,IAAI,CACH,SAAS,CAAC,CAAC,IAAuB,EAAE,EAAE,CACpC,IAAI,YAAY,QAAQ;YACtB,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,2BAA2B,CAAC,IAAI,CAAC;YAC7D,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,qCAAqC,CACxD,IAAI,+BAA+B,CAAC,IAAI,CAAC,CAC1C,CACN,EACD,IAAI,CAAC,CAAC,CAAC,CACR;aACA,SAAS,CAAC;YACT,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAClD,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAC7C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC;IAEO,iBAAiB,CAAC,MAAc;QACtC,IAAI;YACF,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;SACpB;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,KAAK,CAAC;SACd;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,aAAa,CAAC,QAAkB;QACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CACnD,2DAA2D,CAC5D,CAAC;QACF,QAAQ,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAClD,0DAA0D,CAC3D,CAAC;IACJ,CAAC;IAEO,UAAU;QAChB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC3C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC9C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACpC,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;QACpC,CAAC,EAAE,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;IACxC,CAAC;+GA9OU,gCAAgC;mGAAhC,gCAAgC,0PCzC7C,wiLAoJA;;4FD3Ga,gCAAgC;kBAN5C,SAAS;+BACE,mCAAmC,mBAG5B,uBAAuB,CAAC,MAAM;4NAGX,KAAK;sBAAxC,SAAS;uBAAC,uBAAuB;gBAEzB,IAAI;sBAAZ,KAAK;gBACI,UAAU;sBAAnB,MAAM","sourcesContent":["/*\n * Copyright 2015-2023 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {AbstractControl, FormBuilder, FormGroup, Validators} from '@angular/forms';\nimport {WarningFilled16} from '@carbon/icons';\nimport {TranslateService} from '@ngx-translate/core';\nimport {CARBON_CONSTANTS, ModalComponent} from '@valtimo/components';\nimport {DocumentDefinitionCreateRequest, DocumentService} from '@valtimo/document';\nimport {FileItem, IconService, NotificationContent} from 'carbon-components-angular';\nimport {BehaviorSubject, combineLatest, map, Observable, Subscription, switchMap, take} from 'rxjs';\nimport {DossierImportService} from '../../services/dossier-import.service';\nimport {STEPS, UPLOAD_STATUS, UPLOAD_STEP} from './dossier-management-upload.constants';\n\n@Component({\n  selector: 'valtimo-dossier-management-upload',\n  templateUrl: './dossier-management-upload.component.html',\n  styleUrls: ['./dossier-management-upload.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DossierManagementUploadComponent implements OnInit, OnDestroy {\n  @ViewChild('uploadDefinitionModal') modal: ModalComponent;\n\n  @Input() open = false;\n  @Output() closeModal = new EventEmitter<boolean>();\n\n  public acceptedFiles: string[] = ['.json', '.zip'];\n  public selectedFile: File | null;\n\n  private readonly _disabled$ = new BehaviorSubject<boolean>(true);\n\n  public readonly UPLOAD_STEP = UPLOAD_STEP;\n  public readonly UPLOAD_STATUS = UPLOAD_STATUS;\n  public readonly activeStep$ = new BehaviorSubject<UPLOAD_STEP>(UPLOAD_STEP.PLUGINS);\n  public readonly backButtonEnabled$: Observable<boolean> = this.activeStep$.pipe(\n    map((activeStep: UPLOAD_STEP) =>\n      [UPLOAD_STEP.FILE_SELECT, UPLOAD_STEP.ACCESS_CONTROL, UPLOAD_STEP.DASHBOARD].includes(\n        activeStep\n      )\n    )\n  );\n  public readonly isStepAfterUpload$: Observable<boolean> = this.activeStep$.pipe(\n    map(\n      (activeStep: UPLOAD_STEP) =>\n        ![UPLOAD_STEP.PLUGINS, UPLOAD_STEP.FILE_SELECT].includes(activeStep)\n    )\n  );\n  public readonly showCloseButton$: Observable<boolean> = this.activeStep$.pipe(\n    map((activeStep: UPLOAD_STEP) =>\n      [UPLOAD_STEP.PLUGINS, UPLOAD_STEP.FILE_SELECT, UPLOAD_STEP.FILE_UPLOAD].includes(activeStep)\n    )\n  );\n  public readonly nextButtonDisabled$: Observable<boolean> = combineLatest([\n    this.activeStep$,\n    this._disabled$,\n  ]).pipe(map(([activeStep, disabled]) => activeStep !== UPLOAD_STEP.PLUGINS && disabled));\n  public readonly notificationObj$: Observable<NotificationContent> = combineLatest([\n    this.translateService.stream('interface.warning'),\n    this.translateService.stream('dossierManagement.importDefinition.overwriteWarning'),\n  ]).pipe(\n    map(([title, message]) => ({\n      type: 'warning',\n      title,\n      message,\n      showClose: false,\n      lowContrast: true,\n    }))\n  );\n  public readonly showCheckboxError$ = new BehaviorSubject<boolean>(false);\n  public readonly uploadStatus$ = new BehaviorSubject<UPLOAD_STATUS>(UPLOAD_STATUS.ACTIVE);\n\n  public form: FormGroup = this.fb.group({\n    file: this.fb.control(new Set<any>(), [Validators.required]),\n  });\n\n  private _checked = false;\n\n  private readonly _importFile$ = new BehaviorSubject<string | FormData>('');\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly documentService: DocumentService,\n    private readonly dossierImportService: DossierImportService,\n    private readonly fb: FormBuilder,\n    private readonly iconService: IconService,\n    private readonly translateService: TranslateService\n  ) {\n    this.iconService.register(WarningFilled16);\n  }\n\n  public ngOnInit(): void {\n    const control: AbstractControl | null = this.form.get('file');\n    if (!control) {\n      return;\n    }\n\n    this._subscriptions.add(\n      control.valueChanges.subscribe((fileSet: Set<FileItem>) => {\n        const [fileItem] = fileSet;\n        if (!fileItem) {\n          this._disabled$.next(true);\n          this.showCheckboxError$.next(false);\n          this._checked = false;\n          return;\n        }\n\n        if (fileItem.file.type === 'application/json') {\n          this.setJsonFile(fileItem);\n          return;\n        }\n\n        this.setZipFile(fileItem);\n      })\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this.resetModal();\n  }\n\n  public onCloseModal(definitionUploaded?: boolean): void {\n    this.closeModal.emit(definitionUploaded ?? false);\n    this.resetModal();\n  }\n\n  public onBackClick(activeStep: UPLOAD_STEP): void {\n    const prevIndex: number = STEPS.findIndex((step: UPLOAD_STEP) => step === activeStep) - 1;\n    if (prevIndex === -1) {\n      return;\n    }\n\n    this.activeStep$.next(STEPS[prevIndex]);\n  }\n\n  public onNextClick(activeStep: UPLOAD_STEP): void {\n    const nextIndex: number = STEPS.findIndex((step: UPLOAD_STEP) => step === activeStep) + 1;\n    if (nextIndex === STEPS.length) {\n      return;\n    }\n\n    if (activeStep === UPLOAD_STEP.FILE_SELECT && !this._checked) {\n      this.showCheckboxError$.next(true);\n      return;\n    }\n\n    this.activeStep$.next(STEPS[nextIndex]);\n    if (STEPS[nextIndex] !== UPLOAD_STEP.FILE_UPLOAD) {\n      return;\n    }\n\n    this.uploadDefinition();\n  }\n\n  public onCheckedChange(checked: boolean): void {\n    this._checked = checked;\n\n    if (!checked) {\n      return;\n    }\n\n    this.showCheckboxError$.next(false);\n  }\n\n  private setJsonFile(fileItem: FileItem | undefined): void {\n    const file = fileItem?.file;\n\n    if (!file) {\n      this.clearJsonString();\n      return;\n    }\n    const reader = new FileReader();\n\n    reader.onloadend = () => {\n      const result = (reader.result ?? '').toString();\n      if (this.stringIsValidJson(result)) {\n        this._disabled$.next(false);\n        this._importFile$.next(result);\n        return;\n      }\n\n      this.clearJsonString();\n      this.setErrorState(fileItem);\n    };\n\n    reader.readAsText(file);\n  }\n\n  private setZipFile(fileItem: FileItem): void {\n    const file = fileItem?.file;\n\n    if (!file) {\n      this._importFile$.next('');\n      return;\n    }\n\n    const blob = new Blob([fileItem.file], {type: fileItem.file.type});\n    const fd = new FormData();\n    fd.append('file', blob, fileItem.file.name);\n    this._importFile$.next(fd);\n    this._disabled$.next(false);\n  }\n\n  private uploadDefinition(): void {\n    this._disabled$.next(true);\n    this._importFile$\n      .pipe(\n        switchMap((file: string | FormData) =>\n          file instanceof FormData\n            ? this.dossierImportService.importDocumentDefinitionZip(file)\n            : this.documentService.createDocumentDefinitionForManagement(\n                new DocumentDefinitionCreateRequest(file)\n              )\n        ),\n        take(1)\n      )\n      .subscribe({\n        next: () => {\n          this._disabled$.next(false);\n          this.uploadStatus$.next(UPLOAD_STATUS.FINISHED);\n        },\n        error: () => {\n          this.uploadStatus$.next(UPLOAD_STATUS.ERROR);\n          this._disabled$.next(false);\n        },\n      });\n  }\n\n  private clearJsonString(): void {\n    this._importFile$.next('');\n  }\n\n  private stringIsValidJson(string: string) {\n    try {\n      JSON.parse(string);\n    } catch (e) {\n      return false;\n    }\n    return true;\n  }\n\n  private setErrorState(fileItem: FileItem): void {\n    this._disabled$.next(true);\n    fileItem.invalid = true;\n    fileItem.invalidTitle = this.translateService.instant(\n      'dossierManagement.importDefinition.invalidJsonError.title'\n    );\n    fileItem.invalidText = this.translateService.instant(\n      'dossierManagement.importDefinition.invalidJsonError.text'\n    );\n  }\n\n  private resetModal(): void {\n    setTimeout(() => {\n      this.activeStep$.next(UPLOAD_STEP.PLUGINS);\n      this.uploadStatus$.next(UPLOAD_STATUS.ACTIVE);\n      this.showCheckboxError$.next(false);\n      this._subscriptions.unsubscribe();\n    }, CARBON_CONSTANTS.modalAnimationMs);\n  }\n}\n","<!--\n  ~ Copyright 2015-2023 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  *ngIf=\"{\n    activeStep: activeStep$ | async,\n    backButtonEnabled: backButtonEnabled$ | async,\n    isStepAfterUpload: isStepAfterUpload$ | async,\n    nextButtonDisabled: nextButtonDisabled$ | async,\n    notificationObj: notificationObj$ | async,\n    showCheckboxError: showCheckboxError$ | async,\n    showCloseButton: showCloseButton$ | async,\n    uploadStatus: uploadStatus$ | async\n  } as obs\"\n  valtimoCdsModal\n  [open]=\"open\"\n  showFooter=\"true\"\n  class=\"valtimo-definition-uploader\"\n  (close)=\"onCloseModal()\"\n>\n  <cds-modal-header\n    [showCloseButton]=\"obs.showCloseButton\"\n    (closeSelect)=\"onCloseModal(obs.isStepAfterUpload && obs.uploadStatus !== UPLOAD_STATUS.ERROR)\"\n  >\n    <h3 cdsModalHeaderHeading>\n      {{ 'dossierManagement.importDefinition.title' | translate }}\n    </h3>\n  </cds-modal-header>\n\n  <section [ngSwitch]=\"obs.activeStep\" cdsModalContent class=\"valtimo-definition-uploader__content\">\n    <ng-template ngSwitchDefault>\n      <valtimo-dossier-management-upload-step\n        [message]=\"\n          'dossierManagement.importDefinition.steps.' + obs.activeStep + '.message' | translate\n        \"\n        [title]=\"\n          'dossierManagement.importDefinition.steps.' + obs.activeStep + '.title' | translate\n        \"\n        [illustration]=\"'valtimo-layout/img/' + obs.activeStep + '.svg'\"\n      >\n      </valtimo-dossier-management-upload-step>\n    </ng-template>\n\n    <form *ngSwitchCase=\"UPLOAD_STEP.FILE_SELECT\" [formGroup]=\"form\">\n      <cds-file-uploader\n        [accept]=\"acceptedFiles\"\n        [buttonText]=\"'dossierManagement.importDefinition.upload.buttonText' | translate\"\n        [description]=\"'dossierManagement.importDefinition.upload.description' | translate\"\n        [multiple]=\"false\"\n        [title]=\"'dossierManagement.importDefinition.upload.title' | translate\"\n        buttonType=\"primary\"\n        data-carbon-theme=\"g10\"\n        formControlName=\"file\"\n        class=\"valtimo-definition-uploader__file-uploader\"\n      >\n      </cds-file-uploader>\n\n      <ng-container *ngIf=\"!obs.nextButtonDisabled\">\n        <cds-inline-notification [notificationObj]=\"obs.notificationObj\"></cds-inline-notification>\n\n        <div class=\"valtimo-uploader__checkbox\">\n          <cds-checkbox\n            [class.valtimo-definition-uploader__checkbox--invalid]=\"obs.showCheckboxError\"\n            (checkedChange)=\"onCheckedChange($event)\"\n          >\n            {{ 'dossierManagement.importDefinition.checkbox.message' | translate }}\n          </cds-checkbox>\n\n          <div *ngIf=\"obs.showCheckboxError\" class=\"valtimo-definition-uploader__error\">\n            <svg cdsIcon=\"warning--filled\" size=\"16\"></svg>\n\n            {{ 'dossierManagement.importDefinition.checkbox.error' | translate }}\n          </div>\n        </div>\n      </ng-container>\n    </form>\n\n    <cds-progress-bar\n      *ngSwitchCase=\"UPLOAD_STEP.FILE_UPLOAD\"\n      class=\"valtimo-definition-uploader__progress-bar\"\n      [label]=\"'dossierManagement.importDefinition.progressBar.label' | translate\"\n      [status]=\"obs.uploadStatus\"\n      [helperText]=\"\n        'dossierManagement.importDefinition.progressBar.' + obs.uploadStatus | translate\n      \"\n    ></cds-progress-bar>\n  </section>\n\n  <cds-modal-footer\n    class=\"valtimo-definition-uploader__footer\"\n    [class.valtimo-definition-uploader__footer--double]=\"obs.activeStep === UPLOAD_STEP.PLUGINS\"\n  >\n    <button\n      *ngIf=\"obs.uploadStatus !== UPLOAD_STATUS.ERROR && obs.activeStep !== UPLOAD_STEP.FILE_UPLOAD\"\n      class=\"valtimo-definition-uploader__cancel\"\n      cdsButton=\"ghost\"\n      (click)=\"onCloseModal(obs.isStepAfterUpload)\"\n    >\n      {{ (obs.isStepAfterUpload ? 'interface.skip' : 'interface.cancel') | translate }}\n    </button>\n\n    <div class=\"valtimo-definition-uploader__actions\">\n      <button\n        *ngIf=\"obs.backButtonEnabled\"\n        cdsButton=\"secondary\"\n        (click)=\"onBackClick(obs.activeStep)\"\n      >\n        {{ 'interface.back' | translate }}\n      </button>\n\n      <button\n        *ngIf=\"obs.uploadStatus !== UPLOAD_STATUS.ERROR && obs.activeStep !== UPLOAD_STEP.DASHBOARD\"\n        cdsButton=\"primary\"\n        [disabled]=\"obs.nextButtonDisabled\"\n        (click)=\"onNextClick(obs.activeStep)\"\n      >\n        {{\n          (obs.activeStep === UPLOAD_STEP.FILE_SELECT\n            ? 'dossierManagement.importDefinition.startUpload'\n            : 'interface.next'\n          ) | translate\n        }}\n      </button>\n\n      <button\n        *ngIf=\"obs.uploadStatus === UPLOAD_STATUS.ERROR || obs.activeStep === UPLOAD_STEP.DASHBOARD\"\n        class=\"valtimo-definition-uploader__cancel\"\n        cdsButton=\"primary\"\n        (click)=\"onCloseModal(true)\"\n      >\n        {{ 'interface.finish' | translate }}\n      </button>\n    </div>\n  </cds-modal-footer>\n</cds-modal>\n"]}
@@ -0,0 +1,23 @@
1
+ var UPLOAD_STATUS;
2
+ (function (UPLOAD_STATUS) {
3
+ UPLOAD_STATUS["ACTIVE"] = "active";
4
+ UPLOAD_STATUS["ERROR"] = "error";
5
+ UPLOAD_STATUS["FINISHED"] = "finished";
6
+ })(UPLOAD_STATUS || (UPLOAD_STATUS = {}));
7
+ var UPLOAD_STEP;
8
+ (function (UPLOAD_STEP) {
9
+ UPLOAD_STEP["ACCESS_CONTROL"] = "accessControl";
10
+ UPLOAD_STEP["DASHBOARD"] = "dashboard";
11
+ UPLOAD_STEP["FILE_SELECT"] = "fileSelect";
12
+ UPLOAD_STEP["FILE_UPLOAD"] = "fileUpload";
13
+ UPLOAD_STEP["PLUGINS"] = "plugins";
14
+ })(UPLOAD_STEP || (UPLOAD_STEP = {}));
15
+ const STEPS = [
16
+ UPLOAD_STEP.PLUGINS,
17
+ UPLOAD_STEP.FILE_SELECT,
18
+ UPLOAD_STEP.FILE_UPLOAD,
19
+ UPLOAD_STEP.ACCESS_CONTROL,
20
+ UPLOAD_STEP.DASHBOARD,
21
+ ];
22
+ export { STEPS, UPLOAD_STATUS, UPLOAD_STEP };
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9zc2llci1tYW5hZ2VtZW50LXVwbG9hZC5jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0aW1vL2Rvc3NpZXItbWFuYWdlbWVudC9zcmMvbGliL2NvbXBvbmVudHMvZG9zc2llci1tYW5hZ2VtZW50LXVwbG9hZC9kb3NzaWVyLW1hbmFnZW1lbnQtdXBsb2FkLmNvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxJQUFLLGFBSUo7QUFKRCxXQUFLLGFBQWE7SUFDaEIsa0NBQWlCLENBQUE7SUFDakIsZ0NBQWUsQ0FBQTtJQUNmLHNDQUFxQixDQUFBO0FBQ3ZCLENBQUMsRUFKSSxhQUFhLEtBQWIsYUFBYSxRQUlqQjtBQUVELElBQUssV0FNSjtBQU5ELFdBQUssV0FBVztJQUNkLCtDQUFnQyxDQUFBO0lBQ2hDLHNDQUF1QixDQUFBO0lBQ3ZCLHlDQUEwQixDQUFBO0lBQzFCLHlDQUEwQixDQUFBO0lBQzFCLGtDQUFtQixDQUFBO0FBQ3JCLENBQUMsRUFOSSxXQUFXLEtBQVgsV0FBVyxRQU1mO0FBRUQsTUFBTSxLQUFLLEdBQUc7SUFDWixXQUFXLENBQUMsT0FBTztJQUNuQixXQUFXLENBQUMsV0FBVztJQUN2QixXQUFXLENBQUMsV0FBVztJQUN2QixXQUFXLENBQUMsY0FBYztJQUMxQixXQUFXLENBQUMsU0FBUztDQUN0QixDQUFDO0FBRUYsT0FBTyxFQUFDLEtBQUssRUFBRSxhQUFhLEVBQUUsV0FBVyxFQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJlbnVtIFVQTE9BRF9TVEFUVVMge1xuICBBQ1RJVkUgPSAnYWN0aXZlJyxcbiAgRVJST1IgPSAnZXJyb3InLFxuICBGSU5JU0hFRCA9ICdmaW5pc2hlZCcsXG59XG5cbmVudW0gVVBMT0FEX1NURVAge1xuICBBQ0NFU1NfQ09OVFJPTCA9ICdhY2Nlc3NDb250cm9sJyxcbiAgREFTSEJPQVJEID0gJ2Rhc2hib2FyZCcsXG4gIEZJTEVfU0VMRUNUID0gJ2ZpbGVTZWxlY3QnLFxuICBGSUxFX1VQTE9BRCA9ICdmaWxlVXBsb2FkJyxcbiAgUExVR0lOUyA9ICdwbHVnaW5zJyxcbn1cblxuY29uc3QgU1RFUFMgPSBbXG4gIFVQTE9BRF9TVEVQLlBMVUdJTlMsXG4gIFVQTE9BRF9TVEVQLkZJTEVfU0VMRUNULFxuICBVUExPQURfU1RFUC5GSUxFX1VQTE9BRCxcbiAgVVBMT0FEX1NURVAuQUNDRVNTX0NPTlRST0wsXG4gIFVQTE9BRF9TVEVQLkRBU0hCT0FSRCxcbl07XG5cbmV4cG9ydCB7U1RFUFMsIFVQTE9BRF9TVEFUVVMsIFVQTE9BRF9TVEVQfTtcbiJdfQ==
@@ -0,0 +1,17 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class DossierManagementUploadStepComponent {
4
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierManagementUploadStepComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DossierManagementUploadStepComponent, selector: "valtimo-dossier-management-upload-step", inputs: { illustration: "illustration", message: "message", title: "title" }, ngImport: i0, template: "<div class=\"valtimo-upload-step__content\">\n <div class=\"valtimo-upload-step__title\">{{ title }}</div>\n\n <div class=\"valtimo-upload-step__message\">{{ message }}</div>\n</div>\n\n<img [src]=\"illustration\" alt=\"{{ illustration }}\" class=\"valtimo-upload-step__illustration\" />\n", styles: [":host{display:flex;justify-content:space-around;align-items:center;gap:32px;height:100%}:host label{color:unset}.valtimo-upload-step__content{display:flex;flex-direction:column;gap:16px}.valtimo-upload-step__title{font-weight:600;font-size:16px}.valtimo-upload-step__message{font-size:16px;line-height:28px}.valtimo-upload-step__illustration{max-width:200px}\n"] }); }
6
+ }
7
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierManagementUploadStepComponent, decorators: [{
8
+ type: Component,
9
+ args: [{ selector: 'valtimo-dossier-management-upload-step', template: "<div class=\"valtimo-upload-step__content\">\n <div class=\"valtimo-upload-step__title\">{{ title }}</div>\n\n <div class=\"valtimo-upload-step__message\">{{ message }}</div>\n</div>\n\n<img [src]=\"illustration\" alt=\"{{ illustration }}\" class=\"valtimo-upload-step__illustration\" />\n", styles: [":host{display:flex;justify-content:space-around;align-items:center;gap:32px;height:100%}:host label{color:unset}.valtimo-upload-step__content{display:flex;flex-direction:column;gap:16px}.valtimo-upload-step__title{font-weight:600;font-size:16px}.valtimo-upload-step__message{font-size:16px;line-height:28px}.valtimo-upload-step__illustration{max-width:200px}\n"] }]
10
+ }], propDecorators: { illustration: [{
11
+ type: Input
12
+ }], message: [{
13
+ type: Input
14
+ }], title: [{
15
+ type: Input
16
+ }] } });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9zc2llci1tYW5hZ2VtZW50LXVwbG9hZC1zdGVwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vZG9zc2llci1tYW5hZ2VtZW50L3NyYy9saWIvY29tcG9uZW50cy9kb3NzaWVyLW1hbmFnZW1lbnQtdXBsb2FkL3N0ZXAvZG9zc2llci1tYW5hZ2VtZW50LXVwbG9hZC1zdGVwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vZG9zc2llci1tYW5hZ2VtZW50L3NyYy9saWIvY29tcG9uZW50cy9kb3NzaWVyLW1hbmFnZW1lbnQtdXBsb2FkL3N0ZXAvZG9zc2llci1tYW5hZ2VtZW50LXVwbG9hZC1zdGVwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQU8vQyxNQUFNLE9BQU8sb0NBQW9DOytHQUFwQyxvQ0FBb0M7bUdBQXBDLG9DQUFvQyw0SkNQakQscVNBT0E7OzRGREFhLG9DQUFvQztrQkFMaEQsU0FBUzsrQkFDRSx3Q0FBd0M7OEJBS3pDLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbHRpbW8tZG9zc2llci1tYW5hZ2VtZW50LXVwbG9hZC1zdGVwJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Rvc3NpZXItbWFuYWdlbWVudC11cGxvYWQtc3RlcC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Rvc3NpZXItbWFuYWdlbWVudC11cGxvYWQtc3RlcC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBEb3NzaWVyTWFuYWdlbWVudFVwbG9hZFN0ZXBDb21wb25lbnQge1xuICBASW5wdXQoKSBpbGx1c3RyYXRpb24hOiBzdHJpbmc7XG4gIEBJbnB1dCgpIG1lc3NhZ2UhOiBzdHJpbmc7XG4gIEBJbnB1dCgpIHRpdGxlITogc3RyaW5nO1xufVxuIiwiPGRpdiBjbGFzcz1cInZhbHRpbW8tdXBsb2FkLXN0ZXBfX2NvbnRlbnRcIj5cbiAgPGRpdiBjbGFzcz1cInZhbHRpbW8tdXBsb2FkLXN0ZXBfX3RpdGxlXCI+e3sgdGl0bGUgfX08L2Rpdj5cblxuICA8ZGl2IGNsYXNzPVwidmFsdGltby11cGxvYWQtc3RlcF9fbWVzc2FnZVwiPnt7IG1lc3NhZ2UgfX08L2Rpdj5cbjwvZGl2PlxuXG48aW1nIFtzcmNdPVwiaWxsdXN0cmF0aW9uXCIgYWx0PVwie3sgaWxsdXN0cmF0aW9uIH19XCIgY2xhc3M9XCJ2YWx0aW1vLXVwbG9hZC1zdGVwX19pbGx1c3RyYXRpb25cIiAvPlxuIl19