@dsivd/prestations-ng 15.5.2 → 15.5.3

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 (22) hide show
  1. package/CHANGELOG.md +29 -0
  2. package/dsivd-prestations-ng-v15.5.3.tgz +0 -0
  3. package/esm2020/foehn-input-date-time/foehn-input-date-time.component.mjs +7 -3
  4. package/esm2020/foehn-status-progress-bar/foehn-status-progress-bar.component.mjs +11 -6
  5. package/esm2020/foehn-upload/foehn-bo-multi-upload/bo-multi-upload.service.mjs +14 -6
  6. package/esm2020/foehn-upload/foehn-bo-multi-upload/foehn-bo-multi-upload.component.mjs +15 -8
  7. package/esm2020/foehn-upload/foehn-bo-multi-upload/foehn-bo-multi-upload.module.mjs +8 -4
  8. package/esm2020/foehn-upload/foehn-multi-upload/foehn-multi-upload.component.mjs +9 -3
  9. package/esm2020/foehn-upload/foehn-picture-upload/foehn-picture-upload.component.mjs +15 -8
  10. package/esm2020/foehn-upload/foehn-picture-upload/foehn-picture-upload.module.mjs +8 -4
  11. package/esm2020/supported-browser.mjs +2 -2
  12. package/fesm2015/dsivd-prestations-ng.mjs +63 -28
  13. package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
  14. package/fesm2020/dsivd-prestations-ng.mjs +62 -28
  15. package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
  16. package/foehn-input-date-time/foehn-input-date-time.component.d.ts +1 -0
  17. package/foehn-status-progress-bar/foehn-status-progress-bar.component.d.ts +1 -1
  18. package/foehn-upload/foehn-bo-multi-upload/bo-multi-upload.service.d.ts +3 -1
  19. package/foehn-upload/foehn-bo-multi-upload/foehn-bo-multi-upload.module.d.ts +2 -1
  20. package/foehn-upload/foehn-picture-upload/foehn-picture-upload.module.d.ts +2 -1
  21. package/package.json +1 -1
  22. package/dsivd-prestations-ng-v15.5.2.tgz +0 -0
package/CHANGELOG.md CHANGED
@@ -26,6 +26,35 @@ A change is considered **breaking** if you have to change your code or update yo
26
26
 
27
27
  ---
28
28
 
29
+ ## [15.5.3]
30
+
31
+ ### Added
32
+
33
+ - [foehn-bo-multi-upload.component.html](projects/prestations-ng/src/foehn-upload/foehn-bo-multi-upload/foehn-bo-multi-upload.component.html)
34
+ - Added `<foehn-upload-progress-bar></foehn-upload-progress-bar>`
35
+
36
+ - [foehn-status-progress-bar.component.ts](projects/prestations-ng/src/foehn-status-progress-bar/foehn-status-progress-bar.component.ts)
37
+ - In your application routing module, you can force page to be in step 2 (Verification)
38
+
39
+ ```diff
40
+ data: {
41
+ order: 3,
42
+ + isStep2: true
43
+ }
44
+ ```
45
+
46
+ ### Fixed
47
+
48
+ - [foehn-multi-upload.component.ts](projects/prestations-ng/src/foehn-upload/foehn-multi-upload/foehn-multi-upload.component.ts)
49
+ - Now provides `MultiUploadService` and `UploadProgressService` to avoid using a singleton
50
+
51
+ - [foehn-bo-multi-upload.component.ts](projects/prestations-ng/src/foehn-upload/foehn-bo-multi-upload/foehn-bo-multi-upload.component.ts)
52
+ - Now provides `BoMultiUploadService` and `UploadProgressService` to avoid using a singleton
53
+
54
+ - [foehn-input-date-time.component.ts](projects/prestations-ng/src/foehn-input-date-time/foehn-input-date-time.component.ts)
55
+ - [foehn-input-date-time.component.html](projects/prestations-ng/src/foehn-input-date-time/foehn-input-date-time.component.html)
56
+ - Fixed date picker not selecting nor updating model after first selection
57
+
29
58
  ## [15.5.2]
30
59
 
31
60
  ### Updated
Binary file
@@ -69,6 +69,10 @@ export class FoehnDateTimeComponent extends FoehnInputComponent {
69
69
  handleUserInputTime(value) {
70
70
  this.userInputTimeSubject.next(value);
71
71
  }
72
+ handleUserInputDate() {
73
+ this.updateDateTime();
74
+ this.handleUserInput();
75
+ }
72
76
  onModelChange(value) {
73
77
  if (value && value.length >= 5) {
74
78
  this.date = value.slice(0, 3);
@@ -113,7 +117,7 @@ FoehnDateTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0",
113
117
  useExisting: forwardRef(() => FoehnDateTimeComponent),
114
118
  multi: true
115
119
  }
116
- ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"row\">\n <div\n [attr.id]=\"buildId() + 'MainColumn'\"\n [ngClass]=\"\n hideDatePickerButton\n ? 'col-lg-7 col-md-9'\n : 'col-lg-8 col-md-10'\n \"\n >\n <div class=\"row\">\n <div\n [attr.id]=\"buildId() + 'DateColumn'\"\n class=\"col-sm-7 pr-sm-0\"\n >\n <foehn-input-date\n [id]=\"buildId() + '_date'\"\n [name]=\"name + '_date'\"\n [(model)]=\"date\"\n [disableDay]=\"disableDay\"\n [disableMonth]=\"disableMonth\"\n [disableYear]=\"disableYear\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [hideDatePickerButton]=\"hideDatePickerButton\"\n (modelChange)=\"updateDateTime()\"\n (userInput)=\"handleUserInput()\"\n [disabled]=\"disabled\"\n [hideNotRequiredExtraLabel]=\"true\"\n ></foehn-input-date>\n </div>\n <div\n [attr.id]=\"buildId() + 'TimeColumn'\"\n class=\"col-sm-5 pl-sm-0\"\n >\n <foehn-input-time\n [id]=\"buildId() + '_time'\"\n [name]=\"name + '_date'\"\n [(model)]=\"time\"\n (modelChange)=\"timeModelChange($event)\"\n (userInput)=\"handleUserInputTime($event)\"\n [disabled]=\"disabled\"\n [hideNotRequiredExtraLabel]=\"true\"\n ></foehn-input-time>\n </div>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnDateComponent, selector: "foehn-input-date", inputs: ["disableDay", "disableMonth", "disableYear", "minDate", "maxDate", "hideDatePickerButton"] }, { type: i3.FoehnTimeComponent, selector: "foehn-input-time" }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe } });
120
+ ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"row\">\n <div\n [attr.id]=\"buildId() + 'MainColumn'\"\n [ngClass]=\"\n hideDatePickerButton\n ? 'col-lg-7 col-md-9'\n : 'col-lg-8 col-md-10'\n \"\n >\n <div class=\"row\">\n <div\n [attr.id]=\"buildId() + 'DateColumn'\"\n class=\"col-sm-7 pr-sm-0\"\n >\n <foehn-input-date\n [id]=\"buildId() + '_date'\"\n [name]=\"name + '_date'\"\n [(model)]=\"date\"\n [disableDay]=\"disableDay\"\n [disableMonth]=\"disableMonth\"\n [disableYear]=\"disableYear\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [hideDatePickerButton]=\"hideDatePickerButton\"\n (userInput)=\"handleUserInputDate()\"\n [disabled]=\"disabled\"\n [hideNotRequiredExtraLabel]=\"true\"\n ></foehn-input-date>\n </div>\n <div\n [attr.id]=\"buildId() + 'TimeColumn'\"\n class=\"col-sm-5 pl-sm-0\"\n >\n <foehn-input-time\n [id]=\"buildId() + '_time'\"\n [name]=\"name + '_date'\"\n [(model)]=\"time\"\n (modelChange)=\"timeModelChange($event)\"\n (userInput)=\"handleUserInputTime($event)\"\n [disabled]=\"disabled\"\n [hideNotRequiredExtraLabel]=\"true\"\n ></foehn-input-time>\n </div>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnDateComponent, selector: "foehn-input-date", inputs: ["disableDay", "disableMonth", "disableYear", "minDate", "maxDate", "hideDatePickerButton"] }, { type: i3.FoehnTimeComponent, selector: "foehn-input-time" }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe } });
117
121
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: FoehnDateTimeComponent, decorators: [{
118
122
  type: Component,
119
123
  args: [{ selector: 'foehn-input-date-time', providers: [
@@ -122,7 +126,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
122
126
  useExisting: forwardRef(() => FoehnDateTimeComponent),
123
127
  multi: true
124
128
  }
125
- ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"row\">\n <div\n [attr.id]=\"buildId() + 'MainColumn'\"\n [ngClass]=\"\n hideDatePickerButton\n ? 'col-lg-7 col-md-9'\n : 'col-lg-8 col-md-10'\n \"\n >\n <div class=\"row\">\n <div\n [attr.id]=\"buildId() + 'DateColumn'\"\n class=\"col-sm-7 pr-sm-0\"\n >\n <foehn-input-date\n [id]=\"buildId() + '_date'\"\n [name]=\"name + '_date'\"\n [(model)]=\"date\"\n [disableDay]=\"disableDay\"\n [disableMonth]=\"disableMonth\"\n [disableYear]=\"disableYear\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [hideDatePickerButton]=\"hideDatePickerButton\"\n (modelChange)=\"updateDateTime()\"\n (userInput)=\"handleUserInput()\"\n [disabled]=\"disabled\"\n [hideNotRequiredExtraLabel]=\"true\"\n ></foehn-input-date>\n </div>\n <div\n [attr.id]=\"buildId() + 'TimeColumn'\"\n class=\"col-sm-5 pl-sm-0\"\n >\n <foehn-input-time\n [id]=\"buildId() + '_time'\"\n [name]=\"name + '_date'\"\n [(model)]=\"time\"\n (modelChange)=\"timeModelChange($event)\"\n (userInput)=\"handleUserInputTime($event)\"\n [disabled]=\"disabled\"\n [hideNotRequiredExtraLabel]=\"true\"\n ></foehn-input-time>\n </div>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n" }]
129
+ ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"row\">\n <div\n [attr.id]=\"buildId() + 'MainColumn'\"\n [ngClass]=\"\n hideDatePickerButton\n ? 'col-lg-7 col-md-9'\n : 'col-lg-8 col-md-10'\n \"\n >\n <div class=\"row\">\n <div\n [attr.id]=\"buildId() + 'DateColumn'\"\n class=\"col-sm-7 pr-sm-0\"\n >\n <foehn-input-date\n [id]=\"buildId() + '_date'\"\n [name]=\"name + '_date'\"\n [(model)]=\"date\"\n [disableDay]=\"disableDay\"\n [disableMonth]=\"disableMonth\"\n [disableYear]=\"disableYear\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [hideDatePickerButton]=\"hideDatePickerButton\"\n (userInput)=\"handleUserInputDate()\"\n [disabled]=\"disabled\"\n [hideNotRequiredExtraLabel]=\"true\"\n ></foehn-input-date>\n </div>\n <div\n [attr.id]=\"buildId() + 'TimeColumn'\"\n class=\"col-sm-5 pl-sm-0\"\n >\n <foehn-input-time\n [id]=\"buildId() + '_time'\"\n [name]=\"name + '_date'\"\n [(model)]=\"time\"\n (modelChange)=\"timeModelChange($event)\"\n (userInput)=\"handleUserInputTime($event)\"\n [disabled]=\"disabled\"\n [hideNotRequiredExtraLabel]=\"true\"\n ></foehn-input-time>\n </div>\n </div>\n </div>\n </div>\n </fieldset>\n</div>\n" }]
126
130
  }], ctorParameters: function () { return []; }, propDecorators: { disableDay: [{
127
131
  type: Input
128
132
  }], disableMonth: [{
@@ -136,4 +140,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImpo
136
140
  }], hideDatePickerButton: [{
137
141
  type: Input
138
142
  }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-date-time.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input-date-time/foehn-input-date-time.component.ts","../../../../projects/prestations-ng/src/foehn-input-date-time/foehn-input-date-time.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnDestroy } from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { combineLatest, Subject, Subscription } from 'rxjs';\nimport { debounceTime, filter } from 'rxjs/operators';\n\n/**\n * @param num as string\n * @returns string\n */\n// eslint-disable-next-line prefer-arrow/prefer-arrow-functions\nfunction leftPad(num: string): string {\n    if (num === undefined || num === null) {\n        return '';\n    }\n    if (num.length < 2) {\n        return `0${num}`;\n    }\n    return num;\n}\n\n@Component({\n    selector: 'foehn-input-date-time',\n    templateUrl: './foehn-input-date-time.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnDateTimeComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnDateTimeComponent\n    extends FoehnInputComponent<number[]>\n    implements OnDestroy {\n    @Input()\n    disableDay = false;\n\n    @Input()\n    disableMonth = false;\n\n    @Input()\n    disableYear = false;\n\n    @Input()\n    minDate: number[];\n\n    @Input()\n    maxDate: number[];\n\n    @Input()\n    hideDatePickerButton = false;\n\n    date: number[] = null;\n    time: string = null;\n\n    private userInputTimeSubject = new Subject<string>();\n    private timeModelChangeSubject = new Subject<string>();\n\n    private readonly userInputTimeSubscription: Subscription;\n\n    constructor() {\n        super();\n\n        // We need to wait for foehn-input-time modelChange to be fired as it is done on 'focusOut'\n        // otherwise userInput value and time model are not synchronized\n        this.userInputTimeSubscription = combineLatest([\n            this.userInputTimeSubject.asObservable(),\n            this.timeModelChangeSubject.asObservable()\n        ])\n            .pipe(\n                debounceTime(0),\n                filter(\n                    ([userInputTime, timeModel]) => userInputTime === timeModel\n                )\n            )\n            .subscribe(() => {\n                this.handleUserInput();\n            });\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        if (!!this.userInputTimeSubscription) {\n            this.userInputTimeSubscription.unsubscribe();\n        }\n    }\n\n    updateDateTime(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    timeModelChange(value: string): void {\n        this.updateDateTime();\n        this.timeModelChangeSubject.next(value);\n    }\n\n    handleUserInputTime(value: string): void {\n        this.userInputTimeSubject.next(value);\n    }\n\n    onModelChange(value: number[]): void {\n        if (value && value.length >= 5) {\n            this.date = value.slice(0, 3);\n            this.time = `${leftPad(this.toString(value[3]))}:${leftPad(\n                this.toString(value[4])\n            )}`;\n        } else if (!value) {\n            this.date = null;\n            this.time = null;\n        }\n    }\n\n    getValidValue(): number[] | null | undefined {\n        if (this.isEmpty(this.date) && this.isEmpty(this.time)) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        const result: number[] = [null, null, null, null, null];\n        if (!!this.date) {\n            result[0] = this.date[0];\n            result[1] = this.date[1];\n            result[2] = this.date[2];\n        }\n        const timeParts = !!this.time ? this.time.split(':') : null;\n        if (timeParts) {\n            result[3] = this.toNumber(timeParts[0]);\n            result[4] = this.toNumber(timeParts[1]);\n        }\n        return result;\n    }\n\n    private toNumber(str: string): number {\n        return str ? Number(str) : null;\n    }\n\n    private toString(num: number): string {\n        return num ? num.toString() : null;\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <fieldset\n        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"row\">\n            <div\n                [attr.id]=\"buildId() + 'MainColumn'\"\n                [ngClass]=\"\n                    hideDatePickerButton\n                        ? 'col-lg-7 col-md-9'\n                        : 'col-lg-8 col-md-10'\n                \"\n            >\n                <div class=\"row\">\n                    <div\n                        [attr.id]=\"buildId() + 'DateColumn'\"\n                        class=\"col-sm-7 pr-sm-0\"\n                    >\n                        <foehn-input-date\n                            [id]=\"buildId() + '_date'\"\n                            [name]=\"name + '_date'\"\n                            [(model)]=\"date\"\n                            [disableDay]=\"disableDay\"\n                            [disableMonth]=\"disableMonth\"\n                            [disableYear]=\"disableYear\"\n                            [minDate]=\"minDate\"\n                            [maxDate]=\"maxDate\"\n                            [hideDatePickerButton]=\"hideDatePickerButton\"\n                            (modelChange)=\"updateDateTime()\"\n                            (userInput)=\"handleUserInput()\"\n                            [disabled]=\"disabled\"\n                            [hideNotRequiredExtraLabel]=\"true\"\n                        ></foehn-input-date>\n                    </div>\n                    <div\n                        [attr.id]=\"buildId() + 'TimeColumn'\"\n                        class=\"col-sm-5 pl-sm-0\"\n                    >\n                        <foehn-input-time\n                            [id]=\"buildId() + '_time'\"\n                            [name]=\"name + '_date'\"\n                            [(model)]=\"time\"\n                            (modelChange)=\"timeModelChange($event)\"\n                            (userInput)=\"handleUserInputTime($event)\"\n                            [disabled]=\"disabled\"\n                            [hideNotRequiredExtraLabel]=\"true\"\n                        ></foehn-input-time>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
143
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-date-time.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input-date-time/foehn-input-date-time.component.ts","../../../../projects/prestations-ng/src/foehn-input-date-time/foehn-input-date-time.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnDestroy } from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { combineLatest, Subject, Subscription } from 'rxjs';\nimport { debounceTime, filter } from 'rxjs/operators';\n\n/**\n * @param num as string\n * @returns string\n */\n// eslint-disable-next-line prefer-arrow/prefer-arrow-functions\nfunction leftPad(num: string): string {\n    if (num === undefined || num === null) {\n        return '';\n    }\n    if (num.length < 2) {\n        return `0${num}`;\n    }\n    return num;\n}\n\n@Component({\n    selector: 'foehn-input-date-time',\n    templateUrl: './foehn-input-date-time.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnDateTimeComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnDateTimeComponent\n    extends FoehnInputComponent<number[]>\n    implements OnDestroy {\n    @Input()\n    disableDay = false;\n\n    @Input()\n    disableMonth = false;\n\n    @Input()\n    disableYear = false;\n\n    @Input()\n    minDate: number[];\n\n    @Input()\n    maxDate: number[];\n\n    @Input()\n    hideDatePickerButton = false;\n\n    date: number[] = null;\n    time: string = null;\n\n    private userInputTimeSubject = new Subject<string>();\n    private timeModelChangeSubject = new Subject<string>();\n\n    private readonly userInputTimeSubscription: Subscription;\n\n    constructor() {\n        super();\n\n        // We need to wait for foehn-input-time modelChange to be fired as it is done on 'focusOut'\n        // otherwise userInput value and time model are not synchronized\n        this.userInputTimeSubscription = combineLatest([\n            this.userInputTimeSubject.asObservable(),\n            this.timeModelChangeSubject.asObservable()\n        ])\n            .pipe(\n                debounceTime(0),\n                filter(\n                    ([userInputTime, timeModel]) => userInputTime === timeModel\n                )\n            )\n            .subscribe(() => {\n                this.handleUserInput();\n            });\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        if (!!this.userInputTimeSubscription) {\n            this.userInputTimeSubscription.unsubscribe();\n        }\n    }\n\n    updateDateTime(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    timeModelChange(value: string): void {\n        this.updateDateTime();\n        this.timeModelChangeSubject.next(value);\n    }\n\n    handleUserInputTime(value: string): void {\n        this.userInputTimeSubject.next(value);\n    }\n\n    handleUserInputDate(): void {\n        this.updateDateTime();\n        this.handleUserInput();\n    }\n\n    onModelChange(value: number[]): void {\n        if (value && value.length >= 5) {\n            this.date = value.slice(0, 3);\n            this.time = `${leftPad(this.toString(value[3]))}:${leftPad(\n                this.toString(value[4])\n            )}`;\n        } else if (!value) {\n            this.date = null;\n            this.time = null;\n        }\n    }\n\n    getValidValue(): number[] | null | undefined {\n        if (this.isEmpty(this.date) && this.isEmpty(this.time)) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        const result: number[] = [null, null, null, null, null];\n        if (!!this.date) {\n            result[0] = this.date[0];\n            result[1] = this.date[1];\n            result[2] = this.date[2];\n        }\n        const timeParts = !!this.time ? this.time.split(':') : null;\n        if (timeParts) {\n            result[3] = this.toNumber(timeParts[0]);\n            result[4] = this.toNumber(timeParts[1]);\n        }\n        return result;\n    }\n\n    private toNumber(str: string): number {\n        return str ? Number(str) : null;\n    }\n\n    private toString(num: number): string {\n        return num ? num.toString() : null;\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <fieldset\n        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"row\">\n            <div\n                [attr.id]=\"buildId() + 'MainColumn'\"\n                [ngClass]=\"\n                    hideDatePickerButton\n                        ? 'col-lg-7 col-md-9'\n                        : 'col-lg-8 col-md-10'\n                \"\n            >\n                <div class=\"row\">\n                    <div\n                        [attr.id]=\"buildId() + 'DateColumn'\"\n                        class=\"col-sm-7 pr-sm-0\"\n                    >\n                        <foehn-input-date\n                            [id]=\"buildId() + '_date'\"\n                            [name]=\"name + '_date'\"\n                            [(model)]=\"date\"\n                            [disableDay]=\"disableDay\"\n                            [disableMonth]=\"disableMonth\"\n                            [disableYear]=\"disableYear\"\n                            [minDate]=\"minDate\"\n                            [maxDate]=\"maxDate\"\n                            [hideDatePickerButton]=\"hideDatePickerButton\"\n                            (userInput)=\"handleUserInputDate()\"\n                            [disabled]=\"disabled\"\n                            [hideNotRequiredExtraLabel]=\"true\"\n                        ></foehn-input-date>\n                    </div>\n                    <div\n                        [attr.id]=\"buildId() + 'TimeColumn'\"\n                        class=\"col-sm-5 pl-sm-0\"\n                    >\n                        <foehn-input-time\n                            [id]=\"buildId() + '_time'\"\n                            [name]=\"name + '_date'\"\n                            [(model)]=\"time\"\n                            (modelChange)=\"timeModelChange($event)\"\n                            (userInput)=\"handleUserInputTime($event)\"\n                            [disabled]=\"disabled\"\n                            [hideNotRequiredExtraLabel]=\"true\"\n                        ></foehn-input-time>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
@@ -20,11 +20,16 @@ export class FoehnStatusProgressBarComponent {
20
20
  isEnabled() {
21
21
  return this.hidden !== true;
22
22
  }
23
- isStepVerificationActive() {
24
- return (this.isTransmitted ||
23
+ isStep2Active() {
24
+ if (this.isTransmitted ||
25
25
  (this.navigation.initialized &&
26
26
  this.navigation.isLastFormPage() &&
27
- !this.navigation.isFirstFormPage()));
27
+ !this.navigation.isFirstFormPage())) {
28
+ return true;
29
+ }
30
+ const orderedRoutes = this.navigation.orderedRoutes;
31
+ return (!!orderedRoutes &&
32
+ !!orderedRoutes[this.navigation.currentRouteOrder]?.data?.isStep2);
28
33
  }
29
34
  ngOnInit() {
30
35
  this.isTransmittedSub = merge(of(this.gesdemHand.lastResponse?.meta), this.gesdemHand.updateFormDataSubject.pipe(map(() => this.gesdemHand.lastResponse.meta)))
@@ -40,11 +45,11 @@ export class FoehnStatusProgressBarComponent {
40
45
  }
41
46
  }
42
47
  FoehnStatusProgressBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: FoehnStatusProgressBarComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.FoehnNavigationService }, { token: i3.GesdemEventService }, { token: i4.GesdemHandlerService }], target: i0.ɵɵFactoryTarget.Component });
43
- FoehnStatusProgressBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: FoehnStatusProgressBarComponent, selector: "foehn-status-progress-bar", inputs: { hidden: "hidden" }, ngImport: i0, template: "<div *ngIf=\"isEnabled()\">\n <div class=\"container\">\n <div class=\"row justify-content-center\">\n <div class=\"col\">\n <div\n class=\"sr-only\"\n aria-live=\"polite\"\n role=\"status\"\n aria-atomic=\"true\"\n tabindex=\"0\"\n >\n <span *ngIf=\"isTransmitted; else notTransmitted\">\n {{\n 'foehn-status-progress-bar.step3.srOnly'\n | fromDictionary\n }}\n </span>\n <ng-template #notTransmitted>\n <span *ngIf=\"isStepVerificationActive()\">\n {{\n 'foehn-status-progress-bar.step2.srOnly'\n | fromDictionary\n }}\n </span>\n <span *ngIf=\"!isStepVerificationActive()\">\n {{\n 'foehn-status-progress-bar.step1.srOnly'\n | fromDictionary\n }}\n </span>\n </ng-template>\n </div>\n\n <ul id=\"progressbar\" class=\"pl-0 mt-1\" aria-hidden=\"true\">\n <li class=\"active\" id=\"step1\">\n <strong>\n {{\n 'foehn-status-progress-bar.step1'\n | fromDictionary\n }}\n </strong>\n </li>\n <li\n id=\"step2\"\n [ngClass]=\"{\n active: isStepVerificationActive()\n }\"\n >\n <strong>\n {{\n 'foehn-status-progress-bar.step2'\n | fromDictionary\n }}\n </strong>\n </li>\n\n <li id=\"step3\" [ngClass]=\"{ active: isTransmitted }\">\n <strong>\n {{\n 'foehn-status-progress-bar.step3'\n | fromDictionary\n }}\n </strong>\n </li>\n </ul>\n </div>\n </div>\n </div>\n</div>\n", styles: [".col{text-align:center;position:relative}#progressbar{overflow:hidden;color:#d3d3d3}#progressbar .active{color:var(--vd-primary-dark)}#progressbar li{list-style-type:none;font-size:15px;width:33%;float:left;position:relative;font-weight:400}#progressbar #step1:before{content:\"1\"}#progressbar #step2:before{content:\"2\"}#progressbar #step3:before{content:\"3\"}#progressbar li:before{width:50px;height:50px;line-height:45px;display:block;font-size:20px;color:var(--white);background:lightgray;border-radius:50%;margin:0 auto 10px;padding:2px}#progressbar li:after{content:\"\";width:100%;height:2px;background:lightgray;position:absolute;left:0;top:25px;z-index:-1}#progressbar li.active:before,#progressbar li.active:after{background:var(--vd-primary-dark)}\n"], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": i6.SdkDictionaryPipe } });
48
+ FoehnStatusProgressBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: FoehnStatusProgressBarComponent, selector: "foehn-status-progress-bar", inputs: { hidden: "hidden" }, ngImport: i0, template: "<div *ngIf=\"isEnabled()\">\n <div class=\"container\">\n <div class=\"row justify-content-center\">\n <div class=\"col\">\n <div\n class=\"sr-only\"\n aria-live=\"polite\"\n role=\"status\"\n aria-atomic=\"true\"\n tabindex=\"0\"\n >\n <span *ngIf=\"isTransmitted; else notTransmitted\">\n {{\n 'foehn-status-progress-bar.step3.srOnly'\n | fromDictionary\n }}\n </span>\n <ng-template #notTransmitted>\n <span *ngIf=\"isStep2Active()\">\n {{\n 'foehn-status-progress-bar.step2.srOnly'\n | fromDictionary\n }}\n </span>\n <span *ngIf=\"!isStep2Active()\">\n {{\n 'foehn-status-progress-bar.step1.srOnly'\n | fromDictionary\n }}\n </span>\n </ng-template>\n </div>\n\n <ul id=\"progressbar\" class=\"pl-0 mt-1\" aria-hidden=\"true\">\n <li class=\"active\" id=\"step1\">\n <strong>\n {{\n 'foehn-status-progress-bar.step1'\n | fromDictionary\n }}\n </strong>\n </li>\n <li\n id=\"step2\"\n [ngClass]=\"{\n active: isStep2Active()\n }\"\n >\n <strong>\n {{\n 'foehn-status-progress-bar.step2'\n | fromDictionary\n }}\n </strong>\n </li>\n\n <li id=\"step3\" [ngClass]=\"{ active: isTransmitted }\">\n <strong>\n {{\n 'foehn-status-progress-bar.step3'\n | fromDictionary\n }}\n </strong>\n </li>\n </ul>\n </div>\n </div>\n </div>\n</div>\n", styles: [".col{text-align:center;position:relative}#progressbar{overflow:hidden;color:#d3d3d3}#progressbar .active{color:var(--vd-primary-dark)}#progressbar li{list-style-type:none;font-size:15px;width:33%;float:left;position:relative;font-weight:400}#progressbar #step1:before{content:\"1\"}#progressbar #step2:before{content:\"2\"}#progressbar #step3:before{content:\"3\"}#progressbar li:before{width:50px;height:50px;line-height:45px;display:block;font-size:20px;color:var(--white);background:lightgray;border-radius:50%;margin:0 auto 10px;padding:2px}#progressbar li:after{content:\"\";width:100%;height:2px;background:lightgray;position:absolute;left:0;top:25px;z-index:-1}#progressbar li.active:before,#progressbar li.active:after{background:var(--vd-primary-dark)}\n"], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": i6.SdkDictionaryPipe } });
44
49
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: FoehnStatusProgressBarComponent, decorators: [{
45
50
  type: Component,
46
- args: [{ selector: 'foehn-status-progress-bar', template: "<div *ngIf=\"isEnabled()\">\n <div class=\"container\">\n <div class=\"row justify-content-center\">\n <div class=\"col\">\n <div\n class=\"sr-only\"\n aria-live=\"polite\"\n role=\"status\"\n aria-atomic=\"true\"\n tabindex=\"0\"\n >\n <span *ngIf=\"isTransmitted; else notTransmitted\">\n {{\n 'foehn-status-progress-bar.step3.srOnly'\n | fromDictionary\n }}\n </span>\n <ng-template #notTransmitted>\n <span *ngIf=\"isStepVerificationActive()\">\n {{\n 'foehn-status-progress-bar.step2.srOnly'\n | fromDictionary\n }}\n </span>\n <span *ngIf=\"!isStepVerificationActive()\">\n {{\n 'foehn-status-progress-bar.step1.srOnly'\n | fromDictionary\n }}\n </span>\n </ng-template>\n </div>\n\n <ul id=\"progressbar\" class=\"pl-0 mt-1\" aria-hidden=\"true\">\n <li class=\"active\" id=\"step1\">\n <strong>\n {{\n 'foehn-status-progress-bar.step1'\n | fromDictionary\n }}\n </strong>\n </li>\n <li\n id=\"step2\"\n [ngClass]=\"{\n active: isStepVerificationActive()\n }\"\n >\n <strong>\n {{\n 'foehn-status-progress-bar.step2'\n | fromDictionary\n }}\n </strong>\n </li>\n\n <li id=\"step3\" [ngClass]=\"{ active: isTransmitted }\">\n <strong>\n {{\n 'foehn-status-progress-bar.step3'\n | fromDictionary\n }}\n </strong>\n </li>\n </ul>\n </div>\n </div>\n </div>\n</div>\n", styles: [".col{text-align:center;position:relative}#progressbar{overflow:hidden;color:#d3d3d3}#progressbar .active{color:var(--vd-primary-dark)}#progressbar li{list-style-type:none;font-size:15px;width:33%;float:left;position:relative;font-weight:400}#progressbar #step1:before{content:\"1\"}#progressbar #step2:before{content:\"2\"}#progressbar #step3:before{content:\"3\"}#progressbar li:before{width:50px;height:50px;line-height:45px;display:block;font-size:20px;color:var(--white);background:lightgray;border-radius:50%;margin:0 auto 10px;padding:2px}#progressbar li:after{content:\"\";width:100%;height:2px;background:lightgray;position:absolute;left:0;top:25px;z-index:-1}#progressbar li.active:before,#progressbar li.active:after{background:var(--vd-primary-dark)}\n"] }]
51
+ args: [{ selector: 'foehn-status-progress-bar', template: "<div *ngIf=\"isEnabled()\">\n <div class=\"container\">\n <div class=\"row justify-content-center\">\n <div class=\"col\">\n <div\n class=\"sr-only\"\n aria-live=\"polite\"\n role=\"status\"\n aria-atomic=\"true\"\n tabindex=\"0\"\n >\n <span *ngIf=\"isTransmitted; else notTransmitted\">\n {{\n 'foehn-status-progress-bar.step3.srOnly'\n | fromDictionary\n }}\n </span>\n <ng-template #notTransmitted>\n <span *ngIf=\"isStep2Active()\">\n {{\n 'foehn-status-progress-bar.step2.srOnly'\n | fromDictionary\n }}\n </span>\n <span *ngIf=\"!isStep2Active()\">\n {{\n 'foehn-status-progress-bar.step1.srOnly'\n | fromDictionary\n }}\n </span>\n </ng-template>\n </div>\n\n <ul id=\"progressbar\" class=\"pl-0 mt-1\" aria-hidden=\"true\">\n <li class=\"active\" id=\"step1\">\n <strong>\n {{\n 'foehn-status-progress-bar.step1'\n | fromDictionary\n }}\n </strong>\n </li>\n <li\n id=\"step2\"\n [ngClass]=\"{\n active: isStep2Active()\n }\"\n >\n <strong>\n {{\n 'foehn-status-progress-bar.step2'\n | fromDictionary\n }}\n </strong>\n </li>\n\n <li id=\"step3\" [ngClass]=\"{ active: isTransmitted }\">\n <strong>\n {{\n 'foehn-status-progress-bar.step3'\n | fromDictionary\n }}\n </strong>\n </li>\n </ul>\n </div>\n </div>\n </div>\n</div>\n", styles: [".col{text-align:center;position:relative}#progressbar{overflow:hidden;color:#d3d3d3}#progressbar .active{color:var(--vd-primary-dark)}#progressbar li{list-style-type:none;font-size:15px;width:33%;float:left;position:relative;font-weight:400}#progressbar #step1:before{content:\"1\"}#progressbar #step2:before{content:\"2\"}#progressbar #step3:before{content:\"3\"}#progressbar li:before{width:50px;height:50px;line-height:45px;display:block;font-size:20px;color:var(--white);background:lightgray;border-radius:50%;margin:0 auto 10px;padding:2px}#progressbar li:after{content:\"\";width:100%;height:2px;background:lightgray;position:absolute;left:0;top:25px;z-index:-1}#progressbar li.active:before,#progressbar li.active:after{background:var(--vd-primary-dark)}\n"] }]
47
52
  }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.FoehnNavigationService }, { type: i3.GesdemEventService }, { type: i4.GesdemHandlerService }]; }, propDecorators: { hidden: [{
48
53
  type: Input
49
54
  }] } });
50
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-status-progress-bar.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-status-progress-bar/foehn-status-progress-bar.component.ts","../../../../projects/prestations-ng/src/foehn-status-progress-bar/foehn-status-progress-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAIpE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAgB,MAAM,MAAM,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAChF,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;AAQ7C,MAAM,OAAO,+BAA+B;IAOxC,YACc,cAA8B,EAChC,UAAkC,EAClC,kBAAsC,EACtC,UAAgC;QAH9B,mBAAc,GAAd,cAAc,CAAgB;QAChC,eAAU,GAAV,UAAU,CAAwB;QAClC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,eAAU,GAAV,UAAU,CAAsB;QAP5C,kBAAa,GAAG,KAAK,CAAC;IAQnB,CAAC;IAEJ,SAAS;QACL,OAAO,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC;IAChC,CAAC;IAED,wBAAwB;QACpB,OAAO,CACH,IAAI,CAAC,aAAa;YAClB,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW;gBACxB,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE;gBAChC,CAAC,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC,CAC1C,CAAC;IACN,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,gBAAgB,GAAG,KAAK,CACzB,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,IAAI,CAAC,EACtC,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,CACtC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,CAC/C,CACJ;aACI,IAAI,CACD,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EACtB,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,MAAsB,CAAC,CAAC,EACtD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,iBAAiB,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CACnD;aACA,SAAS,CAAC,WAAW,CAAC,EAAE;YACrB,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC;QACrC,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC;SACvC;IACL,CAAC;;6HAhDQ,+BAA+B;iHAA/B,+BAA+B,+FCd5C,mqFAqEA;4FDvDa,+BAA+B;kBAL3C,SAAS;+BACI,2BAA2B;8MAMrC,MAAM;sBADL,KAAK","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';\nimport { ActivatedRoute } from '@angular/router';\nimport { GesdemEventService } from '../gesdem/gesdem-event.service';\nimport { merge, of, Subscription } from 'rxjs';\nimport { ActionStatut, GesdemStatutUtils } from '../gesdem/gesdem-statut-utils';\nimport { filter, map } from 'rxjs/operators';\nimport { GesdemHandlerService } from '../gesdem/gesdem-handler.service';\n\n@Component({\n    selector: 'foehn-status-progress-bar',\n    templateUrl: './foehn-status-progress-bar.component.html',\n    styleUrls: ['./foehn-status-progress-bar.component.css']\n})\nexport class FoehnStatusProgressBarComponent implements OnInit, OnDestroy {\n    @Input()\n    hidden: boolean;\n\n    isTransmitted = false;\n    isTransmittedSub: Subscription;\n\n    constructor(\n        protected activatedRoute: ActivatedRoute,\n        private navigation: FoehnNavigationService,\n        private gesdemEventService: GesdemEventService,\n        private gesdemHand: GesdemHandlerService\n    ) {}\n\n    isEnabled(): boolean {\n        return this.hidden !== true;\n    }\n\n    isStepVerificationActive(): boolean {\n        return (\n            this.isTransmitted ||\n            (this.navigation.initialized &&\n                this.navigation.isLastFormPage() &&\n                !this.navigation.isFirstFormPage())\n        );\n    }\n\n    ngOnInit(): void {\n        this.isTransmittedSub = merge(\n            of(this.gesdemHand.lastResponse?.meta),\n            this.gesdemHand.updateFormDataSubject.pipe(\n                map(() => this.gesdemHand.lastResponse.meta)\n            )\n        )\n            .pipe(\n                filter(meta => !!meta),\n                map(meta => ActionStatut[meta.statut as ActionStatut]),\n                map(statut => GesdemStatutUtils.isFinal(statut))\n            )\n            .subscribe(transmitted => {\n                this.isTransmitted = transmitted;\n            });\n    }\n\n    ngOnDestroy(): void {\n        if (this.isTransmittedSub) {\n            this.isTransmittedSub.unsubscribe();\n        }\n    }\n}\n","<div *ngIf=\"isEnabled()\">\n    <div class=\"container\">\n        <div class=\"row justify-content-center\">\n            <div class=\"col\">\n                <div\n                    class=\"sr-only\"\n                    aria-live=\"polite\"\n                    role=\"status\"\n                    aria-atomic=\"true\"\n                    tabindex=\"0\"\n                >\n                    <span *ngIf=\"isTransmitted; else notTransmitted\">\n                        {{\n                            'foehn-status-progress-bar.step3.srOnly'\n                                | fromDictionary\n                        }}\n                    </span>\n                    <ng-template #notTransmitted>\n                        <span *ngIf=\"isStepVerificationActive()\">\n                            {{\n                                'foehn-status-progress-bar.step2.srOnly'\n                                    | fromDictionary\n                            }}\n                        </span>\n                        <span *ngIf=\"!isStepVerificationActive()\">\n                            {{\n                                'foehn-status-progress-bar.step1.srOnly'\n                                    | fromDictionary\n                            }}\n                        </span>\n                    </ng-template>\n                </div>\n\n                <ul id=\"progressbar\" class=\"pl-0 mt-1\" aria-hidden=\"true\">\n                    <li class=\"active\" id=\"step1\">\n                        <strong>\n                            {{\n                                'foehn-status-progress-bar.step1'\n                                    | fromDictionary\n                            }}\n                        </strong>\n                    </li>\n                    <li\n                        id=\"step2\"\n                        [ngClass]=\"{\n                            active: isStepVerificationActive()\n                        }\"\n                    >\n                        <strong>\n                            {{\n                                'foehn-status-progress-bar.step2'\n                                    | fromDictionary\n                            }}\n                        </strong>\n                    </li>\n\n                    <li id=\"step3\" [ngClass]=\"{ active: isTransmitted }\">\n                        <strong>\n                            {{\n                                'foehn-status-progress-bar.step3'\n                                    | fromDictionary\n                            }}\n                        </strong>\n                    </li>\n                </ul>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
55
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-status-progress-bar.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-status-progress-bar/foehn-status-progress-bar.component.ts","../../../../projects/prestations-ng/src/foehn-status-progress-bar/foehn-status-progress-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAIpE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAgB,MAAM,MAAM,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAChF,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;AAQ7C,MAAM,OAAO,+BAA+B;IAOxC,YACc,cAA8B,EAChC,UAAkC,EAClC,kBAAsC,EACtC,UAAgC;QAH9B,mBAAc,GAAd,cAAc,CAAgB;QAChC,eAAU,GAAV,UAAU,CAAwB;QAClC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,eAAU,GAAV,UAAU,CAAsB;QAP5C,kBAAa,GAAG,KAAK,CAAC;IAQnB,CAAC;IAEJ,SAAS;QACL,OAAO,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC;IAChC,CAAC;IAED,aAAa;QACT,IACI,IAAI,CAAC,aAAa;YAClB,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW;gBACxB,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE;gBAChC,CAAC,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC,EACzC;YACE,OAAO,IAAI,CAAC;SACf;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,OAAO,CACH,CAAC,CAAC,aAAa;YACf,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,EAAE,IAAI,EAAE,OAAO,CACpE,CAAC;IACN,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,gBAAgB,GAAG,KAAK,CACzB,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,IAAI,CAAC,EACtC,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,CACtC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,CAC/C,CACJ;aACI,IAAI,CACD,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EACtB,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,MAAsB,CAAC,CAAC,EACtD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,iBAAiB,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CACnD;aACA,SAAS,CAAC,WAAW,CAAC,EAAE;YACrB,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC;QACrC,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC;SACvC;IACL,CAAC;;6HAxDQ,+BAA+B;iHAA/B,+BAA+B,+FCd5C,koFAqEA;4FDvDa,+BAA+B;kBAL3C,SAAS;+BACI,2BAA2B;8MAMrC,MAAM;sBADL,KAAK","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';\nimport { ActivatedRoute } from '@angular/router';\nimport { GesdemEventService } from '../gesdem/gesdem-event.service';\nimport { merge, of, Subscription } from 'rxjs';\nimport { ActionStatut, GesdemStatutUtils } from '../gesdem/gesdem-statut-utils';\nimport { filter, map } from 'rxjs/operators';\nimport { GesdemHandlerService } from '../gesdem/gesdem-handler.service';\n\n@Component({\n    selector: 'foehn-status-progress-bar',\n    templateUrl: './foehn-status-progress-bar.component.html',\n    styleUrls: ['./foehn-status-progress-bar.component.css']\n})\nexport class FoehnStatusProgressBarComponent implements OnInit, OnDestroy {\n    @Input()\n    hidden: boolean;\n\n    isTransmitted = false;\n    isTransmittedSub: Subscription;\n\n    constructor(\n        protected activatedRoute: ActivatedRoute,\n        private navigation: FoehnNavigationService,\n        private gesdemEventService: GesdemEventService,\n        private gesdemHand: GesdemHandlerService\n    ) {}\n\n    isEnabled(): boolean {\n        return this.hidden !== true;\n    }\n\n    isStep2Active(): boolean {\n        if (\n            this.isTransmitted ||\n            (this.navigation.initialized &&\n                this.navigation.isLastFormPage() &&\n                !this.navigation.isFirstFormPage())\n        ) {\n            return true;\n        }\n\n        const orderedRoutes = this.navigation.orderedRoutes;\n        return (\n            !!orderedRoutes &&\n            !!orderedRoutes[this.navigation.currentRouteOrder]?.data?.isStep2\n        );\n    }\n\n    ngOnInit(): void {\n        this.isTransmittedSub = merge(\n            of(this.gesdemHand.lastResponse?.meta),\n            this.gesdemHand.updateFormDataSubject.pipe(\n                map(() => this.gesdemHand.lastResponse.meta)\n            )\n        )\n            .pipe(\n                filter(meta => !!meta),\n                map(meta => ActionStatut[meta.statut as ActionStatut]),\n                map(statut => GesdemStatutUtils.isFinal(statut))\n            )\n            .subscribe(transmitted => {\n                this.isTransmitted = transmitted;\n            });\n    }\n\n    ngOnDestroy(): void {\n        if (this.isTransmittedSub) {\n            this.isTransmittedSub.unsubscribe();\n        }\n    }\n}\n","<div *ngIf=\"isEnabled()\">\n    <div class=\"container\">\n        <div class=\"row justify-content-center\">\n            <div class=\"col\">\n                <div\n                    class=\"sr-only\"\n                    aria-live=\"polite\"\n                    role=\"status\"\n                    aria-atomic=\"true\"\n                    tabindex=\"0\"\n                >\n                    <span *ngIf=\"isTransmitted; else notTransmitted\">\n                        {{\n                            'foehn-status-progress-bar.step3.srOnly'\n                                | fromDictionary\n                        }}\n                    </span>\n                    <ng-template #notTransmitted>\n                        <span *ngIf=\"isStep2Active()\">\n                            {{\n                                'foehn-status-progress-bar.step2.srOnly'\n                                    | fromDictionary\n                            }}\n                        </span>\n                        <span *ngIf=\"!isStep2Active()\">\n                            {{\n                                'foehn-status-progress-bar.step1.srOnly'\n                                    | fromDictionary\n                            }}\n                        </span>\n                    </ng-template>\n                </div>\n\n                <ul id=\"progressbar\" class=\"pl-0 mt-1\" aria-hidden=\"true\">\n                    <li class=\"active\" id=\"step1\">\n                        <strong>\n                            {{\n                                'foehn-status-progress-bar.step1'\n                                    | fromDictionary\n                            }}\n                        </strong>\n                    </li>\n                    <li\n                        id=\"step2\"\n                        [ngClass]=\"{\n                            active: isStep2Active()\n                        }\"\n                    >\n                        <strong>\n                            {{\n                                'foehn-status-progress-bar.step2'\n                                    | fromDictionary\n                            }}\n                        </strong>\n                    </li>\n\n                    <li id=\"step3\" [ngClass]=\"{ active: isTransmitted }\">\n                        <strong>\n                            {{\n                                'foehn-status-progress-bar.step3'\n                                    | fromDictionary\n                            }}\n                        </strong>\n                    </li>\n                </ul>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
@@ -1,5 +1,5 @@
1
1
  import { Injectable } from '@angular/core';
2
- import { catchError, map, tap } from 'rxjs/operators';
2
+ import { catchError, filter, map, tap } from 'rxjs/operators';
3
3
  import { throwError } from 'rxjs';
4
4
  import { GrowlType } from '../../foehn-growl/growl-types';
5
5
  import { UploaderHelper } from '../uploader.helper';
@@ -8,12 +8,14 @@ import * as i1 from "@angular/common/http";
8
8
  import * as i2 from "../../foehn-growl/growl-broker.service";
9
9
  import * as i3 from "../../sdk-appinfo/application-info.service";
10
10
  import * as i4 from "../../sdk-dictionary/sdk-dictionary.service";
11
+ import * as i5 from "../foehn-upload-progress-bar/upload-progress.service";
11
12
  export class BoMultiUploadService {
12
- constructor(httpClient, growlService, applicationInfoService, dictionaryService) {
13
+ constructor(httpClient, growlService, applicationInfoService, dictionaryService, uploadProgressService) {
13
14
  this.httpClient = httpClient;
14
15
  this.growlService = growlService;
15
16
  this.applicationInfoService = applicationInfoService;
16
17
  this.dictionaryService = dictionaryService;
18
+ this.uploadProgressService = uploadProgressService;
17
19
  // A way to have a unique Id per file
18
20
  this.globalSequence = 0;
19
21
  this.uniqPrefix = new Date().getTime();
@@ -22,7 +24,13 @@ export class BoMultiUploadService {
22
24
  uploadDocuments(url, formKey, label, files, key, isMultiple, language, shouldDisplayFileSavedConfirmation) {
23
25
  const documents = files.map(file => this.uploaderHelper.mapToDocumentReference(file, label, key, isMultiple, this.uniqPrefix, this.globalSequence++));
24
26
  const formData = this.uploaderHelper.mapToFormData(documents, formKey, language);
25
- return this.httpClient.post(url, formData).pipe(tap(result => {
27
+ return this.httpClient
28
+ .post(url, formData, {
29
+ reportProgress: true,
30
+ observe: 'events',
31
+ responseType: 'json'
32
+ })
33
+ .pipe(filter((e) => this.uploadProgressService.manageUploadEventFilter(e)), map((e) => e.body), tap(result => {
26
34
  const successfulDocumentsCount = result.documents && result.documents.length;
27
35
  if (successfulDocumentsCount &&
28
36
  shouldDisplayFileSavedConfirmation) {
@@ -52,12 +60,12 @@ export class BoMultiUploadService {
52
60
  return `${baseUrl}/${document.reference}`;
53
61
  }
54
62
  }
55
- BoMultiUploadService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BoMultiUploadService, deps: [{ token: i1.HttpClient }, { token: i2.GrowlBrokerService }, { token: i3.ApplicationInfoService }, { token: i4.SdkDictionaryService }], target: i0.ɵɵFactoryTarget.Injectable });
63
+ BoMultiUploadService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BoMultiUploadService, deps: [{ token: i1.HttpClient }, { token: i2.GrowlBrokerService }, { token: i3.ApplicationInfoService }, { token: i4.SdkDictionaryService }, { token: i5.UploadProgressService }], target: i0.ɵɵFactoryTarget.Injectable });
56
64
  BoMultiUploadService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BoMultiUploadService, providedIn: 'root' });
57
65
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BoMultiUploadService, decorators: [{
58
66
  type: Injectable,
59
67
  args: [{
60
68
  providedIn: 'root'
61
69
  }]
62
- }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.GrowlBrokerService }, { type: i3.ApplicationInfoService }, { type: i4.SdkDictionaryService }]; } });
63
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bo-multi-upload.service.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/foehn-upload/foehn-bo-multi-upload/bo-multi-upload.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAc,UAAU,EAAE,MAAM,MAAM,CAAC;AAE9C,OAAO,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAC;AAK1D,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;;;;;;AAKpD,MAAM,OAAO,oBAAoB;IAM7B,YACY,UAAsB,EACtB,YAAgC,EAChC,sBAA8C,EAC9C,iBAAuC;QAHvC,eAAU,GAAV,UAAU,CAAY;QACtB,iBAAY,GAAZ,YAAY,CAAoB;QAChC,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,sBAAiB,GAAjB,iBAAiB,CAAsB;QATnD,qCAAqC;QAC7B,mBAAc,GAAG,CAAC,CAAC;QACnB,eAAU,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;QAStC,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CACpC,iBAAiB,EACjB,sBAAsB,CACzB,CAAC;IACN,CAAC;IAED,eAAe,CACX,GAAW,EACX,OAAe,EACf,KAAa,EACb,KAAa,EACb,GAAW,EACX,UAAmB,EACnB,QAAgB,EAChB,kCAA2C;QAE3C,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAC/B,IAAI,CAAC,cAAc,CAAC,sBAAsB,CACtC,IAAI,EACJ,KAAK,EACL,GAAG,EACH,UAAU,EACV,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,cAAc,EAAE,CACxB,CACJ,CAAC;QACF,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAC9C,SAAS,EACT,OAAO,EACP,QAAQ,CACX,CAAC;QACF,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAwB,GAAG,EAAE,QAAQ,CAAC,CAAC,IAAI,CAClE,GAAG,CAAC,MAAM,CAAC,EAAE;YACT,MAAM,wBAAwB,GAC1B,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC;YAChD,IACI,wBAAwB;gBACxB,kCAAkC,EACpC;gBACE,MAAM,OAAO,GAAG,GAAG,wBAAwB,uCAAuC,CAAC;gBACnF,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;aAC7D;QACL,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,CAAU,EAAE,EAAE;YACtB,MAAM,OAAO,GACT,kEAAkE,CAAC;YACvE,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;YACzD,OAAO,UAAU,CAAC,CAAC,CAAC,CAAC;QACzB,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED,cAAc,CACV,OAAe,EACf,QAA2B;QAE3B,MAAM,GAAG,GAAG,GAAG,OAAO,IAAI,QAAQ,CAAC,SAAS,EAAE,CAAC;QAE/C,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI;QACnC,6EAA6E;QAC7E,GAAG,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EACnB,GAAG,CAAC,GAAG,EAAE;YACL,MAAM,OAAO,GAAG,0BAA0B,QAAQ,CAAC,QAAQ,UAAU,CAAC;YACtE,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAC9D,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,CAAU,EAAE,EAAE;YACtB,MAAM,OAAO,GACT,kEAAkE,CAAC;YACvE,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;YACzD,OAAO,UAAU,CAAC,CAAC,CAAC,CAAC;QACzB,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED,cAAc,CAAC,OAAe,EAAE,QAA2B;QACvD,OAAO,GAAG,OAAO,IAAI,QAAQ,CAAC,SAAS,EAAE,CAAC;IAC9C,CAAC;;kHAxFQ,oBAAoB;sHAApB,oBAAoB,cAFjB,MAAM;4FAET,oBAAoB;kBAHhC,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { catchError, map, tap } from 'rxjs/operators';\nimport { Observable, throwError } from 'rxjs';\nimport { BoDocumentsWithErrors } from './bo-multi-upload.type';\nimport { GrowlType } from '../../foehn-growl/growl-types';\nimport { GrowlBrokerService } from '../../foehn-growl/growl-broker.service';\nimport { DocumentReference } from '../document-reference';\nimport { ApplicationInfoService } from '../../sdk-appinfo/application-info.service';\nimport { SdkDictionaryService } from '../../sdk-dictionary/sdk-dictionary.service';\nimport { UploaderHelper } from '../uploader.helper';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class BoMultiUploadService {\n    // A way to have a unique Id per file\n    private globalSequence = 0;\n    private uniqPrefix = new Date().getTime();\n    private uploaderHelper: UploaderHelper;\n\n    constructor(\n        private httpClient: HttpClient,\n        private growlService: GrowlBrokerService,\n        private applicationInfoService: ApplicationInfoService,\n        private dictionaryService: SdkDictionaryService\n    ) {\n        this.uploaderHelper = new UploaderHelper(\n            dictionaryService,\n            applicationInfoService\n        );\n    }\n\n    uploadDocuments(\n        url: string,\n        formKey: string,\n        label: string,\n        files: File[],\n        key: string,\n        isMultiple: boolean,\n        language: string,\n        shouldDisplayFileSavedConfirmation: boolean\n    ): Observable<BoDocumentsWithErrors> {\n        const documents = files.map(file =>\n            this.uploaderHelper.mapToDocumentReference(\n                file,\n                label,\n                key,\n                isMultiple,\n                this.uniqPrefix,\n                this.globalSequence++\n            )\n        );\n        const formData = this.uploaderHelper.mapToFormData(\n            documents,\n            formKey,\n            language\n        );\n        return this.httpClient.post<BoDocumentsWithErrors>(url, formData).pipe(\n            tap(result => {\n                const successfulDocumentsCount =\n                    result.documents && result.documents.length;\n                if (\n                    successfulDocumentsCount &&\n                    shouldDisplayFileSavedConfirmation\n                ) {\n                    const message = `${successfulDocumentsCount} fichier(s) sauvegardé(s) avec succès`;\n                    this.growlService.addWithType(GrowlType.SUCCESS, message);\n                }\n            }),\n            catchError((e: unknown) => {\n                const message =\n                    'Une erreur est survenue lors de la transmission de vos documents';\n                this.growlService.addWithType(GrowlType.DANGER, message);\n                return throwError(e);\n            })\n        );\n    }\n\n    deleteDocument(\n        baseUrl: string,\n        document: DocumentReference\n    ): Observable<DocumentReference> {\n        const url = `${baseUrl}/${document.reference}`;\n\n        return this.httpClient.delete(url).pipe(\n            // Reflect the document once the update is done to ease chaining observables.\n            map(() => document),\n            tap(() => {\n                const message = `Suppression du fichier ${document.filename} réussie`;\n                this.growlService.addWithType(GrowlType.SUCCESS, message);\n            }),\n            catchError((e: unknown) => {\n                const message =\n                    'Une erreur est survenue lors de la suppression de votre document';\n                this.growlService.addWithType(GrowlType.DANGER, message);\n                return throwError(e);\n            })\n        );\n    }\n\n    getDownloadUrl(baseUrl: string, document: DocumentReference): string {\n        return `${baseUrl}/${document.reference}`;\n    }\n}\n"]}
70
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.GrowlBrokerService }, { type: i3.ApplicationInfoService }, { type: i4.SdkDictionaryService }, { type: i5.UploadProgressService }]; } });
71
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bo-multi-upload.service.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/foehn-upload/foehn-bo-multi-upload/bo-multi-upload.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient, HttpEvent, HttpResponse } from '@angular/common/http';\nimport { catchError, filter, map, tap } from 'rxjs/operators';\nimport { Observable, throwError } from 'rxjs';\nimport { BoDocumentsWithErrors } from './bo-multi-upload.type';\nimport { GrowlType } from '../../foehn-growl/growl-types';\nimport { GrowlBrokerService } from '../../foehn-growl/growl-broker.service';\nimport { DocumentReference } from '../document-reference';\nimport { ApplicationInfoService } from '../../sdk-appinfo/application-info.service';\nimport { SdkDictionaryService } from '../../sdk-dictionary/sdk-dictionary.service';\nimport { UploaderHelper } from '../uploader.helper';\nimport { UploadProgressService } from '../foehn-upload-progress-bar/upload-progress.service';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class BoMultiUploadService {\n    // A way to have a unique Id per file\n    private globalSequence = 0;\n    private uniqPrefix = new Date().getTime();\n    private uploaderHelper: UploaderHelper;\n\n    constructor(\n        private httpClient: HttpClient,\n        private growlService: GrowlBrokerService,\n        private applicationInfoService: ApplicationInfoService,\n        private dictionaryService: SdkDictionaryService,\n        private uploadProgressService: UploadProgressService\n    ) {\n        this.uploaderHelper = new UploaderHelper(\n            dictionaryService,\n            applicationInfoService\n        );\n    }\n\n    uploadDocuments(\n        url: string,\n        formKey: string,\n        label: string,\n        files: File[],\n        key: string,\n        isMultiple: boolean,\n        language: string,\n        shouldDisplayFileSavedConfirmation: boolean\n    ): Observable<BoDocumentsWithErrors> {\n        const documents = files.map(file =>\n            this.uploaderHelper.mapToDocumentReference(\n                file,\n                label,\n                key,\n                isMultiple,\n                this.uniqPrefix,\n                this.globalSequence++\n            )\n        );\n        const formData = this.uploaderHelper.mapToFormData(\n            documents,\n            formKey,\n            language\n        );\n        return this.httpClient\n            .post<BoDocumentsWithErrors>(url, formData, {\n                reportProgress: true,\n                observe: 'events',\n                responseType: 'json'\n            })\n            .pipe(\n                filter((e: HttpEvent<BoDocumentsWithErrors>) =>\n                    this.uploadProgressService.manageUploadEventFilter(e)\n                ),\n                map(\n                    (e: HttpEvent<BoDocumentsWithErrors>) =>\n                        (e as HttpResponse<BoDocumentsWithErrors>).body\n                ),\n                tap(result => {\n                    const successfulDocumentsCount =\n                        result.documents && result.documents.length;\n                    if (\n                        successfulDocumentsCount &&\n                        shouldDisplayFileSavedConfirmation\n                    ) {\n                        const message = `${successfulDocumentsCount} fichier(s) sauvegardé(s) avec succès`;\n                        this.growlService.addWithType(\n                            GrowlType.SUCCESS,\n                            message\n                        );\n                    }\n                }),\n                catchError((e: unknown) => {\n                    const message =\n                        'Une erreur est survenue lors de la transmission de vos documents';\n                    this.growlService.addWithType(GrowlType.DANGER, message);\n                    return throwError(e);\n                })\n            );\n    }\n\n    deleteDocument(\n        baseUrl: string,\n        document: DocumentReference\n    ): Observable<DocumentReference> {\n        const url = `${baseUrl}/${document.reference}`;\n\n        return this.httpClient.delete(url).pipe(\n            // Reflect the document once the update is done to ease chaining observables.\n            map(() => document),\n            tap(() => {\n                const message = `Suppression du fichier ${document.filename} réussie`;\n                this.growlService.addWithType(GrowlType.SUCCESS, message);\n            }),\n            catchError((e: unknown) => {\n                const message =\n                    'Une erreur est survenue lors de la suppression de votre document';\n                this.growlService.addWithType(GrowlType.DANGER, message);\n                return throwError(e);\n            })\n        );\n    }\n\n    getDownloadUrl(baseUrl: string, document: DocumentReference): string {\n        return `${baseUrl}/${document.reference}`;\n    }\n}\n"]}